& elements/search.html,
'html_init' => '
Part VI
',
'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' => \@header,
'xml_elements' => [
'county_fips',
'census_tract',
'upload_rate_code',
'download_rate_code',
'technology_code',
'technology_code_other',
'value',
'percentage',
],
'fields' => \@fields,
'links' => \@links,
'url' => $opt{url} || '',
'xml_row_element' => 'Datarow',
'really_disable_download' => 1,
&>
<%init>
my $curuser = $FS::CurrentUser::CurrentUser;
die "access denied"
unless $curuser->access_right('List packages');
my %opt = @_;
my %state_hash = ();
my %state_pkgcount = ();
my @header = ();
my @fields = ();
my @links = ();
my $num = ($cgi->param('offset') =~ /^(\d+)$/) ? $1 : 0;
unless ( $cgi->param('_type') eq 'xml' ) {
push @header, '#';
push @fields, sub { ++$num };
push @links, '';
}
push @header,
'County code',
'Census tract code',
'Upload rate',
'Download rate',
'Technology code',
'Technology code other',
'Quantity',
'Percentage residential',
;
push @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 },
;
my %search_hash = ();
my @sql_query = ();
for ( qw(agentnum magic state) ) {
$search_hash{$_} = $cgi->param($_) if $cgi->param($_);
}
$search_hash{'country'} = 'US';
$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, cust_location.censustract, $percent";
$sql_query->{order_by} =~ /^(.*)(ORDER BY pkgnum)(.*)$/s
or die "couldn't parse order_by";
$sql_query->{order_by} = "$1 GROUP BY cust_location.censustract $3";
push @sql_query, $sql_query;
}
$columncount++;
}
$rowcount++;
}
my $count_query = 'SELECT count(*) FROM ( ('.
join( ') UNION ALL (',
map { my $addl_from = $_->{addl_from};
my $extra_sql = $_->{extra_sql};
my $order_by = $_->{order_by};
"SELECT cust_location.censustract from cust_pkg $addl_from
$extra_sql $order_by";
}
@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;
};
for (1..8) { push @links, [ $link, $link_suffix ]; }
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 { ''.
''.
( &FS::Report::FCC_477::statenum2state($_) || 'None' ).
' | '.
''.
qq().
$state_pkgcount{$_}.
' packages in '.
$state_hash{$_}. ' census tracts'.
' | '.
'
';
}
keys %state_hash
).
'
';
} else {
'';
}
};
%init>