X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FUnit.pm;h=508aa747718cd2fe9a0520df18df204c347e023b;hb=a27846ef2756ed0f59c29d256a5d43d6caaf0b58;hp=b133d8f131263cf39e3dea9c4b7da4827cf97c7b;hpb=e42233910a57d39f3ccef150db1212f7ecb7fb30;p=kivitendo-erp.git diff --git a/SL/DB/Unit.pm b/SL/DB/Unit.pm index b133d8f13..508aa7477 100644 --- a/SL/DB/Unit.pm +++ b/SL/DB/Unit.pm @@ -1,5 +1,8 @@ package SL::DB::Unit; +use List::MoreUtils qw(any); + + use strict; use SL::DB::MetaSetup::Unit; @@ -27,8 +30,8 @@ sub unit_class { sub convertible_units { my $self = shift; - my $all_units = scalar(@_) && (ref($_[0]) eq 'ARRAY') ? $_[0] : \@_; - $all_units = SL::DB::Manager::Unit->get_all if !@{ $all_units }; + my $all_units = scalar(@_) && (ref($_[0]) eq 'ARRAY') ? $_[0] : [ @_ ]; + $all_units = SL::DB::Manager::Unit->all_units if ! @{ $all_units }; return [ sort { $a->sortkey <=> $b->sortkey } grep { $_->unit_class->name eq $self->unit_class->name } @@ -39,11 +42,13 @@ sub convertible_units { sub base_factor { my ($self) = @_; - if (!defined $self->{__base_factor}) { - $self->{__base_factor} = !$self->base_unit || !$self->factor || ($self->name eq $self->base_unit) ? 1 : $self->factor * $self->base->base_factor; + my $cache = $::request->cache('base_factor'); + + if (!defined $cache->{$self->id}) { + $cache->{$self->id} = !$self->base_unit || !$self->factor || ($self->name eq $self->base_unit) ? 1 : $self->factor * $self->base->base_factor; } - return $self->{__base_factor}; + return $cache->{$self->id}; } sub convert_to { @@ -52,7 +57,13 @@ sub convert_to { my $my_base_factor = $self->base_factor || 1; my $other_base_factor = $other_unit->base_factor || 1; - return $qty * $my_base_factor / $other_base_factor; + return ($qty // 0) * $my_base_factor / $other_base_factor; +} + +sub is_time_based { + my ($self) = @_; + + return any { $_->id == $self->id } @{ SL::DB::Manager::Unit->time_based_units }; } 1;