summaryrefslogtreecommitdiff
path: root/httemplate/browse/reason.html
blob: b017f8f587018e2215c58c02d35869af4db8a9ee (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
<% include( 'elements/browse.html',
                 'title'       => ucfirst($classname) . ' Reasons',
                 'menubar'     => [ # 'Main menu' => $p,
                                    ucfirst($classname) . ' Reason Types' =>
				       $p.'browse/reason_type.html?class='.
				       $class,
                                  ],
                 'html_init'   => $html_init,
                 'name'        => $classname . ' reasons',
                 'query'       => { 'table'     => 'reason',
                                    'hashref'   => {},
                                    'extra_sql' => $where_clause . 
				                   'ORDER BY reason_type', 
                                    'addl_from' => 'LEFT JOIN reason_type ON reason_type.typenum = reason.reason_type', 
                                  },
                 'count_query' => $count_query,
                 'header'      => [ '#',
                                    ucfirst($classname) . ' Reason Type',
                                    ucfirst($classname) . ' Reason',
                                  ],
                 'fields'      => [ 'reasonnum',
                                    sub { shift->reasontype->type },
                                    'reason',
                                  ],
                 'links'       => [ $link,
                                    $link,
                                    '',
                                  ],
             )
%>
<%init>

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

$cgi->param('class') =~ /^(\w)$/ or die "illegal class";
my $class = $1;

my %classmap = ( 'C' => 'cancel',
               'S' => 'suspend',
             );

my $classname = $classmap{$class};

my $html_init = ucfirst($classname) .
" reasons explain why we $classname a package.<BR><BR>".
qq!<A HREF="${p}edit/reason.html?class=$class">!.
"<I>Add a $classname reason</I></A><BR><BR>";

my $where_clause = "WHERE class='$class'";
$where_clause .= " AND (disabled = '' OR disabled IS NULL)"
unless $cgi->param('showdisabled');

my $disabledurl = $cgi->param('showdisabled')
   ? do { $cgi->param('showdisabled', 0);
         '( <a href="'. $cgi->self_url. '">hide disabled reasons</a> )'; }
   : do { $cgi->param('showdisabled', 1);
         '( <a href="'. $cgi->self_url. '">show disabled reasons</a> )'; }
   ;

$html_init .= $disabledurl;

my $count_query = 'SELECT COUNT(*) FROM reason LEFT JOIN reason_type on ' .
                'reason_type.typenum = reason.reason_type ' . $where_clause;

my $link = [ $p."edit/reason.html?class=$class&reasonnum=", 'reasonnum' ];

</%init>