X-Git-Url: http://lists.indexdata.dk/cgi-bin?a=blobdiff_plain;f=www%2Fdemo%2Fsearch.js;h=64f685bf73efb7738b78afc37679cc0ffede1cd9;hb=7a31488b5aee7ead673f2112fadd3f8b8f5c00e8;hp=633b10bd0fcc7c6dd65fdc350d2a32789d3e7af5;hpb=7268be709f8b7ecc6e2abb3bff746d1bd2c9a8e3;p=pazpar2-moved-to-github.git
diff --git a/www/demo/search.js b/www/demo/search.js
index 633b10b..64f685b 100644
--- a/www/demo/search.js
+++ b/www/demo/search.js
@@ -1,4 +1,4 @@
-/* $Id: search.js,v 1.4 2007-01-05 13:45:35 sondberg Exp $
+/* $Id: search.js,v 1.24 2007-01-15 19:01:29 quinn Exp $
* ---------------------------------------------------
* Javascript container
*/
@@ -20,15 +20,19 @@ var stattimer;
var session_cells = Array('query', 'startrec', 'action_type');
var old_session = session_read();
var url_surveillence;
-var recstoshow = 15;
+var recstoshow = 20;
+var page_window = 5; // Number of pages prior to and after the current page
var facet_list;
var cur_facet = 0;
+var cur_sort = "relevance";
+var searched = 0;
function initialize ()
{
facet_list = get_available_facets();
start_session();
session_check();
+ set_sort();
}
@@ -59,7 +63,7 @@ function session_started()
return;
var xml = xinitSession.responseXML;
var sesid = xml.getElementsByTagName("session")[0].childNodes[0].nodeValue;
- document.getElementById("status").innerHTML = "Live";
+ assign_text(document.getElementById("status"), 'Live');
session = sesid;
setTimeout(ping_session, 50000);
}
@@ -72,8 +76,6 @@ function start_session()
xinitSession.onreadystatechange=session_started;
xinitSession.open("GET", url);
xinitSession.send(null);
-
- //url_surveillence = setInterval(session_check, 200);
}
function ping_session()
@@ -100,51 +102,117 @@ function session_pinged()
setTimeout(ping_session, 50000);
}
-function targets_loaded()
-{
- if (xloadTargets.readyState != 4)
- return;
- var xml = xloadTargets.responseXML;
- var error = xml.getElementsByTagName("error");
- if (error[0])
- {
- var msg = error[0].childNodes[0].nodeValue;
- alert(msg);
- return;
+function update_action (new_action) {
+ document.search.action_type.value = new_action;
+}
+
+
+function make_pager (hits, offset, max) {
+ var html = '';
+ var off;
+ var start_offset = offset - page_window * max;
+ var div_elem = document.createElement('div');
+
+ div_elem.className = 'pages';
+
+ if (start_offset < 0) {
+ start_offset = 0;
+ }
+
+ for (off = start_offset;
+ off < hits && off < (start_offset + 2 * page_window * max);
+ off += max) {
+
+ var p = off / max + 1;
+ var page_elem = create_element('a', p);
+ var newline_node = document.createTextNode(' ');
+
+ if ((offset >= off) && (offset < (off + max))) {
+ page_elem.className = 'select';
+ }
+
+ page_elem.setAttribute('off', off);
+ page_elem.style.cursor = 'pointer';
+ page_elem.onclick = function () {
+ update_offset(this.getAttribute('off'));
+ };
+
+ div_elem.appendChild(page_elem);
+ div_elem.appendChild(newline_node);
}
- document.getElementById("targetstatus").innerHTML = "Targets loaded";
+
+ return div_elem;
}
-function load_targets()
-{
- var fn = document.getElementById("targetfilename").value;
- clearTimeout(termtimer);
+
+function update_offset (offset) {
clearTimeout(searchtimer);
- clearTimeout(stattimer);
- clearTimeout(showtimer);
- document.getElementById("stat").innerHTML = "";
- if (!fn)
+ document.search.startrec.value = offset;
+ update_action('page');
+ check_search();
+ update_history();
+ return false;
+}
+
+
+function create_element (name, cdata) {
+ var elem_node = document.createElement(name);
+ var text_node = document.createTextNode(cdata);
+ elem_node.appendChild(text_node);
+
+ return elem_node;
+}
+
+
+function clear_cell (cell) {
+ while (cell.hasChildNodes())
+ cell.removeChild(cell.firstChild);
+}
+
+
+function append_text(cell, text) {
+ text_node = document.createTextNode(text);
+ cell.appendChild(text_node);
+}
+
+
+function assign_text (cell, text) {
+ clear_cell(cell);
+ append_text(cell, text);
+}
+
+function set_sort_opt(n, opt, str)
+{
+ var txt = document.createTextNode(str);
+ if (opt == cur_sort)
+ n.appendChild(txt);
+ else
{
- alert("Please enter a target definition file name");
- return;
+ var a = document.createElement('a');
+ a.appendChild(txt);
+ a.setAttribute('href', "");
+ a.setAttribute('onclick', "set_sort('" + opt + "'); return false");
+ n.appendChild(a);
}
- var url="search.pz2?" +
- "command=load" +
- "&session=" + session +
- "&name=" + fn;
- document.getElementById("targetstatus").innerHTML = "Loading targets...";
- xloadTargets = GetXmlHttpObject();
- xloadTargets.onreadystatechange=targets_loaded;
- xloadTargets.open("GET", url);
- xloadTargets.send(null);
}
+function set_sort(sort)
+{
+ if (sort && sort != cur_sort)
+ {
+ cur_sort = sort;
+ if (searched)
+ check_search();
+ }
-function update_action (new_action) {
- document.search.action_type.value = new_action;
+ var t = document.getElementById("sortselect");
+ clear_cell(t);
+ t.appendChild(document.createTextNode("Sort results by: "));
+ set_sort_opt(t, 'relevance', 'Relevance');
+ t.appendChild(document.createTextNode(" or "));
+ set_sort_opt(t, 'title:1', 'Title');
}
-
function show_records()
{
if (xshow.readyState != 4)
@@ -153,45 +221,68 @@ function show_records()
var xml = xshow.responseXML;
var body = document.getElementById("body");
var hits = xml.getElementsByTagName("hit");
+
+ clear_cell(body);
+
if (!hits[0]) // We should never get here with blocking operations
{
- body.innerHTML = "No records yet";
+ assign_text(body, 'No records yet');
searchtimer = setTimeout(check_search, 250);
}
else
{
-
var total = Number(xml.getElementsByTagName('total')[0].childNodes[0].nodeValue);
var merged = Number(xml.getElementsByTagName('merged')[0].childNodes[0].nodeValue);
var start = Number(xml.getElementsByTagName('start')[0].childNodes[0].nodeValue);
var num = Number(xml.getElementsByTagName('num')[0].childNodes[0].nodeValue);
var clients = Number(xml.getElementsByTagName("activeclients")[0].childNodes[0].nodeValue);
- body.innerHTML = 'Records : ';
- body.innerHTML += (start + 1) + ' to ' + (start + num) +
- ' of ' + merged + ' (total hits: ' + total + ')';
-
- if (start + num < merged)
- body.innerHTML += ' Next';
-
- if (start > 0)
- body.innerHTML += ' Previous';
-
- body.innerHTML += '
';
+ var pager = make_pager(merged, start,recstoshow);
+ var break_node1 = document.createElement('br');
+ var break_node2 = document.createElement('br');
+ var record_container = document.createElement('div');
+ var interval = create_element('div', 'Records : ' + (start + 1) +
+ ' to ' + (start + num) + ' of ' +
+ merged + ' (total hits: ' +
+ total + ')');
+ searched = 1;
+ interval.className = 'results';
+ record_container.className = 'records';
+
+ body.appendChild(pager);
+ body.appendChild(interval);
+ body.appendChild(break_node1);
+ body.appendChild(break_node2);
+ body.appendChild(record_container);
+
for (i = 0; i < hits.length; i++)
{
- body.innerHTML += '
'; - body.innerHTML += (i + start + 1) + ': '; - var mk = hits[i].getElementsByTagName("title"); - if (mk[0]) - body.innerHTML += mk[0].childNodes[0].nodeValue; - body.innerHTML += '
'; + var tn = hits[i].getElementsByTagName("md-title"); + var title = ''; + var an = hits[i].getElementsByTagName("md-author"); + var author = ''; + + if (tn[0]) { + title = tn[0].childNodes[0].nodeValue; + } else { + title = 'N/A'; + } + if (an[0]) + author = an[0].childNodes[0].nodeValue; + + var record_div = document.createElement('div'); + record_div.className = 'record'; + + var record_cell = create_element('a', title); + record_cell.setAttribute('href', '#'); + record_div.appendChild(record_cell); + if (author) + { + record_div.appendChild(document.createTextNode(', by ')); + record_div.appendChild(document.createTextNode(author)); + } + record_container.appendChild(record_div); } + shown++; if (clients > 0) { @@ -213,6 +304,7 @@ function check_search() "&start=" + document.search.startrec.value + "&num=" + recstoshow + "&session=" + session + + "&sort=" + cur_sort + "&block=1"; xshow = GetXmlHttpObject(); xshow.onreadystatechange=show_records; @@ -222,14 +314,17 @@ function check_search() function refine_query (obj) { + var term = obj.getAttribute('term'); + var cur_termlist = obj.getAttribute('facet'); var query_cell = document.getElementById('query'); - var term = obj.innerHTML; term = term.replace(/[\(\)]/g, ''); + if (cur_termlist == 'subject') query_cell.value += ' and su=(' + term + ')'; else if (cur_termlist == 'author') query_cell.value += ' and au=(' + term + ')'; + start_search(); } @@ -243,6 +338,7 @@ function show_termlist() var i; var xml = xtermlist.responseXML; var body = facet_list[cur_facet][1]; + var facet_name = facet_list[cur_facet][0]; var hits = xml.getElementsByTagName("term"); var clients = Number(xml.getElementsByTagName("activeclients")[0].childNodes[0].nodeValue); @@ -258,15 +354,22 @@ function show_termlist() } else { - body.innerHTML = ''; + clear_cell(body); for (i = 0; i < hits.length; i++) { var namen = hits[i].getElementsByTagName("name"); if (namen[0]) - body.innerHTML += '' + - namen[0].childNodes[0].nodeValue + - ''; + var term = namen[0].childNodes[0].nodeValue; + var refine_cell = create_element('a', term); + refine_cell.setAttribute('href', '#'); + refine_cell.setAttribute('term', term); + refine_cell.setAttribute('facet', facet_name); + refine_cell.onclick = function () { + refine_query(this); + return false; + }; + body.appendChild(refine_cell); } if (clients > 0) @@ -303,7 +406,7 @@ function show_stat() } else { - body.innerHTML = "("; + assign_text(body, '('); for (i = 0; i < nodes.length; i++) { if (nodes[i].nodeType != 1) @@ -312,9 +415,10 @@ function show_stat() if (value == 0) continue; var name = nodes[i].nodeName; - body.innerHTML += ' ' + name + '=' + value; + append_text(body, ' ' + name + '=' + value); } - body.innerHTML += ')'; + + append_text(body, ')'); if (clients > 0) stattimer = setTimeout(check_stat, 2000); } @@ -357,11 +461,6 @@ function start_search() stattimer = 0; clearTimeout(showtimer); showtimer = 0; - if (!targets_loaded) - { - alert("Please load targets first"); - return; - } var query = escape(document.getElementById('query').value); var url = "search.pz2?" + "command=search" + @@ -371,14 +470,12 @@ function start_search() xsearch.onreadystatechange=search_started; xsearch.open("GET", url); xsearch.send(null); -// document.getElementById("termlist").innerHTML = ''; - document.getElementById("body").innerHTML = ''; + clear_cell(document.getElementById("body")); update_history(); shown = 0; document.search.startrec.value = 0; } - function session_encode () { var i; @@ -488,7 +585,7 @@ function toggle_facet (obj) { if (obj.className == 'selected') { obj.className = 'unselected'; - container.style.display = 'block'; + container.style.display = 'inline'; } else { obj.className = 'selected'; container.style.display = 'none';