summaryrefslogtreecommitdiff
path: root/httemplate/edit/process/cust_main_county-expand.cgi
blob: 9984b08fa24c21b3410dbb3b81eaa3028393630d (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<% 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',$_);
  } elsif ( ! $cust_main_county->county ) {
    $new->setfield('county',$_);
  } else {
    #uppercase cities in the US to try and agree with USPS validation
    $new->setfield('city', $new->country eq 'US' ? uc($_) : $_ );
  }
  my $error = $new->insert;
  die $error if $error;
}

unless ( qsearch( 'cust_main', {
                                 'city'    => $cust_main_county->city,
                                 'county'  => $cust_main_county->county,
                                 'state'   => $cust_main_county->state,
                                 '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?".
                         'city='.    uri_escape($cust_main_county->city   ).';'.
                         'county='.  uri_escape($cust_main_county->county ).';'.
                         'state='.   uri_escape($cust_main_county->state  ).';'.
                         'country='. uri_escape($cust_main_county->country)
                      );
  myexit;
}

</%init>