blob: 0b93c64e5e4a79d8d2c137bbe3989e0d018f949f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
%if ( $error ) {
% $cgi->param('error', $error);
% $dbh->rollback if $oldAutoCommit;
%
<% $cgi->redirect(popurl(2). "cust_credit.cgi?". $cgi->query_string ) %>
%
%} else {
%
% if ( $cgi->param('apply') eq 'yes' ) {
% my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum })
% or die "unknown custnum $custnum";
% $cust_main->apply_credits;
% }
%
% $dbh->commit or die $dbh->errstr if $oldAutoCommit;
%
<& /elements/header-popup.html, emt('Credit successful') &>
<SCRIPT TYPE="text/javascript">
topreload();
</SCRIPT>
</BODY></HTML>
% }
<%init>
die "access denied"
unless $FS::CurrentUser::CurrentUser->access_right('Post credit');
$cgi->param('custnum') =~ /^(\d+)$/ or die "Illegal custnum!";
my $custnum = $1;
$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 ($reasonnum, $error) = $m->comp('/misc/process/elements/reason');
if (!$reasonnum) {
$error ||= 'Reason required'
}
$cgi->param('reasonnum', $reasonnum) unless $error;
my $_date;
if ( $FS::CurrentUser::CurrentUser->access_right('Backdate credit') ) {
$_date = parse_datetime($cgi->param('_date'));
}
else {
$_date = time;
}
my @fields = grep { $_ ne '_date' } fields('cust_credit');
unless ($error) {
my $new = new FS::cust_credit ( {
_date => $_date,
map { $_ => scalar($cgi->param($_)) } @fields
} );
$error = $new->insert;
}
</%init>
|