1003475 IDEMPIERE-1530 Allow Material Receipt Line with Quantity Receipt more then Purchase Order Line's Quantity Ordered
This commit is contained in:
parent
74f6661322
commit
d421ce00e2
|
@ -0,0 +1,25 @@
|
||||||
|
SET SQLBLANKLINES ON
|
||||||
|
SET DEFINE OFF
|
||||||
|
|
||||||
|
|
||||||
|
-- Nov 13, 2013 5:26:33 PM MYT
|
||||||
|
-- Make validation of purchase order quantity against invoice and receipt quantity optional
|
||||||
|
INSERT INTO AD_SysConfig (AD_SysConfig_ID,ConfigurationLevel,Value,Description,AD_SysConfig_UU,Created,Updated,AD_Org_ID,CreatedBy,IsActive,UpdatedBy,Name,AD_Client_ID,EntityType) VALUES (200039,'C','Y','Set this to false (N) to allow material receipt and invoice with quantity more than purchase order quantity.','f473c472-1285-4936-8bb8-2f36f68de12e',TO_DATE('2013-11-13 17:26:26','YYYY-MM-DD HH24:MI:SS'),TO_DATE('2013-11-13 17:26:26','YYYY-MM-DD HH24:MI:SS'),0,100,'Y',100,'VALIDATE_MATCHING_TO_ORDERED_QTY',0,'D')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:44:29 PM MYT
|
||||||
|
-- Make validation of purchase order quantity against invoice and receipt quantity optional
|
||||||
|
INSERT INTO AD_Element (ColumnName,AD_Element_ID,Help,Name,Description,PrintName,AD_Element_UU,Created,Updated,CreatedBy,AD_Org_ID,UpdatedBy,IsActive,AD_Client_ID,EntityType) VALUES ('QtyOverReceipt',202627,'Calculated: Receipt - ordered quantity','Over Receipt','Over Receipt Quantity','Over Receipt','6872e34a-74bc-4590-b8e3-da15b6d365ba',TO_DATE('2013-11-13 19:44:25','YYYY-MM-DD HH24:MI:SS'),TO_DATE('2013-11-13 19:44:25','YYYY-MM-DD HH24:MI:SS'),100,0,100,'Y',0,'D')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:45:25 PM MYT
|
||||||
|
INSERT INTO AD_Column (SeqNoSelection,IsSyncDatabase,Version,AD_Table_ID,AD_Column_ID,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,AD_Reference_ID,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,Updated,CreatedBy,AD_Org_ID,IsActive,Created,UpdatedBy,IsToolbarButton,IsAlwaysUpdateable,AD_Client_ID,EntityType,IsEncrypted,AD_Element_ID,IsSecure) VALUES (0,'N',1,320,210888,'N','N','N',0,'N',22,'N',29,'N','N','Y','8a1f15d1-412e-464e-9797-b547a152b54b','Y','QtyOverReceipt','Over Receipt Quantity','0','Calculated: Receipt - ordered quantity','Over Receipt','N',TO_DATE('2013-11-13 19:45:22','YYYY-MM-DD HH24:MI:SS'),100,0,'Y',TO_DATE('2013-11-13 19:45:22','YYYY-MM-DD HH24:MI:SS'),100,'N','N',0,'D','N',202627,'N')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:45:55 PM MYT
|
||||||
|
ALTER TABLE M_InOutLine ADD QtyOverReceipt NUMBER DEFAULT 0
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201311131356_IDEMPIERE-1530.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
-- Nov 13, 2013 5:26:33 PM MYT
|
||||||
|
-- Make validation of purchase order quantity against invoice and receipt quantity optional
|
||||||
|
INSERT INTO AD_SysConfig (AD_SysConfig_ID,ConfigurationLevel,Value,Description,AD_SysConfig_UU,Created,Updated,AD_Org_ID,CreatedBy,IsActive,UpdatedBy,Name,AD_Client_ID,EntityType) VALUES (200039,'C','Y','Set this to false (N) to allow material receipt and invoice with quantity more than purchase order quantity.','f473c472-1285-4936-8bb8-2f36f68de12e',TO_TIMESTAMP('2013-11-13 17:26:26','YYYY-MM-DD HH24:MI:SS'),TO_TIMESTAMP('2013-11-13 17:26:26','YYYY-MM-DD HH24:MI:SS'),0,100,'Y',100,'VALIDATE_MATCHING_TO_ORDERED_QTY',0,'D')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:44:29 PM MYT
|
||||||
|
-- Make validation of purchase order quantity against invoice and receipt quantity optional
|
||||||
|
INSERT INTO AD_Element (ColumnName,AD_Element_ID,Help,Name,Description,PrintName,AD_Element_UU,Created,Updated,CreatedBy,AD_Org_ID,UpdatedBy,IsActive,AD_Client_ID,EntityType) VALUES ('QtyOverReceipt',202627,'Calculated: Receipt - ordered quantity','Over Receipt','Over Receipt Quantity','Over Receipt','6872e34a-74bc-4590-b8e3-da15b6d365ba',TO_TIMESTAMP('2013-11-13 19:44:25','YYYY-MM-DD HH24:MI:SS'),TO_TIMESTAMP('2013-11-13 19:44:25','YYYY-MM-DD HH24:MI:SS'),100,0,100,'Y',0,'D')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:45:25 PM MYT
|
||||||
|
INSERT INTO AD_Column (SeqNoSelection,IsSyncDatabase,Version,AD_Table_ID,AD_Column_ID,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,AD_Reference_ID,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,Updated,CreatedBy,AD_Org_ID,IsActive,Created,UpdatedBy,IsToolbarButton,IsAlwaysUpdateable,AD_Client_ID,EntityType,IsEncrypted,AD_Element_ID,IsSecure) VALUES (0,'N',1,320,210888,'N','N','N',0,'N',22,'N',29,'N','N','Y','8a1f15d1-412e-464e-9797-b547a152b54b','Y','QtyOverReceipt','Over Receipt Quantity','0','Calculated: Receipt - ordered quantity','Over Receipt','N',TO_TIMESTAMP('2013-11-13 19:45:22','YYYY-MM-DD HH24:MI:SS'),100,0,'Y',TO_TIMESTAMP('2013-11-13 19:45:22','YYYY-MM-DD HH24:MI:SS'),100,'N','N',0,'D','N',202627,'N')
|
||||||
|
;
|
||||||
|
|
||||||
|
-- Nov 13, 2013 7:45:55 PM MYT
|
||||||
|
ALTER TABLE M_InOutLine ADD COLUMN QtyOverReceipt NUMERIC DEFAULT 0
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201311131356_IDEMPIERE-1530.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -434,6 +434,19 @@ public interface I_M_InOutLine
|
||||||
*/
|
*/
|
||||||
public BigDecimal getQtyEntered();
|
public BigDecimal getQtyEntered();
|
||||||
|
|
||||||
|
/** Column name QtyOverReceipt */
|
||||||
|
public static final String COLUMNNAME_QtyOverReceipt = "QtyOverReceipt";
|
||||||
|
|
||||||
|
/** Set Over Receipt.
|
||||||
|
* Over Receipt Quantity
|
||||||
|
*/
|
||||||
|
public void setQtyOverReceipt (BigDecimal QtyOverReceipt);
|
||||||
|
|
||||||
|
/** Get Over Receipt.
|
||||||
|
* Over Receipt Quantity
|
||||||
|
*/
|
||||||
|
public BigDecimal getQtyOverReceipt();
|
||||||
|
|
||||||
/** Column name Ref_InOutLine_ID */
|
/** Column name Ref_InOutLine_ID */
|
||||||
public static final String COLUMNNAME_Ref_InOutLine_ID = "Ref_InOutLine_ID";
|
public static final String COLUMNNAME_Ref_InOutLine_ID = "Ref_InOutLine_ID";
|
||||||
|
|
||||||
|
|
|
@ -758,6 +758,10 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
line.setM_RMALine_ID(peer.getRef_RMALine_ID());
|
line.setM_RMALine_ID(peer.getRef_RMALine_ID());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (!isSOTrx())
|
||||||
|
{
|
||||||
|
line.setQtyOverReceipt(fromLine.getQtyOverReceipt());
|
||||||
|
}
|
||||||
//
|
//
|
||||||
line.setProcessed(false);
|
line.setProcessed(false);
|
||||||
if (line.save(get_TrxName()))
|
if (line.save(get_TrxName()))
|
||||||
|
@ -1287,7 +1291,6 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
if (MovementType.charAt(1) == '-') // C- Customer Shipment - V- Vendor Return
|
if (MovementType.charAt(1) == '-') // C- Customer Shipment - V- Vendor Return
|
||||||
Qty = Qty.negate();
|
Qty = Qty.negate();
|
||||||
BigDecimal QtySO = Env.ZERO;
|
BigDecimal QtySO = Env.ZERO;
|
||||||
BigDecimal QtyPO = Env.ZERO;
|
|
||||||
|
|
||||||
// Update Order Line
|
// Update Order Line
|
||||||
MOrderLine oLine = null;
|
MOrderLine oLine = null;
|
||||||
|
@ -1298,8 +1301,6 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
+ ", Delivered=" + oLine.getQtyDelivered());
|
+ ", Delivered=" + oLine.getQtyDelivered());
|
||||||
if (isSOTrx())
|
if (isSOTrx())
|
||||||
QtySO = sLine.getMovementQty();
|
QtySO = sLine.getMovementQty();
|
||||||
else
|
|
||||||
QtyPO = sLine.getMovementQty();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1334,6 +1335,27 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
sameWarehouse = oLine.getM_Warehouse_ID()==getM_Warehouse_ID();
|
sameWarehouse = oLine.getM_Warehouse_ID()==getM_Warehouse_ID();
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
BigDecimal overReceipt = BigDecimal.ZERO;
|
||||||
|
if (!isSOTrx())
|
||||||
|
{
|
||||||
|
if (!isReversal())
|
||||||
|
{
|
||||||
|
BigDecimal toDelivered = oLine.getQtyOrdered().subtract(oLine.getQtyDelivered());
|
||||||
|
if (sLine.getMovementQty().compareTo(toDelivered) > 0)
|
||||||
|
overReceipt = sLine.getMovementQty().subtract(toDelivered);
|
||||||
|
if (overReceipt.signum() != 0)
|
||||||
|
{
|
||||||
|
sLine.setQtyOverReceipt(overReceipt);
|
||||||
|
sLine.saveEx();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
overReceipt = sLine.getQtyOverReceipt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
BigDecimal orderedQtyToUpdate = sLine.getMovementQty().subtract(overReceipt);
|
||||||
|
//
|
||||||
if (sLine.getM_AttributeSetInstance_ID() == 0)
|
if (sLine.getM_AttributeSetInstance_ID() == 0)
|
||||||
{
|
{
|
||||||
MInOutLineMA mas[] = MInOutLineMA.get(getCtx(),
|
MInOutLineMA mas[] = MInOutLineMA.get(getCtx(),
|
||||||
|
@ -1349,10 +1371,23 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
if (sLine.getC_OrderLine_ID() != 0)
|
if (sLine.getC_OrderLine_ID() != 0)
|
||||||
{
|
{
|
||||||
if (isSOTrx())
|
if (isSOTrx())
|
||||||
|
{
|
||||||
reservedDiff = ma.getMovementQty().negate();
|
reservedDiff = ma.getMovementQty().negate();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if (ma.getMovementQty().compareTo(orderedQtyToUpdate) >= 0)
|
||||||
|
{
|
||||||
|
orderedQtyToUpdate = orderedQtyToUpdate.subtract(ma.getMovementQty());
|
||||||
orderedDiff = ma.getMovementQty().negate();
|
orderedDiff = ma.getMovementQty().negate();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
orderedDiff = orderedQtyToUpdate.negate();
|
||||||
|
orderedQtyToUpdate = BigDecimal.ZERO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Update Storage - see also VMatch.createMatchRecord
|
// Update Storage - see also VMatch.createMatchRecord
|
||||||
if (!MStorageOnHand.add(getCtx(), getM_Warehouse_ID(),
|
if (!MStorageOnHand.add(getCtx(), getM_Warehouse_ID(),
|
||||||
|
@ -1435,7 +1470,7 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
if (mtrx == null)
|
if (mtrx == null)
|
||||||
{
|
{
|
||||||
BigDecimal reservedDiff = sameWarehouse ? QtySO.negate() : Env.ZERO;
|
BigDecimal reservedDiff = sameWarehouse ? QtySO.negate() : Env.ZERO;
|
||||||
BigDecimal orderedDiff = sameWarehouse ? QtyPO.negate(): Env.ZERO;
|
BigDecimal orderedDiff = sameWarehouse ? orderedQtyToUpdate.negate(): Env.ZERO;
|
||||||
|
|
||||||
// Fallback: Update Storage - see also VMatch.createMatchRecord
|
// Fallback: Update Storage - see also VMatch.createMatchRecord
|
||||||
if (!MStorageOnHand.add(getCtx(), getM_Warehouse_ID(),
|
if (!MStorageOnHand.add(getCtx(), getM_Warehouse_ID(),
|
||||||
|
@ -1482,11 +1517,11 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
return DocAction.STATUS_Invalid;
|
return DocAction.STATUS_Invalid;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (QtyPO.signum() != 0) {
|
if (orderedQtyToUpdate.signum() != 0) {
|
||||||
if (!MStorageReservation.add(getCtx(), oLine.getM_Warehouse_ID(),
|
if (!MStorageReservation.add(getCtx(), oLine.getM_Warehouse_ID(),
|
||||||
sLine.getM_Product_ID(),
|
sLine.getM_Product_ID(),
|
||||||
sLine.getM_AttributeSetInstance_ID(), reservationAttributeSetInstance_ID,
|
sLine.getM_AttributeSetInstance_ID(), reservationAttributeSetInstance_ID,
|
||||||
QtyPO.negate(), false, get_TrxName()))
|
orderedQtyToUpdate.negate(), false, get_TrxName()))
|
||||||
{
|
{
|
||||||
m_processMsg = "Cannot correct Inventory Ordered [" + product.getValue() + "]";
|
m_processMsg = "Cannot correct Inventory Ordered [" + product.getValue() + "]";
|
||||||
return DocAction.STATUS_Invalid;
|
return DocAction.STATUS_Invalid;
|
||||||
|
@ -1509,7 +1544,12 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
|
|
||||||
// Correct Order Line
|
// Correct Order Line
|
||||||
if (product != null && oLine != null) // other in VMatch.createMatchRecord
|
if (product != null && oLine != null) // other in VMatch.createMatchRecord
|
||||||
|
{
|
||||||
|
if (isSOTrx())
|
||||||
oLine.setQtyReserved(oLine.getQtyReserved().subtract(sLine.getMovementQty()));
|
oLine.setQtyReserved(oLine.getQtyReserved().subtract(sLine.getMovementQty()));
|
||||||
|
else
|
||||||
|
oLine.setQtyReserved(oLine.getQtyReserved().subtract(sLine.getMovementQty().subtract(sLine.getQtyOverReceipt())));
|
||||||
|
}
|
||||||
|
|
||||||
// Update Sales Order Line
|
// Update Sales Order Line
|
||||||
if (oLine != null)
|
if (oLine != null)
|
||||||
|
@ -2174,6 +2214,7 @@ public class MInOut extends X_M_InOut implements DocAction
|
||||||
MInOutLine rLine = rLines[i];
|
MInOutLine rLine = rLines[i];
|
||||||
rLine.setQtyEntered(rLine.getQtyEntered().negate());
|
rLine.setQtyEntered(rLine.getQtyEntered().negate());
|
||||||
rLine.setMovementQty(rLine.getMovementQty().negate());
|
rLine.setMovementQty(rLine.getMovementQty().negate());
|
||||||
|
rLine.setQtyOverReceipt(rLine.getQtyOverReceipt().negate());
|
||||||
rLine.setM_AttributeSetInstance_ID(sLines[i].getM_AttributeSetInstance_ID());
|
rLine.setM_AttributeSetInstance_ID(sLines[i].getM_AttributeSetInstance_ID());
|
||||||
// Goodwill: store original (voided/reversed) document line
|
// Goodwill: store original (voided/reversed) document line
|
||||||
rLine.setReversalLine_ID(sLines[i].getM_InOutLine_ID());
|
rLine.setReversalLine_ID(sLines[i].getM_InOutLine_ID());
|
||||||
|
|
|
@ -910,6 +910,9 @@ public class MMatchPO extends X_M_MatchPO
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getC_OrderLine_ID() > 0)
|
if (getC_OrderLine_ID() > 0)
|
||||||
|
{
|
||||||
|
boolean validateOrderedQty = MSysConfig.getBooleanValue(MSysConfig.VALIDATE_MATCHING_TO_ORDERED_QTY, true, Env.getAD_Client_ID(Env.getCtx()));
|
||||||
|
if (validateOrderedQty)
|
||||||
{
|
{
|
||||||
MOrderLine line = new MOrderLine(getCtx(), getC_OrderLine_ID(), get_TrxName());
|
MOrderLine line = new MOrderLine(getCtx(), getC_OrderLine_ID(), get_TrxName());
|
||||||
BigDecimal invoicedQty = DB.getSQLValueBD(get_TrxName(), "SELECT Coalesce(SUM(Qty),0) FROM M_MatchPO WHERE C_InvoiceLine_ID > 0 and C_OrderLine_ID=?" , getC_OrderLine_ID());
|
BigDecimal invoicedQty = DB.getSQLValueBD(get_TrxName(), "SELECT Coalesce(SUM(Qty),0) FROM M_MatchPO WHERE C_InvoiceLine_ID > 0 and C_OrderLine_ID=?" , getC_OrderLine_ID());
|
||||||
|
@ -925,6 +928,7 @@ public class MMatchPO extends X_M_MatchPO
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Purchase Order Delivered/Invoiced
|
// Purchase Order Delivered/Invoiced
|
||||||
// (Reserved in VMatch and MInOut.completeIt)
|
// (Reserved in VMatch and MInOut.completeIt)
|
||||||
|
|
|
@ -118,6 +118,7 @@ public class MSysConfig extends X_AD_SysConfig
|
||||||
public static final String ZK_MAX_UPLOAD_SIZE = "ZK_MAX_UPLOAD_SIZE";
|
public static final String ZK_MAX_UPLOAD_SIZE = "ZK_MAX_UPLOAD_SIZE";
|
||||||
public static final String CALENDAR_ALTERNATE_TIMEZONE = "CALENDAR_ALTERNATE_TIMEZONE";
|
public static final String CALENDAR_ALTERNATE_TIMEZONE = "CALENDAR_ALTERNATE_TIMEZONE";
|
||||||
public static final String ZK_REPORT_JASPER_OUTPUT_TYPE = "ZK_REPORT_JASPER_OUTPUT_TYPE";
|
public static final String ZK_REPORT_JASPER_OUTPUT_TYPE = "ZK_REPORT_JASPER_OUTPUT_TYPE";
|
||||||
|
public static final String VALIDATE_MATCHING_TO_ORDERED_QTY = "VALIDATE_MATCHING_TO_ORDERED_QTY";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard Constructor
|
* Standard Constructor
|
||||||
|
|
|
@ -32,7 +32,7 @@ public class X_M_InOutLine extends PO implements I_M_InOutLine, I_Persistent
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 20130626L;
|
private static final long serialVersionUID = 20131113L;
|
||||||
|
|
||||||
/** Standard Constructor */
|
/** Standard Constructor */
|
||||||
public X_M_InOutLine (Properties ctx, int M_InOutLine_ID, String trxName)
|
public X_M_InOutLine (Properties ctx, int M_InOutLine_ID, String trxName)
|
||||||
|
@ -704,6 +704,26 @@ public class X_M_InOutLine extends PO implements I_M_InOutLine, I_Persistent
|
||||||
return bd;
|
return bd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Set Over Receipt.
|
||||||
|
@param QtyOverReceipt
|
||||||
|
Over Receipt Quantity
|
||||||
|
*/
|
||||||
|
public void setQtyOverReceipt (BigDecimal QtyOverReceipt)
|
||||||
|
{
|
||||||
|
set_Value (COLUMNNAME_QtyOverReceipt, QtyOverReceipt);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Get Over Receipt.
|
||||||
|
@return Over Receipt Quantity
|
||||||
|
*/
|
||||||
|
public BigDecimal getQtyOverReceipt ()
|
||||||
|
{
|
||||||
|
BigDecimal bd = (BigDecimal)get_Value(COLUMNNAME_QtyOverReceipt);
|
||||||
|
if (bd == null)
|
||||||
|
return Env.ZERO;
|
||||||
|
return bd;
|
||||||
|
}
|
||||||
|
|
||||||
/** Set Referenced Shipment Line.
|
/** Set Referenced Shipment Line.
|
||||||
@param Ref_InOutLine_ID Referenced Shipment Line */
|
@param Ref_InOutLine_ID Referenced Shipment Line */
|
||||||
public void setRef_InOutLine_ID (int Ref_InOutLine_ID)
|
public void setRef_InOutLine_ID (int Ref_InOutLine_ID)
|
||||||
|
|
Loading…
Reference in New Issue