X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fcust_pay.cgi;h=5d74365e7223bc418034230cfe0a3afe15501edb;hb=e80770898cc86365b335845dd1a02b4d82bd7e40;hp=83e4e82ea7d420b10fb09ac662f140ad5eb02233;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e;p=freeside.git diff --git a/httemplate/edit/cust_pay.cgi b/httemplate/edit/cust_pay.cgi index 83e4e82ea..5d74365e7 100755 --- a/httemplate/edit/cust_pay.cgi +++ b/httemplate/edit/cust_pay.cgi @@ -1,141 +1,182 @@ -% -% -%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, '') %> + <& /elements/header.html, $title, '' &> % } -% if ( $cgi->param('error') ) { -Error: <% $cgi->param('error') %> -

-% } +<& /elements/init_calendar.html &> +<& /elements/error.html &> - - - - +% unless ( $link eq 'popup' ) { + <% small_custview($custnum, $conf->config('countrydefault')) %> +% } -
+ -% -%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')) %> -% } +
+<% mt('Payment') |h %> +<% ntable("#cccccc", 2) %> - +% 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) %> - - Date - - "> - - - - - Amount - <% $money_char %> - by <% $payby{$payby} %> + <% mt('Amount') |h %> + <% $money_char |h %> <% mt('by') |h %> <% mt(FS::payby->payname($payby)) |h %> -% 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' ) { - Check # + <% mt('Check #') |h %> -% } - +% } +% elsif ( $payby eq 'CASH' and $conf->exists('require_cash_deposit_info') ) { + + <% mt('Bank') |h %> + + + + <% mt('Check #') |h %> + + + + <% mt('Teller #') |h %> + + + + <% mt('Depositor') |h %> + + + + <% mt('Account #') |h %> + + +% } -% if ( $link eq 'custnum' ) { +% if ( $link eq 'custnum' || $link eq 'popup' ) { + + <% mt('Auto-apply to invoices') |h %> + + + - Auto-apply
to invoices - % } elsif ( $link eq 'invnum' ) { - Apply to + <% 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.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; +} + +