X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fcust_main%2Fbottomfixup.js;h=77d4294a62f943b7a88b1dd46bf6fd93c42bb005;hb=51c3d90d07c9d5b3e33a1f002cf5a252ef65bb7b;hp=4d9ef070dcc10c8ff901f1d6c7e3d0ea8c5bd251;hpb=eec4949e2c8f09a0b89331437186b77c4db6ff38;p=freeside.git diff --git a/httemplate/edit/cust_main/bottomfixup.js b/httemplate/edit/cust_main/bottomfixup.js index 4d9ef070d..77d4294a6 100644 --- a/httemplate/edit/cust_main/bottomfixup.js +++ b/httemplate/edit/cust_main/bottomfixup.js @@ -1,9 +1,51 @@ +<%init> +my %opt = @_; # custnum +my $conf = new FS::Conf; + +my $company_latitude = $conf->config('company_latitude'); +my $company_longitude = $conf->config('company_longitude'); + +my @fixups = ('copy_payby_fields', 'standardize_locations'); + +push @fixups, 'fetch_censustract' + if $conf->exists('cust_main-require_censustract'); + +push @fixups, 'check_unique' + if $conf->exists('cust_main-check_unique') and !$opt{'custnum'}; + +push @fixups, 'do_submit'; # always last + + +var fixups = <% encode_json(\@fixups) %>; +var fixup_position; + +%# state machine to deal with all the asynchronous stuff we're doing +%# call this after each fixup on success: +function submit_continue() { + window[ fixups[fixup_position++] ].call(); +} + +%# or on failure: +function submit_abort() { + fixup_position = 0; + document.CustomerForm.submitButton.disabled = false; + cClick(); +} + function bottomfixup(what) { + fixup_position = 0; + document.CustomerForm.submitButton.disabled = true; + submit_continue(); +} + +function do_submit() { + document.CustomerForm.submit(); +} -%# ../cust_main.cgi +function copy_payby_fields() { var layervars = new Array( - 'payauto', - 'payinfo', 'payinfo1', 'payinfo2', 'paytype', + 'payauto', 'billday', + 'payinfo', 'payinfo1', 'payinfo2', 'payinfo3', 'paytype', 'payname', 'paystate', 'exp_month', 'exp_year', 'paycvv', 'paystart_month', 'paystart_year', 'payissue', 'payip', @@ -18,39 +60,113 @@ function bottomfixup(what) { cf.elements[field] ); } - - //this part does USPS address correction - standardize_locations(); - + submit_continue(); } +%# call submit_continue() on completion... +%# otherwise not touching standardize_locations for now <% include( '/elements/standardize_locations.js', - 'callback', 'post_geocode();' + 'callback' => 'submit_continue();', + 'main_prefix' => 'bill_', + 'no_company' => 1, ) %> -function post_geocode() { - -% if ( $conf->exists('cust_main-require_censustract') ) { +var prefix; +function fetch_censustract() { //alert('fetch census tract data'); + prefix = document.getElementById('same').checked ? 'bill_' : 'ship_'; var cf = document.CustomerForm; - var state_el = cf.elements['ship_state']; + var state_el = cf.elements[prefix + 'state']; var census_data = new Array( - 'year', <% $conf->config('census_year') || '2009' %>, - 'address', cf.elements['ship_address1'].value, - 'city', cf.elements['ship_city'].value, - 'state', state_el.options[ state_el.selectedIndex ].value, - 'zip', cf.elements['ship_zip'].value + 'year', <% $conf->config('census_year') || '2012' %>, + 'address1', cf.elements[prefix + 'address1'].value, + 'city', cf.elements[prefix + 'city'].value, + 'state', state_el.options[ state_el.selectedIndex ].value, + 'zip', cf.elements[prefix + 'zip'].value ); censustract( census_data, update_censustract ); -% }else{ +} - document.CustomerForm.submit(); +var set_censustract; -% } +function update_censustract(arg) { + + var argsHash = eval('(' + arg + ')'); + + var cf = document.CustomerForm; + +/* var msacode = argsHash['msacode']; + var statecode = argsHash['statecode']; + var countycode = argsHash['countycode']; + var tractcode = argsHash['tractcode']; + + var newcensus = + new String(statecode) + + new String(countycode) + + new String(tractcode).replace(/\s$/, ''); // JSON 1 workaround */ + var error = argsHash['error']; + var newcensus = argsHash['censustract']; + + set_censustract = function () { + + cf.elements[prefix + 'censustract'].value = newcensus; + submit_continue(); + + } + + if (error || cf.elements[prefix + 'censustract'].value != newcensus) { + // popup an entry dialog + + if (error) { newcensus = error; } + newcensus.replace(/.*ndefined.*/, 'Not found'); + + var latitude = cf.elements[prefix + 'latitude'].value + || '<% $company_latitude %>'; + var longitude= cf.elements[prefix + 'longitude'].value + || '<% $company_longitude %>'; + + var choose_censustract = + '

Confirm censustract
' + + 'Map service module location
' + + 'Map zip code center

' + + ''; + + choose_censustract = choose_censustract + + '' + + '' + + '' + + ''; + + choose_censustract = choose_censustract + + '' + + '' + + + '
Entered census tractCalculated census tract
' + cf.elements[prefix + 'censustract'].value + + '' + newcensus + '
  
' + + '' + + '' + + '' + + '
' + + '
'; + + overlib( choose_censustract, CAPTION, 'Confirm censustract', STICKY, AUTOSTATUSCAP, CLOSETEXT, '', MIDX, 0, MIDY, 0, DRAGGABLE, WIDTH, 576, HEIGHT, 268, BGCOLOR, '#333399', CGCOLOR, '#333399', TEXTSIZE, 3 ); + + } else { + + submit_continue(); + + } } @@ -76,8 +192,24 @@ function copyelement(from, to) { //alert(from + " (" + from.type + "): " + to.name + " => " + to.value); } -<%init> +function check_unique() { + var search_hash = new Object; +% foreach ($conf->config('cust_main-check_unique')) { + search_hash['<% $_ %>'] = document.CustomerForm.elements['<% $_ %>'].value; +% } -my $conf = new FS::Conf; +%# supported in IE8+, Firefox 3.5+, WebKit, Opera 10.5+ + duplicates_form(JSON.stringify(search_hash), confirm_unique); +} + +function confirm_unique(arg) { + if ( arg.match(/\S/) ) { +%# arg contains a complete form to choose an existing customer, or not + overlib( arg, CAPTION, 'Duplicate customer', STICKY, AUTOSTATUSCAP, + CLOSETEXT, '', MIDX, 0, MIDY, 0, DRAGGABLE, WIDTH, 576, HEIGHT, + 268, BGCOLOR, '#333399', CGCOLOR, '#333399', TEXTSIZE, 3 ); + } else { // no duplicates + submit_continue(); + } +} -