X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=www%2Fdemo%2Fsearch.js;h=c856961e4768693edbb78800797231a54e86900e;hb=5d943bcaa56f11883c2c3d5c79248777bab80a76;hp=ddd41bd500f36c6f27cb93863337006128da1bf5;hpb=2c44badbd3d21622d70fb2ceac2fa96e7cc9e6d7;p=pazpar2-moved-to-github.git diff --git a/www/demo/search.js b/www/demo/search.js index ddd41bd..c856961 100644 --- a/www/demo/search.js +++ b/www/demo/search.js @@ -1,4 +1,4 @@ -/* $Id: search.js,v 1.50 2007-03-20 05:23:06 quinn Exp $ +/* $Id: search.js,v 1.53 2007-04-11 02:11:29 quinn Exp $ * --------------------------------------------------- * Javascript container */ @@ -28,12 +28,13 @@ var cur_sort = "relevance"; var searched = 0; var cur_id = -1; var cur_rec = 0; +var filter = ''; function initialize () { facet_list = get_available_facets(); start_session(); - //session_check(); + session_check(); set_sort(); } @@ -524,7 +525,7 @@ function show_records() record_div.appendChild(record_cell); if (author) { - record_div.appendChild(document.createTextNode(', by ')); + record_div.appendChild(document.createTextNode(' by ')); var al = create_element('a', author); al.setAttribute('href', '#'); al.setAttribute('term', author); @@ -580,6 +581,7 @@ function refine_query (obj) { var term = obj.getAttribute('term'); var cur_termlist = obj.getAttribute('facet'); var query_cell = document.getElementById('query'); + var id = obj.getAttribute('target_id'); term = term.replace(/[\(\)]/g, ''); @@ -589,6 +591,8 @@ function refine_query (obj) { query_cell.value += ' and au="' + term + '"'; else if (cur_termlist == 'date') query_cell.value += ' and date="' + term + '"'; + else if (cur_termlist == 'xtargets') + filter ='pz:id=' + id; start_search(); } @@ -624,25 +628,24 @@ function show_termlists() { var namen = terms[t].getElementsByTagName("name"); var freqn = terms[t].getElementsByTagName("frequency"); + var idn = terms[t].getElementsByTagName("id"); if (namen[0]) { var term = namen[0].childNodes[0].nodeValue; var freq = freqn[0].childNodes[0].nodeValue; - var refine_cell; - if (listname != 'xtargets') - { - refine_cell = create_element('a', term + ' (' + freq + ')'); - refine_cell.setAttribute('href', '#'); - refine_cell.setAttribute('term', term); - refine_cell.setAttribute('facet', listname); - refine_cell.onclick = function () { - refine_query(this); - return false; - }; - } - else - refine_cell = create_element('div', term + ' (' + freq + ')'); - body.appendChild(refine_cell); + var id; + if (idn[0]) + id = idn[0].childNodes[0].nodeValue; + var refine_cell = create_element('a', term + ' (' + freq + ')'); + refine_cell.setAttribute('href', '#'); + refine_cell.setAttribute('term', term); + refine_cell.setAttribute('facet', listname); + refine_cell.setAttribute('target_id', id); + refine_cell.onclick = function () { + refine_query(this); + return false; + }; + body.appendChild(refine_cell); } } } @@ -730,6 +733,11 @@ function search_started() stattimer = setTimeout(check_stat, 1000); } +function clear_filter() +{ + filter = ''; +} + function start_search() { clearTimeout(termtimer); @@ -746,7 +754,8 @@ function start_search() var url = "search.pz2?" + "command=search" + "&session=" + session + - "&query=" + query; + "&query=" + query + + "&filter=" + escape(filter); xsearch = GetXmlHttpObject(); xsearch.onreadystatechange=search_started; xsearch.open("GET", url);