Merge commit 'origin/master' into sopac
[koha.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 with
22 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
23 # Suite 330, Boston, MA  02111-1307 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 if ($from eq 'borrower'){
74   print $query->redirect("/cgi-bin/koha/members/moremember.pl?borrowernumber=$borrower[0]");
75  } elsif ($from eq 'circ'){
76   print $query->redirect("/cgi-bin/koha/circ/circulation.pl?borrowernumber=$borrower[0]");
77  } else {
78      my $url = "/cgi-bin/koha/reserve/request.pl?";
79      if ($multi_hold) {
80          $url .= "multi_hold=1&biblionumbers=$biblionumbers";
81      } else {
82          $url .= "biblionumber=$biblionumber[0]";
83      }
84      print $query->redirect($url);
85 }