summaryrefslogtreecommitdiff
path: root/httemplate/edit/access_group.html
blob: b5757afca0121420c77898562557115fbed7f4b8 (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
<% include( 'elements/edit.html',
              'name'   => 'Employee Group',
              'table'  => 'access_group',
              'labels' => { 
                            'groupnum'   => 'Group number',
                            'groupname'  => 'Group name',
                          },

              'viewall_dir' => 'browse',

              'html_bottom' => $html_bottom_sub,
          )
%>
<%once>

tie my %rights, 'Tie::IxHash', FS::AccessRight->rights_info;

</%once>
<%init>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Configuration');

my $html_bottom_sub = sub {
  my $access_group = shift;

  #some false laziness w/browse/access_group.html
  my $columns = 3;
  my $count = 0;

  '<BR>'.
  '<FONT SIZE="+1">Group limited to these agent(s)</FONT><BR>'.
  'Employees in this group will only see customers of the selected agents in the system and reports.<BR>'.
  ntable("#cccccc",2).
  '<TR><TD>'.
  include( '/elements/checkboxes-table.html',
             'source_obj'   => $access_group,
             'link_table'   => 'access_groupagent',
             'target_table' => 'agent',
             'name_col'     => 'agent',
             'target_link'  => $p.'edit/agent.cgi?',
             'disable-able' => 1,
         ).
  '</TD></TR></TABLE>'.

  '<BR><FONT SIZE="+1">Group access rights</FONT><BR>'.
  include('/elements/table-grid.html', bgcolor=>'#cccccc' ).
  '<TR>'. join( '', map {
    '<TD CLASS="inv" VALIGN="top"><TABLE BGCOLOR="#cccccc" WIDTH=100%>'.
    '<TR><TH BGCOLOR="#dcdcdc">'. $_. '</TH></TR>'.
    '<TR><TD>'.
    include( '/elements/checkboxes-table-name.html',
               'source_obj'   => $access_group,
               'link_table'   => 'access_right',
               'link_static'  => { 'righttype' =>
                                     'FS::access_group',
                                 },
               'num_col'      => 'rightobjnum',
               'name_col'     => 'rightname',
               'names_list'   => [ map { 
                                         my $rn =
                                           ref($_) ? $_->{'rightname'} : $_;
                                         my %hash = ();
                                         $hash{'note'} = '&nbsp;*'
                                           if ref($_) && $_->{'global'};
                                         $hash{'desc'} = $_->{'desc'}
                                           if ref($_) &&  $_->{'desc'};
                                         [ $rn => \%hash ];
                                       }
                                       @{ $rights{$_} }
                                 ],
           ).
    '<BR>'.
    '</TD></TR></TABLE></TD>'.
    ( ++$count % $columns ? '' : '</TR><TR>')
  
  } keys %rights ). '</TR></TABLE>'.
  
  '* Global rights.  These rights provide access to global data which is shared among all agents.  Their use is not recommended for groups which are limited to a subset of agents.<BR>';

};

</%init>