#!/usr/bin/perl # Copyright 2000-2002 Katipo Communications # Copyright 2004-2010 BibLibre # # 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 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. # # You should have received a copy of the GNU General Public License # along with Koha; if not, see . use Modern::Perl; use CGI; use C4::Output qw( output_html_with_http_headers ); use C4::Auth qw( get_template_and_user haspermission ); use C4::Biblio qw( AddBiblio DelBiblio GetFrameworkCode GetMarcFromKohaField GetMarcStructure GetUsedMarcStructure ModBiblio prepare_host_field PrepHostMarcField TransformHtmlToMarc ApplyMarcOverlayRules ); use C4::Search qw( FindDuplicate enabled_staff_search_views ); use C4::Auth qw( get_template_and_user haspermission ); use C4::Context; use MARC::Record; use C4::ClassSource qw( GetClassSources ); use C4::ImportBatch qw( GetImportRecordMarc ); use C4::Charset qw( SetMarcUnicodeFlag ); use Koha::BiblioFrameworks; use Koha::DateUtils qw( dt_from_string ); use Koha::Biblios; use Koha::ItemTypes; use Koha::Libraries; use Koha::BiblioFrameworks; use Koha::Patrons; use MARC::File::USMARC; use MARC::File::XML; use URI::Escape qw( uri_escape_utf8 ); if ( C4::Context->preference('marcflavour') eq 'UNIMARC' ) { MARC::File::XML->default_record_format('UNIMARC'); } our($tagslib,$authorised_values_sth,$is_a_modif,$usedTagsLib,$mandatory_z3950); =head1 FUNCTIONS =head2 MARCfindbreeding $record = MARCfindbreeding($breedingid); Look up the import record repository for the record with record with id $breedingid. If found, returns the decoded MARC::Record; otherwise, -1 is returned (FIXME). Returns as second parameter the character encoding. =cut sub MARCfindbreeding { my ( $id ) = @_; my ($marc, $encoding) = GetImportRecordMarc($id); # remove the - in isbn, koha store isbn without any - if ($marc) { my $record = MARC::Record->new_from_usmarc($marc); if(C4::Context->preference('autoControlNumber') eq 'biblionumber'){ my @control_num = $record->field('001'); $record->delete_fields(@control_num); } my ($isbnfield,$isbnsubfield) = GetMarcFromKohaField( 'biblioitems.isbn' ); if ( $record->field($isbnfield) ) { foreach my $field ( $record->field($isbnfield) ) { foreach my $subfield ( $field->subfield($isbnsubfield) ) { my $newisbn = $field->subfield($isbnsubfield); $newisbn =~ s/-//g; $field->update( $isbnsubfield => $newisbn ); } } } # fix the unimarc 100 coded field (with unicode information) if (C4::Context->preference('marcflavour') eq 'UNIMARC' && $record->subfield(100,'a')) { my $f100a=$record->subfield(100,'a'); my $f100 = $record->field(100); my $f100temp = $f100->as_string; $record->delete_field($f100); if ( length($f100temp) > 28 ) { substr( $f100temp, 26, 2, "50" ); $f100->update( 'a' => $f100temp ); my $f100 = MARC::Field->new( '100', '', '', 'a' => $f100temp ); $record->insert_fields_ordered($f100); } } if ( !defined(ref($record)) ) { return -1; } else { # normalize author : UNIMARC specific... if ( C4::Context->preference("z3950NormalizeAuthor") and C4::Context->preference("z3950AuthorAuthFields") and C4::Context->preference("marcflavour") eq 'UNIMARC' ) { my ( $tag, $subfield ) = GetMarcFromKohaField( "biblio.author" ); my $auth_fields = C4::Context->preference("z3950AuthorAuthFields"); my @auth_fields = split /,/, $auth_fields; my $field; if ( $record->field($tag) ) { foreach my $tmpfield ( $record->field($tag)->subfields ) { my $subfieldcode = shift @$tmpfield; my $subfieldvalue = shift @$tmpfield; if ($field) { $field->add_subfields( "$subfieldcode" => $subfieldvalue ) if ( $subfieldcode ne $subfield ); } else { $field = MARC::Field->new( $tag, "", "", $subfieldcode => $subfieldvalue ) if ( $subfieldcode ne $subfield ); } } } $record->delete_field( $record->field($tag) ); foreach my $fieldtag (@auth_fields) { next unless ( $record->field($fieldtag) ); my $lastname = $record->field($fieldtag)->subfield('a'); my $firstname = $record->field($fieldtag)->subfield('b'); my $title = $record->field($fieldtag)->subfield('c'); my $number = $record->field($fieldtag)->subfield('d'); if ($title) { $field->add_subfields( "$subfield" => ucfirst($title) . " " . ucfirst($firstname) . " " . $number ); } else { $field->add_subfields( "$subfield" => ucfirst($firstname) . ", " . ucfirst($lastname) ); } } $record->insert_fields_ordered($field); } return $record, $encoding; } } return -1; } =head2 build_authorized_values_list =cut sub build_authorized_values_list { my ( $tag, $subfield, $value, $dbh, $authorised_values_sth,$index_tag,$index_subfield ) = @_; my @authorised_values; my %authorised_lib; # builds list, depending on authorised value... #---- branch my $category = $tagslib->{$tag}->{$subfield}->{authorised_value}; if ( $category eq "branches" ) { my $libraries = Koha::Libraries->search_filtered({}, {order_by => ['branchname']}); while ( my $l = $libraries->next ) { push @authorised_values, $l->branchcode;; $authorised_lib{$l->branchcode} = $l->branchname; } } elsif ( $category eq "itemtypes" ) { push @authorised_values, ""; my $itemtype; my $itemtypes = Koha::ItemTypes->search_with_localization; while ( $itemtype = $itemtypes->next ) { push @authorised_values, $itemtype->itemtype; $authorised_lib{$itemtype->itemtype} = $itemtype->translated_description; } $value = $itemtype unless ($value); } elsif ( $category eq "cn_source" ) { push @authorised_values, ""; my $class_sources = GetClassSources(); my $default_source = C4::Context->preference("DefaultClassificationSource"); foreach my $class_source (sort keys %$class_sources) { next unless $class_sources->{$class_source}->{'used'} or ($value and $class_source eq $value) or ($class_source eq $default_source); push @authorised_values, $class_source; $authorised_lib{$class_source} = $class_sources->{$class_source}->{'description'}; } $value = $default_source unless $value; } else { my $branch_limit = C4::Context->userenv ? C4::Context->userenv->{"branch"} : ""; $authorised_values_sth->execute( $tagslib->{$tag}->{$subfield}->{authorised_value}, $branch_limit ? $branch_limit : (), ); push @authorised_values, ""; while ( my ( $value, $lib ) = $authorised_values_sth->fetchrow_array ) { push @authorised_values, $value; $authorised_lib{$value} = $lib; } } $authorised_values_sth->finish; return { type => 'select', id => "tag_".$tag."_subfield_".$subfield."_".$index_tag."_".$index_subfield, name => "tag_".$tag."_subfield_".$subfield."_".$index_tag."_".$index_subfield, default => $value, values => \@authorised_values, labels => \%authorised_lib, ( ( grep { $_ eq $category } ( qw(branches itemtypes cn_source) ) ) ? () : ( category => $category ) ), }; } =head2 CreateKey Create a random value to set it into the input name =cut sub CreateKey { return int(rand(1000000)); } =head2 GetMandatoryFieldZ3950 This function returns a hashref which contains all mandatory field to search with z3950 server. =cut sub GetMandatoryFieldZ3950 { my $frameworkcode = shift; my @isbn = GetMarcFromKohaField( 'biblioitems.isbn' ); my @title = GetMarcFromKohaField( 'biblio.title' ); my @author = GetMarcFromKohaField( 'biblio.author' ); my @issn = GetMarcFromKohaField( 'biblioitems.issn' ); my @lccn = GetMarcFromKohaField( 'biblioitems.lccn' ); return { $isbn[0].$isbn[1] => 'isbn', $title[0].$title[1] => 'title', $author[0].$author[1] => 'author', $issn[0].$issn[1] => 'issn', $lccn[0].$lccn[1] => 'lccn', }; } =head2 create_input builds the entry for a subfield. =cut sub create_input { my ( $tag, $subfield, $value, $index_tag, $rec, $authorised_values_sth,$cgi ) = @_; my $index_subfield = CreateKey(); # create a specifique key for each subfield # Apply optional framework default value when it is a new record, # or when editing as new (duplicating a record), # or when changing a record's framework, # or when importing a record, # based on the ApplyFrameworkDefaults setting. # Substitute date parts, user name my $applydefaults = C4::Context->preference('ApplyFrameworkDefaults'); if ( $value eq '' && ( ( $applydefaults =~ /new/ && !$cgi->param('biblionumber') ) || ( $applydefaults =~ /duplicate/ && $cgi->param('op') eq 'duplicate' ) || ( $applydefaults =~ /changed/ && $cgi->param('changed_framework') ) || ( $applydefaults =~ /imported/ && $cgi->param('breedingid') ) ) ) { $value = $tagslib->{$tag}->{$subfield}->{defaultvalue} // q{}; # get today date & replace <>, <>, <>, <
> if provided in the default value my $today_dt = dt_from_string; my $year = $today_dt->strftime('%Y'); my $shortyear = $today_dt->strftime('%y'); my $month = $today_dt->strftime('%m'); my $day = $today_dt->strftime('%d'); $value =~ s/<>/$year/g; $value =~ s/<>/$shortyear/g; $value =~ s/<>/$month/g; $value =~ s/<
>/$day/g; # And <> with surname (?) my $username=(C4::Context->userenv?C4::Context->userenv->{'surname'}:"superlibrarian"); $value=~s/<>/$username/g; } my $dbh = C4::Context->dbh; # map '@' as "subfield" label for fixed fields # to something that's allowed in a div id. my $id_subfield = $subfield; $id_subfield = "00" if $id_subfield eq "@"; my %subfield_data = ( tag => $tag, subfield => $id_subfield, marc_lib => $tagslib->{$tag}->{$subfield}->{lib}, tag_mandatory => $tagslib->{$tag}->{mandatory}, mandatory => $tagslib->{$tag}->{$subfield}->{mandatory}, important => $tagslib->{$tag}->{$subfield}->{important}, repeatable => $tagslib->{$tag}->{$subfield}->{repeatable}, kohafield => $tagslib->{$tag}->{$subfield}->{kohafield}, index => $index_tag, id => "tag_".$tag."_subfield_".$id_subfield."_".$index_tag."_".$index_subfield, value => $value, maxlength => $tagslib->{$tag}->{$subfield}->{maxlength}, random => CreateKey(), ); if(exists $mandatory_z3950->{$tag.$subfield}){ $subfield_data{z3950_mandatory} = $mandatory_z3950->{$tag.$subfield}; } # Subfield is hidden depending of hidden and mandatory flag, and is always # shown if it contains anything or if its field is mandatory or important. my $tdef = $tagslib->{$tag}; $subfield_data{visibility} = "display:none;" if $tdef->{$subfield}->{hidden} % 2 == 1 && $value eq '' && !$tdef->{$subfield}->{mandatory} && !$tdef->{mandatory} && !$tdef->{$subfield}->{important} && !$tdef->{important}; # expand all subfields of 773 if there is a host item provided in the input $subfield_data{visibility} ="" if ($tag eq 773 and $cgi->param('hostitemnumber')); # it's an authorised field if ( $tagslib->{$tag}->{$subfield}->{authorised_value} ) { $subfield_data{marc_value} = build_authorized_values_list( $tag, $subfield, $value, $dbh, $authorised_values_sth,$index_tag,$index_subfield ); # it's a subfield $9 linking to an authority record - see bug 2206 and 28022 } elsif ($subfield eq "9" and exists($tagslib->{$tag}->{'a'}->{authtypecode}) and defined($tagslib->{$tag}->{'a'}->{authtypecode}) and $tagslib->{$tag}->{'a'}->{authtypecode} ne '' and $tagslib->{$tag}->{'a'}->{hidden} > -4 and $tagslib->{$tag}->{'a'}->{hidden} < 5) { $subfield_data{marc_value} = { type => 'text', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 5, maxlength => $subfield_data{maxlength}, readonly => 1, }; # it's a thesaurus / authority field } elsif ( $tagslib->{$tag}->{$subfield}->{authtypecode} ) { # when authorities auto-creation is allowed, do not set readonly my $is_readonly = C4::Context->preference("RequireChoosingExistingAuthority"); $subfield_data{marc_value} = { type => 'text', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 67, maxlength => $subfield_data{maxlength}, readonly => ($is_readonly) ? 1 : 0, authtype => $tagslib->{$tag}->{$subfield}->{authtypecode}, }; # it's a plugin field } elsif ( $tagslib->{$tag}->{$subfield}->{'value_builder'} ) { require Koha::FrameworkPlugin; my $plugin = Koha::FrameworkPlugin->new( { name => $tagslib->{$tag}->{$subfield}->{'value_builder'}, }); my $pars= { dbh => $dbh, record => $rec, tagslib => $tagslib, id => $subfield_data{id} }; $plugin->build( $pars ); if( !$plugin->errstr ) { $subfield_data{marc_value} = { type => 'text_complex', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 67, maxlength => $subfield_data{maxlength}, javascript => $plugin->javascript, plugin => $plugin->name, noclick => $plugin->noclick, }; } else { warn $plugin->errstr; # supply default input form $subfield_data{marc_value} = { type => 'text', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 67, maxlength => $subfield_data{maxlength}, readonly => 0, }; } # it's an hidden field } elsif ( $tag eq '' ) { $subfield_data{marc_value} = { type => 'hidden', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 67, maxlength => $subfield_data{maxlength}, }; } else { # it's a standard field if ( length($value) > 100 or ( C4::Context->preference("marcflavour") eq "UNIMARC" && $tag >= 300 and $tag < 400 && $subfield eq 'a' ) or ( $tag >= 500 and $tag < 600 && C4::Context->preference("marcflavour") eq "MARC21" ) ) { $subfield_data{marc_value} = { type => 'textarea', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, }; } else { $subfield_data{marc_value} = { type => 'text', id => $subfield_data{id}, name => $subfield_data{id}, value => $value, size => 67, maxlength => $subfield_data{maxlength}, readonly => 0, }; } } $subfield_data{'index_subfield'} = $index_subfield; return \%subfield_data; } =head2 format_indicator Translate indicator value for output form - specifically, map indicator = ' ' to ''. This is for the convenience of a cataloger using a mouse to select an indicator input. =cut sub format_indicator { my $ind_value = shift; return '' if not defined $ind_value; return '' if $ind_value eq ' '; return $ind_value; } sub build_tabs { my ( $template, $record, $dbh, $encoding,$input ) = @_; # fill arrays my @loop_data = (); my $tag; my $branch_limit = C4::Context->userenv ? C4::Context->userenv->{"branch"} : ""; my $query = "SELECT authorised_value, lib FROM authorised_values"; $query .= qq{ LEFT JOIN authorised_values_branches ON ( id = av_id )} if $branch_limit; $query .= " WHERE category = ?"; $query .= " AND ( branchcode = ? OR branchcode IS NULL )" if $branch_limit; $query .= " GROUP BY authorised_value,lib ORDER BY lib, lib_opac"; my $authorised_values_sth = $dbh->prepare( $query ); # in this array, we will push all the 10 tabs # to avoid having 10 tabs in the template : they will all be in the same BIG_LOOP my @BIG_LOOP; my %seen; my @tab_data; # all tags to display my $max_num_tab=-1; my ( $itemtag, $itemsubfield ) = GetMarcFromKohaField( "items.itemnumber" ); foreach my $used ( @$usedTagsLib ){ push @tab_data,$used->{tagfield} if not $seen{$used->{tagfield}}; $seen{$used->{tagfield}}++; if ( $used->{tab} > -1 && $used->{tab} >= $max_num_tab && $used->{tagfield} ne $itemtag ) { $max_num_tab = $used->{tab}; } } if($max_num_tab >= 9){ $max_num_tab = 9; } # loop through each tab 0 through 9 for ( my $tabloop = 0 ; $tabloop <= $max_num_tab ; $tabloop++ ) { my @loop_data = (); #innerloop in the template. my $i = 0; foreach my $tag (sort @tab_data) { $i++; next if ! $tag; my ($indicator1, $indicator2); my $index_tag = CreateKey; # if MARC::Record is not empty =>use it as master loop, then add missing subfields that should be in the tab. # if MARC::Record is empty => use tab as master loop. if ( $record ne -1 && ( $record->field($tag) || $tag eq '000' ) ) { my @fields; if ( $tag ne '000' ) { @fields = $record->field($tag); } else { push @fields, $record->leader(); # if tag == 000 } # loop through each field foreach my $field (@fields) { my @subfields_data; if ( $tag < 10 ) { my ( $value, $subfield ); if ( $tag ne '000' ) { $value = $field->data(); $subfield = "@"; } else { $value = $field; $subfield = '@'; } next if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop ); next if ( $tagslib->{$tag}->{$subfield}->{kohafield} eq 'biblio.biblionumber' ); push( @subfields_data, &create_input( $tag, $subfield, $value, $index_tag, $record, $authorised_values_sth,$input ) ); } else { my @subfields = $field->subfields(); foreach my $subfieldcount ( 0 .. $#subfields ) { my $subfield = $subfields[$subfieldcount][0]; my $value = $subfields[$subfieldcount][1]; next if ( length $subfield != 1 ); next if ( !defined $tagslib->{$tag}->{$subfield} || $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop ); push( @subfields_data, &create_input( $tag, $subfield, $value, $index_tag, $record, $authorised_values_sth,$input ) ); } } # now, loop again to add parameter subfield that are not in the MARC::Record foreach my $subfield ( sort( keys %{ $tagslib->{$tag} } ) ) { next if ( length $subfield != 1 ); next if ( $tagslib->{$tag}->{$subfield}->{tab} ne $tabloop ); next if ( $tag < 10 ); next if ( ( $tagslib->{$tag}->{$subfield}->{hidden} <= -4 ) or ( $tagslib->{$tag}->{$subfield}->{hidden} >= 5 ) ) and not ( $subfield eq "9" and exists($tagslib->{$tag}->{'a'}->{authtypecode}) and defined($tagslib->{$tag}->{'a'}->{authtypecode}) and $tagslib->{$tag}->{'a'}->{authtypecode} ne "" and $tagslib->{$tag}->{'a'}->{hidden} > -4 and $tagslib->{$tag}->{'a'}->{hidden} < 5 ) ; #check for visibility flag # if subfield is $9 in a field whose $a is authority-controlled, # always include in the form regardless of the hidden setting - bug 2206 and 28022 next if ( defined( $field->subfield($subfield) ) ); push( @subfields_data, &create_input( $tag, $subfield, '', $index_tag, $record, $authorised_values_sth,$input ) ); } if ( $#subfields_data >= 0 ) { # build the tag entry. # note that the random() field is mandatory. Otherwise, on repeated fields, you'll # have twice the same "name" value, and cgi->param() will return only one, making # all subfields to be merged in a single field. my %tag_data = ( tag => $tag, index => $index_tag, tag_lib => $tagslib->{$tag}->{lib}, repeatable => $tagslib->{$tag}->{repeatable}, mandatory => $tagslib->{$tag}->{mandatory}, important => $tagslib->{$tag}->{important}, subfield_loop => \@subfields_data, fixedfield => $tag < 10?1:0, random => CreateKey, ); if ($tag >= 10){ # no indicator for 00x tags $tag_data{indicator1} = format_indicator($field->indicator(1)), $tag_data{indicator2} = format_indicator($field->indicator(2)), } push( @loop_data, \%tag_data ); } } # foreach $field end # if breeding is empty } else { my @subfields_data; foreach my $subfield ( sort { $a->{display_order} <=> $b->{display_order} || $a->{subfield} cmp $b->{subfield} } grep { ref($_) && %$_ } # Not a subfield (values for "important", "lib", "mandatory", etc.) or empty values %{ $tagslib->{$tag} } ) { next if ( ( $subfield->{hidden} <= -4 ) or ( $subfield->{hidden} >= 5 ) ) and not ( $subfield->{subfield} eq "9" and exists($tagslib->{$tag}->{'a'}->{authtypecode}) and defined($tagslib->{$tag}->{'a'}->{authtypecode}) and $tagslib->{$tag}->{'a'}->{authtypecode} ne "" and $tagslib->{$tag}->{'a'}->{hidden} > -4 and $tagslib->{$tag}->{'a'}->{hidden} < 5 ) ; #check for visibility flag # if subfield is $9 in a field whose $a is authority-controlled, # always include in the form regardless of the hidden setting - bug 2206 and 28022 next if ( $subfield->{tab} ne $tabloop ); push( @subfields_data, &create_input( $tag, $subfield->{subfield}, '', $index_tag, $record, $authorised_values_sth,$input ) ); } if ( $#subfields_data >= 0 ) { my %tag_data = ( tag => $tag, index => $index_tag, tag_lib => $tagslib->{$tag}->{lib}, repeatable => $tagslib->{$tag}->{repeatable}, mandatory => $tagslib->{$tag}->{mandatory}, important => $tagslib->{$tag}->{important}, indicator1 => ( $indicator1 || $tagslib->{$tag}->{ind1_defaultvalue} ), #if not set, try to load the default value indicator2 => ( $indicator2 || $tagslib->{$tag}->{ind2_defaultvalue} ), #use short-circuit operator for efficiency subfield_loop => \@subfields_data, tagfirstsubfield => $subfields_data[0], fixedfield => $tag < 10?1:0, ); push @loop_data, \%tag_data ; } } } if ( $#loop_data >= 0 ) { push @BIG_LOOP, { number => $tabloop, innerloop => \@loop_data, }; } } $authorised_values_sth->finish; $template->param( BIG_LOOP => \@BIG_LOOP ); } # ======================== # MAIN #========================= my $input = CGI->new; my $error = $input->param('error'); my $biblionumber = $input->param('biblionumber'); # if biblionumber exists, it's a modif, not a new biblio. my $parentbiblio = $input->param('parentbiblionumber'); my $breedingid = $input->param('breedingid'); my $z3950 = $input->param('z3950'); my $op = $input->param('op') // q{}; my $mode = $input->param('mode') // q{}; my $frameworkcode = $input->param('frameworkcode'); my $redirect = $input->param('redirect'); my $searchid = $input->param('searchid') // ""; my $dbh = C4::Context->dbh; my $hostbiblionumber = $input->param('hostbiblionumber'); my $hostitemnumber = $input->param('hostitemnumber'); # fast cataloguing datas in transit my $fa_circborrowernumber = $input->param('circborrowernumber'); my $fa_barcode = $input->param('barcode'); my $fa_branch = $input->param('branch'); my $fa_stickyduedate = $input->param('stickyduedate'); my $fa_duedatespec = $input->param('duedatespec'); my $userflags = 'edit_catalogue'; my $changed_framework = $input->param('changed_framework') // q{}; $frameworkcode = &GetFrameworkCode($biblionumber) if ( $biblionumber and not( defined $frameworkcode) and $op ne 'addbiblio' ); if ($frameworkcode eq 'FA'){ $userflags = 'fast_cataloging'; } $frameworkcode = '' if ( $frameworkcode eq 'Default' ); my ( $template, $loggedinuser, $cookie ) = get_template_and_user( { template_name => "cataloguing/addbiblio.tt", query => $input, type => "intranet", flagsrequired => { editcatalogue => $userflags }, } ); my $biblio; if ($biblionumber){ $biblio = Koha::Biblios->find($biblionumber); unless ( $biblio ) { $biblionumber = undef; $template->param( bib_doesnt_exist => 1 ); } } if ($frameworkcode eq 'FA'){ # We need to grab and set some variables in the template for use on the additems screen $template->param( 'circborrowernumber' => $fa_circborrowernumber, 'barcode' => $fa_barcode, 'branch' => $fa_branch, 'stickyduedate' => $fa_stickyduedate, 'duedatespec' => $fa_duedatespec, ); } elsif ( $op ne "delete" && C4::Context->preference('EnableAdvancedCatalogingEditor') && C4::Auth::haspermission(C4::Context->userenv->{id},{'editcatalogue'=>'advanced_editor'}) && $input->cookie( 'catalogue_editor_' . $loggedinuser ) eq 'advanced' && !$breedingid ) { # Only use the advanced editor for non-fast-cataloging. # breedingid is not handled because those would only come off a Z39.50 # search initiated by the basic editor. print $input->redirect( '/cgi-bin/koha/cataloguing/editor.pl' . ( $biblionumber ? ( ($op eq 'duplicate'?'#duplicate/':'#catalog/') . $biblionumber ) : '' ) ); exit; } my $frameworks = Koha::BiblioFrameworks->search({}, { order_by => ['frameworktext'] }); $template->param( frameworks => $frameworks, breedingid => $breedingid, ); # ++ Global $tagslib = &GetMarcStructure( 1, $frameworkcode ); $usedTagsLib = &GetUsedMarcStructure( $frameworkcode ); $mandatory_z3950 = GetMandatoryFieldZ3950($frameworkcode); # -- Global my $record = -1; my $encoding = ""; my ( $biblionumbertagfield, $biblionumbertagsubfield, $biblioitemnumtagfield, $biblioitemnumtagsubfield, $biblioitemnumber ); if ( $biblio && !$breedingid ) { $record = $biblio->metadata->record; } if ($breedingid) { ( $record, $encoding ) = MARCfindbreeding( $breedingid ) ; } if ( $record && $op eq 'duplicate' && C4::Context->preference('autoControlNumber') eq 'biblionumber' ){ my @control_num = $record->field('001'); $record->delete_fields(@control_num); } #populate hostfield if hostbiblionumber is available if ($hostbiblionumber) { my $marcflavour = C4::Context->preference("marcflavour"); $record = MARC::Record->new(); $record->leader(''); my $field = PrepHostMarcField( $hostbiblionumber, $hostitemnumber, $marcflavour ); $record->append_fields($field); } # This is a child record if ($parentbiblio) { my $marcflavour = C4::Context->preference('marcflavour'); $record = MARC::Record->new(); SetMarcUnicodeFlag($record, $marcflavour); my $hostfield = prepare_host_field($parentbiblio,$marcflavour); if ($hostfield) { $record->append_fields($hostfield); } } $is_a_modif = 0; if ($biblionumber) { $is_a_modif = 1; my $title = C4::Context->preference('marcflavour') eq "UNIMARC" ? $record->subfield('200', 'a') : $record->title; $template->param( title => $title ); # if it's a modif, retrieve bibli and biblioitem numbers for the future modification of old-DB. ( $biblionumbertagfield, $biblionumbertagsubfield ) = &GetMarcFromKohaField( "biblio.biblionumber" ); ( $biblioitemnumtagfield, $biblioitemnumtagsubfield ) = &GetMarcFromKohaField( "biblioitems.biblioitemnumber" ); # search biblioitems value my $sth = $dbh->prepare("select biblioitemnumber from biblioitems where biblionumber=?"); $sth->execute($biblionumber); ($biblioitemnumber) = $sth->fetchrow; if (C4::Context->preference('MARCOverlayRules')) { my $member = Koha::Patrons->find($loggedinuser); $record = ApplyMarcOverlayRules( { biblionumber => $biblionumber, record => $record, overlay_context => { source => $z3950 ? 'z3950' : 'intranet', categorycode => $member->categorycode, userid => $member->userid } } ); } } #------------------------------------------------------------------------------------- if ( $op eq "addbiblio" ) { #------------------------------------------------------------------------------------- $template->param( biblionumberdata => $biblionumber, ); # getting html input my @params = $input->multi_param(); $record = TransformHtmlToMarc( $input, 1 ); # check for a duplicate my ( $duplicatebiblionumber, $duplicatetitle ); if ( !$is_a_modif ) { ( $duplicatebiblionumber, $duplicatetitle ) = FindDuplicate($record); } my $confirm_not_duplicate = $input->param('confirm_not_duplicate'); # it is not a duplicate (determined either by Koha itself or by user checking it's not a duplicate) if ( !$duplicatebiblionumber or $confirm_not_duplicate ) { my $oldbibitemnum; if ( $is_a_modif ) { my $member = Koha::Patrons->find($loggedinuser); ModBiblio( $record, $biblionumber, $frameworkcode, { overlay_context => { source => $z3950 ? 'z3950' : 'intranet', categorycode => $member->categorycode, userid => $member->userid } } ); } else { ( $biblionumber, $oldbibitemnum ) = AddBiblio( $record, $frameworkcode ); } if ($redirect eq "items" || ($mode ne "popup" && !$is_a_modif && $redirect ne "view" && $redirect ne "just_save")){ if ($frameworkcode eq 'FA'){ print $input->redirect( '/cgi-bin/koha/cataloguing/additem.pl?' .'biblionumber='.$biblionumber .'&frameworkcode='.$frameworkcode .'&circborrowernumber='.$fa_circborrowernumber .'&branch='.$fa_branch .'&barcode='.uri_escape_utf8($fa_barcode) .'&stickyduedate='.$fa_stickyduedate .'&duedatespec='.$fa_duedatespec ); exit; } else { print $input->redirect( "/cgi-bin/koha/cataloguing/additem.pl?biblionumber=$biblionumber&frameworkcode=$frameworkcode&searchid=$searchid" ); exit; } } elsif(($is_a_modif || $redirect eq "view") && $redirect ne "just_save"){ my $defaultview = C4::Context->preference('IntranetBiblioDefaultView'); my $views = { C4::Search::enabled_staff_search_views }; if ($defaultview eq 'isbd' && $views->{can_view_ISBD}) { print $input->redirect("/cgi-bin/koha/catalogue/ISBDdetail.pl?biblionumber=$biblionumber&searchid=$searchid"); } elsif ($defaultview eq 'marc' && $views->{can_view_MARC}) { print $input->redirect("/cgi-bin/koha/catalogue/MARCdetail.pl?biblionumber=$biblionumber&frameworkcode=$frameworkcode&searchid=$searchid"); } elsif ($defaultview eq 'labeled_marc' && $views->{can_view_labeledMARC}) { print $input->redirect("/cgi-bin/koha/catalogue/labeledMARCdetail.pl?biblionumber=$biblionumber&searchid=$searchid"); } else { print $input->redirect("/cgi-bin/koha/catalogue/detail.pl?biblionumber=$biblionumber&searchid=$searchid"); } exit; } elsif ($redirect eq "just_save"){ my $tab = $input->param('current_tab'); print $input->redirect("/cgi-bin/koha/cataloguing/addbiblio.pl?biblionumber=$biblionumber&framework=$frameworkcode&tab=$tab&searchid=$searchid"); } else { $template->param( biblionumber => $biblionumber, done =>1, popup =>1 ); if ( $record ne '-1' ) { my $title = C4::Context->preference('marcflavour') eq "UNIMARC" ? $record->subfield('200', 'a') : $record->title; $template->param( title => $title ); } $template->param( popup => $mode, itemtype => $frameworkcode, ); output_html_with_http_headers $input, $cookie, $template->output; exit; } } else { # it may be a duplicate, warn the user and do nothing build_tabs ($template, $record, $dbh,$encoding,$input); $template->param( biblionumber => $biblionumber, biblioitemnumber => $biblioitemnumber, duplicatebiblionumber => $duplicatebiblionumber, duplicatebibid => $duplicatebiblionumber, duplicatetitle => $duplicatetitle, ); } } elsif ( $op eq "delete" ) { my $error = &DelBiblio($biblionumber); if ($error) { warn "ERROR when DELETING BIBLIO $biblionumber : $error"; print "Content-Type: text/html\n\n

ERROR when DELETING BIBLIO $biblionumber : $error

"; exit; } print $input->redirect('/cgi-bin/koha/catalogue/search.pl' . ($searchid ? "?searchid=$searchid" : "")); exit; } else { #---------------------------------------------------------------------------- # If we're in a duplication case, we have to set to "" the biblionumber # as we'll save the biblio as a new one. $template->param( biblionumberdata => $biblionumber, op => $op, z3950 => $z3950 ); if ( $op eq "duplicate" ) { $biblionumber = ""; } if($changed_framework eq "changed"){ $record = TransformHtmlToMarc( $input, 1 ); } elsif( $record ne -1 ) { #FIXME: it's kind of silly to go from MARC::Record to MARC::File::XML and then back again just to fix the encoding eval { my $uxml = $record->as_xml; MARC::Record::default_record_format("UNIMARC") if ( C4::Context->preference("marcflavour") eq "UNIMARC" ); my $urecord = MARC::Record::new_from_xml( $uxml, 'UTF-8' ); $record = $urecord; }; } build_tabs( $template, $record, $dbh, $encoding,$input ); $template->param( biblionumber => $biblionumber, biblionumbertagfield => $biblionumbertagfield, biblionumbertagsubfield => $biblionumbertagsubfield, biblioitemnumtagfield => $biblioitemnumtagfield, biblioitemnumtagsubfield => $biblioitemnumtagsubfield, biblioitemnumber => $biblioitemnumber, hostbiblionumber => $hostbiblionumber, hostitemnumber => $hostitemnumber ); } if ( $record ne '-1' ) { my $title = C4::Context->preference('marcflavour') eq "UNIMARC" ? $record->subfield('200', 'a') : $record->title; $template->param( title => $title ); } $template->param( popup => $mode, frameworkcode => $frameworkcode, itemtype => $frameworkcode, borrowernumber => $loggedinuser, tab => scalar $input->param('tab') ); $template->{'VARS'}->{'searchid'} = $searchid; output_html_with_http_headers $input, $cookie, $template->output;