projects
/
kivitendo-erp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'nummernkreise-leer-2432'
[kivitendo-erp.git]
/
SL
/
DB
/
DeliveryOrder.pm
diff --git
a/SL/DB/DeliveryOrder.pm
b/SL/DB/DeliveryOrder.pm
index
b65bf3e
..
372a5cc
100644
(file)
--- a/
SL/DB/DeliveryOrder.pm
+++ b/
SL/DB/DeliveryOrder.pm
@@
-2,39
+2,52
@@
package SL::DB::DeliveryOrder;
use strict;
use strict;
+use Carp;
+
use SL::DB::MetaSetup::DeliveryOrder;
use SL::DB::Manager::DeliveryOrder;
use SL::DB::Helper::LinkedRecords;
use SL::DB::Helper::TransNumberGenerator;
use SL::DB::MetaSetup::DeliveryOrder;
use SL::DB::Manager::DeliveryOrder;
use SL::DB::Helper::LinkedRecords;
use SL::DB::Helper::TransNumberGenerator;
-use SL::DB::Order;
use List::Util qw(first);
__PACKAGE__->meta->add_relationship(orderitems => { type => 'one to many',
class => 'SL::DB::DeliveryOrderItem',
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' ] }
},
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;
);
__PACKAGE__->meta->initialize;
+__PACKAGE__->before_save('_before_save_set_donumber');
+
+# hooks
+
+sub _before_save_set_donumber {
+ my ($self) = @_;
+
+ $self->create_trans_number if !$self->donumber;
+
+ return 1;
+}
+
# methods
sub items { goto &orderitems; }
# methods
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 = @_;
sub sales_order {
my $self = shift;
my %params = @_;
+
+ require SL::DB::Order;
my $orders = SL::DB::Manager::Order->get_all(
query => [
ordnumber => $self->ordnumber,
my $orders = SL::DB::Manager::Order->get_all(
query => [
ordnumber => $self->ordnumber,
@@
-45,4
+58,20
@@
sub sales_order {
return first { $_->is_type('sales_order') } @{ $orders };
}
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;
1;