X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/5a7ae14c769710c1de947b115cf2cd0c38d3df7e..ba802064109d19f3488e5555ec04491681e37b51:/SL/DB/OrderItem.pm?ds=sidebyside diff --git a/SL/DB/OrderItem.pm b/SL/DB/OrderItem.pm index 37520977b..ffae434d1 100644 --- a/SL/DB/OrderItem.pm +++ b/SL/DB/OrderItem.pm @@ -17,14 +17,6 @@ use SL::DB::Helper::CustomVariables ( }, ); -__PACKAGE__->meta->add_relationship( - unit_obj => { - type => 'many to one', - class => 'SL::DB::Unit', - column_map => { unit => 'name' }, - }, -); - __PACKAGE__->meta->initialize; sub is_price_update_available { @@ -42,4 +34,41 @@ sub shipped_qty { return sum(map { AM->convert_unit($_->unit => $self->unit) * $_->qty } @doi); } +sub delivered_qty { + my ($self) = @_; + + return $self->_delivered_qty; +} + +sub _delivered_qty { + my ($self) = @_; + + return $self->{delivered_qty} if $self->{delivered_qty}; + + my $d_orders = $self->order->linked_records(direction => 'to', to => 'SL::DB::DeliveryOrder'); + + my @d_orders_delivered = grep { $_->delivered } @$d_orders; + + my @doi_delivered = grep { $_->parts_id == $self->parts_id } map { $_->orderitems } @d_orders_delivered; + + require SL::AM; + $self->{delivered_qty} = sum(map { AM->convert_unit($_->unit => $self->unit) * $_->qty } @doi_delivered); + + return $self->{delivered_qty}; +} + +sub value_of_goods { + my ($self) = @_; + + my $price_factor = $self->price_factor || 1; + + $self->_delivered_qty; + return ($self->_delivered_qty * $self->sellprice * (1 - $self->discount ) / $price_factor); +} + +sub taxincluded { + my ($self) = @_; + + return SL::DB::Manager::Order->find_by(id => $self->trans_id)->taxincluded ? $::locale->text('WARN: Tax included value!') : ''; +} 1;