X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fcust_main%2Ftop_misc.html;h=c19f347c3297b6cb32372002b148210bdc669c33;hb=622c72770c971ae44d37dfb59a0f25972051a25a;hp=36add372184a8c5f3f22bf4fc80f3424e3dee17f;hpb=624b2d44625f69d71175c3348cae635d580c890b;p=freeside.git diff --git a/httemplate/edit/cust_main/top_misc.html b/httemplate/edit/cust_main/top_misc.html index 36add3721..c19f347c3 100644 --- a/httemplate/edit/cust_main/top_misc.html +++ b/httemplate/edit/cust_main/top_misc.html @@ -1,19 +1,136 @@ -<% &ntable("#cccccc") %> +<TABLE CLASS="fsinnerbox"> + +<TR> + <TD ALIGN="right">Residential</TD> + <TD><INPUT TYPE = "radio" + NAME = "residential_commercial" + ID = "residential_commercial_Residential" + VALUE = "Residential" + onChange = "rescom_changed(this)" + <% $cust_main->residential_commercial eq 'Commercial' ? '' : 'CHECKED' %> + ></TD> +</TR> +<TR> + <TD ALIGN="right">Commercial</TD> + <TD><INPUT TYPE = "radio" + NAME = "residential_commercial" + ID = "residential_commercial_Commercial" + VALUE = "Commercial" + onChange = "rescom_changed(this)" + <% $cust_main->residential_commercial eq 'Commercial' ? 'CHECKED' : '' %> + ></TD> +</TR> + +<SCRIPT TYPE="text/javascript"> + + function rescom_changed(what) { + if ( what.checked == (what.value == 'Commercial' ) ) { + document.getElementById('company_row').style.display = ''; + document.getElementById('contacts_div').style.display = ''; + document.getElementById('spouse_row').style.display = 'none'; + } else { + if ( document.getElementById('company').value.length == 0 ) { + document.getElementById('company_row').style.display = 'none'; + } + document.getElementById('contacts_div').style.display = 'none'; + document.getElementById('spouse_row').style.display = ''; + } + } + + + var ship_locked_agents = <% encode_json(\%ship_locked_agents) %>; + var ship_fields = [ + 'locationname', 'address1',<% $conf->exists('cust_main-no_city_in_address') ? '' : q( 'city',) %> 'state', 'zip', 'country', + 'latitude', 'longitude', 'district' + ]; + + function agent_changed(what) { + var agentnum = what.value; + +% # unlock/lock service location + + var f = what.form; + if ( ship_locked_agents[agentnum] ) { +% # For this agent, the service location (except address2) +% # should be locked to the agent's location. +% # Set the ship_ fields to those values (just for display) and +% # then disable them. + for(var x in ship_locked_agents[agentnum]) { + f['ship_'+x].value = ship_locked_agents[agentnum][x]; + f['ship_'+x].disabled = true; + } + f['same'].checked = false; + f['same'].disabled = true; + } else { +% # Unlock the ship_ location fields. If they were previously +% # disabled, then they contain some agent's address, which is +% # no longer meaningful. So set them back to the customer's +% # current location. + for(var i=0; i<ship_fields.length; i++) { + x = ship_fields[i]; + if ( f['ship_'+x].disabled ) { + f['ship_'+x].value = f['old_ship_'+x].value; + } + f['ship_'+x].disabled = false; + } + f['same'].disabled = false; + } + samechanged(f['same']); + +% # update sales dropdown + salesnum_agentnum_changed(what); + + } + + <&| /elements/onload.js &> + rescom_changed(document.getElementById('residential_commercial_Residential')); + agent_changed(document.getElementById('agentnum')) + </&> + +</SCRIPT> + +% foreach my $field ($cust_main->virtual_fields) { + <% $cust_main->pvf($field)->widget('HTML', 'edit',$cust_main->getfield($field)) %> +% } + +%# tags +<& /elements/tr-select-cust_tag.html, + 'custnum' => $custnum, + 'cgi' => $cgi, +&> %# agent -<% include('/elements/tr-select-agent.html', - 'curr_value' => $cust_main->agentnum, - 'label' => "<B>${r}Agent</B>", - 'empty_label' => 'Select agent', - 'disable_empty' => ( $cust_main->agentnum ? 1 : 0 ), - ) -%> +% if ( $cgi->param('lock_agentnum') =~ /^(\d+)$/ && $curuser->agentnum($1) ) { +% +% my $agentnum = $1; +% $cust_main->agentnum($agentnum); + + <INPUT TYPE="hidden" NAME="lock_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, + 'curr_value' => $cust_main->agentnum, + 'label' => "<B>${r}".emt('Agent')."</B>", + 'empty_label' => emt('Select agent'), + 'disable_empty' => ( $cust_main->agentnum ? 1 : 0 ), + 'viewall_right' => emt('None'), + 'onchange' => 'agent_changed(this)', + &> + +% } %# agent_custid % if ( $conf->exists('cust_main-edit_agent_custid') ) { <TR> - <TD ALIGN="right">Customer identifier</TD> + <TD ALIGN="right"><% mt('Customer identifier') |h %></TD> <TD><INPUT TYPE="text" NAME="agent_custid" VALUE="<% $cust_main->agent_custid %>"></TD> </TR> @@ -24,13 +141,15 @@ % } %# class -<% include('/elements/tr-select-cust_class.html', +<& /elements/tr-select-cust_class.html, 'curr_value' => $cust_main->classnum, - 'label' => "Class", - #'empty_label' => '(none)', - #'disable_empty' => - ) -%> + 'label' => emt("Class"), +&> + +%#sales person +<& /elements/tr-select-sales.html, + 'curr_value' => $cust_main->salesnum, +&> %# referral (advertising source) %my $refnum = $cust_main->refnum || $conf->config('referraldefault') || 0; @@ -40,10 +159,10 @@ % } else { - <% include('/elements/tr-select-part_referral.html', - 'curr_value' => $refnum - ) - %> + <& /elements/tr-select-part_referral.html, + 'curr_value' => $refnum, + 'label' => "<B>${r}".emt('Advertising source')."</B>" + &> % } @@ -56,9 +175,9 @@ %) { <TR> - <TD ALIGN="right">Referring customer</TD> + <TD ALIGN="right"><% mt('Referring customer') |h %></TD> <TD> - <A HREF="<% popurl(1) %>/cust_main.cgi?<% $cust_main->referral_custnum %>"><% $cust_main->referral_custnum %>: <% $referring_cust_main->name %></A> + <A HREF="<% popurl(1) %>/cust_main.cgi?<% $cust_main->referral_custnum %>"><% $cust_main->referral_custnum %>: <% $referring_cust_main->name |h %></A> </TD> </TR> <INPUT TYPE="hidden" NAME="referral_custnum" VALUE="<% $cust_main->referral_custnum %>"> @@ -66,14 +185,12 @@ % } elsif ( ! $conf->exists('disable_customer_referrals') ) { <TR> - <TD ALIGN="right">Referring customer</TD> + <TD ALIGN="right"><% mt('Referring customer') |h %></TD> <TD> - <!-- <INPUT TYPE="text" NAME="referral_custnum" VALUE=""> --> - <% include('/elements/search-cust_main.html', + <& /elements/search-cust_main.html, 'field_name' => 'referral_custnum', 'curr_value' => $cust_main->referral_custnum, - ) - %> + &> </TD> </TR> @@ -83,13 +200,37 @@ %# signup date % if ( $conf->exists('cust_main-edit_signupdate') ) { - <% include('/elements/tr-input-date-field.html', { + <& /elements/tr-input-date-field.html, { 'name' => 'signupdate', 'value' => $cust_main->signupdate, - 'label' => 'Signup date', + 'label' => emt('Signup date'), 'format' => ( $conf->config('date_format') || "%m/%d/%Y" ), - }) - %> + } + &> +% } + +% # permission to edit ticket subjects +% if ( $conf->exists('ticket_system-selfservice_edit_subject') ) { + <TR> + <TD ALIGN="right"> + <INPUT TYPE="checkbox" NAME="edit_subject" VALUE="Y" <% + $cust_main->edit_subject ? 'CHECKED' : '' %>></TD> + <TD ALIGN="left"><% mt('Can edit ticket subjects') |h %></TD> + </TR> +% } else { + <INPUT TYPE="hidden" NAME="edit_subject" VALUE="<% $cust_main->edit_subject %>"> +% } + +% # permission to edit +% if ( $conf->exists('cust_main-edit_calling_list_exempt') ) { + <TR> + <TD ALIGN="right"> + <INPUT TYPE="checkbox" NAME="calling_list_exempt" VALUE="Y" <% + $cust_main->calling_list_exempt ? 'CHECKED' : '' %>></TD> + <TD ALIGN="left"><% mt('Calling list exempt') |h %></TD> + </TR> +% } else { + <INPUT TYPE="hidden" NAME="calling_list_exempt" VALUE="<% $cust_main->calling_list_exempt %>"> % } </TABLE> @@ -102,8 +243,44 @@ my $custnum = $opt{'custnum'}; my $conf = new FS::Conf; +if ( $cgi->param('error') ) { + $cust_main->set('residential_commercial', + ($cgi->param('residential_commercial') eq 'Commercial') + ? 'Commercial' + : 'Residential' + ); +} elsif ( $custnum ) { #editing + $cust_main->set('residential_commercial', + length($cust_main->company) + ? 'Commercial' + : 'Residential' + ); +} else { #new customer + $cust_main->set('residential_commercial', + $conf->exists('cust_main-default_commercial') + ? 'Commercial' + : 'Residential' + ); +} + 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 $cust_main = $_->agent_cust_main or next; + my $agent_ship_location = $cust_main->ship_location; + $ship_locked_agents{$agentnum} = +{ + map { $_ => $agent_ship_location->$_ } + ( + qw(locationname address1 state zip country latitude longitude district), + ($conf->exists('cust_main-no_city_in_address') ? () : 'city') + ) + }; +} + </%init>