<html>
-<head>
-<title> WWW/Z39.50 Gateway Query Form</title>
-</head>
-<body>
{
-# $Id: query.egw,v 1.17 1995/11/14 16:01:50 adam Exp $
+# $Id: query.egw,v 1.41 2001/02/26 14:32:36 adam Exp $
if {[info commands saveState] == ""} {
source z39util.tcl
+ if {![info exists debug]} {
+ session-lost
+ egw_abort
+ }
}
proc fail-response {} {
global nextSetNo
global hist
- set host [lindex $sessionParms 0]
+ html {<head><title> WWW/Z39.50 Gateway Query Form</title></head><body>}
+
+ set initSet [lindex $sessionParms 0]
+ set host [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]}]} {
+ if {[catch {set oldHost [z390 connect]}]} {
set oldHost ""
}
- set hist($setNo,host) $host
- set hist($setNo,idAuthentication) [lindex $targets($host) 3]
-
- if {[catch {z39 failback fail-response}]} {
- ir z39
- }
+ set hist($setNo,0,host) $host
+ set hist($setNo,0,idAuthentication) [lindex $targets($host) 3]
- html "<h2> Search in " [lindex $targets($host) 0] "</h2>\n"
+ mkAssoc z390 $host
- z39 callback ok-response
- z39 failback fail-response
- if {$host != $oldHost} {
- catch {z39 disconnect}
+ z390 callback ok-response
+ z390 failback fail-response
+ set thisHost [splitHostSpec $host]
+ if {[string compare $thisHost $oldHost]} {
+ catch {z390 disconnect}
set sessionWait 0
- if {[catch {z39 connect $host}]} {
- displayError "Cannot connect to target ${host}" {}
+ if {[catch {z390 connect $thisHost}]} {
+ displayError "Cannot connect to target ${thisHost}" {}
html "</body></html>\n"
- z39 disconnect
- wabort
+ z390 disconnect
+ egw_abort
} elseif {$sessionWait == 0} {
- if {[catch {zwait sessionWait 30}]} {
- displayError "Cannot connect to target ${host}" {}
+ if {[catch {egw_wait sessionWait 35}]} {
+ displayError "Cannot connect to target ${thisHost}" {}
html "</body></html>\n"
- z39 disconnect
- wabort
+ z390 disconnect
+ egw_abort
}
if {$sessionWait != 1} {
- displayError "Cannot connect to target ${host}" {}
+ displayError "Cannot connect to target ${thisHost}" {}
html "</body></html>\n"
- z39 disconnect
- wabort
+ z390 disconnect
+ egw_abort
}
}
set sessionWait 0
- z39 idAuthentication $hist($setNo,idAuthentication)
- if {[catch {z39 init}]} {
- displayError "Cannot initialize target ${host}" {}
+ z390 idAuthentication $hist($setNo,0,idAuthentication)
+ if {[catch {z390 init}]} {
+ displayError "Cannot initialize target ${thisHost}" {}
html "</body></html>\n"
- wabort
+ egw_abort
}
- if {[catch {zwait sessionWait 60}]} {
- displayError "Cannot initialize target ${host}" {}
+ if {$sessionWait == 0 && [catch {egw_wait sessionWait 60}]} {
+ displayError "Cannot initialize target ${thisHost}" {}
html "</body></html>\n"
- wabort
+ egw_abort
}
if {$sessionWait != "1"} {
- displayError "Cannot initialize target ${host}" {}
- htmlr "</body></html>\n"
- wabort
+ displayError "Cannot initialize target ${thisHost}" {}
+ html "</body></html>\n"
+ egw_abort
}
- if {![z39 initResult]} {
- displayError "Connection rejected by target ${host}" \
- [z39 userInformationField]
- z39 disconnect
- htmlr "</body></html>"
- wabort
+ if {![z390 initResult]} {
+ displayError "Connection rejected by target ${thisHost}" \
+ [z390 userInformationField]
+ z390 disconnect
+ html "</body></html>\n"
+ egw_abort
}
}
- set databases [lindex $targets($host) 1]
- if {$setNo > 1 && $hist([expr $setNo - 1],host) == $host} {
- set oSetNo [expr $setNo - 1]
- set databaseDefault $hist($oSetNo,database)
- } else {
+ set useIcons 1
+ button-main
+ button-feedback
+ button-new-target
+ if {[lsearch [z390 options] scan] >= 0} {
+ button-scan-window $setNo
+ }
+ button-view-history
+
+ html "<h2>" [lindex $targets($host) 0] "</h2><br>\n"
+
+ html [lindex $targets($host) 4] "<br>\n"
+
+ set databases [splitDatabaseSpec $host]
+ if {$initSet == -1} {
set databaseDefault [lindex $databases 0]
set oSetNo 0
+ } else {
+ set oSetNo $initSet
+ set databaseDefault $hist($oSetNo,0,database)
}
-
- html {<form action="http:} $env(SCRIPT_NAME)
- html / $sessionId {/search.egw/} $setNo {" method=post>} \n
+
+ html {<form action="} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo + 0 {" method=get>} \n
set nodb [llength $databases]
if {$nodb > 1} {
if {$nodb > 2} {
html [concat $databases] {"> All <br>} \n
}
}
-}
-<hr>
-<h3>Input your search criteria: </h3> <br>
-{
+ html "<b>Fill-in this search form:</b><br>\n"
set fields [lindex $targets($host) 2]
for {set no 1} {$no < 4} {incr no} {
html {<select name="menu} $no {">} \n
+ set template {}
if {$oSetNo > 0} {
- html {<option> } $hist($oSetNo,form,menu$no) \n
+ set template [join $hist($oSetNo,form,menu$no)]
+ }
+ if {[string length $template] > 0} {
+ html {<option> } $template "\n"
}
foreach f $fields {
set name [lindex $f 0]
- if {$oSetNo > 0} {
- if {$hist($oSetNo,form,menu$no) == $name} continue
- }
+ if {$template == $name} continue
html {<option> } $name \n
}
html "</select>\n"
html {<input type="text" name="entry} $no {"}
- html { size=30>} \n
+ set template {}
+ if {$scanLine == $no} {
+ set template [join $scanTerm " "]
+ } elseif {[info exists hist($oSetNo,form,entry$no)]} {
+ set template [join $hist($oSetNo,form,entry$no) " "]
+ }
+ if {[string length $template] > 0} {
+ html { value="} $template {"}
+ }
+ html { size=35> }
+ if {0 && [lsearch [z390 options] scan] >= 0} {
+ html {<input type="checkbox" name="scan} $no {" value="1" scan>}
+ }
if {$no < 3} {
html {<select name="logic} $no {">} \n
+ set template {}
if {$oSetNo > 0} {
- html "<option> " $hist($oSetNo,form,logic$no) \n
+ set template [join $hist($oSetNo,form,logic$no) " "]
+ }
+ if {[string length $template] > 0} {
+ html "<option> " $template \n
}
foreach op {And Or {And not}} {
- if {$oSetNo > 0} {
- if {$hist($oSetNo,form,logic$no) == $op} continue
- }
- html "<option> " $op \n
+ if {$template == $op} continue
+ html "<option> " [join $op " "] \n
}
html "</select>\n"
}
html "<br>\n"
}
}
-<hr><p>
-Alternatively you can enter your query in
-<a href="http://www.dtv.dk/ccl.html"> CCL </a> here: <br>
-<input type=text name="cclentry" size=52> <br>
-<hr>
-<input type=submit value="Search"><input type=reset value="Reset">
-<h3> Various technical parameters: </h3> <br>
+
+<input type=submit name=submit value="Search">
+<input type=reset value="Reset">
+<br>
{
- html {Max hits: <input type="text" name="hits" value="}
+ 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=3>}
+ html {" size=4>}
+ html "</form>\n"
+ html "<p>\n"
+
+ set useIcons 0
+ button-main
+ button-feedback
+ button-new-target
+ if {[lsearch [z390 options] scan] >= 0} {
+ button-scan-window $setNo
+ }
+ button-view-history
}
-Records are shown in:
-<select name="format">
-<option> Long format
-<option> Medium format
-<option> Short format
-<option> Raw MARC
-</select>
-<br>
-<p>
-</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>
{
- html {<a href="http:} $env(SCRIPT_NAME)
- html / $sessionId {/targets.egw"> New target </a>}
-}
-{
+ catch maintenance
+ global debug
+ if {!$debug} return
html "<hr>\n"
html "<h3>Debug information</h3>\n"
html "sessionId: $sessionId <br>\n"
foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} {
html $e {: } $env($e) {<br>} \n
}
- html "form: " [wform] " <br>\n"
+ html "form: " [egw_form] " <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"
}
</body></html>
-
-