X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/kivitendo-erp.git/blobdiff_plain/82515b2d93dc5632f24d6e0b6f8f05f3fd19fbb0..42ea98b4:/SL/DB/Order.pm diff --git a/SL/DB/Order.pm b/SL/DB/Order.pm index 309b5061f..ebf099442 100644 --- a/SL/DB/Order.pm +++ b/SL/DB/Order.pm @@ -1,15 +1,19 @@ package SL::DB::Order; +use utf8; use strict; -use SL::RecordLinks; +use Carp; +use DateTime; +use List::Util qw(max); use SL::DB::MetaSetup::Order; use SL::DB::Manager::Order; use SL::DB::Invoice; - -__PACKAGE__->attr_number($_, places => -2) for qw(amount netamount marge_total marge_percent); -__PACKAGE__->attr_date($_) for qw(transdate reqdate); +use SL::DB::Helper::LinkedRecords; +use SL::DB::Helper::PriceTaxCalculator; +use SL::DB::Helper::TransNumberGenerator; +use SL::RecordLinks; __PACKAGE__->meta->add_relationship( orderitems => { @@ -19,13 +23,30 @@ __PACKAGE__->meta->add_relationship( manager_args => { with_objects => [ 'part' ] } - } + }, + periodic_invoices_config => { + type => 'one to one', + class => 'SL::DB::PeriodicInvoicesConfig', + column_map => { id => 'oe_id' }, + }, + periodic_invoices => { + type => 'one to many', + class => 'SL::DB::PeriodicInvoice', + column_map => { id => 'oe_id' }, + }, + payment_term => { + type => 'one to one', + class => 'SL::DB::PaymentTerm', + column_map => { payment_id => 'id' }, + }, ); __PACKAGE__->meta->initialize; # methods +sub items { goto &orderitems; } + sub type { my $self = shift; @@ -65,6 +86,42 @@ sub end_invoice { return shift()->invoices(query => [ abschlag => 0 ]); } +sub convert_to { + my ($self, %params) = @_; + + my $destination_type = lc(delete $params{destination_type}); + + if ($destination_type eq 'invoice') { + $self->convert_to_invoice(%params); + } else { + croak("Unsupported destination type `$destination_type'"); + } +} + +sub convert_to_invoice { + my ($self, %params) = @_; + + if (!$params{ar_id}) { + my $chart = SL::DB::Manager::Chart->get_all(query => [ SL::DB::Manager::Chart->link_filter('AR') ], + sort_by => 'id ASC', + limit => 1)->[0]; + croak("No AR chart found and no parameter `ar_id' given") unless $chart; + $params{ar_id} = $chart->id; + } + + my $invoice; + if (!$self->db->do_transaction(sub { + $invoice = SL::DB::Invoice->new_from($self)->post(%params) || die; + $self->link_to_record($invoice); + $self->update_attributes(closed => 1); + # die; + })) { + return undef; + } + + return $invoice; +} + 1; __END__ @@ -101,6 +158,6 @@ Nothing here yet. =head1 AUTHOR - Sven Schöling +Sven Schöling =cut