X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fcust_main%2Fbottomfixup.js;h=9e18fa0dfc5725f173bfc3c7ba20fe234a41712d;hb=5f2093d63b321716766535a0ff3e7420882a8888;hp=6b30cbc80317de5698642709b9c317b571cae5b5;hpb=caba365bbebc7e73ad0c25f9a3a9c75a48ed6140;p=freeside.git diff --git a/httemplate/edit/cust_main/bottomfixup.js b/httemplate/edit/cust_main/bottomfixup.js index 6b30cbc80..9e18fa0df 100644 --- a/httemplate/edit/cust_main/bottomfixup.js +++ b/httemplate/edit/cust_main/bottomfixup.js @@ -1,6 +1,54 @@ +<%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' + if $conf->exists('cust_main-require_censustract'); + +# currently doesn't work; disable to avoid problems +#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; +var running = false; + +%# 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', 'billday', 'payinfo', 'payinfo1', 'payinfo2', 'payinfo3', 'paytype', @@ -18,118 +66,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') || '2012' %>, - 'address1', 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 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['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 latitude = cf.elements['latitude' ].value || '<% $company_latitude %>'; - var longitude= cf.elements['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['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 { - - cf.submit(); - - } - -} +<& /elements/standardize_locations.js, + 'callback' => 'submit_continue();', + 'billship' => 1, + 'with_census' => 1, # no with_firm, apparently +&> function copyelement(from, to) { if ( from == undefined ) { @@ -153,12 +97,58 @@ function copyelement(from, to) { //alert(from + " (" + from.type + "): " + to.name + " => " + to.value); } -<%init> +% # the value in pre+'censustract' is the confirmed censustract; if it's set, +% # do nothing here +function confirm_censustract() { + var cf = document.CustomerForm; + var pre = cf.elements['same'].checked ? 'bill_' : 'ship_'; + if ( cf.elements[pre+'censustract'].value == '' ) { + var address_info = form_address_info(); + address_info[pre+'latitude'] = cf.elements[pre+'latitude'].value; + address_info[pre+'longitude'] = cf.elements[pre+'longitude'].value; + OLpostAJAX( + '<%$p%>/misc/confirm-censustract.html', + 'q=' + encodeURIComponent(JSON.stringify(address_info)), + function() { + overlib( OLresponseAJAX, CAPTION, 'Confirm censustract', STICKY, + AUTOSTATUSCAP, CLOSETEXT, '', MIDX, 0, MIDY, 0, DRAGGABLE, WIDTH, + 576, HEIGHT, 268, BGCOLOR, '#333399', CGCOLOR, '#333399', + TEXTSIZE, 3 ); + }, + 0); + } else submit_continue(); +} -my $conf = new FS::Conf; +%# called from confirm-censustract.html +function set_censustract(tract, year) { + var cf = document.CustomerForm; + var pre = 'ship_'; + if ( cf.elements['same'].checked ) { + pre = 'bill_'; + } + cf.elements[pre + 'censustract'].value = tract; + cf.elements[pre + 'censusyear'].value = year; + submit_continue(); +} -my $company_latitude = $conf->config('company_latitude'); -my $company_longitude = $conf->config('company_longitude'); +function check_unique() { + var search_hash = new Object; +% foreach ($conf->config('cust_main-check_unique')) { + search_hash['<% $_ %>'] = document.CustomerForm.elements['<% $_ %>'].value; +% } + +%# 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(); + } +} -