BF [ 2528220 ] Posting commitment release issues
https://sourceforge.net/tracker/?func=detail&atid=879332&aid=2528220&group_id=176962
This commit is contained in:
parent
d6529914fc
commit
0fc80586b8
|
@ -1,5 +1,5 @@
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* Product: Adempiere ERP & CRM Smart Business Solution *
|
* Product: Adempiere ERP & CRM Smart Business Solution *
|
||||||
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
|
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
|
||||||
* This program is free software; you can redistribute it and/or modify it *
|
* This program is free software; you can redistribute it and/or modify it *
|
||||||
* under the terms version 2 of the GNU General Public License as published *
|
* under the terms version 2 of the GNU General Public License as published *
|
||||||
|
@ -596,15 +596,20 @@ public class Doc_Order extends Doc
|
||||||
Fact fact = new Fact(doc, as, Fact.POST_Commitment);
|
Fact fact = new Fact(doc, as, Fact.POST_Commitment);
|
||||||
DocLine[] commitments = Doc_Order.getCommitments(doc, Qty,
|
DocLine[] commitments = Doc_Order.getCommitments(doc, Qty,
|
||||||
C_InvoiceLine_ID);
|
C_InvoiceLine_ID);
|
||||||
|
if (commitments.length == 0)
|
||||||
|
{
|
||||||
|
return fact;
|
||||||
|
}
|
||||||
|
|
||||||
BigDecimal total = Env.ZERO;
|
BigDecimal total = Env.ZERO;
|
||||||
FactLine fl = null;
|
|
||||||
int C_Currency_ID = -1;
|
int C_Currency_ID = -1;
|
||||||
for (int i = 0; i < commitments.length; i++)
|
for (int i = 0; i < commitments.length; i++)
|
||||||
{
|
{
|
||||||
DocLine line = commitments[i];
|
DocLine line = commitments[i];
|
||||||
if (C_Currency_ID == -1)
|
if (C_Currency_ID == -1)
|
||||||
|
{
|
||||||
C_Currency_ID = line.getC_Currency_ID();
|
C_Currency_ID = line.getC_Currency_ID();
|
||||||
|
}
|
||||||
else if (C_Currency_ID != line.getC_Currency_ID())
|
else if (C_Currency_ID != line.getC_Currency_ID())
|
||||||
{
|
{
|
||||||
doc.p_Error = "Different Currencies of Order Lines";
|
doc.p_Error = "Different Currencies of Order Lines";
|
||||||
|
@ -616,8 +621,7 @@ public class Doc_Order extends Doc
|
||||||
|
|
||||||
// Account
|
// Account
|
||||||
MAccount expense = line.getAccount(ProductCost.ACCTTYPE_P_Expense, as);
|
MAccount expense = line.getAccount(ProductCost.ACCTTYPE_P_Expense, as);
|
||||||
fl = fact.createLine (line, expense,
|
fact.createLine (line, expense, C_Currency_ID, null, cost);
|
||||||
C_Currency_ID, null, cost);
|
|
||||||
}
|
}
|
||||||
// Offset
|
// Offset
|
||||||
MAccount offset = doc.getAccount(ACCTTYPE_CommitmentOffset, as);
|
MAccount offset = doc.getAccount(ACCTTYPE_CommitmentOffset, as);
|
||||||
|
@ -627,8 +631,7 @@ public class Doc_Order extends Doc
|
||||||
s_log.log(Level.SEVERE, doc.p_Error);
|
s_log.log(Level.SEVERE, doc.p_Error);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
fact.createLine (null, offset,
|
fact.createLine (null, offset, C_Currency_ID, total, null);
|
||||||
C_Currency_ID, total, null);
|
|
||||||
return fact;
|
return fact;
|
||||||
} // getCommitmentRelease
|
} // getCommitmentRelease
|
||||||
|
|
||||||
|
@ -734,17 +737,21 @@ public class Doc_Order extends Doc
|
||||||
BigDecimal Qty, int M_InOutLine_ID, BigDecimal multiplier)
|
BigDecimal Qty, int M_InOutLine_ID, BigDecimal multiplier)
|
||||||
{
|
{
|
||||||
Fact fact = new Fact(doc, as, Fact.POST_Commitment);
|
Fact fact = new Fact(doc, as, Fact.POST_Commitment);
|
||||||
DocLine[] commitments = Doc_Order.getCommitmentsSales(doc, Qty,
|
DocLine[] commitments = Doc_Order.getCommitmentsSales(doc, Qty, M_InOutLine_ID);
|
||||||
M_InOutLine_ID);
|
if (commitments.length == 0)
|
||||||
|
{
|
||||||
|
return fact;
|
||||||
|
}
|
||||||
|
|
||||||
BigDecimal total = Env.ZERO;
|
BigDecimal total = Env.ZERO;
|
||||||
FactLine fl = null;
|
|
||||||
int C_Currency_ID = -1;
|
int C_Currency_ID = -1;
|
||||||
for (int i = 0; i < commitments.length; i++)
|
for (int i = 0; i < commitments.length; i++)
|
||||||
{
|
{
|
||||||
DocLine line = commitments[i];
|
DocLine line = commitments[i];
|
||||||
if (C_Currency_ID == -1)
|
if (C_Currency_ID == -1)
|
||||||
|
{
|
||||||
C_Currency_ID = line.getC_Currency_ID();
|
C_Currency_ID = line.getC_Currency_ID();
|
||||||
|
}
|
||||||
else if (C_Currency_ID != line.getC_Currency_ID())
|
else if (C_Currency_ID != line.getC_Currency_ID())
|
||||||
{
|
{
|
||||||
doc.p_Error = "Different Currencies of Order Lines";
|
doc.p_Error = "Different Currencies of Order Lines";
|
||||||
|
@ -756,8 +763,7 @@ public class Doc_Order extends Doc
|
||||||
|
|
||||||
// Account
|
// Account
|
||||||
MAccount revenue = line.getAccount(ProductCost.ACCTTYPE_P_Revenue, as);
|
MAccount revenue = line.getAccount(ProductCost.ACCTTYPE_P_Revenue, as);
|
||||||
fl = fact.createLine (line, revenue,
|
fact.createLine (line, revenue, C_Currency_ID, cost, null);
|
||||||
C_Currency_ID, cost, null);
|
|
||||||
}
|
}
|
||||||
// Offset
|
// Offset
|
||||||
MAccount offset = doc.getAccount(ACCTTYPE_CommitmentOffsetSales, as);
|
MAccount offset = doc.getAccount(ACCTTYPE_CommitmentOffsetSales, as);
|
||||||
|
@ -767,8 +773,7 @@ public class Doc_Order extends Doc
|
||||||
s_log.log(Level.SEVERE, doc.p_Error);
|
s_log.log(Level.SEVERE, doc.p_Error);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
fact.createLine (null, offset,
|
fact.createLine (null, offset, C_Currency_ID, null, total);
|
||||||
C_Currency_ID, null, total);
|
|
||||||
return fact;
|
return fact;
|
||||||
} // getCommitmentSalesRelease
|
} // getCommitmentSalesRelease
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue