#
# 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.
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
=head1 NAME
=cut
+use Modern::Perl;
-use strict;
-use warnings;
-
-use C4::AuthoritiesMarc;
-use C4::Auth;
+use C4::Auth qw( get_template_and_user );
+use C4::AuthoritiesMarc qw( GetAuthority GenerateHierarchy );
use C4::Context;
-use C4::Output;
-use CGI;
-use MARC::Record;
+use C4::Output qw( output_html_with_http_headers );
+use CGI qw ( -utf8 );
use C4::Koha;
+use Koha::Authorities;
+
+use Koha::Authority::Types;
+use Koha::Token;
+use Koha::Z3950Servers;
our ($tagslib);
my %subfield_data;
$subfield_data{marc_lib}=$tagslib->{$field->tag()}->{$subf[$i][0]}->{lib};
if ($tagslib->{$field->tag()}->{$subf[$i][0]}->{isurl}) {
- $subfield_data{marc_value}="<a href=\"$subf[$i][1]\">$subf[$i][1]</a>";
+ $subfield_data{marc_value} = $subf[$i][1];
+ $subfield_data{is_url} = 1;
} else {
$subfield_data{marc_value}=$subf[$i][1];
}
}
if ($#subfields_data>=0) {
my %tag_data;
- $tag_data{tag}=$field->tag(). ' '
- . C4::Koha::display_marc_indicators($field)
- . ' - '
- . $tagslib->{$field->tag()}->{lib};
+ $tag_data{tag_number} = $tag;
+ $tag_data{tag_desc} = $tagslib->{$field->tag()}->{lib};
$tag_data{subfield} = \@subfields_data;
+ my $indicators = C4::Koha::display_marc_indicators($field);
+ if ( $indicators ) {
+ $tag_data{ind1} = substr $indicators, 0, 1;
+ $tag_data{ind2} = substr $indicators, 1, 1;
+ }
+
push (@loop_data, \%tag_data);
}
}
#
-my $query=new CGI;
+my $query=CGI->new;
my $dbh=C4::Context->dbh;
# open template
-my ($template, $loggedinuser, $cookie)
- = get_template_and_user({template_name => "authorities/detail.tmpl",
- query => $query,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => {catalogue => 1},
- debug => 1,
- });
+my ($template, $loggedinuser, $cookie) = get_template_and_user(
+ {
+ template_name => "authorities/detail.tt",
+ query => $query,
+ type => "intranet",
+ flagsrequired => { catalogue => 1 },
+ }
+);
my $authid = $query->param('authid');
-my $authtypecode = GetAuthTypeCode($authid);
+my $authobj = Koha::Authorities->find($authid);
+my $authtypecode = $authobj ? $authobj->authtypecode : q{};
$tagslib = &GetTagsLabels(1,$authtypecode);
# Build list of authtypes for showing them
-my $authtypes = getauthtypes;
-my @authtypesloop;
-
-foreach my $thisauthtype (sort { $authtypes->{$b} cmp $authtypes->{$a} } keys %$authtypes) {
- my %row =(value => $thisauthtype,
- selected => $thisauthtype eq $authtypecode,
- authtypetext => $authtypes->{$thisauthtype}{'authtypetext'},
- );
- push @authtypesloop, \%row;
-}
+my $authority_types = Koha::Authority::Types->search({}, { order_by => ['authtypetext']});
my $record=GetAuthority($authid);
# authid invalid
$template->param ( errauthid => $authid,
unknownauthid => 1,
- authtypesloop => \@authtypesloop );
+ authority_types => $authority_types, );
output_html_with_http_headers $query, $cookie, $template->output;
exit;
}
$template->{VARS}->{'loophierarchies'} = GenerateHierarchy($authid);
}
-my $count = CountUsage($authid);
+my $count = $authobj ? $authobj->get_usage_count : 0;
# find the marc field/subfield used in biblio by this authority
my $sth = $dbh->prepare("select distinct tagfield from marc_subfield_structure where authtypecode=?");
while (my ($tagfield) = $sth->fetchrow) {
$biblio_fields.= $tagfield."9,";
}
-chop $biblio_fields;
+chop $biblio_fields if $biblio_fields;
build_tabs ($template, $record, $dbh,"",$query);
-$template->param(authid => $authid,
- count => $count,
- biblio_fields => $biblio_fields,
- authtypetext => $authtypes->{$authtypecode}{'authtypetext'},
- authtypesloop => \@authtypesloop,
- );
+my $servers = Koha::Z3950Servers->search(
+ {
+ recordtype => 'authority',
+ servertype => ['zed', 'sru'],
+ },
+);
+
+my $type = $authority_types->find($authtypecode);
+$template->param(
+ authid => $authid,
+ count => $count,
+ biblio_fields => $biblio_fields,
+ authtypetext => $type ? $type->authtypetext: "",
+ authtypecode => $authtypecode,
+ authority_types => $authority_types,
+ csrf_token => Koha::Token->new->generate_csrf({ session_id => scalar $query->cookie('CGISESSID') }),
+ servers => $servers,
+);
$template->{VARS}->{marcflavour} = C4::Context->preference("marcflavour");
output_html_with_http_headers $query, $cookie, $template->output;