X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=inline;f=tools%2Fhtdocs%2Fmkws.js;h=144d2de477c896580095d8fafead11c8fa481a69;hb=9c7195162561ca11d57775a6fd5ef42f82cde3f4;hp=75f9f4ffeb51c266888dd9cc115e62e9d7776ff9;hpb=ae2258fe03fae77bfe7ff285e8e7f2a1482d118b;p=mkws-moved-to-github.git
diff --git a/tools/htdocs/mkws.js b/tools/htdocs/mkws.js
index 75f9f4f..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,36 +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;
-
-// exported symobols
-var debug;
-var my_paz;
-var limitTarget;
-var delimitTarget;
-var limitQuery;
-var showDetails;
-var pagerNext;
-var switchView;
-var showPage;
-var mkws_locale_lang;
-
-(function ($) {
+mkws.pazpar2path = mkws_config.use_service_proxy ? service_proxy_url : pazpar2_url;
+mkws.usesessions = mkws_config.use_service_proxy ? false : true;
-mkws_locale_lang = {
+mkws.locale_lang = {
"de": {
"Authors": "Autoren",
"Subjects": "Schlagwörter",
@@ -89,8 +78,8 @@ mkws_locale_lang = {
}
};
-debug = function (string) {
- if (!mkws_debug)
+mkws.debug = function (string) {
+ if (!mkws.debug)
return;
if (typeof console === "undefined" || typeof console.log === "undefined") { /* ARGH!!! old IE */
@@ -98,20 +87,21 @@ debug = function (string) {
}
// you need to disable use strict at the top of the file!!!
- if (mkws_debug >= 3) {
+ if (mkws.debug >= 3) {
console.log(arguments.callee.caller);
- } else if (mkws_debug >= 2) {
+ } 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];
}
}
}
@@ -120,17 +110,20 @@ for (var key in mkws_config) {
// create a parameters array and pass it to the pz2's constructor
// then register the form submit event with the pz2.search function
// autoInit is set to true on default
-my_paz = new pz2( { "onshow": my_onshow,
+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;
@@ -171,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"] + ' ');
@@ -239,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 + '');
@@ -306,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;
}
@@ -342,18 +335,18 @@ function loadSelect ()
}
// limit the query after clicking the facet
-limitQuery = function (field, value)
+mkws.limitQuery = function (field, value)
{
document.mkwsSearchForm.mkwsQuery.value += ' and ' + field + '="' + value + '"';
onFormSubmitEventHandler();
}
// limit by target functions
-limitTarget = function (id, name)
+mkws.limitTarget = function (id, name)
{
var navi = document.getElementById('mkwsNavi');
navi.innerHTML =
- 'Source:
'
+ 'Source: '
+ name + '';
curFilter = 'pz:id=' + id;
resetPage();
@@ -362,7 +355,7 @@ limitTarget = function (id, name)
return false;
}
-delimitTarget = function ()
+mkws.delimitTarget = function ()
{
var navi = document.getElementById('mkwsNavi');
navi.innerHTML = '';
@@ -398,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 = '';
@@ -419,7 +412,7 @@ function drawPager (pagerDiv)
+ prev + predots + middle + postdots + next + '
';
}
-showPage = function (pageNum)
+mkws.showPage = function (pageNum)
{
curPage = pageNum;
my_paz.showPage( curPage - 1 );
@@ -427,7 +420,7 @@ showPage = function (pageNum)
// simple paging functions
-pagerNext = function () {
+mkws.pagerNext = function () {
if ( totalRec - recPerPage*curPage > 0) {
my_paz.showNext();
curPage++;
@@ -441,7 +434,7 @@ function pagerPrev() {
// switching view between targets and records
-switchView = function(view) {
+mkws.switchView = function(view) {
var targets = document.getElementById('mkwsTargets');
var results = document.getElementById('mkwsResults') ||
document.getElementById('mkwsRecords');
@@ -473,7 +466,7 @@ switchView = function(view) {
}
// detailed record drawing
-showDetails = function (prefixRecId) {
+mkws.showDetails = function (prefixRecId) {
var recId = prefixRecId.replace('mkwsRec_', '');
var oldRecId = curDetRecId;
curDetRecId = recId;
@@ -571,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 */
@@ -674,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;
@@ -689,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")
}));
@@ -759,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!");
@@ -769,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;
});
}
@@ -785,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);
}
@@ -845,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;
}
/*
@@ -1009,5 +1006,3 @@ $(document).ready(function() {
});
})(jQuery);
-
-jQuery = null;
\ No newline at end of file