X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=tools%2Fhtdocs%2Fmkws.js;h=144d2de477c896580095d8fafead11c8fa481a69;hb=9c7195162561ca11d57775a6fd5ef42f82cde3f4;hp=9a9c682cb4afc13466b75f0a227f88e5e9fa0833;hpb=557fca6b65b234ed0df652e5ae434df1def6519b;p=mkws-moved-to-github.git
diff --git a/tools/htdocs/mkws.js b/tools/htdocs/mkws.js
index 9a9c682..144d2de 100644
--- a/tools/htdocs/mkws.js
+++ b/tools/htdocs/mkws.js
@@ -3,6 +3,15 @@
"use strict"; // HTML5: disable for debug >= 2
+// Set up namespace and some state.
+var mkws = {};
+
+if (!mkws_config)
+ var mkws_config = {}; // for the guys who forgot to define mkws_config...
+
+// Wrapper for jQuery
+(function ($) {
+
/*
* global config object: mkws_config
*
@@ -10,23 +19,16 @@
* including this JS file
*/
-if (!mkws_config)
- var mkws_config = {}; // for the guys who forgot to define mkws_config...
-
if (typeof mkws_config.use_service_proxy === 'undefined')
mkws_config.use_service_proxy = true;
-// global debug flag
-var mkws_debug;
-
var pazpar2_url = mkws_config.pazpar2_url ? mkws_config.pazpar2_url : "/pazpar2/search.pz2";
var service_proxy_url = mkws_config.service_proxy_url ? mkws_config.service_proxy_url : "http://mkws.indexdata.com/service-proxy/";
-var pazpar2path = mkws_config.use_service_proxy ? service_proxy_url : pazpar2_url;
-var usesessions = mkws_config.use_service_proxy ? false : true;
-
+mkws.pazpar2path = mkws_config.use_service_proxy ? service_proxy_url : pazpar2_url;
+mkws.usesessions = mkws_config.use_service_proxy ? false : true;
-var mkws_locale_lang = {
+mkws.locale_lang = {
"de": {
"Authors": "Autoren",
"Subjects": "Schlagwörter",
@@ -76,13 +78,30 @@ var mkws_locale_lang = {
}
};
+mkws.debug = function (string) {
+ if (!mkws.debug)
+ return;
+
+ if (typeof console === "undefined" || typeof console.log === "undefined") { /* ARGH!!! old IE */
+ return;
+ }
+
+ // you need to disable use strict at the top of the file!!!
+ if (mkws.debug >= 3) {
+ console.log(arguments.callee.caller);
+ } else if (mkws.debug >= 2) {
+ console.log(">>> called from function " + arguments.callee.caller.name + ' <<<');
+ }
+ console.log(string);
+}
+var debug = mkws.debug; // local alias
for (var key in mkws_config) {
if (mkws_config.hasOwnProperty(key)) {
if (key.match(/^language_/)) {
var lang = key.replace(/^language_/, "");
// Copy custom languages into list
- mkws_locale_lang[lang] = mkws_config[key];
+ mkws.locale_lang[lang] = mkws_config[key];
}
}
}
@@ -93,15 +112,18 @@ for (var key in mkws_config) {
// autoInit is set to true on default
var my_paz = new pz2( { "onshow": my_onshow,
"showtime": 500, //each timer (show, stat, term, bytarget) can be specified this way
- "pazpar2path": pazpar2path,
+ "pazpar2path": mkws.pazpar2path,
"oninit": my_oninit,
"onstat": my_onstat,
"onterm": my_onterm,
"termlist": "xtargets,subject,author",
"onbytarget": my_onbytarget,
- "usesessions" : usesessions,
+ "usesessions" : mkws.usesessions,
"showResponseType": '', // or "json" (for debugging?)
"onrecord": my_onrecord } );
+
+mkws.my_paz = my_paz; // export
+
// some state vars
var curPage = 1;
var recPerPage = 20;
@@ -142,7 +164,7 @@ function my_onshow(data) {
html.push('
'
+'
'+ (i + 1 + recPerPage * (curPage - 1)) +'. '
+'
'
+ +'" onclick="mkws.showDetails(this.id);return false;">'
+ hit["md-title"] +' ');
if (hit["md-title-remainder"] !== undefined) {
html.push('
' + hit["md-title-remainder"] + ' ');
@@ -210,9 +232,9 @@ function add_single_facet(acc, caption, data, max, cclIndex) {
if (!cclIndex) {
// Special case: target selection
acc.push('target_id='+data[i].id+' ');
- action = 'limitTarget(this.getAttribute(\'target_id\'),this.firstChild.nodeValue)';
+ action = 'mkws.limitTarget(this.getAttribute(\'target_id\'),this.firstChild.nodeValue)';
} else {
- action = 'limitQuery(\'' + cclIndex + '\', this.firstChild.nodeValue)';
+ action = 'mkws.limitQuery(\'' + cclIndex + '\', this.firstChild.nodeValue)';
}
acc.push('onclick="' + action + ';return false;">' + data[i].name + ''
+ '
' + data[i].freq + '');
@@ -277,7 +299,7 @@ function onFormSubmitEventHandler()
resetPage();
loadSelect();
triggerSearch();
- switchView('records'); // In case it's configured to start off as hidden
+ mkws.switchView('records'); // In case it's configured to start off as hidden
submitted = true;
return false;
}
@@ -313,18 +335,18 @@ function loadSelect ()
}
// limit the query after clicking the facet
-function limitQuery (field, value)
+mkws.limitQuery = function (field, value)
{
document.mkwsSearchForm.mkwsQuery.value += ' and ' + field + '="' + value + '"';
onFormSubmitEventHandler();
}
// limit by target functions
-function limitTarget (id, name)
+mkws.limitTarget = function (id, name)
{
var navi = document.getElementById('mkwsNavi');
navi.innerHTML =
- 'Source:
'
+ 'Source: '
+ name + '';
curFilter = 'pz:id=' + id;
resetPage();
@@ -333,7 +355,7 @@ function limitTarget (id, name)
return false;
}
-function delimitTarget ()
+mkws.delimitTarget = function ()
{
var navi = document.getElementById('mkwsNavi');
navi.innerHTML = '';
@@ -369,13 +391,13 @@ function drawPager (pagerDiv)
if(i == curPage)
numLabel = '
' + i + '';
- middle += '
'
+ middle += ' '
+ numLabel + ' ';
}
var next = '
| ' + M('Next') + ' >>';
if (pages - curPage > 0)
- next = '
| '
+ next = ' | '
+ M('Next') + ' >>';
var predots = '';
@@ -390,7 +412,7 @@ function drawPager (pagerDiv)
+ prev + predots + middle + postdots + next + '
';
}
-function showPage (pageNum)
+mkws.showPage = function (pageNum)
{
curPage = pageNum;
my_paz.showPage( curPage - 1 );
@@ -398,7 +420,7 @@ function showPage (pageNum)
// simple paging functions
-function pagerNext() {
+mkws.pagerNext = function () {
if ( totalRec - recPerPage*curPage > 0) {
my_paz.showNext();
curPage++;
@@ -412,7 +434,7 @@ function pagerPrev() {
// switching view between targets and records
-function switchView(view) {
+mkws.switchView = function(view) {
var targets = document.getElementById('mkwsTargets');
var results = document.getElementById('mkwsResults') ||
document.getElementById('mkwsRecords');
@@ -444,7 +466,7 @@ function switchView(view) {
}
// detailed record drawing
-function showDetails (prefixRecId) {
+mkws.showDetails = function (prefixRecId) {
var recId = prefixRecId.replace('mkwsRec_', '');
var oldRecId = curDetRecId;
curDetRecId = recId;
@@ -542,9 +564,9 @@ function mkws_html_all(config) {
/* set global debug flag early */
if (typeof config.debug !== 'undefined') {
- mkws_debug = config.debug;
+ mkws.debug = config.debug;
} else if (typeof mkws_config_default.debug !== 'undefined') {
- mkws_debug = mkws_config_default.debug;
+ mkws.debug = mkws_config_default.debug;
}
/* override standard config values by function parameters */
@@ -645,7 +667,7 @@ function mkws_html_all(config) {
function mkws_set_lang(mkws_config) {
var lang = $.parseQuerystring().lang || mkws_config.lang || "";
- if (!lang || !mkws_locale_lang[lang]) {
+ if (!lang || !mkws.locale_lang[lang]) {
mkws_config.lang = ""
} else {
mkws_config.lang = lang;
@@ -660,13 +682,13 @@ function mkws_html_switch(config) {
$("#mkwsSwitch").html($("", {
href: '#',
- onclick: "switchView(\'records\')",
+ onclick: "mkws.switchView(\'records\')",
text: M("Records")
}));
$("#mkwsSwitch").append($("", { text: " | " }));
$("#mkwsSwitch").append($("", {
href: '#',
- onclick: "switchView(\'targets\')",
+ onclick: "mkws.switchView(\'targets\')",
text: M("Targets")
}));
@@ -730,6 +752,7 @@ function mkws_service_proxy_auth(auth_url) {
alert("HTTP call for authentication failed: " + err)
return;
});
+
request.get(null, function(data) {
if (!$.isXMLDoc(data)) {
alert("service proxy auth response document is not valid XML document, give up!");
@@ -740,6 +763,9 @@ function mkws_service_proxy_auth(auth_url) {
alert("service proxy auth repsonse status: " + status.text() + ", give up!");
return;
}
+
+ debug("Service proxy auth successfully done");
+ mkws.service_proxy_auth = true;
});
}
@@ -756,7 +782,7 @@ function mkws_html_lang(mkws_config) {
hash[lang_display[i]] = 1;
}
- for (var k in mkws_locale_lang) {
+ for (var k in mkws.locale_lang) {
if (hash[k] == 1 || lang_display.length == 0)
list.push(k);
}
@@ -816,10 +842,10 @@ function mkws_resize_page () {
function M(word) {
var lang = mkws_config.lang;
- if (!lang || !mkws_locale_lang[lang])
+ if (!lang || !mkws.locale_lang[lang])
return word;
- return mkws_locale_lang[lang][word] ? mkws_locale_lang[lang][word] : word;
+ return mkws.locale_lang[lang][word] ? mkws.locale_lang[lang][word] : word;
}
/*
@@ -964,23 +990,19 @@ function init_popup(obj) {
});
};
-function debug(string) {
- if (!mkws_debug)
- return;
- if (typeof console === "undefined" || typeof console.log === "undefined") { /* ARGH!!! old IE */
- return;
- }
- // you need to disable use strict at the top of the file!!!
- if (mkws_debug >= 3) {
- console.log(arguments.callee.caller);
- } else if (mkws_debug >= 2) {
- console.log(">>> called from function " + arguments.callee.caller.name + ' <<<');
+
+/* magic */
+$(document).ready(function() {
+ try {
+ mkws_html_all(mkws_config)
}
- console.log(string);
-}
+ catch (e) {
+ mkws_config.error = e.message;
+ // alert(e.message);
+ }
+});
-/* magic */
-$(document).ready(function() { mkws_html_all(mkws_config) });
+})(jQuery);