Bug 10572: Add phone to message_transport_types table for new installs
[koha.git] / opac / opac-account.pl
index 94fc308..c3cb9b4 100755 (executable)
@@ -1,48 +1,79 @@
 #!/usr/bin/perl
 
-# wrriten 15/10/2002 by finlay@katipo.oc.nz
-# script to display borrowers account details in the opac
+# Copyright Katipo Communications 2002
+# Copyright Biblibre 2007,2010
+#
+# This file is part of Koha.
+#
+# Koha is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or (at your option) any later
+# version.
+#
+# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along
+# with Koha; if not, write to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+
 
 use strict;
-use C4::Output;
 use CGI;
-use C4::Search;
-use C4::Circulation::Circ2;
+use C4::Members;
+use C4::Circulation;
 use C4::Auth;
+use C4::Output;
+use warnings;
 
 my $query = new CGI;
-
-my $flagsrequired;
-$flagsrequired->{borrow}=1;
-
-my ($loggedinuser, $cookie, $sessionID) = checkauth($query, 0, $flagsrequired);
-
-my $template = gettemplate("opac-account.tmpl", "opac");
+my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
+    {
+        template_name   => "opac-account.tmpl",
+        query           => $query,
+        type            => "opac",
+        authnotrequired => 0,
+        flagsrequired   => { borrow => 1 },
+        debug           => 1,
+    }
+);
 
 # get borrower information ....
-my $borrowernumber = getborrowernumber($loggedinuser);
-my ($borr, $flags) = getpatroninformation(undef, $borrowernumber);
-
+my $borr = GetMemberDetails( $borrowernumber );
 my @bordat;
 $bordat[0] = $borr;
 
 $template->param( BORROWER_INFO => \@bordat );
 
-
 #get account details
-my ($numaccts,$accts,$total) = getboracctrecord(undef,$borr);   
+my ( $total , $accts, $numaccts) = GetMemberAccountRecords( $borrowernumber );
 
-for (my $i=0;$i<$numaccts;$i++){
-    $accts->[$i]{'amount'}+=0.00;
-    $accts->[$i]{'amountoutstanding'}+=0.00;
-    if ($accts->[$i]{'accounttype'} ne 'F' && $accts->[$i]{'accounttype'} ne 'FU'){
-       $accts->[$i]{'print_title'};
+for ( my $i = 0 ; $i < $numaccts ; $i++ ) {
+    $accts->[$i]{'amount'} = sprintf( "%.2f", $accts->[$i]{'amount'} || '0.00');
+    if ( $accts->[$i]{'amount'} >= 0 ) {
+        $accts->[$i]{'amountcredit'} = 1;
     }
+    $accts->[$i]{'amountoutstanding'} =
+      sprintf( "%.2f", $accts->[$i]{'amountoutstanding'} || '0.00' );
+    if ( $accts->[$i]{'amountoutstanding'} >= 0 ) {
+        $accts->[$i]{'amountoutstandingcredit'} = 1;
+    }
+}
+
+# add the row parity
+my $num = 0;
+foreach my $row (@$accts) {
+    $row->{'even'} = 1 if $num % 2 == 0;
+    $row->{'odd'}  = 1 if $num % 2 == 1;
+    $num++;
 }
 
-$template->param( ACCOUNT_LINES => $accts );
+$template->param (
+    ACCOUNT_LINES => $accts,
+    total => sprintf( "%.2f", $total ),
+       accountview => 1
+);
 
-$template->param( total => $total );
+output_html_with_http_headers $query, $cookie, $template->output;
 
-$template->param( loggedinuser => $loggedinuser );
-print "Content-Type: text/html\n\n", $template->output;