<% include('/elements/header.html', "Customer $action", '', ' onUnload="myclose()"' #hmm, in billing.html ) %> <% include('/elements/error.html') %>
> % if ( $custnum ) { Customer #<% $cust_main->display_custnum %> - <% ucfirst($cust_main->status) %>

% } %# agent, agent_custid, refnum (advertising source), referral_custnum <% include('cust_main/top_misc.html', $cust_main, 'custnum' => $custnum ) %> %# birthdate % if ( $conf->exists('cust_main-enable_birthdate') ) {
<% include('cust_main/birthdate.html', $cust_main) %> % } %# latitude and longitude % if ( $conf->exists('cust_main-require_censustract') ) { % my ($latitude, $longitude) = $cust_main->service_coordinates; % $latitude ||= $conf->config('company_latitude') || ''; % $longitude ||= $conf->config('company_longitude') || ''; % } %# contact info % my $same_checked = ''; % my $ship_disabled = ''; % my @ship_style = (); % unless ( $cust_main->ship_last && $same ne 'Y' ) { % $same_checked = 'CHECKED'; % $ship_disabled = 'DISABLED'; % push @ship_style, 'background-color:#dddddd'; % foreach ( % qw( last first company address1 address2 city county state zip country % daytime night fax ) % ) { % $cust_main->set("ship_$_", $cust_main->get($_) ); % } % }
Billing address <% include('cust_main/contact.html', 'cust_main' => $cust_main, 'pre' => '', 'onchange' => 'bill_changed(this)', 'disabled' => '', 'ss' => $ss, 'stateid' => $stateid, 'same_checked' => $same_checked, #for address2 "Unit #" labeling ) %>
Service address (>same as billing address) <% include('cust_main/contact.html', 'cust_main' => $cust_main, 'pre' => 'ship_', 'onchange' => '', 'disabled' => $ship_disabled, 'style' => \@ship_style ) %> %# billing info <% include( 'cust_main/billing.html', $cust_main, 'payinfo' => $payinfo, 'invoicing_list' => \@invoicing_list, ) %> % my $ro_comments = $conf->exists('cust_main-use_comments')?'':'readonly'; % if (!$ro_comments || $cust_main->comments) {
Comments <% &ntable("#cccccc") %> % } % unless ( $custnum ) { <% include('cust_main/first_pkg.html', $cust_main, 'pkgpart_svcpart' => $pkgpart_svcpart, #svc_acct 'username' => $username, 'password' => $password, 'popnum' => $popnum, 'saved_domsvc' => $saved_domsvc, %svc_phone, ) %> % } %# cust_main/bottomfixup.js % foreach my $hidden ( % 'payauto', % 'payinfo', 'payinfo1', 'payinfo2', 'paytype', % 'payname', 'paystate', 'exp_month', 'exp_year', 'paycvv', % 'paystart_month', 'paystart_year', 'payissue', % 'payip', % 'paid', % ) { % } <% include('cust_main/bottomfixup.html') %>
" onClick = "this.disabled=true; bottomfixup(this.form);" >
<% include('/elements/footer.html') %> <%init> my $curuser = $FS::CurrentUser::CurrentUser; #probably redundant given the checks below... die "access denied" unless $curuser->access_right('New customer') || $curuser->access_right('Edit customer'); my $conf = new FS::Conf; #get record my($custnum, $cust_main, $ss, $stateid, $payinfo, @invoicing_list); my $same = ''; my $pkgpart_svcpart = ''; #first_pkg my($username, $password, $popnum, $saved_domsvc) = ( '', '', 0, 0 ); #svc_acct my %svc_phone = (); if ( $cgi->param('error') ) { $cust_main = new FS::cust_main ( { map { $_, scalar($cgi->param($_)) } fields('cust_main') } ); $custnum = $cust_main->custnum; die "access denied" unless $curuser->access_right($custnum ? 'Edit customer' : 'New customer'); @invoicing_list = split( /\s*,\s*/, $cgi->param('invoicing_list') ); $same = $cgi->param('same'); $cust_main->setfield('paid' => $cgi->param('paid')) if $cgi->param('paid'); $ss = $cust_main->ss; # don't mask an entered value on errors $stateid = $cust_main->stateid; # don't mask an entered value on errors $payinfo = $cust_main->payinfo; # don't mask an entered value on errors $pkgpart_svcpart = $cgi->param('pkgpart_svcpart') || ''; #svc_acct $username = $cgi->param('username'); $password = $cgi->param('_password'); $popnum = $cgi->param('popnum'); $saved_domsvc = $cgi->param('domsvc') || ''; if ( $saved_domsvc =~ /^(\d+)$/ ) { $saved_domsvc = $1; } else { $saved_domsvc = ''; } #svc_phone $svc_phone{$_} = $cgi->param($_) foreach qw( countrycode phonenum sip_password pin phone_name ); } elsif ( $cgi->keywords ) { #editing die "access denied" unless $curuser->access_right('Edit customer'); my( $query ) = $cgi->keywords; $query =~ /^(\d+)$/; $custnum=$1; $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } ); if ( $cust_main->dbdef_table->column('paycvv') && length($cust_main->paycvv) ) { my $paycvv = $cust_main->paycvv; $paycvv =~ s/./*/g; $cust_main->paycvv($paycvv); } @invoicing_list = $cust_main->invoicing_list; $ss = $cust_main->masked('ss'); $stateid = $cust_main->masked('stateid'); $payinfo = $cust_main->paymask; } else { #new customer die "access denied" unless $curuser->access_right('New customer'); $custnum=''; $cust_main = new FS::cust_main ( {} ); $cust_main->otaker( &getotaker ); $cust_main->referral_custnum( $cgi->param('referral_custnum') ); @invoicing_list = (); push @invoicing_list, 'POST' unless $conf->exists('disablepostalinvoicedefault'); $ss = ''; $stateid = ''; $payinfo = ''; } my $error = $cgi->param('error'); $cgi->delete_all(); $cgi->param('error', $error); my $action = $custnum ? 'Edit' : 'Add'; $action .= ": ". $cust_main->name if $custnum; my $r = qq!* !;