1 package FS::Report::Table::Daily;
7 use Time::Local qw( timelocal timelocal_nocheck ); # eventually replace with DateTime
8 use Date::Format qw( time2str );
10 @ISA = qw( FS::Report::Table );
14 FS::Report::Table::Daily - Tables of report data, indexed daily
18 use FS::Report::Table::Daily;
20 my $report = new FS::Report::Table::Daily (
21 'items' => [ 'invoiced', 'netsales', 'credits', 'receipts', ],
30 'cust_classnum' => [ 1,2,4 ],
31 'params' => [ [ 'paramsfor', 'item_one' ], [ 'item', 'two' ] ], # ...
32 'remove_empty' => 1, #collapse empty rows, default 0
33 'item_labels' => [ ], #useful with remove_empty
36 my $data = $report->data;
44 Returns a hashref of data (!! describe)
51 my $sday = $self->{'start_day'};
52 my $smonth = $self->{'start_month'};
53 my $syear = $self->{'start_year'};
54 my $eday = $self->{'end_day'};
55 my $emonth = $self->{'end_month'};
56 my $eyear = $self->{'end_year'};
57 my $agentnum = $self->{'agentnum'};
58 my $cust_classnum = $self->{'cust_classnum'} || [];
59 $cust_classnum = [ $cust_classnum ] if !ref($cust_classnum);
63 my $sdate = timelocal(0,0,0,$sday,$smonth-1,$syear);
64 my $edate = timelocal(0,0,0,$eday,$emonth-1,$eyear);
66 my $conf = FS::Conf->new;
67 my $date_format = $conf->config('date_format') || '%d/%m/%Y';
69 #warn "daily range $sdate $edate\n";
71 # XXX: use date_format config for the labels since we have day in the labels now?
72 while ( $sdate < $edate ) {
73 push @{$data{label}}, time2str($date_format, $sdate);
77 #ala part_pkg->add_freq, to deal with local DST. DateTime also a good idea
78 my ($mday,$mon,$year) = (localtime($sdate) )[3,4,5];
79 $sdate = timelocal_nocheck(0,0,0,$mday+1,$mon,$year);
83 push @{$data{speriod}}, $speriod;
84 push @{$data{eperiod}}, $eperiod;
87 my @items = @{$self->{'items'}};
89 for ( $i = 0; $i < scalar(@items); $i++ ) {
90 my $item = $items[$i];
91 my @param = $self->{'params'} ? @{ $self->{'params'}[$col] }: ();
92 push @param, 'cust_classnum' => $cust_classnum if @$cust_classnum;
93 my $value = $self->$item($speriod, $eperiod, $agentnum, @param);
94 push @{$data{data}->[$col++]}, $value;
98 #these need to get generalized, sheesh
99 $data{'items'} = $self->{'items'};
100 $data{'item_labels'} = $self->{'item_labels'} || $self->{'items'};
101 $data{'colors'} = $self->{'colors'};
102 $data{'links'} = $self->{'links'} || [];
104 if ( $self->{'remove_empty'} ) {
107 #these need to get generalized, sheesh
113 foreach my $item ( @{$self->{'items'}} ) {
115 if ( grep { $_ != 0 } @{$data{'data'}->[$col]} ) {
116 push @newitems, $data{'items'}->[$col];
117 push @newlabels, $data{'item_labels'}->[$col];
118 push @newdata, $data{'data'}->[$col];
119 push @newcolors, $data{'colors'}->[$col];
120 push @newlinks, $data{'links'}->[$col];
126 $data{'items'} = \@newitems;
127 $data{'item_labels'} = \@newlabels;
128 $data{'data'} = \@newdata;
129 $data{'colors'} = \@newcolors;
130 $data{'links'} = \@newlinks;