2018-08-13 10:34:00 +00:00
'use strict' ;
var me = { } ;
var phraseBox = { } ;
var tmplInits = { } ;
var tmplPhrases = [ ] ; // [key] array of phrases indexed by order of use
var hooks = {
"pre_iffe" : [ ] ,
"pre_init" : [ ] ,
"start_init" : [ ] ,
"end_init" : [ ] ,
2018-11-30 03:02:20 +00:00
"after_phrases" : [ ] ,
2018-09-20 10:45:33 +00:00
"after_add_alert" : [ ] ,
"after_update_alert_list" : [ ] ,
2018-12-27 05:42:41 +00:00
"open_edit" : [ ] ,
"close_edit" : [ ] ,
2018-08-13 10:34:00 +00:00
} ;
var ranInitHooks = { }
function runHook ( name , ... args ) {
if ( ! ( name in hooks ) ) {
console . log ( "Couldn't find hook '" + name + "'" ) ;
return ;
}
console . log ( "Running hook '" + name + "'" ) ;
let hook = hooks [ name ] ;
for ( const index in hook ) {
hook [ index ] ( ... args ) ;
}
}
function addHook ( name , callback ) {
hooks [ name ] . push ( callback ) ;
}
// InitHooks are slightly special, as if they are run, then any adds after the initial run will run immediately, this is to deal with the async nature of script loads
2018-11-30 03:02:20 +00:00
function runInitHook ( name , ... args ) {
runHook ( name , ... args ) ;
2018-08-13 10:34:00 +00:00
ranInitHooks [ name ] = true ;
}
function addInitHook ( name , callback ) {
addHook ( name , callback ) ;
if ( name in ranInitHooks ) {
callback ( ) ;
}
}
// Temporary hack for templates
function len ( item ) {
return item . length ;
}
const asyncGetScript = ( source ) => {
return new Promise ( ( resolve , reject ) => {
let script = document . createElement ( 'script' ) ;
script . async = true ;
const onloadHander = ( haha , isAbort ) => {
if ( isAbort || ! script . readyState || /loaded|complete/ . test ( script . readyState ) ) {
script . onload = null ;
script . onreadystatechange = null ;
script = undefined ;
isAbort ? reject ( haha ) : resolve ( ) ;
}
}
script . onerror = ( haha ) => {
reject ( haha ) ;
} ;
script . onload = onloadHander ;
script . onreadystatechange = onloadHander ;
script . src = source ;
const prior = document . getElementsByTagName ( 'script' ) [ 0 ] ;
prior . parentNode . insertBefore ( script , prior ) ;
} ) ;
} ;
function loadScript ( name , callback ) {
let url = "/static/" + name
asyncGetScript ( url )
. then ( callback )
. catch ( ( haha ) => {
console . log ( "Unable to get script '" + url + "'" ) ;
console . log ( "haha: " , haha ) ;
console . trace ( ) ;
} ) ;
}
2019-02-10 05:52:26 +00:00
/ *
function loadTmpl ( name , callback ) {
let url = "/static/" + name
let worker = new Worker ( url ) ;
}
* /
2018-08-13 10:34:00 +00:00
function DoNothingButPassBack ( item ) {
return item ;
}
2019-02-10 05:52:26 +00:00
function RelativeTime ( date ) {
return date ;
}
2019-01-21 12:27:59 +00:00
function initPhrases ( ) {
2019-02-10 05:52:26 +00:00
fetchPhrases ( "status,topic_list,alerts,paginator" )
2019-01-21 12:27:59 +00:00
}
function fetchPhrases ( plist ) {
fetch ( "/api/phrases/?query=" + plist )
2018-08-13 10:34:00 +00:00
. then ( ( resp ) => resp . json ( ) )
. then ( ( data ) => {
console . log ( "loaded phrase endpoint data" ) ;
console . log ( "data:" , data ) ;
Object . keys ( tmplInits ) . forEach ( ( key ) => {
let phrases = [ ] ;
let tmplInit = tmplInits [ key ] ;
2019-01-21 12:27:59 +00:00
for ( let phraseName of tmplInit ) phrases . push ( data [ phraseName ] ) ;
2018-08-13 10:34:00 +00:00
console . log ( "Adding phrases" ) ;
console . log ( "key:" , key ) ;
console . log ( "phrases:" , phrases ) ;
tmplPhrases [ key ] = phrases ;
} ) ;
let prefixes = { } ;
Object . keys ( data ) . forEach ( ( key ) => {
let prefix = key . split ( "." ) [ 0 ] ;
2019-01-21 12:27:59 +00:00
if ( prefixes [ prefix ] === undefined ) prefixes [ prefix ] = { } ;
2018-08-13 10:34:00 +00:00
prefixes [ prefix ] [ key ] = data [ key ] ;
} ) ;
Object . keys ( prefixes ) . forEach ( ( prefix ) => {
console . log ( "adding phrase prefix '" + prefix + "' to box" ) ;
phraseBox [ prefix ] = prefixes [ prefix ] ;
} ) ;
2018-11-30 03:02:20 +00:00
runInitHook ( "after_phrases" ) ;
2018-08-13 10:34:00 +00:00
} ) ;
}
( ( ) => {
runInitHook ( "pre_iife" ) ;
2019-02-10 05:52:26 +00:00
let toLoad = 2 ;
// TODO: Shunt this into loggedIn if there aren't any search and filter widgets?
loadScript ( "template_topics_topic.js" , ( ) => {
console . log ( "Loaded template_topics_topic.js" ) ;
toLoad -- ;
if ( toLoad === 0 ) initPhrases ( ) ;
} ) ;
loadScript ( "template_paginator.js" , ( ) => {
console . log ( "Loaded template_paginator.js" ) ;
toLoad -- ;
if ( toLoad === 0 ) initPhrases ( ) ;
} ) ;
2018-08-13 10:34:00 +00:00
let loggedIn = document . head . querySelector ( "[property='x-loggedin']" ) . content ;
2018-12-27 05:42:41 +00:00
if ( loggedIn == "true" ) {
2018-08-13 12:01:27 +00:00
fetch ( "/api/me/" )
2018-08-13 10:34:00 +00:00
. then ( ( resp ) => resp . json ( ) )
. then ( ( data ) => {
console . log ( "loaded me endpoint data" ) ;
console . log ( "data:" , data ) ;
me = data ;
runInitHook ( "pre_init" ) ;
} ) ;
2018-08-13 12:01:27 +00:00
} else {
me = { User : { ID : 0 , Session : "" } , Site : { "MaxRequestSize" : 0 } } ;
runInitHook ( "pre_init" ) ;
2018-08-13 10:34:00 +00:00
}
} ) ( ) ;