X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fview%2Fcust_main%2Fcontacts.html;h=1660c1c2272a649ce8783c6864287d0a2160b299;hp=456d117a64289b0ee8063f74c7426b2c2e0145f0;hb=ae58eda132b5a89ce251dbdf13822dee2f3bc92f;hpb=673b9a458d9138523026963df6fa3b4683e09bae diff --git a/httemplate/view/cust_main/contacts.html b/httemplate/view/cust_main/contacts.html index 456d117a6..1660c1c22 100644 --- a/httemplate/view/cust_main/contacts.html +++ b/httemplate/view/cust_main/contacts.html @@ -1,131 +1,221 @@ -<% - my( $cust_main ) = @_; - my $conf = new FS::Conf; -%> +% my %addr_label = ('bill' => 'Billing address', 'ship' => 'Service address'); -Billing address -<%= ntable("#cccccc") %><%= ntable("#cccccc",2) %> - - Contact name - - <%= $cust_main->last. ', '. $cust_main->first %> - -<% if ( $conf->exists('show_ss') ) { %> - SS# - <%= $cust_main->ss || ' ' %> -<% } %> - - - Company - <%= $cust_main->company %> - - - Address - <%= $cust_main->address1 %> - -<% if ( $cust_main->address2 ) { %> - -   - <%= $cust_main->address2 %> - -<% } %> - - City - <%= $cust_main->city %> - State - <%= $cust_main->state %> - Zip - <%= $cust_main->zip %> - - - Country - <%= $cust_main->country %> - -<% - my $daytime_label = FS::Msgcat::_gettext('daytime') =~ /^(daytime)?$/ - ? 'Day Phone' - : FS::Msgcat::_gettext('daytime'); - my $night_label = FS::Msgcat::_gettext('night') =~ /^(night)?$/ - ? 'Night Phone' - : FS::Msgcat::_gettext('night'); -%> - - <%= $daytime_label %> - - <%= $cust_main->daytime || ' ' %> - - - - <%= $night_label %> - - <%= $cust_main->night || ' ' %> - - - - Fax - - <%= $cust_main->fax || ' ' %> - - - +%# 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 ( defined $cust_main->dbdef_table->column('ship_last') ) { - my $pre = $cust_main->ship_last ? 'ship_' : ''; -%> +% 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) ) { + + + + +% } +% +% # 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 ) { + + + + +% } -
-Service address -<%= ntable("#cccccc") %> - - - - - - - - - - - -<% if ( $cust_main->get("${pre}address2") ) { %> - - + + -<% } %> + +% if ( $location->get('address2') ) { +% my $address2_label = $conf->exists('cust_main-require_address2') +% ? emt('Unit #') +% : ' '; + - - - - - - + + + +% } + - - + + - - + + - - - + + +% } #foreach $phone +% if ( $cust_main->get('fax') ) { + + + + + + +% } +% +% if ( $conf->exists('show_stateid') ) { + - - - -
<% mt('Contact name') |h %><% $cust_main->contact |h %><% mt('SS#') |h %><% $conf->exists('unmask_ss') + ? $cust_main->ss + : $cust_main->masked('ss') || ' ' %>
<% mt('Spouse') |h %> + <% join(', ', grep $_, + $cust_main->spouse_last, $cust_main->spouse_first) %> +
<% 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 %>
<%= ntable("#cccccc",2) %> -
Contact name - <%= $cust_main->get("${pre}last"). ', '. $cust_main->get("${pre}first") %> -
Company<%= $cust_main->get("${pre}company") %>
Address<%= $cust_main->get("${pre}address1") %>
 <%= $cust_main->get("${pre}address2") %><% mt('Address') |h %><% $location->address1 |h %>
City<%= $cust_main->get("${pre}city") %>State<%= $cust_main->get("${pre}state") %>Zip<%= $cust_main->get("${pre}zip") %><% $address2_label %><% $location->address2 |h %>
Country<%= $cust_main->get("${pre}country") %><% $location->city |h %>\ +% if ( $location->county ) { + (<% $location->county |h %> county)\ +% } +<% ($location->city || $location->county) ? ', ' : ''%><% state_label( $location->state, $location->country ) |h %> + <% $location->zip |h %> +
<%= $daytime_label %> - <%= $cust_main->get("${pre}daytime") || ' ' %> - <% $location->country_full |h %>
<%= $night_label %> - <%= $cust_main->get("${pre}night") || ' ' %> + +% if ( $location->latitude && $location->longitude ) { + <& /elements/tr-coords.html, $location->latitude, + $location->longitude, + $cust_main->name_short, + $cust_main->agentnum, + &> +% } +<& /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); +
<% $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('fax') || ' ' %> +
Fax - <%= $cust_main->get("${pre}fax") || ' ' %> -
+ <% $stateid_label %> + <% $cust_main->masked('stateid') || ' ' %> + <% $stateid_state_label %> + <% $cust_main->stateid_state || ' ' %> + + +% } +% } #if $this eq 'bill' + +% if ( @which ) { +
+% } +% } #while @which +<%once> + +my %phone_label = ( + + 'daytime' => ( FS::Msgcat::_gettext('daytime') =~ /^(daytime)?$/ + ? 'Day Phone' + : FS::Msgcat::_gettext('daytime') + ), + + 'night' => ( FS::Msgcat::_gettext('night') =~ /^(night)?$/ + ? 'Night Phone' + : FS::Msgcat::_gettext('night') + ), + + 'mobile' => ( FS::Msgcat::_gettext('mobile') =~ /^(mobile)?$/ + ? 'Mobile Phone' + : FS::Msgcat::_gettext('Mobile') + ), +); + +my $stateid_label = FS::Msgcat::_gettext('stateid') =~ /^(stateid)?$/ + ? 'Driver’s License' + : FS::Msgcat::_gettext('stateid'); +my $stateid_state_label = FS::Msgcat::_gettext('stateid_state') =~ /^(stateid_state)?$/ + ? 'Driver’s License State' + : FS::Msgcat::_gettext('stateid_state'); + + +<%init> + +my $cust_main = shift; +my $conf = new FS::Conf; +my @invoicing_list = $cust_main->invoicing_list_emailonly; -<% } %> +