vpj-cd 2008-08-05 08:16:54 +00:00
parent 0099f9febd
commit 8a84aabf10
5 changed files with 34 additions and 26 deletions

View File

@ -216,7 +216,7 @@ public class MPPProductBOM extends X_PP_Product_BOM
// find Default BOM in Product Data Planning // find Default BOM in Product Data Planning
if (ad_org_id > 0 ) if (ad_org_id > 0 )
{ {
MPPProductPlanning pp = MPPProductPlanning.get(ctx, ad_org_id, product.getM_Product_ID(), trxName); MPPProductPlanning pp = MPPProductPlanning.get(ctx, product.getAD_Client_ID(),ad_org_id, product.getM_Product_ID(), trxName);
if(pp!= null && pp.getPP_Product_BOM_ID() > 0 ) if(pp!= null && pp.getPP_Product_BOM_ID() > 0 )
{ {
@ -254,7 +254,7 @@ public class MPPProductBOM extends X_PP_Product_BOM
// find Default BOM in Product Data Planning // find Default BOM in Product Data Planning
if (ad_org_id > 0 ) if (ad_org_id > 0 )
{ {
MPPProductPlanning pp = MPPProductPlanning.get(ctx, ad_org_id, product.getM_Product_ID(), trxName); MPPProductPlanning pp = MPPProductPlanning.get(ctx, product.getAD_Client_ID() ,ad_org_id, product.getM_Product_ID(), trxName);
if(pp!= null && pp.getPP_Product_BOM_ID() > 0 ) if(pp!= null && pp.getPP_Product_BOM_ID() > 0 )
{ {

View File

@ -82,23 +82,24 @@ public class MPPProductPlanning extends X_PP_Product_Planning
* @param trxName Transaction Name * @param trxName Transaction Name
* @return MPPProductPlanning * @return MPPProductPlanning
*/ */
public static MPPProductPlanning get(Properties ctx, int ad_org_id , int m_product_id, String trxname) public static MPPProductPlanning get(Properties ctx,int ad_client_id, int ad_org_id , int m_product_id, String trxname)
{ {
int m_M_Warehouse_ID = MOrgInfo.get(ctx, ad_org_id).getM_Warehouse_ID(); int m_M_Warehouse_ID = MOrgInfo.get(ctx, ad_org_id).getM_Warehouse_ID();
if(m_M_Warehouse_ID <= 0) if(m_M_Warehouse_ID <= 0)
return null; return null;
int m_S_Resource_ID = DB.getSQLValue(trxname, "SELECT MAX(S_Resource_ID) FROM S_Resource WHERE IsManufacturingResource='Y' AND ManufacturingResourceType ='" + MResource.MANUFACTURINGRESOURCETYPE_Plant +"' AND M_Warehouse_ID= ?", m_M_Warehouse_ID); int m_S_Resource_ID = DB.getSQLValue(trxname, "SELECT MAX(S_Resource_ID) FROM S_Resource WHERE IsManufacturingResource='Y' AND ManufacturingResourceType ='" + MResource.MANUFACTURINGRESOURCETYPE_Plant +"' AND AD_Client_ID=? AND M_Warehouse_ID= ?", ad_client_id, m_M_Warehouse_ID);
if (m_S_Resource_ID <=0 ) if (m_S_Resource_ID <=0 )
return null; return null;
return get(ctx,ad_org_id, m_M_Warehouse_ID, m_S_Resource_ID, m_product_id, trxname); return get(ctx, ad_client_id,ad_org_id, m_M_Warehouse_ID, m_S_Resource_ID, m_product_id, trxname);
} }
/** /**
* Get Data Product Planning * Get Data Product Planning
* @param ctx Context * @param ctx Context
* @param AD_Client_ID ID Organization
* @param AD_Org_ID ID Organization * @param AD_Org_ID ID Organization
* @param M_Warehouse_ID Warehouse * @param M_Warehouse_ID Warehouse
* @param S_Resource_ID Resource type Plant * @param S_Resource_ID Resource type Plant
@ -106,20 +107,26 @@ public class MPPProductPlanning extends X_PP_Product_Planning
* @param trxname Trx Name * @param trxname Trx Name
* @return MPPProductPlanning * @return MPPProductPlanning
*/ */
public static MPPProductPlanning get(Properties ctx, int ad_org_id , int m_warehouse_id, int s_resource_id, int m_product_id, String trxname) public static MPPProductPlanning get(Properties ctx,int ad_client_id, int ad_org_id , int m_warehouse_id, int s_resource_id, int m_product_id, String trxname)
{ {
log.info("Ad_Org_ID" + ad_org_id + "M_Product_ID" + m_product_id + "M_Warehouse_ID" + m_warehouse_id + "S_Resource_ID" + s_resource_id ); log.info("AD_Client_ID=" + ad_client_id + " AD_Org_ID=" + ad_org_id + " M_Product_ID=" + m_product_id + " M_Warehouse_ID=" + m_warehouse_id + " S_Resource_ID=" + s_resource_id );
String sql = "SELECT * FROM PP_Product_Planning pp WHERE pp.AD_Org_ID = ? AND pp.M_Product_ID = ? AND pp.M_Warehouse_ID = ? AND pp.S_Resource_ID = ? "; String sql_warehouse = "pp.M_Warehouse_ID = ? ";
if(m_warehouse_id == 0)
sql_warehouse += "OR pp.M_Warehouse_ID IS NULL ";
String sql = "SELECT * FROM PP_Product_Planning pp WHERE pp.AD_Client_ID = ? AND pp.AD_Org_ID = ? AND pp.M_Product_ID = ? AND "+sql_warehouse+" AND pp.S_Resource_ID = ? ";
PreparedStatement pstmt = null; PreparedStatement pstmt = null;
try try
{ {
pstmt = DB.prepareStatement(sql, trxname); pstmt = DB.prepareStatement(sql, trxname);
pstmt.setInt(1, ad_org_id); pstmt.setInt(1, ad_client_id);
pstmt.setInt(2, m_product_id); pstmt.setInt(2, ad_org_id);
pstmt.setInt(3, m_warehouse_id); pstmt.setInt(3, m_product_id);
pstmt.setInt(4, s_resource_id); pstmt.setInt(4, m_warehouse_id);
pstmt.setInt(5, s_resource_id);
ResultSet rs = pstmt.executeQuery(); ResultSet rs = pstmt.executeQuery();
while (rs.next()) while (rs.next())
return new MPPProductPlanning(ctx, rs, trxname); return new MPPProductPlanning(ctx, rs, trxname);
@ -155,7 +162,7 @@ public class MPPProductPlanning extends X_PP_Product_Planning
* @param trxName Transaction Name * @param trxName Transaction Name
* @return MPPProductPlanning Planning Data * @return MPPProductPlanning Planning Data
*/ */
public static MPPProductPlanning getMPPProductPlanning(Properties ctx ,int AD_Client_ID, int AD_Org_ID ,int M_Warehouse_ID, int S_Resource_ID, int M_Product_ID, String trxName) public static MPPProductPlanning getFisrt(Properties ctx ,int AD_Client_ID, int AD_Org_ID ,int M_Warehouse_ID, int S_Resource_ID, int M_Product_ID, String trxName)
{ {
MPPProductPlanning pp = null; MPPProductPlanning pp = null;
PreparedStatement pstmt = null; PreparedStatement pstmt = null;

View File

@ -16,6 +16,7 @@
package org.eevolution.process; package org.eevolution.process;
import java.util.Properties;
import java.util.logging.*; import java.util.logging.*;
import java.math.*; import java.math.*;
import java.sql.*; import java.sql.*;
@ -208,11 +209,12 @@ public class CreateProductPlanning extends SvrProcess
{ {
int M_Product_ID = rs.getInt(1); int M_Product_ID = rs.getInt(1);
MPPProductPlanning pp = MPPProductPlanning.get(getCtx(), m_AD_Org_ID , p_M_Warehouse_ID, p_S_Resource_ID,M_Product_ID, get_TrxName()); MPPProductPlanning pp = MPPProductPlanning.get(getCtx(),m_AD_Client_ID , m_AD_Org_ID , p_M_Warehouse_ID, p_S_Resource_ID,M_Product_ID, get_TrxName());
if (pp==null && ( p_S_Resource_ID == 0 || p_M_Warehouse_ID == 0 )) //Create Product Data Planning
if (pp==null)
{ {
pp = new MPPProductPlanning(getCtx(),0,get_TrxName()); pp = new MPPProductPlanning(getCtx(),0,get_TrxName());
pp.setAD_Org_ID(0); pp.setAD_Org_ID(m_AD_Org_ID);
pp.setM_Product_ID(rs.getInt(1)); pp.setM_Product_ID(rs.getInt(1));
pp.setDD_NetworkDistribution_ID (p_DD_NetworkDistribution_ID); pp.setDD_NetworkDistribution_ID (p_DD_NetworkDistribution_ID);
pp.setAD_Workflow_ID(p_AD_Workflow_ID); pp.setAD_Workflow_ID(p_AD_Workflow_ID);
@ -236,11 +238,10 @@ public class CreateProductPlanning extends SvrProcess
pp.setTimeFence(p_TimeFence); pp.setTimeFence(p_TimeFence);
pp.setWorkingTime(p_WorkingTime); pp.setWorkingTime(p_WorkingTime);
pp.setYield(p_Yield); pp.setYield(p_Yield);
pp.save(get_TrxName()); pp.save();
} }
else else
{ {
pp.setDD_NetworkDistribution_ID (p_DD_NetworkDistribution_ID); pp.setDD_NetworkDistribution_ID (p_DD_NetworkDistribution_ID);
pp.setAD_Workflow_ID(p_AD_Workflow_ID); pp.setAD_Workflow_ID(p_AD_Workflow_ID);
pp.setIsCreatePlan(p_CreatePlan); pp.setIsCreatePlan(p_CreatePlan);

View File

@ -483,7 +483,7 @@ public class MRP extends SvrProcess
{ {
//find data product planning demand //find data product planning demand
MPPProductPlanning pp = MPPProductPlanning.getMPPProductPlanning(getCtx(), AD_Client_ID ,AD_Org_ID , M_Warehouse_ID, S_Resource_ID , product.getM_Product_ID(), get_TrxName()); MPPProductPlanning pp = MPPProductPlanning.get(getCtx(), AD_Client_ID ,AD_Org_ID , M_Warehouse_ID, S_Resource_ID , product.getM_Product_ID(), get_TrxName());
DatePromisedTo = null; DatePromisedTo = null;
DatePromisedFrom = null; DatePromisedFrom = null;
if (pp != null) if (pp != null)

View File

@ -118,7 +118,7 @@ public class RollupWorkflow extends SvrProcess
// check if element cost is of type Labor // check if element cost is of type Labor
if (element.getCostElementType().equals(element.COSTELEMENTTYPE_Resource)) if (element.getCostElementType().equals(element.COSTELEMENTTYPE_Resource))
{ {
BigDecimal Labor = getCost(element.COSTELEMENTTYPE_Resource , p_AD_Org_ID , M_Product_ID , p_M_CostType_ID , p_C_AcctSchema_ID); BigDecimal Labor = getCost(element.COSTELEMENTTYPE_Resource , getAD_Client_ID(), p_AD_Org_ID , M_Product_ID , p_M_CostType_ID , p_C_AcctSchema_ID);
log.info("Labor : " + Labor); log.info("Labor : " + Labor);
cost.setCurrentCostPrice(Labor); cost.setCurrentCostPrice(Labor);
cost.save(); cost.save();
@ -126,7 +126,7 @@ public class RollupWorkflow extends SvrProcess
} }
if (element.getCostElementType().equals(element.COSTELEMENTTYPE_BurdenMOverhead)) if (element.getCostElementType().equals(element.COSTELEMENTTYPE_BurdenMOverhead))
{ {
BigDecimal Burden = getCost(element.COSTELEMENTTYPE_BurdenMOverhead, p_AD_Org_ID , M_Product_ID , p_M_CostType_ID , p_C_AcctSchema_ID); BigDecimal Burden = getCost(element.COSTELEMENTTYPE_BurdenMOverhead, getAD_Client_ID() , p_AD_Org_ID , M_Product_ID , p_M_CostType_ID , p_C_AcctSchema_ID);
log.info("Burden : " + Burden); log.info("Burden : " + Burden);
cost.setCurrentCostPrice(Burden); cost.setCurrentCostPrice(Burden);
cost.save(get_TrxName()); cost.save(get_TrxName());
@ -160,11 +160,11 @@ public class RollupWorkflow extends SvrProcess
* @return Cost for this Element * @return Cost for this Element
* @throws Exception if not successful * @throws Exception if not successful
*/ */
private BigDecimal getCost(String CostElementType , int AD_Org_ID , int M_Product_ID , int M_CostType_ID , int C_AcctSchema_ID) private BigDecimal getCost(String CostElementType ,int AD_Client_ID , int AD_Org_ID , int M_Product_ID , int M_CostType_ID , int C_AcctSchema_ID)
{ {
BigDecimal cost = Env.ZERO; BigDecimal cost = Env.ZERO;
int AD_Workflow_ID = getAD_Workflow_ID(AD_Org_ID , M_Product_ID); int AD_Workflow_ID = getAD_Workflow_ID(AD_Client_ID , AD_Org_ID , M_Product_ID);
if (AD_Workflow_ID != 0) if (AD_Workflow_ID != 0)
{ {
MWorkflow Workflow = new MWorkflow(getCtx(),AD_Workflow_ID,get_TrxName()); MWorkflow Workflow = new MWorkflow(getCtx(),AD_Workflow_ID,get_TrxName());
@ -256,10 +256,10 @@ public class RollupWorkflow extends SvrProcess
* @param M_Product_ID Product ID * @param M_Product_ID Product ID
* @return Workflow ID * @return Workflow ID
**/ **/
private int getAD_Workflow_ID(int AD_Org_ID , int M_Product_ID) private int getAD_Workflow_ID(int AD_Client_ID ,int AD_Org_ID , int M_Product_ID)
{ {
MPPProductPlanning pp = MPPProductPlanning.get(getCtx(), AD_Org_ID , M_Product_ID, get_TrxName()); MPPProductPlanning pp = MPPProductPlanning.get(getCtx(), AD_Client_ID, AD_Org_ID , M_Product_ID, get_TrxName());
MProduct M_Product = new MProduct(getCtx(), M_Product_ID,null); MProduct M_Product = new MProduct(getCtx(), M_Product_ID,null);
int AD_Workflow_ID = 0; int AD_Workflow_ID = 0;