use SL::IS;
use SL::PE;
use SL::DN;
+use SL::ReportGenerator;
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' });
}
}
- $form->{title} = $locale->text('Edit Dunning Process Config');
- $form->{callback} ||= build_std_url("action=edit_config");
- $form->{rowcount} = 1 + scalar @{ $form->{DUNNING} };
- $form->{rowcount_odd} = $form->{rowcount} % 2;
+ $form->{title} = $locale->text('Edit Dunning Process Config');
+ $form->{callback} ||= build_std_url("action=edit_config");
$form->header();
print $form->parse_html_template("dunning/edit_config");
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,
- 'no_postscript' => 1,
- 'no_html' => 1,
- 'no_opendocument' => 1, });
+ $form->{PRINT_OPTIONS} = print_options('inline' => 1,
+ 'no_queue' => 1,
+ 'no_postscript' => 1,
+ 'no_html' => 1,
+ 'no_opendocument' => 1,);
$form->header();
print $form->parse_html_template("dunning/show_invoices");
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);
$form->{addition} = "SAVED FOR DUNNING";
$form->save_history($form->dbconnect(\%myconfig));
}
- # /saving the history
+ # /saving the history
$form->redirect($locale->text('Dunning Process Config saved!'));
$lxdebug->leave_sub();
sub save_dunning {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
+
my $active=1;
my @rows = ();
undef($form->{DUNNING_PDFS});
foreach my $level (values %{ $levels }) {
next unless scalar @{ $level };
- DN->save_dunning(\%myconfig, $form, $level, $userspath, $spool, $sendmail);
+ DN->save_dunning(\%myconfig, $form, $level, $userspath, $spool);
}
}
"customer_id" => $form->{"customer_id_$i"},
"next_dunning_config_id" => $form->{"next_dunning_config_id_$i"},
"email" => $form->{"email_$i"}, } ];
- DN->save_dunning(\%myconfig, $form, $level, $userspath, $spool, $sendmail);
+ DN->save_dunning(\%myconfig, $form, $level, $userspath, $spool);
}
}
sub set_email {
$lxdebug->enter_sub();
+ $auth->assert('dunning_edit');
- my $callback = "$form->{script}?action=set_email&";
- map({ $callback .= "$_=" . $form->escape($form->{$_}) . "&" }
- (qw(login password name input_subject input_body input_attachment email_subject email_body email_attachment), grep({ /^[fl]_/ } keys %$form)));
-
- if ($form->{email_attachment}) {
- $form->{email_attachment} = "checked";
- }
$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");
$form->{SHOW_DUNNING_LEVELS} = scalar @{ $form->{DUNNING} };
$form->{jsscript} = 1;
- $form->{title} = $locale->text('Search Dunning');
+ $form->{title} = $locale->text('Dunnings');
$form->{fokus} = "search.customer";
$form->header();
sub show_dunning {
$lxdebug->enter_sub();
- DN->get_dunning(\%myconfig, \%$form);
-
- my $odd_even = 0;
- my ($previous_dunning_id, $first_row_for_dunning);
+ $auth->assert('dunning_edit');
- foreach $ref (@{ $form->{DUNNINGS} }) {
- if ($previous_dunning_id != $ref->{dunning_id}) {
- $odd_even = ($odd_even + 1) % 2;
- $ref->{first_row_for_dunning} = 1;
+ my @filter_field_list = qw(customer_id customer dunning_level department_id invnumber ordnumber
+ transdatefrom transdateto dunningfrom dunningto notes showold);
- } else {
- $ref->{first_row_for_dunning} = 0;
- }
+ report_generator_set_default_sort('customername', 1);
- $previous_dunning_id = $ref->{dunning_id};
- $ref->{listrow_odd_even} = $odd_even;
- }
+ DN->get_dunning(\%myconfig, \%$form);
if (!$form->{callback}) {
- $form->{callback} =
- build_std_url("action=show_dunning", qw(customer_id customer dunning_level department_id invnumber ordnumber
- ransdatefrom transdateto dunningfrom dunningto notes showold));
+ $form->{callback} = build_std_url("action=show_dunning", @filter_field_list);
}
$form->get_lists('printers' => 'printers',
'languages' => 'languages');
$form->{type} = 'dunning';
- $form->{PRINT_OPTIONS} = print_options({ 'inline' => 1,
- 'no_queue' => 1,
- 'no_postscript' => 1,
- 'no_html' => 1,
- 'no_opendocument' => 1, });
+ $form->{PRINT_OPTIONS} = print_options('inline' => 1,
+ 'no_queue' => 1,
+ 'no_postscript' => 1,
+ 'no_html' => 1,
+ 'no_opendocument' => 1,);
$form->{title} = $locale->text('Dunning overview');
- $form->header();
+ my $report = SL::ReportGenerator->new(\%myconfig, $form);
+
+ $report->set_options('std_column_visibility' => 1,
+ 'title' => $form->{title});
+ $report->set_export_options('show_dunning', @filter_field_list, qw(sort sortdir));
+
+ my %column_defs = (
+ 'checkbox' => { 'text' => '', 'visible' => 'HTML' },
+ 'dunning_description' => { 'text' => $locale->text('Dunning Level') },
+ 'customername' => { 'text' => $locale->text('Customername') },
+ 'invnumber' => { 'text' => $locale->text('Invnumber') },
+ 'transdate' => { 'text' => $locale->text('Invdate') },
+ 'duedate' => { 'text' => $locale->text('Invoice Duedate') },
+ 'amount' => { 'text' => $locale->text('Amount') },
+ 'dunning_date' => { 'text' => $locale->text('Dunning Date') },
+ 'dunning_duedate' => { 'text' => $locale->text('Dunning Duedate') },
+ 'fee' => { 'text' => $locale->text('Total Fees') },
+ '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);
+
+ my ($current_dunning_rows, $previous_dunning_id, $first_row_for_dunning);
- print $form->parse_html_template("dunning/show_dunning");
+ $current_dunning_rows = [];
+ $first_row_for_dunning = 1;
+ $form->{rowcount} = scalar @{ $form->{DUNNINGS} };
+
+ my $i = 0;
+
+ foreach $ref (@{ $form->{DUNNINGS} }) {
+ $i++;
+
+ if ($previous_dunning_id != $ref->{dunning_id}) {
+ $report->add_data($current_dunning_rows) if (scalar @{ $current_dunning_rows });
+ $current_dunning_rows = [];
+ $first_row_for_dunning = 1;
+ }
+
+ my $row = { };
+ foreach my $column (keys %{ $ref }) {
+ $row->{$column} = {
+ 'data' => $first_row_for_dunning || (($column ne 'dunning_description') && ($column ne 'customername')) ? $ref->{$column} : '',
+
+ 'align' => $alignment{$column},
+
+ 'link' => ($column eq 'invnumber' ? $edit_url . E($ref->{id}) :
+ $column eq 'dunning_description' ? $print_url . E($ref->{dunning_id}) : ''),
+ };
+ }
+
+ $row->{checkbox} = !$first_row_for_dunning ? { } : {
+ 'raw_data' => $cgi->hidden('-name' => "dunning_id_$i", '-value' => $ref->{dunning_id})
+ . $cgi->checkbox('-name' => "selected_$i", '-value' => 1, '-label' => ''),
+ 'valign' => 'center',
+ 'align' => 'center',
+ };
+
+ push @{ $current_dunning_rows }, $row;
+
+ $previous_dunning_id = $ref->{dunning_id};
+ $first_row_for_dunning = 0;
+ }
+
+ $report->add_data($current_dunning_rows) if (scalar @{ $current_dunning_rows });
+
+ $report->set_options('raw_top_info_text' => $form->parse_html_template('dunning/show_dunning_top'),
+ 'raw_bottom_info_text' => $form->parse_html_template('dunning/show_dunning_bottom'),
+ 'output_format' => 'HTML',
+ 'attachment_basename' => $locale->text('dunning_list') . strftime('_%Y%m%d', localtime time),
+ );
+
+ $report->set_options_from_form();
+
+ $report->generate_with_headers();
$lxdebug->leave_sub();
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();
}
-# end of main
+sub continue {
+ call_sub($form->{nextsub});
+}
+# end of main