Bug 14648: Batch remove reserve items

Adds "Batch remove items" button to course-reserves.tt. Creates batch_rm_items.pl and batch_rm_items.tt. Allows user to enter a list of
barcode numbers so that they will be removed from all course reserves to which they are attached. A dialog box will provide a warning
before the final deletion is made.

This patch also now moves barcodes that are invalid or not attached to a course reserve to the invalid barcodes output. It also provides
a count of the courses that the deleted items were attached to.

Test Plan
1. Log in as a user with permissions to add and delete course reserves
2. Add the same items to multiple course reserves
3. Go to the main course reserves page (i.e. /cgi-bin/koha/course_reserves/course-reserves.pl)
4. Click the "- Batch remove items" button
5. Enter the barcodes that you added to multiple reserves in step 1
6. Click submit
7. Click Ok if you are ready to delete all of these items
8. Check each course reserve that you added the items to in step 1 to make sure the items you entered were deleted but nothing else
9. Repeat 2-5
10. Add an invalid barcode and a valid barcode that is not attached to a course reserve
11. Repeat 6-7
12. You should see that the items attached to course reserves were removed while the invalid and unattached barcodes were rejected
13. Log out
14. Log in as a user without permission to delete course reserves
15. Go to the main course reserves page (i.e. /cgi-bin/koha/course_reserves/course-reserves.pl)
16. You should not longer see the "- Batch remove items" button

Signed-off-by: David Nind <david@davidnind.com>

Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
This commit is contained in:
Joseph Sikowitz 2020-07-17 11:34:30 -04:00 committed by Jonathan Druart
parent c72f01d907
commit 3bf7430d1c
3 changed files with 178 additions and 1 deletions

View file

@ -0,0 +1,90 @@
#!/usr/bin/perl
# This file is part of Koha.
#
# Copyright (C) 2020 Fenway Library Organization
#
# Koha is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# Koha is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Koha; if not, see <http://www.gnu.org/licenses>.
use Modern::Perl;
use CGI qw( -utf8 );
use List::MoreUtils qw( uniq );
use C4::Auth;
use C4::Output;
use C4::CourseReserves qw(GetItemCourseReservesInfo DelCourseReserve GetCourseItem);
use Koha::Items;
my $cgi = new CGI;
my $action = $cgi->param('action') || q{};
my $barcodes = $cgi->param('barcodes') || q{};
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
template_name => "course_reserves/batch_rm_items.tt",
query => $cgi,
type => "intranet",
flagsrequired => { coursereserves => 'delete_reserves' },
}
);
if ( !$action ) {
$template->param( action => 'display_form' );
}
elsif ( $action eq 'batch_rm' ) {
my @barcodes = uniq( split (/\s\n/, $barcodes ) );
my @invalid_barcodes;
my @item_and_count;
foreach my $bar (@barcodes) {
my $item = Koha::Items->find( { barcode => $bar } );
if($item) {
my $courseitem = GetCourseItem(itemnumber => $item->id);
if($courseitem) {
my $res_info = GetItemCourseReservesInfo(itemnumber => $item->id);
my $no_of_res = @$res_info;
my $delitemcount = {'delitem' => $item, 'delcount' => $no_of_res};
push ( @item_and_count, $delitemcount );
foreach my $cr (@$res_info) {
if($cr->{cr_id}) {
DelCourseReserve('cr_id' => $cr->{cr_id});
}
}
}
else {
push( @invalid_barcodes, $bar);
}
}
else {
push( @invalid_barcodes, $bar );
}
}
$template->param(
action => 'display_results',
invalid_barcodes => \@invalid_barcodes,
item_and_count => \@item_and_count,
);
}
output_html_with_http_headers $cgi, $cookie, $template->output;

View file

@ -0,0 +1,84 @@
[% SET footerjs = 1 %]
[% INCLUDE 'doc-head-open.inc' %]
<title>Koha &rsaquo; Course reserves &rsaquo; Remove items</title>
[% INCLUDE 'doc-head-close.inc' %]
</head>
<body id="courses_rm_items" class="course">
[% INCLUDE 'header.inc' %]
[% INCLUDE 'cat-search.inc' %]
<div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> &rsaquo; <a href="/cgi-bin/koha/course_reserves/course-reserves.pl">Course reserves</a> &rsaquo; Batch remove reserves</div>
<div class="main container-fluid">
<div class="row">
<div class="col-md-8 col-md-offset-2">
[% IF action == 'display_form' %]
<form method="post" action="/cgi-bin/koha/course_reserves/batch_rm_items.pl">
<input type="hidden" name="action" value="batch_rm" />
<fieldset class="rows">
<legend>Remove items: scan barcodes</legend>
<ol>
<li>
<label class="required" for="barcodes">Item barcodes:</label>
<textarea rows="20" cols="50" id="barcodes" name="barcodes" class="focus"></textarea>
</li>
</ol>
</fieldset>
<fieldset class="action">
<p>All course reserve items will be deleted from all courses to which they are attached.</p>
<input type="submit" value="Submit" class="submit" id="batch_rm_btn" />
<a href="/cgi-bin/koha/course_reserves/course-reserves.pl" class="cancel">Cancel</a>
</fieldset>
</form>
[% END %]
[% IF action == 'display_results' %]
<h1>Results</h1>
<h3>Items deleted</h3>
[% IF item_and_count > 0 %]
<p>The following items were removed from all courses:</p>
<ul>
[% FOREACH i IN item_and_count %]
[% IF i.delcount == 1 %]
<li>[% i.delitem.biblio.title | html %] ([% i.delitem.barcode | html %]) was removed from [% i.delcount %] course.</li>
[% ELSIF i.delcount > 1 %]
<li>[% i.delitem.biblio.title | html %] ([% i.delitem.barcode | html %]) was removed from [% i.delcount %] courses.</li>
[% END %]
[% END %]
</ul>
[% ELSE %]
No valid item barcodes found.
[% END %]
[% IF invalid_barcodes.size > 0 %]
<h3>Invalid barcodes</h3>
<p>The following invalid barcodes were skipped:</p>
<ul>
[% FOREACH b IN invalid_barcodes %]
<li>[% b | html %]</li>
[% END %]
</ul>
[% END %]
<p>
<a class='btn btn-default' href="/cgi-bin/koha/course_reserves/course-reserves.pl">Return</a>
</p>
[% END %]
</div>
</div>
[% MACRO jsinclude BLOCK %]
<script>
$(document).ready(function() {
$("#batch_rm_btn").click(function(){
return confirmDelete(_("Are you sure you want to remove these items from all courses?"));
});
});
</script>
[% END %]
[% INCLUDE 'intranet-bottom.inc' %]

View file

@ -20,11 +20,14 @@
<div class="row">
<div class="col-md-10 col-md-offset-1">
[% IF CAN_user_coursereserves_add_reserves OR CAN_user_coursereserves_manage_courses OR CAN_user_coursereserves_manage_courses %]
[% IF CAN_user_coursereserves_add_reserves OR CAN_user_coursereserves_manage_courses OR CAN_user_coursereserves_manage_courses OR CAN_user_coursereserves_delete_reserves %]
<div id="toolbar">
[% IF ( CAN_user_coursereserves_manage_courses ) %]
<a class="btn btn-default" id="new_course" href="/cgi-bin/koha/course_reserves/course.pl"><i class="fa fa-plus"></i> New course</a>
[% END %]
[% IF ( CAN_user_coursereserves_delete_reserves ) %]
<a class="btn btn-default" id="batch_rm" href="/cgi-bin/koha/course_reserves/batch_rm_items.pl"><i class="fa fa-minus"></i> Batch remove items</a>
[% END %]
</div><!-- /toolbar -->
[% END %]