summaryrefslogtreecommitdiff
path: root/httemplate/edit/cust_main-contacts.html
blob: bae58bd332a686626b8cdec1abf8cea5306d39de (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<% include('elements/edit.html',
     'name_singular'   => 'customer contacts', #yes, we're editing all of them
     'table'           => 'cust_main',
     'post_url'       => popurl(1). 'process/cust_main-contacts.html',
     'labels'          => { 'custnum'     => ' ', #XXX supress this line entirely, its being redundant
                            'contactnum'  => 'Contact',
                            #'locationnum' => '&nbsp;',
                          },
     'fields'          => [
       { 'field'             => 'contactnum',
         'type'              => 'contact',
         'colspan'           => 6,
         'm2m_method'        => 'cust_contact',
         'm2m_dstcol'        => 'contactnum',   
         'm2_label'          => 'Contact',
         'm2_error_callback' => $m2_error_callback,
       },
     ],
     #'new_callback'    => $new_callback,
     #'edit_callback'   => $edit_callback,
     #'error_callback'  => $error_callback,
     'agent_virt'      => 1,
     'menubar'          => [], #remove "view all" link

     #XXX it would be nice if this could instead be after the error but before
     # the table
     'html_init'        => include('/elements/small_custview.html',
                                     $custnum,
                                     $conf->config('countrydefault') || 'US',
                                     1, #no balance
                                  ),
   )
%>
<%init>

my $curuser = $FS::CurrentUser::CurrentUser;
my $conf = new FS::Conf;

my $custnum;
if ( $cgi->param('error') ) {
  $custnum = scalar($cgi->param('custnum'));

  die "access denied"
    unless $curuser->access_right(($custnum ? 'Edit' : 'New'). ' customer'); #contacts?

} elsif ( $cgi->keywords ) { #editing
  $custnum = ($cgi->keywords)[0];

  die "access denied"
    unless $curuser->access_right('Edit customer');

} else { #new customer

  #this doesn't really work here, we're an edit only
  die "guru meditation #32";

  die "access denied"
    unless $curuser->access_right('New customer');

}

#my $new_callback = sub {
#  my( $cgi, $prospect_main, $fields_listref, $opt_hashref ) = @_;
#};

#my $edit_callback = sub {
# my( $cgi, $prospect_main, $fields_listref, $opt_hashref ) = @_;
#};

#my $error_callback = sub {
#  my( $cgi, $prospect_main, $fields_listref, $opt_hashref ) = @_;
#};

my $m2_error_callback = sub {
  my($cgi, $object) = @_;

  #process_o2m fields in process/cust_main-contacts.html
  my @fields = qw( first last title comment );
  my @gfields = ( '', map "_$_", @fields );

  map {
        if ( /^contactnum(\d+)$/ ) {
          my $num = $1;
          if ( grep $cgi->param("contactnum$num$_"), @gfields ) {
            my $x = new FS::contact {
              'contactnum' => scalar($cgi->param("contactnum$num")),
              map { $_ => scalar($cgi->param("contactnum${num}_$_")) } @fields,
            };
            $x;
          } else {
            ();
          }
        } else {
          ();
        }
      }
      $cgi->param;
};

</%init>