summaryrefslogtreecommitdiff
path: root/FS/FS
diff options
context:
space:
mode:
authorMark Wells <mark@freeside.biz>2015-03-06 15:00:00 -0800
committerMark Wells <mark@freeside.biz>2015-03-06 15:00:00 -0800
commit53ed077b4901be22b3ca5405a093364b6f6b6407 (patch)
tree0970dcddb54e6cec099c6a4ba5e38fa0a96fd7bc /FS/FS
parent35c18f29bc29dedfe2fa4ef037390d90b17f87ba (diff)
estimate tax on quotations, #32489
Diffstat (limited to 'FS/FS')
-rw-r--r--FS/FS/Schema.pm7
-rw-r--r--FS/FS/cust_main_county.pm30
-rw-r--r--FS/FS/quotation_pkg.pm14
-rw-r--r--FS/FS/quotation_pkg_tax.pm6
4 files changed, 24 insertions, 33 deletions
diff --git a/FS/FS/Schema.pm b/FS/FS/Schema.pm
index cd4f01d..6a156a5 100644
--- a/FS/FS/Schema.pm
+++ b/FS/FS/Schema.pm
@@ -1980,7 +1980,12 @@ sub tables_hashref {
'primary_key' => 'quotationtaxnum',,
'unique' => [],
'index' => [ [ 'quotationpkgnum' ] ],
- },
+ 'foreign_keys' => [
+ { columns => [ 'quotationpkgnum' ],
+ table => 'quotation_pkg',
+ },
+ ],
+},
'cust_location' => { #'location' now that its prospects too, but...
'columns' => [
diff --git a/FS/FS/cust_main_county.pm b/FS/FS/cust_main_county.pm
index 075ac32..652ff33 100644
--- a/FS/FS/cust_main_county.pm
+++ b/FS/FS/cust_main_county.pm
@@ -277,7 +277,7 @@ sub taxline {
my $cust_bill = $taxables->[0]->cust_bill;
my $custnum = $cust_bill ? $cust_bill->custnum : $opt{'custnum'};
my $invoice_time = $cust_bill ? $cust_bill->_date : $opt{'invoice_time'};
- my $cust_main = FS::cust_main->by_key($custnum) if $custnum > 0;
+ my $cust_main = FS::cust_main->by_key($custnum) if $custnum;
# (to avoid complications with estimated tax on quotations, assume it's
# taxable if there is no customer)
#if (!$cust_main) {
@@ -285,18 +285,21 @@ sub taxline {
#}
# set a flag if the customer is tax-exempt
- my $exempt_cust;
+ my ($exempt_cust, $exempt_cust_taxname);
my $conf = FS::Conf->new;
- if ( $conf->exists('cust_class-tax_exempt') ) {
- my $cust_class = $cust_main->cust_class;
- $exempt_cust = $cust_class->tax if $cust_class;
- } else {
- $exempt_cust = $cust_main->tax;
- }
+ if ( $cust_main ) {
+ if ( $conf->exists('cust_class-tax_exempt') ) {
+ my $cust_class = $cust_main->cust_class;
+ $exempt_cust = $cust_class->tax if $cust_class;
+ } else {
+ $exempt_cust = $cust_main->tax;
+ }
- # set a flag if the customer is exempt from this tax here
- my $exempt_cust_taxname = $cust_main->tax_exemption($self->taxname)
- if $self->taxname;
+ # set a flag if the customer is exempt from this tax here
+ if ( $self->taxname ) {
+ $exempt_cust_taxname = $cust_main->tax_exemption($self->taxname);
+ }
+ }
# Gather any exemptions that are already attached to these cust_bill_pkgs
# so that we can deduct them from the customer's monthly limit.
@@ -320,9 +323,8 @@ sub taxline {
my $part_pkg = $cust_bill_pkg->part_pkg;
my $part_fee = $cust_bill_pkg->part_fee;
- my $locationnum = $cust_pkg
- ? $cust_pkg->locationnum
- : $cust_main->bill_locationnum;
+ my $locationnum = $cust_bill_pkg->tax_locationnum
+ || $cust_main->ship_locationnum;
my @new_exemptions;
my $taxable_charged = $cust_bill_pkg->setup + $cust_bill_pkg->recur
diff --git a/FS/FS/quotation_pkg.pm b/FS/FS/quotation_pkg.pm
index c579e35..1c4766e 100644
--- a/FS/FS/quotation_pkg.pm
+++ b/FS/FS/quotation_pkg.pm
@@ -442,7 +442,7 @@ Returns the customer (L<FS::cust_main> object).
sub cust_main {
my $self = shift;
- my $quotation = FS::quotation->by_key($self->quotationnum) or return '';
+ my $quotation = $self->quotation or return '';
$quotation->cust_main;
}
@@ -454,20 +454,10 @@ Returns the prospect (L<FS::prospect_main> object).
sub prospect_main {
my $self = shift;
- my $quotation = FS::quotation->by_key($self->quotationnum) or return '';
+ my $quotation = $self->quotation or return '';
$quotation->prospect_main;
}
-sub quotation_pkg_tax {
- my $self = shift;
- qsearch('quotation_pkg_tax', { quotationpkgnum => $self->quotationpkgnum });
-}
-
-sub cust_location {
- my $self = shift;
- $self->locationnum ? qsearchs('cust_location', { locationnum => $self->locationnum }) : '';
-}
-
=back
=head1 BUGS
diff --git a/FS/FS/quotation_pkg_tax.pm b/FS/FS/quotation_pkg_tax.pm
index 3d1dceb..f459ed2 100644
--- a/FS/FS/quotation_pkg_tax.pm
+++ b/FS/FS/quotation_pkg_tax.pm
@@ -104,12 +104,6 @@ sub check {
$self->SUPER::check;
}
-#stub for 3.x
-sub quotation_pkg {
- my $self = shift;
- FS::quotation_pkg->by_key($self->quotationpkgnum);
-}
-
=back
=head1 SEE ALSO