3 <title>mikers experimental opensearch portal</title>
7 font-family: verdana,arial,helvetica,sans-serif;
14 text-decoration: none;
22 border: dotted blue 1px;
26 border: solid black 1px;
30 border: solid lightblue 1px;
31 background-color: lightblue;
36 text-decoration: none;
41 text-decoration: underline;
46 text-decoration: underline;
51 text-decoration: none;
68 border-collapse: collapse;
69 border: solid gray 1px;
73 border-collapse: collapse;
77 max-width: 300px !important;
78 min-width: 200px !important;
82 max-width: 100% !important;
86 max-width: 100% !important;
87 min-width: 400px !important;
91 border-bottom: 1px dashed darkgrey;
104 function create_requestor () {
107 req = new ActiveXObject("Msxml2.XMLHTTP");
111 req = new ActiveXObject("Microsoft.XMLHTTP");
118 if (!req && typeof XMLHttpRequest!='undefined') {
119 req = new XMLHttpRequest();
123 alert("NEEDS NEWER JAVASCRIPT for XMLHTTPRequest()");
130 var proxy = 'http://gapines.org/opensearch/?fetch=';
133 var search_templates = [];
134 var search_urls = {};
137 var current_startPage = 1;
138 var current_startIndex = 1;
139 var current_count = 5;
141 function opensearch ( term, reset ) {
144 current_startPage = 1;
148 document.getElementById('next_button').className = 'hide';
150 if (current_startPage == 1)
151 document.getElementById('prev_button').className = 'hide';
153 document.getElementById('prev_button').className = '';
155 var tot = document.getElementById('total');
156 while (tot.lastChild)
157 tot.removeChild(tot.lastChild);
159 var src = document.getElementById('result_sources');
160 while (src.lastChild)
161 src.removeChild(src.lastChild);
163 document.getElementById('int_res_hide').className = 'noshow';
164 document.getElementById('col_res_hide').className = 'noshow';
166 var tab = document.getElementById('int_res');
167 while (tab.lastChild)
168 tab.removeChild(tab.lastChild);
170 tab = document.getElementById('col_res');
171 while (tab.lastChild)
172 tab.removeChild(tab.lastChild);
176 var sources = new Array();
177 var selector = document.getElementsByName('source');
178 for (var i = 0; i < selector.length; i++) {
179 if (selector[i].checked) {
180 sources.push(selector[i].value);
184 search_templates = [];
185 for (var i in sources) {
186 create_search( sources[i] );
189 current_startIndex = (current_count * (current_startPage - 1)) + 1;
192 for (var i in search_templates) {
193 if (!search_templates[i])
199 var url = search_templates[i].replace(/\{searchTerms\}/,encodeURIComponent(term));
200 url = url.replace(/\{startPage\}/,current_startPage);
201 url = url.replace(/\{startIndex\}/,current_startIndex);
202 url = url.replace(/\{count\}/,current_count);
203 url = url.replace(/\{relevanceScale}/,rel_scales[i]);
204 search_urls[i] = proxy + encodeURIComponent(url);
206 src.innerHTML += '<a href="' + url + '">' + url + '</a><br>';
209 for (var i in search_urls) {
210 if (!search_templates[i])
216 document.getElementById('page_label').innerHTML = current_startPage;
219 function perform_search ( source ) {
220 var req = create_requestor();
222 req.onreadystatechange = function () {
223 if (req.readyState != 4)
226 var xml = req.responseXML;
228 var desc = getElementTextNS('','description',xml,0);
229 var xml_link = getElementTextNS('','link',xml,0);
231 var total = getElementFloatNS('openSearch','totalResults',xml,0);
232 var integratible = (getElementNS('openIll','relevance',xml,0) != null);
233 var scale = getElementFloatNS('openIll','relevanceScale',xml,0);
235 rel_scales[source] = scale;
237 var current_tot = getElementFloatNS('','span',document.getElementById('total').parentNode,0);
238 var tot = document.getElementById('total');
243 if (total > (current_startPage * current_count))
244 document.getElementById('next_button').className = '';
247 tot.innerHTML = current_tot;
249 var list = xml.getElementsByTagName('item');
250 for (var i = 0; i < list.length; i++) {
252 if ( typeof list[i] != 'object')
257 tab = document.getElementById('col_res');
258 document.getElementById('col_res_hide').className = '';
259 var col = document.getElementById(source);
261 var row = tab.rows[0];
263 row = tab.insertRow(0);
265 col = document.createElement('td');
266 col.setAttribute('id',source);
267 row.appendChild(col);
269 tab = document.createElement('table');
270 tab.setAttribute('valign','top');
271 tab.setAttribute('class','col_tab');
273 var cap = document.createElement('caption');
274 tab.appendChild(cap);
275 cap.innerHTML = desc + ' -- <a href="' + xml_link + '">XML</a>';
277 col.appendChild(tab);
279 var per = parseInt(100 / (search_urls.length * 2)) - 1;
280 col.setAttribute('valign','top');
281 col.setAttribute('width', + per + '%');
284 tab = col.firstChild;
287 tab = document.getElementById('int_res');
288 document.getElementById('int_res_hide').className = '';
291 if (!tab.rows.length) {
292 add_result_row(tab, 0, list[i], source);
294 for (var j = 0; j < tab.rows.length; j++) {
295 if ( typeof tab.rows[j] != 'object')
300 rank = getElementFloatNS('openIll','relevance',list[i],0);
302 alert("error getting float relevance: " + e);
306 if ( rank < parseFloat(tab.rows[j].firstChild.firstChild.textContent) ) {
307 if ( (j + 1) == tab.rows.length) {
308 add_result_row(tab, tab.rows.length, list[i], source);
313 add_result_row(tab, j, list[i], source);
320 req.open('GET', proxy + encodeURIComponent(search_urls[source]), true);
325 // retrieve float of an XML document element, including
326 // elements using namespaces
327 function getElementFloatNS(prefix, local, parentElem, index) {
328 var result = getElementNS(prefix, local, parentElem, index);
330 // get text, accounting for possible
331 // whitespace (carriage return) text nodes
332 if (result.childNodes.length > 1) {
333 return parseFloat(result.childNodes[1].nodeValue);
335 return parseFloat(result.textContent);
342 function getElementNS(prefix, local, parentElem, index) {
344 if (prefix && isIE) {
345 // IE/Windows way of handling namespaces
346 return parentElem.getElementsByTagName(prefix + ":" + local)[index];
348 // the namespace versions of this method
349 // (getElementsByTagNameNS()) operate
350 // differently in Safari and Mozilla, but both
351 // return value with just local name, provided
352 // there aren't conflicts with non-namespace element
354 return parentElem.getElementsByTagName(local)[index];
358 // retrieve text of an XML document element, including
359 // elements using namespaces
360 function getElementTextNS(prefix, local, parentElem, index) {
361 var result = getElementNS(prefix, local, parentElem, index);
363 // get text, accounting for possible
364 // whitespace (carriage return) text nodes
365 if (result.childNodes.length > 1) {
366 return result.childNodes[1].nodeValue;
368 return result.firstChild.nodeValue;
375 function add_result_row (tab, index, xml, source) {
376 var img = images[source];
377 var rank,title,tlink,desc;
380 rank = getElementFloatNS('openIll','relevance',xml,0);
382 alert("error getting relevance: " + e);
387 title = getElementTextNS('','title',xml,0);
393 tlink = getElementTextNS('','link',xml,0);
399 description = getElementTextNS('','description',xml,0);
400 if (description.length > 1024)
401 description = description.substring(1,1024);
406 var row = tab.insertRow(index);
407 row.className = 'res_tr';
408 row.innerHTML = '<td style="padding: 4px"><div style="display: none; visibility: hidden;">' + rank +
409 '</div><span class="title_link"><a href="' + tlink + '">' + title +
410 '</a></span><br/><span class="desc_text">' + description + '</span></td>' +
411 '<td><img title="' + parseInt(rank) + '% Relevant" width="32" height="32" src="' + img + '"></td>';
414 function create_search ( s ) {
415 var req = create_requestor();
417 req.open('GET',proxy + encodeURIComponent(s),false);
421 var xml = req.responseXML;
422 search_templates[s] = xml.getElementsByTagName('Url')[0].textContent;
423 var i = xml.getElementsByTagName('Image');
425 images[s] = i[0].textContent;
427 alert('BAD XML!\n\n' + e + '\n\n' + req.responseText);
428 search_templates[s] = null;
441 <td align="left">Keyword Search:
442 <input type="text" id="term" value="javascript"/>
443 <input type="submit" value="Go!" onclick="opensearch(document.getElementById('term').value, true); return false;"/>
445 <td align="right">Hits per Source:
446 <select onchange="current_count=this.options[this.selectedIndex].value;">
447 <option value="5" selected>5</option>
448 <option value="10">10</option>
449 <option value="25">25</option>
454 <td colspan=2>Sources:
455 <label class="source_input"><input name="source" type="checkbox" value="http://gapines.org/opensearch.xml" checked>GPLS Pines</label>
456 <label class="source_input"><input name="source" type="checkbox" value="http://rsinger.library.gatech.edu/opensearch/osdd-gil.xml" checked>GIL Universal Catalog</label>
457 <label class="source_input"><input name="source" type="checkbox" value="http://search.athenscounty.lib.oh.us/cgi-bin/koha/opensearchdescription">NPL/Koha</label>
458 <label class="source_input"><input name="source" type="checkbox" value="http://www.koders.com/search/KodersSourceCodeSearchDescription.xml">Koders Source Code</label>
459 <label class="source_input"><input name="source" type="checkbox" value="http://cnx.rice.edu/content/opensearchdescription">rice.edu Connexions</label>
460 <label class="source_input"><input name="source" type="checkbox" value="http://redlightgreen.com/ucwprod/web/opensearchDescription.xml">RedLightGreen</label>
461 <label class="source_input"><input name="source" type="checkbox" value="http://www.itpapers.com/itpaperssearchdescription.xml">ITPapers</label>
462 <!-- <input name="source" type="checkbox" value="http://www.webdevref.com/blog/opensearchdescription.xml">WebDefRef -->
468 <div>Total results: <span id="total"/></div>
469 <div>Current page: <span id="page_label"></span> --
470 <button class='hide' id='prev_button' onclick="if (this.className != 'hide') {current_startPage -= 1; opensearch(document.getElementById('term').value);}">Previous Page</button>
472 <button class='hide' id='next_button' onclick="if (this.className != 'hide') {current_startPage += 1; opensearch(document.getElementById('term').value);}">Next Page</button>
476 <table id="results" width="100%">
478 <td id="int_res_hide" class="noshow" width="100%">
480 <caption class="header">Merged search results</caption>
483 <table id='int_res' class="res_table" width="100%"></table>
488 <td id='col_res_hide' class="noshow">
490 <caption class="header">Unranked search results</caption>
493 <table id='col_res' class="res_table"></table>
500 <div id="result_sources"></div>