X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=www%2Fsearch.egw;h=fd25d08ff8236d9404a0774351ee919a70b0e604;hb=a61ad0378b93e99e362a1d92c33d701dbf103eba;hp=d1046ba7bdd561592b52af4266598838e701415e;hpb=74a4580ba9945fc86b47654230865a68089245b6;p=egate.git diff --git a/www/search.egw b/www/search.egw index d1046ba..fd25d08 100644 --- a/www/search.egw +++ b/www/search.egw @@ -1,33 +1,171 @@ { -# $Id: search.egw,v 1.14 1995/11/10 14:47:32 adam Exp $ +# $Id: search.egw,v 1.38 1996/03/13 14:07:31 adam Exp $ -proc buttons {setNo setMax startPos} { +proc start-scan {scanNo targetNo cache dir initSet} { global sessionId - global env + global sessionParms + global sessionWait + global setNo global hist + global targets + global nextSetNo + global env + global useIcons + global debug - html "

\n" - if {$setMax < [z39.$setNo resultCount]} { - html {Next records} " | \n" + set host $hist($setNo,$targetNo,host) + + html " WWW/Z39.50 Gateway Scan " [splitHostSpec $host] + html " \n" + html "\n" + + set useIcons 1 + button-main + + 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 {$startPos != "" && $startPos != "1"} { + if {$hist($setNo,$scanNo,scanTerm) != ""} { + if {[z39scan $setNo $scanNo 0 $lines $pos $cache] != "1"} { + button-new-query $setNo + egw_log debug "z39_scan failed" + return + } html {} + if {$useIcons} { + html {} + } else { + html {Previous Terms | } + } + + html {} + if {$useIcons} { + html {} + } else { + html {Next Terms | } } - html {">Previous records} " | \n" + html {} } + button-new-query $setNo + + set databases [splitDatabaseSpec $host] + + if {$initSet == ""} { + set databaseDefault [lindex $databases 0] + set oSetNo 0 + } else { + set oSetNo $initSet + set databaseDefault $hist($oSetNo,$targetNo,database) + } + + html {

} \n + set nodb [llength $databases] + if {$nodb > 1} { + if {$nodb > 2} { + html "Databases:
\n" + } + set i 0 + foreach d $databases { + html { } $d \n + } else { + html {" checked> } $d \n + } + } + html "
\n" + if {$nodb > 2} { + html { All
} \n + } + } + html "Input your scan criteria:
\n" + set fields [lindex $targets($host) 2] + set no 1 + html {\n" + html { } + html {} + html "\n" + html {

} + + set useIcons 0 + if {$hist($setNo,$scanNo,scanTerm) == ""} { + button-main + button-new-query $setNo + return + } + + html "

\n" + display-scan $setNo $scanNo 0 + html "

\n" + + button-main + html {New target} " | \n" + html / $sessionId {/search.egw/} $setNo + $targetNo + + html [expr $scanNo - 1] + b {">} + if {$useIcons} { + html {} + } else { + html {Previous Terms | } + } + html {New query} "\n

\n" + html / $sessionId {/search.egw/} $setNo + $targetNo + + html [expr $scanNo + 1] + f {">} + if {$useIcons} { + html {} + } else { + html {Next Terms | } + } + html {} + button-new-query $setNo + + if {!$debug} return + 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: " [egw_form] "
\n" + html "databases: " $hist($setNo,$targetNo,database) "
\n" + html "selected: " [egw_form base] "
\n" + html "setNo: " $setNo "
\n" + html "nextSetNo: " $nextSetNo "
\n" } if {[info commands saveState] == ""} { @@ -39,88 +177,149 @@ proc buttons {setNo setMax startPos} { 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) " WWW/Z39.50 Gateway Search " $host " \n" - html "\n" + set hist($setNo,format) brief + set hist($setNo,sort) server - set startPos [lindex $sessionParms 1] - set endPos [lindex $sessionParms 2] - set setMax 0 - set setOffset 0 - if {$startPos == ""} { - if {[z39search $setNo 1 0] != "1"} { + set i [lindex $sessionParms 2] + if {[string length $i] == 0} { + for {set j 1} {$j <= 3} {incr j} { + if {[egw_form scan$j] != ""} { + set i $j + break + } + } + } + if {[string length $i] != 0} { + set scanNo 1000 + set hist($setNo,scan) $i + set termPlusAttr [build-scan $hist($setNo,0,host) $i] + set hist($setNo,$scanNo,scanTerm) [lindex $termPlusAttr 0] + set hist($setNo,scanAttr) [lindex $termPlusAttr 1] + start-scan $scanNo $targetNo 0 {} $setNo + html "\n" + egw_abort return } - set r [z39.$setNo resultCount] - html "

Search result $r hits

\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) + set query [build-query $hist($setNo,0,host) 3] + if {[string length $query] == 0} { + html " WWW/Z39.50 Gateway Search\n\n" + displayError "Empty query" \ + "You must specify at least one search word" + html "\n" + egw_abort } - } else { - if {[z39search $setNo 0 0] != "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 + set hist($setNo,0,query) $query + } elseif {[lindex $sessionParms 2] == "hyper"} { + egw_log debug "hyper search" + set hist($nextSetNo,$targetNo,idAuthentication) \ + $hist($setNo,$targetNo,idAuthentication) + set hist($nextSetNo,$targetNo,host) \ + $hist($setNo,$targetNo,host) + set hist($nextSetNo,$targetNo,database) \ + $hist($setNo,$targetNo,database) + + if {$nextSetNo == $setNo} { + set setNo $nextSetNo + incr nextSetNo + } else { + catch {unset hist($setNo,$targetNo,hits)} } - if {$setMax > 0} { - buttons $setNo $setMax $startPos + set hist($setNo,scan) 0 + set hist($setNo,$targetNo,query) \ + "$hist($setNo,scanAttr) \"[lindex $sessionParms 3]\"" + egw_log debug "hyper databases: $hist($setNo,$targetNo,database)" + set hist($setNo,form,entry1) [lindex $sessionParms 3] + set startPos "" + } elseif {[lindex $sessionParms 2] == "scan"} { + egw_log debug "star scan" + set scanNo 1000 + set hist($setNo,$scanNo,scanTerm) {} + start-scan $scanNo $targetNo 0 {} {} + html "\n" + egw_abort + } else { + if {![info exists hist($setNo,scan)]} return + if {$hist($setNo,scan) > 0} { + set scanNo [lindex $sessionParms 2] + set dir [lindex $sessionParms 3] + if {$scanNo == ""} { + set scanNo 1000 + } + start-scan $scanNo $targetNo 1 $dir $setNo + html "\n" + egw_abort } } - if {$setMax > 0} { - z39present $setNo 0 $setOffset $setMax display-brief - } + set host $hist($setNo,$targetNo,host) - buttons $setNo $setMax $startPos -} + html " WWW/Z39.50 Gateway Search " [splitHostSpec $host] + html " \n" + html "\n" + display-result-set-s $setNo $targetNo $startPos $endPos +} { + global debug + if {!$debug} return 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 + foreach n [array names env] { + html "env($n) = " $env($n) "
\n" } - html "form: " [wform] "
\n" - html "target: " $host "
\n" - html "databases: " $hist($setNo,database) "
\n" - html "selected: " [wform base] "
\n" - html "query: --" $hist($setNo,query) "--
" + html "form: " [egw_form] "
\n" + html "databases: " $hist($setNo,$targetNo,database) "
\n" + html "selected: " [egw_form base] "
\n" + html "query: --" $hist($setNo,$targetNo,query) "--
" html "setNo: " $setNo "
\n" html "nextSetNo: " $nextSetNo "
\n" } -