X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Ffound.mc;h=dfca595f9c4bf12ce0c59f350fad544d6da67b60;hp=2d690a91d17a7af1fd365005a64c00fb9f9411bb;hb=34006aed3916d7c41c4de2811a7451888fcdff22;hpb=d13b3c4a81cd7d20ed47d48d773739d8427c41f4 diff --git a/web/htdocs/details/found.mc b/web/htdocs/details/found.mc index 2d690a9..dfca595 100644 --- a/web/htdocs/details/found.mc +++ b/web/htdocs/details/found.mc @@ -1,54 +1,89 @@ -%# $Id: found.mc,v 1.1 2006-09-15 16:51:51 mike Exp $ +%# $Id: found.mc,v 1.8 2006-09-20 16:37:15 mike Exp $ <%once> use XML::LibXML; use XML::LibXML::XPathContext; %once> <%perl> +my %params = map { ( $_, $r->param($_)) } grep { $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 ""; + +my $sort = $params{"_sort"}; +if ($sort) { + my $modifiers = ""; + if ($sort =~ s/(\/.*)//) { + $modifiers = $1; + } + $query .= " or $sort=/sort"; + $query .= "-desc" if $params{_desc}; + $query .= $modifiers; + $query .= " 0"; +} ### We can think about keeping the Connection object open to re-use # for multiple requests, but that may not get us much. Same applies # for the XML parser. -my $conn = new ZOOM::Connection("localhost:1313/IR-Explain---1"); +my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1"); $conn->option(elementSetName => "zeerex"); 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; $last = $n if $last > $n; %perl> +
- <% $query %>
-
% 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];
+}
+%perl>
% }
# | +Title | +Author | Host | Port | DB | ++ | |
---|---|---|---|---|---|---|---|
<% $i %> | +<% $title %> | +<% $author %> | <% $host %> | <% $port %> | <% $db %> | +">[Test] | +">[Raw] |