1 %# $Id: found.mc,v 1.11 2006-09-25 16:52:30 mike Exp $
4 use XML::LibXML::XPathContext;
8 my($params, $cond, $caption, $skip) = @_;
11 print(' <a href="', navlink($params, $caption, $skip),
12 '"', ">$caption</a>\n");
14 print qq[ <span class="disabled">$caption</span>\n];
19 my($params, $caption, $skip) = @_;
20 local $params->{_skip} = $skip;
21 my $url = "?" . join("&", map { "$_=" . $params->{$_} } sort keys %$params);
22 $url = xml_encode($url);
28 my %params = map { ( $_, $r->param($_)) } grep { $r->param($_) } $r->param();
30 foreach my $key (keys %params) {
32 my $val = $params{$key};
34 $query .= " and " if $query ne "";
35 $query .= "$key = ($val)";
37 $query = 'cql.allRecords=x' if $query eq "";
39 my $sort = $params{"_sort"};
42 if ($sort =~ s/(\/.*)//) {
45 $query .= " or $sort=/sort";
46 $query .= "-desc" if $params{_desc};
51 ### We can think about keeping the Connection object open to re-use
52 # for multiple requests, but that may not get us much. Same applies
54 my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
55 $conn->option(elementSetName => "zeerex");
56 my $parser = new XML::LibXML();
58 my $rs = $conn->search(new ZOOM::Query::CQL($query));
61 my $skip = $params{"_skip"} || 0;
62 my $count = $params{"_count"} || 10;
65 my $last = $first+$count-1;
66 $last = $n if $last > $n;
68 <h2><% xml_encode($query) %></h2>
72 % } elsif ($first > $n) {
74 Past end of <% $n %> records
76 Records <% $first %> to <% $last %> of <% $n %><br/>
78 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
79 print_navlink(\%params, $last < $n, "Next", $skip+$count);
83 % if ($n > 0 && $first <= $n) {
96 % foreach my $i ($first .. $last) {
98 my $rec = $rs->record($i-1);
99 my $xml = $rec->render();
100 my $doc = $parser->parse_string($xml);
101 my $root = $doc->getDocumentElement();
102 my $xc = XML::LibXML::XPathContext->new($root);
103 $xc->registerNs(e => 'http://explain.z3950.org/dtd/2.0/');
104 my $title = $xc->find("e:databaseInfo/e:title");
105 my $author = $xc->find("e:databaseInfo/e:author");
106 my $host = $xc->find("e:serverInfo/e:host");
107 my $port = $xc->find("e:serverInfo/e:port");
108 my $db = $xc->find("e:serverInfo/e:database");
109 my $id = $xc->find("concat(e:serverInfo/e:host, ':',
110 e:serverInfo/e:port, '/',
111 e:serverInfo/e:database)");
114 <tr style="background: <% ($i % 2) ? '#ffffc0' : 'white' %>">
116 <td><% xml_encode($title) %></td>
117 <td><% xml_encode($author) %></td>
118 <td><% xml_encode($host) %></td>
119 <td><% xml_encode($port) %></td>
120 <td><% xml_encode($db) %></td>
121 <td><a href="<% xml_encode("/check.html?id=" . uri_escape($id))
123 <td><a href="<% xml_encode("/raw.html?id=" . uri_escape($id))
129 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
130 print_navlink(\%params, $last < $n, "Next", $skip+$count);
133 <a href="<% "/check.html?" .
134 xml_encode(join("&", map { "id=" . uri_escape($_) } @ids))
135 %>">[Test all targets on this list]</a>