X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FVendor.pm;h=b1740147c369da08bc959048dc8e51d1554a4cf4;hb=972b87711cb3c7543d585ceedca0eda2058aa6d7;hp=11e23fe5174a8aa1b3040ea25b1247cb1aba2f0a;hpb=82515b2d93dc5632f24d6e0b6f8f05f3fd19fbb0;p=kivitendo-erp.git diff --git a/SL/DB/Vendor.pm b/SL/DB/Vendor.pm index 11e23fe51..b1740147c 100644 --- a/SL/DB/Vendor.pm +++ b/SL/DB/Vendor.pm @@ -2,7 +2,17 @@ package SL::DB::Vendor; use strict; +use Rose::DB::Object::Helpers qw(as_tree); + +use SL::DBUtils (); use SL::DB::MetaSetup::Vendor; +use SL::DB::Manager::Vendor; +use SL::DB::Helper::IBANValidation; +use SL::DB::Helper::TransNumberGenerator; +use SL::DB::Helper::CustomVariables ( + module => 'CT', + cvars_alias => 1, +); use SL::DB::VC; @@ -12,16 +22,68 @@ __PACKAGE__->meta->add_relationship( class => 'SL::DB::Shipto', column_map => { id => 'trans_id' }, manager_args => { sort_by => 'lower(shipto.shiptoname)' }, - query_args => [ 'shipto.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_vendornumber'); + +sub _before_save_set_vendornumber { + my ($self) = @_; + + $self->create_trans_number if !defined $self->vendornumber || $self->vendornumber eq ''; + return 1; +} + +sub validate { + my ($self) = @_; + + my @errors; + push @errors, $::locale->text('The vendor name is missing.') if !$self->name; + push @errors, $self->validate_ibans; + + return @errors; +} + +sub displayable_name { + my $self = shift; + + return join ' ', grep $_, $self->vendornumber, $self->name; +} + +sub is_customer { 0 }; +sub is_vendor { 1 }; +sub payment_terms { goto &payment } +sub number { goto &vendornumber } + +sub last_used_ap_chart { + my ($self) = @_; + + my $query = <db->dbh, $query, ($self->id) x 2); + + return if !$chart_id; + return SL::DB::Chart->load_cached($chart_id); +} + 1;