X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=web%2Fhtdocs%2Fdetails%2Fedit.mc;h=ad724a0e428b39f585a120494045f4ad1832a7c5;hp=d6503f58cf28a65550ee8884934a88d0c0a2d851;hb=03c3919c5236b5518e6ae23ca80634d25c608c57;hpb=c527e508f77eeb64c8da37031d698500ab5c73de
diff --git a/web/htdocs/details/edit.mc b/web/htdocs/details/edit.mc
index d6503f5..ad724a0 100644
--- a/web/htdocs/details/edit.mc
+++ b/web/htdocs/details/edit.mc
@@ -1,17 +1,12 @@
-%# $Id: edit.mc,v 1.10 2006-11-14 14:54:41 mike Exp $
+%# $Id: edit.mc,v 1.14 2006-11-16 12:16:32 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/error.mc",
- title => "Error", message => "No such ID '$id'");
+ $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>