diff options
author | jeff <jeff> | 2007-12-04 18:20:58 +0000 |
---|---|---|
committer | jeff <jeff> | 2007-12-04 18:20:58 +0000 |
commit | e8a09e945986a32f9b7d0a5d546142ada91654ca (patch) | |
tree | e0439507bc510ae41ef9b02c0b34bef3a9313863 /httemplate/edit | |
parent | b8a41c45daf3e4cfa21200f5d9e59e38bd41293c (diff) |
change credit reasons from freetext to new reason/reason type system (#2777)
Diffstat (limited to 'httemplate/edit')
-rwxr-xr-x | httemplate/edit/cust_credit.cgi | 7 | ||||
-rwxr-xr-x | httemplate/edit/process/cust_credit.cgi | 38 | ||||
-rw-r--r-- | httemplate/edit/reason.html | 5 | ||||
-rw-r--r-- | httemplate/edit/reason_type.html | 6 |
4 files changed, 35 insertions, 21 deletions
diff --git a/httemplate/edit/cust_credit.cgi b/httemplate/edit/cust_credit.cgi index 13d062c74..b6924f4d9 100755 --- a/httemplate/edit/cust_credit.cgi +++ b/httemplate/edit/cust_credit.cgi @@ -5,7 +5,7 @@ <BR><BR> % } -<FORM ACTION="<% $p1 %>process/cust_credit.cgi" METHOD=POST> +<FORM NAME="credit_popup" ACTION="<% $p1 %>process/cust_credit.cgi" METHOD=POST> <INPUT TYPE="hidden" NAME="crednum" VALUE=""> <INPUT TYPE="hidden" NAME="custnum" VALUE="<% $custnum %>"> <INPUT TYPE="hidden" NAME="paybatch" VALUE=""> @@ -30,10 +30,7 @@ Credit %#print qq! <INPUT TYPE="checkbox" NAME="refund" VALUE="$refund">Also post refund!; % - <TR> - <TD ALIGN="right">Reason</TD> - <TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="<% $reason %>" SIZE=32></TD> - </TR> +<% include('/elements/tr-select-reason.html', 'reasonnum', 'R', '', '', '', 'document.credit_popup.submit',) %> <TR> <TD ALIGN="right">Auto-apply<BR>to invoices</TD> diff --git a/httemplate/edit/process/cust_credit.cgi b/httemplate/edit/process/cust_credit.cgi index 19faca47a..9dcad7f68 100755 --- a/httemplate/edit/process/cust_credit.cgi +++ b/httemplate/edit/process/cust_credit.cgi @@ -3,16 +3,39 @@ %$cgi->param('custnum') =~ /^(\d*)$/ or die "Illegal custnum!"; %my $custnum = $1; % -%my $new = new FS::cust_credit ( { -% map { -% $_, scalar($cgi->param($_)); -% } fields('cust_credit') -%} ); -% -%my $error = $new->insert; +%$cgi->param('reasonnum') =~ /^(-?\d+)$/ or die "Illegal reasonnum"; +%my $reasonnum = $1; +% +%my $oldAutoCommit = $FS::UID::AutoCommit; +%local $FS::UID::AutoCommit = 0; +%my $dbh = dbh; +% +%my $error = ''; +%if ($reasonnum == -1) { +% +% $error = 'Enter a new reason (or select an existing one)' +% unless $cgi->param('newreasonnum') !~ /^\s*$/; +% my $reason = new FS::reason({ 'reason_type' => $cgi->param('newreasonnumT'), +% 'reason' => $cgi->param('newreasonnum'), +% }); +% $error ||= $reason->insert; +% $cgi->param('reasonnum', $reason->reasonnum) +% unless $error; +%} +% +%unless ($error) { +% my $new = new FS::cust_credit ( { +% map { +% $_, scalar($cgi->param($_)); +% } fields('cust_credit') +% } ); +% $error = $new->insert; +%} % %if ( $error ) { +% $cgi->param('reasonnum', $reasonnum); % $cgi->param('error', $error); +% $dbh->rollback if $oldAutoCommit; % % <% $cgi->redirect(popurl(2). "cust_credit.cgi?". $cgi->query_string ) %> @@ -27,6 +50,7 @@ % } % #print $cgi->redirect(popurl(3). "view/cust_main.cgi?$custnum"); % +% $dbh->commit or die $dbh->errstr if $oldAutoCommit; % <% header('Credit sucessful') %> <SCRIPT TYPE="text/javascript"> diff --git a/httemplate/edit/reason.html b/httemplate/edit/reason.html index c652a0820..512013ace 100644 --- a/httemplate/edit/reason.html +++ b/httemplate/edit/reason.html @@ -2,10 +2,7 @@ % $cgi->param('class') =~ /^(\w)$/ or die "illegal class"; % my $class=$1; % -% my %classmap = ('C' => 'cancel', -% 'S' => 'suspend', -% ); -% my $classname = $classmap{$class}; +% my $classname = $FS::reason_type::class_name{$class}; % % my (@types) = qsearch( 'reason_type', { 'class' => $class } ); % diff --git a/httemplate/edit/reason_type.html b/httemplate/edit/reason_type.html index 970529e35..056544e5d 100644 --- a/httemplate/edit/reason_type.html +++ b/httemplate/edit/reason_type.html @@ -2,11 +2,7 @@ %$cgi->param('class') =~ /^(\w)$/; %my $class = $1; % -%my %classmap = ( 'C' => 'Cancel', -% 'S' => 'Suspend', -% ); -% -%my $classname = $classmap{$class}; +%my $classname = $FS::reason_type::class_name{$class}; % <% include( 'elements/edit.html', 'name' => $classname . ' Reason Type', |