-%# $Id: full.mc,v 1.12 2006-11-06 17:40:04 mike Exp $
+%# $Id: full.mc,v 1.18 2006-12-05 17:37:26 mike Exp $
<%args>
$id
</%args>
-<%once>
-use ZOOM;
-</%once>
<%perl>
my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1");
$conn->option(elementSetName => "zeerex");
$m->comp("/details/error.mc",
title => "Error", message => "No such ID '$id'");
} else {
- my $rec = $rs->record(0);
- my $xc = irspy_xpath_context($rec);
+ my $xc = irspy_xpath_context($rs->record(0));
my @fields = (
+ [ Name => "e:databaseInfo/e:title",
+ lang => "en", primary => "true" ],
+ [ Country => "i:status/i:country" ],
[ "Last Checked" => "i:status/i:probe[last()]" ],
[ Protocol => "e:serverInfo/\@protocol" ],
[ Host => "e:serverInfo/e:host" ],
[ Port => "e:serverInfo/e:port" ],
[ "Database Name" => "e:serverInfo/e:database" ],
+ [ "Type of Library" => "i:status/i:libraryType" ],
[ "Username (if needed)" =>
"e:serverInfo/e:authentication/e:user" ],
[ "Password (if needed)" =>
"e:serverInfo/e:authentication/e:password" ],
- [ Title => "e:databaseInfo/e:title",
- lang => "en", primary => "true" ],
[ Description => "e:databaseInfo/e:description",
lang => "en", primary => "true" ],
[ Author => "e:databaseInfo/e:author" ],
[ Contact => "e:databaseInfo/e:contact" ],
+ [ "URL to Hosting Organisation" => "i:status/i:hostURL" ],
[ Extent => "e:databaseInfo/e:extent" ],
[ History => "e:databaseInfo/e:history" ],
[ "Language of Records" => "e:databaseInfo/e:langUsage" ],
[ "Bib-1 Use attributes" => \&calc_ap, $xc, "bib-1" ],
[ "Dan-1 Use attributes" => \&calc_ap, $xc, "dan-1" ],
[ "Operators" => \&calc_boolean, $xc ],
+ [ "Named Result Sets" => \&calc_nrs, $xc ],
[ "Record syntaxes" => \&calc_recsyn, $xc ],
[ "Explain" => \&calc_explain, $xc ],
);
</%perl>
- <h2><% xml_encode($xc->find("e:databaseInfo/e:title")) %></h2>
+ <h2><% xml_encode($xc->find("e:databaseInfo/e:title"), "") %></h2>
<table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
<%perl>
foreach my $ref (@fields) {
return $res;
}
+sub calc_nrs {
+ my($xc) = @_;
+
+ my @nodes = $xc->findnodes('i:status/i:named_resultset[@ok = "1"]');
+ return @nodes ? "Yes" : "No";
+}
+
sub calc_recsyn {
my($xc) = @_;