Wiederkehrende Rechnungen: Erste Startperiode nicht vergessen
authorMoritz Bunkus <m.bunkus@linet-services.de>
Wed, 16 Oct 2013 12:01:46 +0000 (14:01 +0200)
committerMoritz Bunkus <m.bunkus@linet-services.de>
Thu, 3 Apr 2014 12:19:14 +0000 (14:19 +0200)
SL/DB/PeriodicInvoicesConfig.pm

index 4553675..9bd5e1d 100644 (file)
@@ -83,7 +83,7 @@ sub calculate_invoice_dates {
   my $cur_date   = $self->first_billing_date        || $self->start_date;
   my $end_date   = $self->end_date                  || DateTime->today_local->add(years => 10);
   my $start_date = $params{past_dates} ? undef : $self->get_previous_invoice_date;
-  $start_date  ||= $cur_date->clone->subtract(days => 1);
+  $start_date    = $start_date         ? $start_date->subtract(days => 1) : $cur_date->clone;
 
   $start_date    = max($start_date, $params{start_date}) if $params{start_date};
   $end_date      = min($end_date,   $params{end_date})   if $params{end_date};
@@ -91,7 +91,7 @@ sub calculate_invoice_dates {
   my @dates;
 
   while ($cur_date <= $end_date) {
-    push @dates, $cur_date->clone if $cur_date > $start_date;
+    push @dates, $cur_date->clone if $cur_date >= $start_date;
 
     $cur_date->add(months => $period_len);
   }