X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCustomer.pm;h=36bddc0c78c6464fdaf757960ba3ec76a9b20e1c;hb=1168e9c997382048dd721eb94a5e021ac9145432;hp=27683b3c1a396c8b0a4f750d3a9a5a8d2698eba4;hpb=587c7468815169f69621cf374fe455d7b7694eeb;p=kivitendo-erp.git diff --git a/SL/DB/Customer.pm b/SL/DB/Customer.pm index 27683b3c1..36bddc0c7 100644 --- a/SL/DB/Customer.pm +++ b/SL/DB/Customer.pm @@ -3,6 +3,12 @@ package SL::DB::Customer; use strict; use SL::DB::MetaSetup::Customer; +use SL::DB::Manager::Customer; +use SL::DB::Helper::TransNumberGenerator; +use SL::DB::Helper::CustomVariables ( + module => 'CT', + cvars_alias => 1, +); use SL::DB::VC; @@ -12,22 +18,40 @@ __PACKAGE__->meta->add_relationship( class => 'SL::DB::Shipto', column_map => { id => 'trans_id' }, manager_args => { sort_by => 'lower(shipto.shiptoname)' }, - query_args => [ 'module' => 'CT' ], + query_args => [ module => 'CT' ], }, - business => { - type => 'one to one', - class => 'SL::DB::Business', - column_map => { business_id => 'id' }, + contacts => { + type => 'one to many', + class => 'SL::DB::Contact', + column_map => { id => 'cp_cv_id' }, + manager_args => { sort_by => 'lower(contacts.cp_name)' }, }, ); -__PACKAGE__->meta->make_manager_class; __PACKAGE__->meta->initialize; +__PACKAGE__->before_save('_before_save_set_customernumber'); + +sub _before_save_set_customernumber { + my ($self) = @_; + + $self->create_trans_number if $self->customernumber eq ''; + return 1; +} + sub short_address { my ($self) = @_; return join ', ', grep { $_ } $self->street, $self->zipcode, $self->city; } +sub displayable_name { + my $self = shift; + + return join ' ', grep $_, $self->customernumber, $self->name; +} + +sub is_customer { 1 }; +sub is_vendor { 0 }; + 1;