X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Fedit.mc;h=432bffc11a29f3696946287dfabf5e8f0c4fe388;hp=28f46dbcd772b4e3864206bdcc21dc9a7415be75;hb=d1e6ec25c0d535d5faad8dc01da8f3da9b3d845a;hpb=c9f981f9db231e717db2e2293c2fcaad20e0245e
diff --git a/web/htdocs/details/edit.mc b/web/htdocs/details/edit.mc
index 28f46db..432bffc 100644
--- a/web/htdocs/details/edit.mc
+++ b/web/htdocs/details/edit.mc
@@ -1,17 +1,12 @@
-%# $Id: edit.mc,v 1.11 2006-11-15 17:56:23 mike Exp $
+%# $Id: edit.mc,v 1.15 2006-11-16 12:26:26 mike Exp $
<%args>
$id => undef
%args>
-<%once>
-use ZOOM;
-%once>
<%perl>
my $conn = new ZOOM::Connection("localhost:3313/IR-Explain---1", 0,
user => "admin", password => "fruitbat");
-if (!defined $id || $id eq "") {
- $m->comp("/details/form.mc", id => undef, conn => $conn,
- rec => '');
-} else {
+my $rec = '';
+if (defined $id && $id ne "") {
$conn->option(elementSetName => "zeerex");
my $qid = $id;
$qid =~ s/"/\\"/g;
@@ -19,11 +14,118 @@ if (!defined $id || $id eq "") {
my $rs = $conn->search(new ZOOM::Query::CQL($query));
my $n = $rs->size();
if ($n == 0) {
- $m->comp("/details/form.mc", id => undef, conn => $conn,
- rec => '');
+ $id = undef;
} else {
- my $rec = $rs->record(0);
- $m->comp("/details/form.mc", id => $id, conn => $conn, rec => $rec);
+ $rec = $rs->record(0);
}
}
+
+my $xc = irspy_xpath_context($rec);
+my @fields =
+ (
+ [ protocol => [ qw(Z39.50 SRW SRU SRW/U) ],
+ "Protocol", "e:serverInfo/\@protocol" ],
+ [ host => 0, "Host", "e:serverInfo/e:host" ],
+ [ port => 0, "Port", "e:serverInfo/e:port" ],
+ [ dbname => 0, "Database Name", "e:serverInfo/e:database",
+ qw(e:host e:port) ],
+ [ type => [ qw(Academic Public Corporate Special National Education Other) ],
+ "Type of Library", "i:status/i:libraryType" ],
+ [ country => 0, "Country", "i:status/i:country" ],
+ [ username => 0, "Username (if needed)", "e:serverInfo/e:authentication/e:user",
+ qw() ],
+ [ password => 0, "Password (if needed)", "e:serverInfo/e:authentication/e:password",
+ qw(e:user) ],
+ [ title => 0, "Title", "e:databaseInfo/e:title",
+ qw() ],
+ [ description => 5, "Description", "e:databaseInfo/e:description",
+ qw(e:title) ],
+ [ author => 0, "Author", "e:databaseInfo/e:author",
+ qw(e:title e:description) ],
+ [ hosturl => 0, "URL to Hosting Organisation", "i:status/i:hostURL" ],
+ [ contact => 0, "Contact", "e:databaseInfo/e:contact",
+ qw(e:title e:description) ],
+ [ extent => 3, "Extent", "e:databaseInfo/e:extent",
+ qw(e:title e:description) ],
+ [ history => 5, "History", "e:databaseInfo/e:history",
+ qw(e:title e:description) ],
+ [ language => 0, "Language of Records", "e:databaseInfo/e:langUsage",
+ qw(e:title e:description) ],
+ [ restrictions => 2, "Restrictions", "e:databaseInfo/e:restrictions",
+ qw(e:title e:description) ],
+ [ subjects => 2, "Subjects", "e:databaseInfo/e:subjects",
+ qw(e:title e:description) ],
+ );
+
+my $nchanges = 0;
+my $update = $r->param("update");
+if (defined $update) {
+ # Update record with submitted data
+ my %fieldsByKey = map { ( $_->[0], $_) } @fields;
+ my %data;
+ foreach my $key ($r->param()) {
+ next if grep { $key eq $_ } qw(id update new copy);
+ $data{$key} = $r->param($key);
+ }
+
+ $nchanges = modify_xml_document($xc, \%fieldsByKey, \%data);
+ if ($nchanges) {
+ ### Set e:metaInfo/e:dateModified
+ }
+ ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode());
+}
+%perl>
+
<% xml_encode($xc->find("e:databaseInfo/e:title"), "[Untitled]") %>
+% if ($nchanges) {
+
+ The record has been <% $r->param("new") ? "created" : "updated" %>.
+ Changed <% $nchanges %> field<% $nchanges == 1 ? "" : "s" %>.
+
+% }
+
+<%perl>
+ if ($nchanges && 0) {
+ my $x = $xc->getContextNode()->toString();
+ $x = xml_encode($x);
+ #$x =~ s/$/
/gm;
+ print "$x
\n";
+ }
%perl>