X-Git-Url: http://wagnertech.de/git?p=kivitendo-erp.git;a=blobdiff_plain;f=SL%2FDB%2FCustomer.pm;fp=SL%2FDB%2FCustomer.pm;h=d72d0c91ac9f4abf9fcd1b6c6a6b5b7a00dc678c;hp=048db7c101fb5e008f37263d9120197597dc6ec2;hb=53593baa211863fbf66540cf1bcc36c8fb37257f;hpb=deb4d2dbb676d7d6f69dfe7815d6e0cb09bd4a44 diff --git a/SL/DB/Customer.pm b/SL/DB/Customer.pm index 048db7c10..d72d0c91a 100644 --- a/SL/DB/Customer.pm +++ b/SL/DB/Customer.pm @@ -2,19 +2,40 @@ package SL::DB::Customer; use strict; +use List::Util qw(first); use Rose::DB::Object::Helpers qw(as_tree); +use SL::Locale::String qw(t8); +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::VATIDNrValidation; use SL::DB::Helper::CustomVariables ( module => 'CT', cvars_alias => 1, ); +use SL::DB::Helper::DisplayableNamePreferences ( + title => t8('Customer'), + options => [ {name => 'customernumber', title => t8('Customer Number') }, + {name => 'name', title => t8('Name') }, + {name => 'street', title => t8('Street') }, + {name => 'city', title => t8('City') }, + {name => 'zipcode', title => t8('Zipcode')}, + {name => 'email', title => t8('E-Mail') }, + {name => 'phone', title => t8('Phone') }, ] +); use SL::DB::VC; __PACKAGE__->meta->add_relationship( + additional_billing_addresses => { + type => 'one to many', + class => 'SL::DB::AdditionalBillingAddress', + column_map => { id => 'customer_id' }, + manager_args => { sort_by => 'lower(additional_billing_addresses.name)' }, + }, shipto => { type => 'one to many', class => 'SL::DB::Shipto', @@ -34,6 +55,7 @@ __PACKAGE__->meta->initialize; __PACKAGE__->before_save('_before_save_set_customernumber'); + sub _before_save_set_customernumber { my ($self) = @_; @@ -46,6 +68,8 @@ sub validate { my @errors; push @errors, $::locale->text('The customer name is missing.') if !$self->name; + push @errors, $self->validate_ibans; + push @errors, $self->validate_vat_id_numbers; return @errors; } @@ -56,14 +80,46 @@ sub short_address { return join ', ', grep { $_ } $self->street, $self->zipcode, $self->city; } -sub displayable_name { - my $self = shift; +sub last_used_ar_chart { + my ($self) = @_; - return join ' ', grep $_, $self->customernumber, $self->name; + 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 } + +sub create_zugferd_invoices_for_this_customer { + my ($self) = @_; + + no warnings 'once'; + return $::instance_conf->get_create_zugferd_invoices if $self->create_zugferd_invoices == -1; + return $self->create_zugferd_invoices; +} + +sub default_billing_address { + my $self = shift; + + die 'not an accessor' if @_ > 1; + return first { $_->default_address } @{ $self->additional_billing_addresses }; +} 1;