Fixed: [ 1691676 ] Duplicate Allocation when you reverse invoice with PR cash
https://sourceforge.net/tracker/index.php?func=detail&aid=1691676&group_id=176962&atid=879332
This commit is contained in:
parent
a8f220dd40
commit
56575e6679
|
@ -2011,14 +2011,18 @@ public class MInvoice extends X_C_Invoice implements DocAction
|
|||
m_processMsg = "@PeriodClosed@";
|
||||
return false;
|
||||
}
|
||||
//
|
||||
MAllocationHdr[] allocations = MAllocationHdr.getOfInvoice(getCtx(),
|
||||
getC_Invoice_ID(), get_TrxName());
|
||||
for (int i = 0; i < allocations.length; i++)
|
||||
{
|
||||
allocations[i].setDocAction(DocAction.ACTION_Reverse_Correct);
|
||||
allocations[i].reverseCorrectIt();
|
||||
allocations[i].save(get_TrxName());
|
||||
|
||||
if(!getPaymentRule().equals(MInvoice.PAYMENTRULE_Cash))
|
||||
{
|
||||
//
|
||||
MAllocationHdr[] allocations = MAllocationHdr.getOfInvoice(getCtx(),
|
||||
getC_Invoice_ID(), get_TrxName());
|
||||
for (int i = 0; i < allocations.length; i++)
|
||||
{
|
||||
allocations[i].setDocAction(DocAction.ACTION_Reverse_Correct);
|
||||
allocations[i].reverseCorrectIt();
|
||||
allocations[i].save(get_TrxName());
|
||||
}
|
||||
}
|
||||
// Reverse/Delete Matching
|
||||
if (!isSOTrx())
|
||||
|
@ -2050,6 +2054,7 @@ public class MInvoice extends X_C_Invoice implements DocAction
|
|||
return false;
|
||||
}
|
||||
reversal.setReversal(true);
|
||||
|
||||
|
||||
// Reverse Line Qty
|
||||
MInvoiceLine[] rLines = reversal.getLines(false);
|
||||
|
@ -2109,6 +2114,8 @@ public class MInvoice extends X_C_Invoice implements DocAction
|
|||
setC_Payment_ID(0);
|
||||
setIsPaid(true);
|
||||
|
||||
if(!getPaymentRule().equals(MInvoice.PAYMENTRULE_Cash))
|
||||
{
|
||||
// Create Allocation
|
||||
MAllocationHdr alloc = new MAllocationHdr(getCtx(), false, getDateAcct(),
|
||||
getC_Currency_ID(),
|
||||
|
@ -2135,6 +2142,7 @@ public class MInvoice extends X_C_Invoice implements DocAction
|
|||
if (alloc.processIt(DocAction.ACTION_Complete))
|
||||
alloc.save();
|
||||
}
|
||||
}
|
||||
// After reverseCorrect
|
||||
m_processMsg = ModelValidationEngine.get().fireDocValidate(this,ModelValidator.TIMING_AFTER_REVERSECORRECT);
|
||||
if (m_processMsg != null)
|
||||
|
|
Loading…
Reference in New Issue