Merge branch 'master' of git://git.koha-community.org/koha into MSWin32
[wip/koha-chris_n.git] / 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 under the
9 # terms of the GNU General Public License as published by the Free Software
10 # Foundation; either version 2 of the License, or (at your option) any later
11 # version.
12 #
13 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
14 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License along
18 # with Koha; if not, write to the Free Software Foundation, Inc.,
19 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20
21 use strict;
22 use warnings;
23 use vars qw($debug);
24
25 use CGI;
26 use autouse 'Data::Dumper' => qw(Dumper);
27
28 use C4::Auth qw(get_template_and_user);
29 use C4::Output qw(output_html_with_http_headers);
30 use autouse 'C4::Branch' => qw(get_branch_code_from_name);
31 use C4::Creators 1.000000;
32 use C4::Patroncards 1.000000;
33 use C4::Labels 1.000000;
34
35 my $cgi = new CGI;
36 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
37     {
38         template_name   => "patroncards/manage.tmpl",
39         query           => $cgi,
40         type            => "intranet",
41         authnotrequired => 0,
42         flagsrequired   => { catalogue => 1 },
43         debug           => 1,
44     }
45 );
46
47 my $op = $cgi->param('op') || 'none';
48 my $card_element = $cgi->param('card_element') || 'template';   # default to template managment
49 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
50
51 my $db_rows = {};
52 my $display_columns = { layout =>   [  # db column       => {col label                  is link?
53                                         {layout_id       => {label => 'Layout ID',      link_field      => 0}},
54                                         {layout_name     => {label => 'Layout',         link_field      => 0}},
55                                         #{layout_xml      => {label => 'Layout XML',     link_field      => 0}},
56                                         {select          => {label => 'Select',         value           => 'layout_id'}},
57                                     ],
58                         template => [   {template_id     => {label => 'Template ID',    link_field      => 0}},
59                                         {template_code   => {label => 'Template Name',  link_field      => 0}},
60                                         {template_desc   => {label => 'Description',    link_field      => 0}},
61                                         {select          => {label => 'Select',         value           => 'template_id'}},
62                                     ],
63                         profile =>  [   {profile_id      => {label => 'Profile ID',     link_field      => 0}},
64                                         {printer_name    => {label => 'Printer Name',   link_field      => 0}},
65                                         {paper_bin       => {label => 'Paper Bin',      link_field      => 0}},
66                                         {_template_code  => {label => 'Template Name',  link_field      => 0}},     # this display column does not have a corrisponding db column in the profile table, hence the underscore
67                                         {select          => {label => 'Select',         value           => 'profile_id'}},
68                                     ],
69                         batch =>    [   {batch_id        => {label => 'Batch ID',       link_field      => 0}},
70                                         {_item_count     => {label => 'Item Count',     link_field      => 0}},
71                                         {select          => {label => 'Select',         value           => 'batch_id'}},
72                                     ],
73 };
74
75 my $errstr = ($cgi->param('error') ? $cgi->param('error') : '');
76 my $branch_code = ($card_element eq 'batch' ? C4::Context->userenv->{'branch'} : '');
77
78 if ($op eq 'delete') {
79     my $err = 0;
80     if          ($card_element eq 'layout')    {$err = C4::Patroncards::Layout::delete(layout_id => $element_id);}
81     elsif       ($card_element eq 'template')  {$err = C4::Patroncards::Template::delete(template_id => $element_id);}
82     elsif       ($card_element eq 'profile')   {$err = C4::Patroncards::Profile::delete(profile_id => $element_id);}
83     elsif       ($card_element eq 'batch')     {$err = C4::Labels::Batch::delete(batch_id => $element_id, branch_code => $branch_code);}
84     else                                       {warn sprintf("Unknown card element passed in for delete operation: %s.",$card_element); $errstr = 202;}
85     print $cgi->redirect("manage.pl?card_element=$card_element" . ($err ? "&error=102" : ''));
86     exit;
87 }
88 elsif ($op eq 'none') {
89     if      ($card_element eq 'layout')    {$db_rows = get_all_layouts(table_name => 'creator_layouts', filter => 'creator=\'Patroncards\'');}
90     elsif   ($card_element eq 'template')  {$db_rows = get_all_templates(table_name => 'creator_templates', filter => 'creator=\'Patroncards\'');}
91     elsif   ($card_element eq 'profile')   {$db_rows = get_all_profiles(table_name => 'printers_profile', filter => 'creator=\'Patroncards\'');}
92     elsif   ($card_element eq 'batch')     {$db_rows = get_batch_summary(filter => "branch_code=\'$branch_code\' OR branch_code=\'NB\'", creator => 'Patroncards');}
93     else                                   {warn sprintf("Unknown card element passed in: %s.",$card_element); $errstr = 202;}
94 }
95 else { # trap unsupported operations here
96     warn sprintf('Manage interface called an unsupported operation: %s',$op);
97     print $cgi->redirect("manage.pl?card_element=$card_element&error=201");
98     exit;
99 }
100
101 my $table = html_table($display_columns->{$card_element}, $db_rows);
102
103 $template->param(print => 1) if ($card_element eq 'batch');
104 $template->param(
105                 error           => ($errstr ? 1 : 0),
106                 $errstr         => 1,
107 );
108 $template->param(
109                 op              => $op,
110                 element_id      => $element_id,
111                 table_loop      => $table,
112                 card_element    => $card_element,
113                 card_element_title     => ($card_element eq 'layout' ? 'Layouts' :
114                                             $card_element eq 'template' ? 'Templates' :
115                                             $card_element eq 'profile' ? 'Profiles' :
116                                             $card_element eq 'batch' ? 'Batches' :
117                                             ''
118                                             ),
119 );
120
121 output_html_with_http_headers $cgi, $cookie, $template->output;