X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCustomVariable.pm;h=cb6c83158bcba5d96720f0f5b794f4c52b26d936;hb=refs%2Fheads%2Fdebian;hp=3f1f7a2e303db134b934dd2274f4eb0fd3bd4a5a;hpb=2bb1c9616f0fe4c8c1d39574a99eff02a7ece42e;p=kivitendo-erp.git diff --git a/SL/DB/CustomVariable.pm b/SL/DB/CustomVariable.pm index 3f1f7a2e3..cb6c83158 100644 --- a/SL/DB/CustomVariable.pm +++ b/SL/DB/CustomVariable.pm @@ -4,6 +4,9 @@ package SL::DB::CustomVariable; use strict; + +use List::MoreUtils qw(any); + use SL::DB::MetaSetup::CustomVariable; __PACKAGE__->meta->initialize; @@ -35,12 +38,18 @@ sub parse_value { my $unparsed = delete $self->{__unparsed_value}; - if ($type =~ m{^(?:customer|vendor|part|bool|number)}) { - return $self->number_value(defined($unparsed) ? $unparsed * 1 : undef); + if ($type =~ m{^(?:customer|vendor|part|number)}) { + return $self->number_value(!defined($unparsed) ? undef + : (any { ref($unparsed) eq $_ } qw(SL::DB::Customer SL::DB::Vendor SL::DB::Part)) ? $unparsed->id * 1 + : $unparsed * 1); + } + + if ($type =~ m{^(?:bool)}) { + return $self->bool_value(defined($unparsed) ? !!$unparsed : undef); } if ($type =~ m{^(?:date|timestamp)}) { - return $self->timestamp_value(defined($unparsed) ? DateTime->from_kivitendo($unparsed) : undef); + return $self->timestamp_value(!defined($unparsed) ? undef : ref($unparsed) eq 'DateTime' ? $unparsed->clone : DateTime->from_kivitendo($unparsed)); } # text, textfield, select @@ -54,11 +63,15 @@ sub value { if (scalar(@_) > 1) { $self->unparsed_value($_[1]); $self->parse_value; + @_ = ($self); } goto &bool_value if $type eq 'bool'; goto ×tamp_value if $type eq 'timestamp'; - goto &number_value if $type eq 'number'; + + if ($type eq 'number') { + return defined($self->number_value) ? $self->number_value * 1 : undef; + } if ( $type eq 'customer' ) { require SL::DB::Customer; @@ -76,7 +89,7 @@ sub value { my $id = int($self->number_value); return $id ? SL::DB::Part->new(id => $id)->load() : undef; } elsif ( $type eq 'date' ) { - return $self->timestamp_value->clone->truncate(to => 'day'); + return $self->timestamp_value ? $self->timestamp_value->clone->truncate(to => 'day') : undef; } goto &text_value; # text, textfield and select @@ -92,27 +105,15 @@ sub value_as_text { if ($type eq 'bool') { return $self->bool_value ? $::locale->text('Yes') : $::locale->text('No'); } elsif ($type =~ m{^(?:timestamp|date)}) { + return '' if !$self->timestamp_value; return $::locale->reformat_date( { dateformat => 'yy-mm-dd' }, $self->timestamp_value->ymd, $::myconfig{dateformat}); } elsif ($type eq 'number') { return $::form->format_amount(\%::myconfig, $self->number_value, $cfg->processed_options->{PRECISION}); - } elsif ( $type eq 'customer' ) { - require SL::DB::Customer; - - my $id = int($self->number_value); - my $customer = $id ? SL::DB::Customer->new(id => $id)->load() : 0; - return $customer ? $customer->name : ''; - } elsif ( $type eq 'vendor' ) { - require SL::DB::Vendor; - - my $id = int($self->number_value); - my $vendor = $id ? SL::DB::Vendor->new(id => $id)->load() : 0; - return $vendor ? $vendor->name : ''; - } elsif ( $type eq 'part' ) { - require SL::DB::Part; - - my $id = int($self->number_value); - my $part = $id ? SL::DB::Part->new(id => $id)->load() : 0; - return $part ? $part->description : ''; + } elsif ( $type =~ m{^(?:customer|vendor|part)$}) { + my $class = "SL::DB::" . ucfirst($type); + eval "require $class"; + my $object = $class->_get_manager_class->find_by(id => int($self->number_value)); + return $object ? $object->displayable_name : ''; } goto &text_value; # text, textfield and select @@ -123,8 +124,13 @@ sub is_valid { require SL::DB::CustomVariableValidity; - my $query = [config_id => $self->config_id, trans_id => $self->trans_id]; - return (SL::DB::Manager::CustomVariableValidity->get_all_count(query => $query) == 0) ? 1 : 0; + # only base level custom variables can be invalid. ovverloaded ones could potentially clash on trans_id, so disallow them + return 1 if $self->sub_module; + + $self->{is_valid} //= do { + my $query = [config_id => $self->config_id, trans_id => $self->trans_id]; + (SL::DB::Manager::CustomVariableValidity->get_all_count(query => $query) == 0) ? 1 : 0; + } } 1;