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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
<% include('/elements/header-popup.html', 'Addition successful' ) %>
<SCRIPT TYPE="text/javascript">
window.top.location.reload();
</SCRIPT>
</BODY>
</HTML>
<%init>
die "access denied"
unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
$cgi->param('taxnum') =~ /^(\d+)$/ or die "Illegal taxnum!";
my $taxnum = $1;
my $cust_main_county = qsearchs('cust_main_county',{'taxnum'=>$taxnum})
or die ("Unknown taxnum!");
my @expansion;
if ( $cgi->param('taxclass') ) {
my $sth = dbh->prepare('SELECT taxclass FROM part_pkg_taxclass')
or die dbh->errstr;
$sth->execute or die $sth->errstr;
@expansion = map $_->[0], @{$sth->fetchall_arrayref};
die "no taxclasses - add one first" unless @expansion;#XXX better err handling
} else {
@expansion = split /[\n\r]{1,2}/, $cgi->param('expansion');
#warn scalar(@expansion);
#warn "$_: $expansion[$_]\n" foreach (0..$#expansion);
@expansion=map {
unless ( /^\s*([\w\- ]+)\s*$/ ) {
$cgi->param('error', "Illegal item in expansion: $_");
print $cgi->redirect(popurl(2). "cust_main_county-expand.cgi?". $cgi->query_string );
myexit();
}
$1;
} @expansion;
}
foreach ( @expansion) {
my(%hash)=$cust_main_county->hash;
my($new)=new FS::cust_main_county \%hash;
$new->setfield('taxnum','');
if ( $cgi->param('taxclass') ) {
$new->setfield('taxclass', $_);
} elsif ( ! $cust_main_county->state ) {
$new->setfield('state',$_);
} else {
$new->setfield('county',$_);
}
my $error = $new->insert;
die $error if $error;
}
unless ( qsearch( 'cust_main', {
'state' => $cust_main_county->state,
'county' => $cust_main_county->county,
'country' => $cust_main_county->country,
} )
|| ! @expansion
) {
my $error = $cust_main_county->delete;
die $error if $error;
}
if ( $cgi->param('taxclass') ) {
print $cgi->redirect(popurl(3). "browse/cust_main_county.cgi?".
'state='. uri_escape($cust_main_county->state ).';'.
'county='. uri_escape($cust_main_county->county ).';'.
'country='. uri_escape($cust_main_county->country)
);
myexit;
}
</%init>
|