4 # Copyright 2000-2002 Katipo Communications
6 # This file is part of Koha.
8 # Koha is free software; you can redistribute it and/or modify it under the
9 # terms of the GNU General Public License as published by the Free Software
10 # Foundation; either version 2 of the License, or (at your option) any later
13 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
14 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License along with
18 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
19 # Suite 330, Boston, MA 02111-1307 USA
27 use C4::AuthoritiesMarc;
31 use C4::Koha; # XXX subfield_is_koha_internal_p
32 use C4::Branch; # XXX subfield_is_koha_internal_p
36 use Date::Calc qw(Today);
37 use MARC::File::USMARC;
40 if ( C4::Context->preference('marcflavour') eq 'UNIMARC' ) {
41 MARC::File::XML->default_record_format('UNIMARC');
44 our($tagslib,$authorised_values_sth,$is_a_modif,$usedTagsLib,$mandatory_z3950);
46 =item MARCfindbreeding
48 $record = MARCfindbreeding($breedingid);
50 Look up the import record repository for the record with
51 record with id $breedingid. If found, returns the decoded
52 MARC::Record; otherwise, -1 is returned (FIXME).
53 Returns as second parameter the character encoding.
57 sub MARCfindbreeding {
59 my ($marc, $encoding) = GetImportRecordMarc($id);
60 # remove the - in isbn, koha store isbn without any -
62 my $record = MARC::Record->new_from_usmarc($marc);
63 my ($isbnfield,$isbnsubfield) = GetMarcFromKohaField('biblioitems.isbn','');
64 if ( $record->field($isbnfield) ) {
65 foreach my $field ( $record->field($isbnfield) ) {
66 foreach my $subfield ( $field->subfield($isbnsubfield) ) {
67 my $newisbn = $field->subfield($isbnsubfield);
69 $field->update( $isbnsubfield => $newisbn );
73 # fix the unimarc 100 coded field (with unicode information)
74 if (C4::Context->preference('marcflavour') eq 'UNIMARC' && $record->subfield(100,'a')) {
75 my $f100a=$record->subfield(100,'a');
76 my $f100 = $record->field(100);
77 my $f100temp = $f100->as_string;
78 $record->delete_field($f100);
79 if ( length($f100temp) > 28 ) {
80 substr( $f100temp, 26, 2, "50" );
81 $f100->update( 'a' => $f100temp );
82 my $f100 = MARC::Field->new( '100', '', '', 'a' => $f100temp );
83 $record->insert_fields_ordered($f100);
87 if ( ref($record) eq undef ) {
91 # normalize author : probably UNIMARC specific...
92 if ( C4::Context->preference("z3950NormalizeAuthor")
93 and C4::Context->preference("z3950AuthorAuthFields") )
95 my ( $tag, $subfield ) = GetMarcFromKohaField("biblio.author");
97 # my $summary = C4::Context->preference("z3950authortemplate");
99 C4::Context->preference("z3950AuthorAuthFields");
100 my @auth_fields = split /,/, $auth_fields;
103 if ( $record->field($tag) ) {
104 foreach my $tmpfield ( $record->field($tag)->subfields ) {
106 # foreach my $subfieldcode ($tmpfield->subfields){
107 my $subfieldcode = shift @$tmpfield;
108 my $subfieldvalue = shift @$tmpfield;
110 $field->add_subfields(
111 "$subfieldcode" => $subfieldvalue )
112 if ( $subfieldcode ne $subfield );
116 MARC::Field->new( $tag, "", "",
117 $subfieldcode => $subfieldvalue )
118 if ( $subfieldcode ne $subfield );
122 $record->delete_field( $record->field($tag) );
123 foreach my $fieldtag (@auth_fields) {
124 next unless ( $record->field($fieldtag) );
125 my $lastname = $record->field($fieldtag)->subfield('a');
126 my $firstname = $record->field($fieldtag)->subfield('b');
127 my $title = $record->field($fieldtag)->subfield('c');
128 my $number = $record->field($fieldtag)->subfield('d');
131 # $field->add_subfields("$subfield"=>"[ ".ucfirst($title).ucfirst($firstname)." ".$number." ]");
132 $field->add_subfields(
133 "$subfield" => ucfirst($title) . " "
134 . ucfirst($firstname) . " "
139 # $field->add_subfields("$subfield"=>"[ ".ucfirst($firstname).", ".ucfirst($lastname)." ]");
140 $field->add_subfields(
141 "$subfield" => ucfirst($firstname) . ", "
142 . ucfirst($lastname) );
145 $record->insert_fields_ordered($field);
147 return $record, $encoding;
153 =item build_authorized_values_list
157 sub build_authorized_values_list ($$$$$$$) {
158 my ( $tag, $subfield, $value, $dbh, $authorised_values_sth,$index_tag,$index_subfield ) = @_;
160 my @authorised_values;
163 # builds list, depending on authorised value...
166 if ( $tagslib->{$tag}->{$subfield}->{'authorised_value'} eq "branches" ) {
167 #Use GetBranches($onlymine)
168 my $onlymine=C4::Context->preference('IndependantBranches') &&
169 C4::Context->userenv &&
170 C4::Context->userenv->{flags}!=1 &&
171 C4::Context->userenv->{branch};
172 my $branches = GetBranches($onlymine);
174 foreach my $thisbranch ( sort keys %$branches ) {
175 push @authorised_values, $thisbranch;
176 $authorised_lib{$thisbranch} = $branches->{$thisbranch}->{'branchname'};
181 elsif ( $tagslib->{$tag}->{$subfield}->{authorised_value} eq "itemtypes" ) {
184 "select itemtype,description from itemtypes order by description");
186 push @authorised_values, ""
187 unless ( $tagslib->{$tag}->{$subfield}->{mandatory} );
191 while ( my ( $itemtype, $description ) = $sth->fetchrow_array ) {
192 push @authorised_values, $itemtype;
193 $authorised_lib{$itemtype} = $description;
195 $value = $itemtype unless ($value);
199 elsif ( $tagslib->{$tag}->{$subfield}->{authorised_value} eq "cn_source" ) {
200 push @authorised_values, ""
201 unless ( $tagslib->{$tag}->{$subfield}->{mandatory} );
203 my $class_sources = GetClassSources();
205 my $default_source = C4::Context->preference("DefaultClassificationSource");
207 foreach my $class_source (sort keys %$class_sources) {
208 next unless $class_sources->{$class_source}->{'used'} or
209 ($value and $class_source eq $value) or
210 ($class_source eq $default_source);
211 push @authorised_values, $class_source;
212 $authorised_lib{$class_source} = $class_sources->{$class_source}->{'description'};
213 $value = $class_source unless ($value);
214 $value = $default_source unless ($value);
216 #---- "true" authorised value
219 $authorised_values_sth->execute(
220 $tagslib->{$tag}->{$subfield}->{authorised_value} );
222 push @authorised_values, ""
223 unless ( $tagslib->{$tag}->{$subfield}->{mandatory} );
225 while ( my ( $value, $lib ) = $authorised_values_sth->fetchrow_array ) {
226 push @authorised_values, $value;
227 $authorised_lib{$value} = $lib;
230 return CGI::scrolling_list(
231 -name => "tag_".$tag."_subfield_".$subfield."_".$index_tag."_".$index_subfield,
232 -values => \@authorised_values,
234 -labels => \%authorised_lib,
239 -id => "tag_".$tag."_subfield_".$subfield."_".$index_tag."_".$index_subfield,
240 -class => "input_marceditor",
246 Create a random value to set it into the input name
251 return int(rand(1000000));
254 =item GetMandatoryFieldZ3950
256 This function return an hashref which containts all mandatory field
257 to search with z3950 server.
261 sub GetMandatoryFieldZ3950($){
262 my $frameworkcode = shift;
263 my @isbn = GetMarcFromKohaField('biblioitems.isbn',$frameworkcode);
264 my @title = GetMarcFromKohaField('biblio.title',$frameworkcode);
265 my @author = GetMarcFromKohaField('biblio.author',$frameworkcode);
266 my @issn = GetMarcFromKohaField('biblioitems.issn',$frameworkcode);
267 my @lccn = GetMarcFromKohaField('biblioitems.lccn',$frameworkcode);
270 $isbn[0].$isbn[1] => 'isbn',
271 $title[0].$title[1] => 'title',
272 $author[0].$author[1] => 'author',
273 $issn[0].$issn[1] => 'issn',
274 $lccn[0].$lccn[1] => 'lccn',
280 builds the <input ...> entry for a subfield.
285 my ( $tag, $subfield, $value, $index_tag, $tabloop, $rec, $authorised_values_sth,$cgi ) = @_;
287 my $index_subfield = CreateKey(); # create a specifique key for each subfield
289 $value =~ s/"/"/g;
291 # if there is no value provided but a default value in parameters, get it
293 $value = $tagslib->{$tag}->{$subfield}->{defaultvalue};
295 # get today date & replace YYYY, MM, DD if provided in the default value
296 my ( $year, $month, $day ) = Today();
297 $month = sprintf( "%02d", $month );
298 $day = sprintf( "%02d", $day );
299 $value =~ s/YYYY/$year/g;
300 $value =~ s/MM/$month/g;
301 $value =~ s/DD/$day/g;
303 my $dbh = C4::Context->dbh;
305 # map '@' as "subfield" label for fixed fields
306 # to something that's allowed in a div id.
307 my $id_subfield = $subfield;
308 $id_subfield = "00" if $id_subfield eq "@";
310 my %subfield_data = (
312 subfield => $id_subfield,
313 marc_lib => substr( $tagslib->{$tag}->{$subfield}->{lib}, 0, 22 ),
314 marc_lib_plain => $tagslib->{$tag}->{$subfield}->{lib},
315 tag_mandatory => $tagslib->{$tag}->{mandatory},
316 mandatory => $tagslib->{$tag}->{$subfield}->{mandatory},
317 repeatable => $tagslib->{$tag}->{$subfield}->{repeatable},
318 kohafield => $tagslib->{$tag}->{$subfield}->{kohafield},
320 id => "tag_".$tag."_subfield_".$id_subfield."_".$index_tag."_".$index_subfield,
322 random => CreateKey(),
325 if(exists $mandatory_z3950->{$tag.$subfield}){
326 $subfield_data{z3950_mandatory} = $mandatory_z3950->{$tag.$subfield};
328 # decide if the subfield must be expanded (visible) by default or not
329 # if it is mandatory, then expand. If it is hidden explicitly by the hidden flag, hidden anyway
330 $subfield_data{visibility} = "display:none;"
331 if ( ($tagslib->{$tag}->{$subfield}->{hidden} % 2 == 1) and $value ne ''
332 or ($value eq '' and !$tagslib->{$tag}->{$subfield}->{mandatory})
334 # always expand all subfields of a mandatory field
335 $subfield_data{visibility} = "" if $tagslib->{$tag}->{mandatory};
336 # it's an authorised field
337 if ( $tagslib->{$tag}->{$subfield}->{authorised_value} ) {
338 $subfield_data{marc_value} =
339 build_authorized_values_list( $tag, $subfield, $value, $dbh,
340 $authorised_values_sth,$index_tag,$index_subfield );
342 # it's a subfield $9 linking to an authority record - see bug 2206
344 elsif ($subfield eq "9" and
345 exists($tagslib->{$tag}->{'a'}->{authtypecode}) and
346 defined($tagslib->{$tag}->{'a'}->{authtypecode}) and
347 $tagslib->{$tag}->{'a'}->{authtypecode} ne '') {
349 $subfield_data{marc_value} =
350 "<input type=\"text\"
351 id=\"".$subfield_data{id}."\"
352 name=\"".$subfield_data{id}."\"
354 class=\"input_marceditor\"
358 readonly=\"readonly\"
361 # it's a thesaurus / authority field
363 elsif ( $tagslib->{$tag}->{$subfield}->{authtypecode} ) {
364 if (C4::Context->preference("BiblioAddsAuthorities")) {
365 $subfield_data{marc_value} =
366 "<input type=\"text\"
367 id=\"".$subfield_data{id}."\"
368 name=\"".$subfield_data{id}."\"
370 class=\"input_marceditor\"
375 <a href=\"#\" class=\"buttonDot\"
376 onclick=\"Dopop('/cgi-bin/koha/authorities/auth_finder.pl?authtypecode=".$tagslib->{$tag}->{$subfield}->{authtypecode}."&index=$subfield_data{id}','$subfield_data{id}'); return false;\" title=\"Tag Editor\">...</a>
379 $subfield_data{marc_value} =
380 "<input type=\"text\"
381 id=\"".$subfield_data{id}."\"
382 name=\"".$subfield_data{id}."\"
384 class=\"input_marceditor\"
388 readonly=\"readonly\"
390 <a href=\"#\" class=\"buttonDot\"
391 onclick=\"Dopop('/cgi-bin/koha/authorities/auth_finder.pl?authtypecode=".$tagslib->{$tag}->{$subfield}->{authtypecode}."&index=$subfield_data{id}','$subfield_data{id}'); return false;\" title=\"Tag Editor\">...</a>
394 # it's a plugin field
396 elsif ( $tagslib->{$tag}->{$subfield}->{'value_builder'} ) {
398 # opening plugin. Just check wether we are on a developper computer on a production one
399 # (the cgidir differs)
400 my $cgidir = C4::Context->intranetdir . "/cgi-bin/cataloguing/value_builder";
401 unless ( opendir( DIR, "$cgidir" ) ) {
402 $cgidir = C4::Context->intranetdir . "/cataloguing/value_builder";
405 my $plugin = $cgidir . "/" . $tagslib->{$tag}->{$subfield}->{'value_builder'};
407 my $extended_param = plugin_parameters( $dbh, $rec, $tagslib, $subfield_data{id}, $tabloop );
408 my ( $function_name, $javascript ) = plugin_javascript( $dbh, $rec, $tagslib, $subfield_data{id}, $tabloop );
410 $subfield_data{marc_value} =
411 "<input tabindex=\"1\"
413 id=\"".$subfield_data{id}."\"
414 name=\"".$subfield_data{id}."\"
416 class=\"input_marceditor\"
417 onfocus=\"Focus$function_name($index_tag)\"
420 onblur=\"Blur$function_name($index_tag); \" \/>
421 <a href=\"#\" class=\"buttonDot\" onclick=\"Clic$function_name('$subfield_data{id}'); return false;\" title=\"Tag Editor\">...</a>
424 warn "Plugin Failed: $plugin";
425 # supply default input form
426 $subfield_data{marc_value} =
427 "<input type=\"text\"
428 id=\"".$subfield_data{id}."\"
429 name=\"".$subfield_data{id}."\"
434 class=\"input_marceditor\"
438 # it's an hidden field
440 elsif ( $tag eq '' ) {
441 $subfield_data{marc_value} =
442 "<input tabindex=\"1\"
444 id=\"".$subfield_data{id}."\"
445 name=\"".$subfield_data{id}."\"
451 elsif ( $tagslib->{$tag}->{$subfield}->{'hidden'} ) {
452 $subfield_data{marc_value} =
453 "<input type=\"text\"
454 id=\"".$subfield_data{id}."\"
455 name=\"".$subfield_data{id}."\"
456 class=\"input_marceditor\"
463 # it's a standard field
469 ( C4::Context->preference("marcflavour") eq "UNIMARC" && $tag >= 300
470 and $tag < 400 && $subfield eq 'a' )
473 && C4::Context->preference("marcflavour") eq "MARC21" )
476 $subfield_data{marc_value} =
477 "<textarea cols=\"70\"
479 id=\"".$subfield_data{id}."\"
480 name=\"".$subfield_data{id}."\"
481 class=\"input_marceditor\"
487 $subfield_data{marc_value} =
488 "<input type=\"text\"
489 id=\"".$subfield_data{id}."\"
490 name=\"".$subfield_data{id}."\"
495 class=\"input_marceditor\"
500 $subfield_data{'index_subfield'} = $index_subfield;
501 return \%subfield_data;
505 =item format_indicator
507 Translate indicator value for output form - specifically, map
508 indicator = ' ' to ''. This is for the convenience of a cataloger
509 using a mouse to select an indicator input.
513 sub format_indicator {
514 my $ind_value = shift;
515 return '' if not defined $ind_value;
516 return '' if $ind_value eq ' ';
520 sub build_tabs ($$$$$) {
521 my ( $template, $record, $dbh, $encoding,$input ) = @_;
527 my $authorised_values_sth = $dbh->prepare(
528 "select authorised_value,lib
529 from authorised_values
530 where category=? order by lib"
533 # in this array, we will push all the 10 tabs
534 # to avoid having 10 tabs in the template : they will all be in the same BIG_LOOP
537 my @tab_data; # all tags to display
539 foreach my $used ( @$usedTagsLib ){
540 push @tab_data,$used->{tagfield} if not $seen{$used->{tagfield}};
541 $seen{$used->{tagfield}}++;
545 foreach(@$usedTagsLib){
546 if($_->{tab} > -1 && $_->{tab} >= $max_num_tab && $_->{tagfield} != '995'){ # FIXME : MARC21 ?
547 $max_num_tab = $_->{tab};
550 if($max_num_tab >= 9){
553 # loop through each tab 0 through 9
554 for ( my $tabloop = 0 ; $tabloop <= $max_num_tab ; $tabloop++ ) {
555 my @loop_data = (); #innerloop in the template.
557 foreach my $tag (@tab_data) {
560 my ($indicator1, $indicator2);
561 my $index_tag = CreateKey;
563 # if MARC::Record is not empty =>use it as master loop, then add missing subfields that should be in the tab.
564 # if MARC::Record is empty => use tab as master loop.
565 if ( $record ne -1 && ( $record->field($tag) || $tag eq '000' ) ) {
567 if ( $tag ne '000' ) {
568 @fields = $record->field($tag);
571 push @fields, $record->leader(); # if tag == 000
573 # loop through each field
574 foreach my $field (@fields) {
578 my ( $value, $subfield );
579 if ( $tag ne '000' ) {
580 $value = $field->data();
587 next if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop );
589 if ( $tagslib->{$tag}->{$subfield}->{kohafield} eq
590 'biblio.biblionumber' );
594 $tag, $subfield, $value, $index_tag, $tabloop, $record,
595 $authorised_values_sth,$input
600 my @subfields = $field->subfields();
601 foreach my $subfieldcount ( 0 .. $#subfields ) {
602 my $subfield = $subfields[$subfieldcount][0];
603 my $value = $subfields[$subfieldcount][1];
604 next if ( length $subfield != 1 );
605 next if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop );
609 $tag, $subfield, $value, $index_tag, $tabloop,
610 $record, $authorised_values_sth,$input
616 # now, loop again to add parameter subfield that are not in the MARC::Record
617 foreach my $subfield ( sort( keys %{ $tagslib->{$tag} } ) )
619 next if ( length $subfield != 1 );
620 next if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop );
621 next if ( $tag < 10 );
623 if ( ( $tagslib->{$tag}->{$subfield}->{hidden} <= -4 )
624 or ( $tagslib->{$tag}->{$subfield}->{hidden} >= 5 ) )
625 and not ( $subfield eq "9" and
626 exists($tagslib->{$tag}->{'a'}->{authtypecode}) and
627 defined($tagslib->{$tag}->{'a'}->{authtypecode}) and
628 $tagslib->{$tag}->{'a'}->{authtypecode} ne ""
630 ; #check for visibility flag
631 # if subfield is $9 in a field whose $a is authority-controlled,
632 # always include in the form regardless of the hidden setting - bug 2206
633 next if ( defined( $field->subfield($subfield) ) );
637 $tag, $subfield, '', $index_tag, $tabloop, $record,
638 $authorised_values_sth,$input
642 if ( $#subfields_data >= 0 ) {
643 # build the tag entry.
644 # note that the random() field is mandatory. Otherwise, on repeated fields, you'll
645 # have twice the same "name" value, and cgi->param() will return only one, making
646 # all subfields to be merged in a single field.
650 tag_lib => $tagslib->{$tag}->{lib},
651 repeatable => $tagslib->{$tag}->{repeatable},
652 subfield_loop => \@subfields_data,
653 fixedfield => $tag < 10?1:0,
656 if ($tag >= 010){ # no indicator for theses tag
657 $tag_data{indicator1} = format_indicator($field->indicator(1)),
658 $tag_data{indicator2} = format_indicator($field->indicator(2)),
660 push( @loop_data, \%tag_data );
662 } # foreach $field end
664 # if breeding is empty
668 foreach my $subfield ( sort( keys %{ $tagslib->{$tag} } ) ) {
669 next if ( length $subfield != 1 );
671 if ( ( $tagslib->{$tag}->{$subfield}->{hidden} <= -5 )
672 or ( $tagslib->{$tag}->{$subfield}->{hidden} >= 4 ) )
673 and not ( $subfield eq "9" and
674 exists($tagslib->{$tag}->{'a'}->{authtypecode}) and
675 defined($tagslib->{$tag}->{'a'}->{authtypecode}) and
676 $tagslib->{$tag}->{'a'}->{authtypecode} ne ""
678 ; #check for visibility flag
679 # if subfield is $9 in a field whose $a is authority-controlled,
680 # always include in the form regardless of the hidden setting - bug 2206
682 if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop );
686 $tag, $subfield, '', $index_tag, $tabloop, $record,
687 $authorised_values_sth,$input
691 if ( $#subfields_data >= 0 ) {
695 tag_lib => $tagslib->{$tag}->{lib},
696 repeatable => $tagslib->{$tag}->{repeatable},
697 indicator1 => $indicator1,
698 indicator2 => $indicator2,
699 subfield_loop => \@subfields_data,
700 tagfirstsubfield => $subfields_data[0],
701 fixedfield => $tag < 10?1:0,
704 push @loop_data, \%tag_data ;
708 if ( $#loop_data >= 0 ) {
711 innerloop => \@loop_data,
715 $template->param( BIG_LOOP => \@BIG_LOOP );
719 # sub that tries to find authorities linked to the biblio
721 # - search in the authority DB for the same authid (in $9 of the biblio)
722 # - search in the authority DB for the same 001 (in $3 of the biblio in UNIMARC)
723 # - search in the authority DB for the same values (exactly) (in all subfields of the biblio)
724 # if the authority is found, the biblio is modified accordingly to be connected to the authority.
725 # if the authority is not found, it's added, and the biblio is then modified to be connected to the authority.
728 sub BiblioAddAuthorities{
729 my ( $record, $frameworkcode ) = @_;
730 my $dbh=C4::Context->dbh;
731 my $query=$dbh->prepare(qq|
732 SELECT authtypecode,tagfield
733 FROM marc_subfield_structure
734 WHERE frameworkcode=?
735 AND (authtypecode IS NOT NULL AND authtypecode<>\"\")|);
736 # SELECT authtypecode,tagfield
737 # FROM marc_subfield_structure
738 # WHERE frameworkcode=?
739 # AND (authtypecode IS NOT NULL OR authtypecode<>\"\")|);
740 $query->execute($frameworkcode);
741 my ($countcreated,$countlinked);
742 while (my $data=$query->fetchrow_hashref){
743 foreach my $field ($record->field($data->{tagfield})){
744 next if ($field->subfield('3')||$field->subfield('9'));
745 # No authorities id in the tag.
746 # Search if there is any authorities to link to.
747 my $query='at='.$data->{authtypecode}.' ';
748 map {$query.= ' and he,ext="'.$_->[1].'"' if ($_->[0]=~/[A-z]/)} $field->subfields();
749 my ($error, $results, $total_hits)=SimpleSearch( $query, undef, undef, [ "authorityserver" ] );
750 # there is only 1 result
752 warn "BIBLIOADDSAUTHORITIES: $error";
755 if ($results && scalar(@$results)==1) {
756 my $marcrecord = MARC::File::USMARC::decode($results->[0]);
757 $field->add_subfields('9'=>$marcrecord->field('001')->data);
759 } elsif (scalar(@$results)>1) {
760 #More than One result
761 #This can comes out of a lack of a subfield.
762 # my $marcrecord = MARC::File::USMARC::decode($results->[0]);
763 # $record->field($data->{tagfield})->add_subfields('9'=>$marcrecord->field('001')->data);
766 #There are no results, build authority record, add it to Authorities, get authid and add it to 9
767 ###NOTICE : This is only valid if a subfield is linked to one and only one authtypecode
768 ###NOTICE : This can be a problem. We should also look into other types and rejected forms.
769 my $authtypedata=GetAuthType($data->{authtypecode});
770 next unless $authtypedata;
771 my $marcrecordauth=MARC::Record->new();
772 my $authfield=MARC::Field->new($authtypedata->{auth_tag_to_report},'','',"a"=>"".$field->subfield('a'));
773 map { $authfield->add_subfields($_->[0]=>$_->[1]) if ($_->[0]=~/[A-z]/ && $_->[0] ne "a" )} $field->subfields();
774 $marcrecordauth->insert_fields_ordered($authfield);
775 # warn "AUTH RECORD ADDED : ".$marcrecordauth->as_formatted;
776 my $authid=AddAuthority($marcrecordauth,'',$data->{authtypecode});
778 $field->add_subfields('9'=>$authid);
782 return ($countlinked,$countcreated);
785 # ========================
787 #=========================
789 my $error = $input->param('error');
790 my $biblionumber = $input->param('biblionumber'); # if biblionumber exists, it's a modif, not a new biblio.
791 my $breedingid = $input->param('breedingid');
792 my $z3950 = $input->param('z3950');
793 my $op = $input->param('op');
794 my $mode = $input->param('mode');
795 my $frameworkcode = $input->param('frameworkcode');
796 my $dbh = C4::Context->dbh;
798 $frameworkcode = &GetFrameworkCode($biblionumber)
799 if ( $biblionumber and not($frameworkcode) );
801 $frameworkcode = '' if ( $frameworkcode eq 'Default' );
802 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
804 template_name => "cataloguing/addbiblio.tmpl",
807 authnotrequired => 0,
808 flagsrequired => { editcatalogue => 1 },
812 # Getting the list of all frameworks
814 my $frameworks = getframeworks;
815 my @frameworkcodeloop;
816 foreach my $thisframeworkcode ( keys %$frameworks ) {
818 value => $thisframeworkcode,
819 frameworktext => $frameworks->{$thisframeworkcode}->{'frameworktext'},
821 if ($frameworkcode eq $thisframeworkcode){
822 $row{'selected'}="selected=\"selected\"";
824 push @frameworkcodeloop, \%row;
826 $template->param( frameworkcodeloop => \@frameworkcodeloop,
827 breedingid => $breedingid );
830 $tagslib = &GetMarcStructure( 1, $frameworkcode );
831 $usedTagsLib = &GetUsedMarcStructure( $frameworkcode );
832 $mandatory_z3950 = GetMandatoryFieldZ3950($frameworkcode);
838 $biblionumbertagfield,
839 $biblionumbertagsubfield,
840 $biblioitemnumtagfield,
841 $biblioitemnumtagsubfield,
846 if (($biblionumber) && !($breedingid)){
847 $record = GetMarcBiblio($biblionumber);
850 ( $record, $encoding ) = MARCfindbreeding( $breedingid ) ;
857 $template->param( title => $record->title(), );
859 # if it's a modif, retrieve bibli and biblioitem numbers for the future modification of old-DB.
860 ( $biblionumbertagfield, $biblionumbertagsubfield ) =
861 &GetMarcFromKohaField( "biblio.biblionumber", $frameworkcode );
862 ( $biblioitemnumtagfield, $biblioitemnumtagsubfield ) =
863 &GetMarcFromKohaField( "biblioitems.biblioitemnumber", $frameworkcode );
865 # search biblioitems value
866 my $sth = $dbh->prepare("select biblioitemnumber from biblioitems where biblionumber=?");
867 $sth->execute($biblionumber);
868 ($biblioitemnumber) = $sth->fetchrow;
871 #-------------------------------------------------------------------------------------
872 if ( $op eq "addbiblio" ) {
873 #-------------------------------------------------------------------------------------
875 my @params = $input->param();
876 $record = TransformHtmlToMarc( \@params , $input );
877 # check for a duplicate
878 my ($duplicatebiblionumber,$duplicatetitle) = FindDuplicate($record) if (!$is_a_modif);
879 my $confirm_not_duplicate = $input->param('confirm_not_duplicate');
880 # it is not a duplicate (determined either by Koha itself or by user checking it's not a duplicate)
881 if ( !$duplicatebiblionumber or $confirm_not_duplicate ) {
884 if (C4::Context->preference("BiblioAddsAuthorities")){
885 my ($countlinked,$countcreated)=BiblioAddAuthorities($record,$frameworkcode);
888 ModBiblioframework( $biblionumber, $frameworkcode );
889 ModBiblio( $record, $biblionumber, $frameworkcode );
892 ( $biblionumber, $oldbibitemnum ) = AddBiblio( $record, $frameworkcode );
895 if ($mode ne "popup"){
896 print $input->redirect(
897 "/cgi-bin/koha/cataloguing/additem.pl?biblionumber=$biblionumber&frameworkcode=$frameworkcode"
902 biblionumber => $biblionumber,
906 $template->param( title => $record->subfield('200',"a") ) if ($record ne "-1" && C4::Context->preference('marcflavour') =~/unimarc/i);
907 $template->param( title => $record->title() ) if ($record ne "-1" && C4::Context->preference('marcflavour') eq "usmarc");
910 itemtype => $frameworkcode,
912 output_html_with_http_headers $input, $cookie, $template->output;
916 # it may be a duplicate, warn the user and do nothing
917 build_tabs ($template, $record, $dbh,$encoding,$input);
919 biblionumber => $biblionumber,
920 biblioitemnumber => $biblioitemnumber,
921 duplicatebiblionumber => $duplicatebiblionumber,
922 duplicatebibid => $duplicatebiblionumber,
923 duplicatetitle => $duplicatetitle,
927 elsif ( $op eq "delete" ) {
929 my $error = &DelBiblio($biblionumber);
931 warn "ERROR when DELETING BIBLIO $biblionumber : $error";
932 print "Content-Type: text/html\n\n<html><body><h1>ERROR when DELETING BIBLIO $biblionumber : $error</h1></body></html>";
936 print $input->redirect('/cgi-bin/koha/catalogue/search.pl');
940 #----------------------------------------------------------------------------
941 # If we're in a duplication case, we have to set to "" the biblionumber
942 # as we'll save the biblio as a new one.
943 if ( $op eq "duplicate" ) {
947 #FIXME: it's kind of silly to go from MARC::Record to MARC::File::XML and then back again just to fix the encoding
949 my $uxml = $record->as_xml;
950 MARC::Record::default_record_format("UNIMARC")
951 if ( C4::Context->preference("marcflavour") eq "UNIMARC" );
952 my $urecord = MARC::Record::new_from_xml( $uxml, 'UTF-8' );
955 build_tabs( $template, $record, $dbh, $encoding,$input );
957 biblionumber => $biblionumber,
958 biblionumbertagfield => $biblionumbertagfield,
959 biblionumbertagsubfield => $biblionumbertagsubfield,
960 biblioitemnumtagfield => $biblioitemnumtagfield,
961 biblioitemnumtagsubfield => $biblioitemnumtagsubfield,
962 biblioitemnumber => $biblioitemnumber,
966 $template->param( title => $record->title() ) if ( $record ne "-1" );
969 frameworkcode => $frameworkcode,
970 itemtype => $frameworkcode,
973 output_html_with_http_headers $input, $cookie, $template->output;