X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=www%2Fsearch.egw;h=daaf3b7fb70e32b74e0b4e700bfb6bb58e4fdeb5;hb=6ceeaa167e3ef2970b6ef0ce2b6c7d9c362eda0a;hp=21af85462ff139c2f58af083befab5047fbccf64;hpb=b443634fbd412cea15ea527188c3e241bb1edf21;p=egate.git diff --git a/www/search.egw b/www/search.egw index 21af854..daaf3b7 100644 --- a/www/search.egw +++ b/www/search.egw @@ -1,32 +1,148 @@ { -# $Id: search.egw,v 1.11 1995/11/08 16:14:33 adam Exp $ +# $Id: search.egw,v 1.22 1996/01/03 08:59:43 adam Exp $ -proc buttons {setNo setMax startPos} { +proc start-scan {scanNo cache dir} { global sessionId + global sessionParms + global sessionWait + global setNo + global hist + global targets + global nextSetNo + global env + + set host $hist($setNo,host) + + html " WWW/Z39.50 Gateway Scan " $host " \n" + html "\n" + + if {$hist($setNo,$scanNo,scanTerm) == ""} { + displayError "Empty query" \ + "You must specify at least one search word" + html "\n" + wabort + return + } + if {$dir == "b"} { + set lines 20 + set pos 20 + } elseif {$dir == "f"} { + set lines 20 + set pos 1 + } else { + set lines 20 + set pos 10 + } + if {[z39scan $setNo $scanNo 0 $lines $pos $cache] != "1"} { + return + } + html {Backward} "\n" + + html {Forward
} + + display-scan $setNo $scanNo 0 + + html {Backward} "\n" + + html {Forward
} + + html "
\n" + html "

Debug information

\n" + html "sessionId: $sessionId
\n" + html "sessionParms: $sessionParms
\n" + foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} { + html $e {: } $env($e) {
} \n + } + html "form: " [wform] "
\n" + html "target: " $host "
\n" + html "databases: " $hist($setNo,database) "
\n" + html "selected: " [wform base] "
\n" + html "setNo: " $setNo "
\n" + html "nextSetNo: " $nextSetNo "
\n" + + html "\n" +} + +proc buttons {setNo setMax startPos after} { + global sessionId + global useIcons global env global hist + if {!$useIcons && $after && $setMax < [z39.$setNo resultCount]} { + html "

\n" + html "

\n" + html {} + html "
\n" + } + html "

\n" + if {$useIcons} { + html {Europagate} + } if {$setMax < [z39.$setNo resultCount]} { html { Next } "| \n" + html + [expr $setMax + $hist($setNo,maxPresent)] + if {$useIcons} { + html {">Next Records} + } else { + html {">Next Records} " | \n" + } } if {$startPos != "" && $startPos != "1"} { html {} + } else { + html {">Previous Records} " | \n" } - html {"> Prev } "| \n" } html { New target } " | \n" - html { New query } "

\n" + if {$useIcons} { + html {">} + } else { + html {">New Query} " | \n" + } + + html {} + } else { + html {">New Target} + } + html "

\n" + if {!$useIcons && !$after && $startPos != "" && $startPos != "1"} { + html "

\n" + html {} + html "

\n" + } + } if {[info commands saveState] == ""} { @@ -37,20 +153,36 @@ proc buttons {setNo setMax startPos} { global setNo global hist - if {[wform menu1] == ""} { - set setNo [lindex $sessionParms 0] - } else { - if {![info exists hist($nextSetNo,host)]} { - set hist($nextSetNo,idAuthentication) $hist($setNo,idAuthentication) - set hist($nextSetNo,host) $hist($setNo,host) + set setNo [lindex $sessionParms 0] + + if {[wform] != ""} { + set hist($nextSetNo,idAuthentication) $hist($setNo,idAuthentication) + set hist($nextSetNo,host) $hist($setNo,host) + + if {$nextSetNo == $setNo} { + set setNo $nextSetNo + incr nextSetNo + } else { + catch {unset hist($setNo,hits)} } - set setNo $nextSetNo - html "using host " $hist($setNo,host) " WWW/Z39.50 Gateway Search\n\n" + displayError "Empty query" \ + "You must specify at least one search word" + html "\n" + wabort + } + set hist($setNo,query) $query + } else { + if {$hist($setNo,scan) > 0} { + set scanNo [lindex $sessionParms 1] + set dir [lindex $sessionParms 2] + if {$scanNo == ""} { + set scanNo 1000 + } + start-scan $scanNo 1 $dir + wabort + } } set host $hist($setNo,host) - set databases [lindex $targets($host) 1] html " WWW/Z39.50 Gateway Search " $host " \n" html "\n" @@ -71,40 +234,40 @@ proc buttons {setNo setMax startPos} { set setMax 0 set setOffset 0 if {$startPos == ""} { - if {[z39search $setNo 1] != "1"} { + if {[z39search $setNo 1 0 B] != "1"} { return } set r [z39.$setNo resultCount] - html "

Search result $r hits

\n" + html "

Search result $r hits

\n" wflush set setOffset [z39.$setNo numberOfRecordsReturned] - display-rec 1 $setOffset display-brief z39 + 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 { - if {[z39search $setNo 0] != "1"} { + if {[z39search $setNo 0 0 B] != "1"} { return } set r [z39.$setNo resultCount] - html "

Search result $r hits

\n" - wflush set setOffset $startPos set setMax [z39.$setNo resultCount] if {$setMax > $endPos} { set setMax $endPos } if {$setMax > 0} { - buttons $setNo $setMax $startPos + buttons $setNo $setMax $startPos 0 } + html "

Search result $r hits

\n" + wflush } if {$setMax > 0} { - z39present $setNo $setOffset $setMax display-brief + z39present $setNo 0 $setOffset $setMax display-brief B } - buttons $setNo $setMax $startPos + buttons $setNo $setMax $startPos 1 } {