X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=experiments%2Fspclient%2Fmkws.js;h=f4e9646e1319c4056d605ca6989a4d2cf31d5fff;hb=15694650eb5ea2b7b3bba5f0c73d618ef40aad25;hp=477da1066760379102835cedcecf0df2fbdaa8ac;hpb=dcc97e4df313226636de5160da6082bf1036cfb5;p=mkws-moved-to-github.git
diff --git a/experiments/spclient/mkws.js b/experiments/spclient/mkws.js
index 477da10..f4e9646 100644
--- a/experiments/spclient/mkws.js
+++ b/experiments/spclient/mkws.js
@@ -16,7 +16,8 @@ if (!mkws_config)
if (typeof mkws_config.use_service_proxy === 'undefined')
mkws_config.use_service_proxy = true;
-var mkws_debug = 1;
+// 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/";
@@ -115,13 +116,13 @@ function my_onshow(data) {
// move it out
var pager = document.getElementById("mkwsPager");
pager.innerHTML = "";
- pager.innerHTML +='
' + M('Displaying') + ': '
+ pager.innerHTML +='
' + M('Displaying') + ': '
+ (data.start + 1) + ' ' + M('to') + ' ' + (data.start + data.num) +
' ' + M('of') + ' ' + data.merged + ' (' + M('found') + ': '
+ data.total + ')
';
drawPager(pager);
// navi
- var results = document.getElementById("mkwsResults");
+ var results = document.getElementById("mkwsRecords");
var html = [];
for (var i = 0; i < data.hits.length; i++) {
@@ -160,12 +161,12 @@ function my_onstat(data) {
function my_onterm(data) {
// no facets
if (!mkws_config.facets || mkws_config.facets.length == 0) {
- $("#mkwsTermlists").parent().hide();
+ $("#mkwsTermlists").hide();
return;
}
// display if we first got results
- $("#mkwsTermlists").parent().show();
+ $("#mkwsTermlists").show();
var acc = [];
acc.push('
' + M('Termlists') + '
');
@@ -185,6 +186,9 @@ function my_onterm(data) {
var termlist = document.getElementById("mkwsTermlists");
replaceHtml(termlist, acc.join(''));
+
+ if (mkws_config.responsive_design)
+ mkws_mobile_resize();
}
function add_single_facet(acc, caption, data, max, cclIndex) {
@@ -241,10 +245,14 @@ function my_onbytarget(data) {
// wait until the DOM is ready
function domReady ()
{
- document.search.onsubmit = onFormSubmitEventHandler;
- document.search.mkwsQuery.value = '';
- document.mkwsSelect.sort.onchange = onSelectDdChange;
- document.mkwsSelect.perpage.onchange = onSelectDdChange;
+ document.mkwsSearchForm.onsubmit = onFormSubmitEventHandler;
+ document.mkwsSearchForm.mkwsQuery.value = '';
+ if (document.mkwsSelect) {
+ if (document.mkwsSelect.mkwsSort)
+ document.mkwsSelect.mkwsSort.onchange = onSelectDdChange;
+ if (document.mkwsSelect.mkwsPerpage)
+ document.mkwsSelect.mkwsPerpage.onchange = onSelectDdChange;
+ }
}
// when search button pressed
@@ -275,19 +283,23 @@ function resetPage()
function triggerSearch ()
{
- my_paz.search(document.search.mkwsQuery.value, recPerPage, curSort, curFilter);
+ my_paz.search(document.mkwsSearchForm.mkwsQuery.value, recPerPage, curSort, curFilter);
}
function loadSelect ()
{
- curSort = document.mkwsSelect.sort.value;
- recPerPage = document.mkwsSelect.perpage.value;
+ if (document.mkwsSelect) {
+ if (document.mkwsSelect.mkwsSort)
+ curSort = document.mkwsSelect.mkwsSort.value;
+ if (document.mkwsSelect.mkwsPerpage)
+ recPerPage = document.mkwsSelect.mkwsPerpage.value;
+ }
}
// limit the query after clicking the facet
function limitQuery (field, value)
{
- document.search.query.value += ' and ' + field + '="' + value + '"';
+ document.mkwsSearchForm.query.value += ' and ' + field + '="' + value + '"';
onFormSubmitEventHandler();
}
@@ -298,7 +310,6 @@ function limitTarget (id, name)
navi.innerHTML =
'Source:
'
+ name + '';
- navi.innerHTML += '
';
curFilter = 'pz:id=' + id;
resetPage();
loadSelect();
@@ -331,9 +342,9 @@ function drawPager (pagerDiv)
? firstClkbl + 2*onsides
: pages;
- var prev = '
<< ' + M('Prev') + ' | ';
+ var prev = '
<< ' + M('Prev') + ' | ';
if (curPage > 1)
- prev = '
'
+ prev = ''
+'<< ' + M('Prev') + ' | ';
var middle = '';
@@ -346,9 +357,9 @@ function drawPager (pagerDiv)
+ numLabel + ' ';
}
- var next = '
| ' + M('Next') + ' >>';
+ var next = '
| ' + M('Next') + ' >>';
if (pages - curPage > 0)
- next = '
| '
+ next = ' | '
+ M('Next') + ' >>';
var predots = '';
@@ -360,7 +371,7 @@ function drawPager (pagerDiv)
postdots = '...';
pagerDiv.innerHTML += '
'
- + prev + predots + middle + postdots + next + '
';
+ + prev + predots + middle + postdots + next + '
';
}
function showPage (pageNum)
@@ -383,28 +394,27 @@ function pagerPrev() {
curPage--;
}
-// swithing view between targets and records
+// switching view between targets and records
function switchView(view) {
-
var targets = document.getElementById('mkwsTargets');
- var records = document.getElementById('mkwsRecords');
+ var records = document.getElementById('mkwsResults');
var blanket = document.getElementById('mkwsBlanket');
switch(view) {
case 'targets':
targets.style.display = "block";
- records.style.display = "none";
+ if (records) records.style.display = "none";
if (blanket) { blanket.style.display = "none"; }
break;
case 'records':
targets.style.display = "none";
- records.style.display = "block";
+ if (records) records.style.display = "block";
if (blanket) { blanket.style.display = "block"; }
break;
case 'none':
targets.style.display = "none";
- records.style.display = "none";
+ if (records) records.style.display = "none";
if (blanket) { blanket.style.display = "none"; }
break;
default:
@@ -500,18 +510,20 @@ function mkws_html_all(config) {
query_width: 50,
switch_menu: true, /* show/hide Records|Targets menu */
lang_menu: true, /* show/hide language menu */
+ sort_menu: true, /* show/hide sort menu */
+ perpage_menu: true, /* show/hide perpage menu */
lang_display: [], /* display languages links for given languages, [] for all */
facets: ["sources", "subjects", "authors"], /* display facets, in this order, [] for none */
-
- debug: 0, /* debug level for development: 0..2 */
+ responsive_design_width: 980, /* a page with less pixel width considered as mobile */
+ debug: 1, /* debug level for development: 0..2 */
dummy: "dummy"
};
/* set global debug flag early */
- if (config.debug !== 'undefined') {
+ if (typeof config.debug !== 'undefined') {
mkws_debug = config.debug;
- } else if (mkws_config_default.debug !== 'undefined') {
+ } else if (typeof mkws_config_default.debug !== 'undefined') {
mkws_debug = mkws_config_default.debug;
}
@@ -532,35 +544,53 @@ function mkws_html_all(config) {
mkws_html_lang(mkws_config);
// For some reason, doing this programmatically results in
- // document.search.mkwsQuery being undefined, hence the raw HTML.
+ // document.mkwsSearchForm.mkwsQuery being undefined, hence the raw HTML.
debug("HTML search form");
$("#mkwsSearch").html('\
-