Acq: add a Create PO interface for workflows starting with new, blank POs
authorsenator <senator@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 22 Jun 2010 17:07:38 +0000 (17:07 +0000)
committersenator <senator@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 22 Jun 2010 17:07:38 +0000 (17:07 +0000)
git-svn-id: svn://svn.open-ils.org/ILS/trunk@16778 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/web/js/dojo/openils/widget/EditPane.js
Open-ILS/web/js/ui/default/acq/po/create.js [new file with mode: 0644]
Open-ILS/web/opac/locale/en-US/lang.dtd
Open-ILS/web/templates/default/acq/po/create.tt2 [new file with mode: 0644]
Open-ILS/xul/staff_client/chrome/content/main/menu.js
Open-ILS/xul/staff_client/chrome/content/main/menu_frame_menus.xul
Open-ILS/xul/staff_client/chrome/locale/en-US/offline.properties

index 69b005b..800eb0b 100644 (file)
@@ -204,7 +204,6 @@ if(!dojo._hasResource['openils.widget.EditPane']) {
             },
 
             performEditAction : function(opts) {
-                var pcrud = new openils.PermaCrud();
                 var fields = this.getFields();
                 if(this.mode == 'create')
                     this.fmObject = new fieldmapper[this.fmClass]();
@@ -212,7 +211,11 @@ if(!dojo._hasResource['openils.widget.EditPane']) {
                     this.fmObject[fields[idx]](this.getFieldValue(fields[idx]));
                 if(this.mode == 'create' && this.fmIDL.pkey_sequence)
                     this.fmObject[this.fmIDL.pkey](null);
-                pcrud[this.mode](this.fmObject, opts);
+                if (typeof(this.onSubmit) == "function") {
+                    this.onSubmit(this.fmObject);
+                } else {
+                    (new openils.PermaCrud())[this.mode](this.fmObject, opts);
+                }
             }
         }
     );
diff --git a/Open-ILS/web/js/ui/default/acq/po/create.js b/Open-ILS/web/js/ui/default/acq/po/create.js
new file mode 100644 (file)
index 0000000..804ad0a
--- /dev/null
@@ -0,0 +1,54 @@
+dojo.require("openils.widget.EditDialog");
+dojo.require("openils.widget.EditPane");
+
+var editDialog;
+
+function toPoListing() {
+    location.href = oilsBasePath + "/acq/search/unified?ca=po";
+}
+
+function toOnePo(id) {
+    location.href = oilsBasePath + "/acq/po/view/" + id;
+}
+
+openils.Util.addOnLoad(
+    function() {
+        editDialog = new openils.widget.EditDialog({
+            "editPane": new openils.widget.EditPane({
+                "fmObject": new acqpo(),
+                /* After realizing how many fields should be excluded from this
+                 * interface because users shouldn't set them arbitrarily,
+                 * it hardly seems like using these Edit widgets gives much
+                 * much advantage over a hardcoded interface. */
+                "suppressFields": [
+                    "create_time", "edit_time", "editor", "order_date",
+                    "owner", "cancel_reason", "creator", "state", "name"
+                ],
+                "fieldOrder": ["ordering_agency", "provider"],
+                "mode": "create",
+                "onSubmit": function(po) {
+                    fieldmapper.standardRequest(
+                        ["open-ils.acq", "open-ils.acq.purchase_order.create"],{
+                            "async": false,
+                            "params": [openils.User.authtoken, po],
+                            "onresponse": function(r) {
+                                toOnePo(
+                                    openils.Util.readResponse(r).
+                                    purchase_order.id()
+                                );
+                            }
+                        }
+                    );
+                },
+                "onCancel": function() {
+                    editDialog.hide();
+                    toPoListing();
+                    /* I'd rather do window.close() or xulG.close_tab(),
+                     * but neither of those seem to work here. */
+                }
+            })
+        });
+        editDialog.startup();
+        editDialog.show();
+    }
+);
index de0946f..365f92e 100644 (file)
 <!ENTITY staff.main.menu.acq.upload.accesskey "M">
 <!ENTITY staff.main.menu.acq.view_local_po.label "Purchase Orders">
 <!ENTITY staff.main.menu.acq.view_local_po.accesskey "P">
+<!ENTITY staff.main.menu.acq.create_po.label "Create Purchase Order">
+<!ENTITY staff.main.menu.acq.create_po.accesskey "O">
 <!ENTITY staff.main.menu.acq.claim_eligible.label "Claim-Ready Items">
 <!ENTITY staff.main.menu.acq.claim_eligible.accesskey "R">
 <!ENTITY staff.main.menu.acq.view_local_inv.label "Open Invoices">
diff --git a/Open-ILS/web/templates/default/acq/po/create.tt2 b/Open-ILS/web/templates/default/acq/po/create.tt2
new file mode 100644 (file)
index 0000000..87d2b47
--- /dev/null
@@ -0,0 +1,8 @@
+[% WRAPPER "default/base.tt2" %]
+[% ctx.page_title = "Create Purchase Order" %]
+<script
+    type="text/javascript"
+    src="[% ctx.media_prefix %]/js/ui/default/acq/po/create.js">
+</script>
+<h1>Create Purchase Order</h1>
+[% END %]
index b679c1c..ff628ce 100644 (file)
@@ -788,6 +788,10 @@ main.menu.prototype = {
                 ['oncommand'],
                 function() { open_eg_web_page('acq/search/unified?ca=po', 'menu.cmd_acq_unified_search.tab'); }
             ],
+            'cmd_acq_create_po' : [
+                ['oncommand'],
+                function() { open_eg_web_page('acq/po/create', 'menu.cmd_acq_po.tab'); }
+            ],
             'cmd_acq_view_local_inv' : [
                 ['oncommand'],
                 function() { open_eg_web_page('acq/search/unified?ca=inv', 'menu.cmd_acq_unified_search.tab'); }
index d81e384..8a737ec 100644 (file)
@@ -78,6 +78,7 @@
     <command id="cmd_open_vandelay" />
     
     <command id="cmd_acq_create_invoice" />
+    <command id="cmd_acq_create_po" />
     <command id="cmd_acq_view_my_pl" />
     <command id="cmd_acq_view_local_po" />
     <command id="cmd_acq_view_local_inv" />
         <menuseparator />
         <menuitem label="&staff.main.menu.acq.upload.label;" accesskey="&staff.main.menu.acq.upload.accesskey;" command="cmd_acq_upload"/>
         <menuitem label="&staff.main.menu.acq.view_local_po.label;" accesskey="&staff.main.menu.acq.view_local_po.accesskey;" command="cmd_acq_view_local_po"/>
+        <menuitem label="&staff.main.menu.acq.create_po.label;" accesskey="&staff.main.menu.acq.create_po.accesskey;" command="cmd_acq_create_po"/>
         <menuseparator />
         <menuitem label="&staff.main.menu.acq.claim_eligible.label;" accesskey="&staff.main.menu.acq.claim_eligible.accesskey;" command="cmd_acq_claim_eligible" />
         <menuitem label="&staff.main.menu.acq.view_local_inv.label;" accesskey="&staff.main.menu.acq.view_local_inv.accesskey;" command="cmd_acq_view_local_inv"/>
index 7e84bc9..5435982 100644 (file)
@@ -230,7 +230,7 @@ menu.cmd_acq_from_bib.tab=Import Catalog Records
 menu.cmd_acq_unified_search.tab=Acquisitions Search
 menu.cmd_acq_upload.tab=Load Order Record
 menu.cmd_acq_new_brief_record.tab=New Brief Record
-menu.cmd_acq_view_po_events.tab=Purchase Order Events
+menu.cmd_acq_po.tab=Purchase Orders
 menu.cmd_acq_user_requests.tab=User Requests
 menu.cmd_acq_claim_eligible.tab=Claim-Eligible Items
 menu.cmd_booking_resource.tab=Resources