X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=tools%2Fhtdocs%2Fmkws.js;h=c11738a88f6be33dd25d7bcd3e197c59bda0b0f6;hb=925d2356891199a978c06866733f663af30f335d;hp=5b428bf9994ea47be1ece31b26920aa83b1ced14;hpb=72e0d26475c1cee0ef58f8a0e31b01cd1b58940a;p=mkws-moved-to-github.git diff --git a/tools/htdocs/mkws.js b/tools/htdocs/mkws.js index 5b428bf..c11738a 100644 --- a/tools/htdocs/mkws.js +++ b/tools/htdocs/mkws.js @@ -264,24 +264,43 @@ function my_onshow(data) { var html = []; for (var i = 0; i < data.hits.length; i++) { var hit = data.hits[i]; - html.push('
' - +'' - + hit["md-title"] +' '); - if (hit["md-title-remainder"] !== undefined) { - html.push('' + hit["md-title-remainder"] + ' '); - } - if (hit["md-title-responsibility"] !== undefined) { - html.push(''+hit["md-title-responsibility"]+''); - } - if (hit.recid == curDetRecId) { + html.push('
', + renderSummary(hit), + '
'); + if (hit.recid == curDetRecId) { html.push(renderDetails(curDetRecData)); - } - html.push('
'); + } } replaceHtml(results, html.join('')); } + +function renderSummary(hit) +{ + if (mkws.templateSummary === undefined) { + loadTemplate("Summary"); + } + + if (mkws.templateSummary) { + hit._id = "mkwsRec_" + hit.recid; + hit._onclick = "mkws.showDetails(this.id);return false;" + return mkws.templateSummary(hit); + } else { + var html = []; + html.push('' + + hit["md-title"] +' '); + if (hit["md-title-remainder"] !== undefined) { + html.push('' + hit["md-title-remainder"] + ' '); + } + if (hit["md-title-responsibility"] !== undefined) { + html.push(''+hit["md-title-responsibility"]+''); + } + return html.join(''); + } +} + + function my_onstat(data) { var stat = document.getElementById("mkwsStat"); if (stat == null) @@ -695,22 +714,16 @@ function replaceHtml(el, html) { function renderDetails(data, marker) { if (mkws.templateRecord === undefined) { - maybeLoadTemplate("Record"); - } - - var details; - if (mkws.templateRecord) { - var template = mkws.templateRecord; - details = template(data); - } else { - details = defaultRenderDetails(data, marker); + loadTemplate("Record"); } + var template = mkws.templateRecord; + var details = template(data); return '
' + details + '
'; } -function maybeLoadTemplate(name) +function loadTemplate(name) { var source = $("#mkwsTemplate" + name).html(); if (!source) { @@ -791,60 +804,6 @@ function defaultTemplate(name) } -function defaultRenderDetails(data, marker) -{ - var details = ''; - if (marker) details += ''; - - var locations = []; - for (var i in data.location) { - locations.push(data.location[i]['@name']); - } - - details += renderField("Title", data["md-title"], data["md-title-remainder"], data["md-title-responsibility"]); - details += renderField("Date", data["md-date"]); - details += renderField("Author", data["md-author"]); - details += renderField("URL", data["md-electronic-url"]); - details += renderField("Subject", data["location"][0]["md-subject"]); - if (locations.length == 0) { - details += ''; - } else { - details += renderField("Location" + (locations.length == 1 ? "" : "s"), locations); - } - details += '
'+ marker + '
No locations for record!
'; - return details; -} - - -function renderField(caption, data, data2, data3) { - if (data === undefined) { - return ""; - } - - var res = ""; - for (var i = 0; i < data.length; i++) { - var s = data[i]; - if (i > 0) - res += ", "; - - if (caption == "URL") - s = '' + s + ''; - - res += s - } - - if (data2 != undefined) { - res = res + " (" + data2 + ")"; - } - - if (data3 != undefined) { - res = res + " " + data3 + ""; - } - - return '' + M(caption) + '' + res + ''; -} - - /* * All the HTML stuff to render the search forms and * result pages.