X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fview%2Fcust_bill.cgi;h=e35d7f1cfb343d75b54c5c1b26947bf9b0cfc250;hb=998b32d356338772484814a477d9efb159206b8d;hp=3772e8dd09b1f6ed4e8c2f62b843ee72aeedec37;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e;p=freeside.git
diff --git a/httemplate/view/cust_bill.cgi b/httemplate/view/cust_bill.cgi
index 3772e8dd0..e35d7f1cf 100755
--- a/httemplate/view/cust_bill.cgi
+++ b/httemplate/view/cust_bill.cgi
@@ -1,155 +1,250 @@
-%
-%
-%#untaint invnum
-%my($query) = $cgi->keywords;
-%$query =~ /^((.+)-)?(\d+)$/;
-%my $templatename = $2;
-%my $invnum = $3;
-%
-%my $conf = new FS::Conf;
-%
-%my @payby = grep /\w/, $conf->config('payby');
-%#@payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH WEST COMP ))
-%@payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH COMP ))
-% unless @payby;
-%my %payby = map { $_=>1 } @payby;
-%
-%my $cust_bill = qsearchs('cust_bill',{'invnum'=>$invnum});
-%die "Invoice #$invnum not found!" unless $cust_bill;
-%my $custnum = $cust_bill->getfield('custnum');
-%
-%#my $printed = $cust_bill->printed;
-%
-%my $link = $templatename ? "$templatename-$invnum" : $invnum;
-%
-%
-
-<% include("/elements/header.html",'Invoice View', menubar(
- "Main Menu" => $p,
- "View this customer (#$custnum)" => "${p}view/cust_main.cgi?$custnum",
-)) %>
+<& /elements/header-cust_main.html, view=>'payment_history', custnum=>$custnum &>
+
+
Invoice #<% $invnum %>
+
+% if ( !$cust_bill->closed ) { # otherwise allow no changes
+% my $can_delete = $conf->exists('deleteinvoices')
+% && $curuser->access_right('Delete invoices');
+% my $can_void = $curuser->access_right('Void invoices');
+% if ( $can_void ) {
+ <& /elements/popup_link.html,
+ 'label' => emt('Void this invoice'),
+ 'actionlabel' => emt('Void this invoice'),
+ 'action' => $p.'misc/void-cust_bill.html?invnum='.$invnum,
+ &>
+% }
+% if ( $can_void and $can_delete ) {
+ |
+% }
+% if ( $can_delete ) {
+ \
+ <% emt('Delete this invoice') |h %>
+% }
+% if ( $can_void or $can_delete ) {
+
+% }
+% }
+
% if ( $cust_bill->owed > 0
-% && ( $payby{'BILL'} || $payby{'CASH'} || $payby{'WEST'} || $payby{'MCRD'} )
-% )
-% {
+% && $curuser->access_right(['Post payment', 'Post check payment', 'Post cash payment'])
+% && ! $conf->exists('pkg-balances')
+% )
+% {
% my $s = 0;
-%
-
-
- Post
-% if ( $payby{'BILL'} ) {
-
-
- <% $s++ ? ' | ' : '' %>
- check
-% }
-% if ( $payby{'CASH'} ) {
-
-
- <% $s++ ? ' | ' : '' %>
- cash
-% }
-% if ( $payby{'WEST'} ) {
-
-
- <% $s++ ? ' | ' : '' %>
- Western Union
-% }
-% if ( $payby{'MCRD'} ) {
-
-
- <% $s++ ? ' | ' : '' %>
- manual credit card
-% }
-
-
- payment against this invoice
-% }
-
-Re-print this invoice
-% if ( grep { $_ ne 'POST' } $cust_bill->cust_main->invoicing_list ) {
+ <% mt('Post') |h %>
+
+% if ( $curuser->access_right(['Post payment', 'Post check payment']) ) {
+ <% $s++ ? ' | ' : '' %>
+ <% mt('check') |h %>
+% }
+
+% if ( $curuser->access_right(['Post payment', 'Post cash payment']) ) {
+ <% $s++ ? ' | ' : '' %>
+ <% mt('cash') |h %>
+% }
+
+%# % if ( $payby{'WEST'} && $curuser->access_right(['Post payment']) ) {
+%# <% $s++ ? ' | ' : '' %>
+%# <% mt('Western Union') |h %>
+%# % }
+%#
+%# % if ( $payby{'MCRD'} && $curuser->access_right(['Post payment']) ) {
+%# <% $s++ ? ' | ' : '' %>
+%# <% mt('manual credit card') |h %>
+%# % }
+%#
+%# % if ( $payby{'MCHK'} && $curuser->access_right(['Post payment']) ) {
+%# <% $s++ ? ' | ' : '' %>
+%# <% mt('manual electronic check') |h %>
+%# % }
+
+ <% mt('payment against this invoice') |h %>
- | Re-email
- this invoice
% }
-% if ( $conf->exists('hylafax') && length($cust_bill->cust_main->fax) ) {
- | Re-fax
- this invoice
+% if ( $conf->exists('cust_bill-enable_promised_date') ) {
+% my $onclick = include('/elements/popup_link_onclick.html',
+% 'action' => $p.'misc/cust_bill-promised_date.html?'.$invnum,
+% 'actionlabel' => emt('Set promised payment date'),
+% 'width' => 320,
+% 'height' => 240,
+% );
+% $onclick = '';
+% if ( $cust_bill->promised_date ) {
+% my $date_format = $conf->config('date_format') || '%b %o, %Y';
+ <% emt('Payment promised by [_1]',
+ time2str($date_format, $cust_bill->promised_date) ) %>
+ ( <% $onclick %><% mt('change') |h %> )
+
+% }
+% elsif ( $cust_bill->owed > 0 ) {
+ <% $onclick %><% mt('Set promised payment date' ) |h %>
+
+% }
+% }
+
+% if ( $curuser->access_right('Resend invoices') ) {
+ <% mt('Print this invoice') |h %>
+% }
+
+% if ( $conf->exists('support-key')
+% && $curuser->access_right('Print and mail invoices')
+% )
+% {
+ | <& /elements/popup_link.html,
+ 'action' => $p."misc/post_fsinc-invoice.cgi?$link",
+ 'label' => 'Print and mail this invoice online',
+ 'actionlabel' => 'Invoice printing and mailing',
+ &>
+% }
+
+% if ( $curuser->access_right('Resend invoices') ) {
+
+% if ( grep { $_ ne 'POST' } $cust_bill->cust_main->invoicing_list ) {
+ | <% mt('Re-email this invoice') |h %>
+% }
+
+% if ( $conf->exists('hylafax') && length($cust_bill->cust_main->fax) ) {
+ | <% mt('Re-fax this invoice') |h %>
+% }
+
+% }
+
+% if ( $curuser->access_right('Resend invoices')
+% || $curuser->access_right('Print and mail invoices') ) {
+
% }
+% my $br = 0;
+% if ( $conf->exists('invoice_latex') ) {
+
+ <% mt('View typeset invoice PDF') |h %>
+
+% $br++;
+% }
+
+% my @modes = grep {! $_->disabled}
+% $cust_bill->cust_main->agent->invoice_modes;
+% if ( @modes || $include_statement_template ) {
+<% $br ? '|' : '' %>
+<% emt('View as:') %>
+
+% }
+
+% if ( $cust_bill->num_cust_event ) {
+<% $br ? '|' : '' %>
+<% mt('View invoice events') |h %>
+% $br++;
+% }
+% if ( $cust_bill->tax > 0 ) { # inefficient
+<% $br ? '|' : '' %>
+<& /elements/popup_link.html,
+ 'action' => 'cust_bill_tax_matrix.html?' . $cust_bill->invnum,
+ 'label' => mt('View tax details'),
+ 'actionlabel' => mt('Tax details'),
+ 'width' => 1050,
+ 'height' => 500,
+ 'title' => emt('Tax details'),
+&>
+% $br++;
+% }
-% if ( $conf->exists('invoice_latex') ) {
- View typeset invoice
-
-% }
-% #false laziness with search/cust_bill_event.cgi
-% unless ( $templatename ) {
-
-
- <% table() %>
-
- Event |
- Date |
- Status |
-
-% foreach my $cust_bill_event (
-% sort { $a->_date <=> $b->_date } $cust_bill->cust_bill_event
-% ) {
-%
-% my $status = $cust_bill_event->status;
-% $status .= ': '. encode_entities($cust_bill_event->statustext)
-% if $cust_bill_event->statustext;
-% my $part_bill_event = $cust_bill_event->part_bill_event;
-%
-
-
- <% $part_bill_event->event %>
-% if ( $part_bill_event->templatename ) {
-% my $alt_templatename = $part_bill_event->templatename;
-% my $alt_link = "$alt_templatename-$invnum";
-%
-
- ( view
- | view
- typeset
- | re-print
-% if ( grep { $_ ne 'POST' }
-% $cust_bill->cust_main->invoicing_list ) {
-
- | re-email
-% }
-% if ( $conf->exists('hylafax')
-% && length($cust_bill->cust_main->fax) ) {
-
- | re-fax
-% }
-
-
- )
-% }
-
-
- |
- <% time2str("%a %b %e %T %Y", $cust_bill_event->_date) %> |
- <% $status %> |
-
-% }
-
-
-
-
-% }
-% if ( $conf->exists('invoice_html') ) {
-
- <% join('', $cust_bill->print_html('', $templatename) ) %>
+% if ( $conf->exists('invoice_html') && ! $cgi->param('plaintext') ) {
+ <% join('', $cust_bill->print_html(\%opt) ) %>
% } else {
-
- <% join('', $cust_bill->print_text('', $templatename) ) %>
+ <% join('', $cust_bill->print_text(\%opt) ) |h %>
% }
-
-