X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FCustomer.pm;h=d15f5ecd0127f17c55c7dd849d8bdb6d54d9b1c1;hb=452e195fa7d3ecf6cb625938d8016dd04bcc33ce;hp=e3e30ddff6c2e59115579703d207050cecab7daf;hpb=f16c552035ab973a9aed4a1dc29d0e16be7ff541;p=kivitendo-erp.git diff --git a/SL/DB/Customer.pm b/SL/DB/Customer.pm index e3e30ddff..d15f5ecd0 100644 --- a/SL/DB/Customer.pm +++ b/SL/DB/Customer.pm @@ -4,8 +4,10 @@ use strict; use Rose::DB::Object::Helpers qw(as_tree); +use SL::DBUtils (); 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', @@ -41,6 +43,16 @@ sub _before_save_set_customernumber { 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) = @_; @@ -53,8 +65,31 @@ sub displayable_name { return join ' ', grep $_, $self->customernumber, $self->name; } +sub last_used_ar_chart { + my ($self) = @_; + + my $query = <db->dbh, $query, ($self->id) x 2); + + return if !$chart_id; + return SL::DB::Chart->load_cached($chart_id); +} + sub is_customer { 1 }; sub is_vendor { 0 }; sub payment_terms { goto &payment } +sub number { goto &customernumber } 1;