X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=httemplate%2Felements%2Fcontact.html;h=43e520155d3e6864199ae9e44d991327848cc86e;hb=8c36d1e4f1255abb483bc7372fa1908cc192b528;hp=ef74481c046be2a2b932d800901b5314097ba3e5;hpb=aeb90ade381fc3d5477db0334048c2af623fccfe;p=freeside.git
diff --git a/httemplate/elements/contact.html b/httemplate/elements/contact.html
index ef74481c0..43e520155 100644
--- a/httemplate/elements/contact.html
+++ b/httemplate/elements/contact.html
@@ -40,7 +40,10 @@
% }
% } elsif ( $field eq 'emailaddress' ) {
% $value = join(', ', map $_->emailaddress, $contact->contact_email);
-% } elsif ( $field eq 'selfservice_access' || $field eq 'comment' ) {
+% } elsif ( $field eq 'selfservice_access'
+% or $field eq 'comment'
+% or $field eq 'invoice_dest'
+% or $field eq 'message_dest' ) {
% $value = $X_contact->get($field);
% } else {
% $value = $contact->get($field);
@@ -48,24 +51,50 @@
% 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' || $field eq 'message_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 {
>
@@ -83,6 +112,7 @@
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';
@@ -115,12 +145,17 @@ if ( $curr_value ) {
'contactnum' => $curr_value,
'prospectnum' => $opt{'prospectnum'},
});
+ $opt{'for_prospect'} = 1;
} else {
die 'neither custnum nor prospectnum specified';
}
} else {
$contact = new FS::contact {};
- $X_contact = new FS::cust_contact; #arbitrary, it could be prospect_contact
+ if ($opt{'for_prospect'}) {
+ $X_contact = new FS::prospect_contact;
+ } else {
+ $X_contact = new FS::cust_contact;
+ }
}
my %size = ( 'title' => 12 );
@@ -129,13 +164,18 @@ tie my %label, 'Tie::IxHash',
'first' => 'First name',
'last' => 'Last name',
'title' => 'Title/Position',
- 'emailaddress' => 'Email',
- 'selfservice_access' => 'Self-service'
+ 'emailaddress' => 'Email'
;
+unless ($opt{'for_prospect'}) {
+ $label{'invoice_dest'} = 'Send invoices';
+ $label{'message_dest'} = 'Send messages';
+ $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++ ? 10 : 15;
@@ -145,4 +185,7 @@ $label{'comment'} = 'Comment';
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>
|