X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Ffound.mc;h=677bb6852fe44ad075b11962ddf26387fb8e5f38;hp=2d690a91d17a7af1fd365005a64c00fb9f9411bb;hb=93936991183ffb9ee82314407b7a731e204af780;hpb=d13b3c4a81cd7d20ed47d48d773739d8427c41f4 diff --git a/web/htdocs/details/found.mc b/web/htdocs/details/found.mc index 2d690a9..677bb68 100644 --- a/web/htdocs/details/found.mc +++ b/web/htdocs/details/found.mc @@ -1,17 +1,19 @@ -%# $Id: found.mc,v 1.1 2006-09-15 16:51:51 mike Exp $ +%# $Id: found.mc,v 1.3 2006-09-18 19:26:37 mike Exp $ <%once> use XML::LibXML; use XML::LibXML::XPathContext; <%perl> +my %params = map { ( $_, $r->param($_)) } $r->param(); my $query = ""; -foreach my $key ($r->param()) { +foreach my $key (keys %params) { next if $key =~ /^_/; - my $val = $r->param($key); + my $val = $params{$key}; next if $val eq ""; $query .= " and " if $query ne ""; $query .= "$key = ($val)"; } +$query = 'cql.allRecords=x' if $query eq ""; ### We can think about keeping the Connection object open to re-use # for multiple requests, but that may not get us much. Same applies @@ -23,8 +25,8 @@ my $parser = new XML::LibXML(); my $rs = $conn->search(new ZOOM::Query::CQL($query)); my $n = $rs->size(); -my $skip = $r->param("_skip") || 0; -my $count = $r->param("_count") || 10; +my $skip = $params{"_skip"} || 0; +my $count = $params{"_count"} || 10; my $first = $skip+1; my $last = $first+$count-1; @@ -36,9 +38,26 @@ $last = $n if $last > $n; % if ($n == 0) { No matches % } elsif ($first > $n) { +%# "Can't happen" Past end of <% $n %> records % } else { - Records <% $first %> to <% $last %> of <% $n %> + Records <% $first %> to <% $last %> of <% $n %>
+<%perl> +if ($skip > 0) { + $params{_skip} = $count < $skip ? $skip-$count : 0; + my $prev = "?" . join("&", map { "$_=" . $params{$_} } sort keys %params); + print qq[ Prev\n]; +} else { + print qq[ Prev\n]; +} +if ($last < $n) { + $params{_skip} = $skip+$count; + my $next = "?" . join("&", map { "$_=" . $params{$_} } sort keys %params); + print qq[ Next\n]; +} else { + print qq[ Next\n]; +} + % }

% if ($n > 0 && $first <= $n) { @@ -48,6 +67,7 @@ $last = $n if $last > $n; Host Port DB + % foreach my $i ($first .. $last) { <%perl> @@ -60,12 +80,16 @@ $xc->registerNs(e => 'http://explain.z3950.org/dtd/2.0/'); my $host = $xc->find("e:serverInfo/e:host"); my $port = $xc->find("e:serverInfo/e:port"); my $db = $xc->find("e:serverInfo/e:database"); +my $id = $xc->find("concat(e:serverInfo/e:host, ':', + e:serverInfo/e:port, '/', + e:serverInfo/e:database)"); <% $i %> <% $host %> <% $port %> <% $db %> + ">[Check] %}