X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FOrder.pm;h=1be7b22bfefae0699521a3f1fe15a63c2f0a43dd;hb=c19b30d22f462a5913610d1f9005a34ed95e1119;hp=c81deae7dc0dfdee6c0a8bbcc6f3bde843782877;hpb=b9dbc9e3d4f8821d9fd324b52dafb81b699a776e;p=kivitendo-erp.git diff --git a/SL/DB/Order.pm b/SL/DB/Order.pm index c81deae7d..1be7b22bf 100644 --- a/SL/DB/Order.pm +++ b/SL/DB/Order.pm @@ -3,7 +3,9 @@ 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; @@ -11,6 +13,7 @@ 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 => { @@ -83,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__