</head>
<body>
{
-# $Id: query.egw,v 1.6 1995/10/31 16:56:23 adam Exp $
+# $Id: query.egw,v 1.26 1996/01/08 08:42:15 adam Exp $
+
+ if {[info commands saveState] == ""} {
+ source z39util.tcl
+ }
+
proc fail-response {} {
global sessionWait
set sessionWait -1
set sessionWait 1
}
- global host
- set host $sessionParms
- set databases [lindex $targets($host) 1]
- catch {z39 disconnect}
- set sessionWait 0
- ir z39
- z39 failback fail-response
+ global setNo
+ global nextSetNo
+ global hist
+
+ set host [lindex $sessionParms 0]
+ set initSet [lindex $sessionParms 1]
+ set scanLine [lindex $sessionParms 2]
+ set scanTerm [lrange $sessionParms 3 end]
+
+ if {[catch {set setNo $nextSetNo}]} {
+ set nextSetNo 1
+ set setNo 1
+ }
+ if {[catch {set oldHost [z39 connect]}]} {
+ set oldHost ""
+ }
+
+ set hist($setNo,host) $host
+ set hist($setNo,idAuthentication) [lindex $targets($host) 3]
+
+ if {[catch {z39 failback fail-response}]} {
+ ir z39
+ }
+
+ html "<h2>Search in " [lindex $targets($host) 0] "</h2>\n"
z39 callback ok-response
- if {[catch {z39 connect $host}]} {
- htmlr "Cannot connect to target ${host} <br>"
- htmlr "</body></html>"
- wabort
- } elseif {$sessionWait == 0} {
- zwait sessionWait
- if {$sessionWait != 1} {
- htmlr "Cannot connect to target ${host} <br>"
+ z39 failback fail-response
+ if {$host != $oldHost} {
+ catch {z39 disconnect}
+
+ set sessionWait 0
+ if {[catch {z39 connect $host}]} {
+ displayError "Cannot connect to target ${host}" {}
+ html "</body></html>\n"
+ z39 disconnect
+ wabort
+ } elseif {$sessionWait == 0} {
+ if {[catch {zwait sessionWait 35}]} {
+ displayError "Cannot connect to target ${host}" {}
+ html "</body></html>\n"
+ z39 disconnect
+ wabort
+ }
+ if {$sessionWait != 1} {
+ displayError "Cannot connect to target ${host}" {}
+ html "</body></html>\n"
+ z39 disconnect
+ wabort
+ }
+ }
+ set sessionWait 0
+ z39 idAuthentication $hist($setNo,idAuthentication)
+ if {[catch {z39 init}]} {
+ displayError "Cannot initialize target ${host}" {}
+ html "</body></html>\n"
+ wabort
+ }
+ if {[catch {zwait sessionWait 60}]} {
+ displayError "Cannot initialize target ${host}" {}
+ html "</body></html>\n"
+ wabort
+ }
+ if {$sessionWait != "1"} {
+ displayError "Cannot initialize target ${host}" {}
+ htmlr "</body></html>\n"
+ wabort
+ }
+ if {![z39 initResult]} {
+ displayError "Connection rejected by target ${host}" \
+ [z39 userInformationField]
+ z39 disconnect
htmlr "</body></html>"
wabort
}
}
- set sessionWait 0
- z39 init
- zwait sessionWait
- if {$sessionWait == -1} {
- htmlr "Cannot initialize with target ${host} <br>"
- htmlr "</body></html>"
- wabort
+ set databases [lindex $targets($host) 1]
+
+# if {[catch {set prevHost $hist([expr $setNo - 1],host)}]} {
+# set databaseDefault [lindex $databases 0]
+# set oSetNo 0
+# } else {
+# set oSetNo [expr $setNo - 1]
+# set databaseDefault $hist($oSetNo,database)
+# }
+ if {$initSet == ""} {
+ set databaseDefault [lindex $databases 0]
+ set oSetNo 0
+ } else {
+ set oSetNo $initSet
+ set databaseDefault $hist($oSetNo,database)
}
- htmlr {<h2> Search in databases </h2>}
- html {<form action="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- htmlr / $sessionId {/search.egw/} $host {" method=post>}
+
+ html {<form action="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo {" method=get>} \n
set nodb [llength $databases]
if {$nodb > 1} {
if {$nodb > 2} {
- html {The chosen target supports searching in }
- htmlr {several databases. <br>}
- htmlr {Choose the bases you want to search: <br>}
+ html "The chosen target supports searching in "
+ html "several databases. <br>\n"
+ html "Choose the bases you want to search: <br>\n"
}
set i 0
foreach d $databases {
html {<input type="checkbox" name="base" value="} $d
- if {[incr i] > 1} {
- htmlr {"> } $d
+ if {[lsearch $databaseDefault $d] == -1} {
+ html {"> } $d \n
} else {
- htmlr {" checked> } $d
+ html {" checked> } $d \n
}
}
- htmlr {<br>}
+ html "<br>\n"
if {$nodb > 2} {
- html {<input type="checkbox" name="base" value="}
- htmlr [concat $databases] {"> All <br>}
+ html {<input type="checkbox" name="baseall" value="}
+ html [concat $databases] {"> All <br>} \n
}
+ html "Input your search criteria:<br>\n"
}
-}
-<hr>
-<strong>Input your search criteria: </strong> <br>
-{
set fields [lindex $targets($host) 2]
for {set no 1} {$no < 4} {incr no} {
- htmlr {<select name="menu} $no {">}
+ html {<select name="menu} $no {">} \n
+ if {$oSetNo > 0} {
+ html {<option> } $hist($oSetNo,form,menu$no) \n
+ }
foreach f $fields {
- htmlr {<option> } [lindex $f 0]
+ set name [lindex $f 0]
+ if {$oSetNo > 0} {
+ if {$hist($oSetNo,form,menu$no) == $name} continue
+ }
+ html {<option> } $name \n
+ }
+ html "</select>\n"
+ html {<input type="text" name="entry} $no {"}
+ if {$scanLine == $no} {
+ html { value="} [join $scanTerm " "] {"}
+ } elseif {[info exists hist($oSetNo,form,entry$no)]} {
+ html { value="} [join $hist($oSetNo,form,entry$no) " "] {"}
+ }
+ html { size=35> }
+ if {[lsearch [z39 options] scan] >= 0} {
+ html {<input type="checkbox" name="scan} $no {" value="1" scan>}
}
- htmlr </select>
- htmlr {<input type="text" name="entry} $no {" size=30>}
if {$no < 3} {
- htmlr {<select name="logic} $no {">}
- htmlr {<option> And}
- htmlr {<option> Or}
- htmlr {<option> And not}
- htmlr {</select>}
+ html {<select name="logic} $no {">} \n
+ if {$oSetNo > 0} {
+ html "<option> " [join $hist($oSetNo,form,logic$no) " "] \n
+ }
+ foreach op {And Or {And not}} {
+ if {$oSetNo > 0} {
+ if {$hist($oSetNo,form,logic$no) == $op} continue
+ }
+ html "<option> " [join $op " "] \n
+ }
+ html "</select>\n"
}
- htmlr <br>
+ html "<br>\n"
}
}
-<hr><p>
-Alternatively you can enter your query in
-<a href="ccl.html"> CCL </a> here: <br>
-<input type=text name="cclentry" size=60> <br>
-<hr>
-<strong> Various technical parameters: </strong> <br>
-Max hits: <input type="text" name="hits" value="50" size=3>
-Records are shown in:
-<select name="format">
-<option> Long format
-<option> Medium format
-<option> Short format
-<option> Raw MARC
-</select>
+
+<input type=submit name=submit value="Search">
+<input type=reset value="Reset">
<br>
-<p>
-<input type="submit" value="Send Query">
+{
+ html {Number of records to display in the result set list: }
+ html {<input type="text" name="hits" value="}
+ if {$oSetNo > 0} {
+ html $hist($oSetNo,maxPresent)
+ } else {
+ html 20
+ }
+ html {" size=4>}
+}
</form>
-<hr>
-This page is maintained by <a href="mailto:pwh@dtv.dk"> Peter Wad Hansen </a>.
-Last modified 29. september 1995. <br>
-<em> This and the following pages are under construction
-and will continue to be so until the end of December 1995.</em>
-<hr>
-sessionId: {html $sessionId} <br>
-sessionParms: {html $sessionParms}<br>
+<p>
+
{
+ button-europagate
+
+ button-new-target 1
+ button-view-history 0
+}
+
+{
+ catch maintenance
+ global debug
+ if {!$debug} return
+ 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} {
- htmlr $e {: } $env($e) {<br>}
+ html $e {: } $env($e) {<br>} \n
}
+ html "form: " [wform] " <br>\n"
+ html "target: " $host " <br>\n"
+ html "databases: " $databases " <br>\n"
+ html "setNo: " $setNo " <br>\n"
+ html "nextSetNo: " $nextSetNo " <br>\n"
+ html "initSet: " $initSet " <br>\n"
+ html "scanLine: " $scanLine " <br>\n"
+ html "scanTerm: " $scanTerm " <br>\n"
}
-form: {html [wform]} <br>
-target: {html $host} <br>
-databases: {html $databases} <br>
</body></html>
+
+