Jonathan Druart
8f436a5075
C4::Koha::getframeworks returned a hashref of biblio frameworks. It was mainly used to generate the dropdown list of frameworks. The scripts modified in this patch did not necessary order the element by description (frameworktext), the displays were not consistent from one screen to another. Using the same search method everywhere: Koha::BiblioFrameworks->search({}, { order_by => ['frameworktext'] }); We will know always get the framework in the same order. Test plan: Following the different pages modified by this patch, and make sure the frameworks are displayed correctly in the dropdown list: 1/ acqui/z3950_search.pl - Create an order from an external source. 2/ admin/fieldmapping.pl - Define some mappings keyword / MARC field 3/ admin/marctagstructure.pl - On the MARC frameworks admin page, select another framework than the default one and click on the 'Search' button 4/ catalogue/MARCdetail.pl - On the MARC defail page, change the framework you want to use to display the record 5/ cataloguing/addbiblio.pl - Add or edit a biblio record, change its framework. When editing, the framework of the record should be selected by default 6/ cataloguing/addbooks.pl - Go on the cataloguing home page and click on the "New record" button. You should see all the frameworks 7/ cataloguing/merge.pl - Select 2 biblio records to merge. On the first step (select the merge reference), you should be allowed to select the framework to use. 8/ tools/inventory.pl - On the inventory page, the "Item statuses" part should be populated as before this patch 9/ tools/manage-marc-import.pl - Stage records for import. Before importing them into the catalog, you should see the framework dropdown list. Signed-off-by: Bernardo Gonzalez Kriegel <bgkriegel@gmail.com> Works Ok. No errors Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
261 lines
8.9 KiB
Perl
Executable file
261 lines
8.9 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2009 BibLibre
|
|
# Parts Copyright Catalyst IT 2011
|
|
#
|
|
# 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 C4::Output;
|
|
use C4::Auth;
|
|
use C4::Items;
|
|
use C4::Biblio;
|
|
use C4::Serials;
|
|
use C4::Koha;
|
|
use C4::Reserves qw/MergeHolds/;
|
|
use C4::Acquisition qw/ModOrder GetOrdersByBiblionumber/;
|
|
|
|
use Koha::BiblioFrameworks;
|
|
use Koha::MetadataRecord;
|
|
|
|
my $input = new CGI;
|
|
my @biblionumbers = $input->multi_param('biblionumber');
|
|
my $merge = $input->param('merge');
|
|
|
|
my @errors;
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "cataloguing/merge.tt",
|
|
query => $input,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { editcatalogue => 'edit_catalogue' },
|
|
}
|
|
);
|
|
|
|
#------------------------
|
|
# Merging
|
|
#------------------------
|
|
if ($merge) {
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
|
|
# Creating a new record from the html code
|
|
my $record = TransformHtmlToMarc( $input, 1 );
|
|
my $ref_biblionumber = $input->param('ref_biblionumber');
|
|
@biblionumbers = grep { $_ != $ref_biblionumber } @biblionumbers;
|
|
|
|
# prepare report
|
|
my @report_records;
|
|
my $report_fields_str = $input->param('report_fields');
|
|
$report_fields_str ||= C4::Context->preference('MergeReportFields');
|
|
my @report_fields;
|
|
foreach my $field_str (split /,/, $report_fields_str) {
|
|
if ($field_str =~ /(\d{3})([0-9a-z]*)/) {
|
|
my ($field, $subfields) = ($1, $2);
|
|
push @report_fields, {
|
|
tag => $field,
|
|
subfields => [ split //, $subfields ]
|
|
}
|
|
}
|
|
}
|
|
|
|
# Rewriting the leader
|
|
$record->leader(GetMarcBiblio($ref_biblionumber)->leader());
|
|
|
|
my $frameworkcode = $input->param('frameworkcode');
|
|
my @notmoveditems;
|
|
|
|
# Modifying the reference record
|
|
ModBiblio($record, $ref_biblionumber, $frameworkcode);
|
|
|
|
# Moving items from the other record to the reference record
|
|
foreach my $biblionumber (@biblionumbers) {
|
|
my $itemnumbers = get_itemnumbers_of($biblionumber);
|
|
foreach my $itemnumber (@{ $itemnumbers->{$biblionumber} }) {
|
|
my $res = MoveItemFromBiblio($itemnumber, $biblionumber, $ref_biblionumber);
|
|
if (not defined $res) {
|
|
push @notmoveditems, $itemnumber;
|
|
}
|
|
}
|
|
}
|
|
# If some items could not be moved :
|
|
if (scalar(@notmoveditems) > 0) {
|
|
my $itemlist = join(' ',@notmoveditems);
|
|
push @errors, { code => "CANNOT_MOVE", value => $itemlist };
|
|
}
|
|
|
|
my $sth_subscription = $dbh->prepare("
|
|
UPDATE subscription SET biblionumber = ? WHERE biblionumber = ?
|
|
");
|
|
my $sth_subscriptionhistory = $dbh->prepare("
|
|
UPDATE subscriptionhistory SET biblionumber = ? WHERE biblionumber = ?
|
|
");
|
|
my $sth_serial = $dbh->prepare("
|
|
UPDATE serial SET biblionumber = ? WHERE biblionumber = ?
|
|
");
|
|
|
|
my $report_header = {};
|
|
foreach my $biblionumber ($ref_biblionumber, @biblionumbers) {
|
|
# build report
|
|
my $marcrecord = GetMarcBiblio($biblionumber);
|
|
my %report_record = (
|
|
biblionumber => $biblionumber,
|
|
fields => {},
|
|
);
|
|
foreach my $field (@report_fields) {
|
|
my @marcfields = $marcrecord->field($field->{tag});
|
|
foreach my $marcfield (@marcfields) {
|
|
my $tag = $marcfield->tag();
|
|
if (scalar @{$field->{subfields}}) {
|
|
foreach my $subfield (@{$field->{subfields}}) {
|
|
my @values = $marcfield->subfield($subfield);
|
|
$report_header->{ $tag . $subfield } = 1;
|
|
push @{ $report_record{fields}->{$tag . $subfield} }, @values;
|
|
}
|
|
} elsif ($field->{tag} gt '009') {
|
|
my @marcsubfields = $marcfield->subfields();
|
|
foreach my $marcsubfield (@marcsubfields) {
|
|
my ($code, $value) = @$marcsubfield;
|
|
$report_header->{ $tag . $code } = 1;
|
|
push @{ $report_record{fields}->{ $tag . $code } }, $value;
|
|
}
|
|
} else {
|
|
$report_header->{ $tag . '@' } = 1;
|
|
push @{ $report_record{fields}->{ $tag .'@' } }, $marcfield->data();
|
|
}
|
|
}
|
|
}
|
|
push @report_records, \%report_record;
|
|
}
|
|
|
|
foreach my $biblionumber (@biblionumbers) {
|
|
# Moving subscriptions from the other record to the reference record
|
|
my $subcount = CountSubscriptionFromBiblionumber($biblionumber);
|
|
if ($subcount > 0) {
|
|
$sth_subscription->execute($ref_biblionumber, $biblionumber);
|
|
$sth_subscriptionhistory->execute($ref_biblionumber, $biblionumber);
|
|
}
|
|
|
|
# Moving serials
|
|
$sth_serial->execute($ref_biblionumber, $biblionumber);
|
|
|
|
# Moving orders (orders linked to items of frombiblio have already been moved by MoveItemFromBiblio)
|
|
my @allorders = GetOrdersByBiblionumber($biblionumber);
|
|
my @tobiblioitem = GetBiblioItemByBiblioNumber ($ref_biblionumber);
|
|
my $tobiblioitem_biblioitemnumber = $tobiblioitem [0]-> {biblioitemnumber };
|
|
foreach my $myorder (@allorders) {
|
|
$myorder->{'biblionumber'} = $ref_biblionumber;
|
|
ModOrder ($myorder);
|
|
# TODO : add error control (in ModOrder?)
|
|
}
|
|
|
|
# Deleting the other records
|
|
if (scalar(@errors) == 0) {
|
|
# Move holds
|
|
MergeHolds($dbh, $ref_biblionumber, $biblionumber);
|
|
my $error = DelBiblio($biblionumber);
|
|
push @errors, $error if ($error);
|
|
}
|
|
}
|
|
|
|
# Parameters
|
|
$template->param(
|
|
result => 1,
|
|
report_records => \@report_records,
|
|
report_header => $report_header,
|
|
ref_biblionumber => scalar $input->param('ref_biblionumber')
|
|
);
|
|
|
|
#-------------------------
|
|
# Show records to merge
|
|
#-------------------------
|
|
} else {
|
|
my $ref_biblionumber = $input->param('ref_biblionumber');
|
|
|
|
if ($ref_biblionumber) {
|
|
my $framework = $input->param('frameworkcode');
|
|
$framework //= GetFrameworkCode($ref_biblionumber);
|
|
|
|
# Getting MARC Structure
|
|
my $tagslib = GetMarcStructure(1, $framework);
|
|
|
|
my $marcflavour = lc(C4::Context->preference('marcflavour'));
|
|
|
|
# Creating a loop for display
|
|
my @records;
|
|
foreach my $biblionumber (@biblionumbers) {
|
|
my $marcrecord = GetMarcBiblio($biblionumber);
|
|
my $frameworkcode = GetFrameworkCode($biblionumber);
|
|
my $recordObj = new Koha::MetadataRecord({'record' => $marcrecord, schema => $marcflavour});
|
|
my $record = {
|
|
recordid => $biblionumber,
|
|
record => $marcrecord,
|
|
frameworkcode => $frameworkcode,
|
|
display => $recordObj->createMergeHash($tagslib),
|
|
};
|
|
if ($ref_biblionumber and $ref_biblionumber == $biblionumber) {
|
|
$record->{reference} = 1;
|
|
$template->param(ref_record => $record);
|
|
unshift @records, $record;
|
|
} else {
|
|
push @records, $record;
|
|
}
|
|
}
|
|
|
|
my ($biblionumbertag) = GetMarcFromKohaField('biblio.biblionumber');
|
|
|
|
# Parameters
|
|
$template->param(
|
|
ref_biblionumber => $ref_biblionumber,
|
|
records => \@records,
|
|
ref_record => $records[0],
|
|
framework => $framework,
|
|
biblionumbertag => $biblionumbertag,
|
|
MergeReportFields => C4::Context->preference('MergeReportFields'),
|
|
);
|
|
} else {
|
|
my @records;
|
|
foreach my $biblionumber (@biblionumbers) {
|
|
my $frameworkcode = GetFrameworkCode($biblionumber);
|
|
my $record = {
|
|
biblionumber => $biblionumber,
|
|
data => GetBiblioData($biblionumber),
|
|
frameworkcode => $frameworkcode,
|
|
};
|
|
push @records, $record;
|
|
}
|
|
# Ask the user to choose which record will be the kept
|
|
$template->param(
|
|
choosereference => 1,
|
|
records => \@records,
|
|
);
|
|
|
|
my $frameworks = Koha::BiblioFrameworks->search({}, { order_by => ['frameworktext'] });
|
|
$template->param( frameworks => $frameworks );
|
|
}
|
|
}
|
|
|
|
if (@errors) {
|
|
# Errors
|
|
$template->param( errors => \@errors );
|
|
}
|
|
|
|
output_html_with_http_headers $input, $cookie, $template->output;
|
|
exit;
|