IDEMPIERE-217 Allocate Payment to Charge

This commit is contained in:
Carlos Ruiz 2012-12-17 14:42:46 -05:00
parent 4d96865590
commit 2e5fb7c33f
3 changed files with 47 additions and 34 deletions

View File

@ -361,20 +361,14 @@ public class VAllocation extends Allocation
// Organization // Organization
if (name.equals("AD_Org_ID")) if (name.equals("AD_Org_ID"))
{ {
if (value == null) m_AD_Org_ID = ((Integer) value).intValue();
m_AD_Org_ID = 0;
else
m_AD_Org_ID = ((Integer) value).intValue();
loadBPartner(); loadBPartner();
} }
// Charge // Charge
else if (name.equals("C_Charge_ID") ) else if (name.equals("C_Charge_ID") )
{ {
if ( value == null ) m_C_Charge_ID = ((Integer) value).intValue();
m_C_Charge_ID = 0;
else
m_C_Charge_ID = ((Integer) value).intValue();
setAllocateButton(); setAllocateButton();
} }

View File

@ -16,6 +16,10 @@
*****************************************************************************/ *****************************************************************************/
package org.adempiere.webui.apps.form; package org.adempiere.webui.apps.form;
import static org.compiere.model.SystemIDs.COLUMN_C_INVOICE_C_BPARTNER_ID;
import static org.compiere.model.SystemIDs.COLUMN_C_INVOICE_C_CURRENCY_ID;
import static org.compiere.model.SystemIDs.COLUMN_C_PERIOD_AD_ORG_ID;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.Vector; import java.util.Vector;
import java.util.logging.Level; import java.util.logging.Level;
@ -47,18 +51,18 @@ import org.adempiere.webui.window.FDialog;
import org.compiere.apps.form.Allocation; import org.compiere.apps.form.Allocation;
import org.compiere.model.MLookup; import org.compiere.model.MLookup;
import org.compiere.model.MLookupFactory; import org.compiere.model.MLookupFactory;
import static org.compiere.model.SystemIDs.*;
import org.compiere.util.DisplayType; import org.compiere.util.DisplayType;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.compiere.util.Trx; import org.compiere.util.Trx;
import org.compiere.util.TrxRunnable;
import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.event.EventListener;
import org.zkoss.zul.Borderlayout; import org.zkoss.zul.Borderlayout;
import org.zkoss.zul.Center; import org.zkoss.zul.Center;
import org.zkoss.zul.North; import org.zkoss.zul.North;
import org.zkoss.zul.South;
import org.zkoss.zul.Separator; import org.zkoss.zul.Separator;
import org.zkoss.zul.South;
import org.zkoss.zul.Space; import org.zkoss.zul.Space;
/** /**
@ -409,20 +413,14 @@ public class WAllocation extends Allocation
// Organization // Organization
if (name.equals("AD_Org_ID")) if (name.equals("AD_Org_ID"))
{ {
if (value == null) m_AD_Org_ID = ((Integer) value).intValue();
m_AD_Org_ID = 0;
else
m_AD_Org_ID = ((Integer) value).intValue();
loadBPartner(); loadBPartner();
} }
// Charge // Charge
else if (name.equals("C_Charge_ID") ) else if (name.equals("C_Charge_ID") )
{ {
if ( value == null ) m_C_Charge_ID = ((Integer) value).intValue();
m_C_Charge_ID = 0;
else
m_C_Charge_ID = ((Integer) value).intValue();
setAllocateButton(); setAllocateButton();
} }
@ -535,10 +533,21 @@ public class WAllocation extends Allocation
Env.setContext(Env.getCtx(), form.getWindowNo(), "AD_Org_ID", m_AD_Org_ID); Env.setContext(Env.getCtx(), form.getWindowNo(), "AD_Org_ID", m_AD_Org_ID);
else else
Env.setContext(Env.getCtx(), form.getWindowNo(), "AD_Org_ID", ""); Env.setContext(Env.getCtx(), form.getWindowNo(), "AD_Org_ID", "");
Trx trx = Trx.get(Trx.createTrxName("AL"), true); try
statusBar.setStatusLine(saveData(form.getWindowNo(), dateField.getValue(), paymentTable, invoiceTable, trx.getTrxName())); {
trx.commit(); Trx.run(new TrxRunnable()
trx.close(); {
public void run(String trxName)
{
statusBar.setStatusLine(saveData(form.getWindowNo(), dateField.getValue(), paymentTable, invoiceTable, trxName));
}
});
}
catch (Exception e)
{
FDialog.error(form.getWindowNo(), form, "Error", e.getLocalizedMessage());
return;
}
} // saveData } // saveData
/** /**

View File

@ -138,9 +138,11 @@ public class Allocation
sql = new StringBuilder( MRole.getDefault(Env.getCtx(), false).addAccessSQL( sql.toString(), "p", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO ) ); sql = new StringBuilder( MRole.getDefault(Env.getCtx(), false).addAccessSQL( sql.toString(), "p", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO ) );
log.fine("PaySQL=" + sql.toString()); log.fine("PaySQL=" + sql.toString());
PreparedStatement pstmt = null;
ResultSet rs = null;
try try
{ {
PreparedStatement pstmt = DB.prepareStatement(sql.toString(), null); pstmt = DB.prepareStatement(sql.toString(), null);
pstmt.setInt(1, m_C_Currency_ID); pstmt.setInt(1, m_C_Currency_ID);
pstmt.setTimestamp(2, (Timestamp)date); pstmt.setTimestamp(2, (Timestamp)date);
pstmt.setInt(3, m_C_Currency_ID); pstmt.setInt(3, m_C_Currency_ID);
@ -148,7 +150,7 @@ public class Allocation
pstmt.setInt(5, m_C_BPartner_ID); pstmt.setInt(5, m_C_BPartner_ID);
if (!isMultiCurrency) if (!isMultiCurrency)
pstmt.setInt(6, m_C_Currency_ID); pstmt.setInt(6, m_C_Currency_ID);
ResultSet rs = pstmt.executeQuery(); rs = pstmt.executeQuery();
while (rs.next()) while (rs.next())
{ {
Vector<Object> line = new Vector<Object>(); Vector<Object> line = new Vector<Object>();
@ -171,13 +173,15 @@ public class Allocation
// //
data.add(line); data.add(line);
} }
rs.close();
pstmt.close();
} }
catch (SQLException e) catch (SQLException e)
{ {
log.log(Level.SEVERE, sql.toString(), e); log.log(Level.SEVERE, sql.toString(), e);
} }
finally
{
DB.close(rs, pstmt);
}
return data; return data;
} }
@ -266,9 +270,11 @@ public class Allocation
// role security // role security
sql = new StringBuilder( MRole.getDefault(Env.getCtx(), false).addAccessSQL( sql.toString(), "i", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO ) ); sql = new StringBuilder( MRole.getDefault(Env.getCtx(), false).addAccessSQL( sql.toString(), "i", MRole.SQL_FULLYQUALIFIED, MRole.SQL_RO ) );
PreparedStatement pstmt = null;
ResultSet rs = null;
try try
{ {
PreparedStatement pstmt = DB.prepareStatement(sql.toString(), null); pstmt = DB.prepareStatement(sql.toString(), null);
pstmt.setInt(1, m_C_Currency_ID); pstmt.setInt(1, m_C_Currency_ID);
pstmt.setTimestamp(2, (Timestamp)date); pstmt.setTimestamp(2, (Timestamp)date);
pstmt.setInt(3, m_C_Currency_ID); pstmt.setInt(3, m_C_Currency_ID);
@ -278,7 +284,7 @@ public class Allocation
pstmt.setInt(7, m_C_BPartner_ID); pstmt.setInt(7, m_C_BPartner_ID);
if (!isMultiCurrency) if (!isMultiCurrency)
pstmt.setInt(8, m_C_Currency_ID); pstmt.setInt(8, m_C_Currency_ID);
ResultSet rs = pstmt.executeQuery(); rs = pstmt.executeQuery();
while (rs.next()) while (rs.next())
{ {
Vector<Object> line = new Vector<Object>(); Vector<Object> line = new Vector<Object>();
@ -309,13 +315,15 @@ public class Allocation
if (Env.ZERO.compareTo(open) != 0) if (Env.ZERO.compareTo(open) != 0)
data.add(line); data.add(line);
} }
rs.close();
pstmt.close();
} }
catch (SQLException e) catch (SQLException e)
{ {
log.log(Level.SEVERE, sql.toString(), e); log.log(Level.SEVERE, sql.toString(), e);
} }
finally
{
DB.close(rs, pstmt);
}
return data; return data;
} }
@ -441,6 +449,7 @@ public class Allocation
applied = applied.subtract(discount); applied = applied.subtract(discount);
writeOff = Env.ZERO; // to be sure writeOff = Env.ZERO; // to be sure
overUnder = Env.ZERO; overUnder = Env.ZERO;
totalDiff = Env.ZERO;
if (totalDiff.abs().compareTo(applied.abs()) < 0 // where less is available to allocate than open if (totalDiff.abs().compareTo(applied.abs()) < 0 // where less is available to allocate than open
&& totalDiff.signum() == applied.signum() ) // and the available amount has the same sign && totalDiff.signum() == applied.signum() ) // and the available amount has the same sign
@ -737,11 +746,12 @@ public class Allocation
// Allocation Line // Allocation Line
MAllocationLine aLine = new MAllocationLine (alloc, chargeAmt.negate(), MAllocationLine aLine = new MAllocationLine (alloc, chargeAmt.negate(),
Env.ZERO, Env.ZERO, Env.ZERO); Env.ZERO, Env.ZERO, Env.ZERO);
aLine.set_CustomColumn("C_Charge_ID", m_C_Charge_ID); aLine.setC_Charge_ID(m_C_Charge_ID);
//aLine.set_CustomColumn("ChargeAmt", chargeAmt);
aLine.setC_BPartner_ID(m_C_BPartner_ID); aLine.setC_BPartner_ID(m_C_BPartner_ID);
if (!aLine.save(trxName)) if (!aLine.save(trxName)) {
log.log(Level.SEVERE, "Allocation Line not saved - Charge=" + m_C_Charge_ID); StringBuilder msg = new StringBuilder("Allocation Line not saved - Charge=").append(m_C_Charge_ID);
throw new AdempiereException(msg.toString());
}
unmatchedApplied = unmatchedApplied.add(chargeAmt); unmatchedApplied = unmatchedApplied.add(chargeAmt);
} }