42396: Prospect creation without contact (v4+) [hide fields prospect doesn't use]
[freeside.git] / httemplate / elements / contact.html
index ef74481..b0a7cac 100644 (file)
@@ -40,7 +40,9 @@
 %         }
 %       } 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' ) {
 %         $value = $X_contact->get($field);
 %       } else {
 %         $value = $contact->get($field);
 %               }
 %             }
             </SELECT>
-
+%         } 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 {
             <INPUT TYPE  = "text"
                    NAME  = "<%$name%>_<%$field%>"
                    ID    = "<%$id%>_<%$field%>"
                    SIZE  = "<% $size{$field} || 14 %>"
-                   VALUE = "<% scalar($cgi->param($name."_$field"))
+                   VALUE = "<% scalar($cgi->param($name . '_' . $field))
                                || $value |h %>"
                    <% $onchange %>
             >
@@ -115,12 +126,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 +145,17 @@ 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{'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;