libero: operation cost should be rounded using accounting schema currency costing precision

This commit is contained in:
teo_sarca 2009-02-19 08:20:32 +00:00
parent 4f5340552b
commit 46f5a77bf4
1 changed files with 31 additions and 9 deletions

View File

@ -18,6 +18,7 @@ package org.compiere.wf;
import java.awt.Point; import java.awt.Point;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.math.RoundingMode;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
@ -674,42 +675,63 @@ public class MWFNode extends X_AD_WF_Node
* @return cost for this Cost Element Type (Labor or Burden) * @return cost for this Cost Element Type (Labor or Burden)
* @throws Exception when the UOM do not is Hours * @throws Exception when the UOM do not is Hours
*/ */
public BigDecimal getCostForCostElementType(String CostElementType, int C_AcctSchema_ID,int M_CostType_ID,int AD_Org_ID,int setuptime, int duration) public BigDecimal getCostForCostElementType(String CostElementType, int C_AcctSchema_ID, int M_CostType_ID, int AD_Org_ID,
int setuptime, int duration)
{ {
MResource resource = MResource.get(getCtx(), getS_Resource_ID()); MResource resource = MResource.get(getCtx(), getS_Resource_ID());
if(resource == null) if(resource == null)
return Env.ZERO; return Env.ZERO;
//get the rate and convert in second for this cost type element (Resource, Burden)
MWorkflow workflow = getWorkflow(); BigDecimal cost = Env.ZERO;
// Validate the CostingLevel // Validate the CostingLevel
MAcctSchema as = MAcctSchema.get(getCtx(), C_AcctSchema_ID); MAcctSchema as = MAcctSchema.get(getCtx(), C_AcctSchema_ID);
final int precision = as.getCostingPrecision();
MProduct product = resource.getProduct(); MProduct product = resource.getProduct();
if(MAcctSchema.COSTINGLEVEL_Client.equals(product.getCostingLevel(as))) if(MAcctSchema.COSTINGLEVEL_Client.equals(product.getCostingLevel(as)))
{ {
AD_Org_ID = 0; AD_Org_ID = 0;
} }
//
// Get Resource Rate
double rate = resource.getResouceRate(C_AcctSchema_ID, M_CostType_ID,CostElementType, AD_Org_ID); double rate = resource.getResouceRate(C_AcctSchema_ID, M_CostType_ID,CostElementType, AD_Org_ID);
BigDecimal cost = Env.ZERO;
if (rate == 0) if (rate == 0)
{ {
return Env.ZERO; return Env.ZERO;
} }
//
// Calculate duration in hours
double hours;
int C_UOM_ID = DB.getSQLValueEx(get_TrxName(),"SELECT C_UOM_ID FROM M_Product WHERE S_Resource_ID = ? " , getS_Resource_ID()); int C_UOM_ID = DB.getSQLValueEx(get_TrxName(),"SELECT C_UOM_ID FROM M_Product WHERE S_Resource_ID = ? " , getS_Resource_ID());
MUOM uom = MUOM.get(getCtx(), C_UOM_ID); MUOM uom = MUOM.get(getCtx(), C_UOM_ID);
if (uom.isHour()) if (uom.isHour())
{ {
double hours = (setuptime / workflow.getQtyBatchSize().doubleValue() + duration) MWorkflow workflow = getWorkflow();
* workflow.getDurationBaseSec() / 3600; hours = (setuptime / workflow.getQtyBatchSize().doubleValue() + duration)
double nodeCost = rate * hours; * workflow.getDurationBaseSec() / 3600;
cost = cost.add(new BigDecimal(nodeCost));
log.info("Node: " + getName() + " Resouce: " + resource.getName() +" CostElementType: " + CostElementType + " Time Base: "+workflow.getDurationUnit() +" Duration (H): " + hours + " Rate: " + rate + " Activity Cost: " + nodeCost +" =>Cost: "+cost);
} }
else else
{ {
throw new AdempiereException("@NotSupported@ @C_UOM_ID@="+uom.getName()); throw new AdempiereException("@NotSupported@ @C_UOM_ID@="+uom.getName());
} }
//
// Calculate Activity Cost
double nodeCost = rate * hours;
cost = cost.add(new BigDecimal(nodeCost));
//
// Round to Costing Precision
if (cost.scale() > precision)
{
cost = cost.setScale(precision, RoundingMode.HALF_UP);
}
log.info("Node: " + getName() + ", Resouce: " + resource.getName() +", CostElementType: " + CostElementType);
log.info("Duration (H): " + hours + " Rate: " + rate);
log.info("Activity Cost: " + nodeCost +" => Cost: "+cost);
return cost; return cost;
} }
} // M_WFNext } // M_WFNext