summaryrefslogtreecommitdiff
path: root/httemplate/search/report_prepaid_income.cgi
blob: fd9b01ec1e1c30266b26fde7d177937547b63a03 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
<% include("/elements/header.html", 'Prepaid Income (Unearned Revenue) Report',
            menubar( 'Main Menu'=>$p, ) )               %>
<% table() %>
  <TR>
    <TH>Actual Unearned Revenue</TH>
    <TH>Legacy Unearned Revenue</TH>
  </TR>
  <TR>
    <TD ALIGN="right">$<% $total %>
    <TD ALIGN="right">
      <% $now == $time ? "\$$total_legacy" : '<i>N/A</i>'%>
    </TD>
  </TR>

</TABLE>
<BR>
Actual unearned revenue is the amount of unearned revenue Freeside has  
actually invoiced for packages with longer-than monthly terms.
<BR><BR>
Legacy unearned revenue is the amount of unearned revenue represented by 
customer packages.  This number may be larger than actual unearned 
revenue if you have imported longer-than monthly customer packages from
a previous billing system.
</BODY>
</HTML>
<%init>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Financial reports');

#doesn't yet deal with daily/weekly packages

#needs to be re-written in sql for efficiency

my $time = time;

my $now = $cgi->param('date') && str2time($cgi->param('date')) || $time;
$now =~ /^(\d+)$/ or die "unparsable date?";
$now = $1;

my( $total, $total_legacy ) = ( 0, 0 );

my @cust_bill_pkg =
  grep { $_->cust_pkg && $_->cust_pkg->part_pkg->freq !~ /^([01]|\d+[dw])$/ }
    qsearch( 'cust_bill_pkg', {
                                'recur' => { op=>'!=', value=>0 },
                                'edate' => { op=>'>', value=>$now },
                              }, );

my @cust_pkg = 
  grep { $_->part_pkg->recur != 0
         && $_->part_pkg->freq !~ /^([01]|\d+[dw])$/
       }
    qsearch ( 'cust_pkg', {
                            'bill' => { op=>'>', value=>$now }
                          } );

foreach my $cust_bill_pkg ( @cust_bill_pkg) { 
  my $period = $cust_bill_pkg->edate - $cust_bill_pkg->sdate;

  my $elapsed = $now - $cust_bill_pkg->sdate;
  $elapsed = 0 if $elapsed < 0;

  my $remaining = 1 - $elapsed/$period;

  my $unearned = $remaining * $cust_bill_pkg->recur;
  $total += $unearned;

}

foreach my $cust_pkg ( @cust_pkg ) {
  my $period = $cust_pkg->bill - $cust_pkg->last_bill;

  my $elapsed = $now - $cust_pkg->last_bill;
  $elapsed = 0 if $elapsed < 0;

  my $remaining = 1 - $elapsed/$period;

  my $unearned = $remaining * $cust_pkg->part_pkg->recur; #!! only works for flat/legacy
  $total_legacy += $unearned;

}

$total = sprintf('%.2f', $total);
$total_legacy = sprintf('%.2f', $total_legacy);

</%init>