X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=www%2Fdemo%2Fsearch.js;h=edf3c005a66af6f461fc72f6a9900ee53fa11337;hb=df1fd6502c261c3939c5799b23cbb1bf66c13c0c;hp=9ef3be4fe9890046f72446c9128677fa0ecdd98e;hpb=f9130dd792cd1f6d021984a7b58cb5cedffdda07;p=pazpar2-moved-to-github.git diff --git a/www/demo/search.js b/www/demo/search.js index 9ef3be4..edf3c00 100644 --- a/www/demo/search.js +++ b/www/demo/search.js @@ -1,4 +1,4 @@ -/* $Id: search.js,v 1.18 2007-01-11 10:18:38 sondberg Exp $ +/* $Id: search.js,v 1.26 2007-01-16 03:38:50 quinn Exp $ * --------------------------------------------------- * Javascript container */ @@ -10,6 +10,7 @@ var xsearch; var xshow; var xstat; var xtermlist; +var xfetchDetails; var session = false; var targetsloaded = false; var shown; @@ -20,16 +21,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(); } @@ -99,47 +103,6 @@ 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; - } - - assign_text(document.getElementById("targetstatus"), 'Targets loaded'); -} - -function load_targets() -{ - var fn = document.getElementById("targetfilename").value; - clearTimeout(termtimer); - clearTimeout(searchtimer); - clearTimeout(stattimer); - clearTimeout(showtimer); - clear_cell(document.getElementById("stat")); - if (!fn) - { - alert("Please enter a target definition file name"); - return; - } - var url="search.pz2?" + - "command=load" + - "&session=" + session + - "&name=" + fn; - assign_text(document.getElementById("targetstatus"), 'Loading targets...'); - xloadTargets = GetXmlHttpObject(); - xloadTargets.onreadystatechange=targets_loaded; - xloadTargets.open("GET", url); - xloadTargets.send(null); -} - - function update_action (new_action) { document.search.action_type.value = new_action; } @@ -169,8 +132,11 @@ function make_pager (hits, offset, max) { page_elem.className = 'select'; } - page_elem.setAttribute('href', '#'); - page_elem.setAttribute('onclick', 'update_offset(' + off + ')'); + 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); @@ -216,6 +182,122 @@ function assign_text (cell, text) { append_text(cell, text); } +function set_sort_opt(n, opt, str) +{ + var txt = document.createTextNode(str); + if (opt == cur_sort) + n.appendChild(txt); + else + { + var a = document.createElement('a'); + a.appendChild(txt); + a.setAttribute('href', ""); + a.setAttribute('onclick', "set_sort('" + opt + "'); return false"); + n.appendChild(a); + } +} + +function set_sort(sort) +{ + if (sort && sort != cur_sort) + { + cur_sort = sort; + if (searched) + check_search(); + } + + 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 displayname(name) +{ + if (name == 'md-author') + return 'Author'; + else if (name == 'md-subject') + return 'Subject'; + else if (name == 'md-date') + return 'Date'; + else if (name == 'md-isbn') + return 'ISBN'; + else if (name == 'md-publisher') + return 'Publisher'; + else + return name; +} + +function show_details() +{ + if (xfetchDetails.readyState != 4) + return; + var xml = xfetchDetails.responseXML; + var error = xml.getElementsByTagName("error"); + if (error[0]) + { + var msg = error[0].childNodes[0].nodeValue; + alert(msg); + location = "?"; + return; + } + + // This is some ugly display code. Replace with your own ting o'beauty + + var idn = xml.getElementsByTagName('recid'); + if (!idn[0]) + return; + var id = idn[0].childNodes[0].nodeValue; + + var body = document.getElementById('rec_' + id); + if (!body) + return; + clear_cell(body); + //body.appendChild(document.createElement('br')); + var nodes = xml.childNodes[0].childNodes; + var i; + var table = document.createElement('table'); + table.setAttribute('cellpadding', 2); + for (i = 0; i < nodes.length; i++) + { + if (nodes[i].nodeType != 1) + continue; + var name = nodes[i].nodeName; + if (name == 'recid' || name == 'md-title') + continue; + name = displayname(name); + var value = nodes[i].childNodes[0].nodeValue; + var lbl = create_element('b', name ); + var lbln = document.createElement('td'); + lbln.setAttribute('width', 70); + lbln.appendChild(lbl); + var val = create_element('td', value); + var tr = document.createElement('tr'); + tr.appendChild(lbln); + tr.appendChild(val); + table.appendChild(tr); + } + body.appendChild(table); + body.style.display = 'inline'; +} + +function fetch_details(id) +{ + var node = document.getElementById('rec_' + id); + if (node && node.style.display == 'inline') + { + node.style.display = 'none'; + return; + } + if (!session) + return; + var url = "search.pz2?session=" + session + + "&command=record" + + "&id=" + id; + SendXmlHttpObject(xfetchDetails = GetXmlHttpObject(), url, show_details); +} function show_records() { @@ -235,7 +317,6 @@ function show_records() } 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); @@ -249,6 +330,7 @@ function show_records() ' to ' + (start + num) + ' of ' + merged + ' (total hits: ' + total + ')'); + searched = 1; interval.className = 'results'; record_container.className = 'records'; @@ -260,19 +342,47 @@ function show_records() for (i = 0; i < hits.length; i++) { - var mk = hits[i].getElementsByTagName("md-title"); - var field = ''; - - if (mk[0]) { - field = mk[0].childNodes[0].nodeValue; + var tn = hits[i].getElementsByTagName("md-title"); + var title = ''; + var an = hits[i].getElementsByTagName("md-author"); + var author = ''; + var cn = hits[i].getElementsByTagName("count"); + var count = 1; + var idn = hits[i].getElementsByTagName("recid"); + + if (tn[0]) { + title = tn[0].childNodes[0].nodeValue; } else { - field = 'N/A'; + title = 'N/A'; } + if (an[0] && an[0].childNodes[0]) + author = an[0].childNodes[0].nodeValue; + if (cn[0]) + count = Number(cn[0].childNodes[0].nodeValue); + var id = idn[0].childNodes[0].nodeValue; - var record_cell = create_element('a', field); + var record_div = document.createElement('div'); + record_div.className = 'record'; + + var record_cell = create_element('a', title); record_cell.setAttribute('href', '#'); - record_cell.className = 'record'; - record_container.appendChild(record_cell); + record_cell.setAttribute('onclick', 'fetch_details(' + id + '); return false'); + record_div.appendChild(record_cell); + if (author) + { + record_div.appendChild(document.createTextNode(', by ')); + record_div.appendChild(document.createTextNode(author)); + } + if (count > 1) + record_div.appendChild(document.createTextNode( + ' (' + count + ')')); + var det_div = document.createElement('div'); + det_div.style.display = 'none'; + det_div.setAttribute('id', 'rec_' + id); + det_div.appendChild(document.createElement('br')); + det_div.appendChild(document.createTextNode('Hugo')); + record_div.appendChild(det_div); + record_container.appendChild(record_div); } shown++; @@ -296,6 +406,7 @@ function check_search() "&start=" + document.search.startrec.value + "&num=" + recstoshow + "&session=" + session + + "&sort=" + cur_sort + "&block=1"; xshow = GetXmlHttpObject(); xshow.onreadystatechange=show_records; @@ -305,14 +416,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(); } @@ -326,6 +440,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); @@ -346,11 +461,18 @@ function show_termlist() for (i = 0; i < hits.length; i++) { var namen = hits[i].getElementsByTagName("name"); + var freqn = hits[i].getElementsByTagName("frequency"); if (namen[0]) - var refine_cell = create_element('a', - namen[0].childNodes[0].nodeValue); + var term = namen[0].childNodes[0].nodeValue; + var freq = freqn[0].childNodes[0].nodeValue; + var refine_cell = create_element('a', term + ' (' + freq + ')'); refine_cell.setAttribute('href', '#'); - refine_cell.setAttribute('onclick', 'refine_query(this)'); + refine_cell.setAttribute('term', term); + refine_cell.setAttribute('facet', facet_name); + refine_cell.onclick = function () { + refine_query(this); + return false; + }; body.appendChild(refine_cell); } @@ -443,11 +565,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" + @@ -463,7 +580,6 @@ function start_search() document.search.startrec.value = 0; } - function session_encode () { var i;