1 %# $Id: found.mc,v 1.17 2006-10-27 00:47:05 mike Exp $
4 my($params, $cond, $caption, $skip) = @_;
7 print(' <a href="', navlink($params, $caption, $skip),
8 '"', ">$caption</a>\n");
10 print qq[ <span class="disabled">$caption</span>\n];
15 my($params, $caption, $skip) = @_;
16 local $params->{_skip} = $skip;
17 my $url = "?" . join("&", map { "$_=" . $params->{$_} } sort keys %$params);
18 $url = xml_encode($url);
22 # Just make this once; forge the connection on first use
26 my %params = map { ( $_, $r->param($_)) } grep { $r->param($_) } $r->param();
28 if ($params{_query}) {
29 $query = $params{_query};
32 foreach my $key (keys %params) {
34 my $val = $params{$key};
36 $query .= " and " if $query ne "";
37 $query .= "$key = ($val)";
40 $query = 'cql.allRecords=x' if $query eq "";
42 my $sort = $params{"_sort"};
45 if ($sort =~ s/(\/.*)//) {
48 $query .= " or $sort=/sort";
49 $query .= "-desc" if $params{_desc};
54 my $tried_to_open = 0;
57 $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
58 $conn->option(elementSetName => "zeerex");
62 eval { $rs = $conn->search(new ZOOM::Query::CQL($query)) };
63 if ($@ && ref $@ && $@->isa('ZOOM::Exception') &&
64 $@->code() == ZOOM::Error::CONNECTION_LOST && !$tried_to_open) {
73 my $skip = $params{"_skip"} || 0;
74 my $count = $params{"_count"} || 10;
77 my $last = $first+$count-1;
78 $last = $n if $last > $n;
80 <form method="get" action="">
81 <input type="text" name="_query" size="60" value="<% xml_encode($query) %>"/>
82 <input type="submit" name="_search" value="Search"/>
87 % } elsif ($first > $n) {
89 Past end of <% $n %> records
91 Records <% $first %> to <% $last %> of <% $n %><br/>
93 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
94 print_navlink(\%params, $last < $n, "Next", $skip+$count);
98 % if ($n > 0 && $first <= $n) {
111 % foreach my $i ($first .. $last) {
113 my $rec = $rs->record($i-1);
114 my $xc = irspy_xpath_context($rec);
115 my $title = $xc->find("e:databaseInfo/e:title");
116 my $author = $xc->find("e:databaseInfo/e:author");
117 my $host = $xc->find("e:serverInfo/e:host");
118 my $port = $xc->find("e:serverInfo/e:port");
119 my $db = $xc->find("e:serverInfo/e:database");
120 my $id = $xc->find("concat(e:serverInfo/e:host, ':',
121 e:serverInfo/e:port, '/',
122 e:serverInfo/e:database)");
125 <tr style="background: <% ($i % 2) ? '#ffffc0' : 'white' %>">
127 <td><a href="<% xml_encode("/full.html?id=" . uri_escape($id))
128 %>"><% xml_encode($title) %></a></td>
129 <td><% xml_encode($author) %></td>
130 <td><% xml_encode($host) %></td>
131 <td><% xml_encode($port) %></td>
132 <td><% xml_encode($db) %></td>
134 <a href="<% xml_encode("/check.html?id=" . uri_escape($id))
135 %>" title="Test this target">Test</a
136 > <a href="<% xml_encode("/edit.html?id=" . uri_escape($id))
137 %>" title="Edit this target's record">Edit</a
138 > <a href="<% xml_encode("/raw.html?id=" . uri_escape($id))
139 %>" title="Raw XML record">XML</a>
145 print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0);
146 print_navlink(\%params, $last < $n, "Next", $skip+$count);
149 <a href="<% "/check.html?" .
150 xml_encode(join("&", map { "id=" . uri_escape($_) } @ids))
151 %>">[Test all targets on this list]</a>