X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fsearch%2F477.html;h=b485161376c2ff03b56d026218b41cf7f9e72d30;hb=1509cd837ea7e4e147a088d939b4198ee2456ef8;hp=45c92ffe7d494aa934a17afcc16ec8332dd19e3d;hpb=0b407666b53dea109661f25d51860a7e7e06981f;p=freeside.git diff --git a/httemplate/search/477.html b/httemplate/search/477.html index 45c92ffe7..b48516137 100755 --- a/httemplate/search/477.html +++ b/httemplate/search/477.html @@ -1,26 +1,41 @@ <% include( 'elements/search.html', - 'title' => 'FCC Form 477 Results', - 'html_init' => $html_init, - 'name' => 'regions', - 'query' => $sql_query, - 'count_query' => $count_query, - 'header' => [ - 'State code', - 'County code', - 'Census tract code', - 'Quantity', - ], - 'fields' => [ - sub { my $row = shift; substr($row->censustract, 0, 2) }, + 'title' => 'FCC Form 477 Results', + 'html_init' => $html_init, + 'name' => 'regions', + 'query' => [ @sql_query ], + 'count_query' => $count_query, + 'order_by' => 'ORDER BY censustract', + 'avoid_quote' => 1, + 'no_csv_header' => 1, + 'header' => [ + 'County code', + 'Census tract code', + 'Upload rate', + 'Download rate', + 'Technology code', + 'Technology code other', + 'Quantity', + 'Percentage residential', + ], + 'fields' => [ sub { my $row = shift; substr($row->censustract, 2, 3) }, sub { my $row = shift; substr($row->censustract, 5) }, + 'upload', + 'download', + sub { 7 }, + sub { '' }, 'quantity', + sub { my $row = shift; sprintf "%.2f", $row->residential }, ], - 'links' => [ - [ $link, 'censustract' ], - [ $link, 'censustract' ], - [ $link, 'censustract' ], - [ $link, 'censustract' ], + 'links' => [ + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], + [ $link, $link_suffix ], ], ) %> @@ -32,39 +47,136 @@ die "access denied" unless $curuser->access_right('List packages'); my %search_hash = (); +my @sql_query = (); -$search_hash{'query'} = $cgi->keywords; - -for ( qw(agentnum magic status classnum) ) { +for ( qw(agentnum magic classnum) ) { $search_hash{$_} = $cgi->param($_) if $cgi->param($_); } +my @column_option = $cgi->param('column_option') + if $cgi->param('column_option'); -my @report_option = $cgi->param('report_option') - if $cgi->param('report_option'); -$search_hash{report_option} = join(',', @report_option) if @report_option; +my @row_option = $cgi->param('row_option') + if $cgi->param('row_option'); -my $where = join(' OR ', map { "num = $_" } grep { /^\d+$/ } @report_option ); -my @report_option_name = $where ? - ( map { $_->name } +my $where = join(' OR ', map { "num = $_" } grep { /^\d+$/ } @column_option ); +my %column_option_name = $where ? + ( map { $_->name => $_->num } qsearch({ 'table' => 'part_pkg_report_option', 'hashref' => {}, 'extra_sql' => "WHERE $where", }) ) : - ( 'all packages' ); + ( 'all packages' => '' ); + +$where = join(' OR ', map { "num = $_" } grep { /^\d+$/ } @row_option ); +my %row_option_name = $where ? + ( map { $_->name => $_->num } + qsearch({ 'table' => 'part_pkg_report_option', + 'hashref' => {}, + 'extra_sql' => "WHERE $where", + }) + ) : + ( 'all packages' => '' ); + +@row_option = map { $row_option_name{$_} } sort keys %row_option_name; +@column_option = map { $column_option_name{$_} } sort keys %column_option_name; + +#$search_hash{row_option} = join(',', @row_option) if @row_option; +my $summary .= '

Summary

'. include('/elements/table.html'); +$summary .= ''; +foreach my $column ( sort keys %column_option_name ) { + $summary .= "$column"; +} +$summary .= ""; + +my $total_count = 0; +my $total_residential = 0; +my $rowcount = 1; +foreach my $row ( sort keys %row_option_name ) { + + $summary .= "$row"; -my $html_init = "For
". join(' and
', @report_option_name). "
"; + my $columncount = 2; + foreach my $column ( sort keys %column_option_name ) { + my @report_option = (); + push @report_option, $row_option_name{$row} + if $row_option_name{$row}; + push @report_option, $column_option_name{$column} + if $column_option_name{$column}; + my $report_option = join(',', @report_option) if @report_option; + + my $sql_query = FS::cust_pkg->search_sql( + { %search_hash, + ($report_option ? ( 'report_option' => $report_option ) : () ), + } + ); + my $extracolumns = "$rowcount AS upload, $columncount AS download"; + my $percent = "CASE WHEN count(*) > 0 THEN 100-100*cast(count(cust_main.company) as numeric)/cast(count(*) as numeric) ELSE cast(0 as numeric) END AS residential"; + $sql_query->{select} = "count(*) AS quantity, $extracolumns, censustract, $percent"; + $sql_query->{extra_sql} =~ /^(.*)(ORDER BY pkgnum)(.*)$/s + or die "couldn't parse extra_sql"; + $sql_query->{extra_sql} = "$1 GROUP BY censustract $3"; + + my $count_sql = delete($sql_query->{'count_query'}); + $count_sql =~ s/ FROM/,count(cust_main.company) FROM/ + or die "couldn't parse count_sql"; + + my $count_sth = dbh->prepare($count_sql) + or die "Error preparing $count_sql: ". dbh->errstr; + $count_sth->execute + or die "Error executing $count_sql: ". $count_sth->errstr; + my $count_arrayref = $count_sth->fetchrow_arrayref; + my $count = $count_arrayref->[0]; + $total_count += $count; + my $residential = $count_arrayref->[1]; + $total_residential += $residential; + my $percentage = sprintf('%.2f', $count ? 100-100*$residential/$count : 0); + + $summary .= "$count
$percentage% residential"; + push @sql_query, $sql_query; + $columncount++; + } + + $summary .= ""; + $rowcount++; +} -my $sql_query = FS::cust_pkg->search_sql(\%search_hash); +my $total_percentage = + sprintf("%.2f", $total_count ? 100-100*$total_residential/$total_count : 0); -$sql_query->{select} = 'count(*) as quantity, censustract'; -$sql_query->{extra_sql} =~ /^(.*)(ORDER BY bill)(.*)$/s or die "couldn't parse extra_sql"; -$sql_query->{extra_sql} = "$1 GROUP BY censustract $3"; +my $html_init = '

Totals

'. include('/elements/table.html'). ""; +$html_init .= "Total Connections"; +$html_init .= "% owned loop"; +$html_init .= "% billed to end users"; +$html_init .= "% residential"; +$html_init .= "% residential > 200kbps"; +$html_init .= ""; +$html_init .= "$total_count"; +$html_init .= "100.00"; +$html_init .= "100.00"; +$html_init .= "$total_percentage"; +$html_init .= "$total_percentage"; +$html_init .= "
"; +$html_init .= $summary; +$html_init .= "

Details

"; -my $count_query = delete($sql_query->{'count_query'}); -$count_query = 'SELECT count(*) FROM (SELECT count(*) FROM cust_pkg '. - $sql_query->{addl_from}. ' '. $sql_query->{extra_sql}. ') AS foo'; +my $count_query = 'SELECT count(*) FROM ( ('. + join( ') UNION (', + map { my $extra = $_->{extra_sql}; my $addl = $_->{addl_from}; + "SELECT censustract from cust_pkg $addl $extra"; + } + @sql_query + ). ') ) AS foo'; -my $link = 'cust_pkg.cgi?'. $cgi->query_string. ';censustract='; +my $link = 'cust_pkg.cgi?'. + join(';', map{ "$_=". $search_hash{$_} } keys %search_hash). ';'; +my $link_suffix = sub { my $row = shift; + my $result = 'censustract='. $row->censustract. ';'; + $result .= 'report_option='. @row_option[$row->upload - 1] + if @row_option[$row->upload - 1]; + $result .= 'report_option='. @column_option[$row->download - 1] + if @column_option[$row->download - 1]; + $result; + };