X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FOrder.pm;h=1be7b22bfefae0699521a3f1fe15a63c2f0a43dd;hb=c19b30d22f462a5913610d1f9005a34ed95e1119;hp=864da21efc69519fff007b6aa055bf7437e37555;hpb=4ac74078e265ea321464c4cbd446a55c373c936a;p=kivitendo-erp.git diff --git a/SL/DB/Order.pm b/SL/DB/Order.pm index 864da21ef..1be7b22bf 100644 --- a/SL/DB/Order.pm +++ b/SL/DB/Order.pm @@ -3,11 +3,17 @@ 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; +use SL::DB::Helper::LinkedRecords; +use SL::DB::Helper::PriceTaxCalculator; +use SL::DB::Helper::TransNumberGenerator; +use SL::RecordLinks; __PACKAGE__->meta->add_relationship( orderitems => { @@ -28,6 +34,11 @@ __PACKAGE__->meta->add_relationship( 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; @@ -75,6 +86,32 @@ sub end_invoice { return shift()->invoices(query => [ abschlag => 0 ]); } +sub convert_to_invoice { + my ($self, %params) = @_; + + croak("Conversion to invoices is only supported for sales records") unless $self->customer_id; + + 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__