BF [ 2528220 ] Posting commitment release issues

https://sourceforge.net/tracker/?func=detail&atid=879332&aid=2528220&group_id=176962
This commit is contained in:
teo_sarca 2009-01-22 10:50:25 +00:00
parent d6529914fc
commit 0fc80586b8
1 changed files with 18 additions and 13 deletions

View File

@ -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