diff options
| author | jeff <jeff> | 2008-09-30 21:05:14 +0000 | 
|---|---|---|
| committer | jeff <jeff> | 2008-09-30 21:05:14 +0000 | 
| commit | 3a88582ed5708b0b0dd6c50c7227de8970b1344b (patch) | |
| tree | f1b82445c4118550ec352c60cc625444cc68263f | |
| parent | fdab21bcd110c98808614f704d29638ecc2fd2aa (diff) | |
simple reporting for new tax system
| -rw-r--r-- | httemplate/elements/menu.html | 4 | ||||
| -rw-r--r-- | httemplate/search/cust_bill_pkg.cgi | 7 | ||||
| -rwxr-xr-x | httemplate/search/report_newtax.cgi | 158 | ||||
| -rwxr-xr-x | httemplate/search/report_newtax.html | 23 | 
4 files changed, 191 insertions, 1 deletions
diff --git a/httemplate/elements/menu.html b/httemplate/elements/menu.html index 66e8ab6c5..e5c0246dc 100644 --- a/httemplate/elements/menu.html +++ b/httemplate/elements/menu.html @@ -195,7 +195,9 @@ $report_financial{'Payment Batch Report'} = [ $fsurl.'search/pay_batch.html', 'P    if $conf->exists('batch-enable');  $report_financial{'A/R Aging'} = [ $fsurl.'search/report_receivables.html', 'Accounts Receivable Aging report' ];  $report_financial{'Prepaid Income'} = [ $fsurl.'search/report_prepaid_income.html', 'Prepaid income (unearned revenue)  report' ]; -$report_financial{'Sales Tax Liability'} = [ $fsurl.'search/report_tax.html', 'Sales tax liability report' ]; +$report_financial{'Sales Tax Liability'} = [ $fsurl.'search/report_tax.html', 'Sales tax liability report (old taxclass system)' ]; +$report_financial{'Tax Liability'} = [ $fsurl.'search/report_newtax.html', 'Tax liability report (new tax products system)' ] +  if $conf->exists('enable_taxproducts');  ;  tie my %report_menu, 'Tie::IxHash'; diff --git a/httemplate/search/cust_bill_pkg.cgi b/httemplate/search/cust_bill_pkg.cgi index 74efe4f7e..61d9a7505 100644 --- a/httemplate/search/cust_bill_pkg.cgi +++ b/httemplate/search/cust_bill_pkg.cgi @@ -138,6 +138,13 @@ if ( $cgi->param('out') ) {  } +if ($cgi->param('itemdesc')) { +  if ($cgi->param('itemdesc') eq 'Tax') { +    push @where, "(itemdesc='Tax' OR itemdesc is null)"; +  }else{ +    push @where, 'itemdesc='. dbh->quote($cgi->param('itemdesc')); +  } +}  push @where, 'pkgnum != 0' if $cgi->param('nottax');  push @where, 'pkgnum  = 0' if $cgi->param('istax'); diff --git a/httemplate/search/report_newtax.cgi b/httemplate/search/report_newtax.cgi new file mode 100755 index 000000000..586fddd25 --- /dev/null +++ b/httemplate/search/report_newtax.cgi @@ -0,0 +1,158 @@ +<% include("/elements/header.html", "$agentname Tax Report - ". +              ( $beginning +                  ? time2str('%h %o %Y ', $beginning ) +                  : '' +              ). +              'through '. +              ( $ending == 4294967295 +                  ? 'now' +                  : time2str('%h %o %Y', $ending ) +              ) +          ) +%> + +<% include('/elements/table-grid.html') %> + +  <TR> +    <TH CLASS="grid" BGCOLOR="#cccccc"></TH> +    <TH CLASS="grid" BGCOLOR="#cccccc">Tax collected</TH> +  </TR> +% my $bgcolor1 = '#eeeeee'; +% my $bgcolor2 = '#ffffff'; +% my $bgcolor; +% +% foreach my $tax ( @taxes ) { +% +%   if ( $bgcolor eq $bgcolor1 ) { +%     $bgcolor = $bgcolor2; +%   } else { +%     $bgcolor = $bgcolor1; +%   } +% +%   my $link = ''; +%   if ( $tax->{'label'} ne 'Total' ) { +%     $link = ';'. $tax->{'url_param'}; +%   } +% + +    <TR> +      <TD CLASS="grid" BGCOLOR="<% $bgcolor %>"><% $tax->{'label'} %></TD> +      <TD CLASS="grid" BGCOLOR="<% $bgcolor %>" ALIGN="right"> +        <A HREF="<% $baselink. $link %>;istax=1"><% $money_char %><% sprintf('%.2f', $tax->{'tax'} ) %></A> +      </TD> +    </TR> +% }  + +</TABLE> + +</BODY> +</HTML> +<%init> + +die "access denied" +  unless $FS::CurrentUser::CurrentUser->access_right('Financial reports'); + +my $conf = new FS::Conf; +my $money_char = $conf->config('money_char') || '$'; + +my($beginning, $ending) = FS::UI::Web::parse_beginning_ending($cgi); + +my $join_cust = " +    JOIN cust_bill USING ( invnum )  +    LEFT JOIN cust_main USING ( custnum ) +"; +my $from_join_cust = " +    FROM cust_bill_pkg +    $join_cust +";  + +my $where = "WHERE _date >= $beginning AND _date <= $ending "; + +my $agentname = ''; +if ( $cgi->param('agentnum') =~ /^(\d+)$/ ) { +  my $agent = qsearchs('agent', { 'agentnum' => $1 } ); +  die "agent not found" unless $agent; +  $agentname = $agent->agent; +  $where .= ' AND cust_main.agentnum = '. $agent->agentnum; +} + +my $tax = 0; +my %taxes = (); +foreach my $t (qsearch({ table     => 'cust_bill_pkg', +                         hashref   => { pkgpart => 0 }, +                         addl_from => $join_cust, +                         extra_sql => $where, +                      }) +              ) +{ +  #warn $t->itemdesc. "\n"; + +  my $label = $t->itemdesc; +  $label ||= 'Tax'; +  $taxes{$label}->{'label'} = $label; +  $taxes{$label}->{'url_param'} = "itemdesc=$label"; + +  # calculate total for this tax  +  # calculate customer-exemption for this tax +  # calculate package-exemption for this tax +  # calculate monthly exemption (texas tax) for this tax +  # count up all the cust_tax_exempt_pkg records associated with +  # the actual line items. +} + + +foreach my $t (qsearch({ table     => 'cust_bill_pkg', +                         select    => 'DISTINCT itemdesc', +                         hashref   => { pkgpart => 0 }, +                         addl_from => $join_cust, +                         extra_sql => $where, +                      }) +              ) +{ + +  my $label = $t->itemdesc; +  $label ||= 'Tax'; +  my @taxparam = ( 'itemdesc' ); +  my $taxwhere = "$from_join_cust $where AND payby != 'COMP' ". +    "AND itemdesc = ?" ; + +  my $sql = "SELECT SUM(cust_bill_pkg.setup+cust_bill_pkg.recur) ". +            " $taxwhere AND pkgnum = 0"; + +  my $x = scalar_sql($t, \@taxparam, $sql ); +  $tax += $x; +  $taxes{$label}->{'tax'} += $x; + +} + +#ordering +my @taxes = +  map $taxes{$_}, +  sort { ($b cmp $a) } +  keys %taxes; + +push @taxes, { +  'label'          => 'Total', +  'url_param'      => '', +  'tax'            => $tax, +}; + +#--  + +#false laziness w/FS::Report::Table::Monthly (sub should probably be moved up +#to FS::Report or FS::Record or who the fuck knows where) +sub scalar_sql { +  my( $r, $param, $sql ) = @_; +  #warn "$sql\n"; +  my $sth = dbh->prepare($sql) or die dbh->errstr; +  $sth->execute( map $r->$_(), @$param ) +    or die "Unexpected error executing statement $sql: ". $sth->errstr; +  $sth->fetchrow_arrayref->[0] || 0; +} + +my $dateagentlink = "begin=$beginning;end=$ending"; +$dateagentlink .= ';agentnum='. $cgi->param('agentnum') +  if length($agentname); +my $baselink   = $p. "search/cust_bill_pkg.cgi?$dateagentlink"; + +</%init> diff --git a/httemplate/search/report_newtax.html b/httemplate/search/report_newtax.html new file mode 100755 index 000000000..52f920289 --- /dev/null +++ b/httemplate/search/report_newtax.html @@ -0,0 +1,23 @@ +<% include('/elements/header.html', 'Tax Report' ) %> + +<FORM ACTION="report_newtax.cgi" METHOD="GET"> + +<TABLE> + + <% include( '/elements/tr-select-agent.html' ) %> + + <% include( '/elements/tr-input-beginning_ending.html' ) %> + +</TABLE> + +<BR><INPUT TYPE="submit" VALUE="Get Report"> + +</FORM> + +<% include('/elements/footer.html') %> +<%init> + +die "access denied" +  unless $FS::CurrentUser::CurrentUser->access_right('Financial reports'); + +</%init>  | 
