Jonathan Druart
2b1b168ec4
C4::Items::GetItemnumberFromBarcode calls can be replaced with Koha::Items->find({ barcode => $barcode }); We should make sure the barcode existed in DB and so that ->find returns an object. Note that most of the time we just wanted to know if the barcode existed. The changes are very simple, the only one that need attention is the one in batchMod.pl. It is basically reusing what we did on bug 21141. Test plan: Use the batch item modification/deletion tools to modify/delete items from their barcode (using the textarea or a file) Signed-off-by: Josef Moravec <josef.moravec@gmail.com> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
146 lines
5.5 KiB
Perl
Executable file
146 lines
5.5 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
#
|
|
# Copyright 2006 Katipo Communications.
|
|
# Parts Copyright 2009 Foundations Bible College.
|
|
#
|
|
# 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 vars qw($debug);
|
|
|
|
use CGI qw ( -utf8 );
|
|
|
|
use C4::Auth qw(get_template_and_user);
|
|
use C4::Output qw(output_html_with_http_headers);
|
|
use C4::Items qw(GetItem);
|
|
use C4::Creators;
|
|
use C4::Labels;
|
|
|
|
use Koha::Items;
|
|
|
|
my $cgi = new CGI;
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "labels/label-edit-batch.tt",
|
|
query => $cgi,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { catalogue => 1 },
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
my $err = 0;
|
|
my $errtype = undef;
|
|
my $duplicate_count = undef;
|
|
my $duplicate_message = undef;
|
|
my $db_rows = {};
|
|
my $batch = undef;
|
|
my $display_columns = [ {_label_number => {label => 'Label number', link_field => 0}},
|
|
{_summary => {label => 'Summary', link_field => 0}},
|
|
{_item_type => {label => 'Item type', link_field => 0}},
|
|
{_item_cn => {label => 'Call number', link_field => 0}},
|
|
{_barcode => {label => 'Barcode', link_field => 0}},
|
|
{_delete => {label => 'Actions', link_field => 0}},
|
|
{select => {label => 'Select', value => '_label_id'}},
|
|
];
|
|
my $op = $cgi->param('op') || 'edit';
|
|
my @label_ids;
|
|
my @item_numbers;
|
|
my $number_list;
|
|
my $number_type = $cgi->param('number_type') || "barcode";
|
|
my $batch_id = $cgi->param('element_id') || $cgi->param('batch_id') || 0;
|
|
@label_ids = $cgi->multi_param('label_id') if $cgi->param('label_id');
|
|
@item_numbers = $cgi->multi_param('item_number') if $cgi->param('item_number');
|
|
$number_list = $cgi->param('number_list') if $cgi->param('number_list');
|
|
|
|
my $branch_code = C4::Context->userenv->{'branch'};
|
|
|
|
if ($op eq 'remove') {
|
|
$batch = C4::Labels::Batch->retrieve(batch_id => $batch_id);
|
|
foreach my $label_id (@label_ids) {
|
|
$err = $batch->remove_item($label_id);
|
|
}
|
|
$errtype = 'ITEM_NOT_REMOVED' if $err;
|
|
# Something like this would be nice to avoid problems with the browser's 'refresh' button, but it needs an error handling mechanism...
|
|
# print $cgi->redirect("label-edit-batch.pl?op=edit&batch_id=$batch_id");
|
|
# exit;
|
|
}
|
|
elsif ($op eq 'delete') {
|
|
$err = C4::Labels::Batch::delete(batch_id => $batch_id, branch_code => $branch_code);
|
|
$errtype = 'BATCH_NOT_DELETED' if $err;
|
|
}
|
|
elsif ($op eq 'add') {
|
|
if ($number_list) {
|
|
my @numbers_list = split /\n/, $number_list; # Entries are effectively passed in as a <cr> separated list
|
|
foreach my $number (@numbers_list) {
|
|
$number =~ s/\r$//; # strip any naughty return chars
|
|
if( $number_type eq "itemnumber" && GetItem($number) ) {
|
|
push @item_numbers, $number;
|
|
}
|
|
elsif ($number_type eq "barcode" ) { # we must test in case an invalid barcode is passed in; we effectively disgard them atm
|
|
my $item = Koha::Items->find({barcode => $number});
|
|
push @item_numbers, $item->itemnumber if $item;
|
|
}
|
|
}
|
|
}
|
|
if ($batch_id != 0) {$batch = C4::Labels::Batch->retrieve(batch_id => $batch_id);}
|
|
if ($batch_id == 0 || $batch == -2) {$batch = C4::Labels::Batch->new(branch_code => $branch_code);}
|
|
if ($branch_code){
|
|
foreach my $item_number (@item_numbers) {
|
|
$err = $batch->add_item($item_number);
|
|
}
|
|
$batch_id = $batch->get_attr('batch_id') if $batch_id == 0; #update batch_id if we added to a new batch
|
|
$errtype = 'ITEM_NOT_ADDED' if $err;
|
|
}
|
|
else {
|
|
$err = 1;
|
|
$errtype = 'BRANCH_NOT_SET';
|
|
}
|
|
}
|
|
elsif ($op eq 'new') {
|
|
$batch = C4::Labels::Batch->new(branch_code => $branch_code);
|
|
$batch_id = $batch->get_attr('batch_id');
|
|
}
|
|
elsif ($op eq 'de_duplicate') {
|
|
$batch = C4::Labels::Batch->retrieve(batch_id => $batch_id);
|
|
$duplicate_count = $batch->remove_duplicates();
|
|
$duplicate_message = 1 if $duplicate_count != -1;
|
|
$errtype = 'BATCH_NOT_DEDUP' if $duplicate_count == -1;
|
|
}
|
|
else { # edit
|
|
$batch = C4::Labels::Batch->retrieve(batch_id => $batch_id);
|
|
}
|
|
|
|
my $items = $batch->get_attr('items');
|
|
$db_rows = get_label_summary(items => $items, batch_id => $batch_id);
|
|
|
|
my $table = html_table($display_columns, $db_rows);
|
|
|
|
$template->param(
|
|
err => $err,
|
|
errtype => $errtype,
|
|
) if ($err ne 0);
|
|
|
|
$template->param(
|
|
op => $op,
|
|
batch_id => $batch_id,
|
|
table_loop => $table,
|
|
duplicate_message => $duplicate_message,
|
|
duplicate_count => $duplicate_count,
|
|
);
|
|
|
|
output_html_with_http_headers $cgi, $cookie, $template->output;
|