projects
/
mkws-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
document, refactor for empty mkws_config object
[mkws-moved-to-github.git]
/
experiments
/
spclient
/
mkws.js
diff --git
a/experiments/spclient/mkws.js
b/experiments/spclient/mkws.js
index
0504753
..
4a6eb6d
100644
(file)
--- a/
experiments/spclient/mkws.js
+++ b/
experiments/spclient/mkws.js
@@
-1,18
+1,26
@@
/* A very simple client that shows a basic usage of the pz2.js
*/
/* 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...
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 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_debug = 1;
var mkws_locale_lang = {
"de": {
var mkws_locale_lang = {
"de": {
@@
-30,6
+38,11
@@
var mkws_locale_lang = {
"to": "von",
"of": "aus",
"found": "gefunden",
"to": "von",
"of": "aus",
"found": "gefunden",
+ "Title": "Titel",
+ "Author": "Autor",
+ "Date": "Datum",
+ "Subject": "Schlagwort",
+ "Location": "Ort",
"dummy": "dummy"
},
"dummy": "dummy"
},
@@
-49,6
+62,11
@@
var mkws_locale_lang = {
"to": "til",
"of": "ud af",
"found": "fandt",
"to": "til",
"of": "ud af",
"found": "fandt",
+ "Title": "Title",
+ "Author": "Forfatter",
+ "Date": "Dato",
+ "Subject": "Emneord",
+ "Location": "Lokation",
"dummy": "dummy"
}
"dummy": "dummy"
}
@@
-137,6
+155,9
@@
function my_onstat(data) {
}
function my_onterm(data) {
}
function my_onterm(data) {
+ if (!mkws_config.termlist_menu)
+ return;
+
var termlists = [];
termlists.push('<hr/><b>' + M('TERMLISTS') + ':</b><hr/><div class="termtitle">' + M('Sources') + '</div>');
for (var i = 0; i < data.xtargets.length && i < SourceMax; i++ ) {
var termlists = [];
termlists.push('<hr/><b>' + M('TERMLISTS') + ':</b><hr/><div class="termtitle">' + M('Sources') + '</div>');
for (var i = 0; i < data.xtargets.length && i < SourceMax; i++ ) {
@@
-401,7
+422,7
@@
function renderDetails(data, marker)
var details = '<div class="details" id="det_'+data.recid+'"><table>';
if (marker) details += '<tr><td>'+ marker + '</td></tr>';
if (data["md-title"] != undefined) {
var details = '<div class="details" id="det_'+data.recid+'"><table>';
if (marker) details += '<tr><td>'+ marker + '</td></tr>';
if (data["md-title"] != undefined) {
- details += '<tr><td><b>Title</b></td><td><b>:</b> '+data["md-title"];
+ details += '<tr><td><b>' + M('Title') + '</b></td><td><b>:</b> '+data["md-title"];
if (data["md-title-remainder"] !== undefined) {
details += ' : <span>' + data["md-title-remainder"] + ' </span>';
}
if (data["md-title-remainder"] !== undefined) {
details += ' : <span>' + data["md-title-remainder"] + ' </span>';
}
@@
-411,15
+432,15
@@
function renderDetails(data, marker)
details += '</td></tr>';
}
if (data["md-date"] != undefined)
details += '</td></tr>';
}
if (data["md-date"] != undefined)
- details += '<tr><td><b>Date</b></td><td><b>:</b> ' + data["md-date"] + '</td></tr>';
+ details += '<tr><td><b>' + M('Date') + '</b></td><td><b>:</b> ' + data["md-date"] + '</td></tr>';
if (data["md-author"] != undefined)
if (data["md-author"] != undefined)
- details += '<tr><td><b>Author</b></td><td><b>:</b> ' + data["md-author"] + '</td></tr>';
+ details += '<tr><td><b>' + M('Author') + '</b></td><td><b>:</b> ' + data["md-author"] + '</td></tr>';
if (data["md-electronic-url"] != undefined)
details += '<tr><td><b>URL</b></td><td><b>:</b> <a href="' + data["md-electronic-url"] + '" target="_blank">' + data["md-electronic-url"] + '</a>' + '</td></tr>';
if (data["location"][0]["md-subject"] != undefined)
if (data["md-electronic-url"] != undefined)
details += '<tr><td><b>URL</b></td><td><b>:</b> <a href="' + data["md-electronic-url"] + '" target="_blank">' + data["md-electronic-url"] + '</a>' + '</td></tr>';
if (data["location"][0]["md-subject"] != undefined)
- details += '<tr><td><b>Subject</b></td><td><b>:</b> ' + data["location"][0]["md-subject"] + '</td></tr>';
+ details += '<tr><td><b>' + M('Subject') + '</b></td><td><b>:</b> ' + data["location"][0]["md-subject"] + '</td></tr>';
if (data["location"][0]["@name"] != undefined)
if (data["location"][0]["@name"] != undefined)
- details += '<tr><td><b>Location</b></td><td><b>:</b> ' + data["location"][0]["@name"] + " (" +data["location"][0]["@id"] + ")" + '</td></tr>';
+ details += '<tr><td><b>' + M('Location') + '</b></td><td><b>:</b> ' + data["location"][0]["@name"] + " (" +data["location"][0]["@id"] + ")" + '</td></tr>';
details += '</table></div>';
return details;
}
details += '</table></div>';
return details;
}
@@
-437,7
+458,10
@@
function mkws_html_all(data) {
sort_default: "relevance",
perpage_default: 20,
query_width: 50,
sort_default: "relevance",
perpage_default: 20,
query_width: 50,
- switch_menu: 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"
debug: 0, /* debug level for development: 0..2 */
dummy: "dummy"
@@
-451,9
+475,9
@@
function mkws_html_all(data) {
}
/* override standard config values by function parameters */
}
/* override standard config values by function parameters */
- for (var k in data) {
- config[k] = data[k];
- debug("Set 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);
}
if (mkws_config.query_width < 5 || mkws_config.query_width > 150) {
debug("Reset query width: " + mkws_config.query_width);
@@
-461,7
+485,8
@@
function mkws_html_all(data) {
}
mkws_set_lang(mkws_config);
}
mkws_set_lang(mkws_config);
- mkws_html_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.
// For some reason, doing this programmatically results in
// document.search.query being undefined, hence the raw HTML.
@@
-610,13
+635,25
@@
function mkws_service_proxy_auth(auth_url) {
function mkws_html_lang(mkws_config) {
var lang_default = "en";
var lang = mkws_config.lang || lang_default;
function mkws_html_lang(mkws_config) {
var lang_default = "en";
var lang = mkws_config.lang || lang_default;
- var list = [lang_default];
+ var list = [];
+
+ /* display a list of configured languages, or all */
+ var lang_display = mkws_config.lang_display || [];
+ var hash = {};
+ for (var i = 0; i < lang_display.length; i++) {
+ hash[lang_display[i]] = 1;
+ }
+ if (hash[lang_default] == 1)
+ list.push(lang_default);
+
for (var k in mkws_locale_lang) {
for (var k in mkws_locale_lang) {
- list.push(k);
+ if (hash[k] == 1 || lang_display.length == 0)
+ list.push(k);
}
debug("Language menu for: " + list.join(", "));
}
debug("Language menu for: " + list.join(", "));
+ /* the HTML part */
var data = "";
for(var i = 0; i < list.length; i++) {
var l = list[i];
var data = "";
for(var i = 0; i < list.length; i++) {
var l = list[i];
@@
-627,7
+664,7
@@
function mkws_html_lang(mkws_config) {
if (lang == l) {
data += l;
} else {
if (lang == l) {
data += l;
} else {
- data += ' <a href="/?lang=' + l + '">' + l + '</a> '
+ data += ' <a href="?lang=' + l + '">' + l + '</a> '
}
}
}
}
@@
-660,9
+697,8
@@
jQuery.extend({
function debug(string) {
if (!mkws_debug)
return;
function debug(string) {
if (!mkws_debug)
return;
-
- var console; // IE8 quirks
- if (!console) { /* ARGH!!! */
+
+ if (typeof console === "undefined" || typeof console.log === "undefined") { /* ARGH!!! */
return;
}
return;
}