X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fview%2Fcust_main%2Fcontacts.html;h=1660c1c2272a649ce8783c6864287d0a2160b299;hp=b3e52b556de17ea0332ecfe20397064d7bb33377;hb=ae58eda132b5a89ce251dbdf13822dee2f3bc92f;hpb=0456422b9eaf771e8c27cfb4ef4a0dd7e6f926f8 diff --git a/httemplate/view/cust_main/contacts.html b/httemplate/view/cust_main/contacts.html index b3e52b556..1660c1c22 100644 --- a/httemplate/view/cust_main/contacts.html +++ b/httemplate/view/cust_main/contacts.html @@ -1,122 +1,189 @@ -% my %which = ( -% '' => emt('Billing'), -% 'ship_' => emt('Service'), -% ); -% foreach my $which ( '', 'ship_' ) { -% my $pre = $cust_main->get("${which}last") ? $which : ''; - -<% $which{$which} %> <% mt('address') |h %> +% my %addr_label = ('bill' => 'Billing address', 'ship' => 'Service address'); + +%# Locations (possibly break this out) +% my @which = ('bill', 'ship'); +% while (@which) { +% my $this = shift @which; +% my $method = $this.'_location'; +% my $location = $cust_main->$method; +<% mt( $addr_label{$this} ) |h %> +% if ( $this eq 'ship' and +% $cust_main->bill_locationnum == $cust_main->ship_locationnum ) +% { + (<% emt('same as billing') %>) +% } + +% if ( +% ($this eq 'ship') +% && $cust_main->invoice_ship_address +% && !$conf->exists('invoice-ship_address') #it's always on, so hide per-cust config +% ) { +(<% emt('included on invoices') %>) +% } - - - -% if ( $which eq '' && $conf->exists('show_ss') ) { - - -% } - -% if ( $conf->exists('cust-email-high-visibility') && $which eq '') { +% if ( $this eq 'bill' ) { +% #billing contact fields + + + +% if ( $conf->exists('show_ss') ) { + + +% } + +% if ( $conf->exists('cust_main-enable_spouse') and +% ($cust_main->spouse_last or $cust_main->spouse_first) ) { - - + -% } - -% if ( $cust_main->get("${pre}company") ) { +% } +% +% # invoicing email +% if ( scalar(@invoicing_list) == 1 ) { # typical individual user; show here - - + + +% } elsif ( scalar(@invoicing_list) > 1 ) { +% # business customer with a contact list +% # show nothing here +% +% } else { # there is no invoice email for them + + +% if ( !$cust_main->postal_invoice or +% $conf->exists('cust_main-require_invoicing_list_email', +% $cust_main->agentnum) +% ) { +% # we need a contact email for this customer (either because that's +% # policy, or because otherwise they won't receive invoices) but we +% # don't have one. + +% } else { + +% } +% } # end of invoicing email + +% if ( $cust_main->company ) { + + + + +% } +% } elsif ( $this eq 'ship' ) { +% if ( $cust_main->ship_company ) { # mostly obsolete these days... + + + + +% } % } + +% if ( $location ) { # now the actual address + +% if ( $location->locationname ) { + + + + +% } + - - + + -% if ( $cust_main->get("${pre}address2") ) { -% my $address2_label = -% ( $conf->exists('cust_main-require_address2') -% && ! ( $pre xor $cust_main->has_ship_address ) -% ) -% ? emt('Unit #') -% : ' '; +% if ( $location->get('address2') ) { +% my $address2_label = $conf->exists('cust_main-require_address2') +% ? emt('Unit #') +% : ' '; - - - - + + + + % } - - -% if ( $cust_main->get("${pre}county") ) { - - + + - - - +<% ($location->city || $location->county) ? ', ' : ''%><% state_label( $location->state, $location->country ) |h %> + <% $location->zip |h %> + - - + + -% if ( $cust_main->get($pre.'latitude') && $cust_main->get($pre.'longitude') ) { - <& /elements/tr-coords.html, $cust_main->get($pre.'latitude'), - $cust_main->get($pre.'longitude'), +% if ( $location->latitude && $location->longitude ) { + <& /elements/tr-coords.html, $location->latitude, + $location->longitude, $cust_main->name_short, $cust_main->agentnum, &> % } - -% foreach my $phone (grep $cust_main->get($pre.$_), qw( daytime night mobile )){ - - - - - +<& /elements/tr-censustract.html, $location &> % } + +% if ( $this eq 'bill' ) { +% # billing contact phone numbers +% foreach my $phone (qw(daytime night mobile)) { +% next if !$cust_main->get($phone); + + + + +% } #foreach $phone +% if ( $cust_main->get('fax') ) { -% if ( $cust_main->get("${pre}fax") ) { - - + -% } -% if ( $which eq '' && $conf->exists('show_stateid') ) { - - - - - +% } +% +% if ( $conf->exists('show_stateid') ) { + + + + + + -% } +% } +% } #if $this eq 'bill'
<% mt('Contact name') |h %> - <% $cust_main->get("${pre}last"). ', '. $cust_main->get("${pre}first") |h %> - <% mt('SS#') |h %><% $cust_main->masked('ss') || ' ' %>
<% mt('Contact name') |h %><% $cust_main->contact |h %><% mt('SS#') |h %><% $conf->exists('unmask_ss') + ? $cust_main->ss + : $cust_main->masked('ss') || ' ' %>
<% mt('Email invoices') |h %> - <% join(', ', grep { $_ !~ /^(POST|FAX)$/ } @invoicing_list ) || $no %> + <% mt('Spouse') |h %> + <% join(', ', grep $_, + $cust_main->spouse_last, $cust_main->spouse_first) %>
<% mt('Company') |h %><% $cust_main->get("${pre}company") |h %><% mt('Email address') |h %> + <% $invoicing_list[0] %> +
<% mt('Email address') |h %><% emt('none') %><% emt('no') %>
<% mt('Company') |h %><% $cust_main->company |h %>
<% mt('Company') |h %><% $cust_main->ship_company |h %>
<% mt('Location ID') |h %><% $location->locationname |h %>
<% mt('Address') |h %><% $cust_main->get("${pre}address1") |h %><% mt('Address') |h %><% $location->address1 |h %>
<% $address2_label %><% $cust_main->get("${pre}address2") |h %>
<% $address2_label %><% $location->address2 |h %>
<% mt('City') |h %><% $cust_main->get("${pre}city") |h %><% mt('County') |h %><% $cust_main->get("${pre}county") |h %><% $location->city |h %>\ +% if ( $location->county ) { + (<% $location->county |h %> county)\ % } - <% mt('State') |h %><% state_label( $cust_main->get("${pre}state"), $cust_main->get("${pre}country") ) |h %><% mt('Zip') |h %><% $cust_main->get("${pre}zip") %>
<% mt('Country') |h %><% code2country( $cust_main->get("${pre}country") ) %><% $location->country_full |h %>
<% $phone_label{$phone} %> - <& /elements/phonenumber.html, - $cust_main->get($pre.$phone), - 'callable'=>1, - 'calling_list_exempt'=>$cust_main->calling_list_exempt, - &> -
<% $phone_label{$phone} %> + + <& /elements/phonenumber.html, + $cust_main->get($phone), + callable => 1, + calling_list_exempt => $cust_main->calling_list_exempt, + &> +
<% mt('Fax') |h %> - <% $cust_main->get("${pre}fax") || ' ' %> + <% mt('Fax') |h %> + <% $cust_main->get('fax') || ' ' %>
<% $stateid_label %><% $cust_main->masked('stateid') || ' ' %><% $stateid_state_label %><% $cust_main->stateid_state || ' ' %>
<% $stateid_label %><% $cust_main->masked('stateid') || ' ' %><% $stateid_state_label %><% $cust_main->stateid_state || ' ' %>
-% if ( $which ne 'ship_' ) { +% if ( @which ) {
% } -% } +% } #while @which <%once> my %phone_label = ( @@ -147,10 +214,8 @@ my $stateid_state_label = FS::Msgcat::_gettext('stateid_state') =~ /^(stateid_st <%init> -my( $cust_main ) = @_; +my $cust_main = shift; my $conf = new FS::Conf; -my @invoicing_list = $cust_main->invoicing_list; -my $no = emt('no'); +my @invoicing_list = $cust_main->invoicing_list_emailonly; -