Bug fix: didn't use correct database(s) when 'all' checkbox was selected.
[egate.git] / www / search.egw
index be30940..a249f6c 100644 (file)
 <html>
 {
-# $Id: search.egw,v 1.3 1995/10/30 17:35:18 adam Exp $
+# $Id: search.egw,v 1.17 1995/11/14 16:01:51 adam Exp $
 
-proc search-response {} {
-    global sessionWait
-    set sessionWait 1
-}
+proc buttons {setNo setMax startPos after} {
+    global sessionId
+    global env
+    global hist
+
+    if {$after && $setMax < [z39.$setNo resultCount]} {
+        html "<p>\n"
+        html "<center>\n"
+        html {<a href="http:} $env(SCRIPT_NAME)
+        html / $sessionId {/search.egw/} $setNo + [expr $setMax + 1]
+        html + [expr $setMax + $hist($setNo,maxPresent)]
+        html {"><img src="/gif/darrw.gif"></a>}
+        html "</center>\n"
+    }
+
+    html "<p>\n"
+    if {$setMax < [z39.$setNo resultCount]} {
+        html {<a href="http:} $env(SCRIPT_NAME)
+        html / $sessionId {/search.egw/} $setNo + [expr $setMax + 1]
+        html + [expr $setMax + $hist($setNo,maxPresent)]
+        html {">Next records</a>} " | \n"
+    }
+    if {$startPos != "" && $startPos != "1"} {
+        html {<a href="http:} $env(SCRIPT_NAME)
+        html / $sessionId {/search.egw/} $setNo 
+        html + [expr $startPos - $hist($setNo,maxPresent)]
+        html + [expr $startPos - 1]
+        html {">Previous records</a>} " | \n"
+    }
+    html {<a href="http:} $env(SCRIPT_NAME)
+    html / $sessionId {/query.egw/} $hist($setNo,host) + $setNo 
+    html {">New query</a>} " | \n"
+
+    html {<a href="http:} $env(SCRIPT_NAME)
+    html / $sessionId {/targets.egw">New target</a>} "<p>\n"
+
+    if {!$after && $startPos != "" && $startPos != "1"} {
+        html "<center>\n"
+        html {<a href="http:} $env(SCRIPT_NAME)
+        html / $sessionId {/search.egw/} $setNo 
+        html + [expr $startPos - $hist($setNo,maxPresent)]
+        html + [expr $startPos - 1]
+        html {"><img src="/gif/uarrw.gif"></a>}
+        html "</center><p>\n"
+    }
 
-proc fail-response {} {
-    global sessionWait
-    set sessionWait -1
 }
 
+    if {[info commands saveState] == ""} {
+        source z39util.tcl
+    }
     global sessionWait
-    z39 callback search-response
-    z39 failback fail-response
-    set sessionWait 0
-    ir-set z39.1 z39
-    z39.1 databaseNames [form base]
-    z39.1 search [form entry1]
-    htmlr {<head><title> WWW/Z39.50 Gateway Search } $t { </title>}
-    htmlr {</head><body>}
-    htmlr {sessionId: } $sessionId {<br>}
-    htmlr {sessionParms: } $sessionParms {<br>}
-    htmlr {form: } [form] { <br>}
-    htmlr {databases: } $databases { <br>}
-    zwait sessionWait
-    if {$sessionWait == 1} {
-         set r [z39.1 resultCount]
-         htmlr {<strong> } $r { hits</strong><br>}
-         htmlr {</body></html>}
+    global nextSetNo
+    global setNo
+    global hist
+
+    set setNo [lindex $sessionParms 0]
+    if {[wform menu1] != ""} {
+        set hist($nextSetNo,idAuthentication) $hist($setNo,idAuthentication)
+        set hist($nextSetNo,host) $hist($setNo,host)
+        set setNo $nextSetNo
+        html "using host " $hist($setNo,host) " <br\n"
+
+        set query [build-query $hist($setNo,host)]
+        if {"x$query" == "x"} {
+            html "<head><title> WWW/Z39.50 Gateway Search</title>\n<body>\n"
+            displayError "Empty query" \
+                "You must specify at least one search word"
+            html "</body></html>\n"
+            wabort
+        }
+        set hist($setNo,query) $query
+
+        set hist($setNo,form,menu1) [wform menu1]
+        set hist($setNo,form,menu2) [wform menu2]
+        set hist($setNo,form,menu3) [wform menu3]
+
+        set hist($setNo,form,entry1) [wform entry1]
+        set hist($setNo,form,entry2) [wform entry2]
+        set hist($setNo,form,entry3) [wform entry3]
+
+        set hist($setNo,form,logic1) [wform logic1]
+        set hist($setNo,form,logic2) [wform logic2]
+
+        incr nextSetNo
+    
+        set host $hist($setNo,host)
+        set databases [lindex $targets($host) 1]
+
+        set b [wform base]
+       if {[wform baseall] != ""} {
+           set hist($setNo,database) $databases
+        } elseif {$b == ""} {
+            set hist($setNo,database) $databases
+        } else {
+            set hist($setNo,database) $b
+        }
+        set hist($setNo,maxPresent) [wform hits]
+        if {$hist($setNo,maxPresent) == ""} {
+            set hist($setNo,maxPresent) 30
+        }
+    }
+    set host $hist($setNo,host)
+    set databases [lindex $targets($host) 1]
+
+    html "<head><title> WWW/Z39.50 Gateway Search " $host " </title>\n"
+    html "</head><body>\n"
+
+    set startPos [lindex $sessionParms 1]
+    set endPos [lindex $sessionParms 2]
+    set setMax 0
+    set setOffset 0
+    if {$startPos == ""} {
+        if {[z39search $setNo 1 0 B] != "1"} {
+            return
+        }
+        set r [z39.$setNo resultCount]
+        html "<h2> Search result $r hits</h2>\n"
+        wflush
+        set setOffset [z39.$setNo numberOfRecordsReturned]
+        display-rec 1 $setOffset display-brief 0
+        incr setOffset
+        set setMax [z39.$setNo resultCount]
+        if {$setMax > $hist($setNo,maxPresent)} {
+            set setMax $hist($setNo,maxPresent)
+        }
     } else {
-        set status [z39.1 searchStatus]
-        set msg [lindex $status 2]
-        set addinfo [lindex $status 3]
-        html {<strong>Search fail: } $msg
-        if ($msg != ""} {
-            html {,} $addinfo
+        if {[z39search $setNo 0 0 B] != "1"} {
+            return 
         }
-        htmlr {</strong><br>}
+        set r [z39.$setNo resultCount]
+        html "<h2> Search result $r hits</h2>\n"
+        wflush
+        set setOffset $startPos
+        set setMax [z39.$setNo resultCount]
+        if {$setMax > $endPos} {
+            set setMax $endPos
+        }
+        if {$setMax > 0} {
+            buttons $setNo $setMax $startPos 0
+        }
+    }
+    if {$setMax > 0} {
+        z39present $setNo 0 $setOffset $setMax display-brief B
     }
 
+    buttons $setNo $setMax $startPos 1
+}
+
+{
+    html "<hr>\n"
+    html "<h3>Debug information</h3>\n"
+    html "sessionId: $sessionId <br>\n"
+    html "sessionParms: $sessionParms <br>\n"
+    foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} {
+        html $e {: } $env($e) {<br>} \n
+    }
+    html "form: " [wform] " <br>\n"
+    html "target: " $host " <br>\n"
+    html "databases: " $hist($setNo,database) " <br>\n"
+    html "selected: " [wform base] " <br>\n"
+    html "query: --" $hist($setNo,query) "-- <br>"
+    html "setNo: " $setNo " <br>\n"
+    html "nextSetNo: " $nextSetNo " <br>\n"
+}
+
+</body>
+</html>