Koha/rotating_collections/addItems.pl
Tomas Cohen Arazi 40803d3035 Bug 21500: Remove warnings in rotating collections
To test:
- Go to Tools > Rotating collections
=> FAIL: Some warinings on the logs
- Apply this patch
- Reload page
=> SUCCESS: No warinings
- Sign off :-D

Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>

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

Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
2018-10-09 15:02:45 +00:00

108 lines
3 KiB
Perl
Executable file

#!/usr/bin/perl
# 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 C4::Output;
use C4::Auth;
use C4::Context;
use C4::RotatingCollections;
use C4::Items;
use Koha::Items;
use CGI qw ( -utf8 );
my $query = new CGI;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
template_name => "rotating_collections/addItems.tt",
query => $query,
type => "intranet",
authnotrequired => 0,
flagsrequired => { tools => 'rotating_collections' },
debug => 1,
}
);
if ( defined $query->param('action') and
$query->param('action') eq 'addItem' ) {
## Add the given item to the collection
my $colId = $query->param('colId');
my $barcode = $query->param('barcode');
my $removeItem = $query->param('removeItem');
my $item = Koha::Items->find({barcode => $barcode});
my $itemnumber = $item ? $item->itemnumber : undef;
my ( $success, $errorCode, $errorMessage );
$template->param( barcode => $barcode );
if ( !$removeItem ) {
( $success, $errorCode, $errorMessage ) =
AddItemToCollection( $colId, $itemnumber );
$template->param(
previousActionAdd => 1,
);
if ($success) {
$template->param( addSuccess => 1 );
}
else {
$template->param( addFailure => 1 );
$template->param( failureMessage => $errorMessage );
}
}
else {
## Remove the given item from the collection
( $success, $errorCode, $errorMessage ) =
RemoveItemFromCollection( $colId, $itemnumber );
$template->param(
previousActionRemove => 1,
removeChecked => 1,
);
if ($success) {
$template->param( removeSuccess => 1 );
}
else {
$template->param( removeFailure => 1 );
$template->param( failureMessage => $errorMessage );
}
}
}
my ( $colId, $colTitle, $colDescription, $colBranchcode ) =
GetCollection( scalar $query->param('colId') );
my $collectionItems = GetItemsInCollection($colId);
if ($collectionItems) {
$template->param( collectionItemsLoop => $collectionItems );
}
$template->param(
colId => $colId,
colTitle => $colTitle,
colDescription => $colDescription,
colBranchcode => $colBranchcode,
);
output_html_with_http_headers $query, $cookie, $template->output;