X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fsearch%2F477partVI_census.html;h=b6043539a1e7c746643c10f976576bcb6f844a6d;hb=b55fb5df35587a35be4c347073364c132970a533;hp=d28caeb47566b8c9a67d18d55f309560047e5a05;hpb=c0e1b949ca42baf12bc501be41401608f10853e6;p=freeside.git diff --git a/httemplate/search/477partVI_census.html b/httemplate/search/477partVI_census.html index d28caeb47..b6043539a 100755 --- a/httemplate/search/477partVI_census.html +++ b/httemplate/search/477partVI_census.html @@ -1,13 +1,6 @@ <% include( 'elements/search.html', 'html_init' => $html_init, - 'html_foot' => sub { if (scalar(keys %state_hash) > 1) { - '
'. - 'WARNING: multiple states found'. - '
'; - } else { - ''; - } - }, + 'html_foot' => $html_foot, 'name' => 'regions', 'query' => [ @sql_query ], 'count_query' => $count_query, @@ -37,15 +30,22 @@ ], 'fields' => [ sub { my $row = shift; - $state_hash{substr($row->censustract, 0, 2)} = 1; - substr($row->censustract, 2, 3) + 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'; }, - sub { my $row = shift; substr($row->censustract, 5) }, 'upload', 'download', 'technology_code', - sub { $cgi->param('_type') eq 'xml' ? '0' : '' }, # doesn't really work - 'quantity', + 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' => [ @@ -76,11 +76,13 @@ 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') ]; +$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'); @@ -134,18 +136,48 @@ my $link = 'cust_pkg.cgi?'. join(';', map { my $key = $_; my @values = ref($search_hash{$_}) ? @{ $search_hash{$_} } - : $search_hash{$_} - map { "$key=$_" } @values + : $search_hash{$_}; + map { "$key=$_" } @values; } 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]; + 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 = join(',', grep $_, @technology_option); + $roa = ";report_option_any=$roa" if $roa; + + '
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 { + ''; + } +}; +