BF: 2431123 Return Trx changes weighted average cost
This commit is contained in:
parent
d224dde0bc
commit
a2701260d6
|
@ -30,6 +30,9 @@ import org.compiere.util.Env;
|
||||||
* Cost Detail Model
|
* Cost Detail Model
|
||||||
*
|
*
|
||||||
* @author Jorg Janke
|
* @author Jorg Janke
|
||||||
|
* @author Armen Rizal, Goodwill Consulting
|
||||||
|
* <li>BF: 2431123 Return Trx changes weighted average cost
|
||||||
|
* <li>BF: 1568752 Average invoice costing: landed costs incorrectly applied
|
||||||
* @author Armen Rizal & Bayu Cahya
|
* @author Armen Rizal & Bayu Cahya
|
||||||
* <li>BF [ 2129781 ] Cost Detail not created properly for multi acc schema
|
* <li>BF [ 2129781 ] Cost Detail not created properly for multi acc schema
|
||||||
* @version $Id: MCostDetail.java,v 1.3 2006/07/30 00:51:05 jjanke Exp $
|
* @version $Id: MCostDetail.java,v 1.3 2006/07/30 00:51:05 jjanke Exp $
|
||||||
|
@ -823,29 +826,6 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
// cost = new MCost(product, M_ASI_ID,
|
// cost = new MCost(product, M_ASI_ID,
|
||||||
// as, Org_ID, ce.getM_CostElement_ID());
|
// as, Org_ID, ce.getM_CostElement_ID());
|
||||||
|
|
||||||
// MZ Goodwill
|
|
||||||
// reset non Material Cost Element when CurrentQty is ZERO and from Matched Invoice
|
|
||||||
if (ce.getCostingMethod() != null)
|
|
||||||
{
|
|
||||||
if (cost.getCurrentQty().signum() == 0 // CurrentQty is ZERO
|
|
||||||
&& getC_InvoiceLine_ID() != 0 && !product.isService() // from Matched Invoice
|
|
||||||
&& ce.getCostingMethod().equals(as.getCostingMethod())) // based on Accounting Schema Costing Method
|
|
||||||
{
|
|
||||||
MCostElement[] nce = MCostElement.getNonCostingMethods(this);
|
|
||||||
for (int i = 0 ; i < nce.length ; i++)
|
|
||||||
{
|
|
||||||
MCost ncost = MCost.get(getCtx(), cost.getAD_Client_ID(), cost.getAD_Org_ID(), cost.getM_Product_ID(), cost.getM_CostType_ID(), cost.getC_AcctSchema_ID(), nce[i].getM_CostElement_ID(), cost.getM_AttributeSetInstance_ID());
|
|
||||||
if (ncost != null)
|
|
||||||
{
|
|
||||||
ncost.setCurrentCostPrice(Env.ZERO);
|
|
||||||
ncost.setCurrentQty(Env.ZERO);
|
|
||||||
ncost.save();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// end MZ
|
|
||||||
|
|
||||||
// MZ Goodwill
|
// MZ Goodwill
|
||||||
// used deltaQty and deltaAmt if exist
|
// used deltaQty and deltaAmt if exist
|
||||||
BigDecimal qty = Env.ZERO;
|
BigDecimal qty = Env.ZERO;
|
||||||
|
@ -881,20 +861,28 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
|
|
||||||
// *** Purchase Order Detail Record ***
|
// *** Purchase Order Detail Record ***
|
||||||
if (getC_OrderLine_ID() != 0)
|
if (getC_OrderLine_ID() != 0)
|
||||||
{
|
{
|
||||||
|
boolean isReturnTrx = qty.signum() < 0;
|
||||||
|
|
||||||
if (ce.isAveragePO())
|
if (ce.isAveragePO())
|
||||||
{
|
{
|
||||||
cost.setWeightedAverage(amt, qty);
|
if (!isReturnTrx)
|
||||||
|
cost.setWeightedAverage(amt, qty);
|
||||||
|
else
|
||||||
|
cost.add(amt, qty);
|
||||||
log.finer("PO - AveragePO - " + cost);
|
log.finer("PO - AveragePO - " + cost);
|
||||||
}
|
}
|
||||||
else if (ce.isLastPOPrice())
|
else if (ce.isLastPOPrice())
|
||||||
{
|
{
|
||||||
if (qty.signum() != 0)
|
if(!isReturnTrx)
|
||||||
cost.setCurrentCostPrice(price);
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
BigDecimal cCosts = cost.getCurrentCostPrice().add(amt);
|
if (qty.signum() != 0)
|
||||||
cost.setCurrentCostPrice(cCosts);
|
cost.setCurrentCostPrice(price);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
BigDecimal cCosts = cost.getCurrentCostPrice().add(amt);
|
||||||
|
cost.setCurrentCostPrice(cCosts);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cost.add(amt, qty);
|
cost.add(amt, qty);
|
||||||
log.finer("PO - LastPO - " + cost);
|
log.finer("PO - LastPO - " + cost);
|
||||||
|
@ -915,9 +903,14 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
// *** AP Invoice Detail Record ***
|
// *** AP Invoice Detail Record ***
|
||||||
else if (getC_InvoiceLine_ID() != 0)
|
else if (getC_InvoiceLine_ID() != 0)
|
||||||
{
|
{
|
||||||
|
boolean isReturnTrx = qty.signum() < 0;
|
||||||
|
|
||||||
if (ce.isAverageInvoice())
|
if (ce.isAverageInvoice())
|
||||||
{
|
{
|
||||||
cost.setWeightedAverage(amt, qty);
|
if (!isReturnTrx)
|
||||||
|
cost.setWeightedAverage(amt, qty);
|
||||||
|
else
|
||||||
|
cost.add(amt, qty);
|
||||||
log.finer("Inv - AverageInv - " + cost);
|
log.finer("Inv - AverageInv - " + cost);
|
||||||
}
|
}
|
||||||
else if (ce.isFifo()
|
else if (ce.isFifo()
|
||||||
|
@ -938,12 +931,15 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
}
|
}
|
||||||
else if (ce.isLastInvoice())
|
else if (ce.isLastInvoice())
|
||||||
{
|
{
|
||||||
if (qty.signum() != 0)
|
if (!isReturnTrx)
|
||||||
cost.setCurrentCostPrice(price);
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
BigDecimal cCosts = cost.getCurrentCostPrice().add(amt);
|
if (qty.signum() != 0)
|
||||||
cost.setCurrentCostPrice(cCosts);
|
cost.setCurrentCostPrice(price);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
BigDecimal cCosts = cost.getCurrentCostPrice().add(amt);
|
||||||
|
cost.setCurrentCostPrice(cCosts);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cost.add(amt, qty);
|
cost.add(amt, qty);
|
||||||
log.finer("Inv - LastInv - " + cost);
|
log.finer("Inv - LastInv - " + cost);
|
||||||
|
@ -971,15 +967,38 @@ public class MCostDetail extends X_M_CostDetail
|
||||||
}
|
}
|
||||||
else if (!ce.isCostingMethod()) // Cost Adjustments
|
else if (!ce.isCostingMethod()) // Cost Adjustments
|
||||||
{
|
{
|
||||||
// MZ Goodwill
|
// AZ Goodwill
|
||||||
// Current Cost is using average
|
//get costing method for product
|
||||||
BigDecimal cCosts = cost.getCurrentCostPrice().multiply(cost.getCurrentQty()).add(amt);
|
String costingMethod = product.getCostingMethod(as);
|
||||||
BigDecimal cQty = cost.getCurrentQty().add(qty);
|
if (MAcctSchema.COSTINGMETHOD_AveragePO.equals(costingMethod) ||
|
||||||
if (cQty.signum() != 0)
|
MAcctSchema.COSTINGMETHOD_AverageInvoice.equals(costingMethod))
|
||||||
cCosts = cCosts.divide(cQty, precision, BigDecimal.ROUND_HALF_UP);
|
{
|
||||||
// end MZ
|
if (cost.getCurrentQty().compareTo(Env.ZERO) == 0)
|
||||||
cost.setCurrentCostPrice(cCosts);
|
{
|
||||||
cost.add(amt, qty);
|
//initialize current qty for new landed cost element
|
||||||
|
String sql = "SELECT QtyOnHand FROM M_Storage"
|
||||||
|
+ " WHERE AD_Client_ID=" + cost.getAD_Client_ID()
|
||||||
|
+ " AND AD_Org_ID=" + cost.getAD_Org_ID()
|
||||||
|
+ " AND M_Product_ID=" + cost.getM_Product_ID()
|
||||||
|
+ " AND M_AttributeSetInstance_ID=" + M_ASI_ID;
|
||||||
|
if (M_ASI_ID == 0)
|
||||||
|
sql = "SELECT SUM(QtyOnHand) FROM M_Storage"
|
||||||
|
+ " WHERE AD_Client_ID=" + cost.getAD_Client_ID()
|
||||||
|
+ " AND AD_Org_ID=" + cost.getAD_Org_ID()
|
||||||
|
+ " AND M_Product_ID=" + cost.getM_Product_ID();
|
||||||
|
BigDecimal bd = DB.getSQLValueBD(get_TrxName(), sql);
|
||||||
|
if (bd != null)
|
||||||
|
cost.setCurrentQty(bd.subtract(qty)); // (initial qty = onhand qty - allocated qty)
|
||||||
|
}
|
||||||
|
cost.setWeightedAverage(amt, qty); //also get averaged
|
||||||
|
}
|
||||||
|
else //original logic from Compiere
|
||||||
|
{
|
||||||
|
BigDecimal cCosts = cost.getCurrentCostPrice().add(amt);
|
||||||
|
cost.setCurrentCostPrice(cCosts);
|
||||||
|
cost.add(amt, qty);
|
||||||
|
}
|
||||||
|
// end AZ
|
||||||
log.finer("Inv - none - " + cost);
|
log.finer("Inv - none - " + cost);
|
||||||
}
|
}
|
||||||
// else
|
// else
|
||||||
|
|
Loading…
Reference in New Issue