From 194c16bf0af62048d118ad28e55f5e1eb5d92ffa Mon Sep 17 00:00:00 2001 From: Mark Wells Date: Fri, 29 Jan 2016 17:12:07 -0800 Subject: [PATCH] fix internal handling of monthly tax exemptions, from #34223 --- FS/FS/TaxEngine/internal.pm | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/FS/FS/TaxEngine/internal.pm b/FS/FS/TaxEngine/internal.pm index 4ca1ea8b6..91b547ce0 100644 --- a/FS/FS/TaxEngine/internal.pm +++ b/FS/FS/TaxEngine/internal.pm @@ -243,7 +243,9 @@ sub taxline { exempt_monthly => 'Y', year => $year, month => $mon, + taxnum => $tax_object->taxnum, }); + $taxable_charged -= $addl; } # if they're using multiple months of exemption for a multi-month @@ -257,10 +259,23 @@ sub taxline { } } # if exempt_amount - $_->taxnum($tax_object->taxnum) foreach @new_exemptions; - # attach them to the line item - push @{ $cust_bill_pkg->cust_tax_exempt_pkg }, @new_exemptions; + foreach my $ex (@new_exemptions) { + + if ( $cust_bill_pkg->billpkgnum ) { + # the exempted item is already inserted (it should be, these days) so + # insert the exemption record now: + $ex->set('billpkgnum', $cust_bill_pkg->billpkgnum); + my $error = $ex->insert; + return "inserting tax exemption record: $error" if $error; + + } else { + # defer it until the item is inserted + push @{ $cust_bill_pkg->cust_tax_exempt_pkg }, $ex; + } + } + + # and remember we've used the exemption push @existing_exemptions, @new_exemptions; $taxable_charged = sprintf( "%.2f", $taxable_charged); -- 2.11.0