<% include( 'elements/search.html', 'html_init' => $html_init, 'html_foot' => $html_foot, 'name' => 'regions', 'query' => [ @sql_query ], 'count_query' => $count_query, 'order_by' => 'ORDER BY censustract', 'avoid_quote' => 1, 'no_csv_header' => 1, 'nohtmlheader' => 1, 'header' => [ 'County code', 'Census tract code', 'Upload rate', 'Download rate', 'Technology code', 'Technology code other', 'Quantity', 'Percentage residential', ], 'xml_elements' => [ 'county_fips', 'census_tract', 'upload_rate_code', 'download_rate_code', 'technology_code', 'technology_code_other', 'value', 'percentage', ], 'fields' => [ sub { my $row = shift; my $state = substr($row->censustract, 0, 2); $state_hash{$state}++; substr($row->censustract, 2, 3) || 'None'; }, sub { my $row = shift; substr($row->censustract, 5) || 'None'; }, 'upload', 'download', 'technology_code', sub { $cgi->param('_type') eq 'xml' ? '0' : '' },#broken sub { my $row = shift; my $state = substr($row->censustract, 0, 2); $state_pkgcount{$state} += $row->quantity; $row->quantity; }, sub { my $row = shift; sprintf "%.2f", $row->residential }, ], '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 ], ], 'url' => $opt{url} || '', 'xml_row_element' => 'Datarow', ) %> <%init> my $curuser = $FS::CurrentUser::CurrentUser; die "access denied" unless $curuser->access_right('List packages'); my %opt = @_; my $html_init = '

Part VI

'; my %search_hash = (); my @sql_query = (); my %state_hash = (); my %state_pkgcount = (); for ( qw(agentnum magic) ) { $search_hash{$_} = $cgi->param($_) if $cgi->param($_); } $search_hash{'classnum'} = [ $cgi->param('classnum') ] if grep { $_ eq 'classnum' } $cgi->param; my @column_option = grep { /^\d+$/ } $cgi->param('part1_column_option') if $cgi->param('part1_column_option'); my @row_option = grep { /^\d+$/ } $cgi->param('part1_row_option') if $cgi->param('part1_row_option'); my @technology_option = &FS::Report::FCC_477::parse_technology_option($cgi); my $rowcount = 1; foreach my $row ( @row_option ) { my $columncount = 2; foreach my $column ( @column_option ) { my $tech_code = 0; foreach my $technology ( @technology_option ) { $tech_code++; next unless $technology; my @report_option = (); push @report_option, $row if $row; push @report_option, $column if $column; push @report_option, $technology; my $report_option = join(',', @report_option) if @report_option; my $sql_query = FS::cust_pkg->search( { %search_hash, ($report_option ? ( 'report_option' => $report_option ) : () ), } ); my $extracolumns = "$rowcount AS upload, $columncount AS download, $tech_code as technology_code"; 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"; push @sql_query, $sql_query; } $columncount++; } $rowcount++; } my $count_query = 'SELECT count(*) FROM ( ('. join( ') UNION ALL (', 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?'. join(';', map { my $key = $_; my @values = ref($search_hash{$_}) ? @{ $search_hash{$_} } : $search_hash{$_}; map { "$key=$_" } @values; } keys %search_hash ). ';'; my $link_suffix = sub { my $row = shift; my $result = 'censustract='. $row->censustract. ';'; my @ro = grep $_, @row_option[$row->upload - 1], @column_option[$row->download - 2], @technology_option[$row->technology_code - 1], ; $result .= 'report_option='. join(',',@ro) if @ro; $result; }; my $html_foot = sub { if (scalar(keys %state_hash) > 1) { my $roa_r = join(',', grep $_, @row_option); $roa_r = ";report_option_any_r=$roa_r" if $roa_r; my $roa_c = join(',', grep $_, @column_option); $roa_c = ";report_option_any_c=$roa_c" if $roa_c; my $roa_t = join(',', grep $_, @technology_option); $roa_t = ";report_option_any_t=$roa_t" if $roa_t; '
WARNING: multiple states found
'. ''. #nicer formatting someday join('', map { ''. ''. ''. ''; } keys %state_hash ). '
'. ( &FS::Report::FCC_477::statenum2state($_) || 'None' ). ''. qq(). $state_pkgcount{$_}. ' packages in '. $state_hash{$_}. ' census tracts'. '
'; } else { ''; } };