BF [ 2042195 ] MPPOrderBOMLine: Set Line automatically if zero

This commit is contained in:
teo_sarca 2008-08-07 21:25:51 +00:00
parent cce7e13ae8
commit cd14a70e07
2 changed files with 17 additions and 2 deletions

View File

@ -565,7 +565,6 @@ public class MPPOrder extends X_PP_Order implements DocAction {
PP_Order_BOMLine.setForecast(PP_Product_BOMline[i].getForecast()); PP_Order_BOMLine.setForecast(PP_Product_BOMline[i].getForecast());
PP_Order_BOMLine.setIsCritical(PP_Product_BOMline[i].isCritical()); PP_Order_BOMLine.setIsCritical(PP_Product_BOMline[i].isCritical());
PP_Order_BOMLine.setIssueMethod(PP_Product_BOMline[i].getIssueMethod()); PP_Order_BOMLine.setIssueMethod(PP_Product_BOMline[i].getIssueMethod());
PP_Order_BOMLine.setLine(MPPOrder.getLines(getPP_Order_ID()).length + 10);
PP_Order_BOMLine.setLeadTimeOffset(PP_Product_BOMline[i].getLeadTimeOffset()); PP_Order_BOMLine.setLeadTimeOffset(PP_Product_BOMline[i].getLeadTimeOffset());
PP_Order_BOMLine.setM_AttributeSetInstance_ID(PP_Product_BOMline[i].getM_AttributeSetInstance_ID()); PP_Order_BOMLine.setM_AttributeSetInstance_ID(PP_Product_BOMline[i].getM_AttributeSetInstance_ID());
PP_Order_BOMLine.setPP_Order_BOM_ID(PP_Order_BOM.getPP_Order_BOM_ID()); PP_Order_BOMLine.setPP_Order_BOM_ID(PP_Order_BOM.getPP_Order_BOM_ID());

View File

@ -20,6 +20,7 @@ import java.sql.ResultSet;
import java.util.Properties; import java.util.Properties;
import org.compiere.model.MProduct; import org.compiere.model.MProduct;
import org.compiere.util.DB;
import org.compiere.util.Env; import org.compiere.util.Env;
/** /**
@ -63,6 +64,22 @@ public class MPPOrderBOMLine extends X_PP_Order_BOMLine
private MPPOrder m_parent = null; private MPPOrder m_parent = null;
private MProduct m_product = null; private MProduct m_product = null;
@Override
protected boolean beforeSave(boolean newRecord) {
// Get Line No
if (getLine() == 0)
{
String sql = "SELECT COALESCE(MAX("+COLUMNNAME_Line+"),0)+10 FROM "+Table_Name
+" WHERE "+COLUMNNAME_PP_Order_ID+"=?";
int ii = DB.getSQLValue (get_TrxName(), sql, getPP_Order_ID());
setLine (ii);
}
return true;
}
/************************************************************************** /**************************************************************************
* after Save * after Save
* @param newRecord new * @param newRecord new
@ -107,7 +124,6 @@ public class MPPOrderBOMLine extends X_PP_Order_BOMLine
PP_Order_BOMLine.setForecast(PP_Product_BOMline[i].getForecast()); PP_Order_BOMLine.setForecast(PP_Product_BOMline[i].getForecast());
PP_Order_BOMLine.setIsCritical(PP_Product_BOMline[i].isCritical()); PP_Order_BOMLine.setIsCritical(PP_Product_BOMline[i].isCritical());
PP_Order_BOMLine.setIssueMethod(PP_Product_BOMline[i].getIssueMethod()); PP_Order_BOMLine.setIssueMethod(PP_Product_BOMline[i].getIssueMethod());
PP_Order_BOMLine.setLine(MPPOrder.getLines(getPP_Order_ID()).length+10);
PP_Order_BOMLine.setLeadTimeOffset(PP_Product_BOMline[i].getLeadTimeOffset()); PP_Order_BOMLine.setLeadTimeOffset(PP_Product_BOMline[i].getLeadTimeOffset());
PP_Order_BOMLine.setM_AttributeSetInstance_ID(PP_Product_BOMline[i].getM_AttributeSetInstance_ID()); PP_Order_BOMLine.setM_AttributeSetInstance_ID(PP_Product_BOMline[i].getM_AttributeSetInstance_ID());
PP_Order_BOMLine.setPP_Order_BOM_ID(getPP_Order_BOM_ID()); PP_Order_BOMLine.setPP_Order_BOM_ID(getPP_Order_BOM_ID());