IDEMPIERE-5078 - M_inout movementtype add to before save (#1038)
* IDEMPIERE-5078 - M_inout movementtype add to before save * IDEMPIERE-5078 - shared logic between CalloutInOut.doctype and MInOut.getMovementType * IDEMPIERE-5078 - javadoc added (#1038) Co-authored-by: Igor Pojzl <igor.pojzl@cloudempiere.com>
This commit is contained in:
parent
5f15207cba
commit
0dbbdcadab
|
@ -196,6 +196,7 @@ public class CalloutInOut extends CalloutEngine
|
||||||
String trxFlag = rs.getString("IsSOTrx");
|
String trxFlag = rs.getString("IsSOTrx");
|
||||||
Object isSOTrxValue = mTab.getValue("IsSOTrx");
|
Object isSOTrxValue = mTab.getValue("IsSOTrx");
|
||||||
String isSOTrxValueStr = null;
|
String isSOTrxValueStr = null;
|
||||||
|
boolean IsSOTrx = "Y".equals(trxFlag);
|
||||||
if (isSOTrxValue != null)
|
if (isSOTrxValue != null)
|
||||||
{
|
{
|
||||||
if (isSOTrxValue instanceof Boolean)
|
if (isSOTrxValue instanceof Boolean)
|
||||||
|
@ -206,28 +207,9 @@ public class CalloutInOut extends CalloutEngine
|
||||||
|
|
||||||
if (!(trxFlag.equals(isSOTrxValueStr)))
|
if (!(trxFlag.equals(isSOTrxValueStr)))
|
||||||
mTab.setValue("IsSOTrx", trxFlag);
|
mTab.setValue("IsSOTrx", trxFlag);
|
||||||
if (DocBaseType.equals("MMS")) // Material Shipments
|
|
||||||
/**solve 1648131 bug vpj-cd e-evolution */
|
mTab.setValue("MovementType", MInOut.getMovementType(ctx, C_DocType_ID, IsSOTrx, null));
|
||||||
{
|
|
||||||
boolean IsSOTrx = "Y".equals(trxFlag);
|
|
||||||
if (IsSOTrx)
|
|
||||||
mTab.setValue("MovementType", "C-"); // Customer Shipments
|
|
||||||
else
|
|
||||||
mTab.setValue("MovementType", "V-"); // Vendor Return
|
|
||||||
|
|
||||||
}
|
|
||||||
/**END vpj-cd e-evolution */
|
|
||||||
else if (DocBaseType.equals("MMR")) // Material Receipts
|
|
||||||
/**solve 1648131 bug vpj-cd e-evolution */
|
|
||||||
{
|
|
||||||
boolean IsSOTrx = "Y".equals(trxFlag);
|
|
||||||
if (IsSOTrx)
|
|
||||||
mTab.setValue("MovementType", "C+"); // Customer Return
|
|
||||||
else
|
|
||||||
mTab.setValue("MovementType", "V+"); // Vendor Receipts
|
|
||||||
}
|
|
||||||
/**END vpj-cd e-evolution */
|
|
||||||
|
|
||||||
// DocumentNo
|
// DocumentNo
|
||||||
if (rs.getString("IsDocNoControlled").equals("Y"))
|
if (rs.getString("IsDocNoControlled").equals("Y"))
|
||||||
{
|
{
|
||||||
|
|
|
@ -202,15 +202,7 @@ public class MInOut extends X_M_InOut implements DocAction, IDocsPostProcess
|
||||||
to.setIsSOTrx(isSOTrx);
|
to.setIsSOTrx(isSOTrx);
|
||||||
if (counter)
|
if (counter)
|
||||||
{
|
{
|
||||||
MDocType docType = MDocType.get(from.getCtx(), C_DocType_ID);
|
to.setMovementType();
|
||||||
if (MDocType.DOCBASETYPE_MaterialDelivery.equals(docType.getDocBaseType()))
|
|
||||||
{
|
|
||||||
to.setMovementType (isSOTrx ? MOVEMENTTYPE_CustomerShipment : MOVEMENTTYPE_VendorReturns);
|
|
||||||
}
|
|
||||||
else if (MDocType.DOCBASETYPE_MaterialReceipt.equals(docType.getDocBaseType()))
|
|
||||||
{
|
|
||||||
to.setMovementType (isSOTrx ? MOVEMENTTYPE_CustomerReturns : MOVEMENTTYPE_VendorReceipts);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -373,13 +365,7 @@ public class MInOut extends X_M_InOut implements DocAction, IDocsPostProcess
|
||||||
}
|
}
|
||||||
setC_DocType_ID (C_DocTypeShipment_ID);
|
setC_DocType_ID (C_DocTypeShipment_ID);
|
||||||
|
|
||||||
String movementTypeShipment = null;
|
setMovementType();
|
||||||
MDocType dtShipment = new MDocType(order.getCtx(), C_DocTypeShipment_ID, order.get_TrxName());
|
|
||||||
if (dtShipment.getDocBaseType().equals(MDocType.DOCBASETYPE_MaterialDelivery))
|
|
||||||
movementTypeShipment = dtShipment.isSOTrx() ? MOVEMENTTYPE_CustomerShipment : MOVEMENTTYPE_VendorReturns;
|
|
||||||
else if (dtShipment.getDocBaseType().equals(MDocType.DOCBASETYPE_MaterialReceipt))
|
|
||||||
movementTypeShipment = dtShipment.isSOTrx() ? MOVEMENTTYPE_CustomerReturns : MOVEMENTTYPE_VendorReceipts;
|
|
||||||
setMovementType (movementTypeShipment);
|
|
||||||
|
|
||||||
// Default - Today
|
// Default - Today
|
||||||
if (movementDate != null)
|
if (movementDate != null)
|
||||||
|
@ -992,7 +978,42 @@ public class MInOut extends X_M_InOut implements DocAction, IDocsPostProcess
|
||||||
}
|
}
|
||||||
} // setM_Warehouse_ID
|
} // setM_Warehouse_ID
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets Movement Type based on Document Type's DocBaseType and isSOTrx
|
||||||
|
* @param ctx
|
||||||
|
* @param C_DocType_ID Document Type ID
|
||||||
|
* @param issotrx is sales transaction
|
||||||
|
* @param trxName transaction name
|
||||||
|
* @return Movement Type
|
||||||
|
*/
|
||||||
|
public static String getMovementType(Properties ctx, int C_DocType_ID, boolean issotrx, String trxName) {
|
||||||
|
String movementType = null;
|
||||||
|
MDocType docType = MDocType.get(C_DocType_ID);
|
||||||
|
|
||||||
|
if (docType == null) return null;
|
||||||
|
|
||||||
|
if (docType.getDocBaseType().equals(MDocType.DOCBASETYPE_MaterialDelivery))
|
||||||
|
movementType = docType.isSOTrx() ? MOVEMENTTYPE_CustomerShipment : MOVEMENTTYPE_VendorReturns;
|
||||||
|
else if (docType.getDocBaseType().equals(MDocType.DOCBASETYPE_MaterialReceipt))
|
||||||
|
movementType = docType.isSOTrx() ? MOVEMENTTYPE_CustomerReturns : MOVEMENTTYPE_VendorReceipts;
|
||||||
|
|
||||||
|
return movementType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets Movement Type based on Document Type's DocBaseType and isSOTrx
|
||||||
|
*/
|
||||||
|
public void setMovementType() {
|
||||||
|
|
||||||
|
if(getC_DocType_ID() <= 0) {
|
||||||
|
log.saveError("FillMandatory", Msg.translate(getCtx(), "C_DocType_ID"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
String movementType = getMovementType(getCtx(), getC_DocType_ID(), isSOTrx(), get_TrxName());
|
||||||
|
setMovementType(movementType);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Before Save
|
* Before Save
|
||||||
* @param newRecord new
|
* @param newRecord new
|
||||||
|
@ -1000,6 +1021,10 @@ public class MInOut extends X_M_InOut implements DocAction, IDocsPostProcess
|
||||||
*/
|
*/
|
||||||
protected boolean beforeSave (boolean newRecord)
|
protected boolean beforeSave (boolean newRecord)
|
||||||
{
|
{
|
||||||
|
if(newRecord || is_ValueChanged("C_DocType")) {
|
||||||
|
setMovementType();
|
||||||
|
}
|
||||||
|
|
||||||
MWarehouse wh = MWarehouse.get(getCtx(), getM_Warehouse_ID());
|
MWarehouse wh = MWarehouse.get(getCtx(), getM_Warehouse_ID());
|
||||||
// Warehouse Org
|
// Warehouse Org
|
||||||
if (newRecord)
|
if (newRecord)
|
||||||
|
@ -1038,7 +1063,7 @@ public class MInOut extends X_M_InOut implements DocAction, IDocsPostProcess
|
||||||
MDocType docType = MDocType.get(getCtx(), rma.getC_DocType_ID());
|
MDocType docType = MDocType.get(getCtx(), rma.getC_DocType_ID());
|
||||||
setC_DocType_ID(docType.getC_DocTypeShipment_ID());
|
setC_DocType_ID(docType.getC_DocTypeShipment_ID());
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} // beforeSave
|
} // beforeSave
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue