X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcust_bill_pkg_tax_location.pm;h=44dd6e3c4c138c66518840a6485dd08eed19f2db;hb=b79a8cb932946c849328a3c117c35821d9d21e66;hp=db652370b061e66115e09c39e3f42a8ebc112193;hpb=e26229306dd63c4989352f082425267bec217100;p=freeside.git diff --git a/FS/FS/cust_bill_pkg_tax_location.pm b/FS/FS/cust_bill_pkg_tax_location.pm index db652370b..44dd6e3c4 100644 --- a/FS/FS/cust_bill_pkg_tax_location.pm +++ b/FS/FS/cust_bill_pkg_tax_location.pm @@ -6,6 +6,9 @@ use FS::Record qw( qsearch qsearchs ); use FS::cust_bill_pkg; use FS::cust_pkg; use FS::cust_location; +use FS::cust_bill_pay_pkg; +use FS::cust_credit_bill_pkg; +use FS::cust_main_county; =head1 NAME @@ -122,10 +125,96 @@ sub check { $self->SUPER::check; } +=item cust_bill_pkg + +Returns the associated cust_bill_pkg object + +=cut + +sub cust_bill_pkg { + my $self = shift; + qsearchs( 'cust_bill_pkg', { 'billpkgnum' => $self->billpkgnum } ); +} + +=item cust_location + +Returns the associated cust_location object + +=cut + +sub cust_location { + my $self = shift; + qsearchs( 'cust_location', { 'locationnum' => $self->locationnum } ); +} + +=item desc + +Returns a description for this tax line item constituent. Currently this +is the desc of the associated line item followed by the state/county/city +for the location in parentheses. + +=cut + +sub desc { + my $self = shift; + my $cust_location = $self->cust_location; + my $location = join('/', grep { $_ } # leave in? + map { $cust_location->$_ } + qw( state county city ) # country? + ); + my $cust_bill_pkg_desc = $self->billpkgnum + ? $self->cust_bill_pkg->desc + : $self->cust_bill_pkg_desc; + "$cust_bill_pkg_desc ($location)"; +} + +=item owed + +Returns the amount owed (still outstanding) on this tax line item which is +the amount of this record minus all payment applications and credit +applications. + +=cut + +sub owed { + my $self = shift; + my $balance = $self->amount; + $balance -= $_->amount foreach ( $self->cust_bill_pay_pkg('setup') ); + $balance -= $_->amount foreach ( $self->cust_credit_bill_pkg('setup') ); + $balance = sprintf( '%.2f', $balance ); + $balance =~ s/^\-0\.00$/0.00/; #yay ieee fp + $balance; +} + +sub cust_bill_pay_pkg { + my $self = shift; + qsearch( 'cust_bill_pay_pkg', + { map { $_ => $self->$_ } qw( billpkgtaxlocationnum billpkgnum ) } + ); +} + +sub cust_credit_bill_pkg { + my $self = shift; + qsearch( 'cust_credit_bill_pkg', + { map { $_ => $self->$_ } qw( billpkgtaxlocationnum billpkgnum ) } + ); +} + +sub cust_main_county { + my $self = shift; + my $result; + if ( $self->taxtype eq 'FS::cust_main_county' ) { + $result = qsearchs( 'cust_main_county', { 'taxnum' => $self->taxnum } ); + } +} + =back =head1 BUGS +The presense of FS::cust_main_county::delete makes the cust_main_county method +unreliable + =head1 SEE ALSO L, schema.html from the base documentation.