plugged in amount paid columns and new total column for amount paid
authorerickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Fri, 9 Apr 2010 13:00:13 +0000 (13:00 +0000)
committererickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Fri, 9 Apr 2010 13:00:13 +0000 (13:00 +0000)
added some confirm dialogs

git-svn-id: svn://svn.open-ils.org/ILS/trunk@16192 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/web/js/dojo/openils/acq/nls/acq.js
Open-ILS/web/js/ui/default/acq/invoice/view.js
Open-ILS/web/templates/default/acq/invoice/view.tt2

index b4759e0..6911122 100644 (file)
@@ -60,5 +60,6 @@
     'INVOICE_CONFIRM_ITEM_DELETE' : "Remove this $${0} '${1}' charge from the invoice?",
     'INVOICE_CONFIRM_ENTRY_DETACH' : "Remove $${0} charge for item '${1}, ${2} [${3}] from the invoice?",
     'INVOICE_TITLE_DETAILS' : "<div class='acq-inoice-item-info'>${0}, by ${1} (${2})</div><div class='acq-inoice-item-extra-info'><a style='padding-right: 10px;' href='${9}/acq/po/view/${10}'>PO: ${11}</a>${3} Ordered, ${4} Received, ${7} Invoiced</div><div class='acq-inoice-item-extra-info'> Estimated Cost Per Item $${5} / Total Estimated Cost $${6}</div>",
+    'INVOICE_CONFIRM_PRORATE' : "Prorate charges?\n\nAny subsequent changes to the invoice that would affect prorated amounts should be resolved manually.",
     'UNNAMED': "Unnamed"
 }
index f44b962..cf1d1b3 100644 (file)
@@ -25,7 +25,8 @@ var invoice;
 var itemTbody;
 var itemTemplate;
 var entryTemplate;
-var totalAmountBox;
+var totalInvoicedBox;
+var totalPaidBox;
 var invoicePane;
 var itemTypes;
 var virtualId = -1;
@@ -164,8 +165,8 @@ function doAttachPo() {
 
 function updateTotalCost() {
     var total = 0;    
-    if(!totalAmountBox) {
-        totalAmountBox = new dijit.form.CurrencyTextBox(
+    if(!totalInvoicedBox) {
+        totalInvoicedBox = new dijit.form.CurrencyTextBox(
             {style : 'width: 5em'}, dojo.byId('acq-invoice-total-invoiced'));
     }
     for(var id in widgetRegistry.acqii) 
@@ -174,7 +175,20 @@ function updateTotalCost() {
     for(var id in widgetRegistry.acqie) 
         if(!widgetRegistry.acqie[id]._object.isdeleted())
             total += widgetRegistry.acqie[id].cost_billed.getFormattedValue();
-    totalAmountBox.attr('value', total);
+    totalInvoicedBox.attr('value', total);
+
+    total = 0;    
+    if(!totalPaidBox) {
+        totalPaidBox = new dijit.form.CurrencyTextBox(
+            {style : 'width: 5em'}, dojo.byId('acq-invoice-total-paid'));
+    }
+    for(var id in widgetRegistry.acqii) 
+        if(!widgetRegistry.acqii[id]._object.isdeleted())
+            total += widgetRegistry.acqii[id].amount_paid.getFormattedValue();
+    for(var id in widgetRegistry.acqie) 
+        if(!widgetRegistry.acqie[id]._object.isdeleted())
+            total += widgetRegistry.acqie[id].amount_paid.getFormattedValue();
+    totalPaidBox.attr('value', total);
 }
 
 
@@ -207,7 +221,7 @@ function addInvoiceItem(item) {
     var itemType = itemTypes.filter(function(t) { return (t.code() == item.inv_item_type()) })[0];
 
     dojo.forEach(
-        ['title', 'author', 'cost_billed'], 
+        ['title', 'author', 'cost_billed', 'amount_paid'], 
         function(field) {
             registerWidget(
                 item,
@@ -216,7 +230,7 @@ function addInvoiceItem(item) {
                     fmClass : 'acqii',
                     fmObject : item,
                     fmField : field,
-                    dijitArgs : (field == 'cost_billed') ? {required : true, style : 'width: 5em'} : null,
+                    dijitArgs : (field == 'cost_billed' || field == 'amount_paid') ? {required : true, style : 'width: 5em'} : null,
                     parentNode : nodeByName(field, row)
                 })
             )
@@ -225,8 +239,6 @@ function addInvoiceItem(item) {
 
 
     /* ----------- fund -------------- */
-    var itemType = itemTypes.filter(function(t) { return (t.code() == item.inv_item_type()) })[0];
-
     var fundArgs = {
         fmClass : 'acqii',
         fmObject : item,
@@ -237,11 +249,11 @@ function addInvoiceItem(item) {
     }
 
     if(item.fund_debit()) {
-        fundArgs.readOnly = true;
+        fundArgs.searchFilter = {'-or' : [{active : 't'}, {id : item.fund()}]};
     } else {
         fundArgs.searchFilter = {active : 't'}
         if(itemType && openils.Util.isTrue(itemType.prorate()))
-            fundArgs.disabled = true;
+            fundArgs.dijitArgs = {disabled : true};
     }
 
     var fundWidget = new openils.widget.AutoFieldWidget(fundArgs);
@@ -350,7 +362,7 @@ function addInvoiceEntry(entry) {
 
 
     dojo.forEach(
-        ['inv_item_count', 'phys_item_count', 'cost_billed'],
+        ['inv_item_count', 'phys_item_count', 'cost_billed', 'amount_paid'],
         function(field) {
             var dijitArgs = {required : true, constraints : {min: 0}, style : 'width:5em'};
             if(entry.isnew() && field == 'phys_item_count') dijitArgs.value = numReceived;
@@ -402,7 +414,7 @@ function liMarcAttr(lineitem, name) {
     return (attr) ? attr.attr_value() : '';
 }
 
-function saveChanges() {
+function saveChanges(doProrate) {
     
     progressDialog.show(true);
 
@@ -470,6 +482,8 @@ function saveChanges() {
                 progressDialog.hide();
                 var invoice = openils.Util.readResponse(r);
                 if(invoice) {
+                    if(doProrate)
+                        return prorateInvoice();
                     location.href = oilsBasePath + '/acq/invoice/view/' + invoice.id();
                 }
             }
@@ -477,11 +491,12 @@ function saveChanges() {
     );
 }
 
-function processInvoice() {
+function prorateInvoice() {
+    if(!confirm(localeStrings.INVOICE_CONFIRM_PRORATE)) return;
     progressDialog.show(true);
 
     fieldmapper.standardRequest(
-        ['open-ils.acq', 'open-ils.acq.invoice.process'],
+        ['open-ils.acq', 'open-ils.acq.invoice.apply_prorate'],
         {
             params : [openils.User.authtoken, invoice.id()],
             oncomplete : function(r) {
index 7112b15..3368e6b 100644 (file)
             <!-- acq.invoice_entry -->
             <thead>
                 <td colspan='3'>Title Details</td>
-                <td># Items Invoiced / # Received</td>
+                <td># Invoiced / # Received</td>
                 <td>Amount Billed</td>
+                <td>Amount Paid</td>
                 <td>Detach</td>
             </thead>
             <tbody id='acq-invoice-entry-tbody'>
                 <tr id='acq-invoice-entry-template' class='acq-invoice-row'>
                     <td colspan='3'>
                         <div name='title_details'></div>
+                        <div name='note'></div>
                     </td>
                     <td nowrap='nowrap'>
                         <span name='inv_item_count'></span>&nbsp;/&nbsp;<span name='phys_item_count'></span>
                     </td>
                     <td><div name='cost_billed'/></td>
+                    <td><div name='amount_paid'/></td>
                     <td><a href='javascript:void(0);' name='detach'>Detach</a></td>
                 </tr>
             </tbody>
@@ -57,6 +60,7 @@
                 <td>Author (optional)</td>
                 <td>Fund</td>
                 <td>Amount Billed</td>
+                <td>Amount Paid</td>
                 <td>Delete</td>
             </thead>
             <tbody id='acq-invoice-item-tbody'>
                     <td><div name='author'/></td>
                     <td><div name='fund'/></td>
                     <td><div name='cost_billed'/></td>
+                    <td><div name='amount_paid'/></td>
                     <td><a href='javascript:void(0);' name='delete'>Delete</a></td>
                 </tr>
             </tbody>
             <tbody>
                 <tr>
                     <td colspan='0'>
-                        <a href='javascript:void(0);' id='acq-invoice-new-item'>Add Invoice Item...</a>
+                        <a href='javascript:void(0);' id='acq-invoice-new-item'>Add Charge...</a>
                     </td>
                 </tr>
             </tbody>
             <thead>
                 <tr>
                     <td colspan='4'/>
-                    <td>Total Amount</td>
+                    <td>Total Invoiced</td>
+                    <td>Total Paid</td>
                 </tr>
             </thead>
             <tbody>
                 <tr>
                     <td colspan='4' style='text-align:right;'>
-                        <button dojoType='dijit.form.Button' onclick='saveChanges();'>Save &amp; Continue</button>
-                        <button dojoType='dijit.form.Button' onclick='processInvoice();'>Process Invoice</button>
+                        <button dojoType='dijit.form.Button' onclick='saveChanges();'>Save Changes</button>
+                        <button dojoType='dijit.form.Button' onclick='saveChanges(true);'>Save &amp; Prorate Charges</button>
                     </td>
                     <td><div id='acq-invoice-total-invoiced'/></td>
+                    <td><div id='acq-invoice-total-paid'/></td>
                 </tr>
             </tbody>
         </table>