diff options
Diffstat (limited to 'httemplate/edit/cust_main')
| -rw-r--r-- | httemplate/edit/cust_main/top_misc.html | 53 |
1 files changed, 51 insertions, 2 deletions
diff --git a/httemplate/edit/cust_main/top_misc.html b/httemplate/edit/cust_main/top_misc.html index 558250cc2..0bdcae0f9 100644 --- a/httemplate/edit/cust_main/top_misc.html +++ b/httemplate/edit/cust_main/top_misc.html @@ -6,6 +6,39 @@ 'cgi' => $cgi, &> +<SCRIPT TYPE="text/javascript"> +var ship_locked_agents = <% encode_json(\%ship_locked_agents) %>; +var ship_fields = ['address1', 'city', 'state', + 'zip', 'country', 'latitude', 'longitude']; +function agent_changed(what) { + var agentnum = what.value; + var f = what.form; + if ( ship_locked_agents[agentnum] ) { + f['same'].checked = false; + f['same'].disabled = true; + samechanged(f['same']); + for(var x in ship_locked_agents[agentnum]) { + f['ship_'+x].value = ship_locked_agents[agentnum][x]; + f['ship_'+x].disabled = true; + f['ship_'+x].style.backgroundColor = '#dddddd'; + } + f['ship_address2'].disabled = false; + f['ship_address2'].style.backgroundColor = '#ffffff'; + } else { + for(var i=0; i<ship_fields.length; i++) { + x = ship_fields[i]; + f['ship_'+x].value = ''; + f['ship_'+x].disabled = false; + } + f['same'].checked = true; + f['same'].disabled = false; + samechanged(f['same']); + } +} +window.onload = function() { + agent_changed(document.getElementById('agentnum')); +}; +</SCRIPT> %# agent % if ( $cgi->param('lock_agentnum') =~ /^(\d+)$/ && $curuser->agentnum($1) ) { % @@ -13,12 +46,13 @@ % $cust_main->agentnum($agentnum); <INPUT TYPE="hidden" NAME="lock_agentnum" VALUE="<% $agentnum %>"> - <INPUT TYPE="hidden" NAME="agentnum" VALUE="<% $agentnum %>"> + <INPUT TYPE="hidden" NAME="agentnum" ID="agentnum" + VALUE="<% $agentnum %>"> <TR> <TD ALIGN="right"><% mt('Agent') |h %></TD> <TD CLASS="fsdisabled"><% $cust_main->agent->agent |h %></TD> </TR> - + % } else { <& /elements/tr-select-agent.html, @@ -27,6 +61,7 @@ 'empty_label' => emt('Select agent'), 'disable_empty' => ( $cust_main->agentnum ? 1 : 0 ), 'viewall_right' => emt('None'), + 'onchange' => 'agent_changed(this)', &> % } @@ -146,4 +181,18 @@ my $curuser = $FS::CurrentUser::CurrentUser; my $r = qq!<font color="#ff0000">*</font> !; +# which agents lock the service address, if any +my %ship_locked_agents; +foreach (qsearch('agent',{})) { + my $agentnum = $_->agentnum; + next unless $conf->exists('agent-ship_address', $_->agentnum); + my $agent_cust_main = $_->agent_cust_main or next; + my $pre = ''; + $pre = 'ship_' if $agent_cust_main->has_ship_address; + $ship_locked_agents{$agentnum} = +{ + map { $_ => $agent_cust_main->get($pre.$_) } + qw(address1 city state zip country latitude longitude) + }; +} + </%init> |
