X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCustomer.pm;h=7a040ed63265fd1ec124d3d833ecc7f2071685f3;hb=5e9cefa2067da6326e3cb9ab6834c51f21bfca2c;hp=2e3fa68562bbb50ad5d95798aa0fef1ebb4310c2;hpb=1b69969f8d9fedd218b059b7148bc3778ee600f3;p=kivitendo-erp.git diff --git a/SL/DB/Customer.pm b/SL/DB/Customer.pm index 2e3fa6856..7a040ed63 100644 --- a/SL/DB/Customer.pm +++ b/SL/DB/Customer.pm @@ -2,8 +2,11 @@ package SL::DB::Customer; use strict; +use Rose::DB::Object::Helpers qw(as_tree); + use SL::DB::MetaSetup::Customer; use SL::DB::Manager::Customer; +use SL::DB::Helper::IBANValidation; use SL::DB::Helper::TransNumberGenerator; use SL::DB::Helper::CustomVariables ( module => 'CT', @@ -35,10 +38,20 @@ __PACKAGE__->before_save('_before_save_set_customernumber'); sub _before_save_set_customernumber { my ($self) = @_; - $self->create_trans_number if $self->customernumber eq ''; + $self->create_trans_number if !defined $self->customernumber || $self->customernumber eq ''; return 1; } +sub validate { + my ($self) = @_; + + my @errors; + push @errors, $::locale->text('The customer name is missing.') if !$self->name; + push @errors, $self->validate_ibans; + + return @errors; +} + sub short_address { my ($self) = @_; @@ -51,4 +64,8 @@ sub displayable_name { return join ' ', grep $_, $self->customernumber, $self->name; } +sub is_customer { 1 }; +sub is_vendor { 0 }; +sub payment_terms { goto &payment } + 1;