From b3cd7f110a7535d597060a2d654dcc3e404e34f0 Mon Sep 17 00:00:00 2001 From: Owen Leonard Date: Tue, 15 Jul 2014 15:35:54 -0400 Subject: [PATCH] Bug 8521 - Error in warning message when deleting list When deleting a list the operation is blocked if there are items still on the list, and the interface shows a warning which includes a count of the items on the list. This count is broken for lists containing more items than the number specified in the numSearchResults system preference. This patch corrects the item count to use an actual count of the total number of results, not the total number of results in the first page of results. The template change to the staff client copies some language logic from the OPAC template for dealing with a single number of list entries. Test in both the OPAC and the staff client. Check the number specified in the numSearchResults system preference and locate or create a list containing more than that number of items. Try to delete the list. You should receive a warning message stating the correct total number of items on the list. Test also with a list which contains fewer than numSearchResults entries, and a list which contains zero entries. Signed-off-by: Ian Beardslee Tested Public and Private lists with 0, 5 & 25 entries, Public with 40 and Private with 45. Working as expected. Signed-off-by: Katrin Fischer Works as described, passes tests and QA script. Signed-off-by: Tomas Cohen Arazi --- C4/VirtualShelves/Page.pm | 6 +++--- .../intranet-tmpl/prog/en/modules/virtualshelves/shelves.tt | 6 +++++- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/C4/VirtualShelves/Page.pm b/C4/VirtualShelves/Page.pm index 3c90afcee3..56518c2956 100644 --- a/C4/VirtualShelves/Page.pm +++ b/C4/VirtualShelves/Page.pm @@ -384,13 +384,13 @@ sub shelfpage { } my $contents; ( $contents, $totshelves ) = GetShelfContents( $number, $shelveslimit, $shelvesoffset ); - if ( my $count = scalar @$contents ) { + if ( $totshelves > 0 ) { unless ( scalar grep { /^CONFIRM-$number$/ } $query->param() ) { if ( defined $shelflist->{$number} ) { - push( @paramsloop, { need_confirm => $shelflist->{$number}->{shelfname}, count => $count, single => ($count eq 1 ? 1:0) } ); + push( @paramsloop, { need_confirm => $shelflist->{$number}->{shelfname}, count => $totshelves, single => ($totshelves eq 1 ? 1:0) } ); $shelflist->{$number}->{confirm} = $number; } else { - push( @paramsloop, { need_confirm => $privshelflist->{$number}->{shelfname}, count => $count } ); + push( @paramsloop, { need_confirm => $privshelflist->{$number}->{shelfname}, count => $totshelves } ); $privshelflist->{$number}->{confirm} = $number; } $stay = 0; diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/virtualshelves/shelves.tt b/koha-tmpl/intranet-tmpl/prog/en/modules/virtualshelves/shelves.tt index 23d815ffc6..95505e8444 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/modules/virtualshelves/shelves.tt +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/virtualshelves/shelves.tt @@ -234,7 +234,11 @@ function placeHold () { [% IF ( paramsloo.noshelfnumber ) %]
ERROR: No list number given.
[% END %] [% IF ( paramsloo.need_confirm ) %]
The list [% paramsloo.need_confirm %] is not empty. -
It has [% paramsloo.count %] entries. + [% IF ( paramsloo.single ) %] +
It has [% paramsloo.count %] entry. + [% ELSE %] +
It has [% paramsloo.count %] entries. + [% END %]
Use the "Confirm" button below to confirm deletion.
[% END %] -- 2.39.5