1 package FS::part_pkg::recur_Common;
4 use vars qw( @ISA %info %recur_method );
7 use FS::part_pkg::prorate;
9 @ISA = qw(FS::part_pkg::prorate);
11 %info = ( 'disabled' => 1 ); #recur_Common not a usable price plan directly
13 tie %recur_method, 'Tie::IxHash',
14 'anniversary' => 'Charge the recurring fee at the frequency specified above',
15 'prorate' => 'Charge a prorated fee the first time (selectable billing date)',
16 'subscription' => 'Charge the full fee for the first partial period (selectable billing date)',
19 sub calc_recur_Common {
21 my($cust_pkg, $sdate, $details, $param ) = @_; #only need $sdate & $param
25 if ( $param->{'increment_next_bill'} ) {
27 my $recur_method = $self->option('recur_method', 1) || 'anniversary';
29 if ( $recur_method eq 'prorate'
30 or ($recur_method eq 'anniversary' and $self->option('sync_bill_date',1))
32 $charges = $self->calc_prorate(@_);
36 $charges = $self->option('recur_fee');
38 if ( $recur_method eq 'subscription' ) {
40 my $cutoff_day = $self->option('cutoff_day', 1) || 1;
41 my ($day, $mon, $year) = ( localtime($$sdate) )[ 3..5 ];
43 if ( $day < $cutoff_day ) {
44 if ( $mon == 0 ) { $mon=11; $year--; }
48 $$sdate = timelocal(0, 0, 0, $cutoff_day, $mon, $year);
50 }#$recur_method eq 'subscription'
51 $charges -= $self->calc_discount( $cust_pkg, $sdate, $details, $param );
53 }#$recur_method eq 'prorate' or ...