X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=www%2Fdemo%2Fsearch.js;h=c856961e4768693edbb78800797231a54e86900e;hb=156df7c9bf0766a922b3611e7f5cbc1697788087;hp=1c521ac21c07b7e96ba74079375bee4d83c50814;hpb=5240c2b4328c8bfedbe5b976a828a548620f34d2;p=pazpar2-moved-to-github.git diff --git a/www/demo/search.js b/www/demo/search.js index 1c521ac..c856961 100644 --- a/www/demo/search.js +++ b/www/demo/search.js @@ -1,4 +1,4 @@ -/* $Id: search.js,v 1.47 2007-02-06 23:22:49 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(); } @@ -338,6 +339,15 @@ function paint_data_elements(target, node) nv.appendChild(link); } + else if (name == 'md-isbn') + { + nv = document.createElement('span'); + nv.appendChild(document.createTextNode(value + ' ')); + var link = create_element('a', 'search OpenWorldCat'); + link.setAttribute('target', '_blank'); + link.setAttribute('href', 'http://www.worldcat.org/search?q=isbn%3A' + value); + nv.appendChild(link); + } else nv = document.createTextNode(value); dn.appendChild(nv); @@ -515,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); @@ -571,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, ''); @@ -580,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(); } @@ -615,18 +628,25 @@ 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 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); + } } } if (clients > 0) @@ -713,6 +733,11 @@ function search_started() stattimer = setTimeout(check_stat, 1000); } +function clear_filter() +{ + filter = ''; +} + function start_search() { clearTimeout(termtimer); @@ -729,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);