]> git.koha-community.org Git - koha.git/blob - reserve/modrequest.pl
Bug 14060: Consider an empty string as a valid date
[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
13 # under the terms of the GNU General Public License as published by
14 # the Free Software Foundation; either version 3 of the License, or
15 # (at your option) any later version.
16 #
17 # Koha is distributed in the hope that it will be useful, but
18 # WITHOUT ANY WARRANTY; without even the implied warranty of
19 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 # GNU General Public License for more details.
21 #
22 # You should have received a copy of the GNU General Public License
23 # along with Koha; if not, see <http://www.gnu.org/licenses>.
24
25 use strict;
26 use warnings;
27 use CGI qw ( -utf8 );
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.tt",
36         query           => $query,
37         type            => "intranet",
38         authnotrequired => 0,
39         flagsrequired   => { catalogue => 1 },
40         debug           => 1,
41     }
42 );
43
44 my @reserve_id = $query->multi_param('reserve_id');
45 my @rank = $query->multi_param('rank-request');
46 my @biblionumber = $query->multi_param('biblionumber');
47 my @borrower = $query->multi_param('borrowernumber');
48 my @branch = $query->multi_param('pickup');
49 my @itemnumber = $query->multi_param('itemnumber');
50 my @suspend_until=$query->multi_param('suspend_until');
51 my $multi_hold = $query->param('multi_hold');
52 my $biblionumbers = $query->param('biblionumbers');
53 my $count=@rank;
54
55 my $CancelBiblioNumber = $query->param('CancelBiblioNumber');
56 my $CancelBorrowerNumber = $query->param('CancelBorrowerNumber');
57 my $CancelItemnumber = $query->param('CancelItemnumber');
58
59 # 2 possibilitys : cancel an item reservation, or modify or cancel the queded list
60
61 # 1) cancel an item reservation by function ModReserveCancelAll (in reserves.pm)
62 if ($CancelBorrowerNumber) {
63     ModReserveCancelAll($CancelItemnumber, $CancelBorrowerNumber);
64     $biblionumber[0] = $CancelBiblioNumber,
65 }
66
67 # 2) Cancel or modify the queue list of reserves (without item linked)
68 else {
69     for (my $i=0;$i<$count;$i++){
70         undef $itemnumber[$i] unless $itemnumber[$i] ne '';
71         ModReserve({
72             rank => $rank[$i],
73             reserve_id => $reserve_id[$i],
74             branchcode => $branch[$i],
75             itemnumber => $itemnumber[$i],
76             suspend_until => $suspend_until[$i]
77         });
78     }
79 }
80
81 my $from=$query->param('from');
82 $from ||= q{};
83 if ( $from eq 'borrower'){
84     print $query->redirect("/cgi-bin/koha/members/moremember.pl?borrowernumber=$borrower[0]");
85 } elsif ( $from eq 'circ'){
86     print $query->redirect("/cgi-bin/koha/circ/circulation.pl?borrowernumber=$borrower[0]");
87 } else {
88      my $url = "/cgi-bin/koha/reserve/request.pl?";
89      if ($multi_hold) {
90          $url .= "multi_hold=1&biblionumbers=$biblionumbers";
91      } else {
92          $url .= "biblionumber=$biblionumber[0]";
93      }
94      print $query->redirect($url);
95 }