Revision 47326326
Von Tamino Steinert vor 5 Monaten hinzugefügt
SL/DB/PeriodicInvoicesConfig.pm | ||
---|---|---|
42 | 42 |
my $new_order = clone($orig_order); |
43 | 43 |
$new_order->reqdate($period_start_date); |
44 | 44 |
$new_order->tax_point( |
45 |
add_months( |
|
45 |
$self->add_months(
|
|
46 | 46 |
$period_start_date, $self->get_billing_period_length || $self->get_order_value_period_length || 1 |
47 | 47 |
)->add(days => -1) |
48 | 48 |
); |
... | ... | |
94 | 94 |
|| $self->first_billing_date || $self->start_date; |
95 | 95 |
my @dates = $self->calculate_invoice_dates( |
96 | 96 |
start_date => $start_date, |
97 |
end_date => add_months($start_date, $b_period), |
|
97 |
end_date => $self->add_months($start_date, $b_period),
|
|
98 | 98 |
); |
99 | 99 |
my $once_date = scalar @dates ? $dates[0] : undef; |
100 | 100 |
return if $period_start_date != $once_date; |
... | ... | |
116 | 116 |
my $periods = $max_periods; |
117 | 117 |
if ($item_config->start_date) { |
118 | 118 |
$periods-- while $periods > 0 |
119 |
&& add_months($period_start_date, -1 * ($periods - 1) * $i_period) < $item_config->start_date; |
|
119 |
&& $self->add_months($period_start_date, -1 * ($periods - 1) * $i_period) < $item_config->start_date;
|
|
120 | 120 |
} |
121 | 121 |
if ($item_config->end_date) { |
122 | 122 |
my $periods_from_end = 0; |
123 | 123 |
$periods_from_end++ while $periods_from_end < $periods |
124 |
&& add_months($period_start_date, -1 * ($periods_from_end)) > $item_config->end_date; |
|
124 |
&& $self->add_months($period_start_date, -1 * ($periods_from_end)) > $item_config->end_date;
|
|
125 | 125 |
$periods -= $periods_from_end; |
126 | 126 |
} |
127 | 127 |
return if $periods == 0; |
... | ... | |
201 | 201 |
|
202 | 202 |
my $month_to_start = $start_date->year * 12 + $start_date->month - $months_first_period; |
203 | 203 |
$month_to_start += 1 |
204 |
if add_months($first_period_start_date, $month_to_start) < $start_date; |
|
204 |
if $self->add_months($first_period_start_date, $month_to_start) < $start_date;
|
|
205 | 205 |
|
206 | 206 |
my $month_after_last_created = 0; |
207 | 207 |
if ($last_created_on_date) { |
208 | 208 |
$month_after_last_created = |
209 | 209 |
$last_created_on_date->year * 12 + $last_created_on_date->month - $months_first_period; |
210 | 210 |
$month_after_last_created += 1 |
211 |
if add_months($first_period_start_date, $month_after_last_created) <= $last_created_on_date; |
|
211 |
if $self->add_months($first_period_start_date, $month_after_last_created) <= $last_created_on_date;
|
|
212 | 212 |
} |
213 | 213 |
|
214 | 214 |
my $months_from_period_start = max( |
... | ... | |
219 | 219 |
my $period_count = int($months_from_period_start / $billing_period_length); # floor |
220 | 220 |
$period_count += $months_from_period_start % $billing_period_length != 0 ? 1 : 0; # ceil |
221 | 221 |
|
222 |
my $next_period_start_date = add_months($first_period_start_date, $period_count * $billing_period_length); |
|
222 |
my $next_period_start_date = $self->add_months($first_period_start_date, $period_count * $billing_period_length);
|
|
223 | 223 |
while ($next_period_start_date <= $end_date) { |
224 | 224 |
push @start_dates, $next_period_start_date; |
225 | 225 |
$period_count++; |
226 |
$next_period_start_date = add_months($first_period_start_date, $period_count * $billing_period_length); |
|
226 |
$next_period_start_date = $self->add_months($first_period_start_date, $period_count * $billing_period_length);
|
|
227 | 227 |
} |
228 | 228 |
} else { # single |
229 | 229 |
push @start_dates, $first_period_start_date |
... | ... | |
247 | 247 |
} |
248 | 248 |
|
249 | 249 |
sub add_months { |
250 |
my ($date, $months) = @_; |
|
250 |
my ($self, $date, $months) = @_;
|
|
251 | 251 |
|
252 | 252 |
my $start_months_of_date = $date->month; |
253 | 253 |
$date = $date->clone(); |
... | ... | |
285 | 285 |
$active = 1; |
286 | 286 |
|
287 | 287 |
my $end_date = $self->end_date; |
288 |
$end_date = add_months($end_date, $self->extend_automatically_by) while $today > $end_date; |
|
288 |
$end_date = $self->add_months($end_date, $self->extend_automatically_by) while $today > $end_date;
|
|
289 | 289 |
_log_msg("HAE for " . $self->id . " from " . $self->end_date . " to " . $end_date . " on " . $today . "\n"); |
290 | 290 |
$self->update_attributes(end_date => $end_date); |
291 | 291 |
} |
... | ... | |
302 | 302 |
$active = 1; |
303 | 303 |
|
304 | 304 |
my $end_date = $item_config->end_date; |
305 |
$end_date = add_months($end_date, $item_config->extend_automatically_by) while $today > $end_date; |
|
305 |
$end_date = $self->add_months($end_date, $item_config->extend_automatically_by) while $today > $end_date;
|
|
306 | 306 |
_log_msg("HAE for item " . $item->id . " from " . $item_config->end_date . " to " . $end_date . " on " . $today . "\n"); |
307 | 307 |
$item_config->update_attributes(end_date => $end_date); |
308 | 308 |
} |
Auch abrufbar als: Unified diff
S:D:PeriodicInvoicesConfig: Helferfunk. add_month über Klasse aufrufbar