&GetReserveCount
&GetReserveFee
&GetReserveInfo
-
+ &GetReserveStatus
+
&GetOtherReserves
&ModReserveFill
=item AddReserve
- AddReserve($branch,$borrowernumber,$biblionumber,$constraint,$bibitems,$priority,$notes,$title,$checkitem,$found)
+ AddReserve($branch,$borrowernumber,$biblionumber,$constraint,$bibitems,$priority,$notes,$title,$checkitem,$found, $from)
=cut
my (
$branch, $borrowernumber, $biblionumber,
$constraint, $bibitems, $priority, $notes,
- $title, $checkitem, $found
+ $title, $checkitem, $found, $from
) = @_;
my $fee =
GetReserveFee($borrowernumber, $biblionumber, $constraint,
if(C4::Context->preference("emailLibrarianWhenHoldIsPlaced")){
my $borrower = GetMemberDetails($borrowernumber);
my $biblio = GetBiblioData($biblionumber);
- my $letter = C4::Letters::getletter( 'reserves', 'HOLDPLACED');
+ my $lettertype = ($from eq "intranet") ? "STAFFHOLDPLACED" : "HOLDPLACED";
+ my $letter = C4::Letters::getletter( 'reserves', $lettertype);
my $admin_email_address = C4::Context->preference('KohaAdminEmailAddress');
my %keys = (%$borrower, %$biblio);
$line->{title} = $biblio->{title};
foreach my $item (@items){
- next if ($indepbranch && $indepbranch ne $item->{holdingbranch});
+ next if ( ($indepbranch && $indepbranch ne $item->{holdingbranch})
+ or $item->{onloan}
+ or $item->{notforloan}
+ or $item->{itemlost}
+ or $item->{count_reserves} eq "Waiting" or $item->{count_reserves} eq "Transit");
$line->{count}++;
$line->{holdingbranches}->{$item->{holdingbranch}} = 1;
$line->{callnumbers}->{$item->{itemcallnumber}} = 1;
# we retrieve borrowers and items informations #
my $item = C4::Items::GetItem($itemnumber);
- my $borrower = C4::Members::GetMember('borrowernumber'=>$borrowernumber);
+ my $borrower = C4::Members::GetMember($borrowernumber, 'borrowernumber');
my $branchcode = "*";
my $branchfield = "reserves.branchcode";
return (@transreserv);
}
+sub GetReserveStatus {
+ my ($itemnumber) = @_;
+
+ my $dbh = C4::Context->dbh;
+
+ my $itemstatus = $dbh->prepare("SELECT found FROM reserves WHERE itemnumber = ?");
+
+ $itemstatus->execute($itemnumber);
+ my ($found) = $itemstatus->fetchrow_array;
+ return $found;
+}
+
=item CheckReserves
($status, $reserve) = &CheckReserves($itemnumber);
# Found it
return ( "Waiting", $res );
}
+ elsif( $res->{'itemnumber'} == $item && $res->{'found'} eq 'T' ){
+ return ( "Transit", $res );
+ }
else {
# See if this item is more important than what we've got
# so far.
$item->{wthdrawn} or
$notforloan_per_itemtype;
+
if (C4::Context->preference('AllowOnShelfHolds')) {
return $available_per_item;
} else {
- return ($available_per_item and $item->{onloan});
+ return ($available_per_item and ($item->{onloan} or GetReserveStatus($itemnumber) eq "W"));
}
}