X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Felements%2Fcontact.html;h=faee7ead445c627d9147fd29461e2410ea6f06de;hb=f4209091a9f7120f1961ab2d2efd4d3a00b94268;hp=3efa232464a9dfd1eebd27792597a59f437993c6;hpb=f2e15ed1a7e7b5938f32e1bd961082bed83de662;p=freeside.git diff --git a/httemplate/elements/contact.html b/httemplate/elements/contact.html index 3efa23246..faee7ead4 100644 --- a/httemplate/elements/contact.html +++ b/httemplate/elements/contact.html @@ -2,8 +2,26 @@ -
+ + Type + |
+% } else {
+
+% }
+%
% foreach my $field ( @fields ) {
%
% my $value = '';
@@ -13,7 +31,7 @@
% 'phonetypenum' => $1,
% });
% if ( $contact_phone ) {
-% $value = $contact_phone->phonenum;
+% $value = $contact_phone->phonenum_pretty;
% $value .= 'x'.$contact_phone->extension
% if $contact_phone->extension;
% $value = '+'. $contact_phone->countrycode. " $value"
@@ -22,19 +40,65 @@
% }
% } elsif ( $field eq 'emailaddress' ) {
% $value = join(', ', map $_->emailaddress, $contact->contact_email);
+% } elsif ( $field eq 'selfservice_access'
+% or $field eq 'comment'
+% or $field eq 'invoice_dest' ) {
+% $value = $X_contact->get($field);
% } else {
% $value = $contact->get($field);
% }
- "
- <% $onchange %>
- > +% if ( $field eq 'selfservice_access' ) { + + + <& /elements/change_password.html, + 'contact_num' => $curr_value, + 'custnum' => $opt{'custnum'}, + 'curr_value' => '', + 'no_label_display' => '1', + 'noformtag' => '1', + 'pre_pwd_field_label' => $id.'_', + &> + +% } elsif ( $field eq 'invoice_dest' ) { +% my $curr_value = $cgi->param($name . '_' . $field); +% $curr_value = $value if !defined($curr_value); + <& select.html, + field => $name . '_' . $field, + curr_value => $curr_value, + options => [ '', 'Y' ], + option_labels => { '' => 'no', 'Y' => 'yes' }, + style => 'width: 100%', + &> +% } else { + + > +% } + <% $label{$field} %> |
% }
@@ -46,6 +110,10 @@
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';
@@ -60,32 +128,62 @@ if ( $opt{'onchange'} ) {
$onchange = 'onChange="'. $onchange. '"';
}
+my @contact_class = qsearch('contact_class', { 'disabled' => '' });
+
my $contact;
+my $X_contact;
if ( $curr_value ) {
$contact = qsearchs('contact', { 'contactnum' => $curr_value } );
+ if ( $opt{'custnum'} ) {
+ $X_contact = qsearchs('cust_contact', {
+ 'contactnum' => $curr_value,
+ 'custnum' => $opt{'custnum'},
+ });
+ } elsif ( $opt{'prospectnum'} ) {
+ $X_contact = qsearchs('prospect_contact', {
+ 'contactnum' => $curr_value,
+ 'prospectnum' => $opt{'prospectnum'},
+ });
+ $opt{'for_prospect'} = 1;
+ } else {
+ die 'neither custnum nor prospectnum specified';
+ }
} else {
$contact = new FS::contact {};
+ if ($opt{'for_prospect'}) {
+ $X_contact = new FS::prospect_contact;
+ } else {
+ $X_contact = new FS::cust_contact;
+ }
}
my %size = ( 'title' => 12 );
tie my %label, 'Tie::IxHash',
- 'first' => 'First name',
- 'last' => 'Last name',
- 'title' => 'Title/Position',
- 'emailaddress' => 'Email',
+ 'first' => 'First name',
+ 'last' => 'Last name',
+ 'title' => 'Title/Position',
+ 'emailaddress' => 'Email'
;
+unless ($opt{'for_prospect'}) {
+ $label{'invoice_dest'} = 'Send invoices';
+ $label{'selfservice_access'} = 'Self-service';
+}
+
my $first = 0;
foreach my $phone_type ( qsearch({table=>'phone_type', order_by=>'weight'}) ) {
- next if $phone_type->typename eq 'Home';
+ next if $phone_type->typename =~ /^(Home|Fax)$/;
my $f = 'phonetypenum'.$phone_type->phonetypenum;
$label{$f} = $phone_type->typename. ' phone';
- $size{$f} = $first++ ? 11 : 15;
+ $size{$f} = $first++ ? 10 : 15;
}
$label{'comment'} = 'Comment';
-my @fields = keys %label;
+my @fields = $opt{'name_only'} ? qw( first last ) : keys %label;
+
+my $pwd_change_label = 'Change Password';
+$pwd_change_label = 'Setup Password' unless $contact->_password;
%init>