Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision dd1e5f3e

Von Moritz Bunkus vor etwa 2 Jahren hinzugefügt

  • ID dd1e5f3eb9a2001052dfcb3c892bf31b52f56a54
  • Vorgänger 0b80cba3
  • Nachfolger cc57660c

Wiederkehrende Abrechnung Positionen: Finanzübersicht

Unterschiede anzeigen:

SL/Controller/FinancialOverview.pm
sub calculate_periodic_invoices {
my ($self) = @_;
my %billed_once_item_ids;
my $start_date = DateTime->new(year => $self->year, month => 1, day => 1, time_zone => $::locale->get_local_time_zone);
my $end_date = DateTime->new(year => $self->year, month => 12, day => 31, time_zone => $::locale->get_local_time_zone);
$self->calculate_one_periodic_invoice(config => $_, start_date => $start_date, end_date => $end_date) for @{ $self->objects->{periodic_invoices_cfg} };
foreach my $config (@{ $self->objects->{periodic_invoices_cfg} }) {
$self->calculate_one_periodic_invoice(
config => $config,
start_date => $start_date,
end_date => $end_date,
billed_once_item_ids => \%billed_once_item_ids,
);
}
}
sub calculate_one_periodic_invoice {
my ($self, %params) = @_;
# Calculate sales order advance
my $net = $params{config}->order->netamount * $params{config}->get_billing_period_length / $params{config}->get_order_value_period_length;
my $sord = $self->data->{sales_orders};
my ($net, $net_once) = (0, 0);
foreach my $item (@{ $params{config}->order->orderitems }) {
next if $item->recurring_billing_mode eq 'never';
my $item_net = $item->qty * (1 - $item->discount) * $item->sellprice;
if ($item->recurring_billing_mode eq 'once') {
next if $item->recurring_billing_invoice_id || $params{billed_once_invoice_id}->{$item->id};
$params{billed_once_invoice_id}->{$item->id} = 1;
$net_once += $item_net;
} else {
$net += $item_net;
}
}
$net = $net * $params{config}->get_billing_period_length / $params{config}->get_order_value_period_length;
foreach my $date ($params{config}->calculate_invoice_dates(start_date => $params{start_date}, end_date => $params{end_date}, past_dates => 1)) {
$sord->{months }->[ $date->month - 1 ] += $net;
$sord->{quarters}->[ $date->quarter - 1 ] += $net;
$sord->{year} += $net;
$sord->{months }->[ $date->month - 1 ] += $net + $net_once;
$sord->{quarters}->[ $date->quarter - 1 ] += $net + $net_once;
$sord->{year} += $net + $net_once;
$net_once = 0;
}
# Calculate total sales order value

Auch abrufbar als: Unified diff