require "bin/mozilla/common.pl";
require "bin/mozilla/reportgenerator.pl";
require "bin/mozilla/io.pl";
-require "bin/mozilla/arap.pl";
1;
sub edit_config {
$lxdebug->enter_sub();
+ $auth->assert('config');
+
DN->get_config(\%myconfig, \%$form);
$form->get_lists('charts' => { 'key' => 'ALL_CHARTS',
'transdate' => 'current_date' });
sub add {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
# setup customer selection
$form->all_vc(\%myconfig, "customer", "AR");
sub show_invoices {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
DN->get_invoices(\%myconfig, \%$form);
$form->{title} = $locale->text('Start Dunning Process');
$form->{type} = 'dunning';
$form->{rowcount} = scalar @{ $form->{DUNNINGS} };
$form->{jsscript} = 1;
- $form->{callback} ||= build_std_url("action=show_invoices", qw(login password customer invnumber ordnumber groupinvoices minamount dunning_level notes));
+ $form->{callback} ||= build_std_url("action=show_invoices", qw(customer invnumber ordnumber groupinvoices minamount dunning_level notes));
$form->{PRINT_OPTIONS} = print_options('inline' => 1,
'no_queue' => 1,
sub save {
$lxdebug->enter_sub();
+ $auth->assert('config');
+
for my $i (1 .. $form->{rowcount}) {
if ($form->{"dunning_description_$i"} ne "") {
$form->isblank("dunning_level_$i", $locale->text('Dunning Level missing in row '). $i);
sub save_dunning {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
my $active=1;
my @rows = ();
undef($form->{DUNNING_PDFS});
sub set_email {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
$form->{"title"} = $locale->text("Set eMail text");
$form->header();
print($form->parse_html_template("dunning/set_email"));
sub search {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
$form->get_lists("customers" => "ALL_CUSTOMERS",
"departments" => "ALL_DEPARTMENTS");
sub show_dunning {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
my @filter_field_list = qw(customer_id customer dunning_level department_id invnumber ordnumber
transdatefrom transdateto dunningfrom dunningto notes showold);
+ report_generator_set_default_sort('customername', 1);
+
DN->get_dunning(\%myconfig, \%$form);
if (!$form->{callback}) {
'title' => $form->{title});
$report->set_export_options('show_dunning', @filter_field_list);
- $report->set_columns(
+ my %column_defs = (
'checkbox' => { 'text' => '', 'visible' => 'HTML' },
'dunning_description' => { 'text' => $locale->text('Dunning Level') },
'customername' => { 'text' => $locale->text('Customername') },
'interest' => { 'text' => $locale->text('Interest') },
);
+ $report->set_columns(%column_defs);
$report->set_column_order(qw(checkbox dunning_description customername invnumber transdate
duedate amount dunning_date dunning_duedate fee interest));
+ $report->set_sort_indicator($form->{sort}, $form->{sortdir});
my $edit_url = build_std_url('script=is.pl', 'action=edit', 'callback') . '&id=';
my $print_url = build_std_url('action=print_dunning', 'format=pdf', 'media=screen') . '&dunning_id=';
+ my $sort_url = build_std_url('action=show_dunning', grep { $form->{$_} } @filter_field_list);
+
+ foreach my $name (qw(dunning_description customername invnumber transdate duedate dunning_date dunning_duedate)) {
+ my $sortdir = $form->{sort} eq $name ? 1 - $form->{sortdir} : $form->{sortdir};
+ $column_defs{$name}->{link} = $sort_url . "&sort=$name&sortdir=$sortdir";
+ }
my %alignment = map { $_ => 'right' } qw(transdate duedate amount dunning_date dunning_duedate fee interest);
sub print_dunning {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
$form->{rowcount} = 1;
$form->{selected_1} = 1;
$form->{dunning_id_1} = $form->{dunning_id};
sub print_multiple {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
$form->{title} = $locale->text('Print dunnings');
my @dunning_ids = map { $form->{"dunning_id_$_"} } grep { $form->{"selected_$_"} } (1..$form->{rowcount});
$lxdebug->leave_sub();
}
+sub continue {
+ call_sub($form->{nextsub});
+}
+
# end of main