diff options
author | lsc <lsc> | 2006-03-31 09:20:54 +0000 |
---|---|---|
committer | lsc <lsc> | 2006-03-31 09:20:54 +0000 |
commit | fe413bf637b9cc4375defe83d8d7e1e9ed06b9dc (patch) | |
tree | 75ded329e3a9df179eb45124e0b364cd90a8ff43 | |
parent | ee8ec98f0161b6fe11a231c7ac44e50811723b99 (diff) |
fixed the errors pointed out by Ivan in the following email:
----
before and after now? I gave subscription and prorate a try.
Subscription came out as:
subscription 27th (03/25/06 - 04/27/06) $10.00
subscription 23rd (03/25/06 - 04/23/06) $10.00
the "23rd" one is right, but the "27th" one should have only advanced
the date two days to 3/27/06.
Prorate came out as:
prorate 23rd (03/25/06 - 04/23/06) $9.20
prorate 27th (03/25/06 - 04/27/06) $10.49
The "23rd" one is right, but the "27th" one should have only advanced
the date two days to 4/27/06.
lsc@prgmr.com
-rw-r--r-- | FS/FS/part_pkg/prorate.pm | 19 | ||||
-rw-r--r-- | FS/FS/part_pkg/subscription.pm | 13 |
2 files changed, 23 insertions, 9 deletions
diff --git a/FS/FS/part_pkg/prorate.pm b/FS/FS/part_pkg/prorate.pm index d9464eef9..ac2f656b9 100644 --- a/FS/FS/part_pkg/prorate.pm +++ b/FS/FS/part_pkg/prorate.pm @@ -35,12 +35,23 @@ use FS::part_pkg::flat; sub calc_recur { my($self, $cust_pkg, $sdate ) = @_; + my $cutoff_day=$self->option('cutoff_day') or 1; my $mnow = $$sdate; my ($sec,$min,$hour,$mday,$mon,$year) = (localtime($mnow) )[0,1,2,3,4,5]; - my $mstart = timelocal(0,0,0,$self->option('cutoff_day'),$mon,$year); - my $mend = timelocal(0,0,0,$self->option('cutoff_day'), $mon == 11 ? 0 : $mon+1, $year+($mon==11)); - $$sdate = $mstart; - + my $mend; + my $mstart; + if($mday > $cutoff_day){ + $mend = timelocal(0,0,0,$cutoff_day, $mon == 11 ? 0 : $mon+1, $year+($mon==11)); + $mstart= timelocal(0,0,0,$cutoff_day,$mon,$year); + + } + else{ + $mend = timelocal(0,0,0,$cutoff_day, $mon, $year); + if ($mon==0) {$mon=11;$year--;} else {$mon--;} + $mstart= timelocal(0,0,0,$cutoff_day,$mon,$year); + } + + $$sdate = $mstart; my $permonth = $self->option('recur_fee') / $self->freq; $permonth * ( ( $self->freq - 1 ) + ($mend-$mnow) / ($mend-$mstart) ); diff --git a/FS/FS/part_pkg/subscription.pm b/FS/FS/part_pkg/subscription.pm index 8ea791154..ccfcc00a8 100644 --- a/FS/FS/part_pkg/subscription.pm +++ b/FS/FS/part_pkg/subscription.pm @@ -9,7 +9,7 @@ use FS::part_pkg::flat; @ISA = qw(FS::part_pkg::flat); %info = ( - 'name' => 'First partial month full charge, then flat-rate (selectable month billing)', + 'name' => 'First partial month full charge, then flat-rate (selectable billing day)', 'fields' => { 'setup_fee' => { 'name' => 'Setup fee for this package', 'default' => 0, @@ -23,18 +23,21 @@ use FS::part_pkg::flat; }, 'fieldorder' => [ 'setup_fee', 'recur_fee','cutoff_day'], - #'setup' => 'what.setup_fee.value', - #'recur' => '\'my $mnow = $sdate; my ($sec,$min,$hour,$mday,$mon,$year) = (localtime($sdate) )[0,1,2,3,4,5]; $sdate = timelocal(0,0,0,$self->option('cutoff_day'),$mon,$year); \' + what.recur_fee.value', 'freq' => 'm', 'weight' => 30, ); sub calc_recur { my($self, $cust_pkg, $sdate ) = @_; - + my $cutoff_day=$self->option('cutoff_day') or 1; my $mnow = $$sdate; my ($sec,$min,$hour,$mday,$mon,$year) = (localtime($mnow) )[0,1,2,3,4,5]; - $$sdate = timelocal(0,0,0,$self->option('cutoff_day'),$mon,$year); + + if($mday <$cutoff_day){ + if ($mon==0) {$mon=11;$year--;} + else {$mon--;} + } +$$sdate = timelocal(0,0,0,$cutoff_day,$mon,$year); $self->option('recur_fee'); } |