Bug 14266: Replace trim() with $.trim() in opac-shareshelf.tt
[koha.git] / members / boraccount.pl
blob8b1b7bd443666d89d333189b3e078d11b20a45c8
1 #!/usr/bin/perl
4 #writen 11/1/2000 by chris@katipo.oc.nz
5 #script to display borrowers account details
8 # Copyright 2000-2002 Katipo Communications
10 # This file is part of Koha.
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.
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.
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>.
25 use strict;
26 use warnings;
28 use C4::Auth;
29 use C4::Output;
30 use CGI qw ( -utf8 );
31 use C4::Members;
32 use C4::Branch;
33 use C4::Accounts;
34 use C4::Members::Attributes qw(GetBorrowerAttributes);
36 my $input=new CGI;
39 my ($template, $loggedinuser, $cookie) = get_template_and_user(
41 template_name => "members/boraccount.tt",
42 query => $input,
43 type => "intranet",
44 authnotrequired => 0,
45 flagsrequired => { borrowers => 1,
46 updatecharges => 'remaining_permissions'},
47 debug => 1,
51 my $borrowernumber=$input->param('borrowernumber');
52 my $action = $input->param('action') || '';
54 #get borrower details
55 my $data=GetMember('borrowernumber' => $borrowernumber);
57 if ( $action eq 'reverse' ) {
58 ReversePayment( $input->param('accountlines_id') );
61 if ( $data->{'category_type'} eq 'C') {
62 my ( $catcodes, $labels ) = GetborCatFromCatType( 'A', 'WHERE category_type = ?' );
63 my $cnt = scalar(@$catcodes);
64 $template->param( 'CATCODE_MULTI' => 1) if $cnt > 1;
65 $template->param( 'catcode' => $catcodes->[0]) if $cnt == 1;
68 #get account details
69 my ($total,$accts,undef)=GetMemberAccountRecords($borrowernumber);
70 my $totalcredit;
71 if($total <= 0){
72 $totalcredit = 1;
75 my $reverse_col = 0; # Flag whether we need to show the reverse column
76 foreach my $accountline ( @{$accts}) {
77 $accountline->{amount} += 0.00;
78 if ($accountline->{amount} <= 0 ) {
79 $accountline->{amountcredit} = 1;
81 $accountline->{amountoutstanding} += 0.00;
82 if ( $accountline->{amountoutstanding} <= 0 ) {
83 $accountline->{amountoutstandingcredit} = 1;
86 $accountline->{amount} = sprintf '%.2f', $accountline->{amount};
87 $accountline->{amountoutstanding} = sprintf '%.2f', $accountline->{amountoutstanding};
88 if ($accountline->{accounttype} =~ /^Pay/) {
89 $accountline->{payment} = 1;
90 $reverse_col = 1;
94 $template->param( adultborrower => 1 ) if ( $data->{'category_type'} eq 'A' );
96 my ($picture, $dberror) = GetPatronImage($data->{'borrowernumber'});
97 $template->param( picture => 1 ) if $picture;
99 if (C4::Context->preference('ExtendedPatronAttributes')) {
100 my $attributes = GetBorrowerAttributes($borrowernumber);
101 $template->param(
102 ExtendedPatronAttributes => 1,
103 extendedattributes => $attributes
107 my $roadtype = C4::Koha::GetAuthorisedValueByCode( 'ROADTYPE', $data->{streettype} );
109 #workaround for Bug 4041 to get rid of duplicated code in circ-menu.tt, use circ-menu.inc instad
110 $template->param(%$data);
112 $template->param(
113 finesview => 1,
114 borrowernumber => $borrowernumber,
115 roadtype => $roadtype,
116 branchname => GetBranchName($data->{'branchcode'}),
117 total => sprintf("%.2f",$total),
118 totalcredit => $totalcredit,
119 is_child => ($data->{'category_type'} eq 'C'),
120 reverse_col => $reverse_col,
121 accounts => $accts,
122 activeBorrowerRelationship => (C4::Context->preference('borrowerRelationship') ne ''),
123 RoutingSerials => C4::Context->preference('RoutingSerials'),
126 output_html_with_http_headers $input, $cookie, $template->output;