+sub delete {
+ $main::auth->assert('dunning_edit');
+
+ my @dunning_ids = map { $::form->{"dunning_id_$_"} } grep { $::form->{"selected_$_"} } (1..$::form->{rowcount});
+
+ if (!scalar @dunning_ids) {
+ $::form->error($::locale->text('No dunnings have been selected for printing.'));
+ }
+
+ my $dunnings = SL::DB::Manager::Dunning->get_all(query => [ dunning_id => \@dunning_ids ]);
+
+ SL::DB::Dunning->new->db->with_transaction(sub {
+ for my $dunning (@$dunnings) {
+ SL::DB::Manager::Invoice->find_by(id => $dunning->trans_id)->update_attributes(dunning_config_id => undef);
+ $dunning->delete;
+ }
+ });
+
+ flash('info', t8('#1 dunnings have been deleted', scalar @$dunnings));
+
+ search();
+}
+