9360c468248cb841ecf59c57639459bcf7599fb2
[pazpar2-moved-to-github.git] / www / test1 / index.html
1 <html>
2
3 <head>
4 <style type="text/css">
5
6 </style>
7
8 <script>
9 var xmlHttp
10 var xinitSession;
11 var xloadTargets;
12 var xsearch;
13 var xshow;
14 var xstat;
15 var xtermlist;
16 var session = false;
17 var targetsloaded = false;
18 var shown;
19 var searchtimer;
20 var showtimer;
21 var termtimer;
22 var stattimer;
23 var startrec;
24
25 function GetXmlHttpObject()
26
27     var objXMLHttp=null
28     if (window.XMLHttpRequest)
29       {
30       objXMLHttp=new XMLHttpRequest()
31       }
32     else if (window.ActiveXObject)
33       {
34       objXMLHttp=new ActiveXObject("Microsoft.XMLHTTP")
35       }
36     return objXMLHttp
37
38
39 function session_started()
40 {
41     if (xinitSession.readyState != 4)
42         return;
43     var xml = xinitSession.responseXML;
44     var sesid = xml.getElementsByTagName("session")[0].childNodes[0].nodeValue;
45     document.getElementById("status").innerHTML = "Live";
46     session = sesid;
47 }
48
49 function start_session()
50 {
51     xinitSession = GetXmlHttpObject();
52     var url="search.pz2?";
53     url += "command=init";
54     xinitSession.onreadystatechange=session_started;
55     xinitSession.open("GET", url);
56     xinitSession.send(null);
57 }
58
59 function targets_loaded()
60 {
61     if (xloadTargets.readyState != 4)
62         return;
63     var xml = xloadTargets.responseXML;
64     var error = xml.getElementsByTagName("error");
65     if (error[0])
66     {
67         var msg = error[0].childNodes[0].nodeValue;
68         alert(msg);
69         return;
70     }
71     document.getElementById("targetstatus").innerHTML = "Targets loaded";
72 }
73
74 function load_targets()
75 {
76     var fn = document.getElementById("targetfilename").value;
77     clearTimeout(termtimer);
78     clearTimeout(searchtimer);
79     clearTimeout(stattimer);
80     clearTimeout(showtimer);
81     document.getElementById("stat").innerHTML = "";
82     if (!fn)
83     {
84         alert("Please enter a target definition file name");
85         return;
86     }
87     var url="search.pz2?" +
88         "command=load" +
89         "&session=" + session +
90         "&name=" + fn;
91     document.getElementById("targetstatus").innerHTML = "Loading targets...";
92     xloadTargets = GetXmlHttpObject();
93     xloadTargets.onreadystatechange=targets_loaded;
94     xloadTargets.open("GET", url);
95     xloadTargets.send(null);
96 }
97
98 function show_records()
99 {
100     if (xshow.readyState != 4)
101         return;
102     var i;
103     var xml = xshow.responseXML;
104     var body = document.getElementById("body");
105     var hits = xml.getElementsByTagName("hit");
106     if (!hits[0]) // We should never get here with blocking operations
107     {
108         body.innerHTML = "No records yet";
109         searchtimer = setTimeout(check_search, 250);
110     }
111     else
112     {
113
114         var total = Number(xml.getElementsByTagName('total')[0].childNodes[0].nodeValue);
115         var merged = Number(xml.getElementsByTagName('merged')[0].childNodes[0].nodeValue);
116         var start = Number(xml.getElementsByTagName('start')[0].childNodes[0].nodeValue);
117         var num = Number(xml.getElementsByTagName('num')[0].childNodes[0].nodeValue);
118         body.innerHTML = '<b>Records : ';
119         body.innerHTML += (start + 1) + ' to ' + (start + num) +
120                 ' of ' + merged + ' (total hits: ' + total + ')</b>';
121
122         if (start + num < merged)
123             body.innerHTML += ' <a href="" ' +
124                 'onclick="startrec=' + (start + 20) +
125                 ';check_search(); return false;">Next</a>';
126
127         if (start > 0)
128             body.innerHTML += ' <a href="" ' +
129                 'onclick="startrec=' + (start - 20) +
130                 ';check_search(); return false;">Previous</a>';
131
132         body.innerHTML += '<br/>';
133         for (i = 0; i < hits.length; i++)
134         {
135             body.innerHTML += '<p>';
136             body.innerHTML += (i + start + 1) + ': ';
137             var mk = hits[i].getElementsByTagName("title");
138             if (mk[0])
139                 body.innerHTML += mk[0].childNodes[0].nodeValue;
140             body.innerHTML += '</p>';
141         }
142         shown++;
143         if (shown < 5)
144             searchtimer = setTimeout(check_search, 1000);
145         else
146             searchtimer = setTimeout(check_search, 2000);
147     }
148     if (!termtimer)
149         termtimer = setTimeout(check_termlist, 1000);
150 }
151
152 function check_search()
153 {
154     clearTimeout(searchtimer);
155     var url = "search.pz2?" +
156         "command=show" +
157         "&start=" + startrec +
158         "&session=" + session +
159         "&block=1";
160     xshow = GetXmlHttpObject();
161     xshow.onreadystatechange=show_records;
162     xshow.open("GET", url);
163     xshow.send(null);
164 }
165
166
167 function refine_query (obj) {
168     var query_cell = document.getElementById('query');
169     var subject = obj.innerHTML;
170     
171     subject = subject.replace(/[\(\)]/g, '');
172     query_cell.value += ' and su=(' + subject + ')';
173     start_search();
174 }
175
176 function show_termlist()
177 {
178     if (xtermlist.readyState != 4)
179         return;
180
181     var i;
182     var xml = xtermlist.responseXML;
183     var body = document.getElementById("termlist");
184     var hits = xml.getElementsByTagName("term");
185     if (!hits[0])
186     {
187         termtimer = setTimeout(check_termlist, 1000);
188         
189     }
190     else
191     {
192         body.innerHTML = "<b>Limit results:</b><br>";
193         for (i = 0; i < hits.length; i++)
194         {
195             var namen = hits[i].getElementsByTagName("name");
196             if (namen[0])
197                 body.innerHTML += '<a href="#" onclick="refine_query(this)">' +
198                                   namen[0].childNodes[0].nodeValue +
199                                   '</a>';
200             /*
201             body.innerHTML += ' (';
202             var freqn = hits[i].getElementsByTagName("frequency");
203             if (freqn[0])
204                 body.innerHTML += freqn[0].childNodes[0].nodeValue;
205             body.innerHTML += ')<br>';
206             */
207             body.innerHTML += '<br>';
208         }
209         termtimer = setTimeout(check_termlist, 2000);
210     }
211 }
212
213
214 function check_termlist()
215 {
216     var url = "search.pz2?" +
217         "command=termlist" +
218         "&session=" + session;
219     xtermlist = GetXmlHttpObject();
220     xtermlist.onreadystatechange=show_termlist;
221     xtermlist.open("GET", url);
222     xtermlist.send(null);
223 }
224
225 function show_stat()
226 {
227     if (xstat.readyState != 4)
228         return;
229     var i;
230     var xml = xstat.responseXML;
231     var body = document.getElementById("stat");
232     var nodes = xml.childNodes[0].childNodes;
233     if (!nodes[0])
234     {
235         stattimer  = setTimeout(check_stat, 500);
236     }
237     else
238     {
239         body.innerHTML = "(";
240         for (i = 0; i < nodes.length; i++)
241         {
242             if (nodes[i].nodeType != 1)
243                 continue;
244             var value = nodes[i].childNodes[0].nodeValue;
245             if (value == 0)
246                 continue;
247             var name = nodes[i].nodeName;
248             body.innerHTML += ' ' + name + '=' + value;
249         }
250         body.innerHTML += ')';
251         stattimer = setTimeout(check_stat, 2000);
252     }
253 }
254
255 function check_stat()
256 {
257     var url = "search.pz2?" +
258         "command=stat" +
259         "&session=" + session;
260     xstat = GetXmlHttpObject();
261     xstat.onreadystatechange=show_stat;
262     xstat.open("GET", url);
263     xstat.send(null);
264 }
265
266 function search_started()
267 {
268     if (xsearch.readyState != 4)
269         return;
270     var xml = xsearch.responseXML;
271     var error = xml.getElementsByTagName("error");
272     if (error[0])
273     {
274         var msg = error[0].childNodes[0].nodeValue;
275         alert(msg);
276         return;
277     }
278     check_search();
279     stattimer = setTimeout(check_stat, 1000);
280 }
281
282 function start_search()
283 {
284     clearTimeout(termtimer);
285     termtimer = 0;
286     clearTimeout(searchtimer);
287     searchtimer = 0;
288     clearTimeout(stattimer);
289     stattimer = 0;
290     clearTimeout(showtimer);
291     showtimer = 0;
292     if (!targets_loaded)
293     {
294         alert("Please load targets first");
295         return;
296     }
297     var query = escape(document.getElementById('query').value);
298     var url = "search.pz2?" +
299         "command=search" +
300         "&session=" + session +
301         "&query=" + query;
302     xsearch = GetXmlHttpObject();
303     xsearch.onreadystatechange=search_started;
304     xsearch.open("GET", url);
305     xsearch.send(null);
306     document.getElementById("termlist").innerHTML = '';
307     document.getElementById("body").innerHTML = '';
308     shown = 0;
309     startrec = 0;
310 }
311
312 </script>
313 </head>
314
315 <body onload="start_session();">
316
317 <table width="100%" border="1" cellpadding="5">
318     <tr>
319         <td width="250" height="100" align="center">
320             <font size="+2"><b>MasterKey mk I</b></font>
321         </td>
322
323         <td>
324             <form onsubmit="start_search(); return false;">
325                 <b>Search:</b> <input id="query" type="text" size="50"/>
326                 <input type="submit" value="Go"/>
327             </form>
328
329         <td>
330     </tr>
331
332     <tr>
333         <td valign="top" id="termlist">&nbsp;</td>
334
335         <td valign="top" id="body">
336         Funky search prototype.<br><br><br><br>
337         <td>
338     </tr>
339
340     <tr>
341         <td>
342         &nbsp;
343             <!-- 
344             <form onsubmit="load_targets(); return false;">
345                 Target file:<br/>
346                 <input type="text" id="targetfilename" size="20"/>
347                 <input type="submit"  value="load" />
348             </form>
349             -->
350         </td>
351
352         <td>
353             Status: <span id="status">Initializing</span> <span id="targetstatus"></span><br/><span id="stat"></span>
354         </td>
355
356     </tr>
357
358 </table>
359
360 </body>
361 </html>