X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=bin%2Fmozilla%2Fdn.pl;h=9422da3f9234042c6a60f38a5bb33a375913bf35;hb=0d4bded426d1f09a85256767e8525bd15f551d88;hp=5cb23000d37778bcfa2b1e55e3d376896976009d;hpb=a2b43e372e56297b9900c24145058d4124e5cbeb;p=kivitendo-erp.git diff --git a/bin/mozilla/dn.pl b/bin/mozilla/dn.pl index 5cb23000d..9422da3f9 100644 --- a/bin/mozilla/dn.pl +++ b/bin/mozilla/dn.pl @@ -38,8 +38,10 @@ use SL::IS; use SL::DN; use SL::DB::Department; use SL::DB::Dunning; +use SL::File; use SL::Helper::Flash qw(flash); use SL::Locale::String qw(t8); +use SL::Presenter::FileObject; use SL::ReportGenerator; require "bin/mozilla/common.pl"; @@ -209,7 +211,7 @@ sub save_dunning { my $saved_language_id = $form->{language_id}; - if ($form->{groupinvoices}) { + if ($form->{groupinvoices} || $form->{l_include_credit_notes}) { my %dunnings_for; for my $i (1 .. $form->{rowcount}) { @@ -223,6 +225,7 @@ sub save_dunning { push @{ $level }, { "row" => $i, "invoice_id" => $form->{"inv_id_$i"}, + "credit_note" => $form->{"credit_note_$i"}, "customer_id" => $form->{"customer_id_$i"}, "language_id" => $form->{"language_id_$i"}, "next_dunning_config_id" => $form->{"next_dunning_config_id_$i"}, @@ -249,6 +252,7 @@ sub save_dunning { "customer_id" => $form->{"customer_id_$i"}, "language_id" => $form->{"language_id_$i"}, "next_dunning_config_id" => $form->{"next_dunning_config_id_$i"}, + "print_invoice" => $form->{"include_invoice_$i"}, "email" => $form->{"email_$i"}, } ]; if (!$form->{force_lang}) { $form->{language_id} = @{$level}[0]->{language_id}; @@ -376,6 +380,7 @@ sub show_dunning { 'fee' => { 'text' => $locale->text('Total Fees') }, 'interest' => { 'text' => $locale->text('Interest') }, 'salesman' => { 'text' => $locale->text('Salesperson'), 'visible' => $form->{l_salesman} ? 1 : 0 }, + 'documents' => { 'text' => $locale->text('Documents') , 'visible' => $::instance_conf->get_doc_storage ? 1 : 0 }, ); $report->set_columns(%column_defs); @@ -442,6 +447,19 @@ sub show_dunning { $row->{language} = { }; } + if ($::instance_conf->get_doc_storage && $first_row_for_dunning) { + my @files = SL::File->get_all_versions(object_id => $ref->{dunning_id}, + object_type => 'dunning', + file_type => 'document',); + if (scalar @files) { + my $html = join '
', map { SL::Presenter::FileObject::file_object($_) } @files; + my $text = join "\n", map { $_->file_name } @files; + $row->{documents} = { 'raw_data' => $html, data => $text }; + } else { + $row->{documents} = { }; + } + } + push @{ $current_dunning_rows }, $row; $previous_dunning_id = $ref->{dunning_id}; @@ -534,6 +552,11 @@ sub print_multiple { $form->{dunning_id} = $dunning_id; DN->print_invoice_for_fees(\%myconfig, $form, $dunning_id); DN->print_dunning(\%myconfig, $form, $dunning_id); + + # print original dunned invoices, if they where printed on dunning run + my $dunnings = SL::DB::Manager::Dunning->get_all(where => [dunning_id => $dunning_id, original_invoice_printed => 1]); + DN->print_original_invoice(\%myconfig, $form, $dunning_id, $_->trans_id) for @$dunnings; + $i++; } $form->{language_id} = $saved_language_id;