3 #script to place reserves/requests
4 #writen 2/1/00 by chris@katipo.oc.nz
7 # Copyright 2000-2002 Katipo Communications
9 # This file is part of Koha.
11 # Koha is free software; you can redistribute it and/or modify it under the
12 # terms of the GNU General Public License as published by the Free Software
13 # Foundation; either version 2 of the License, or (at your option) any later
16 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
17 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
18 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
20 # You should have received a copy of the GNU General Public License along with
21 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
22 # Suite 330, Boston, MA 02111-1307 USA
31 use C4::Circulation::Circ2;
36 # get biblio information....
37 my $bib = $input->param('bib');
38 my $dat = bibdata($bib);
40 # get existing reserves .....
41 my ($count,$reserves) = FindReserves($bib);
42 foreach my $res (@$reserves) {
43 if ($res->{'found'} eq 'W') {
48 # make priorities options
50 my $priorityoptions = priorityoptions($num, $num);
53 # get branch information
54 my $branch = $input->cookie('branch');
55 ($branch) || ($branch = 'L');
56 my $branches = getbranches();
57 my $branchoptions = branchoptions($branch);
61 my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =localtime(time);
64 my $date="$mday/$mon/$year";
69 # get biblioitem information and build rows for form
70 my ($count2,@data) = bibitems($bib);
72 for (my $i=0; $i<$count2; $i++) {
73 my @barcodes = barcodes($data[$i]->{'biblioitemnumber'});
74 if ($data[$i]->{'dewey'} == 0){
75 $data[$i]->{'dewey'}="";
77 $data[$i]->{'volumeddesc'} = " " unless $data[$i]->{'volumeddesc'};
78 $data[$i]->{'dewey'}=~ s/\.0000$//;
79 $data[$i]->{'dewey'}=~ s/00$//;
80 my $class="$data[$i]->{'classification'}$data[$i]->{'dewey'}$data[$i]->{'subclass'}";
82 if ($data[$i]->{'notforloan'}) {
83 $select = "Reference Item.";
84 } elsif ($data[$i]->{'itemlost'} == 1) {
85 $select = "Item Lost";
86 } elsif ($data[$i]->{'itemlost'} == 2) {
87 $select = "Long Overdue";
88 } elsif ($data[$i]->{'wthdrawn'}) {
89 $select = "Item Cancelled";
91 $select = " <input type=checkbox name=reqbib value=$data[$i]->{'biblioitemnumber'}><input type=hidden name=biblioitem value=$data[$i]->{'biblioitemnumber'}>";
93 $bibitemrows .= <<"EOF";
96 <TD>$data[$i]->{'description'}</td>
98 <td>$data[$i]->{'volumeddesc'}</td>
99 <td>$data[$i]->{'isbn'}</td>
100 <td>$dat->{'copyrightdate'}</td>
101 <td>$data[$i]->{'publicationyear'}</td>
110 my $existingreserves = "";
111 foreach my $res (sort {$a->{'found'} cmp $b->{'found'}} @$reserves){
112 my $prioropt = priorityoptions($count, $res->{'priority'});
113 my $bropt = branchoptions($res->{'branchcode'});
114 my $bor=$res->{'borrowernumber'};
115 $date = slashifyDate($res->{'reservedate'});
117 my $type=$res->{'constrainttype'};
119 $type='Next Available';
120 } elsif ($type eq 'o'){
121 $type="This type only $res->{'volumeddesc'} $res->{'itemtype'}";
124 my $notes = $res->{'reservenotes'}." ";
128 if ($res->{'found'} eq 'W') {
130 my $item = $res->{'itemnumber'};
131 $item = getiteminformation(\%env,$item);
132 $item = "<a href=/cgi-bin/koha/detail.pl?bib=$item->{'biblionumber'} &type=intra onClick=\"openWindow(this, 'Item', 480, 640)\">$item->{'barcode'}</a>";
133 my $wbra = $branches->{$res->{'branchcode'}}->{'branchname'};
134 $rank = "Item waiting";
136 $pickup = "at <b>".$wbra."</b>";
137 $change = "<input type=checkbox name=rank-request value=del>delete";
139 $rank = "<select name=rank-request>$prioropt<option value=del>Del</select>";
140 $pickup = "<select name=pickup>$bropt</select>";
141 $change = "<select name=itemtype>
142 <option value=next>Next Available
143 <option value=change>Change Selection
144 <option value=nc >No Change</select>";
146 $existingreserves .= <<"EOF";
147 <input type=hidden name=borrower value=$res->{'borrowernumber'}>
148 <input type=hidden name=biblio value=$res->{'biblionumber'}>
152 <a href=/cgi-bin/koha/moremember.pl?bornum=$bor>$res->{'firstname'} $res->{'surname'}</a>
165 sub priorityoptions {
166 my ($count, $sel) = @_;
168 for (my $i=1; $i<=$count; $i++){
169 $out .= "<option value=$i";
178 # make branch selection options...
182 foreach my $br (keys %$branches) {
183 (next) unless $branches->{$br}->{'IS'};
186 $selected = "selected";
188 $out .= "<option value=$br $selected>$branches->{$br}->{'branchname'}\n";
198 print $input->header;
203 print startmenu('catalogue');
210 <form action="placerequest.pl" method=post>
211 <INPUT TYPE="image" name="submit" VALUE="request" height=42 WIDTH=187 BORDER=0 src="/images/place-request.gif" align=right >
212 <input type=hidden name=biblio value=$bib>
213 <input type=hidden name=type value=str8>
214 <input type=hidden name=title value="$dat->{'title'}">
215 <FONT SIZE=6><em>Requesting: <br>
216 <a href=/cgi-bin/koha/detail.pl?bib=$bib>$dat->{'title'}</a>
217 ($dat->{'author'})</em></FONT><P>
221 <!----------------BIBLIO RESERVE TABLE-------------->
224 <TABLE CELLSPACING=0 CELLPADDING=5 border=1 >
226 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Rank</b></TD>
227 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Member Number</b></TD>
228 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Notes</b></TD>
229 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Date</b></TD>
230 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Pickup</b></TD>
231 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Request</b></TD>
234 <td><select name=rank-request>
237 <td><input type=text size=10 name=member></td>
238 <td><input type=text size=20 name=notes></td>
240 <td><select name=pickup>
243 <td><input type=checkbox name=request value=any>Next Available,
244 <br>(or choose from list below)</td>
249 <TABLE CELLSPACING=0 CELLPADDING=5 border=1 >
252 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Request</b></TD>
253 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Item Type</b></TD>
254 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Classification</b></TD>
255 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Volume</b></TD>
256 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>ISBN</b></TD>
257 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Copyright</b></TD>
258 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Pubdate</b></TD>
259 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Copies</b></TD>
269 <!-----------MODIFY EXISTING REQUESTS----------------->
271 <TABLE CELLSPACING=0 CELLPADDING=5 border=1 >
275 <td bgcolor="99cc33" background="/images/background-mem.gif" colspan=7><B>MODIFY EXISTING REQUESTS </b></TD>
277 <form action=modrequest.pl method=post>
280 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Rank</b></TD>
281 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Member</b></TD>
282 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Notes</b></TD>
283 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Date</b></TD>
284 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Pickup</b></TD>
285 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Request</b></TD>
286 <td bgcolor="99cc33" background="/images/background-mem.gif"><B>Change To</b></TD>
290 <TD colspan=6 align=right>
291 Delete a request by selecting "del" from the rank list.
292 <INPUT TYPE="image" name="submit" VALUE="request" height=42 WIDTH=64 BORDER=0 src="/images/ok.gif"></td>