X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCsvImportProfile.pm;h=bf11279d1e8960df30cd140d5296816f608ac761;hb=0ebb8f829ac2d23b65e8d993c7d03aa0b172b637;hp=58e3d6838864041ae20191658d2bfe5fda646aa9;hpb=1abd784542136a7ce095ae97c754aae088acf1bb;p=kivitendo-erp.git diff --git a/SL/DB/CsvImportProfile.pm b/SL/DB/CsvImportProfile.pm index 58e3d6838..bf11279d1 100644 --- a/SL/DB/CsvImportProfile.pm +++ b/SL/DB/CsvImportProfile.pm @@ -4,7 +4,7 @@ use strict; use List::Util qw(first); -use SL::DB::MetaSetup::CsvImportProfile; +require SL::DB::MetaSetup::CsvImportProfile; __PACKAGE__->meta->add_relationship( settings => { @@ -41,23 +41,6 @@ sub set_defaults { duplicates => 'no_check', ); - if ($self->type eq 'parts') { - my $bugru = SL::DB::Manager::Buchungsgruppe->find_by(description => { like => 'Standard%19%' }); - - $self->_set_defaults(sellprice_places => 2, - sellprice_adjustment => 0, - sellprice_adjustment_type => 'percent', - article_number_policy => 'update_prices', - part_group_sep_char => '!', - shoparticle_if_missing => '0', - parts_type => 'part', - default_buchungsgruppe => ($bugru ? $bugru->description : undef), - apply_buchungsgruppe => 'all', - ); - } else { - $self->_set_defaults(table => 'customer'); - } - return $self; } @@ -95,6 +78,24 @@ sub _set_defaults { return $self; } +sub clone_and_reset_deep { + my ($self) = @_; + + my $clone = $self->clone_and_reset; + $clone->settings(map { $_->clone_and_reset } $self->settings); + $clone->is_default(0); + $clone->name(''); + return $clone; +} + +sub flatten { + my ($self) = @_; + + return map { + $_->key => $_->value + } $self->settings; +} + # # hooks #