moving dotransfer to Biblio.pm::ModItemTransfer + some CheckReserves fixes
[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 C4::Auth;
37 use C4::Context;
38 use C4::Output;
39 use C4::Interface::CGI::Output;
40 use C4::Interface::CGI::Template;
41 use CGI;
42 use C4::Members;
43 use Date::Manip;
44 use C4::Date;
45 use C4::Reserves;
46 use C4::Circulation;
47 use C4::Koha;
48 use C4::Letters;
49 use C4::Biblio;
50 use C4::Reserves;
51 use C4::Branch; # GetBranchName
52
53 my $dbh = C4::Context->dbh;
54
55 my $input = new CGI;
56 my $print = $input->param('print');
57 my $template_name;
58
59 if ( $print eq "page" ) {
60     $template_name = "members/moremember-print.tmpl";
61 }
62 elsif ( $print eq "slip" ) {
63     $template_name = "members/moremember-receipt.tmpl";
64 }
65 else {
66     $template_name = "members/moremember.tmpl";
67 }
68
69 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
70     {
71         template_name   => $template_name,
72         query           => $input,
73         type            => "intranet",
74         authnotrequired => 0,
75         flagsrequired   => { borrowers => 1 },
76         debug           => 1,
77     }
78 );
79 my $borrowernumber = $input->param('borrowernumber');
80
81 #start the page and read in includes
82 my $data           = GetMember( $borrowernumber ,'borrowernumber');
83 my $reregistration = $input->param('reregistration');
84
85 if ( not defined $data ) {
86     $template->param (
87         unknowuser => 1
88     );
89     output_html_with_http_headers $input, $cookie, $template->output;
90     exit;
91 }
92
93 # re-reregistration function to automatic calcul of date expiry
94 (
95     $data->{'dateexpiry'} = GetMembeReregistration(
96         $data->{'categorycode'},
97         $borrowernumber, $data->{'dateenrolled'}
98     )
99 ) if ( $reregistration eq 'y' );
100 my $borrowercategory = GetBorrowercategory( $data->{'categorycode'} );
101 my $category_type = $borrowercategory->{'category_type'};
102
103 # in template <TMPL_IF name="I"> => instutitional (A for Adult& C for children) 
104 $template->param( $data->{'categorycode'} => 1 ); 
105
106 $data->{'dateenrolled'} = format_date( $data->{'dateenrolled'} );
107 $data->{'dateexpiry'}   = format_date( $data->{'dateexpiry'} );
108 $data->{'dateofbirth'}  = format_date( $data->{'dateofbirth'} );
109 $data->{'IS_ADULT'}     = ( $data->{'categorycode'} ne 'I' );
110
111 if (   $data->{'debarred'}
112     || $data->{'gonenoaddress'}
113     || $data->{'lost'}
114     || $data->{'borrowernotes'} )
115 {
116     $template->param( flagged => 1 );
117 }
118
119 $data->{'ethnicity'} = fixEthnicity( $data->{'ethnicity'} );
120
121 $data->{ &expand_sex_into_predicate( $data->{'sex'} ) } = 1;
122
123 if ( $category_type eq 'C' and $data->{'guarantorid'} ne '0' ) {
124     my $data2 = GetMember( $data->{'guarantorid'} ,'borrowernumber');
125     $data->{'address'}   = $data2->{'address'};
126     $data->{'city'}      = $data2->{'city'};
127     $data->{'B_address'} = $data2->{'B_address'};
128     $data->{'B_city'}    = $data2->{'B_city'};
129     $data->{'phone'}     = $data2->{'phone'};
130     $data->{'mobile'}    = $data2->{'mobile'};
131     $data->{'zipcode'}   = $data2->{'zipcode'};
132 }
133
134 if ( $data->{'ethnicity'} || $data->{'ethnotes'} ) {
135     $template->param( printethnicityline => 1 );
136 }
137 if ( $category_type eq 'A' ) {
138     $template->param( isguarantee => 1 );
139
140     # FIXME
141     # It looks like the $i is only being returned to handle walking through
142     # the array, which is probably better done as a foreach loop.
143     #
144     my ( $count, $guarantees ) = GetGuarantees( $data->{'borrowernumber'} );
145     my @guaranteedata;
146     for ( my $i = 0 ; $i < $count ; $i++ ) {
147         push(
148             @guaranteedata,
149             {
150                 borrowernumber => $guarantees->[$i]->{'borrowernumber'},
151                 cardnumber     => $guarantees->[$i]->{'cardnumber'},
152                 name           => $guarantees->[$i]->{'firstname'} . " "
153                   . $guarantees->[$i]->{'surname'}
154             }
155         );
156     }
157     $template->param( guaranteeloop => \@guaranteedata );
158     ( $template->param( adultborrower => 1 ) ) if ( $category_type eq 'A' );
159
160 }
161 else {
162     if ($data->{'guarantorid'}){
163       my ($guarantor) = GetMember( $data->{'guarantorid'},'biblionumber');
164       $template->param( 
165               guarantor => 1,
166               guarantorborrowernumber => $guarantor->{'borrowernumber'},
167               guarantorcardnumber     => $guarantor->{'cardnumber'},
168               guarantorfirstname      => $guarantor->{'firstname'},
169               guarantorsurname        => $guarantor->{'surname'}
170           );
171     }
172 }
173
174 #Independant branches management
175 my $unvalidlibrarian =
176   (      ( C4::Context->preference("IndependantBranches") )
177       && ( C4::Context->userenv->{flags} != 1 )
178       && ( $data->{'branchcode'} ne C4::Context->userenv->{branch} ) );
179
180 my %bor;
181 $bor{'borrowernumber'} = $borrowernumber;
182
183 # Converts the branchcode to the branch name
184 my $samebranch;
185 if ( C4::Context->preference("IndependantBranches") ) {
186     my $userenv = C4::Context->userenv;
187     unless ( $userenv->{flags} == 1 ) {
188         $samebranch = ( $data->{'branchcode'} eq $userenv->{branch} );
189     }
190     $samebranch = 1 if ( $userenv->{flags} == 1 );
191 }
192
193 $data->{'branchname'} =
194   ( ( GetBranchDetail( $data->{'branchcode'} ) )->{'branchname'} );
195
196
197 my ( $total, $accts, $numaccts) = GetBorrowerAcctRecord( $borrowernumber );
198 my $lib1 = &GetSortDetails( "Bsort1", $data->{'sort1'} );
199 my $lib2 = &GetSortDetails( "Bsort2", $data->{'sort2'} );
200 ( $template->param( lib1 => $lib1 ) ) if ($lib1);
201 ( $template->param( lib2 => $lib2 ) ) if ($lib2);
202
203 # current issues
204 #
205 my ( $count, $issue ) = GetPendingIssues($borrowernumber);
206 my $roaddetails = &GetRoadTypeDetails( $data->{'streettype'} );
207 my $today       = ParseDate('today');
208 my @issuedata;
209 my $totalprice = 0;
210 my $toggle     = 0;
211 for ( my $i = 0 ; $i < $count ; $i++ ) {
212     my $datedue = ParseDate( $issue->[$i]{'date_due'} );
213     $issue->[$i]{'date_due'} = format_date( $issue->[$i]{'date_due'} );
214     my %row = %{ $issue->[$i] };
215     $totalprice += $issue->[$i]{'replacementprice'};
216     $row{'replacementprice'} = $issue->[$i]{'replacementprice'};
217     if ( $datedue < $today ) {
218         $row{'red'} = 1;    #print "<font color=red>";
219     }
220     $row{toggle} = $toggle++ % 2;
221
222     #find the charge for an item
223     my ( $charge, $itemtype ) =
224       GetIssuingCharges( $issue->[$i]{'itemnumber'}, $borrowernumber );
225
226     my $itemtypeinfo = getitemtypeinfo($itemtype);
227     $row{'itemtype_description'} = $itemtypeinfo->{description};
228     $row{'itemtype_image'}       = $itemtypeinfo->{imageurl};
229
230     $row{'charge'} = sprintf( "%.2f", $charge );
231
232     #check item is not reserved
233     my ( $restype, $reserves ) = CheckReserves( $issue->[$i]{'itemnumber'} );
234     if ($restype) {
235
236 #               print "<TD><a href=/cgi-bin/koha/reserve/request.pl?biblionumber=$issue->[$i]{'biblionumber'}>On Request - no renewals</a></td></tr>";
237 #  } elsif ($issue->[$i]->{'renewals'} > 0) {
238 #      print "<TD>Previously Renewed - no renewals</td></tr>";
239         $row{'norenew'} = 1;
240     }
241     else {
242         $row{'norenew'} = 0;
243     }
244     push( @issuedata, \%row );
245 }
246
247 #
248 # find reserves
249 #
250 # my ($rescount,$reserves)=FindReserves('',$borrowernumber); #From C4::Reserves
251 # my @reservedata;
252 # $toggle = 0;
253 # foreach my $reserveline (@$reserves) {
254 #       $reserveline->{'reservedate2'} = format_date($reserveline->{'reservedate'});
255 #       my $restitle;
256 #       my %row = %$reserveline;
257 #         $row{toggle} = $toggle++%2;
258 #       if ($reserveline->{'constrainttype'} eq 'o'){
259 #               $restitle=GetReserveTitle($reserveline->{'biblionumber'},$reserveline->{'borrowernumber'},$reserveline->{'reservedate'},$reserveline->{'rtimestamp'});
260 #               %row =  (%row , %$restitle) if $restitle;
261 #       }
262 #       push (@reservedata, \%row);
263 # }
264
265 ##################################################################################
266 # BUILD HTML
267 # show all reserves of this borrower, and the position of the reservation ....
268 if ($borrowernumber) {
269
270     # new op dev
271     # now we show the status of the borrower's reservations
272     my @borrowerreserv = GetReservations( 0, $borrowernumber );
273     my @reservloop;
274     foreach my $num_res (@borrowerreserv) {
275         my %getreserv;
276         my $getiteminfo  = GetBiblioFromItemNumber( $num_res->{'itemnumber'} );
277         my $itemtypeinfo = getitemtypeinfo( $getiteminfo->{'itemtype'} );
278         my ( $transfertwhen, $transfertfrom, $transfertto ) =
279           GetTransfers( $num_res->{'itemnumber'} );
280
281         $getreserv{waiting}       = 0;
282         $getreserv{transfered}    = 0;
283         $getreserv{nottransfered} = 0;
284
285         $getreserv{reservedate}    = format_date( $num_res->{'reservedate'} );
286         $getreserv{biblionumber}   = $getiteminfo->{'biblionumber'};
287         $getreserv{title}          = $getiteminfo->{'title'};
288         $getreserv{itemtype}       = $itemtypeinfo->{'description'};
289         $getreserv{author}         = $getiteminfo->{'author'};
290         $getreserv{barcodereserv}  = $getiteminfo->{'barcode'};
291         $getreserv{itemcallnumber} = $getiteminfo->{'itemcallnumber'};
292
293         #               check if we have a waitin status for reservations
294         if ( $num_res->{'found'} eq 'W' ) {
295             $getreserv{color}   = 'reserved';
296             $getreserv{waiting} = 1;
297         }
298
299         #               check transfers with the itemnumber foud in th reservation loop
300         if ($transfertwhen) {
301             $getreserv{color}      = 'transfered';
302             $getreserv{transfered} = 1;
303             $getreserv{datesent}   = format_date($transfertwhen);
304             $getreserv{frombranch} = GetBranchName($transfertfrom);
305         }
306
307         if ( ( $getiteminfo->{'holdingbranch'} ne $num_res->{'branchcode'} )
308             and not $transfertwhen )
309         {
310             $getreserv{nottransfered}   = 1;
311             $getreserv{nottransferedby} =
312               GetBranchName( $getiteminfo->{'holdingbranch'} );
313         }
314
315 #               if we don't have a reserv on item, we put the biblio infos and the waiting position
316         if ( $getiteminfo->{'title'} eq '' ) {
317             my $getbibinfo = GetBiblioItemData( $num_res->{'biblionumber'} );
318             my $getbibtype = getitemtypeinfo( $getbibinfo->{'itemtype'} );
319             $getreserv{color}           = 'inwait';
320             $getreserv{title}           = $getbibinfo->{'title'};
321             $getreserv{waitingposition} = $num_res->{'priority'};
322             $getreserv{nottransfered}   = 0;
323             $getreserv{itemtype}        = $getbibtype->{'description'};
324             $getreserv{author}          = $getbibinfo->{'author'};
325             $getreserv{itemcallnumber}  = '----------';
326              $getreserv{biblionumber}  = $num_res->{'biblionumber'};    
327         }
328
329         push( @reservloop, \%getreserv );
330     }
331
332     # return result to the template
333     $template->param( reservloop => \@reservloop );
334
335 }
336
337 # current alert subscriptions
338 my $alerts = getalert($borrowernumber);
339 foreach (@$alerts) {
340     $_->{ $_->{type} } = 1;
341     $_->{relatedto} = findrelatedto( $_->{type}, $_->{externalid} );
342 }
343 my $picture;
344 my $htdocs = C4::Context->config('intrahtdocs');
345 $picture = "/borrowerimages/" . $borrowernumber . ".jpg";
346 if ( -e $htdocs . "$picture" ) {
347     $template->param( picture => $picture );
348 }
349
350
351 $template->param($data);
352
353 $template->param(
354     roaddetails      => $roaddetails,
355     borrowernumber   => $borrowernumber,
356     reregistration   => $reregistration,
357     totalprice       => sprintf( "%.2f", $totalprice ),
358     totaldue         => sprintf( "%.2f", $total ),
359     issueloop        => \@issuedata,
360     unvalidlibrarian => $unvalidlibrarian,
361     
362     #            reserveloop     => \@reservedata,
363 );
364
365 output_html_with_http_headers $input, $cookie, $template->output;