Move defaultMkwsConfig out of auto-executer.
[mkws-moved-to-github.git] / src / mkws-core.js
index 233a77f..cc8c63f 100644 (file)
@@ -102,21 +102,63 @@ mkws.log = function(string) {
 };
 
 
+mkws.registerWidgetType = function(name, fn) {
+    mkws.widgetType2function[name] = fn;
+    mkws.log("registered widget-type '" + name + "'");
+};
 
-// wrapper to call team() after page load
-(function(j) {
-    var log = mkws.log;
+mkws.promotionFunction = function(name) {
+    return mkws.widgetType2function[name];
+};
 
-    mkws.registerWidgetType = function(name, fn) {
-       mkws.widgetType2function[name] = fn;
-       log("registered widget-type '" + name + "'");
+
+mkws.defaultMkwsConfig = function() {
+    /* default mkws config */
+    var config_default = {
+       use_service_proxy: true,
+       pazpar2_url: "//mkws.indexdata.com/service-proxy/",
+       service_proxy_auth: "//mkws.indexdata.com/service-proxy-auth",
+       lang: "",
+       sort_options: [["relevance"], ["title:1", "title"], ["date:0", "newest"], ["date:1", "oldest"]],
+       perpage_options: [10, 20, 30, 50],
+       sort_default: "relevance",
+       perpage_default: 20,
+       query_width: 50,
+       show_lang: true,        /* show/hide language menu */
+       show_sort: true,        /* show/hide sort menu */
+       show_perpage: true,     /* show/hide perpage menu */
+       lang_options: [],       /* display languages links for given languages, [] for all */
+       facets: ["xtargets", "subject", "author"], /* display facets, in this order, [] for none */
+       responsive_design_width: undefined, /* a page with less pixel width considered as narrow */
+       log_level: 1,     /* log level for development: 0..2 */
+
+       dummy: "dummy"
+    };
+
+    // Set global log_level flag early so that log() works
+    // Fall back to old "debug_level" setting for backwards compatibility
+    var tmp = mkws_config.log_level;
+    if (typeof(tmp) === 'undefined') tmp = mkws_config.debug_level;
+
+    if (typeof(tmp) !== 'undefined') {
+       mkws.log_level = tmp;
+    } else if (typeof(config_default.log_level) !== 'undefined') {
+       mkws.log_level = config_default.log_level;
     }
 
-    mkws.promotionFunction = function(name) {
-       return mkws.widgetType2function[name];
+    /* override standard config values by function parameters */
+    for (var k in config_default) {
+       if (typeof mkws_config[k] === 'undefined')
+           mkws_config[k] = config_default[k];
+       //log("Set config: " + k + ' => ' + mkws_config[k]);
     }
+};
 
 
+// wrapper to call team() after page load
+(function(j) {
+    var log = mkws.log;
+
     function handleNodeWithTeam(node, callback) {
        // First branch for DOM objects; second branch for jQuery objects
        var classes = node.className || node.attr('class');
@@ -125,7 +167,7 @@ mkws.log = function(string) {
            // undefined, we don't get an error message, but this
            // function and its callers, up several stack level,
            // silently return. What a crock.
-           mkws.log("handleNodeWithTeam() called on node with no classes");
+           log("handleNodeWithTeam() called on node with no classes");
            return;
        }
        var list = classes.split(/\s+/)
@@ -181,88 +223,39 @@ mkws.log = function(string) {
     // this module.
     mkws.switchView = function(tname, view) {
        mkws.teams[tname].switchView(view);
-    }
+    };
 
     mkws.showDetails = function(tname, prefixRecId) {
        mkws.teams[tname].showDetails(prefixRecId);
-    }
+    };
 
     mkws.limitTarget  = function(tname, id, name) {
        mkws.teams[tname].limitTarget(id, name);
-    }
+    };
 
     mkws.limitQuery  = function(tname, field, value) {
        mkws.teams[tname].limitQuery(field, value);
-    }
+    };
 
     mkws.delimitTarget = function(tname, id) {
        mkws.teams[tname].delimitTarget(id);
-    }
+    };
 
     mkws.delimitQuery = function(tname, field, value) {
        mkws.teams[tname].delimitQuery(field, value);
-    }
+    };
 
     mkws.showPage = function(tname, pageNum) {
        mkws.teams[tname].showPage(pageNum);
-    }
+    };
 
     mkws.pagerPrev = function(tname) {
        mkws.teams[tname].pagerPrev();
-    }
+    };
 
     mkws.pagerNext = function(tname) {
        mkws.teams[tname].pagerNext();
-    }
-
-
-    function defaultMkwsConfig() {
-       /* default mkws config */
-       var config_default = {
-           use_service_proxy: true,
-           pazpar2_url: "//mkws.indexdata.com/service-proxy/",
-           service_proxy_auth: "//mkws.indexdata.com/service-proxy-auth",
-           lang: "",
-           sort_options: [["relevance"], ["title:1", "title"], ["date:0", "newest"], ["date:1", "oldest"]],
-           perpage_options: [10, 20, 30, 50],
-           sort_default: "relevance",
-           perpage_default: 20,
-           query_width: 50,
-           show_lang: true,    /* show/hide language menu */
-           show_sort: true,    /* show/hide sort menu */
-           show_perpage: true,         /* show/hide perpage menu */
-           lang_options: [],   /* display languages links for given languages, [] for all */
-           facets: ["xtargets", "subject", "author"], /* display facets, in this order, [] for none */
-           responsive_design_width: undefined, /* a page with less pixel width considered as narrow */
-           log_level: 1,     /* log level for development: 0..2 */
-
-           dummy: "dummy"
-       };
-
-       // Set global log_level flag early so that log() works
-       // Fall back to old "debug_level" setting for backwards compatibility
-       var tmp = mkws_config.log_level;
-       if (typeof(tmp) === 'undefined') tmp = mkws_config.debug_level;
-
-       if (typeof(tmp) !== 'undefined') {
-           mkws.log_level = tmp;
-       } else if (typeof(config_default.log_level) !== 'undefined') {
-           mkws.log_level = config_default.log_level;
-       }
-
-       // make sure the mkws_config is a valid hash
-       if (!$.isPlainObject(mkws_config)) {
-           log("ERROR: mkws_config is not an JS object, ignore it....");
-           mkws_config = {};
-       }
-
-       /* override standard config values by function parameters */
-       for (var k in config_default) {
-           if (typeof mkws_config[k] === 'undefined')
-               mkws_config[k] = config_default[k];
-           //log("Set config: " + k + ' => ' + mkws_config[k]);
-       }
-    }
+    };
 
 
     /*
@@ -316,7 +309,7 @@ mkws.log = function(string) {
 
 
     $(document).ready(function() {
-       defaultMkwsConfig();
+       mkws.defaultMkwsConfig();
 
        if (mkws_config.query_width < 5 || mkws_config.query_width > 150) {
            log("Reset query width: " + mkws_config.query_width);