Metadata elements dynamically created from XSLT normalization output.
[pazpar2-moved-to-github.git] / www / test1 / search.js
index 24f29bf..5d25b70 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: search.js,v 1.2 2006-12-29 10:29:46 sondberg Exp $
+/* $Id: search.js,v 1.9 2007-01-08 18:32:35 quinn Exp $
  * ---------------------------------------------------
  * Javascript container
  */
@@ -17,11 +17,11 @@ var searchtimer;
 var showtimer;
 var termtimer;
 var stattimer;
-var startrec;
-var session_cells = Array('query');
+var session_cells = Array('query', 'startrec', 'action_type');
 var old_session = session_read();
 var url_surveillence;
-
+var recstoshow = 15;
+var cur_termlist = "subject";
 
 function initialize ()
 {
@@ -44,6 +44,13 @@ function GetXmlHttpObject()
     return objXMLHttp
 } 
 
+function SendXmlHttpObject(obj, url, handler)
+{
+    obj.onreadystatechange=handler;
+    obj.open("GET", url);
+    obj.send(null);
+}
+
 function session_started()
 {
     if (xinitSession.readyState != 4)
@@ -52,6 +59,7 @@ function session_started()
     var sesid = xml.getElementsByTagName("session")[0].childNodes[0].nodeValue;
     document.getElementById("status").innerHTML = "Live";
     session = sesid;
+    setTimeout(ping_session, 50000);
 }
 
 function start_session()
@@ -66,6 +74,30 @@ function start_session()
     //url_surveillence = setInterval(session_check, 200);
 }
 
+function ping_session()
+{
+    if (!session)
+       return;
+    var url = "search.pz2?command=ping&session=" + session;
+    SendXmlHttpObject(xpingSession = GetXmlHttpObject(), url, session_pinged);
+}
+
+function session_pinged()
+{
+    if (xpingSession.readyState != 4)
+       return;
+    var xml = xpingSession.responseXML;
+    var error = xml.getElementsByTagName("error");
+    if (error[0])
+    {
+       var msg = error[0].childNodes[0].nodeValue;
+       alert(msg);
+       location = "?";
+       return;
+    }
+    setTimeout(ping_session, 50000);
+}
+
 function targets_loaded()
 {
     if (xloadTargets.readyState != 4)
@@ -105,6 +137,12 @@ function load_targets()
     xloadTargets.send(null);
 }
 
+
+function update_action (new_action) {
+    document.search.action_type.value = new_action;
+}
+
+
 function show_records()
 {
     if (xshow.readyState != 4)
@@ -125,35 +163,41 @@ function show_records()
        var merged = Number(xml.getElementsByTagName('merged')[0].childNodes[0].nodeValue);
        var start = Number(xml.getElementsByTagName('start')[0].childNodes[0].nodeValue);
        var num = Number(xml.getElementsByTagName('num')[0].childNodes[0].nodeValue);
+       var clients = Number(xml.getElementsByTagName("activeclients")[0].childNodes[0].nodeValue);
        body.innerHTML = '<b>Records : ';
        body.innerHTML += (start + 1) + ' to ' + (start + num) +
                ' of ' + merged + ' (total hits: ' + total + ')</b>';
 
        if (start + num < merged)
            body.innerHTML += ' <a href="" ' +
-               'onclick="startrec=' + (start + 20) +
-               ';check_search(); return false;">Next</a>';
+               'onclick="document.search.startrec.value=' + (start + recstoshow) +
+                ";update_action('page')" +
+               ';check_search(); update_history(); return false;">Next</a>';
 
        if (start > 0)
            body.innerHTML += ' <a href="" ' +
-               'onclick="startrec=' + (start - 20) +
-               ';check_search(); return false;">Previous</a>';
+               'onclick="document.search.startrec.value=' + (start - recstoshow) +
+                ";update_action('page')" +
+               ';check_search(); update_history();return false;">Previous</a>';
 
        body.innerHTML += '<br/>';
        for (i = 0; i < hits.length; i++)
        {
            body.innerHTML += '<p>';
            body.innerHTML += (i + start + 1) + ': ';
-           var mk = hits[i].getElementsByTagName("title");
+           var mk = hits[i].getElementsByTagName("md-title");
            if (mk[0])
                body.innerHTML += mk[0].childNodes[0].nodeValue;
            body.innerHTML += '</p>';
        }
        shown++;
-       if (shown < 5)
-           searchtimer = setTimeout(check_search, 1000);
-       else
-           searchtimer = setTimeout(check_search, 2000);
+       if (clients > 0)
+       {
+           if (shown < 5)
+               searchtimer = setTimeout(check_search, 1000);
+           else
+               searchtimer = setTimeout(check_search, 2000);
+       }
     }
     if (!termtimer)
        termtimer = setTimeout(check_termlist, 1000);
@@ -164,8 +208,8 @@ function check_search()
     clearTimeout(searchtimer);
     var url = "search.pz2?" +
         "command=show" +
-       "&start=" + startrec +
-       "&num=15" +
+       "&start=" + document.search.startrec.value +
+       "&num=" + recstoshow +
        "&session=" + session +
        "&block=1";
     xshow = GetXmlHttpObject();
@@ -177,13 +221,46 @@ function check_search()
 
 function refine_query (obj) {
     var query_cell = document.getElementById('query');
-    var subject = obj.innerHTML;
+    var term = obj.innerHTML;
     
-    subject = subject.replace(/[\(\)]/g, '');
-    query_cell.value += ' and su=(' + subject + ')';
+    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();
 }
 
+function set_termlist(termlist)
+{
+    cur_termlist = termlist;
+    check_termlist();
+    if (termtimer)
+    {
+       clearTimeout(termtimer);
+       termtimer = 0;
+    }
+}
+
+function show_termlistoptions(body)
+{
+    var opts = Array(
+        Array('subject', 'Subject'),
+       Array('author', 'Author')
+    );
+
+    for (i in opts)
+    {
+       if (opts[i][0] == cur_termlist)
+           body.innerHTML += opts[i][1];
+       else
+           body.innerHTML += '<a href="" onclick="set_termlist(\'' + opts[i][0] +
+               '\'); return false">' + opts[i][1] + '</a>';
+       body.innerHTML += ' ';
+    }
+    body.innerHTML += '<p>';
+}
+
 function show_termlist()
 {
     if (xtermlist.readyState != 4)
@@ -193,14 +270,16 @@ function show_termlist()
     var xml = xtermlist.responseXML;
     var body = document.getElementById("termlist");
     var hits = xml.getElementsByTagName("term");
+    var clients =
+       Number(xml.getElementsByTagName("activeclients")[0].childNodes[0].nodeValue);
     if (!hits[0])
     {
        termtimer = setTimeout(check_termlist, 1000);
-        
     }
     else
     {
        body.innerHTML = "<b>Limit results:</b><br>";
+       show_termlistoptions(body);
        for (i = 0; i < hits.length; i++)
        {
            var namen = hits[i].getElementsByTagName("name");
@@ -210,16 +289,17 @@ function show_termlist()
                                   '</a>';
            body.innerHTML += '<br>';
        }
-       termtimer = setTimeout(check_termlist, 2000);
+       if (clients > 0)
+           termtimer = setTimeout(check_termlist, 2000);
     }
 }
 
-
 function check_termlist()
 {
     var url = "search.pz2?" +
         "command=termlist" +
-       "&session=" + session;
+       "&session=" + session +
+       "&name=" + cur_termlist;
     xtermlist = GetXmlHttpObject();
     xtermlist.onreadystatechange=show_termlist;
     xtermlist.open("GET", url);
@@ -234,6 +314,8 @@ function show_stat()
     var xml = xstat.responseXML;
     var body = document.getElementById("stat");
     var nodes = xml.childNodes[0].childNodes;
+    var clients =
+       Number(xml.getElementsByTagName("activeclients")[0].childNodes[0].nodeValue);
     if (!nodes[0])
     {
        stattimer  = setTimeout(check_stat, 500);
@@ -252,7 +334,8 @@ function show_stat()
            body.innerHTML += ' ' + name + '=' + value;
        }
        body.innerHTML += ')';
-       stattimer = setTimeout(check_stat, 2000);
+       if (clients > 0)
+           stattimer = setTimeout(check_stat, 2000);
     }
 }
 
@@ -311,7 +394,7 @@ function start_search()
     document.getElementById("body").innerHTML = '';
     update_history();
     shown = 0;
-    startrec = 0;
+    document.search.startrec.value = 0;
 }
 
 
@@ -373,14 +456,22 @@ function update_history ()
 function session_check ()
 {
     var session = session_read();
+    var action = document.search.action_type.value;
 
     clearInterval(url_surveillence);
 
     if ( session != unescape(old_session) )
     {
         session_restore(session);
-        start_search();
-        
+
+        if (action == 'search') {
+            start_search();
+        } else if (action == 'page') {
+            check_search();
+        } else {
+            alert('Unregocnized action_type: ' + action);
+            return;
+        }
     }
     
     url_surveillence = setInterval(session_check, 200);