svn commit: r556498 - in /ofbiz/trunk/applications/accounting: config/AccountingUiLabels.properties src/org/ofbiz/accounting/invoice/InvoiceServices.java webapp/accounting/payment/PaymentForms.xml

Previous Topic Next Topic
 
classic Classic list List threaded Threaded
1 message Options
Reply | Threaded
Open this post in threaded view
|

svn commit: r556498 - in /ofbiz/trunk/applications/accounting: config/AccountingUiLabels.properties src/org/ofbiz/accounting/invoice/InvoiceServices.java webapp/accounting/payment/PaymentForms.xml

hansbak-2
Author: hansbak
Date: Sun Jul 15 19:49:15 2007
New Revision: 556498

URL: http://svn.apache.org/viewvc?view=rev&rev=556498
Log:
OFBIZ-1144, a patch from   Rashko Rejmer to fix payment application problems

Modified:
    ofbiz/trunk/applications/accounting/config/AccountingUiLabels.properties
    ofbiz/trunk/applications/accounting/src/org/ofbiz/accounting/invoice/InvoiceServices.java
    ofbiz/trunk/applications/accounting/webapp/accounting/payment/PaymentForms.xml

Modified: ofbiz/trunk/applications/accounting/config/AccountingUiLabels.properties
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/accounting/config/AccountingUiLabels.properties?view=diff&rev=556498&r1=556497&r2=556498
==============================================================================
--- ofbiz/trunk/applications/accounting/config/AccountingUiLabels.properties (original)
+++ ofbiz/trunk/applications/accounting/config/AccountingUiLabels.properties Sun Jul 15 19:49:15 2007
@@ -602,7 +602,7 @@
 AccountingFromPartySameToParty=At least the 'from' party should be the same as the 'to' party of the other payment\n
 AccountingBillingAccountNotFound=Billing Account [${billingAccountId}] not found...\n
 AccountingBillingAccountBalanceNotFound=Billing Account [${billingAccountId}] balance not found...(\n"
-AccountingBillingAccountBalanceProblem=Billing Account [${billingAccountId}] doesn't have a positive balance: ${billingAccountApplyAvailable?currency(${isoCode})}\n
+AccountingBillingAccountBalanceProblem=Billing Account [${billingAccountId}] doesn't have a positive balance: ${billingAccountAvailableBalance?currency(${isoCode})}\n
 AccountingBillingAccountLessRequested=Billing Account [${billingAccountId}] has ${billingAccountApplyAvailable?currency(${isoCode})} to apply but ${amountApplied?currency(${isoCode})} is requested\n
 AccountingBillingAccountCurrencyProblem=Currencies are not the same, Billing Account [${billingAccountId}] has currency: ${accountCurrencyUomId} and Payment [${paymentId}] has currency: ${paymentCurrencyUomId}\n
 AccountingInvoiceNotFound=Invoice [${invoiceId}] record not found\n

Modified: ofbiz/trunk/applications/accounting/src/org/ofbiz/accounting/invoice/InvoiceServices.java
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/accounting/src/org/ofbiz/accounting/invoice/InvoiceServices.java?view=diff&rev=556498&r1=556497&r2=556498
==============================================================================
--- ofbiz/trunk/applications/accounting/src/org/ofbiz/accounting/invoice/InvoiceServices.java (original)
+++ ofbiz/trunk/applications/accounting/src/org/ofbiz/accounting/invoice/InvoiceServices.java Sun Jul 15 19:49:15 2007
@@ -2327,13 +2327,31 @@
             
             // check if at least one send is the same as one receiver on the other payment
             if (!payment.getString("partyIdFrom").equals(toPayment.getString("partyIdTo")) &&
-                    !payment.getString("partyIdFrom").equals(toPayment.getString("partyIdTo")))    {
+                    !payment.getString("partyIdTo").equals(toPayment.getString("partyIdFrom")))    {
                 errorMessageList.add(UtilProperties.getMessage(resource, "AccountingFromPartySameToParty", locale));
             }
 
             if (debug) Debug.logInfo("toPayment info retrieved and checked...", module);
         }
 
+        // assign payment to billing account if the invoice is assigned to this billing account
+        if (invoiceId != null) {
+            GenericValue invoice = null;
+            try {
+                invoice = delegator.findByPrimaryKey("Invoice", UtilMisc.toMap("invoiceId", invoiceId));
+            } catch (GenericEntityException e) {
+                ServiceUtil.returnError(e.getMessage());
+            }
+            
+            if (invoice == null) {
+                errorMessageList.add(UtilProperties.getMessage(resource, "AccountingInvoiceNotFound",UtilMisc.toMap("invoiceId",invoiceId),locale));
+            } else {
+                if (invoice.getString("billingAccountId") != null) {
+                    billingAccountId = invoice.getString("billingAccountId");
+                }
+            }
+        }
+        
         // billing account
         GenericValue billingAccount = null;
         BigDecimal billingAccountApplyAvailable = ZERO;
@@ -2346,36 +2364,6 @@
             if (billingAccount == null) {
                 errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountNotFound",UtilMisc.toMap("billingAccountId",billingAccountId), locale));
             }
-            
-            // Get the available balance, which is how much can be used, rather than the regular balance, which is how much has already been charged
-            try {
-                billingAccountApplyAvailable = BillingAccountWorker.availableToCapture(billingAccount);
-            } catch (GenericEntityException e) {
-                errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountBalanceNotFound",UtilMisc.toMap("billingAccountId",billingAccountId), locale));
-                ServiceUtil.returnError(e.getMessage());
-            }
-
-            if (paymentApplicationId == null) {
-                // when creating a new PaymentApplication, check if there is sufficient balance in the billing account, but only if the invoiceId is not null
-                // If you create a PaymentApplication with both billingAccountId and invoiceId, then you're applying a billing account towards an invoice
-                // If you create a PaymentApplication just with billingAccountId and no invoiceId, then you're adding value to billing account, so it should not matter
-                // what the previous available balance is
-                if (invoiceId != null) {
-                    if (billingAccountApplyAvailable.signum() <= 0)  {
-                        errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountBalanceProblem",UtilMisc.toMap("billingAccountId",billingAccountId,"isoCode",billingAccount.getString("accountCurrencyUomId")), locale));
-                    } else {
-                        // check here for too much application if a new record is
-                        // added (paymentApplicationId == null)
-                        if (amountApplied.compareTo(billingAccountApplyAvailable) == 1) {
-                            errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountLessRequested",
-                                        UtilMisc.toMap("billingAccountId",billingAccountId,
-                                            "billingAccountApplyAvailable",billingAccountApplyAvailable,
-                                            "amountApplied",amountApplied,"isoCode",billingAccount.getString("accountCurrencyUomId")),locale));
-                        }
-                    }
-                }
-            }
-
             // check the currency
             if (billingAccount.get("accountCurrencyUomId") != null && payment.get("currencyUomId") != null &&
                     !billingAccount.getString("accountCurrencyUomId").equals(payment.getString("currencyUomId"))) {
@@ -2403,8 +2391,7 @@
             
             if (invoice == null) {
                 errorMessageList.add(UtilProperties.getMessage(resource, "AccountingInvoiceNotFound",UtilMisc.toMap("invoiceId",invoiceId),locale));
-            }
-            else { // check the invoice and when supplied the invoice item...
+            } else { // check the invoice and when supplied the invoice item...
                 
                 if (invoice.getString("statusId").equals("INVOICE_CANCELLED")) {
                     errorMessageList.add(UtilProperties.getMessage(resource,"AccountingInvoiceCancelledCannotApplyTo",UtilMisc.toMap("invoiceId",invoiceId),locale));
@@ -2492,9 +2479,6 @@
         BigDecimal newInvoiceItemApplyAvailable = invoiceItemApplyAvailable;
         // amount available on the invoiceItem taking into account if the itemnumber has changed
         BigDecimal newToPaymentApplyAvailable = toPaymentApplyAvailable;
-        // amount available on the Billing Account taking into account if the billing account number has changed
-        BigDecimal newBillingAccountApplyAvailable = billingAccountApplyAvailable;
-        // amount available on the Billing Account taking into account if the billing account number has changed
         BigDecimal newPaymentApplyAvailable = paymentApplyAvailable;
         GenericValue paymentApplication = null;
         if (paymentApplicationId == null) {
@@ -2618,24 +2602,6 @@
                     }
 
                 }
-                // check the billing account when only the amountApplied has
-                // changed,
-                // change in account number is already checked in the billing
-                // account section
-                if (billingAccountId != null && billingAccountId.equals(paymentApplication.getString("billingAccountId"))) {
-                    newBillingAccountApplyAvailable = billingAccountApplyAvailable.subtract(paymentApplication.getBigDecimal("amountApplied")).add(amountApplied).setScale(decimals, rounding);
-                    if (newBillingAccountApplyAvailable.compareTo(ZERO) < 0) {
-                        errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountNotEnough",UtilMisc.toMap("billingAccountId",billingAccountId,"newBillingAccountApplyAvailable",newBillingAccountApplyAvailable,"amountApplied",amountApplied,"isoCode", billingAccount.getString("accountCurrencyUomId")),locale));
-                    }
-                } else if (billingAccountId != null) {
-                    // billing account entered number has changed so we have to
-                    // check the new billing account number.
-                    newBillingAccountApplyAvailable = billingAccountApplyAvailable.add(amountApplied).setScale(decimals, rounding);
-                    if (newBillingAccountApplyAvailable.compareTo(ZERO) < 0) {
-                        errorMessageList.add(UtilProperties.getMessage(resource, "AccountingBillingAccountNotEnough",UtilMisc.toMap("billingAccountId",billingAccountId,"newBillingAccountApplyAvailable",newBillingAccountApplyAvailable,"amountApplied",amountApplied,"isoCode", billingAccount.getString("accountCurrencyUomId")),locale));
-                    }
-
-                }
             }
             if (debug) Debug.logInfo("paymentApplication record info retrieved and checked...", module);
         }
@@ -2657,10 +2623,6 @@
                 Debug.logInfo(" toPayment(" + toPaymentId + ") amount not yet applied: " + newToPaymentApplyAvailable + " Payment(" + paymentId + ") amount not yet applied: " + newPaymentApplyAvailable + " Requested amount to apply:" + amountApplied, module);
                 toMessage = UtilProperties.getMessage(resource, "AccountingApplicationToPayment",UtilMisc.toMap("paymentId",toPaymentId),locale);
             }
-            if (billingAccountId != null) {
-                Debug.logInfo(" billingAccount(" + billingAccountId + ") amount not yet applied: " + newBillingAccountApplyAvailable + " Payment(" + paymentId + ") amount not yet applied: " + newPaymentApplyAvailable + " Requested amount to apply:" + amountApplied, module);
-                toMessage = UtilProperties.getMessage(resource, "AccountingApplicationToBillingAccount",UtilMisc.toMap("billingAccountId",billingAccountId),locale);
-            }
             if (taxAuthGeoId != null) {
                 Debug.logInfo(" taxAuthGeoId(" + taxAuthGeoId + ")  Payment(" + paymentId + ") amount not yet applied: " + newPaymentApplyAvailable + " Requested amount to apply:" + amountApplied, module);
                 toMessage = UtilProperties.getMessage(resource, "AccountingApplicationToTax",UtilMisc.toMap("taxAuthGeoId",taxAuthGeoId),locale);
@@ -2673,7 +2635,7 @@
                 amountApplied = newInvoiceApplyAvailable;
                 toMessage = UtilProperties.getMessage(resource, "AccountingApplicationToInvoice",UtilMisc.toMap("invoiceId",invoiceId),locale);
             }
-            if (toPaymentId != null && newToPaymentApplyAvailable.compareTo(amountApplied) == 1) {
+            if (toPaymentId != null && newToPaymentApplyAvailable.compareTo(amountApplied) < 0) {
                 amountApplied = newToPaymentApplyAvailable;
                 toMessage = UtilProperties.getMessage(resource, "AccountingApplicationToPayment",UtilMisc.toMap("paymentId",toPaymentId),locale);
             }
@@ -2681,8 +2643,7 @@
         
         if (amountApplied.signum() == 0) {
             errorMessageList.add(UtilProperties.getMessage(resource, "AccountingNoAmount",locale));
-        }
-        else {
+        } else {
             successMessage = UtilProperties.getMessage(resource, "AccountingApplicationSuccess",UtilMisc.toMap("amountApplied",amountApplied,"paymentId",paymentId,"isoCode", payment.getString("currencyUomId"),"toMessage",toMessage),locale);
         }
         
@@ -2720,7 +2681,7 @@
                 paymentApplication.set("invoiceItemSeqId", null);
                 paymentApplication.set("toPaymentId", null);
                 paymentApplication.set("amountApplied", new Double(amountApplied.doubleValue()));
-                paymentApplication.set("billingAccountId", null);
+                paymentApplication.set("billingAccountId", billingAccountId);
                 paymentApplication.set("taxAuthGeoId", null);
                 if (debug) Debug.logInfo("creating new paymentapplication", module);
                 return storePaymentApplication(delegator, paymentApplication,locale);

Modified: ofbiz/trunk/applications/accounting/webapp/accounting/payment/PaymentForms.xml
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/accounting/webapp/accounting/payment/PaymentForms.xml?view=diff&rev=556498&r1=556497&r2=556498
==============================================================================
--- ofbiz/trunk/applications/accounting/webapp/accounting/payment/PaymentForms.xml (original)
+++ ofbiz/trunk/applications/accounting/webapp/accounting/payment/PaymentForms.xml Sun Jul 15 19:49:15 2007
@@ -259,6 +259,7 @@
         <field name="paymentApplicationId"><hidden/></field>
         <field name="paymentId"><hidden/></field>
         <field name="billingAccountId"><lookup target-form-name="LookupBillingAccount"/></field>
+        <field name="invoiceId"><hidden/></field>
         <field name="amountApplied"><text size="15"/></field>
         <field name="updateButton" title="${uiLabelMap.CommonUpdate}" widget-style="buttontext"><submit button-type="text-link"/></field>
         <field name="removeButton" title="${uiLabelMap.CommonRemove}" widget-style="buttontext">