X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Felements%2Fcontact.html;h=779905234381c54dd209e8ce822fd80bd97f9eb7;hb=6016bc83d369186275044bd8539f66a3cb03c4cb;hp=a7a33b1f0d95c6592a38e8df724b6e83ee458d0d;hpb=4bc9740be2604e395ffe1aaee23ee2f55092e7e3;p=freeside.git diff --git a/httemplate/elements/contact.html b/httemplate/elements/contact.html index a7a33b1f0..779905234 100644 --- a/httemplate/elements/contact.html +++ b/httemplate/elements/contact.html @@ -2,19 +2,91 @@ <INPUT TYPE="hidden" NAME="<%$name%>" ID="<%$id%>" VALUE="<% $curr_value %>"> - <TABLE> + <TABLE STYLE="display:inline"> <TR> +% if ( @contact_class && ! $opt{name_only} ) { + <TD> + <SELECT NAME="<%$name%>_classnum" <% $onchange %>> + <OPTION VALUE=""> +% my $classnum = scalar($cgi->param($name.'_classnum')) +% || $contact->classnum; +% foreach my $contact_class (@contact_class) { + <OPTION VALUE="<% $contact_class->classnum %>" + <% ($contact_class->classnum == $classnum) ? 'SELECTED' : '' %> + ><% $contact_class->classname |h %> +% } + </SELECT><BR> + <FONT SIZE="-1">Type</FONT> + </TD> +% } else { + <INPUT TYPE="hidden" NAME="<%$name%>_classnum" VALUE=""> +% } +% % foreach my $field ( @fields ) { +% +% my $value = ''; +% if ( $field =~ /^phonetypenum(\d+)$/ ) { +% my $contact_phone = qsearchs('contact_phone', { +% 'contactnum' => $curr_value, +% 'phonetypenum' => $1, +% }); +% if ( $contact_phone ) { +% $value = $contact_phone->phonenum_pretty; +% $value .= 'x'.$contact_phone->extension +% if $contact_phone->extension; +% $value = '+'. $contact_phone->countrycode. " $value" +% if $contact_phone->countrycode +% && $contact_phone->countrycode ne '1'; +% } +% } elsif ( $field eq 'emailaddress' ) { +% $value = join(', ', map $_->emailaddress, $contact->contact_email); +% } else { +% $value = $contact->get($field); +% } + <TD> - <INPUT TYPE = "text" - NAME = "<%$name%>_<%$field%>" - ID = "<%$id%>_<%$field%>" - VALUE = "<% scalar($cgi->param($name."_$field")) - || $contact->get($field) |h %>" - <% $onchange %> - ><BR> +% if ( $field eq 'selfservice_access' ) { + <SELECT NAME = "<%$name%>_<%$field%>" + ID = "<%$id%>_<%$field%>" + > + <OPTION VALUE="">Disabled +% if ( $value || $self_base_url ) { + <OPTION VALUE="Y" <% $value eq 'Y' ? 'SELECTED' : '' %>>Enabled +% if ( $value eq 'Y' && $self_base_url ) { + <OPTION VALUE="R">Re-email +% } +% } + </SELECT> + +% } else { + <INPUT TYPE = "text" + NAME = "<%$name%>_<%$field%>" + ID = "<%$id%>_<%$field%>" + SIZE = "<% $size{$field} || 14 %>" + VALUE = "<% scalar($cgi->param($name."_$field")) + || $value |h %>" + <% $onchange %> + > +% } + <BR> <FONT SIZE="-1"><% $label{$field} %></FONT> </TD> +% } +% my $pwd_change_label = 'change password'; +% $pwd_change_label = 'setup password' unless $contact->_password; +% if ($curr_value) { + <TD> + <span STYLE="white-space: nowrap"> + <& /elements/change_password.html, + 'contact_num' => $curr_value, + 'custnum' => $opt{'custnum'}, + 'curr_value' => '', + 'label' => $pwd_change_label, + &> + </span> + <br> + <FONT SIZE="-1">Password</FONT> + </TD> % } </TR> </TABLE> @@ -24,6 +96,9 @@ my( %opt ) = @_; +my $conf = new FS::Conf; +my $self_base_url = $conf->config('selfservice_server-base_url'); + my $name = $opt{'element_name'} || $opt{'field'} || 'contactnum'; my $id = $opt{'id'} || 'contactnum'; @@ -38,6 +113,8 @@ if ( $opt{'onchange'} ) { $onchange = 'onChange="'. $onchange. '"'; } +my @contact_class = qsearch('contact_class', { 'disabled' => '' }); + my $contact; if ( $curr_value ) { $contact = qsearchs('contact', { 'contactnum' => $curr_value } ); @@ -45,12 +122,26 @@ if ( $curr_value ) { $contact = new FS::contact {}; } +my %size = ( 'title' => 12 ); + tie my %label, 'Tie::IxHash', - 'first' => 'First name', - 'last' => 'Last name', - 'title' => 'Title/Position', - 'comment' => 'Comment', + 'first' => 'First name', + 'last' => 'Last name', + 'title' => 'Title/Position', + 'emailaddress' => 'Email', + 'selfservice_access' => 'Self-service' ; -my @fields = keys %label; + +my $first = 0; +foreach my $phone_type ( qsearch({table=>'phone_type', order_by=>'weight'}) ) { + next if $phone_type->typename =~ /^(Home|Fax)$/; + my $f = 'phonetypenum'.$phone_type->phonetypenum; + $label{$f} = $phone_type->typename. ' phone'; + $size{$f} = $first++ ? 10 : 15; +} + +$label{'comment'} = 'Comment'; + +my @fields = $opt{'name_only'} ? qw( first last ) : keys %label; </%init>