Clearer reporting.
[irspy-moved-to-github.git] / web / htdocs / details / edit.mc
index 9e234e9..2fa9a0a 100644 (file)
@@ -1,4 +1,4 @@
-%# $Id: edit.mc,v 1.5 2006-10-31 09:26:59 mike Exp $
+%# $Id: edit.mc,v 1.8 2006-11-08 17:42:11 mike Exp $
 <%args>
 $id
 </%args>
 <%args>
 $id
 </%args>
@@ -49,44 +49,33 @@ if ($n == 0) {
           qw(e:title e:description) ],
         [ subjects     => 2, "Subjects", "e:databaseInfo/e:subjects",
           qw(e:title e:description) ],
           qw(e:title e:description) ],
         [ subjects     => 2, "Subjects", "e:databaseInfo/e:subjects",
           qw(e:title e:description) ],
-        ### Remember to set e:metaInfo/e:dateModified
         );
         );
-    my %fieldsByKey = map { ( $_->[0], $_) } @fields;
+
+    my $nchanges = 0;
     my $update = $r->param("update");
     if (defined $update) {
        # Update record with submitted data
     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);
        foreach my $key ($r->param()) {
            next if grep { $key eq $_ } qw(id update);
-           my $value = $r->param($key);
-           my $ref = $fieldsByKey{$key} or die "no field '$key'";
-           my($name, $nlines, $caption, $xpath, @addAfter) = @$ref;
-           my @nodes = $xc->findnodes($xpath);
-           if (@nodes) {
-               warn scalar(@nodes), " nodes match '$xpath'" if @nodes > 1;
-               my $node = $nodes[0];
-               if ($node->isa("XML::LibXML::Attr")) {
-                   $node->setValue($value);
-                   #print "Attr $key <- '$value' ($xpath)<br/>\n";
-               } elsif ($node->isa("XML::LibXML::Element")) {
-                   my $child = $node->firstChild();
-                   die "element child $child is not text"
-                       if !ref $child || !$child->isa("XML::LibXML::Text");
-                   $child->setData($value);
-                   #print "Elem $key <- '$value' ($xpath)<br/>\n";
-               } else {
-                   warn "unexpected node type $node";
-               }
-           } else {
-               next if !$value;
-               my($ppath, $element) = $xpath =~ /(.*)\/(.*)/;
-               dom_add_element($xc, $ppath, $element, $value, @addAfter);
-           }
+           $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>
        }
        ZOOM::IRSpy::_really_rewrite_record($conn, $xc->getContextNode());
     }
 </%perl>
-     <h2><% xml_encode($id) %></h2>
-% print "     <p><b>The record has been updated.</b></p>\n" if defined $update;
+     <h2><% xml_encode($xc->find("e:databaseInfo/e:title")) %></h2>
+% if ($nchanges) {
+     <p style="font-weight: bold">
+      The record has been updated.<br/>
+      Changed <% $nchanges %> element<% $nchanges == 1 ? "" : "s" %>.
+     </p>
+% }
      <form method="get" action="">
       <table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
 <%perl>
      <form method="get" action="">
       <table class="fullrecord" border="1" cellspacing="0" cellpadding="5" width="100%">
 <%perl>
@@ -113,4 +102,12 @@ if ($n == 0) {
        </tr>
       </table>
      </form>
        </tr>
       </table>
      </form>
+<%perl>
+       if ($nchanges) {
+           my $x = $xc->getContextNode()->toString();
+           $x = xml_encode($x);
+           #$x =~ s/$/<br\/>/gm;
+           print "<pre>$x</pre>\n";
+       }
+</%perl>
 % }
 % }