a2e9546428b4af31b35def33783d4477be9e2c0f
[srvgit] / patroncards / 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 CGI qw ( -utf8 );
24 use autouse 'Data::Dumper' => qw(Dumper);
25
26 use C4::Auth qw(get_template_and_user);
27 use C4::Output qw(output_html_with_http_headers);
28 use C4::Creators;
29 use C4::Patroncards;
30 use C4::Labels;
31 use Koha::List::Patron;
32
33 my $cgi = CGI->new;
34 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
35     {
36         template_name   => "patroncards/manage.tt",
37         query           => $cgi,
38         type            => "intranet",
39         flagsrequired   => { tools => 'label_creator' },
40     }
41 );
42
43 my $op = $cgi->param('op') || 'none';
44 my $card_element = $cgi->param('card_element') || 'template';   # default to template management
45 my $element_id = $cgi->param('element_id') || 0; # there should never be an element with a id of 0 so this is a safe default
46
47 my $db_rows = {};
48 my $display_columns = { layout =>   [  # db column       => {col label                  is link?
49                                         {layout_id       => {label => 'Layout ID',      link_field      => 0}},
50                                         {layout_name     => {label => 'Layout',         link_field      => 0}},
51                                         {_action         => {label => 'Action',         link_field      => 0}},
52                                         #{layout_xml      => {label => 'Layout XML',     link_field      => 0}},
53                                         {select          => {label => 'Select',         value           => 'layout_id'}},
54                                     ],
55                         template => [   {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                                         {_action         => {label => 'Action',         link_field      => 0}},
59                                         {select          => {label => 'Select',         value           => 'template_id'}},
60                                     ],
61                         profile =>  [   {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                                         {_action         => {label => 'Action',         link_field      => 0}},
66                                         {select          => {label => 'Select',         value           => 'profile_id'}},
67                                     ],
68                         batch =>    [   {batch_id        => {label => 'Batch ID',       link_field      => 0}},
69                                         {description     => {label => 'Description',    link_field      => 0}},
70                                         {_item_count     => {label => 'Patron Count',   link_field      => 0}},
71                                         {_action         => {label => 'Actions',        link_field      => 0}},
72                                         {select          => {label => 'Select',         value           => 'batch_id'}},
73                                     ],
74 };
75
76 my $errstr = ($cgi->param('error') ? $cgi->param('error') : '');
77 my $branch_code = ($card_element eq 'batch' ? C4::Context->userenv->{'branch'} : '');
78
79 if ($op eq 'delete') {
80     my $err = 0;
81     my @element_ids = split(/,/, $element_id);
82     foreach my $element_id (@element_ids) {
83         if          ($card_element eq 'layout')    {$err = C4::Patroncards::Layout::delete(layout_id => $element_id);}
84         elsif       ($card_element eq 'template')  {$err = C4::Patroncards::Template::delete(template_id => $element_id);}
85         elsif       ($card_element eq 'profile')   {$err = C4::Patroncards::Profile::delete(profile_id => $element_id);}
86         elsif       ($card_element eq 'batch')     {$err = C4::Labels::Batch::delete(batch_id => $element_id, branch_code => $branch_code);}
87         else                                       {warn sprintf("Unknown card element passed in for delete operation: %s.",$card_element); $errstr = 202;}
88     }
89     print $cgi->redirect("manage.pl?card_element=$card_element" . ($err ? "&error=102" : ''));
90     exit;
91 }
92 elsif ($op eq 'none') {
93     if      ($card_element eq 'layout')    {$db_rows = get_all_layouts( { filters => { creator => 'Patroncards' } });}
94     elsif   ($card_element eq 'template')  {$db_rows = get_all_templates( { filters => { creator => 'Patroncards' } });}
95     elsif   ($card_element eq 'profile')   {$db_rows = get_all_profiles( { filters => { creator => 'Patroncards' } });}
96     elsif   ($card_element eq 'batch')     {$db_rows = get_batch_summary( { filters => { branch_code => [ $branch_code, 'NB' ], creator => 'Patroncards' } });}
97     else                                   {warn sprintf("Unknown card element passed in: %s.",$card_element); $errstr = 202;}
98 }
99 else { # trap unsupported operations here
100     warn sprintf('Manage interface called an unsupported operation: %s',$op);
101     print $cgi->redirect("manage.pl?card_element=$card_element&error=201");
102     exit;
103 }
104
105 my $table = html_table($display_columns->{$card_element}, $db_rows);
106
107 $template->param(print => 1) if ($card_element eq 'batch');
108 $template->param( patron_lists => [ GetPatronLists() ] ) if ($card_element eq 'batch');
109
110 $template->param(
111                 error           => $errstr,
112 );
113 $template->param(
114                 op              => $op,
115                 element_id      => $element_id,
116                 table_loop      => $table,
117                 card_element    => $card_element,
118                 card_element_title     => ($card_element eq 'layout' ? 'Layouts' :
119                                             $card_element eq 'template' ? 'Templates' :
120                                             $card_element eq 'profile' ? 'Profiles' :
121                                             $card_element eq 'batch' ? 'Batches' :
122                                             ''
123                                             ),
124 );
125
126 output_html_with_http_headers $cgi, $cookie, $template->output;