X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fcust_pay.cgi;h=f9f99de7e0d47f7f209fd3fcdf5d5c7bcb8146aa;hb=a6c5bd2d56ad177a8f79ac0aa5c88b389513dc82;hp=83e4e82ea7d420b10fb09ac662f140ad5eb02233;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e;p=freeside.git diff --git a/httemplate/edit/cust_pay.cgi b/httemplate/edit/cust_pay.cgi index 83e4e82ea..f9f99de7e 100755 --- a/httemplate/edit/cust_pay.cgi +++ b/httemplate/edit/cust_pay.cgi @@ -1,141 +1,176 @@ -% -% -%my $conf = new FS::Conf; -% -%my %payby = ( -% 'BILL' => 'Check', -% 'CASH' => 'Cash', -% 'WEST' => 'Western Union', -% 'MCRD' => 'Manual credit card', -%); -% -%my($link, $linknum, $paid, $payby, $payinfo, $_date); -%if ( $cgi->param('error') ) { -% $link = $cgi->param('link'); -% $linknum = $cgi->param('linknum'); -% $paid = $cgi->param('paid'); -% $payby = $cgi->param('payby'); -% $payinfo = $cgi->param('payinfo'); -% $_date = $cgi->param('_date') ? str2time($cgi->param('_date')) : time; -%} elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) { -% $link = $cgi->param('popup') ? 'popup' : 'custnum'; -% $linknum = $1; -% $paid = ''; -% $payby = $cgi->param('payby') || 'BILL'; -% $payinfo = ''; -% $_date = time; -%} elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) { -% $link = 'invnum'; -% $linknum = $1; -% $paid = ''; -% $payby = $cgi->param('payby') || 'BILL'; -% $payinfo = ""; -% $_date = time; -%} else { -% die "illegal query ". $cgi->keywords; -%} -% -%my $paybatch = "webui-$_date-$$-". rand() * 2**32; -% -%my $title = 'Post '. $payby{$payby}. ' payment'; -%$title .= " against Invoice #$linknum" if $link eq 'invnum'; -% -%if ( $link eq 'popup' ) { -% -% -<% include('/elements/header-popup.html', $title ) %> +% if ( $link eq 'popup' ) { + <& /elements/header-popup.html, $title &> % } else { - - -<% include("/elements/header.html", $title, '') %> -% } -% if ( $cgi->param('error') ) { - -Error: <% $cgi->param('error') %> -

+ <& /elements/header-cust_main.html, view=>'payment_history', custnum=>$custnum &> +

<% $title |h %>

% } +<& /elements/init_calendar.html &> - - - - +<& /elements/error.html &> -
+ -% -%my $money_char = $conf->config('money_char') || '$'; -%my $custnum; -%if ( $link eq 'invnum' ) { -% my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } ) -% or die "unknown invnum $linknum"; -% $custnum = $cust_bill->custnum; -%} elsif ( $link eq 'custnum' ) { -% $custnum = $linknum; -%} -% -% unless ( $link eq 'popup' ) { - -<% small_custview($custnum, $conf->config('countrydefault')) %> -% } + + + - +% my %date_args = ( +% 'name' => '_date', +% 'label' => emt('Date'), +% 'value' => $_date, +% 'format' => $date_format. ' %r', +% 'colspan' => 2, +% ); +% if ( $FS::CurrentUser::CurrentUser->access_right('Backdate payment') ) { + + <& /elements/tr-input-date-field.html, \%date_args &> + +% } else { + + <& /elements/tr-fixed-date.html, \%date_args &> + +% } -

-Payment -<% ntable("#cccccc", 2) %> - - - - - - - - + + -% if ( $payby eq 'BILL' ) { +% if ( $conf->exists('part_pkg-term_discounts') ) { + <& /elements/tr-select-discount_term.html, + 'custnum' => $custnum, + 'amount_id' => 'paid', + &> +% } +% if ( $payby eq 'BILL' ) { - + -% } - +% } +% elsif ( $payby eq 'CASH' and $conf->exists('require_cash_deposit_info') ) { + + + + + + + + + + + + + + + + + + + + +% } -% if ( $link eq 'custnum' ) { +% if ( $link eq 'custnum' || $link eq 'popup' ) { + + + - - % } elsif ( $link eq 'invnum' ) { - - - -% } + + + +% } -
Date - "> - -
Amount<% $money_char %> by <% $payby{$payby} %><% mt('Amount') |h %><% $money_char |h %> <% mt('by') |h %> <% mt(FS::payby->payname($payby)) |h %>
Check #<% mt('Check #') |h %>
<% mt('Bank') |h %>
<% mt('Check #') |h %>
<% mt('Teller #') |h %>
<% mt('Depositor') |h %>
<% mt('Account #') |h %>
<% mt('Auto-apply to invoices') |h %> + + Auto-apply
to invoices
Apply toInvoice #<% $linknum %> only<% mt('Apply to') |h %>Invoice #<% $linknum %> only
+% if ( $conf->exists('pkg-balances') ) { + <& /elements/tr-select-cust_pkg-balances.html, + 'custnum' => $custnum, + 'cgi' => $cgi + &> +% } else { + +% } - +
- -
- - + + + + +% if ( $link eq 'popup' ) { + + +% } else { + <& /elements/footer-cust_main.html &> +% } + +<%init> + +my $conf = new FS::Conf; + +my $money_char = $conf->config('money_char') || '$'; +my $date_format = $conf->config('date_format') || '%m/%d/%Y'; + +my($link, $linknum, $paid, $payby, $payinfo, $_date); +if ( $cgi->param('error') ) { + $link = $cgi->param('link'); + $linknum = $cgi->param('linknum'); + $paid = $cgi->param('paid'); + $payby = $cgi->param('payby'); + $payinfo = $cgi->param('payinfo'); + $_date = $cgi->param('_date') ? parse_datetime($cgi->param('_date')) : time; +} elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) { + $link = $cgi->param('popup') ? 'popup' : 'custnum'; + $linknum = $1; + $paid = ''; + $payby = $cgi->param('payby') || 'BILL'; + $payinfo = ''; + $_date = time; +} elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) { + $link = 'invnum'; + $linknum = $1; + $paid = ''; + $payby = $cgi->param('payby') || 'BILL'; + $payinfo = ""; + $_date = time; +} else { + die "illegal query ". $cgi->keywords; +} + +my @rights = ('Post payment'); +push @rights, 'Post check payment' if $payby eq 'BILL'; +push @rights, 'Post cash payment' if $payby eq 'CASH'; + +die "access denied" + unless $FS::CurrentUser::CurrentUser->access_right(\@rights); + +my $paybatch = "webui-$_date-$$-". rand() * 2**32; + +my $title = mt('Post '. FS::payby->payname($payby). ' payment'); +$title .= mt(" against Invoice #[_1]",$linknum) if $link eq 'invnum'; + +my $custnum; +if ( $link eq 'invnum' ) { + my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } ) + or die "unknown invnum $linknum"; + $custnum = $cust_bill->custnum; +} elsif ( $link eq 'custnum' || $link eq 'popup' ) { + $custnum = $linknum; +} + +