Bug 22122: Rearranged inputs from a patrons basket in Acquisitions.
[koha.git] / members / maninvoice.pl
1 #!/usr/bin/perl
2
3 #written 11/1/2000 by chris@katipo.oc.nz
4 #script to display borrowers account details
5
6
7 # Copyright 2000-2002 Katipo Communications
8 # Copyright 2010 BibLibre
9 #
10 # This file is part of Koha.
11 #
12 # Koha is free software; you can redistribute it and/or modify it
13 # under the terms of the GNU General Public License as published by
14 # the Free Software Foundation; either version 3 of the License, or
15 # (at your option) any later version.
16 #
17 # Koha is distributed in the hope that it will be useful, but
18 # WITHOUT ANY WARRANTY; without even the implied warranty of
19 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 # GNU General Public License for more details.
21 #
22 # You should have received a copy of the GNU General Public License
23 # along with Koha; if not, see <http://www.gnu.org/licenses>.
24
25 use strict;
26 use warnings;
27
28 use C4::Auth;
29 use C4::Output;
30 use CGI qw ( -utf8 );
31 use C4::Members;
32 use C4::Accounts;
33 use C4::Items;
34 use C4::Members::Attributes qw(GetBorrowerAttributes);
35 use Koha::Token;
36
37 use Koha::Patrons;
38
39 use Koha::Patron::Categories;
40
41 my $input=new CGI;
42 my $flagsrequired = { borrowers => 1 };
43
44 my $borrowernumber=$input->param('borrowernumber');
45
46 my $patron = Koha::Patrons->find( $borrowernumber );
47 unless ( $patron ) {
48     print $input->redirect("/cgi-bin/koha/circ/circulation.pl?borrowernumber=$borrowernumber");
49     exit;
50 }
51
52 my $add=$input->param('add');
53 if ($add){
54     if ( checkauth( $input, 0, $flagsrequired, 'intranet' ) ) {
55         die "Wrong CSRF token"
56             unless Koha::Token->new->check_csrf( {
57                 session_id => scalar $input->cookie('CGISESSID'),
58                 token => scalar $input->param('csrf_token'),
59             });
60         #  print $input->header;
61         my $barcode=$input->param('barcode');
62         my $itemnum;
63         if ($barcode) {
64             $itemnum = GetItemnumberFromBarcode($barcode);
65         }
66         my $desc=$input->param('desc');
67         my $amount=$input->param('amount');
68         my $type=$input->param('type');
69         my $note    = $input->param('note');
70         my $error   = manualinvoice( $borrowernumber, $itemnum, $desc, $type, $amount, $note );
71         if ($error) {
72             my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
73                 {   template_name   => "members/maninvoice.tt",
74                     query           => $input,
75                     type            => "intranet",
76                     authnotrequired => 0,
77                     flagsrequired   => $flagsrequired,
78                     debug           => 1,
79                 }
80             );
81             if ( $error =~ /FOREIGN KEY/ && $error =~ /itemnumber/ ) {
82                 $template->param( 'ITEMNUMBER' => 1 );
83             }
84             $template->param( csrf_token => Koha::Token->new->generate_csrf({ session_id => scalar $input->cookie('CGISESSID') }) );
85             $template->param( 'ERROR' => $error );
86             output_html_with_http_headers $input, $cookie, $template->output;
87         } else {
88             print $input->redirect("/cgi-bin/koha/members/boraccount.pl?borrowernumber=$borrowernumber");
89             exit;
90         }
91     }
92 } else {
93
94     my ($template, $loggedinuser, $cookie) = get_template_and_user({
95         template_name   => "members/maninvoice.tt",
96         query           => $input,
97         type            => "intranet",
98         authnotrequired => 0,
99         flagsrequired   => { borrowers => 1,
100                              updatecharges => 'remaining_permissions' },
101         debug           => 1,
102     });
103                                         
104   # get authorised values with type of MANUAL_INV
105   my @invoice_types;
106   my $dbh = C4::Context->dbh;
107   my $sth = $dbh->prepare('SELECT * FROM authorised_values WHERE category = "MANUAL_INV"');
108   $sth->execute();
109   while ( my $row = $sth->fetchrow_hashref() ) {
110     push @invoice_types, $row;
111   }
112   $template->param( invoice_types_loop => \@invoice_types );
113
114     if ( $patron->category->category_type eq 'C') {
115         my $patron_categories = Koha::Patron::Categories->search_limited({ category_type => 'A' }, {order_by => ['categorycode']});
116         $template->param( 'CATCODE_MULTI' => 1) if $patron_categories->count > 1;
117         $template->param( 'catcode' => $patron_categories->next->categorycode )  if $patron_categories->count == 1;
118     }
119
120     $template->param( adultborrower => 1 ) if ( $patron->category->category_type =~ /^(A|I)$/ );
121     $template->param( picture => 1 ) if $patron->image;
122
123     if (C4::Context->preference('ExtendedPatronAttributes')) {
124         my $attributes = GetBorrowerAttributes($borrowernumber);
125         $template->param(
126             ExtendedPatronAttributes => 1,
127             extendedattributes => $attributes
128         );
129     }
130
131     $template->param(%{ $patron->unblessed });
132     $template->param(
133         csrf_token => Koha::Token->new->generate_csrf({ session_id => scalar $input->cookie('CGISESSID') }),
134         finesview      => 1,
135         borrowernumber => $borrowernumber,
136         categoryname   => $patron->category->description,
137         is_child       => ($patron->category->category_type eq 'C'),
138     );
139     output_html_with_http_headers $input, $cookie, $template->output;
140 }