tonnesen
24 years ago
2 changed files with 511 additions and 143 deletions
@ -0,0 +1,207 @@ |
|||||
|
#!/usr/bin/perl |
||||
|
|
||||
|
use CGI qw/:standard/; |
||||
|
use C4::Circulation::Circ2; |
||||
|
use C4::Output; |
||||
|
use DBI; |
||||
|
|
||||
|
|
||||
|
my %env; |
||||
|
my $query=new CGI; |
||||
|
print $query->header; |
||||
|
print startpage(); |
||||
|
print startmenu('catalogue'); |
||||
|
|
||||
|
print << "EOF"; |
||||
|
<center> |
||||
|
<a href=circulation.pl?module=issues>Issues</a> | |
||||
|
<a href=circulation.pl?module=returns>Returns</a> |
||||
|
<hr> |
||||
|
EOF |
||||
|
|
||||
|
SWITCH: { |
||||
|
if ($query->param('module') eq 'issues') { issues(); last SWITCH; } |
||||
|
if ($query->param('module') eq 'returns') { returns(); last SWITCH; } |
||||
|
issues(); |
||||
|
} |
||||
|
|
||||
|
|
||||
|
print endmenu(); |
||||
|
print endpage(); |
||||
|
sub default { |
||||
|
print << "EOF"; |
||||
|
<a href=circulation.pl?module=issues>Issues</a> |
||||
|
<a href=circulation.pl?module=returns>Returns</a> |
||||
|
EOF |
||||
|
} |
||||
|
|
||||
|
sub issues { |
||||
|
if (my $borrnumber=$query->param('borrnumber')) { |
||||
|
my ($borrower, $flags) = getpatroninformation(\%env,$borrnumber,0); |
||||
|
if (my $barcode=$query->param('barcode')) { |
||||
|
my %responses; |
||||
|
foreach (sort $query->param) { |
||||
|
if ($_ =~ /response-(\d*)/) { |
||||
|
$responses{$1}=$query->param($_); |
||||
|
} |
||||
|
} |
||||
|
if (my $qnumber=$query->param('questionnumber')) { |
||||
|
$responses{$qnumber}=$query->param('answer'); |
||||
|
} |
||||
|
my ($iteminformation, $duedate, $rejected, $question, $questionnumber, $defaultanswer) = issuebook(\%env, $borrower, $barcode, \%responses); |
||||
|
if ($rejected) { |
||||
|
if ($rejected == -1) { |
||||
|
} else { |
||||
|
print "Error issuing book: $rejected<br>\n"; |
||||
|
} |
||||
|
} |
||||
|
if ($question) { |
||||
|
print << "EOF"; |
||||
|
<table border=1 bgcolor=#dddddd> |
||||
|
<tr><th bgcolor=black><font color=white><b>Issuing Question</b></font></td></tr> |
||||
|
<tr><td> |
||||
|
Attempting to issue $iteminformation->{'title'} by $iteminformation->{'author'} to $borrower->{'firstname'} $borrower->{'surname'}. |
||||
|
<br> |
||||
|
$question |
||||
|
</td></tr> |
||||
|
|
||||
|
<tr><td align=center> |
||||
|
<table border=0> |
||||
|
<tr><td> |
||||
|
<form method=get> |
||||
|
<input type=hidden name=module value=issues> |
||||
|
<input type=hidden name=borrnumber value=$borrnumber> |
||||
|
<input type=hidden name=barcode value=$barcode> |
||||
|
<input type=hidden name=questionnumber value=$questionnumber> |
||||
|
<input type=hidden name=answer value=Y> |
||||
|
<input type=submit value=Yes> |
||||
|
</form> |
||||
|
</td> |
||||
|
<td> |
||||
|
<form method=get> |
||||
|
<input type=hidden name=module value=issues> |
||||
|
<input type=hidden name=borrnumber value=$borrnumber> |
||||
|
<input type=hidden name=barcode value=$barcode> |
||||
|
<input type=hidden name=questionnumber value=$questionnumber> |
||||
|
<input type=hidden name=answer value=N> |
||||
|
<input type=submit value=No> |
||||
|
</form> |
||||
|
</td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
</td></tr> |
||||
|
</table> |
||||
|
EOF |
||||
|
return; |
||||
|
} |
||||
|
} |
||||
|
my $issueid=$query->param('issueid'); |
||||
|
($issueid) || ($issueid=int(rand()*1000000000)); |
||||
|
my $flag=''; |
||||
|
my $flagtext=''; |
||||
|
foreach $flag (sort keys %$flags) { |
||||
|
$flagtext.="$flag "; |
||||
|
} |
||||
|
$env{'nottodaysissues'}=1; |
||||
|
my ($borrowerissues) = currentissues(\%env, $borrower); |
||||
|
$env{'nottodaysissues'}=0; |
||||
|
$env{'todaysissues'}=1; |
||||
|
my ($today) = currentissues(\%env, $borrower); |
||||
|
$env{'todaysissues'}=0; |
||||
|
my $previssues=''; |
||||
|
my @datearr = localtime(time()); |
||||
|
my $todaysdate = (1900+$datearr[5]).sprintf ("%0.2d", ($datearr[4]+1)).sprintf ("%0.2d", $datearr[3]); |
||||
|
foreach (sort keys %$borrowerissues) { |
||||
|
my $bookissue=$borrowerissues->{$_}; |
||||
|
my $bgcolor=''; |
||||
|
my $datedue=$bookissue->{'date_due'}; |
||||
|
$datedue=~s/-//g; |
||||
|
if ($datedue < $todaysdate) { |
||||
|
$bgcolor="bgcolor=red"; |
||||
|
} |
||||
|
$previssues.="<tr $bgcolor><td>$bookissue->{'date_due'}</td><td>$bookissue->{'barcode'}</td><td>$bookissue->{'title'}</td><td>$bookissue->{'author'}</td><td>$bookissue->{'dewey'} $bookissue->{'subclass'}</td></tr>\n"; |
||||
|
} |
||||
|
my $todaysissues=''; |
||||
|
foreach (sort keys %$today) { |
||||
|
my $bookissue=$today->{$_}; |
||||
|
$todaysissues.="<tr><td>$bookissue->{'date_due'}</td><td>$bookissue->{'barcode'}</td><td>$bookissue->{'title'}</td><td>$bookissue->{'author'}</td><td>$bookissue->{'dewey'} $bookissue->{'subclass'}</td></tr>\n"; |
||||
|
} |
||||
|
print << "EOF"; |
||||
|
<form method=get> |
||||
|
<input type=hidden name=module value=issues> |
||||
|
<input type=hidden name=borrnumber value=$borrnumber> |
||||
|
<table border=0 cellpadding=5> |
||||
|
<tr> |
||||
|
<td align=left> |
||||
|
<table border=3 bgcolor=#dddddd> |
||||
|
<tr><td colspan=2 bgcolor=black><font color=white><b>Enter Book Barcode</b></font></td></tr> |
||||
|
<tr><td>Item Barcode:</td><td><input name=barcode size=10></td></tr> |
||||
|
</table> |
||||
|
</td> |
||||
|
<td align=right> |
||||
|
<table border=1 bgcolor=#dddddd> |
||||
|
<tr><th bgcolor=black><font color=white><b>Patron Information</b></font></td></tr> |
||||
|
<tr><td> |
||||
|
$borrower->{'cardnumber'} $borrower->{'surname'}, $borrower->{'title'} $borrower->{'firstname'}<br> |
||||
|
$borrower->{'streetaddress'} $borrower->{'city'}<br> |
||||
|
$borrower->{'categorycode'} $flagtext |
||||
|
</td></tr> |
||||
|
</table> |
||||
|
</td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td colspan=2 align=center> |
||||
|
<table border=1 width=100% bgcolor=#dddddd> |
||||
|
<tr><th colspan=5 bgcolor=black><font color=white><b>Today's Issues</b></font></th></tr> |
||||
|
<tr><th>Due Date</th><th>Bar Code</th><th>Title</th><th>Author</th><th>Class</th></tr> |
||||
|
$todaysissues |
||||
|
</table> |
||||
|
</td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td colspan=2 align=center> |
||||
|
<table border=1 width=100% bgcolor=#dddddd> |
||||
|
<tr><th colspan=5 bgcolor=black><font color=white><b>Previous Issues</b></font></th></tr> |
||||
|
<tr><th>Due Date</th><th>Bar Code</th><th>Title</th><th>Author</th><th>Class</th></tr> |
||||
|
$previssues |
||||
|
</table> |
||||
|
</td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
EOF |
||||
|
} else { |
||||
|
if (my $findborrower=$query->param('findborrower')) { |
||||
|
my ($borrowers, $flags) = findborrower(\%env, $findborrower); |
||||
|
print "<form method=get>\n"; |
||||
|
print "<input type=hidden name=module value=issues>\n"; |
||||
|
my @borrowers=@$borrowers; |
||||
|
if ($#borrowers == 0) { |
||||
|
$query->param('borrnumber', $borrowers[0]->{'borrowernumber'}); |
||||
|
issues(); |
||||
|
return; |
||||
|
} else { |
||||
|
print "<table border=1 cellpadding=5 bgcolor=#dddddd>"; |
||||
|
print "<tr><th bgcolor=black><font color=white><b>Select a borrower</b></font></th></tr>\n"; |
||||
|
print "<tr><td align=center>\n"; |
||||
|
print "<select name=borrnumber size=7>\n"; |
||||
|
foreach (sort {$a->{'surname'}.$a->{'firstname'} cmp $b->{'surname'}.$b->{'firstname'}} @$borrowers) { |
||||
|
print "<option value=$_->{'borrowernumber'}>$_->{'surname'}, $_->{'firstname'} ($_->{'cardnumber'})\n"; |
||||
|
} |
||||
|
print "</select><br>"; |
||||
|
print "<input type=submit>\n"; |
||||
|
print "</td></tr></table>\n"; |
||||
|
} |
||||
|
} else { |
||||
|
print << "EOF"; |
||||
|
<h1>Issues Module</h1> |
||||
|
<form method=get> |
||||
|
<input type=hidden name=module value=issues> |
||||
|
<table border=1 bgcolor=#dddddd> |
||||
|
<tr><th bgcolor=black><font color=white><b>Enter borrower card number<br> or partial last name</b></font></td></tr> |
||||
|
<tr><td><input name=findborrower></td></tr> |
||||
|
</table> |
||||
|
</form> |
||||
|
EOF |
||||
|
} |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue