Integrate changes on VAllocation on trunk from phib
This commit is contained in:
parent
716bb3311d
commit
72e2b98eb9
|
@ -16,27 +16,63 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
package org.compiere.apps.form;
|
package org.compiere.apps.form;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.BorderLayout;
|
||||||
import java.awt.event.*;
|
import java.awt.Dimension;
|
||||||
import java.beans.*;
|
import java.awt.GridBagConstraints;
|
||||||
import java.math.*;
|
import java.awt.GridBagLayout;
|
||||||
import java.sql.*;
|
import java.awt.Insets;
|
||||||
import java.text.*;
|
import java.awt.event.ActionEvent;
|
||||||
import java.util.*;
|
import java.awt.event.ActionListener;
|
||||||
import java.util.logging.*;
|
import java.beans.PropertyChangeEvent;
|
||||||
import javax.swing.*;
|
import java.beans.VetoableChangeListener;
|
||||||
import javax.swing.event.*;
|
import java.math.BigDecimal;
|
||||||
import javax.swing.table.*;
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Timestamp;
|
||||||
|
import java.text.DecimalFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Vector;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
import javax.swing.BorderFactory;
|
||||||
|
import javax.swing.JButton;
|
||||||
|
import javax.swing.JCheckBox;
|
||||||
|
import javax.swing.JLabel;
|
||||||
|
import javax.swing.JScrollPane;
|
||||||
|
import javax.swing.JSplitPane;
|
||||||
|
import javax.swing.SwingConstants;
|
||||||
|
import javax.swing.event.TableModelEvent;
|
||||||
|
import javax.swing.event.TableModelListener;
|
||||||
|
import javax.swing.table.DefaultTableModel;
|
||||||
|
import javax.swing.table.TableModel;
|
||||||
|
|
||||||
import org.adempiere.plaf.AdempierePLAF;
|
import org.adempiere.plaf.AdempierePLAF;
|
||||||
import org.compiere.apps.*;
|
import org.compiere.apps.ADialog;
|
||||||
import org.compiere.grid.ed.*;
|
import org.compiere.apps.StatusBar;
|
||||||
import org.compiere.minigrid.*;
|
import org.compiere.grid.ed.VDate;
|
||||||
import org.compiere.model.*;
|
import org.compiere.grid.ed.VLookup;
|
||||||
import org.compiere.plaf.*;
|
import org.compiere.minigrid.MiniTable;
|
||||||
import org.compiere.process.*;
|
import org.compiere.model.MAllocationHdr;
|
||||||
import org.compiere.swing.*;
|
import org.compiere.model.MAllocationLine;
|
||||||
import org.compiere.util.*;
|
import org.compiere.model.MInvoice;
|
||||||
|
import org.compiere.model.MLookup;
|
||||||
|
import org.compiere.model.MLookupFactory;
|
||||||
|
import org.compiere.model.MPayment;
|
||||||
|
import org.compiere.model.MRole;
|
||||||
|
import org.compiere.plaf.CompiereColor;
|
||||||
|
import org.compiere.process.DocAction;
|
||||||
|
import org.compiere.swing.CPanel;
|
||||||
|
import org.compiere.swing.CTextField;
|
||||||
|
import org.compiere.util.CLogger;
|
||||||
|
import org.compiere.util.DB;
|
||||||
|
import org.compiere.util.DisplayType;
|
||||||
|
import org.compiere.util.Env;
|
||||||
|
import org.compiere.util.KeyNamePair;
|
||||||
|
import org.compiere.util.Msg;
|
||||||
|
import org.compiere.util.TimeUtil;
|
||||||
|
import org.compiere.util.Trx;
|
||||||
|
import org.compiere.util.Util;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allocation Form
|
* Allocation Form
|
||||||
|
@ -50,6 +86,11 @@ public class VAllocation extends CPanel
|
||||||
implements FormPanel, ActionListener, TableModelListener, VetoableChangeListener
|
implements FormPanel, ActionListener, TableModelListener, VetoableChangeListener
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
private static final long serialVersionUID = -5322824600164192235L;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize Panel
|
* Initialize Panel
|
||||||
* @param WindowNo window
|
* @param WindowNo window
|
||||||
|
@ -99,8 +140,8 @@ public class VAllocation extends CPanel
|
||||||
private int i_open = 6;
|
private int i_open = 6;
|
||||||
private int i_discount = 7;
|
private int i_discount = 7;
|
||||||
private int i_writeOff = 8;
|
private int i_writeOff = 8;
|
||||||
private int i_overUnder = 9;
|
private int i_applied = 9;
|
||||||
private int i_applied = 10;
|
private int i_overUnder = 10;
|
||||||
// private int i_multiplier = 10;
|
// private int i_multiplier = 10;
|
||||||
//
|
//
|
||||||
private CPanel mainPanel = new CPanel();
|
private CPanel mainPanel = new CPanel();
|
||||||
|
@ -497,8 +538,9 @@ public class VAllocation extends CPanel
|
||||||
discount = Env.ZERO;
|
discount = Env.ZERO;
|
||||||
line.add(discount); // 5/7-ConvAllowedDisc
|
line.add(discount); // 5/7-ConvAllowedDisc
|
||||||
line.add(Env.ZERO); // 6/8-WriteOff
|
line.add(Env.ZERO); // 6/8-WriteOff
|
||||||
line.add(Env.ZERO); // 7/9-OverUnder
|
line.add(Env.ZERO); // 7/9-Applied
|
||||||
line.add(Env.ZERO); // 8/10-Applied
|
line.add(open); // 8/10-OverUnder
|
||||||
|
|
||||||
// line.add(rs.getBigDecimal(9)); // 8/10-Multiplier
|
// line.add(rs.getBigDecimal(9)); // 8/10-Multiplier
|
||||||
// Add when open <> 0 (i.e. not if no conversion rate)
|
// Add when open <> 0 (i.e. not if no conversion rate)
|
||||||
if (Env.ZERO.compareTo(open) != 0)
|
if (Env.ZERO.compareTo(open) != 0)
|
||||||
|
@ -528,8 +570,8 @@ public class VAllocation extends CPanel
|
||||||
columnNames.add(Msg.getMsg(Env.getCtx(), "OpenAmt"));
|
columnNames.add(Msg.getMsg(Env.getCtx(), "OpenAmt"));
|
||||||
columnNames.add(Msg.getMsg(Env.getCtx(), "Discount"));
|
columnNames.add(Msg.getMsg(Env.getCtx(), "Discount"));
|
||||||
columnNames.add(Msg.getMsg(Env.getCtx(), "WriteOff"));
|
columnNames.add(Msg.getMsg(Env.getCtx(), "WriteOff"));
|
||||||
columnNames.add(Msg.getMsg(Env.getCtx(), "OverUnderAmt"));
|
|
||||||
columnNames.add(Msg.getMsg(Env.getCtx(), "AppliedAmt"));
|
columnNames.add(Msg.getMsg(Env.getCtx(), "AppliedAmt"));
|
||||||
|
columnNames.add(Msg.getMsg(Env.getCtx(), "OverUnderAmt"));
|
||||||
// columnNames.add(" "); // Multiplier
|
// columnNames.add(" "); // Multiplier
|
||||||
|
|
||||||
// Set Model
|
// Set Model
|
||||||
|
@ -551,7 +593,7 @@ public class VAllocation extends CPanel
|
||||||
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 7-Conv Discount
|
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 7-Conv Discount
|
||||||
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 8-Conv WriteOff
|
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 8-Conv WriteOff
|
||||||
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 9-Conv OverUnder
|
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 9-Conv OverUnder
|
||||||
invoiceTable.setColumnClass(i++, BigDecimal.class, false); // 10-Conv Applied
|
invoiceTable.setColumnClass(i++, BigDecimal.class, true); // 10-Conv Applied
|
||||||
// invoiceTable.setColumnClass(i++, BigDecimal.class, true); // 10-Multiplier
|
// invoiceTable.setColumnClass(i++, BigDecimal.class, true); // 10-Multiplier
|
||||||
// Table UI
|
// Table UI
|
||||||
invoiceTable.autoSize();
|
invoiceTable.autoSize();
|
||||||
|
@ -559,8 +601,8 @@ public class VAllocation extends CPanel
|
||||||
i_open = multiCurrency.isSelected() ? 6 : 4;
|
i_open = multiCurrency.isSelected() ? 6 : 4;
|
||||||
i_discount = multiCurrency.isSelected() ? 7 : 5;
|
i_discount = multiCurrency.isSelected() ? 7 : 5;
|
||||||
i_writeOff = multiCurrency.isSelected() ? 8 : 6;
|
i_writeOff = multiCurrency.isSelected() ? 8 : 6;
|
||||||
i_overUnder = multiCurrency.isSelected() ? 9 : 7;
|
i_applied = multiCurrency.isSelected() ? 9 : 7;
|
||||||
i_applied = multiCurrency.isSelected() ? 10 : 8;
|
i_overUnder = multiCurrency.isSelected() ? 10 : 8;
|
||||||
// i_multiplier = multiCurrency.isSelected() ? 10 : 8;
|
// i_multiplier = multiCurrency.isSelected() ? 10 : 8;
|
||||||
|
|
||||||
// Calculate Totals
|
// Calculate Totals
|
||||||
|
@ -696,7 +738,7 @@ public class VAllocation extends CPanel
|
||||||
if ( selected && col != 0 )
|
if ( selected && col != 0 )
|
||||||
{
|
{
|
||||||
|
|
||||||
// values should have same sign as open except over/under
|
// values should have same sign as open except possibly over/under
|
||||||
if ( discount.signum() == -openSign )
|
if ( discount.signum() == -openSign )
|
||||||
discount = discount.negate();
|
discount = discount.negate();
|
||||||
if ( writeOff.signum() == -openSign)
|
if ( writeOff.signum() == -openSign)
|
||||||
|
@ -710,155 +752,42 @@ public class VAllocation extends CPanel
|
||||||
if ( writeOff.abs().compareTo(open.abs()) > 0)
|
if ( writeOff.abs().compareTo(open.abs()) > 0)
|
||||||
writeOff = open;
|
writeOff = open;
|
||||||
|
|
||||||
// if overUnder has same sign as open it is an under payment -> less than open
|
|
||||||
if ( overUnder.signum() == openSign && overUnder.abs().compareTo(open.abs()) > 0)
|
|
||||||
overUnder = open;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Three rules to maintain:
|
* Two rules to maintain:
|
||||||
* 1) |overUnder + writeOff + discount| < open
|
*
|
||||||
* 2) |writeOff + discount| < open ( in case overUnder is 'negative')
|
* 1) |writeOff + discount| < |open|
|
||||||
* 3) discount + writeOff + overUnder + applied = 0
|
* 2) discount + writeOff + overUnder + applied = 0
|
||||||
*
|
*
|
||||||
* As only one column is edited at a time and the initial position was one of compliance
|
* As only one column is edited at a time and the initial position was one of compliance
|
||||||
* with the rules, we only need to redistribute the increase/decrease in the edited column to
|
* with the rules, we only need to redistribute the increase/decrease in the edited column to
|
||||||
* the others.
|
* the others.
|
||||||
*/
|
*/
|
||||||
|
BigDecimal newTotal = discount.add(writeOff).add(applied).add(overUnder); // all have same sign
|
||||||
|
BigDecimal difference = newTotal.subtract(open);
|
||||||
|
|
||||||
// comply with rules 1 or 2
|
// rule 2
|
||||||
BigDecimal amtOver;
|
BigDecimal diffWOD = writeOff.add(discount).subtract(open);
|
||||||
if ( overUnder.signum() == -openSign )
|
|
||||||
amtOver = (discount.add(writeOff)).subtract(open);
|
|
||||||
else
|
|
||||||
amtOver = (discount.add(writeOff.add(overUnder))).subtract(open);
|
|
||||||
|
|
||||||
if ( amtOver.signum() == openSign )
|
if ( diffWOD.signum() == open.signum() ) // writeOff and discount are too large
|
||||||
{
|
|
||||||
BigDecimal temp = Env.ZERO;
|
|
||||||
if ( col != i_overUnder && overUnder.signum() == openSign )
|
|
||||||
{
|
{
|
||||||
temp = overUnder.subtract(amtOver);
|
if ( col == i_discount ) // then edit writeoff
|
||||||
if ( temp.signum() == -openSign )
|
|
||||||
{
|
{
|
||||||
overUnder = Env.ZERO;
|
writeOff = writeOff.subtract(diffWOD);
|
||||||
amtOver = temp.negate();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
overUnder = temp;
|
|
||||||
amtOver = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( col != i_writeOff )
|
|
||||||
{
|
|
||||||
temp = writeOff.subtract(amtOver);
|
|
||||||
if ( temp.signum() == -openSign )
|
|
||||||
{
|
|
||||||
writeOff = Env.ZERO;
|
|
||||||
amtOver = temp.negate();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
writeOff = temp;
|
|
||||||
amtOver = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( col != i_discount )
|
|
||||||
{
|
|
||||||
temp = discount.subtract(amtOver);
|
|
||||||
if ( temp.signum() == -openSign )
|
|
||||||
{
|
|
||||||
discount = Env.ZERO;
|
|
||||||
amtOver = temp.negate();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
discount = temp;
|
|
||||||
amtOver = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// make everything balance to open
|
|
||||||
BigDecimal remainder = open.subtract(discount.add(writeOff.add(overUnder.add(applied))));
|
|
||||||
|
|
||||||
// need to increase something
|
|
||||||
if ( remainder.signum() == openSign )
|
|
||||||
{
|
|
||||||
BigDecimal temp = Env.ZERO;
|
|
||||||
BigDecimal amtUnder = amtOver.negate();
|
|
||||||
|
|
||||||
if ( autoWriteOff.isSelected() && col != i_writeOff )
|
|
||||||
{
|
|
||||||
temp = writeOff.add(remainder);
|
|
||||||
|
|
||||||
if ( temp.abs().compareTo(amtUnder.abs()) > 0 )
|
|
||||||
{
|
|
||||||
writeOff = amtUnder;
|
|
||||||
remainder = temp.subtract(amtUnder);
|
|
||||||
}
|
}
|
||||||
else
|
else // col = i_writeoff
|
||||||
{
|
{
|
||||||
writeOff = temp;
|
discount = discount.subtract(diffWOD);
|
||||||
remainder = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( col != i_overUnder )
|
difference = difference.subtract(diffWOD);
|
||||||
{
|
|
||||||
temp = overUnder.add(remainder);
|
|
||||||
if ( temp.abs().compareTo(amtUnder.abs()) > 0 )
|
|
||||||
{
|
|
||||||
overUnder = amtUnder;
|
|
||||||
remainder = temp.subtract(amtUnder);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
overUnder = temp;
|
|
||||||
remainder = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( col != i_applied && remainder.signum() != 0 )
|
|
||||||
{
|
|
||||||
applied = applied.add(remainder);
|
|
||||||
remainder = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// need to decrease some amount/s
|
// rule 1
|
||||||
if ( remainder.signum() == -openSign )
|
if ( col == i_applied )
|
||||||
{
|
overUnder = overUnder.subtract(difference);
|
||||||
BigDecimal temp = Env.ZERO;
|
|
||||||
|
|
||||||
|
|
||||||
if ( autoWriteOff.isSelected() && col != i_writeOff )
|
|
||||||
{
|
|
||||||
temp = writeOff.add(remainder);
|
|
||||||
|
|
||||||
if ( temp.signum() == -openSign )
|
|
||||||
{
|
|
||||||
writeOff = Env.ZERO;
|
|
||||||
remainder = temp;
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
applied = applied.subtract(difference);
|
||||||
writeOff = temp;
|
|
||||||
remainder = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if ( col != i_overUnder && remainder.signum() != 0 )
|
|
||||||
{
|
|
||||||
overUnder = overUnder.add(remainder);
|
|
||||||
remainder = Env.ZERO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue