its all about control
[freeside.git] / httemplate / browse / reason.html
1 <% include( 'elements/browse.html',
2                  'title'       => ucfirst($classname) . ' Reasons',
3                  'menubar'     => [ # 'Main menu' => $p,
4                                     ucfirst($classname) . ' Reason Types' =>
5                                        $p.'browse/reason_type.html?class='.
6                                        $class,
7                                   ],
8                  'html_init'   => $html_init,
9                  'name'        => $classname . ' reasons',
10                  'query'       => { 'table'     => 'reason',
11                                     'hashref'   => {},
12                                     'extra_sql' => $where_clause . 
13                                                    'ORDER BY reason_type', 
14                                     'addl_from' => 'LEFT JOIN reason_type ON reason_type.typenum = reason.reason_type', 
15                                   },
16                  'count_query' => $count_query,
17                  'header'      => [ '#',
18                                     ucfirst($classname) . ' Reason Type',
19                                     ucfirst($classname) . ' Reason',
20                                   ],
21                  'fields'      => [ 'reasonnum',
22                                     sub { shift->reasontype->type },
23                                     'reason',
24                                   ],
25                  'links'       => [ $link,
26                                     $link,
27                                     '',
28                                   ],
29              )
30 %>
31 <%init>
32
33 die "access denied"
34   unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
35
36 $cgi->param('class') =~ /^(\w)$/ or die "illegal class";
37 my $class = $1;
38
39 my %classmap = ( 'C' => 'cancel',
40                'S' => 'suspend',
41              );
42
43 my $classname = $classmap{$class};
44
45 my $html_init = ucfirst($classname) .
46 " reasons explain why we $classname a package.<BR><BR>".
47 qq!<A HREF="${p}edit/reason.html?class=$class">!.
48 "<I>Add a $classname reason</I></A><BR><BR>";
49
50 my $where_clause = "WHERE class='$class'";
51 $where_clause .= " AND (disabled = '' OR disabled IS NULL)"
52 unless $cgi->param('showdisabled');
53
54 my $disabledurl = $cgi->param('showdisabled')
55    ? do { $cgi->param('showdisabled', 0);
56          '( <a href="'. $cgi->self_url. '">hide disabled reasons</a> )'; }
57    : do { $cgi->param('showdisabled', 1);
58          '( <a href="'. $cgi->self_url. '">show disabled reasons</a> )'; }
59    ;
60
61 $html_init .= $disabledurl;
62
63 my $count_query = 'SELECT COUNT(*) FROM reason LEFT JOIN reason_type on ' .
64                 'reason_type.typenum = reason.reason_type ' . $where_clause;
65
66 my $link = [ $p."edit/reason.html?class=$class&reasonnum=", 'reasonnum' ];
67
68 </%init>