X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=www%2Fsearch.egw;h=eabe4b9344aa2b75185065f9c40d5636e6348149;hb=3871eda3b3a1518d4d18c1ffc0ed0375cb88bdf5;hp=71f4cb0bda01c3574195457a818d8d9286a2410e;hpb=4a4288c5b72d694c1ca2c1c08926d1e10f01cc48;p=egate.git diff --git a/www/search.egw b/www/search.egw index 71f4cb0..eabe4b9 100644 --- a/www/search.egw +++ b/www/search.egw @@ -1,111 +1,403 @@ { -# $Id: search.egw,v 1.4 1995/10/31 10:03:53 adam Exp $ +# $Id: search.egw,v 1.32 1996/02/12 13:39:40 adam Exp $ -proc ok-response {} { +proc start-scan {scanNo cache dir initSet} { + global sessionId + global sessionParms global sessionWait - set sessionWait 1 -} + global setNo + global hist + global targets + global nextSetNo + global env + global useIcons + global debug -proc fail-response {} { - global sessionWait - set sessionWait -1 + set host $hist($setNo,host) + + html "
\n" + display-scan $setNo $scanNo 0 + html "
\n" + + button-europagate + + html {} + if {$useIcons} { + html {} + } else { + html {Previous Terms | } + } + + html {} + if {$useIcons} { + html {} + } else { + html {Next Terms | } + } + html {} + button-new-query 0 $setNo + + if {!$debug} return + html "
\n" + button-europagate + if {$setMax > 0 && $setMax < [z39.$setNo resultCount]} { + html {} + } else { + html {">Next Records} " | \n" + } + } + if {$setMax > 0 && $startPos != "" && $startPos != "1"} { + html {} + } else { + html {">Previous Records} " | \n" } - incr from } + button-new-query 1 $setNo + button-new-target 1 + button-view-history 0 + + html "
\n" } -proc build-query {} { - global targets - global t - - set op {} - set q {} - for {set i 1} {$i < 4} {incr i} { - set term [form entry$i] - if {$term != ""} { - set field [form menu$i] - foreach x [lindex $targets($t) 2] { - if {[lindex $x 0] == $field} { - set attr [lindex $x 1] + if {[info commands saveState] == ""} { + source z39util.tcl + } + global sessionWait + global nextSetNo + global setNo + global hist + + set setNo [lindex $sessionParms 0] + set startPos [lindex $sessionParms 1] + set endPos [lindex $sessionParms 2] + + if {[egw_form] != ""} { + 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 hist($setNo,scan) 0 + + set hist($setNo,form,menu1) [egw_form menu1] + set hist($setNo,form,menu2) [egw_form menu2] + set hist($setNo,form,menu3) [egw_form menu3] + + set hist($setNo,form,entry1) [egw_form entry1] + set hist($setNo,form,entry2) [egw_form entry2] + set hist($setNo,form,entry3) [egw_form entry3] + + set hist($setNo,form,logic1) [egw_form logic1] + set hist($setNo,form,logic2) [egw_form logic2] + set hist($setNo,form,logic3) {} + + set host $hist($setNo,host) + set databases [lindex $targets($host) 1] + + set b [egw_form base] + if {[egw_form baseall] != ""} { + set hist($setNo,database) $databases + } elseif {$b == ""} { + set hist($setNo,database) $databases + } else { + set hist($setNo,database) $b + } + set hist($setNo,maxPresent) [egw_form hits] + if {$hist($setNo,maxPresent) == ""} { + set hist($setNo,maxPresent) 30 + } + set i [lindex $sessionParms 1] + if {$i == ""} { + for {set j 1} {$j <= 3} {incr j} { + if {[egw_form scan$j] != ""} { + set i $j + break } } - switch $op { - And - { set q "@and $q ${attr} ${term}" } - Or - { set q "@or $q ${attr} ${term}" } - {And not} - { set q "@not $q ${attr} ${term}" } - {} - { set q "${attr} ${term}" } + } + if {$i != ""} { + set scanNo 1000 + set hist($setNo,scan) $i + set termPlusAttr [build-scan $hist($setNo,host) $i] + set hist($setNo,$scanNo,scanTerm) [lindex $termPlusAttr 0] + set hist($setNo,scanAttr) [lindex $termPlusAttr 1] + start-scan $scanNo 0 {} $setNo + html "\n" + egw_abort + return + } + set query [build-query $hist($setNo,host) 3] + if {"x$query" == "x"} { + html "