Merge remote branch 'kc/new/bug2567' into kcmaster
[wip/koha-chris_n.git] / reserve / modrequest.pl
1 #!/usr/bin/perl
2
3 #script to modify reserves/requests
4 #written 2/1/00 by chris@katipo.oc.nz
5 #last update 27/1/2000 by chris@katipo.co.nz
6
7
8 # Copyright 2000-2002 Katipo Communications
9 #
10 # This file is part of Koha.
11 #
12 # Koha is free software; you can redistribute it and/or modify it under the
13 # terms of the GNU General Public License as published by the Free Software
14 # Foundation; either version 2 of the License, or (at your option) any later
15 # version.
16 #
17 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
18 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
19 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
20 #
21 # You should have received a copy of the GNU General Public License along
22 # with Koha; if not, write to the Free Software Foundation, Inc.,
23 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24
25 use strict;
26 use warnings;
27 use CGI;
28 use C4::Output;
29 use C4::Reserves;
30 use C4::Auth;
31
32 my $query = new CGI;
33 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
34     {   
35         template_name   => "about.tmpl",
36         query           => $query,
37         type            => "intranet",
38         authnotrequired => 0,
39         flagsrequired   => { catalogue => 1 },
40         debug           => 1,
41     }
42 );
43
44 my @rank=$query->param('rank-request');
45 my @biblionumber=$query->param('biblionumber');
46 my @borrower=$query->param('borrowernumber');
47 my @branch=$query->param('pickup');
48 my @itemnumber=$query->param('itemnumber');
49 my $multi_hold = $query->param('multi_hold');
50 my $biblionumbers = $query->param('biblionumbers');
51 my $count=@rank;
52
53 my $CancelBiblioNumber=$query->param('CancelBiblioNumber');
54 my $CancelBorrowerNumber=$query->param('CancelBorrowerNumber');
55 my $CancelItemnumber=$query->param('CancelItemnumber');
56
57 # 2 possibilitys : cancel an item reservation, or modify or cancel the queded list
58
59 # 1) cancel an item reservation by fonction ModReserveCancelAll (in reserves.pm)
60 if ($CancelBorrowerNumber) {
61     ModReserveCancelAll($CancelItemnumber, $CancelBorrowerNumber);
62     $biblionumber[0] = $CancelBiblioNumber,
63 }
64
65 # 2) Cancel or modify the queue list of reserves (without item linked)
66 else {
67     for (my $i=0;$i<$count;$i++){
68         undef $itemnumber[$i] unless $itemnumber[$i] ne '';
69         ModReserve($rank[$i],$biblionumber[$i],$borrower[$i],$branch[$i],$itemnumber[$i]); #from C4::Reserves
70     }
71 }
72 my $from=$query->param('from');
73 $from ||= q{};
74 if ( $from eq 'borrower'){
75     print $query->redirect("/cgi-bin/koha/members/moremember.pl?borrowernumber=$borrower[0]");
76 } elsif ( $from eq 'circ'){
77     print $query->redirect("/cgi-bin/koha/circ/circulation.pl?borrowernumber=$borrower[0]");
78 } else {
79      my $url = "/cgi-bin/koha/reserve/request.pl?";
80      if ($multi_hold) {
81          $url .= "multi_hold=1&biblionumbers=$biblionumbers";
82      } else {
83          $url .= "biblionumber=$biblionumber[0]";
84      }
85      print $query->redirect($url);
86 }