X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=httemplate%2Fedit%2Fcust_main%2Fbottomfixup.js;h=8aef1e72c8bee049934d01abef1451c162e99602;hb=2d5acabf71d46aa469a6867f294706242c82db98;hp=2f7839a326609626836791c6dec228e9918ddb7e;hpb=d53fe51e0d705f5923a0be114653492160028ddc;p=freeside.git diff --git a/httemplate/edit/cust_main/bottomfixup.js b/httemplate/edit/cust_main/bottomfixup.js index 2f7839a32..8aef1e72c 100644 --- a/httemplate/edit/cust_main/bottomfixup.js +++ b/httemplate/edit/cust_main/bottomfixup.js @@ -1,8 +1,59 @@ +<%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, 'confirm_censustract_bill', 'confirm_censustract_ship' + if $conf->exists('cust_main-require_censustract'); + +my $uniqueness = $conf->config('cust_main-check_unique'); +push @fixups, 'check_unique' + if $uniqueness and !$opt{'custnum'}; + +push @fixups, 'do_submit'; # always last +%init> +var fixups = <% encode_json(\@fixups) %>; +var fixup_position; +var running = false; + +<&| /elements/onload.js &> +submit_abort(); +&> + +%# state machine to deal with all the asynchronous stuff we're doing +%# call this after each fixup on success: +function submit_continue() { + if ( running ) { + window[ fixups[fixup_position++] ].call(); + } +} + +%# or on failure: +function submit_abort() { + running = false; + fixup_position = 0; + document.CustomerForm.submitButton.disabled = false; + cClick(); +} + function bottomfixup(what) { + fixup_position = 0; + document.CustomerForm.submitButton.disabled = true; + running = true; + submit_continue(); +} -%# ../cust_main.cgi +function do_submit() { + document.CustomerForm.submit(); +} + +function copy_payby_fields() { var layervars = new Array( - 'payauto', + 'payauto', 'billday', 'payinfo', 'payinfo1', 'payinfo2', 'payinfo3', 'paytype', 'payname', 'paystate', 'exp_month', 'exp_year', 'paycvv', 'paystart_month', 'paystart_year', 'payissue', @@ -18,114 +69,14 @@ function bottomfixup(what) { cf.elements[field] ); } - - //this part does USPS address correction - standardize_locations(); - + submit_continue(); } -<% include( '/elements/standardize_locations.js', - 'callback', 'post_geocode();' - ) -%> - -function post_geocode() { - -% if ( $conf->exists('cust_main-require_censustract') ) { - - //alert('fetch census tract data'); - var cf = document.CustomerForm; - var state_el = cf.elements['ship_state']; - var census_data = new Array( - 'year', <% $conf->config('census_year') || '2011' %>, - '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 - ); - - 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 error = argsHash['error']; - - var newcensus = - new String(statecode) + - new String(countycode) + - new String(tractcode).replace(/\s$/, ''); // JSON 1 workaround - - set_censustract = function () { - - cf.elements['censustract'].value = newcensus - cf.submit(); - - } - - if (error || cf.elements['censustract'].value != newcensus) { - // popup an entry dialog - - if (error) { newcensus = error; } - newcensus.replace(/.*ndefined.*/, 'Not found'); - - var choose_censustract = - '
Entered census tract | ' + - 'Calculated census tract |
---|---|
' + cf.elements['censustract'].value + - ' | ' + newcensus + ' |
' + - '' + - ' | ' + - '' + - ' |
' + - ' |