X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCustomVariable.pm;h=144acef00395cb83a325f77e0bc9c20e75568b32;hb=eed2ea364f31c49d86ee4570759a987dc242483f;hp=26c09cf5b35f31fa300f9c451f648f0645082c0f;hpb=e1bf173bae820584e8bafdc01ebe2e7d7537a59c;p=kivitendo-erp.git diff --git a/SL/DB/CustomVariable.pm b/SL/DB/CustomVariable.pm index 26c09cf5b..144acef00 100644 --- a/SL/DB/CustomVariable.pm +++ b/SL/DB/CustomVariable.pm @@ -4,9 +4,10 @@ package SL::DB::CustomVariable; use strict; - use SL::DB::MetaSetup::CustomVariable; +__PACKAGE__->meta->initialize; + # Creates get_all, get_all_count, get_all_iterator, delete_all and update_all. __PACKAGE__->meta->make_manager_class; @@ -17,7 +18,38 @@ sub value { goto &bool_value if $type eq 'boolean'; goto ×tamp_value if $type eq 'timestamp'; goto &number_value if $type eq 'number'; - goto &text_value; # text and select + + if ( $_[1] && ($type eq 'customer' || $type eq 'vendor' || $type eq 'part') ) { + $self->number_value($_[1]); + } + + if ( $type eq 'customer' ) { + require SL::DB::Customer; + + my $id = int($self->number_value); + return $id ? SL::DB::Customer->new(id => $id)->load() : 0; + } 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); + return $id ? SL::DB::Part->new(id => $id)->load() : 0; + } + + goto &text_value; # text, textfield, date and select +} + +sub is_valid { + my ($self) = @_; + + 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;