#
# 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 2 of the License, or (at your option) any later
-# version.
+# 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.
+# 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, write to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
-
-use strict;
-use CGI;
-use C4::Auth;
-use C4::Output;
-use C4::Biblio;
-use C4::Items;
+# 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 C4::Auth qw( get_template_and_user );
+use C4::Output qw( output_html_with_http_headers );
+use C4::Biblio qw( GetMarcBiblio ModBiblio PrepHostMarcField );
use C4::Context;
-use C4::Koha;
-use C4::Branch;
my $query = CGI->new;
my $biblionumber = $query->param('biblionumber');
my $barcode = $query->param('barcode');
-my ($template, $loggedinuser, $cookie)
- = get_template_and_user({template_name => "cataloguing/linkitem.tmpl",
- query => $query,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => {editcatalogue => 'edit_catalogue'},
- debug => 1,
- });
+my ($template, $loggedinuser, $cookie) = get_template_and_user(
+ {
+ template_name => "cataloguing/linkitem.tt",
+ query => $query,
+ type => "intranet",
+ flagsrequired => { editcatalogue => 'edit_catalogue' },
+ }
+);
-my $biblio = GetMarcBiblio($biblionumber);
+my $biblio = GetMarcBiblio({ biblionumber => $biblionumber });
my $marcflavour = C4::Context->preference("marcflavour");
$marcflavour ||="MARC21";
if ($marcflavour eq 'MARC21' || $marcflavour eq 'NORMARC') {
$template->param(biblionumber => $biblionumber);
-if ($barcode && $biblionumber) {
-
- # We get the host itemnumber
- my $hostitemnumber = GetItemnumberFromBarcode($barcode);
-
- if ($hostitemnumber) {
- my $hostbiblionumber = GetBiblionumberFromItemnumber($hostitemnumber);
-
- if ($hostbiblionumber) {
- my $field = PrepHostMarcField($hostbiblionumber, $hostitemnumber,$marcflavour);
- $biblio->append_fields($field);
-
- my $modresult = ModBiblio($biblio, $biblionumber, '');
- if ($modresult) {
- $template->param(success => 1);
- } else {
- $template->param(error => 1,
- errornomodbiblio => 1);
- }
- } else {
- $template->param(error => 1,
- errornohostbiblionumber => 1);
- }
- } else {
- $template->param(error => 1,
- errornohostitemnumber => 1);
-
+if ( $barcode && $biblionumber ) {
+
+ my $item = Koha::Items->find( { barcode => $barcode } );
+
+ if ($item) {
+ my $field = PrepHostMarcField( $item->biblio->biblionumber, $item->itemnumber, $marcflavour );
+ $biblio->append_fields($field);
+
+ my $modresult = ModBiblio( $biblio, $biblionumber, '' );
+ if ($modresult) {
+ $template->param( success => 1 );
+ }
+ else {
+ $template->param(
+ error => 1,
+ errornomodbiblio => 1
+ );
+ }
+ $template->param(
+ hostitemnumber => $item->itemnumber,
+ );
}
+ else {
+ $template->param(
+ error => 1,
+ errornohostitemnumber => 1,
+ );
+ }
+
$template->param(
- barcode => $barcode,
- hostitemnumber => $hostitemnumber,
- );
-
-} else {
- $template->param(missingparameter => 1);
- if (!$barcode) { $template->param(missingbarcode => 1); }
- if (!$biblionumber) { $template->param(missingbiblionumber => 1); }
+ barcode => $barcode,
+ );
+
+}
+else {
+ $template->param( missingparameter => 1 );
+ if ( !$barcode ) { $template->param( missingbarcode => 1 ); }
+ if ( !$biblionumber ) { $template->param( missingbiblionumber => 1 ); }
}