Koha/course_reserves/batch_add_items.pl
Kyle M Hall 7d15ff3404
Bug 23727: Editing course reserve items is broken
Adding an item to course reserves and trying to edit any values in a second step does not work. Values are not saved and the table shows all values as "Unchanged".

This patch set adds two new sets of columns to the course_items table.

The first set determines if the specified column should be swapped or
not. The was previously 'implied' by the column being set to undef which
has been the root problem with that way of knowing if a column should
swap or not.

The second set of new columns are for storing the item field values
while the item is on course reserve. Previously, the column values
were swapped between the items table and the course_items table,
which leaves ambiguity as to what each value is. Now, the original
columns *always* store the value when the item is on course reserve,
and the new storage columns store the original item value while the
item is on reserve, and are NULL when an item is *not* on reserve.

Test Plan:
1) Apply this patch
2) Add and edit course items, not the new checkboxes for enabling fields
3) Everything should function as before

Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl>
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
2020-04-17 13:45:56 +01:00

116 lines
3.6 KiB
Perl
Executable file

#!/usr/bin/perl
#
# Copyright 2018 Bywater Solutions
#
# This file is part of Koha.
#
# 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(ModCourseItem ModCourseReserve GetCourse);
use Koha::Items;
my $cgi = new CGI;
my $action = $cgi->param('action') || q{};
my $course_id = $cgi->param('course_id') || q{};
my $barcodes = $cgi->param('barcodes') || q{};
my $itype = $cgi->param('itype');
my $ccode = $cgi->param('ccode');
my $holdingbranch = $cgi->param('holdingbranch');
my $location = $cgi->param('location');
my $staff_note = $cgi->param('staff_note');
my $public_note = $cgi->param('public_note');
my $itype_enabled = scalar $cgi->param('itype_enabled') ? 1 : 0;
my $ccode_enabled = scalar $cgi->param('ccode_enabled') ? 1 : 0;
my $holdingbranch_enabled = scalar $cgi->param('holdingbranch_enabled') ? 1 : 0;
my $location_enabled = scalar $cgi->param('location_enabled') ? 1 : 0;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
template_name => "course_reserves/batch_add_items.tt",
query => $cgi,
type => "intranet",
authnotrequired => 0,
flagsrequired => { coursereserves => 'add_reserves' },
}
);
my $course = GetCourse($course_id);
if ( $course_id && $course ) {
$template->param( course => $course );
if ( !$action ) {
$template->param( action => 'display_form' );
}
elsif ( $action eq 'add' ) {
my @barcodes = uniq( split( /\s\n/, $barcodes ) );
my @items;
my @invalid_barcodes;
for my $b (@barcodes) {
my $item = Koha::Items->find( { barcode => $b } );
if ($item) {
push( @items, $item );
}
else {
push( @invalid_barcodes, $b );
}
}
foreach my $item (@items) {
my $ci_id = ModCourseItem(
itemnumber => $item->id,
itype => $itype,
ccode => $ccode,
holdingbranch => $holdingbranch,
location => $location,
itype_enabled => $itype_enabled,
ccode_enabled => $ccode_enabled,
holdingbranch_enabled => $holdingbranch_enabled,
location_enabled => $location_enabled,
);
my $cr_id = ModCourseReserve(
course_id => $course_id,
ci_id => $ci_id,
staff_note => $staff_note,
public_note => $public_note,
);
}
$template->param(
action => 'display_results',
items_added => \@items,
invalid_barcodes => \@invalid_barcodes,
course_id => $course_id,
);
}
} else {
$template->param( action => 'invalid_course' );
}
output_html_with_http_headers $cgi, $cookie, $template->output;