[Koha-cvs] CVS: koha/opac opac-MARCdetail.pl,1.4.2.1,1.4.2.2
Paul POULAIN
tipaul at users.sourceforge.net
Thu Mar 10 16:52:40 CET 2005
Update of /cvsroot/koha/koha/opac
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv16975/opac
Modified Files:
Tag: rel_2_2
opac-MARCdetail.pl
Log Message:
* adding glass to opac marc detail.
* changing glasses behaviour : It now appears only on subfields that have a "link" value. Avoid useless glasses and removes nothing. **** WARNING **** : if you don't change you MARC parameters, glasses DISAPPEAR, because no subfields have a link value. So you MUST "reactivate" them manually. If you want to enable the search glass on field 225$a (collection in UNIMARC), just put 225a to "link" field (Koha >> parameters >> framework >> 225 field >> subfield >> modify $a >> enter 225a in link input field (without quotes or anything else)
* fixing bug with libopac
Index: opac-MARCdetail.pl
===================================================================
RCS file: /cvsroot/koha/koha/opac/opac-MARCdetail.pl,v
retrieving revision 1.4.2.1
retrieving revision 1.4.2.2
diff -C2 -r1.4.2.1 -r1.4.2.2
*** opac-MARCdetail.pl 3 Feb 2005 15:25:28 -0000 1.4.2.1
--- opac-MARCdetail.pl 10 Mar 2005 15:52:37 -0000 1.4.2.2
***************
*** 68,72 ****
$biblionumber = &MARCfind_oldbiblionumber_from_MARCbibid($dbh,$bibid) unless $biblionumber;
my $itemtype = &MARCfind_frameworkcode($dbh,$bibid);
! my $tagslib = &MARCgettagslib($dbh,1,$itemtype);
my $record =MARCgetbiblio($dbh,$bibid);
--- 68,72 ----
$biblionumber = &MARCfind_oldbiblionumber_from_MARCbibid($dbh,$bibid) unless $biblionumber;
my $itemtype = &MARCfind_frameworkcode($dbh,$bibid);
! my $tagslib = &MARCgettagslib($dbh,0,$itemtype);
my $record =MARCgetbiblio($dbh,$bibid);
***************
*** 88,119 ****
my @fields = $record->fields();
my @loop_data =();
! foreach my $field (@fields) {
! my @subfields_data;
# if tag <10, there's no subfield, use the "@" trick
! if ($field->tag()<10) {
! next if ($tagslib->{$field->tag()}->{'@'}->{tab} ne $tabloop);
! next if ($tagslib->{$field->tag()}->{'@'}->{hidden});
my %subfield_data;
! $subfield_data{marc_lib}=$tagslib->{$field->tag()}->{'@'}->{lib};
! $subfield_data{marc_value}=$field->data();
$subfield_data{marc_subfield}='@';
! $subfield_data{marc_tag}=$field->tag();
push(@subfields_data, \%subfield_data);
} else {
! my @subf=$field->subfields;
# loop through each subfield
for my $i (0..$#subf) {
$subf[$i][0] = "@" unless $subf[$i][0];
! next if ($tagslib->{$field->tag()}->{$subf[$i][0]}->{tab} ne $tabloop);
! next if ($tagslib->{$field->tag()}->{$subf[$i][0]}->{hidden});
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>";
} else {
! $subfield_data{marc_value}=get_authorised_value_desc($field->tag(), $subf[$i][0], $subf[$i][1], '', $dbh);
}
$subfield_data{marc_subfield}=$subf[$i][0];
! $subfield_data{marc_tag}=$field->tag();
push(@subfields_data, \%subfield_data);
}
--- 88,125 ----
my @fields = $record->fields();
my @loop_data =();
! # foreach my $field (@fields) {
! my @subfields_data;
! for (my $x_i=0;$x_i<=$#fields;$x_i++) {
! # warn "$tabloop => $x_i";
# if tag <10, there's no subfield, use the "@" trick
! if ($fields[$x_i]->tag()<10) {
! next if ($tagslib->{$fields[$x_i]->tag()}->{'@'}->{tab} ne $tabloop);
! next if ($tagslib->{$fields[$x_i]->tag()}->{'@'}->{hidden});
my %subfield_data;
! $subfield_data{marc_lib}=$tagslib->{$fields[$x_i]->tag()}->{'@'}->{lib};
! $subfield_data{marc_value}=$fields[$x_i]->data();
$subfield_data{marc_subfield}='@';
! $subfield_data{marc_tag}=$fields[$x_i]->tag();
push(@subfields_data, \%subfield_data);
} else {
! my @subf=$fields[$x_i]->subfields;
# loop through each subfield
for my $i (0..$#subf) {
$subf[$i][0] = "@" unless $subf[$i][0];
! next if ($tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{tab} ne $tabloop);
! next if ($tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{hidden});
my %subfield_data;
! $subfield_data{marc_lib}=$tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{lib};
! $subfield_data{link}=$tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{link};
! if ($tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{isurl}) {
$subfield_data{marc_value}="<a href=\"$subf[$i][1]\">$subf[$i][1]</a>";
} else {
! if ($tagslib->{$fields[$x_i]->tag()}->{$subf[$i][0]}->{authtypecode}) {
! $subfield_data{authority}=$fields[$x_i]->subfield(9);
! }
! $subfield_data{marc_value}=get_authorised_value_desc($fields[$x_i]->tag(), $subf[$i][0], $subf[$i][1], '', $dbh);
}
$subfield_data{marc_subfield}=$subf[$i][0];
! $subfield_data{marc_tag}=$fields[$x_i]->tag();
push(@subfields_data, \%subfield_data);
}
***************
*** 121,127 ****
if ($#subfields_data>=0) {
my %tag_data;
! $tag_data{tag}=$field->tag().' -'. $tagslib->{$field->tag()}->{lib};
! $tag_data{subfield} = \@subfields_data;
push (@loop_data, \%tag_data);
}
}
--- 127,139 ----
if ($#subfields_data>=0) {
my %tag_data;
! if ($fields[$x_i]->tag() eq $fields[$x_i-1]->tag()) {
! $tag_data{tag}="";
! } else {
! $tag_data{tag}=$fields[$x_i]->tag().' -'. $tagslib->{$fields[$x_i]->tag()}->{lib};
! }
! my @tmp = @subfields_data;
! $tag_data{subfield} = \@tmp;
push (@loop_data, \%tag_data);
+ undef @subfields_data;
}
}
More information about the Koha-cvs
mailing list