X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=experiments%2Fspclient%2Fmkws.js;h=4a6eb6dadaad3db3e64746b755f7fc1eeddf916f;hb=71aa8121e550f16068eddc1365881e2ab652f8ee;hp=950df8ae89fc14092038c0e64eaf1165c9743c6b;hpb=e7cf6c45af6b281116c9db89a2465d7d62bbbd89;p=mkws-moved-to-github.git
diff --git a/experiments/spclient/mkws.js b/experiments/spclient/mkws.js
index 950df8a..4a6eb6d 100644
--- a/experiments/spclient/mkws.js
+++ b/experiments/spclient/mkws.js
@@ -1,17 +1,27 @@
/* A very simple client that shows a basic usage of the pz2.js
*/
-"use strict"; // HTML5
+"use strict"; // HTML5: disable for debug >= 2
+
+/*
+ * global config object: mkws_config
+ *
+ * needs to be defined in the HTML header before
+ * including this JS file
+ */
if (!mkws_config)
var mkws_config = {}; // for the guys who forgot to define mkws_config...
+var mkws_debug = 1;
+
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 : "/service-proxy/";
var pazpar2path = mkws_config.use_service_proxy ? service_proxy_url : pazpar2_url;
var usesessions = mkws_config.use_service_proxy ? false : true;
+
var mkws_locale_lang = {
"de": {
"Authors": "Autoren",
@@ -28,6 +38,11 @@ var mkws_locale_lang = {
"to": "von",
"of": "aus",
"found": "gefunden",
+ "Title": "Titel",
+ "Author": "Autor",
+ "Date": "Datum",
+ "Subject": "Schlagwort",
+ "Location": "Ort",
"dummy": "dummy"
},
@@ -46,7 +61,12 @@ var mkws_locale_lang = {
"Displaying": "Viser",
"to": "til",
"of": "ud af",
- "found": "fundet",
+ "found": "fandt",
+ "Title": "Title",
+ "Author": "Forfatter",
+ "Date": "Dato",
+ "Subject": "Emneord",
+ "Location": "Lokation",
"dummy": "dummy"
}
@@ -135,6 +155,9 @@ function my_onstat(data) {
}
function my_onterm(data) {
+ if (!mkws_config.termlist_menu)
+ return;
+
var termlists = [];
termlists.push('
' + M('TERMLISTS') + ':
' + M('Sources') + '
');
for (var i = 0; i < data.xtargets.length && i < SourceMax; i++ ) {
@@ -399,7 +422,7 @@ function renderDetails(data, marker)
var details = '';
if (marker) details += ''+ marker + ' |
';
if (data["md-title"] != undefined) {
- details += 'Title | : '+data["md-title"];
+ details += ' |
' + M('Title') + ' | : '+data["md-title"];
if (data["md-title-remainder"] !== undefined) {
details += ' : ' + data["md-title-remainder"] + ' ';
}
@@ -409,15 +432,15 @@ function renderDetails(data, marker)
details += ' |
';
}
if (data["md-date"] != undefined)
- details += 'Date | : ' + data["md-date"] + ' |
';
+ details += '' + M('Date') + ' | : ' + data["md-date"] + ' |
';
if (data["md-author"] != undefined)
- details += 'Author | : ' + data["md-author"] + ' |
';
+ details += '' + M('Author') + ' | : ' + data["md-author"] + ' |
';
if (data["md-electronic-url"] != undefined)
details += 'URL | : ' + data["md-electronic-url"] + '' + ' |
';
if (data["location"][0]["md-subject"] != undefined)
- details += 'Subject | : ' + data["location"][0]["md-subject"] + ' |
';
+ details += '' + M('Subject') + ' | : ' + data["location"][0]["md-subject"] + ' |
';
if (data["location"][0]["@name"] != undefined)
- details += 'Location | : ' + data["location"][0]["@name"] + " (" +data["location"][0]["@id"] + ")" + ' |
';
+ details += '' + M('Location') + ' | : ' + data["location"][0]["@name"] + " (" +data["location"][0]["@id"] + ")" + ' |
';
details += '
';
return details;
}
@@ -435,24 +458,46 @@ function mkws_html_all(data) {
sort_default: "relevance",
perpage_default: 20,
query_width: 50,
- switch: true, /* show/hide Records|Targets menu */
+ switch_menu: true, /* show/hide Records|Targets menu */
+ lang_menu: true, /* show/hide language menu */
+ lang_display: [], /* display languages links for given languages, [] for all */
+ termlist_menu: true, /* show/hide termlist */
+ debug: 0, /* debug level for development: 0..2 */
dummy: "dummy"
};
+ /* set global debug flag early */
+ if (data.debug !== 'undefined') {
+ mkws_debug = data.debug;
+ } else if (config.debug !== 'undefined') {
+ mkws_debug = config.debug;
+ }
+
/* override standard config values by function parameters */
- for (var k in data) {
- config[k] = data[k];
+ for (var k in config) {
+ mkws_config[k] = config[k];
+ debug("Set config: " + k + ' => ' + config[k]);
+ }
+ if (mkws_config.query_width < 5 || mkws_config.query_width > 150) {
+ debug("Reset query width: " + mkws_config.query_width);
+ mkws_config.query_width = 50;
}
+
+ mkws_set_lang(mkws_config);
+ if (mkws_config.lang_menu)
+ mkws_html_lang(mkws_config);
// For some reason, doing this programmatically results in
// document.search.query being undefined, hence the raw HTML.
+ debug("HTML search form");
$("#mkwsSearch").html('\
- ');
+ debug("HTML records");
$("#mkwsRecords").html('\
\
\
@@ -461,7 +506,7 @@ function mkws_html_all(data) {
\
\
| \
\
-
\
- ');
+ ');
mkws_html_switch(config);
if (mkws_config.use_service_proxy)
@@ -482,7 +526,21 @@ function mkws_html_all(data) {
domReady();
}
+function mkws_set_lang(mkws_config) {
+ var lang = jQuery.parseQuerystring().lang || mkws_config.lang || "";
+ if (!lang || !mkws_locale_lang[lang]) {
+ mkws_config.lang = ""
+ } else {
+ mkws_config.lang = lang;
+ }
+
+ debug("Locale language: " + (mkws_config.lang ? mkws_config.lang : "none"));
+ return mkws_config.lang;
+}
+
function mkws_html_switch(config) {
+ debug("HTML switch");
+
$("#mkwsSwitch").html($("", {
href: '#',
onclick: "switchView(\'records\')",
@@ -495,18 +553,21 @@ function mkws_html_switch(config) {
text: "Targets"
}));
+ debug("HTML targets");
$("#mkwsTargets").html('\
\
No information available yet.\
');
$("#mkwsTargets").css("display", "none");
- if (!config.switch) {
+ if (!config.switch_menu) {
+ debug("disable switch menu");
$("#mkwsSwitch").css("display", "none");
}
}
function mkws_html_sort(config) {
+ debug("HTML sort");
var sort_html = '