X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/fa7fc7eeb3ca718914affee06c0629a08d571288..61d88e69bd686dcc00bc3cb0cbfa37bc808cebeb:/SL/DB/CustomVariable.pm?ds=sidebyside diff --git a/SL/DB/CustomVariable.pm b/SL/DB/CustomVariable.pm index 7e6b50080..e48c1d829 100644 --- a/SL/DB/CustomVariable.pm +++ b/SL/DB/CustomVariable.pm @@ -64,20 +64,22 @@ sub value { require SL::DB::Customer; my $id = int($self->number_value); - return $id ? SL::DB::Customer->new(id => $id)->load() : 0; + return $id ? SL::DB::Customer->new(id => $id)->load() : undef; } elsif ( $type eq 'vendor' ) { require SL::DB::Vendor; my $id = int($self->number_value); - return $id ? SL::DB::Vendor->new(id => $id)->load() : 0; + return $id ? SL::DB::Vendor->new(id => $id)->load() : undef; } elsif ( $type eq 'part' ) { require SL::DB::Part; my $id = int($self->number_value); - return $id ? SL::DB::Part->new(id => $id)->load() : 0; + return $id ? SL::DB::Part->new(id => $id)->load() : undef; + } elsif ( $type eq 'date' ) { + return $self->timestamp_value ? $self->timestamp_value->clone->truncate(to => 'day') : undef; } - goto &text_value; # text, textfield, date and select + goto &text_value; # text, textfield and select } sub value_as_text { @@ -87,32 +89,21 @@ sub value_as_text { die 'not an accessor' if @_ > 1; - if ($type eq 'boolean') { + if ($type eq 'bool') { return $self->bool_value ? $::locale->text('Yes') : $::locale->text('No'); - } elsif ($type eq 'timestamp') { + } 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); - return $id ? SL::DB::Vendor->new(id => $id)->load() : 0; - } 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, date and select + goto &text_value; # text, textfield and select } sub is_valid {