Bug 22650: Prevent multiple holds on individual items
This patch corrects a missing id on the holds_to_place field and adds code to disable the box when an item is checked Additionally script login now places a single hold if an itemnumebr is passed and checks for holdability of the specific item To test: 1 - Allow multiple holds per record in circ rules 2 - In staff client, go to place a hold on a record 3 - Select a patron 4 - Increase the number of holds 5 - Then select a specific item to hold 6 - Patron now has multiple holds on a single item 7 - Apply patch 8 - Repeat, notice that count is disabled when item checked 9 - Confirm count is enabled when 'Hold next available item' is checked 10 - Set number to more than 1 11 - Check an item and submit 12 - Confirm only one item is reserved 13 - Hit the script directly (with valid info): http://localhost:8081/cgi-bin/koha/reserve/placerequest.pl?biblionumber=1&checkitem=1&holds_to_place_count=2&borrowernumber=5 14 - Confirm only one hold is placed 15 - Confirm multiple hits of the url do not generate further holds Signed-off-by: Liz Rea <wizzyrea@gmail.com> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com> Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
This commit is contained in:
parent
e2fa6d97ef
commit
ef5adaff5a
2 changed files with 9 additions and 4 deletions
|
@ -252,7 +252,7 @@
|
|||
[% IF remaining_holds_for_record > 1 %]
|
||||
<li>
|
||||
<label for="holds_to_place_count">Holds to place (count)</label>
|
||||
<input type="number" name="holds_to_place_count" min="1" max="[% remaining_holds_for_record | html %]" step="1" value="1" />
|
||||
<input id="holds_to_place_count" type="number" name="holds_to_place_count" min="1" max="[% remaining_holds_for_record | html %]" step="1" value="1" />
|
||||
</li>
|
||||
[% ELSE %]
|
||||
<input type="hidden" name="holds_to_place_count" value="1" />
|
||||
|
@ -827,8 +827,10 @@
|
|||
});
|
||||
if(onechecked == 1){
|
||||
$("#requestany").prop("checked", false);
|
||||
$("#holds_to_place_count").prop('disabled', true);
|
||||
} else {
|
||||
$("#requestany").prop("checked",true);
|
||||
$("#holds_to_place_count").prop('disabled', false);
|
||||
}
|
||||
});
|
||||
var prev_rank_request;
|
||||
|
|
|
@ -93,9 +93,12 @@ if ( $type eq 'str8' && $borrower ) {
|
|||
if ( $item->biblionumber ne $biblionumber ) {
|
||||
$biblionumber = $item->biblionumber;
|
||||
}
|
||||
}
|
||||
|
||||
if ($multi_hold) {
|
||||
if ( CanItemBeReserved($borrower->{'borrowernumber'}, $item->itemnumber, $branch)->{status} eq 'OK' ) {
|
||||
AddReserve( $branch, $borrower->{'borrowernumber'},
|
||||
$biblionumber, \@realbi, $rank[0], $startdate, $expirationdate, $notes, $title,
|
||||
$checkitem, $found, $itemtype );
|
||||
}
|
||||
} elsif ($multi_hold) {
|
||||
my $bibinfo = $bibinfos{$biblionumber};
|
||||
if ( CanBookBeReserved($borrower->{'borrowernumber'}, $biblionumber)->{status} eq 'OK' ) {
|
||||
AddReserve($branch,$borrower->{'borrowernumber'},$biblionumber,[$biblionumber],
|
||||
|
|
Loading…
Reference in a new issue