Bug 22216: Make GET /patrons/{patron_id} staff only
[koha.git] / labels / label-manage.pl
1 #!/usr/bin/perl
2 #
3 # Copyright 2006 Katipo Communications.
4 # Parts Copyright 2009 Foundations Bible College.
5 #
6 # This file is part of Koha.
7 #
8 # Koha is free software; you can redistribute it and/or modify it
9 # under the terms of the GNU General Public License as published by
10 # the Free Software Foundation; either version 3 of the License, or
11 # (at your option) any later version.
12 #
13 # Koha is distributed in the hope that it will be useful, but
14 # WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 # GNU General Public License for more details.
17 #
18 # You should have received a copy of the GNU General Public License
19 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20
21 use Modern::Perl;
22
23 use vars qw($debug);
24
25 use CGI qw ( -utf8 );
26 use Data::Dumper;
27
28 use C4::Auth qw(get_template_and_user);
29 use C4::Output qw(output_html_with_http_headers);
30 use C4::Creators;
31 use C4::Labels;
32
33 my $cgi = new CGI;
34 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
35     {
36         template_name   => "labels/label-manage.tt",
37         query           => $cgi,
38         type            => "intranet",
39         authnotrequired => 0,
40         flagsrequired   => { catalogue => 1 },
41         debug           => 1,
42     }
43 );
44
45 my $db_rows = {};
46 my $display_columns = { layout =>   [  # db column       => {col label                  is link?
47                                         {layout_id       => {label => 'Layout ID',      link_field      => 0}},
48                                         {layout_name     => {label => 'Layout',         link_field      => 0}},
49                                         {barcode_type    => {label => 'Barcode Type',   link_field      => 0}},
50                                         {printing_type   => {label => 'Print Type',     link_field      => 0}},
51                                         {format_string   => {label => 'Fields to Print',link_field      => 0}},
52                                         {select         => {label => 'Actions',         value           => 'layout_id'}},
53                                     ],
54                         template => [
55                                         {template_id     => {label => 'Template ID',    link_field      => 0}},
56                                         {template_code   => {label => 'Template Name',  link_field      => 0}},
57                                         {template_desc   => {label => 'Description',    link_field      => 0}},
58                                         {select         => {label => 'Actions',         value           => 'template_id'}},
59                                     ],
60                         profile =>  [
61                                         {profile_id      => {label => 'Profile ID',     link_field      => 0}},
62                                         {printer_name    => {label => 'Printer Name',   link_field      => 0}},
63                                         {paper_bin       => {label => 'Paper Bin',      link_field      => 0}},
64                                         {_template_code  => {label => 'Template Name',  link_field      => 0}},     # this display column does not have a corresponding db column in the profile table, hence the underscore
65                                         {select          => {label => 'Actions',         value           => 'profile_id'}},
66                                     ],
67                         batch =>    [
68                                         {batch_id        => {label => 'Batch ID',       link_field      => 0}},
69                                         {description     => {label => 'Description',    link_field      => 0}},
70                                         {_item_count     => {label => 'Item Count',     link_field      => 0}},
71                                         {select          => {label => 'Actions',         value           => 'batch_id'}},
72                                         {select1         => {label => ' ',           link_field       => 'batch_id'}},
73                                     ],
74 };
75
76 my $label_element = $cgi->param('label_element') || 'template';   # default to template management
77 my $op = $cgi->param('op') || 'none';
78 my $element_id = $cgi->param('element_id') || undef;
79 my $error = $cgi->param('error') || 0;
80
81 my $branch_code = ($label_element eq 'batch' ? C4::Context->userenv->{'branch'} : '');
82
83 if ($op eq 'delete') {
84     if          ($label_element eq 'layout')    {$error = C4::Labels::Layout::delete(layout_id => $element_id);}
85     elsif       ($label_element eq 'template')  {$error = C4::Labels::Template::delete(template_id => $element_id);}
86     elsif       ($label_element eq 'profile')   {$error = C4::Labels::Profile::delete(profile_id => $element_id);}
87     elsif       ($label_element eq 'batch')     {$error = C4::Labels::Batch::delete(batch_id => $element_id, branch_code => $branch_code);}
88     else                                        {}      # FIXME: Some error trapping code
89 }
90
91 if      ($label_element eq 'layout')    {$db_rows = get_all_layouts( { filters => { creator => 'Labels' } });}
92 elsif   ($label_element eq 'template')  {$db_rows = get_all_templates( { filters => { creator => 'Labels' } });}
93 elsif   ($label_element eq 'profile')   {$db_rows = get_all_profiles( { filters => { creator => 'Labels' } });}
94 elsif   ($label_element eq 'batch')     {$db_rows = get_batch_summary( { filters => { branch_code => [$branch_code, 'NB'], creator => 'Labels' } });}
95 else                                    {}      # FIXME: Some error trapping code
96
97 my $table = html_table($display_columns->{$label_element}, $db_rows);
98
99 $template->param(error => $error) if ($error) && ($error ne 0);
100 $template->param(print => 1) if ($label_element eq 'batch');
101 $template->param(
102     op              => $op,
103     element_id      => $element_id,
104     table_loop      => $table,
105     label_element   => $label_element,
106     label_element_title => (
107         $label_element eq 'layout'   ? 'Layouts' :
108         $label_element eq 'template' ? 'Templates' :
109         $label_element eq 'profile'  ? 'Profiles' :
110         $label_element eq 'batch'    ? 'Batches' :
111         '' )
112 );
113
114 output_html_with_http_headers $cgi, $cookie, $template->output;