svn commit: r544091 - in /ofbiz/trunk/applications: ecommerce/webapp/ecommerce/order/ order/src/org/ofbiz/order/shoppingcart/ order/webapp/ordermgr/entry/

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

svn commit: r544091 - in /ofbiz/trunk/applications: ecommerce/webapp/ecommerce/order/ order/src/org/ofbiz/order/shoppingcart/ order/webapp/ordermgr/entry/

jacopoc
Author: jacopoc
Date: Mon Jun  4 01:46:41 2007
New Revision: 544091

URL: http://svn.apache.org/viewvc?view=rev&rev=544091
Log:
A bunch of cleanups and improvements to the billing account selection during checkout.
This also resolves issue OFBIZ-74

Modified:
    ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutpayment.ftl
    ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutshippingoptions.ftl
    ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutEvents.java
    ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutHelper.java
    ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/ShoppingCart.java
    ofbiz/trunk/applications/order/webapp/ordermgr/entry/billsettings.ftl
    ofbiz/trunk/applications/order/webapp/ordermgr/entry/checkoutoptions.ftl

Modified: ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutpayment.ftl
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutpayment.ftl?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutpayment.ftl (original)
+++ ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutpayment.ftl Mon Jun  4 01:46:41 2007
@@ -54,18 +54,6 @@
         form.submit();
 }
 
-function toggleBillingAccount(box) {
-    var amountName = "amount_" + box.value;
-    box.checked = true;
-    box.form.elements[amountName].disabled = false;
-
-    for (var i = 0; i < box.form.elements[box.name].length; i++) {
-        if (!box.form.elements[box.name][i].checked) {
-            box.form.elements["amount_" + box.form.elements[box.name][i].value].disabled = true;
-        }
-    }
-}
-
 // -->
 </script>
 
@@ -234,39 +222,29 @@
               <#if billingAccountList?has_content>
                 <tr><td colspan="3"><hr class="sepbar"/></td></tr>
                 <tr>
-                  <td width="1%" nowrap>
-                    <input type="radio" name="checkOutPaymentId" value="EXT_BILLACT" <#if "EXT_BILLACT" == checkOutPaymentId>checked</#if>></hr>
+                  <td width="1%">
+                    <select name="billingAccountId">
+                      <option value=""></option>
+                        <#list billingAccountList as billingAccount>
+                          <#assign availableAmount = billingAccount.accountBalance?double>
+                          <#assign accountLimit = billingAccount.accountLimit?double>
+                          <option value="${billingAccount.billingAccountId}" <#if billingAccount.billingAccountId == selectedBillingAccountId?default("")>selected</#if>>${billingAccount.description?default("")} [${billingAccount.billingAccountId}] with available amount of <@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId/> and account limit of <@ofbizCurrency amount=accountLimit isoCode=billingAccount.accountCurrencyUomId/></option>
+                        </#list>
+                    </select>
                   </td>
-                  <td width="50%" nowrap>
-                    <span class="tabletext">${uiLabelMap.AccountingPayOnlyWithBillingAccount}</span>
+                  <td width="50%">
+                    <span class="tabletext">${uiLabelMap.FormFieldTitle_billingAccountId}</span>
                   </td>
                   <td>&nbsp;</td>
                 </tr>
-                <tr><td colspan="3"><hr class="sepbar"/></td></tr>
-                <#list billingAccountList as billingAccount>
-                  <#assign availableAmount = billingAccount.accountLimit?double - billingAccount.accountBalance?double>
-                  <tr>
-                    <td align="left" valign="top" width="1%" nowrap>
-                      <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="${billingAccount.billingAccountId}" <#if (billingAccount.billingAccountId == selectedBillingAccountId?default(""))>checked</#if>>
-                    </td>
-                    <td align="left" valign="top" width="99%" nowrap>
-                      <div class="tabletext">
-                       ${billingAccount.description?default("Bill Account")} [${uiLabelMap.OrderNbr}<b>${billingAccount.billingAccountId}</b>]&nbsp;(<@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId?default(cart.getCurrency())/>)<br/>
-                       <b>${uiLabelMap.OrderBillUpTo}:</b> <input type="text" size="8" class="inputBox" name="amount_${billingAccount.billingAccountId}" value="${availableAmount?double?string("##0.00")}" <#if !(billingAccount.billingAccountId == selectedBillingAccountId?default(""))>disabled</#if>>
-                      </div>
-                    </td>
-                    <td>&nbsp;</td>
-                  </tr>
-                </#list>
                 <tr>
-                  <td align="left" valign="top" width="1%" nowrap>
-                    <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="_NA_" <#if (selectedBillingAccountId?default("") == "N")>checked</#if>>
-                    <input type="hidden" name="_NA_amount" value="0.00">
+                  <td width="1%" align="right">
+                    <input type="text" size="5" name="billingAccountAmount" value=""/>
                   </td>
-                  <td align="left" valign="top" width="99%" nowrap>
-                    <div class="tabletext">${uiLabelMap.AccountingNoBillingAccount}</div>
-                   </td>
-                   <td>&nbsp;</td>
+                  <td width="50%">
+                    ${uiLabelMap.OrderBillUpTo}
+                  </td>
+                  <td>&nbsp;</td>
                 </tr>
               </#if>
             </#if>

Modified: ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutshippingoptions.ftl
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutshippingoptions.ftl?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutshippingoptions.ftl (original)
+++ ofbiz/trunk/applications/ecommerce/webapp/ecommerce/order/checkoutshippingoptions.ftl Mon Jun  4 01:46:41 2007
@@ -55,18 +55,6 @@
     }
 }
 
-function toggleBillingAccount(box) {
-    var amountName = box.value + "_amount";
-    box.checked = true;
-    box.form.elements[amountName].disabled = false;
-
-    for (var i = 0; i < box.form.elements[box.name].length; i++) {
-        if (!box.form.elements[box.name][i].checked) {
-            box.form.elements[box.form.elements[box.name][i].value + "_amount"].disabled = true;
-        }
-    }
-}
-
 // -->
 </script>
 

Modified: ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutEvents.java
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutEvents.java?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutEvents.java (original)
+++ ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutEvents.java Mon Jun  4 01:46:41 2007
@@ -160,22 +160,21 @@
                 curPage = "payment";
             }
         } else if ("payment".equals(curPage) == true) {
-            // get the currency format
-            String currencyFormat = UtilProperties.getPropertyValue("general.properties", "currency.decimal.format", "##0.00");
-            DecimalFormat formatter = new DecimalFormat(currencyFormat);
-
             // Set the payment options
             Map selectedPaymentMethods = getSelectedPaymentMethods(request);
-            if (selectedPaymentMethods == null) {
-                return "error";
-            }
 
             String billingAccountId = request.getParameter("billingAccountId");
-            Double billingAccountAmt = determineBillingAccountAmount(request, checkOutHelper, formatter);
-            if ((billingAccountId != null) && !"_NA_".equals(billingAccountId) && (billingAccountAmt == null)) {
-                Map messageMap = UtilMisc.toMap("billingAccountId", billingAccountId);
-                String errMsg = UtilProperties.getMessage(resource, "checkevents.invalid_amount_set_for_billing_account", messageMap, (cart != null ? cart.getLocale() : Locale.getDefault()));
-                request.setAttribute("_ERROR_MESSAGE_", errMsg);
+            if (UtilValidate.isNotEmpty(billingAccountId)) {
+                Double billingAccountAmt = null;
+                billingAccountAmt = determineBillingAccountAmount(billingAccountId, request.getParameter("billingAccountAmount"), dispatcher);
+                if ((billingAccountId != null) && !"_NA_".equals(billingAccountId) && (billingAccountAmt == null)) {
+                    request.setAttribute("_ERROR_MESSAGE_", UtilProperties.getMessage(resource_error,"OrderInvalidAmountSetForBillingAccount", UtilMisc.toMap("billingAccountId",billingAccountId), (cart != null ? cart.getLocale() : Locale.getDefault())));
+                    return "error";
+                }
+                selectedPaymentMethods.put("EXT_BILLACT", billingAccountAmt);
+            }
+
+            if (UtilValidate.isEmpty(selectedPaymentMethods)) {
                 return "error";
             }
 
@@ -198,7 +197,7 @@
                 }
             }
 
-            Map callResult = checkOutHelper.setCheckOutPayment(selectedPaymentMethods, singleUsePayments, billingAccountId, billingAccountAmt);
+            Map callResult = checkOutHelper.setCheckOutPayment(selectedPaymentMethods, singleUsePayments, billingAccountId);
             ServiceUtil.getMessages(request, callResult, null);
 
             if (!(callResult.get(ModelService.RESPONSE_MESSAGE).equals(ModelService.RESPOND_ERROR))) {
@@ -307,13 +306,24 @@
         LocalDispatcher dispatcher = (LocalDispatcher) request.getAttribute("dispatcher");
         GenericDelegator delegator = (GenericDelegator) request.getAttribute("delegator");
 
-        // get the currency format
-        String currencyFormat = UtilProperties.getPropertyValue("general.properties", "currency.decimal.format", "##0.00");
-        DecimalFormat formatter = new DecimalFormat(currencyFormat);
-
         // Set the payment options
         Map selectedPaymentMethods = getSelectedPaymentMethods(request);
-        if (selectedPaymentMethods == null) {
+
+        CheckOutHelper checkOutHelper = new CheckOutHelper(dispatcher, delegator, cart);
+
+        // get the billing account and amount
+        String billingAccountId = request.getParameter("billingAccountId");
+        if (UtilValidate.isNotEmpty(billingAccountId)) {
+            Double billingAccountAmt = null;
+            billingAccountAmt = determineBillingAccountAmount(billingAccountId, request.getParameter("billingAccountAmount"), dispatcher);
+            if (billingAccountAmt == null) {
+                request.setAttribute("_ERROR_MESSAGE_", UtilProperties.getMessage(resource_error,"OrderInvalidAmountSetForBillingAccount", UtilMisc.toMap("billingAccountId",billingAccountId), (cart != null ? cart.getLocale() : Locale.getDefault())));
+                return "error";
+            }
+            selectedPaymentMethods.put("EXT_BILLACT", billingAccountAmt);
+        }
+
+        if (UtilValidate.isEmpty(selectedPaymentMethods)) {
             return "error";
         }
 
@@ -336,7 +346,6 @@
 
         // get a request map of parameters
         Map params = UtilHttp.getParameterMap(request);
-        CheckOutHelper checkOutHelper = new CheckOutHelper(dispatcher, delegator, cart);
 
         // if taxAuthPartyGeoIds is not empty drop that into the database
         if (UtilValidate.isNotEmpty(taxAuthPartyGeoIds)) {
@@ -354,16 +363,6 @@
             }
         }
         
-        // get the billing account and amount
-        String billingAccountId = request.getParameter("billingAccountId");
-        Double billingAccountAmt = determineBillingAccountAmount(request, checkOutHelper, formatter);
-        if ((billingAccountId != null) && !"_NA_".equals(billingAccountId) && (billingAccountAmt == null)) {
-            Map messageMap = UtilMisc.toMap("billingAccountId", billingAccountId);
-            String errMsg = UtilProperties.getMessage(resource, "checkevents.invalid_amount_set_for_billing_account", messageMap, (cart != null ? cart.getLocale() : Locale.getDefault()));
-            request.setAttribute("_ERROR_MESSAGE_", errMsg);
-            return "error";
-        }
-
         // check for gift card not on file
         Map gcResult = checkOutHelper.checkGiftCard(params, selectedPaymentMethods);
         ServiceUtil.getMessages(request, gcResult, null);
@@ -381,7 +380,7 @@
         }
 
         Map optResult = checkOutHelper.setCheckOutOptions(shippingMethod, shippingContactMechId, selectedPaymentMethods,
-                singleUsePayments, billingAccountId, billingAccountAmt, shippingInstructions,
+                singleUsePayments, billingAccountId, shippingInstructions,
                 orderAdditionalEmails, maySplit, giftMessage, isGift, internalCode, shipBeforeDate, shipAfterDate);
 
         ServiceUtil.getMessages(request, optResult, null);
@@ -791,7 +790,20 @@
 
             // Set the payment options
             Map selectedPaymentMethods = getSelectedPaymentMethods(request);
-            if (selectedPaymentMethods == null) {
+
+            // Set the billing account (if any)
+            String billingAccountId = request.getParameter("billingAccountId");
+            if (UtilValidate.isNotEmpty(billingAccountId)) {
+                Double billingAccountAmt = null;
+                billingAccountAmt = determineBillingAccountAmount(billingAccountId, request.getParameter("billingAccountAmount"), dispatcher);
+                if (billingAccountAmt == null) {
+                    request.setAttribute("_ERROR_MESSAGE_", UtilProperties.getMessage(resource_error,"OrderInvalidAmountSetForBillingAccount", UtilMisc.toMap("billingAccountId",billingAccountId), (cart != null ? cart.getLocale() : Locale.getDefault())));
+                    return "error";
+                }
+                selectedPaymentMethods.put("EXT_BILLACT", billingAccountAmt);
+            }
+
+            if (UtilValidate.isEmpty(selectedPaymentMethods)) {
                 return "error";
             }
 
@@ -802,16 +814,8 @@
                 selectedPaymentMethods.put(newPaymentMethodId, null);
             }
             
-            String billingAccountId = request.getParameter("billingAccountId");
-            String currencyFormat = UtilProperties.getPropertyValue("general.properties", "currency.decimal.format", "##0.00");
-            DecimalFormat formatter = new DecimalFormat(currencyFormat);
-            Double billingAccountAmt = determineBillingAccountAmount(request, checkOutHelper, formatter);
-            if ((billingAccountId != null) && !"_NA_".equals(billingAccountId) && (billingAccountAmt == null)) {
-                request.setAttribute("_ERROR_MESSAGE_", UtilProperties.getMessage(resource_error,"OrderInvalidAmountSetForBillingAccount", UtilMisc.toMap("billingAccountId",billingAccountId), (cart != null ? cart.getLocale() : Locale.getDefault())));
-                return "error";
-            }
             // The selected payment methods are set
-            errorMessages.addAll(checkOutHelper.setCheckOutPaymentInternal(selectedPaymentMethods, null, billingAccountId, billingAccountAmt));
+            errorMessages.addAll(checkOutHelper.setCheckOutPaymentInternal(selectedPaymentMethods, null, billingAccountId));
             // Verify if a gift card has been selected during order entry
             callResult = checkOutHelper.checkGiftCard(paramMap, selectedPaymentMethods);
             ServiceUtil.addErrors(errorMessages, errorMaps, callResult);
@@ -994,37 +998,41 @@
      * This method returns the amount that will be charged to the billing account.
      *
      * An amount can be associated with the billingAccountId with a
-     * parameter amount_${billingAccountId}.  If no amount is specified, then
-     * the entire available ballance of the given billing account will be used.
+     * parameter billingAccountAmount.  If no amount is specified, then
+     * the entire available balance of the given billing account will be used.
      * If there is an error, a null will be returned.
      *
      * @return  Amount to charge billing account or null if there was an error
      */
-    private static Double determineBillingAccountAmount(HttpServletRequest request, CheckOutHelper checkOutHelper, DecimalFormat formatter) {
-        ShoppingCart cart = (ShoppingCart) request.getSession().getAttribute("shoppingCart");
-        String billingAccountId = request.getParameter("billingAccountId");
-        String billingAcctAmtStr = request.getParameter("amount_" + billingAccountId);
+    private static Double determineBillingAccountAmount(String billingAccountId, String billingAccountAmount, LocalDispatcher dispatcher) {
         Double billingAccountAmt = null;
 
-        // parse the amount to a decimal
-        if (billingAcctAmtStr != null) {
-            try {
-                billingAccountAmt = new Double(formatter.parse(billingAcctAmtStr).doubleValue());
-            } catch (ParseException e) {
-                return null;
-            }
-        }
-
         // set the billing account amount to the minimum of billing account available balance or amount input if less than balance
-        if ((cart != null) && (billingAccountId != null) && !("".equals(billingAccountId)) && !"_NA_".equals(billingAccountId)) {
-            double availableBalance = checkOutHelper.availableAccountBalance(billingAccountId);
+        if (UtilValidate.isNotEmpty(billingAccountId)) {
+            // parse the amount to a decimal
+            if (UtilValidate.isNotEmpty(billingAccountAmount)) {
+                String currencyFormat = UtilProperties.getPropertyValue("general.properties", "currency.decimal.format", "##0.00");
+                DecimalFormat formatter = new DecimalFormat(currencyFormat);
+                try {
+                    billingAccountAmt = new Double(formatter.parse(billingAccountAmount).doubleValue());
+                } catch (ParseException e) {
+                    return null;
+                }
+            }
+            if (billingAccountAmt == null) {
+                billingAccountAmt = new Double(0.0);
+            }
+            double availableBalance = CheckOutHelper.availableAccountBalance(billingAccountId, dispatcher);
 
             // set amount to be charged to entered amount unless it exceeds the available balance
             double chargeAmount = 0;
-            if ((billingAccountAmt != null) && (billingAccountAmt.doubleValue() < availableBalance)) {
+            if (billingAccountAmt.doubleValue() < availableBalance) {
                 chargeAmount = billingAccountAmt.doubleValue();
             } else {
                 chargeAmount = availableBalance;
+            }
+            if (chargeAmount < 0.0) {
+                chargeAmount = 0.0;
             }
 
             return new Double(chargeAmount);

Modified: ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutHelper.java
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutHelper.java?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutHelper.java (original)
+++ ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/CheckOutHelper.java Mon Jun  4 01:46:41 2007
@@ -203,13 +203,13 @@
         return errorMessages;
     }
 
-    public Map setCheckOutPayment(Map selectedPaymentMethods, List singleUsePayments, String billingAccountId, Double billingAccountAmt) {
+    public Map setCheckOutPayment(Map selectedPaymentMethods, List singleUsePayments, String billingAccountId) {
         List errorMessages = new ArrayList();
         Map result;
         String errMsg = null;
 
         if (this.cart != null && this.cart.size() > 0) {
-            errorMessages.addAll(setCheckOutPaymentInternal(selectedPaymentMethods, singleUsePayments, billingAccountId, billingAccountAmt));
+            errorMessages.addAll(setCheckOutPaymentInternal(selectedPaymentMethods, singleUsePayments, billingAccountId));
         } else {
             errMsg = UtilProperties.getMessage(resource,"checkhelper.no_items_in_cart", (cart != null ? cart.getLocale() : Locale.getDefault()));
             errorMessages.add(errMsg);
@@ -226,7 +226,7 @@
         return result;
     }
 
-    public List setCheckOutPaymentInternal(Map selectedPaymentMethods, List singleUsePayments, String billingAccountId, Double billingAccountAmt) {
+    public List setCheckOutPaymentInternal(Map selectedPaymentMethods, List singleUsePayments, String billingAccountId) {
         List errorMessages = new ArrayList();
         String errMsg = null;
 
@@ -239,11 +239,12 @@
             // clear out the old payments
             cart.clearPayments();
 
-            if (billingAccountId != null && billingAccountAmt != null && !billingAccountId.equals("_NA_")) {
+            if (UtilValidate.isNotEmpty(billingAccountId)) {
+                Double billingAccountAmt = (Double)selectedPaymentMethods.get("EXT_BILLACT");
                 // set cart billing account data and generate a payment method containing the amount we will be charging
-                cart.setBillingAccount(billingAccountId, billingAccountAmt.doubleValue());
-            } else if ("_NA_".equals(billingAccountId)) {
-                // if _NA_ was supplied, erase all billing account data
+                cart.setBillingAccount(billingAccountId, (billingAccountAmt != null? billingAccountAmt.doubleValue(): 0.0));
+            } else {
+                // remove the billing account from the cart
                 cart.setBillingAccount(null, 0.0);
             }
 
@@ -346,7 +347,7 @@
 
 
     public Map setCheckOutOptions(String shippingMethod, String shippingContactMechId, Map selectedPaymentMethods,
-            List singleUsePayments, String billingAccountId, Double billingAccountAmt, String shippingInstructions,
+            List singleUsePayments, String billingAccountId, String shippingInstructions,
             String orderAdditionalEmails, String maySplit, String giftMessage, String isGift, String internalCode, String shipBeforeDate, String shipAfterDate) {
         List errorMessages = new ArrayList();
         Map result = null;
@@ -362,7 +363,7 @@
             errorMessages.addAll(setCheckOutShippingAddressInternal(shippingContactMechId));
 
             // set the payment method(s) option
-            errorMessages.addAll(setCheckOutPaymentInternal(selectedPaymentMethods, singleUsePayments, billingAccountId, billingAccountAmt));
+            errorMessages.addAll(setCheckOutPaymentInternal(selectedPaymentMethods, singleUsePayments, billingAccountId));
 
         } else {
             errMsg = UtilProperties.getMessage(resource,"checkhelper.no_items_in_cart", (cart != null ? cart.getLocale() : Locale.getDefault()));

Modified: ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/ShoppingCart.java
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/ShoppingCart.java?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/ShoppingCart.java (original)
+++ ofbiz/trunk/applications/order/src/org/ofbiz/order/shoppingcart/ShoppingCart.java Mon Jun  4 01:46:41 2007
@@ -3391,6 +3391,9 @@
         remainingAmount = remainingAmount.setScale(2, BigDecimal.ROUND_HALF_UP);
         if (getBillingAccountId() != null) {
             double billingAccountAvailableAmount = CheckOutHelper.availableAccountBalance(getBillingAccountId(), dispatcher);
+            if (this.billingAccountAmt == 0.0 && billingAccountAvailableAmount > 0) {
+                this.billingAccountAmt = billingAccountAvailableAmount;
+            }
             if (remainingAmount.doubleValue() < getBillingAccountAmount()) {
                 this.billingAccountAmt = remainingAmount.doubleValue();
             }

Modified: ofbiz/trunk/applications/order/webapp/ordermgr/entry/billsettings.ftl
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/order/webapp/ordermgr/entry/billsettings.ftl?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/order/webapp/ordermgr/entry/billsettings.ftl (original)
+++ ofbiz/trunk/applications/order/webapp/ordermgr/entry/billsettings.ftl Mon Jun  4 01:46:41 2007
@@ -26,18 +26,6 @@
     }
 }
 
-function toggleBillingAccount(box) {
-    var amountName = "amount_" + box.value;
-    box.checked = true;
-    box.form.elements[amountName].disabled = false;
-
-    for (var i = 0; i < box.form.elements[box.name].length; i++) {
-        if (!box.form.elements[box.name][i].checked) {
-            box.form.elements["amount_" + box.form.elements[box.name][i].value].disabled = true;
-        }
-    }
-}
-
 function makeExpDate() {
     document.checkoutsetupform.expireDate.value = document.checkoutsetupform.expMonth.options[document.checkoutsetupform.expMonth.selectedIndex].value + "/" + document.checkoutsetupform.expYear.options[document.checkoutsetupform.expYear.selectedIndex].value;
 }
@@ -56,7 +44,35 @@
                   <a href="<@ofbizUrl>setBilling?createNew=Y</@ofbizUrl>" class="buttontext">${uiLabelMap.CommonCreateNew}</a>
                 </td>
               </tr>
-              <tr><td colspan="3"><hr class="sepbar"/></td></tr>                      
+              <tr><td colspan="3"><hr class="sepbar"/></td></tr>
+              <#if billingAccountList?has_content>
+                <tr>
+                  <td width="1%">
+                    <select name="billingAccountId">
+                      <option value=""></option>
+                        <#list billingAccountList as billingAccount>
+                          <#assign availableAmount = billingAccount.accountBalance?double>
+                          <#assign accountLimit = billingAccount.accountLimit?double>
+                          <option value="${billingAccount.billingAccountId}" <#if billingAccount.billingAccountId == selectedBillingAccountId?default("")>selected</#if>>${billingAccount.description?default("")} [${billingAccount.billingAccountId}] with available amount of <@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId/> and account limit of <@ofbizCurrency amount=accountLimit isoCode=billingAccount.accountCurrencyUomId/></option>
+                        </#list>
+                    </select>
+                  </td>
+                  <td width="50%">
+                    <span class="tabletext">${uiLabelMap.FormFieldTitle_billingAccountId}</span>
+                  </td>
+                  <td>&nbsp;</td>
+                </tr>
+                <tr>
+                  <td width="1%" align="right">
+                    <input type="text" size="5" name="billingAccountAmount" value=""/>
+                  </td>
+                  <td width="50%">
+                    ${uiLabelMap.OrderBillUpTo}
+                  </td>
+                  <td>&nbsp;</td>
+                </tr>
+                <tr><td colspan="3"><hr class="sepbar"/></td></tr>
+              </#if>                                    
               <tr>
                 <td width="1%">
                   <input type="radio" name="checkOutPaymentId" value="EXT_OFFLINE" <#if checkOutPaymentId?exists && checkOutPaymentId == "EXT_OFFLINE">checked="checked"</#if>/>
@@ -74,43 +90,7 @@
                   <span class="tabletext">${uiLabelMap.OrderCOD}</span>
                 </td>
               </tr>
-             <tr><td colspan="3"><hr class="sepbar"/></td></tr>                  
-              <#if billingAccountList?has_content>
-                <tr>
-                  <td width="1%">
-                    <input type="radio" name="checkOutPaymentId" value="EXT_BILLACT"/>
-                  </td>
-                  <td width="50%">
-                    <span class="tabletext">${uiLabelMap.AccountingBillingAccountOnly}</span>
-                  </td>
-                  <td>&nbsp;</td>
-                </tr>
-                <tr><td colspan="3"><hr class="sepbar"/></td></tr>
-                <#list billingAccountList as billingAccount>
-                  <#assign availableAmount = billingAccount.accountBalance?double>
-                  <tr>
-                    <td align="left" valign="top" width="1%">
-                      <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="${billingAccount.billingAccountId}" <#if (billingAccount.billingAccountId == selectedBillingAccountId?default(""))>checked="checked"</#if>/>
-                    </td>
-                    <td align="left" valign="top" width="99%">
-                      <div class="tabletext">
-                       ${billingAccount.description?default("Bill Account")} #<b>${billingAccount.billingAccountId}</b>&nbsp;(<@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId/>)<br/>
-                       <b>${uiLabelMap.AccountingBillUpTo}:</b> <input type="text" size="5" class="inputBox" name="amount_${billingAccount.billingAccountId}" value="${availableAmount?double?string("##0.00")}" <#if !(billingAccount.billingAccountId == selectedBillingAccountId?default(""))>disabled="disabled"</#if>/>
-                      </div>
-                    </td>
-                  </tr>
-                </#list>
-                <tr>
-                  <td align="left" valign="top" width="1%">
-                    <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="_NA_" <#if (selectedBillingAccountId?default("") == "N")>checked="checked"</#if>/>
-                    <input type="hidden" name="_NA_amount" value="0.00"/>
-                  </td>
-                  <td align="left" valign="top" width="99%">
-                    <div class="tabletext">${uiLabelMap.AccountingNoBillingAccount}</div>
-                   </td>
-                </tr>
-                <tr><td colspan="3"><hr class="sepbar"/></td></tr>
-              </#if>                                    
+             <tr><td colspan="3"><hr class="sepbar"/></td></tr>
               <#if paymentMethodList?has_content>
                 <#list paymentMethodList as paymentMethod>
                   <#if paymentMethod.paymentMethodTypeId == "CREDIT_CARD">

Modified: ofbiz/trunk/applications/order/webapp/ordermgr/entry/checkoutoptions.ftl
URL: http://svn.apache.org/viewvc/ofbiz/trunk/applications/order/webapp/ordermgr/entry/checkoutoptions.ftl?view=diff&rev=544091&r1=544090&r2=544091
==============================================================================
--- ofbiz/trunk/applications/order/webapp/ordermgr/entry/checkoutoptions.ftl (original)
+++ ofbiz/trunk/applications/order/webapp/ordermgr/entry/checkoutoptions.ftl Mon Jun  4 01:46:41 2007
@@ -66,17 +66,6 @@
     }
 }
 
-function toggleBillingAccount(box) {
-    var amountName = "amount_" + box.value;
-    box.checked = true;
-    box.form.elements[amountName].disabled = false;
-
-    for (var i = 0; i < box.form.elements[box.name].length; i++) {
-        if (!box.form.elements[box.name][i].checked) {
-            box.form.elements["amount_" + box.form.elements[box.name][i].value].disabled = true;
-        }
-    }
-}
 </script>
 
 <#assign shipping = !shoppingCart.containAllWorkEffortCartItems()> <#-- contains items which need shipping? -->
@@ -445,35 +434,26 @@
                     <tr><td colspan="2"><hr class="sepbar"/></td></tr>
                     <tr>
                       <td width="1%">
-                        <input type="radio" name="checkOutPaymentId" value="EXT_BILLACT" <#if "EXT_BILLACT" == checkOutPaymentId>checked="checked"</#if>/></hr>
+                        <select name="billingAccountId">
+                          <option value=""></option>
+                            <#list billingAccountList as billingAccount>
+                              <#assign availableAmount = billingAccount.accountBalance?double>
+                              <#assign accountLimit = billingAccount.accountLimit?double>
+                              <option value="${billingAccount.billingAccountId}" <#if billingAccount.billingAccountId == selectedBillingAccountId?default("")>selected</#if>>${billingAccount.description?default("")} [${billingAccount.billingAccountId}] with available amount of <@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId/> and account limit of <@ofbizCurrency amount=accountLimit isoCode=billingAccount.accountCurrencyUomId/></option>
+                            </#list>
+                        </select>
                       </td>
                       <td width="50%">
-                        <span class="tabletext">${uiLabelMap.AccountingPayOnlyWithBillingAccount}</span>
+                        <span class="tabletext">${uiLabelMap.FormFieldTitle_billingAccountId}</span>
                       </td>
                     </tr>
-                    <tr><td colspan="2"><hr class="sepbar"/></td></tr>
-                    <#list billingAccountList as billingAccount>
-                      <#assign availableAmount = billingAccount.accountLimit?double - billingAccount.accountBalance?double>
-                      <tr>
-                        <td align="left" valign="top" width="1%">
-                          <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="${billingAccount.billingAccountId}" <#if (billingAccount.billingAccountId == selectedBillingAccountId?default(""))>checked="checked"</#if>/>
-                        </td>
-                        <td align="left" valign="top" width="99%">
-                          <div class="tabletext">
-                           ${billingAccount.description?default("Bill Account")} [${uiLabelMap.OrderNbr}<b>${billingAccount.billingAccountId}</b>]&nbsp;(<@ofbizCurrency amount=availableAmount isoCode=billingAccount.accountCurrencyUomId?default(shoppingCart.getCurrency())/>)<br/>
-                           <b>${uiLabelMap.OrderBillUpTo}:</b> <input type="text" size="8" class="inputBox" name="amount_${billingAccount.billingAccountId}" value="${availableAmount?double?string("##0.00")}" <#if !(billingAccount.billingAccountId == selectedBillingAccountId?default(""))>disabled</#if>>
-                          </div>
-                        </td>
-                      </tr>
-                    </#list>
                     <tr>
-                      <td align="left" valign="top" width="1%">
-                        <input type="radio" onClick="javascript:toggleBillingAccount(this);" name="billingAccountId" value="_NA_" <#if (selectedBillingAccountId?default("") == "N")>checked="checked"</#if>/>
-                        <input type="hidden" name="_NA_amount" value="0.00"/>
+                      <td width="1%" align="right">
+                        <input type="text" size="5" name="billingAccountAmount" value=""/>
+                      </td>
+                      <td width="50%">
+                        ${uiLabelMap.OrderBillUpTo}
                       </td>
-                      <td align="left" valign="top" width="99%">
-                        <div class="tabletext">${uiLabelMap.AccountingNoBillingAccount}</div>
-                       </td>
                     </tr>
                   </#if>
                 </#if>