bug fixing: there was a 500 error when GetReservesFromBorrowernumber returns an empty...
[koha.git] / members / moremember.pl
1 #!/usr/bin/perl
2
3 # Copyright 2000-2002 Katipo Communications
4 #
5 # This file is part of Koha.
6 #
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 2 of the License, or (at your option) any later
10 # version.
11 #
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License along with
17 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
18 # Suite 330, Boston, MA  02111-1307 USA
19
20 # $Id$
21
22 =head1 moremember.pl
23
24  script to do a borrower enquiry/bring up borrower details etc
25  Displays all the details about a borrower
26  written 20/12/99 by chris@katipo.co.nz
27  last modified 21/1/2000 by chris@katipo.co.nz
28  modified 31/1/2001 by chris@katipo.co.nz
29    to not allow items on request to be renewed
30
31  needs html removed and to use the C4::Output more, but its tricky
32
33 =cut
34
35 use strict;
36 use CGI;
37 use Date::Manip;
38 use C4::Auth;
39 use C4::Context;
40 use C4::Output;
41 use C4::Members;
42 use C4::Date;
43 use C4::Reserves;
44 use C4::Circulation;
45 use C4::Koha;
46 use C4::Letters;
47 use C4::Biblio;
48 use C4::Reserves;
49 use C4::Branch; # GetBranchName
50
51 my $dbh = C4::Context->dbh;
52
53 my $input = new CGI;
54 my $print = $input->param('print');
55 my $template_name;
56
57 if ( $print eq "page" ) {
58     $template_name = "members/moremember-print.tmpl";
59 }
60 elsif ( $print eq "slip" ) {
61     $template_name = "members/moremember-receipt.tmpl";
62 }
63 else {
64     $template_name = "members/moremember.tmpl";
65 }
66
67 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
68     {
69         template_name   => $template_name,
70         query           => $input,
71         type            => "intranet",
72         authnotrequired => 0,
73         flagsrequired   => { borrowers => 1 },
74         debug           => 1,
75     }
76 );
77 my $borrowernumber = $input->param('borrowernumber');
78
79 #start the page and read in includes
80 my $data           = GetMember( $borrowernumber ,'borrowernumber');
81 my $reregistration = $input->param('reregistration');
82
83 if ( not defined $data ) {
84     $template->param (
85         unknowuser => 1
86     );
87     output_html_with_http_headers $input, $cookie, $template->output;
88     exit;
89 }
90
91 # re-reregistration function to automatic calcul of date expiry
92 (
93     $data->{'dateexpiry'} = GetMembeReregistration(
94         $data->{'categorycode'},
95         $borrowernumber, $data->{'dateenrolled'}
96     )
97 ) if ( $reregistration eq 'y' );
98 my $borrowercategory = GetBorrowercategory( $data->{'categorycode'} );
99 my $category_type = $borrowercategory->{'category_type'};
100
101 # in template <TMPL_IF name="I"> => instutitional (A for Adult& C for children) 
102 $template->param( $data->{'categorycode'} => 1 ); 
103
104 $data->{'dateenrolled'} = format_date( $data->{'dateenrolled'} );
105 $data->{'dateexpiry'}   = format_date( $data->{'dateexpiry'} );
106 $data->{'dateofbirth'}  = format_date( $data->{'dateofbirth'} );
107 $data->{'IS_ADULT'}     = ( $data->{'categorycode'} ne 'I' );
108
109 if (   $data->{'debarred'}
110     || $data->{'gonenoaddress'}
111     || $data->{'lost'}
112     || $data->{'borrowernotes'} )
113 {
114     $template->param( flagged => 1 );
115 }
116
117 $data->{'ethnicity'} = fixEthnicity( $data->{'ethnicity'} );
118
119 $data->{ "sex_".$data->{'sex'}."_p" } = 1;
120
121 if ( $category_type eq 'C' and $data->{'guarantorid'} ne '0' ) {
122     my $data2 = GetMember( $data->{'guarantorid'} ,'borrowernumber');
123     $data->{'address'}   = $data2->{'address'};
124     $data->{'city'}      = $data2->{'city'};
125     $data->{'B_address'} = $data2->{'B_address'};
126     $data->{'B_city'}    = $data2->{'B_city'};
127     $data->{'phone'}     = $data2->{'phone'};
128     $data->{'mobile'}    = $data2->{'mobile'};
129     $data->{'zipcode'}   = $data2->{'zipcode'};
130 }
131
132 if ( $data->{'ethnicity'} || $data->{'ethnotes'} ) {
133     $template->param( printethnicityline => 1 );
134 }
135 if ( $category_type eq 'A' ) {
136     $template->param( isguarantee => 1 );
137
138     # FIXME
139     # It looks like the $i is only being returned to handle walking through
140     # the array, which is probably better done as a foreach loop.
141     #
142     my ( $count, $guarantees ) = GetGuarantees( $data->{'borrowernumber'} );
143     my @guaranteedata;
144     for ( my $i = 0 ; $i < $count ; $i++ ) {
145         push(
146             @guaranteedata,
147             {
148                 borrowernumber => $guarantees->[$i]->{'borrowernumber'},
149                 cardnumber     => $guarantees->[$i]->{'cardnumber'},
150                 name           => $guarantees->[$i]->{'firstname'} . " "
151                   . $guarantees->[$i]->{'surname'}
152             }
153         );
154     }
155     $template->param( guaranteeloop => \@guaranteedata );
156     ( $template->param( adultborrower => 1 ) ) if ( $category_type eq 'A' );
157
158 }
159 else {
160     if ($data->{'guarantorid'}){
161       my ($guarantor) = GetMember( $data->{'guarantorid'},'biblionumber');
162       $template->param( 
163               guarantor => 1,
164               guarantorborrowernumber => $guarantor->{'borrowernumber'},
165               guarantorcardnumber     => $guarantor->{'cardnumber'},
166               guarantorfirstname      => $guarantor->{'firstname'},
167               guarantorsurname        => $guarantor->{'surname'}
168           );
169     }
170 }
171
172 #Independant branches management
173 my $unvalidlibrarian =
174   (      ( C4::Context->preference("IndependantBranches") )
175       && ( C4::Context->userenv->{flags} != 1 )
176       && ( $data->{'branchcode'} ne C4::Context->userenv->{branch} ) );
177
178 my %bor;
179 $bor{'borrowernumber'} = $borrowernumber;
180
181 # Converts the branchcode to the branch name
182 my $samebranch;
183 if ( C4::Context->preference("IndependantBranches") ) {
184     my $userenv = C4::Context->userenv;
185     unless ( $userenv->{flags} == 1 ) {
186         $samebranch = ( $data->{'branchcode'} eq $userenv->{branch} );
187     }
188     $samebranch = 1 if ( $userenv->{flags} == 1 );
189 }
190
191 $data->{'branchname'} =
192   ( ( GetBranchDetail( $data->{'branchcode'} ) )->{'branchname'} );
193
194
195 my ( $total, $accts, $numaccts) = GetMemberAccountRecords( $borrowernumber );
196 my $lib1 = &GetSortDetails( "Bsort1", $data->{'sort1'} );
197 my $lib2 = &GetSortDetails( "Bsort2", $data->{'sort2'} );
198 ( $template->param( lib1 => $lib1 ) ) if ($lib1);
199 ( $template->param( lib2 => $lib2 ) ) if ($lib2);
200
201 # current issues
202 #
203 my ( $count, $issue ) = GetPendingIssues($borrowernumber);
204 my $roaddetails = &GetRoadTypeDetails( $data->{'streettype'} );
205 my $today       = ParseDate('today');
206 my @issuedata;
207 my $totalprice = 0;
208 my $toggle     = 0;
209 for ( my $i = 0 ; $i < $count ; $i++ ) {
210     my $datedue = ParseDate( $issue->[$i]{'date_due'} );
211     $issue->[$i]{'date_due'} = format_date( $issue->[$i]{'date_due'} );
212     my %row = %{ $issue->[$i] };
213     $totalprice += $issue->[$i]{'replacementprice'};
214     $row{'replacementprice'} = $issue->[$i]{'replacementprice'};
215     if ( $datedue < $today ) {
216         $row{'red'} = 1;    #print "<font color=red>";
217     }
218     $row{toggle} = $toggle++ % 2;
219
220     #find the charge for an item
221     my ( $charge, $itemtype ) =
222       GetIssuingCharges( $issue->[$i]{'itemnumber'}, $borrowernumber );
223
224     my $itemtypeinfo = getitemtypeinfo($itemtype);
225     $row{'itemtype_description'} = $itemtypeinfo->{description};
226     $row{'itemtype_image'}       = $itemtypeinfo->{imageurl};
227
228     $row{'charge'} = sprintf( "%.2f", $charge );
229
230     #check item is not reserved
231     my ( $restype, $reserves ) = CheckReserves( $issue->[$i]{'itemnumber'} );
232     if ($restype) {
233
234 #               print "<TD><a href=/cgi-bin/koha/reserve/request.pl?biblionumber=$issue->[$i]{'biblionumber'}>On Request - no renewals</a></td></tr>";
235 #  } elsif ($issue->[$i]->{'renewals'} > 0) {
236 #      print "<TD>Previously Renewed - no renewals</td></tr>";
237         $row{'norenew'} = 1;
238     }
239     else {
240         $row{'norenew'} = 0;
241     }
242     push( @issuedata, \%row );
243 }
244
245 ##################################################################################
246 # BUILD HTML
247 # show all reserves of this borrower, and the position of the reservation ....
248 if ($borrowernumber) {
249
250     # new op dev
251     # now we show the status of the borrower's reservations
252     my @borrowerreserv = GetReservesFromBorrowernumber($borrowernumber );
253     my @reservloop;
254     
255     foreach my $num_res (@borrowerreserv) {
256                 next if not scalar @$num_res;
257     
258         my %getreserv;
259         
260         my $getiteminfo  = GetBiblioFromItemNumber( $num_res->{'itemnumber'} );
261         my $itemtypeinfo = getitemtypeinfo( $getiteminfo->{'itemtype'} );
262         my ( $transfertwhen, $transfertfrom, $transfertto ) =
263           GetTransfers( $num_res->{'itemnumber'} );
264
265         $getreserv{waiting}       = 0;
266         $getreserv{transfered}    = 0;
267         $getreserv{nottransfered} = 0;
268
269         $getreserv{reservedate}    = format_date( $num_res->{'reservedate'} );
270         $getreserv{biblionumber}   = $getiteminfo->{'biblionumber'};
271         $getreserv{title}          = $getiteminfo->{'title'};
272         $getreserv{itemtype}       = $itemtypeinfo->{'description'};
273         $getreserv{author}         = $getiteminfo->{'author'};
274         $getreserv{barcodereserv}  = $getiteminfo->{'barcode'};
275         $getreserv{itemcallnumber} = $getiteminfo->{'itemcallnumber'};
276
277         #               check if we have a waitin status for reservations
278         if ( $num_res->{'found'} eq 'W' ) {
279             $getreserv{color}   = 'reserved';
280             $getreserv{waiting} = 1;
281         }
282
283         #               check transfers with the itemnumber foud in th reservation loop
284         if ($transfertwhen) {
285             $getreserv{color}      = 'transfered';
286             $getreserv{transfered} = 1;
287             $getreserv{datesent}   = format_date($transfertwhen);
288             $getreserv{frombranch} = GetBranchName($transfertfrom);
289         }
290
291         if ( ( $getiteminfo->{'holdingbranch'} ne $num_res->{'branchcode'} )
292             and not $transfertwhen )
293         {
294             $getreserv{nottransfered}   = 1;
295             $getreserv{nottransferedby} =
296               GetBranchName( $getiteminfo->{'holdingbranch'} );
297         }
298
299 #               if we don't have a reserv on item, we put the biblio infos and the waiting position
300         if ( $getiteminfo->{'title'} eq '' ) {
301             my $getbibinfo = GetBiblioItemData( $num_res->{'biblionumber'} );
302             my $getbibtype = getitemtypeinfo( $getbibinfo->{'itemtype'} );
303             $getreserv{color}           = 'inwait';
304             $getreserv{title}           = $getbibinfo->{'title'};
305             $getreserv{waitingposition} = $num_res->{'priority'};
306             $getreserv{nottransfered}   = 0;
307             $getreserv{itemtype}        = $getbibtype->{'description'};
308             $getreserv{author}          = $getbibinfo->{'author'};
309             $getreserv{itemcallnumber}  = '----------';
310              $getreserv{biblionumber}  = $num_res->{'biblionumber'};    
311         }
312
313         push( @reservloop, \%getreserv );
314     }
315
316     # return result to the template
317     $template->param( reservloop => \@reservloop );
318
319 }
320
321 # current alert subscriptions
322 my $alerts = getalert($borrowernumber);
323 foreach (@$alerts) {
324     $_->{ $_->{type} } = 1;
325     $_->{relatedto} = findrelatedto( $_->{type}, $_->{externalid} );
326 }
327 my $picture;
328 my $htdocs = C4::Context->config('intrahtdocs');
329 $picture = "/borrowerimages/" . $borrowernumber . ".jpg";
330 if ( -e $htdocs . "$picture" ) {
331     $template->param( picture => $picture );
332 }
333
334
335 $template->param($data);
336
337 $template->param(
338     roaddetails      => $roaddetails,
339     borrowernumber   => $borrowernumber,
340     reregistration   => $reregistration,
341     totalprice       => sprintf( "%.2f", $totalprice ),
342     totaldue         => sprintf( "%.2f", $total ),
343     issueloop        => \@issuedata,
344     unvalidlibrarian => $unvalidlibrarian,
345     
346     #            reserveloop     => \@reservedata,
347 );
348
349 output_html_with_http_headers $input, $cookie, $template->output;