use List::Util qw(first);
require SL::DB::MetaSetup::CsvImportProfile;
-use Rose::DB::Object::Helpers qw(clone_and_reset);
__PACKAGE__->meta->add_relationship(
settings => {
sub set_defaults {
my ($self) = @_;
-
- 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',
- shoparticle_if_missing => '0',
- parts_type => 'part',
- default_buchungsgruppe => ($bugru ? $bugru->id : undef),
- apply_buchungsgruppe => 'all',
- );
- } elsif ($self->type eq 'orders') {
- $self->_set_defaults(order_column => $::locale->text('Order'),
- item_column => $::locale->text('OrderItem'),
- max_amount_diff => 0.02,
- );
- } elsif ($self->type eq 'mt940') {
- $self->_set_defaults(charset => 'UTF8',
- sep_char => ';',
- numberformat => '1000.00',
- update_policy => 'skip',
- );
- } elsif ($self->type eq 'bank_transactions') {
- $self->_set_defaults(charset => 'UTF8',
- update_policy => 'skip',
- );
- } else {
- $self->_set_defaults(table => 'customer');
- }
-
- # TODO: move the defaults into their own controller
- # defaults can only be set once, so use these values as default if they
- # haven't already been set above for one of the special import types
- # If the values have been set above they won't be overwritten here:
-
$self->_set_defaults(sep_char => ',',
quote_char => '"',
escape_char => '"',
charset => 'CP850',
numberformat => $::myconfig{numberformat},
+ dateformat => $::myconfig{dateformat},
duplicates => 'no_check',
);
my $clone = $self->clone_and_reset;
$clone->settings(map { $_->clone_and_reset } $self->settings);
+ $clone->is_default(0);
$clone->name('');
-
return $clone;
}