X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FDeliveryOrder.pm;h=6bf602327ee7dfc7de44fd552f7ea1ace2d5057e;hb=937e37ad007405c6a3a389ee18006379ffecc073;hp=b65bf3eb6960e9343ba78bf8705e9360cb12a068;hpb=89c9ff022d3f13e27ba6bda085df15707fcfb0eb;p=kivitendo-erp.git diff --git a/SL/DB/DeliveryOrder.pm b/SL/DB/DeliveryOrder.pm index b65bf3eb6..6bf602327 100644 --- a/SL/DB/DeliveryOrder.pm +++ b/SL/DB/DeliveryOrder.pm @@ -2,6 +2,8 @@ package SL::DB::DeliveryOrder; use strict; +use Carp; + use SL::DB::MetaSetup::DeliveryOrder; use SL::DB::Manager::DeliveryOrder; use SL::DB::Helper::LinkedRecords; @@ -12,17 +14,9 @@ use List::Util qw(first); __PACKAGE__->meta->add_relationship(orderitems => { type => 'one to many', class => 'SL::DB::DeliveryOrderItem', - column_map => { id => 'trans_id' }, + column_map => { id => 'delivery_order_id' }, manager_args => { with_objects => [ 'part' ] } }, - shipto => { type => 'one to one', - class => 'SL::DB::Shipto', - column_map => { shipto_id => 'shipto_id' }, - }, - department => { type => 'one to one', - class => 'SL::DB::Department', - column_map => { department_id => 'id' }, - }, ); __PACKAGE__->meta->initialize; @@ -31,6 +25,12 @@ __PACKAGE__->meta->initialize; sub items { goto &orderitems; } +sub items_sorted { + my ($self) = @_; + + return [ sort {$a->id <=> $b->id } @{ $self->items } ]; +} + sub sales_order { my $self = shift; my %params = @_; @@ -45,4 +45,20 @@ sub sales_order { return first { $_->is_type('sales_order') } @{ $orders }; } +sub type { + return shift->customer_id ? 'sales_delivery_order' : 'purchase_delivery_order'; +} + +sub displayable_state { + my ($self) = @_; + + return join '; ', + ($self->closed ? $::locale->text('closed') : $::locale->text('open')), + ($self->delivered ? $::locale->text('delivered') : $::locale->text('not delivered')); +} + +sub date { + goto &transdate; +} + 1;