[ 2041226 ] BP Open Balance should count only Completed Invoice

This commit is contained in:
armenrz 2008-08-07 23:45:04 +00:00
parent a4a20bca26
commit 06cbca5a71
1 changed files with 7 additions and 4 deletions

View File

@ -31,6 +31,8 @@ import org.compiere.util.*;
* @author Teo Sarca, SC ARHIPAC SERVICE SRL * @author Teo Sarca, SC ARHIPAC SERVICE SRL
* <li>BF [ 1568774 ] Walk-In BP: invalid created/updated values * <li>BF [ 1568774 ] Walk-In BP: invalid created/updated values
* <li>BF [ 1817752 ] MBPartner.getLocations should return only active one * <li>BF [ 1817752 ] MBPartner.getLocations should return only active one
* @author Armen Rizal, GOODWILL CONSULT
* <LI>BF [ 2041226 ] BP Open Balance should count only Completed Invoice
*/ */
public class MBPartner extends X_C_BPartner public class MBPartner extends X_C_BPartner
{ {
@ -736,16 +738,17 @@ public class MBPartner extends X_C_BPartner
{ {
BigDecimal SO_CreditUsed = null; BigDecimal SO_CreditUsed = null;
BigDecimal TotalOpenBalance = null; BigDecimal TotalOpenBalance = null;
//AZ Goodwill -> BF: only count completed/closed docs.
String sql = "SELECT " String sql = "SELECT "
// SO Credit Used // SO Credit Used
+ "COALESCE((SELECT SUM(currencyBase(invoiceOpen(i.C_Invoice_ID,i.C_InvoicePaySchedule_ID),i.C_Currency_ID,i.DateInvoiced, i.AD_Client_ID,i.AD_Org_ID)) FROM C_Invoice_v i " + "COALESCE((SELECT SUM(currencyBase(invoiceOpen(i.C_Invoice_ID,i.C_InvoicePaySchedule_ID),i.C_Currency_ID,i.DateInvoiced, i.AD_Client_ID,i.AD_Org_ID)) FROM C_Invoice_v i "
+ "WHERE i.C_BPartner_ID=bp.C_BPartner_ID AND i.IsSOTrx='Y' AND i.IsPaid='N'),0), " + "WHERE i.C_BPartner_ID=bp.C_BPartner_ID AND i.IsSOTrx='Y' AND i.IsPaid='N' AND i.DocStatus IN ('CO','CL')),0), "
// Balance (incl. unallocated payments) // Balance (incl. unallocated payments)
+ "COALESCE((SELECT SUM(currencyBase(invoiceOpen(i.C_Invoice_ID,i.C_InvoicePaySchedule_ID),i.C_Currency_ID,i.DateInvoiced, i.AD_Client_ID,i.AD_Org_ID)*i.MultiplierAP) FROM C_Invoice_v i " + "COALESCE((SELECT SUM(currencyBase(invoiceOpen(i.C_Invoice_ID,i.C_InvoicePaySchedule_ID),i.C_Currency_ID,i.DateInvoiced, i.AD_Client_ID,i.AD_Org_ID)*i.MultiplierAP) FROM C_Invoice_v i "
+ "WHERE i.C_BPartner_ID=bp.C_BPartner_ID AND i.IsPaid='N'),0) - " + "WHERE i.C_BPartner_ID=bp.C_BPartner_ID AND i.IsPaid='N' AND i.DocStatus IN ('CO','CL')),0) - "
+ "COALESCE((SELECT SUM(currencyBase(Paymentavailable(p.C_Payment_ID),p.C_Currency_ID,p.DateTrx,p.AD_Client_ID,p.AD_Org_ID)) FROM C_Payment_v p " + "COALESCE((SELECT SUM(currencyBase(Paymentavailable(p.C_Payment_ID),p.C_Currency_ID,p.DateTrx,p.AD_Client_ID,p.AD_Org_ID)) FROM C_Payment_v p "
+ "WHERE p.C_BPartner_ID=bp.C_BPartner_ID AND p.IsAllocated='N'" + "WHERE p.C_BPartner_ID=bp.C_BPartner_ID AND p.IsAllocated='N'"
+ " AND p.C_Charge_ID IS NULL),0) " + " AND p.C_Charge_ID IS NULL AND p.DocStatus IN ('CO','CL')),0) "
+ "FROM C_BPartner bp " + "FROM C_BPartner bp "
+ "WHERE C_BPartner_ID=?"; + "WHERE C_BPartner_ID=?";
PreparedStatement pstmt = null; PreparedStatement pstmt = null;