Galen Charlton
d2f49e1976
The sample bib label layouts and the hard-coded default format_string for new layouts used 'callnumber' when they should have used 'itemcallnumber', preventing call numbers from being printed on spine labels that use the system-supplied layouts. Besides correcting the sample data, this patch now also enshrines 'callnumber' as an alias for 'itemcallnumber'. Signed-off-by: Galen Charlton <gmcharlt@gmail.com> Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de> After applying patch it works for new and old layouts (itemcallnumber and callnumber). Signed-off-by: Chris Cormack <chrisc@catalyst.net.nz>
113 lines
3.7 KiB
Perl
Executable file
113 lines
3.7 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use CGI;
|
|
use XML::Simple;
|
|
use Data::Dumper;
|
|
|
|
use C4::Debug;
|
|
use C4::Creators 1.000000;
|
|
use C4::Labels 1.000000;
|
|
|
|
my $cgi = new CGI;
|
|
|
|
my $batch_id = $cgi->param('batch_id') if $cgi->param('batch_id');
|
|
my $template_id = $cgi->param('template_id') || undef;
|
|
my $layout_id = $cgi->param('layout_id') || undef;
|
|
my @label_ids = $cgi->param('label_id') if $cgi->param('label_id');
|
|
my @item_numbers = $cgi->param('item_number') if $cgi->param('item_number');
|
|
|
|
my $items = undef;
|
|
|
|
my $xml_file = (@label_ids || @item_numbers ? "label_single_" . scalar(@label_ids || @item_numbers) : "label_batch_$batch_id");
|
|
print $cgi->header(-type => 'text/xml',
|
|
-encoding => 'utf-8',
|
|
-attachment => "$xml_file.xml",
|
|
);
|
|
|
|
my $batch = C4::Labels::Batch->retrieve(batch_id => $batch_id);
|
|
my $template = C4::Labels::Template->retrieve(template_id => $template_id, profile_id => 1);
|
|
my $layout = C4::Labels::Layout->retrieve(layout_id => $layout_id);
|
|
|
|
|
|
if (@label_ids) {
|
|
my $batch_items = $batch->get_attr('items');
|
|
grep {
|
|
my $label_id = $_;
|
|
push(@{$items}, grep{$_->{'label_id'} == $label_id;} @{$batch_items});
|
|
} @label_ids;
|
|
}
|
|
elsif (@item_numbers) {
|
|
grep {
|
|
push(@{$items}, {item_number => $_});
|
|
} @item_numbers;
|
|
}
|
|
else {
|
|
$items = $batch->get_attr('items');
|
|
}
|
|
|
|
my $xml = XML::Simple->new();
|
|
my $xml_data = {'label' => []};
|
|
|
|
my $item_count = 0;
|
|
|
|
XML_ITEMS:
|
|
foreach my $item (@$items) {
|
|
push(@{$xml_data->{'label'}}, {'item_number' => $item->{'item_number'}});
|
|
my $label = C4::Labels::Label->new(
|
|
batch_id => $batch_id,
|
|
item_number => $item->{'item_number'},
|
|
format_string => $layout->get_attr('format_string'),
|
|
);
|
|
my $format_string = $layout->get_attr('format_string');
|
|
my @data_fields = map { $_ eq 'callnumber' ? 'itemcallnumber' : $_ } # see bug 5653
|
|
split(/, /, $format_string);
|
|
my $csv_data = $label->csv_data();
|
|
for (my $i = 0; $i <= (scalar(@data_fields) - 1); $i++) {
|
|
push(@{$xml_data->{'label'}[$item_count]->{$data_fields[$i]}}, $$csv_data[$i]);
|
|
}
|
|
$item_count++;
|
|
}
|
|
|
|
#die "XML DATA:\n" . Dumper($xml_data);
|
|
|
|
my $xml_out = $xml->XMLout($xml_data);
|
|
#die "XML OUT:\n" . Dumper($xml_out);
|
|
print $xml_out;
|
|
|
|
exit(1);
|
|
|
|
=head1 NAME
|
|
|
|
labels/label-create-xml.pl - A script for creating a xml export of labels and label batches in Koha
|
|
|
|
=head1 ABSTRACT
|
|
|
|
This script provides the means of producing a xml of labels for items either individually, in groups, or in batches from within Koha. This particular script is provided more as
|
|
a demonstration of the multitude of formats Koha labels could be exported in based on the current Label Creator API.
|
|
|
|
=head1 AUTHOR
|
|
|
|
Chris Nighswonger <cnighswonger AT foundations DOT edu>
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
Copyright 2009 Foundations Bible College.
|
|
|
|
=head1 LICENSE
|
|
|
|
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.
|
|
|
|
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.
|
|
|
|
=head1 DISCLAIMER OF WARRANTY
|
|
|
|
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.
|
|
|