X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Felements%2Flocation.html;h=767231856483e992bc14ca2a7d8ec1af34820efe;hb=a6fe07e49e3fc12169e801b1ed6874c3a5bd8500;hp=b5f76409bbfdeaffe5af126322f5d2f7b2b2fadb;hpb=663b89d06a2c97fb0e7915ba409310fbefefea98;p=freeside.git
diff --git a/httemplate/elements/location.html b/httemplate/elements/location.html
index b5f76409b..767231856 100644
--- a/httemplate/elements/location.html
+++ b/httemplate/elements/location.html
@@ -3,27 +3,49 @@
Example:
include( '/elements/location.html',
- 'object' => $cust_main, # or $cust_location
- 'prefix' => $pre, #only for cust_main objects
+ 'object' => $cust_location
+ 'prefix' => $pre, # prefixed to form field names
'onchange' => $javascript,
- 'disabled' => $disabled,
- 'same_checked' => $same_checked,
'geocode' => $geocode, #passed through
'censustract' => $censustract, #passed through
'no_asterisks' => 0, #set true to disable the red asterisks next
#to required fields
'address1_label' => 'Address', #label for address
+ 'enable_district' => 1, #show tax district field
+ 'enable_censustract' => 1, #show censustract field
)
%doc>
+% if ( $opt{'alt_format'} ) {
+
- <<%$th%> ALIGN="right"><%$r%><% $opt{'address1_label'} || 'Address' %><%$th%>>
+ <<%$th%> ALIGN="right">Location kind<%$th%>>
+
+ <% include('/elements/select.html',
+ 'cgi' => $cgi,
+ 'field' => 'location_kind',
+ 'id' => 'location_kind',
+ 'disabled' => $disabled,
+ #'style' => \@style,
+ 'options' => \@location_kind_options,
+ 'labels' => $location_kind_labels,
+ 'curr_value' => scalar($cgi->param('location_kind'))
+ || $object->get($pre.'location_kind'),
+ )
+ %>
+ |
+
+
+% }
+
+
+ <<%$th%> STYLE="width:16ex" ALIGN="right"><%$r%><% $opt{'address1_label'} || emt('Address') %><%$th%>>
@@ -31,76 +53,115 @@ Example:
>
|
+
+% if ( ! $opt{'alt_format'} ) { #regular format
+
>* >Unit # |
-
- <% $style %>
- >
+
+ <% $style %>
+ >
|
+% } else { # alternate format
+
+
-% if ( $opt{'alt_format'} ) {
- <<%$th%> ALIGN="right">Location Type<%$th%>>
-
- <% $style %>
- >
- |
- |
- <<%$th%> ALIGN="right">Number<%$th%>>
-
- <% $style %>
- >
- |
- <<%$th%> ALIGN="right">Kind<%$th%>>
-
- <% include('/elements/select.html',
- 'cgi' => $cgi,
- 'field' => 'location_kind',
- 'disabled' => $disabled,
- 'style' => $style,
- 'options' => \@location_kind_options,
- 'labels' => $location_kind_labels,
- 'curr_value' => $cgi->param('location_kind'),
- )
- %>
+ <<%$th%> ALIGN="right">Unit type and #<%$th%>>
+ |
+
+% my $location_type = scalar($cgi->param('location_type'))
+% || $object->get('location_type');
+% #my $location_number = scalar($cgi->param('location_number'))
+% # || $object->get($pre.'location_number');
+%
+% if ( $object->get($pre.'address2') && ! $location_type ) {
+% }
+%
+% if ( 1 ) { #ikano, switch on via config
+% tie my %location_types, 'Tie::IxHash',
+% FS::part_export::ikano->location_types;
+ <% include('/elements/select.html',
+ 'cgi' => $cgi,
+ 'field' => 'location_type',
+ 'id' => 'location_type',
+ 'disabled' => $disabled,
+ #'style' => \@style,
+ 'options' => [ keys %location_types ],
+ 'labels' => \%location_types,
+ 'curr_value' => $location_type,
+ 'onchange' => 'location_type_changed',
+ )
+ %>
+
+% } else {
+
+ <% $style %>
+ >
+% }
+
+
+ <% $style %>
+ >
+
+% #XXX i don't work so well when the dropdown is changed :/ i probably need to be triggered by "default service address"
+% $alt_err =~ s/(ship_)?address2/''.encode_entities($object->get($1.'address2')).'<\/B>'/e;
+ <% $alt_err %>
+
|
+
+
% }
+
- <<%$th%> ALIGN="right"><%$r%>City<%$th%>>
- <% include('/elements/city.html', %select_hash) %> |
- <<%$th%> ALIGN="right" ID="<%$pre%>countylabel" <%$county_style%>><%$r%>County<%$th%>>
- <% include('/elements/select-county.html', %select_hash ) %> |
- <<%$th%> ALIGN="right" WIDTH="1"><%$r%>State<%$th%>>
+ <<%$th%> ALIGN="right"><%$r%><% mt('City') |h %><%$th%>>
+ <% include('/elements/city.html', %select_hash, 'text_style' => \@style ) %> |
+ <<%$th%> ALIGN="right" WIDTH="1" ID="<%$pre%>countylabel" <%$county_style%>><%$r%>County<%$th%>>
+ <% include('/elements/select-county.html', %select_hash ) %> |
+ <<%$th%> ALIGN="right" WIDTH="1"><%$r%><% mt('State') |h %><%$th%>>
<% include('/elements/select-state.html', %select_hash ) %>
|
- <<%$th%>><%$r%>Zip<%$th%>>
+ <<%$th%> ALIGN="right" WIDTH="1"><%$r%><% mt('Zip') |h %><%$th%>>
@@ -110,23 +171,62 @@ Example:
|
- <<%$th%> ALIGN="right"><%$r%>Country<%$th%>>
+ <<%$th%> ALIGN="right"><%$r%><% mt('Country') |h %><%$th%>>
<% include('/elements/select-country.html', %select_hash ) %> |
-% if ( !$pre ) {
-
+
+ <% mt('Latitude') |h %>
+ |
+
+ <% $style %>
+ >
+ <% mt('Longitude') |h %>
+
+ <% $style %>
+ >
+ |
+
+
+
+
+
+
+% if ( $opt{enable_censustract} ) {
+ Census tract |
+
+
+ <% '(automatic)' %>
+ |
% } else {
-% if ( $pre eq 'ship_' && $conf->exists('cust_main-require_censustract') ) {
-
<<%$th%> ALIGN="right">Census tract
(automatic)<%$th%>>
-
-
- |
-
-% } else {
-
-% }
+
% }
+
+% if ( $conf->config('tax_district_method') ) {
+
+% if ( $opt{enable_district} ) {
+ Tax district |
+
+
+ <% '(automatic)' %>
+ |
+% } else {
+
+% }
+
+% }
<%init>
@@ -141,16 +241,15 @@ my $conf = new FS::Conf;
my $r = $opt{'no_asterisks'} ? '' : qq!* !;
-#false laziness with ship state
my $countrydefault = $conf->config('countrydefault') || 'US';
-$object->set($pre.'country', $countrydefault )
- unless $object->get($pre.'country');
-
-my $statedefault = $conf->config('statedefault')
+my $statedefault = $conf->config('statedefault')
|| ($countrydefault eq 'US' ? 'CA' : '');
-$object->set($pre.'state', $statedefault )
- unless $object->get($pre.'state')
- || $object->get($pre.'country') ne $countrydefault;
+$object ||= FS::cust_location->new({
+ 'country' => $countrydefault,
+ 'state' => $statedefault,
+});
+
+my $alt_err = ($opt{'alt_format'} && !$disabled) ? $object->alternize : '';
my @style = ();
push @style, 'background-color: #dddddd' if $disabled;
@@ -161,8 +260,8 @@ push @address2_label_style, 'visibility:hidden'
|| ! $conf->exists('cust_main-require_address2')
|| ( !$pre && !$opt{'same_checked'} );
-my @counties = counties( $object->get($pre.'state'),
- $object->get($pre.'country'),
+my @counties = counties( $object->get('state'),
+ $object->get('country'),
);
my @county_style = ();
push @county_style, 'display:none' # 'visibility:hidden'
@@ -182,14 +281,14 @@ my $county_style =
: '';
my %select_hash = (
- 'city' => $object->get($pre.'city'),
- 'county' => $object->get($pre.'county'),
- 'state' => $object->get($pre.'state'),
- 'country' => $object->get($pre.'country'),
+ 'city' => $object->get('city'),
+ 'county' => $object->get('county'),
+ 'state' => $object->get('state'),
+ 'country' => $object->get('country'),
'prefix' => $pre,
'onchange' => $onchange,
'disabled' => $disabled,
- 'style' => \@style,
+ #'style' => \@style,
);
my $th = $opt{'no_bold'} ? 'TD' : 'TH';