1 package SL::DB::OrderItem;
5 use List::Util qw(sum);
7 use SL::DB::MetaSetup::OrderItem;
8 use SL::DB::Manager::OrderItem;
9 use SL::DB::DeliveryOrderItemsStock;
10 use SL::DB::Helper::ActsAsList;
11 use SL::DB::Helper::LinkedRecords;
12 use SL::DB::Helper::RecordItem;
13 use SL::DB::Helper::CustomVariables (
14 sub_module => 'orderitems',
18 class => 'SL::DB::Part',
24 __PACKAGE__->meta->initialize;
26 __PACKAGE__->configure_acts_as_list(group_by => [qw(trans_id)]);
28 sub is_price_update_available {
30 return $self->origprice > $self->part->sellprice;
36 my $d_orders = $self->order->linked_records(direction => 'to', to => 'SL::DB::DeliveryOrder');
37 my @doi = grep { $_->parts_id == $self->parts_id } map { $_->orderitems } @$d_orders;
40 return sum(map { AM->convert_unit($_->unit => $self->unit) * $_->qty } @doi);
43 sub record { goto &order }