[open-ils-commits] r18273 - in branches/rel_1_6/Open-ILS: src/perlmods/OpenILS/WWW web/js/dojo/MARC (miker)

svn at svn.open-ils.org svn at svn.open-ils.org
Mon Oct 11 16:44:44 EDT 2010


Author: miker
Date: 2010-10-11 16:44:39 -0400 (Mon, 11 Oct 2010)
New Revision: 18273

Modified:
   branches/rel_1_6/Open-ILS/src/perlmods/OpenILS/WWW/TemplateBatchBibUpdate.pm
   branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Field.js
   branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Record.js
Log:
Backporting r18271 and r18272 from trunk

Modified: branches/rel_1_6/Open-ILS/src/perlmods/OpenILS/WWW/TemplateBatchBibUpdate.pm
===================================================================
--- branches/rel_1_6/Open-ILS/src/perlmods/OpenILS/WWW/TemplateBatchBibUpdate.pm	2010-10-11 20:42:46 UTC (rev 18272)
+++ branches/rel_1_6/Open-ILS/src/perlmods/OpenILS/WWW/TemplateBatchBibUpdate.pm	2010-10-11 20:44:39 UTC (rev 18273)
@@ -58,16 +58,19 @@
     my $usr = verify_login($authid);
     return show_template($r) unless ($usr);
 
-
     my $template = $cgi->param('template');
     return show_template($r) unless ($template);
 
+
+    my $rsource = $cgi->param('recordSource');
     # find some IDs ...
     my @records;
 
-    @records = map { $_ ? ($_) : () } $cgi->param('recid');
+    if ($rsource eq 'r') {
+        @records = map { $_ ? ($_) : () } $cgi->param('recid');
+    }
 
-    if (!@records) { # try for a file
+    if ($rsource eq 'c') { # try for a file
         my $file = $cgi->param('idfile');
         if ($file) {
             my $col = $cgi->param('idcolumn') || 0;
@@ -89,23 +92,25 @@
 
     # still no records ...
     my $container = $cgi->param('containerid');
-    if ($container) {
-        my $bucket = $e->request(
-            'open-ils.cstore.direct.container.biblio_record_entry_bucket.retrieve',
-            $container
-        )->gather(1);
-        unless($bucket) {
-            $e->request('open-ils.cstore.transaction.rollback')->gather(1);
-            $e->disconnect;
-            $r->log->error("No such bucket $container");
-            $logger->error("No such bucket $container");
-            return Apache2::Const::NOT_FOUND;
+    if ($rsource eq 'b') {
+        if ($container) {
+            my $bucket = $e->request(
+                'open-ils.cstore.direct.container.biblio_record_entry_bucket.retrieve',
+                $container
+            )->gather(1);
+            unless($bucket) {
+                $e->request('open-ils.cstore.transaction.rollback')->gather(1);
+                $e->disconnect;
+                $r->log->error("No such bucket $container");
+                $logger->error("No such bucket $container");
+                return Apache2::Const::NOT_FOUND;
+            }
+            my $recs = $e->request(
+                'open-ils.cstore.direct.container.biblio_record_entry_bucket_item.search.atomic',
+                { bucket => $container }
+            )->gather(1);
+            @records = map { ($_->target_biblio_record_entry) } @$recs;
         }
-        my $recs = $e->request(
-            'open-ils.cstore.direct.container.biblio_record_entry_bucket_item.search.atomic',
-            { bucket => $container }
-        )->gather(1);
-        @records = map { ($_->target_biblio_record_entry) } @$recs;
     }
 
     unless (@records) {
@@ -275,7 +280,7 @@
         </script>
     </head>
 
-    <body class='tundra'>
+    <body style="margin:10px;" class='tundra'>
         <div class="hide_me"><div dojoType="openils.widget.ProgressDialog" jsId="progress_dialog"></div></div>
 
         <table style="width:100%; margin-top:100px;">
@@ -485,21 +490,22 @@
         </script>
     </head>
 
-    <body class='tundra'>
+    <body style="margin:10px;" class='tundra'>
 
         <div dojoType="dijit.form.Form" id="myForm" jsId="myForm" encType="multipart/form-data" action="" method="POST">
                 <script type='dojo/method' event='onSubmit'>
                     var rec = ruleset_to_record();
 
-                    // no-op to force replace mode
-                    rec.appendFields(
-                        new MARC.Field ({
-                            tag : '905',
-                            ind1 : ' ',
-                            ind2 : ' ',
-                            subfields : [['r','901c']]
-                        })
-                    );
+                    if (rec.subfield('905','r') == '') { // no-op to force replace mode
+                        rec.appendFields(
+                            new MARC.Field ({
+                                tag : '905',
+                                ind1 : ' ',
+                                ind2 : ' ',
+                                subfields : [['r','901c']]
+                            })
+                        );
+                    }
 
                     dojo.byId('template_value').value = rec.toXmlString();
                     return true;
@@ -507,14 +513,47 @@
 
             <input type='hidden' id='template_value' name='template'/>
 
-            <table>
+            <label for='inputTypeSelect'>Record source:</label>
+            <select name='recordSource' dojoType='dijit.form.FilteringSelect'>
+                <script type='dojo/method' event='onChange' args="val">
+                    switch (val) {
+                        case 'b':
+                            dojo.removeClass('bucketListContainer','hide_me');
+                            dojo.addClass('csvContainer','hide_me');
+                            dojo.addClass('recordContainer','hide_me');
+                            break;
+                        case 'c':
+                            dojo.addClass('bucketListContainer','hide_me');
+                            dojo.removeClass('csvContainer','hide_me');
+                            dojo.addClass('recordContainer','hide_me');
+                            break;
+                        case 'r':
+                            dojo.addClass('bucketListContainer','hide_me');
+                            dojo.addClass('csvContainer','hide_me');
+                            dojo.removeClass('recordContainer','hide_me');
+                            break;
+                    };
+                </script>
+                <script type='dojo/method' event='postCreate'>
+                    if (cgi.param('recordSource')) {
+                        this.attr('value',cgi.param('recordSource'));
+                        this.onChange(cgi.param('recordSource'));
+                    }
+                </script>
+                <option value='b'>a Bucket</option>
+                <option value='c'>a CSV File</option>
+                <option value='r'>a specific record ID</option>
+            </select>
+
+            <table style='margin:10px; margin-bottom:20px;'>
+<!--
                 <tr>
-                    <th>Optional merge queue name:</th>
-                    <td><input id='bucketName' type='text' dojoType='dijit.form.TextBox' name='bname' value=''/></td>
+                    <th>Merge template name (optional):</th>
+                    <td><input id='bucketName' jsId='bucketName' type='text' dojoType='dijit.form.TextBox' name='bname' value=''/></td>
                 </tr>
-                <tr>
-                    <th>Batch update records in Bucket:</th>
-                    <td>
+-->
+                <tr class='' id='bucketListContainer'>
+                    <td>Bucket named: 
                         <div name='containerid' jsId='bucketList' dojoType='dijit.form.FilteringSelect' store='bucketStore' searchAttr='name' id='bucketList'>
                             <script type='dojo/method' event='postCreate'>
                                 if (cgi.param('containerid')) this.attr('value',cgi.param('containerid'));
@@ -522,20 +561,24 @@
                         </div>
                     </td>
                 </tr>
-                <tr><th colspan='2'><div style='text-align: center;'>or</div></hd></tr>
-                <tr>
-                    <th>Batch update records from CSV file:</th>
-                    <td><input id='idfile' type="file" name="idfile"/><br/>Column <input style='width:75px;' type='text' dojoType='dijit.form.NumberSpinner' name='idcolumn' value='0' constraints='{min:0,max:100,places:0}' /> starting from 0</td>
+                <tr class='hide_me' id='csvContainer'>
+                    <td>
+                        Column <input style='width:75px;' type='text' dojoType='dijit.form.NumberSpinner' name='idcolumn' value='0' constraints='{min:0,max:100,places:0}' /> (starting from 0) of: 
+                        <input id='idfile' type="file" name="idfile"/>
+                    </td>
                 </tr>
-                <tr><th colspan='2'><div style='text-align: center;'>or</div></th></tr>
-                <tr>
-                    <th>Test Ruleset by applying to one record:</th>
-                    <td><input name='recid' style='width:75px;' type='text' dojoType='dijit.form.NumberTextBox' name='id' value='' constraints='{min:0}' /></td>
+                <tr class='hide_me' id='recordContainer'>
+                    <td>Record ID:
+                        <input name='recid' style='width:75px;' type='text' dojoType='dijit.form.NumberTextBox' name='id' value='' constraints='{min:0}'></input>
+                    </td>
                 </tr>
             </table>
 
             <button type="submit" dojoType='dijit.form.Button'>Apply Ruleset</button>
 
+            <br/>
+            <br/>
+
         </div> <!-- end of the form -->
 
         <hr/>
@@ -570,8 +613,9 @@
                         <td name='tagContainer'><input style='with: 2em;' name='tag' type='text'></input</td>
                     </td>
                     <tr>
-                        <th>Optional Subfields</th>
+                        <th>Subfields (optional)</th>
                         <td name='sfContainer'><input name='sf' type='text'/></td>
+                        <td>No spaces, no delimiters, eg: abcnp</td>
                     </tr>
                     <tr>
                         <th>MARC Data</th>

Modified: branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Field.js
===================================================================
--- branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Field.js	2010-10-11 20:42:46 UTC (rev 18272)
+++ branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Field.js	2010-10-11 20:44:39 UTC (rev 18273)
@@ -40,7 +40,7 @@
 
         subfield : function (code) {
             var list = dojo.filter( this.subfields, function (s) {
-                if (s[0] == code) return true; return true;
+                if (s[0] == code) return true; return false;
             });
             if (list.length == 1) return list[0];
             return list;

Modified: branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Record.js
===================================================================
--- branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Record.js	2010-10-11 20:42:46 UTC (rev 18272)
+++ branches/rel_1_6/Open-ILS/web/js/dojo/MARC/Record.js	2010-10-11 20:44:39 UTC (rev 18273)
@@ -57,7 +57,11 @@
             return list;
         },
 
-        subfield : function (spec, code) { return this.field(spec)[0].subfield(code) },
+        subfield : function (spec, code) {
+            var f = this.field(spec);
+            if (dojo.isArray(f)) f = f[0];
+            return f.subfield(code)
+        },
 
         appendFields : function () {
             var me = this;



More information about the open-ils-commits mailing list