IDEMPIERE-4849: fix for MProduction.createLines() storage issue (#743)
* fix for MProduction.createLines/( storage issue * extended if clause to cover storage lines with the same AsiID Co-authored-by: Andreas <sumerauer@kanzlei-wmv.de>
This commit is contained in:
parent
0bb5aa70f6
commit
73b389652f
|
@ -254,8 +254,6 @@ public class MProduction extends X_M_Production implements DocAction {
|
||||||
|
|
||||||
int M_Warehouse_ID = finishedLocator.getM_Warehouse_ID();
|
int M_Warehouse_ID = finishedLocator.getM_Warehouse_ID();
|
||||||
|
|
||||||
int asi = 0;
|
|
||||||
|
|
||||||
// products used in production
|
// products used in production
|
||||||
String sql = "SELECT M_ProductBom_ID, BOMQty" + " FROM M_Product_BOM"
|
String sql = "SELECT M_ProductBom_ID, BOMQty" + " FROM M_Product_BOM"
|
||||||
+ " WHERE M_Product_ID=" + finishedProduct.getM_Product_ID() + " ORDER BY Line";
|
+ " WHERE M_Product_ID=" + finishedProduct.getM_Product_ID() + " ORDER BY Line";
|
||||||
|
@ -339,6 +337,7 @@ public class MProduction extends X_M_Production implements DocAction {
|
||||||
MProductionLine BOMLine = null;
|
MProductionLine BOMLine = null;
|
||||||
int prevLoc = -1;
|
int prevLoc = -1;
|
||||||
int previousAttribSet = -1;
|
int previousAttribSet = -1;
|
||||||
|
int prevAsi = -1;
|
||||||
// Create lines from storage until qty is reached
|
// Create lines from storage until qty is reached
|
||||||
for (int sl = 0; sl < storages.length; sl++) {
|
for (int sl = 0; sl < storages.length; sl++) {
|
||||||
|
|
||||||
|
@ -350,11 +349,11 @@ public class MProduction extends X_M_Production implements DocAction {
|
||||||
|
|
||||||
int loc = storages[sl].getM_Locator_ID();
|
int loc = storages[sl].getM_Locator_ID();
|
||||||
int slASI = storages[sl].getM_AttributeSetInstance_ID();
|
int slASI = storages[sl].getM_AttributeSetInstance_ID();
|
||||||
int locAttribSet = new MAttributeSetInstance(getCtx(), asi,
|
int locAttribSet = new MAttributeSetInstance(getCtx(), slASI,
|
||||||
get_TrxName()).getM_AttributeSet_ID();
|
get_TrxName()).getM_AttributeSet_ID();
|
||||||
|
|
||||||
// roll up costing attributes if in the same locator
|
// roll up costing attributes if in the same locator
|
||||||
if (locAttribSet == 0 && previousAttribSet == 0
|
if (((locAttribSet == 0 && previousAttribSet == 0) || (slASI == prevAsi))
|
||||||
&& prevLoc == loc) {
|
&& prevLoc == loc) {
|
||||||
BOMLine.setQtyUsed(BOMLine.getQtyUsed()
|
BOMLine.setQtyUsed(BOMLine.getQtyUsed()
|
||||||
.add(lineQty));
|
.add(lineQty));
|
||||||
|
@ -379,6 +378,7 @@ public class MProduction extends X_M_Production implements DocAction {
|
||||||
}
|
}
|
||||||
prevLoc = loc;
|
prevLoc = loc;
|
||||||
previousAttribSet = locAttribSet;
|
previousAttribSet = locAttribSet;
|
||||||
|
prevAsi = slASI;
|
||||||
// enough ?
|
// enough ?
|
||||||
BOMMovementQty = BOMMovementQty.subtract(lineQty);
|
BOMMovementQty = BOMMovementQty.subtract(lineQty);
|
||||||
if (BOMMovementQty.signum() == 0)
|
if (BOMMovementQty.signum() == 0)
|
||||||
|
|
Loading…
Reference in New Issue