1922efff85
Enabling warnings in these files did not generate any warnings in the logs when tested. Signed-off-by: Galen Charlton <gmcharlt@gmail.com>
180 lines
5.7 KiB
Perl
Executable file
180 lines
5.7 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2000-2002 Katipo Communications
|
|
#
|
|
# 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 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., 59 Temple Place,
|
|
# Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
=head1 NAME
|
|
|
|
opac-ISBDdetail.pl : script to show a biblio in ISBD format
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This script needs a biblionumber as parameter
|
|
|
|
It shows the biblio
|
|
|
|
The template is in <templates_dir>/catalogue/ISBDdetail.tmpl.
|
|
this template must be divided into 11 "tabs".
|
|
|
|
The first 10 tabs present the biblio, the 11th one presents
|
|
the items attached to the biblio
|
|
|
|
=head1 FUNCTIONS
|
|
|
|
=over 2
|
|
|
|
=cut
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use C4::Auth;
|
|
use C4::Context;
|
|
use C4::Output;
|
|
use CGI;
|
|
use MARC::Record;
|
|
use C4::Biblio;
|
|
use C4::Acquisition;
|
|
use C4::Review;
|
|
use C4::Serials; # uses getsubscriptionfrom biblionumber
|
|
use C4::Koha;
|
|
use C4::Members; # GetMember
|
|
use C4::External::Amazon;
|
|
|
|
my $query = CGI->new();
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "opac-ISBDdetail.tmpl",
|
|
query => $query,
|
|
type => "opac",
|
|
authnotrequired => 1,
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
my $biblionumber = $query->param('biblionumber');
|
|
|
|
$template->param( 'AllowOnShelfHolds' => C4::Context->preference('AllowOnShelfHolds') );
|
|
$template->param( 'ItemsIssued' => CountItemsIssued( $biblionumber ) );
|
|
|
|
my $marcflavour = C4::Context->preference("marcflavour");
|
|
my $record = GetMarcBiblio($biblionumber);
|
|
|
|
# some useful variables for enhanced content;
|
|
# in each case, we're grabbing the first value we find in
|
|
# the record and normalizing it
|
|
my $upc = GetNormalizedUPC($record,$marcflavour);
|
|
my $ean = GetNormalizedEAN($record,$marcflavour);
|
|
my $oclc = GetNormalizedOCLCNumber($record,$marcflavour);
|
|
my $isbn = GetNormalizedISBN(undef,$record,$marcflavour);
|
|
my $content_identifier_exists = 1 if ($isbn or $ean or $oclc or $upc);
|
|
$template->param(
|
|
normalized_upc => $upc,
|
|
normalized_ean => $ean,
|
|
normalized_oclc => $oclc,
|
|
normalized_isbn => $isbn,
|
|
content_identifier_exists => $content_identifier_exists,
|
|
);
|
|
|
|
#coping with subscriptions
|
|
my $subscriptionsnumber = CountSubscriptionFromBiblionumber($biblionumber);
|
|
my $dbh = C4::Context->dbh;
|
|
my $dat = TransformMarcToKoha( $dbh, $record );
|
|
my @subscriptions =
|
|
GetSubscriptions( $dat->{title}, $dat->{issn}, $biblionumber );
|
|
my @subs;
|
|
foreach my $subscription (@subscriptions) {
|
|
my %cell;
|
|
my $serials_to_display;
|
|
$cell{subscriptionid} = $subscription->{subscriptionid};
|
|
$cell{subscriptionnotes} = $subscription->{notes};
|
|
$cell{branchcode} = $subscription->{branchcode};
|
|
|
|
#get the three latest serials.
|
|
$serials_to_display = $subscription->{opacdisplaycount};
|
|
$serials_to_display = C4::Context->preference('OPACSerialIssueDisplayCount') unless $serials_to_display;
|
|
$cell{opacdisplaycount} = $serials_to_display;
|
|
$cell{latestserials} =
|
|
GetLatestSerials( $subscription->{subscriptionid}, $serials_to_display );
|
|
push @subs, \%cell;
|
|
}
|
|
|
|
$template->param(
|
|
subscriptions => \@subs,
|
|
subscriptionsnumber => $subscriptionsnumber,
|
|
);
|
|
|
|
# my @blocs = split /\@/,$ISBD;
|
|
# my @fields = $record->fields();
|
|
my $res = GetISBDView($biblionumber);
|
|
|
|
my $reviews = getreviews( $biblionumber, 1 );
|
|
foreach ( @$reviews ) {
|
|
my $borrower_number_review = $_->{borrowernumber};
|
|
my $borrowerData = GetMember($borrower_number_review,'borrowernumber');
|
|
# setting some borrower info into this hash
|
|
$_->{title} = $borrowerData->{'title'};
|
|
$_->{surname} = $borrowerData->{'surname'};
|
|
$_->{firstname} = $borrowerData->{'firstname'};
|
|
}
|
|
|
|
|
|
$template->param(
|
|
ISBD => $res,
|
|
biblionumber => $biblionumber,
|
|
reviews => $reviews,
|
|
);
|
|
|
|
## Amazon.com stuff
|
|
#not used unless preference set
|
|
if ( C4::Context->preference("OPACAmazonEnabled") == 1 ) {
|
|
|
|
my $amazon_details = &get_amazon_details( $isbn, $record, $marcflavour );
|
|
|
|
foreach my $result ( @{ $amazon_details->{Details} } ) {
|
|
$template->param( item_description => $result->{ProductDescription} );
|
|
$template->param( image => $result->{ImageUrlMedium} );
|
|
$template->param( list_price => $result->{ListPrice} );
|
|
$template->param( amazon_url => $result->{url} );
|
|
}
|
|
|
|
my @products;
|
|
my @reviews;
|
|
for my $details ( @{ $amazon_details->{Details} } ) {
|
|
next unless $details->{SimilarProducts};
|
|
for my $product ( @{ $details->{SimilarProducts}->{Product} } ) {
|
|
push @products, +{ Product => $product };
|
|
}
|
|
next unless $details->{Reviews};
|
|
for my $product ( @{ $details->{Reviews}->{AvgCustomerRating} } ) {
|
|
$template->param( rating => $product * 20 );
|
|
}
|
|
for my $reviews ( @{ $details->{Reviews}->{CustomerReview} } ) {
|
|
push @reviews,
|
|
+{
|
|
Summary => $reviews->{Summary},
|
|
Comment => $reviews->{Comment},
|
|
};
|
|
}
|
|
}
|
|
$template->param( SIMILAR_PRODUCTS => \@products );
|
|
$template->param( AMAZONREVIEWS => \@reviews );
|
|
}
|
|
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|