X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fsearch%2Fcust_main-zip.html;h=e87b21474319ad4ef70ae18373d4a87ce1d0ced2;hp=9790c0fefa2f46d4196f7a3c9f5e1d6963d84d44;hb=c3da5cf1caa244937d280e0f406927103beef148;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e diff --git a/httemplate/search/cust_main-zip.html b/httemplate/search/cust_main-zip.html index 9790c0fef..e87b21474 100644 --- a/httemplate/search/cust_main-zip.html +++ b/httemplate/search/cust_main-zip.html @@ -1,89 +1,3 @@ -% -% -%# XXX link to customers -% -%my @where = (); -% -%# select status -% -%if ( $cgi->param('status') =~ /^(prospect|uncancel|active|susp|cancel)$/ ) { -% my $method = $1.'_sql'; -% push @where, FS::cust_main->$method(); -%} -% -%# select agent -%# XXX this needs to be virtualized by agent too (like lots of stuff) -% -%my $agentnum = ''; -%if ( $cgi->param('agentnum') =~ /^(\d+)$/ ) { -% $agentnum = $1; -% push @where, "cust_main.agentnum = $agentnum"; -%} -%my $where = scalar(@where) ? 'WHERE '. join(' AND ', @where) : ''; -% -%# bill zip vs ship zip -% -%sub fieldorempty { -% my $field = shift; -% "CASE WHEN $field IS NULL THEN '' ELSE $field END"; -%} -% -%sub strip_plus4 { -% my $field = shift; -% "CASE WHEN $field is NULL -% THEN '' -% ELSE CASE WHEN $field LIKE '_____-____' -% THEN SUBSTRING($field FROM 1 FOR 5) -% ELSE $field -% END -% END"; -%} -% -%my( $zip, $czip); -%if ( $cgi->param('column') eq 'ship_zip' ) { -% -% my $casewhen_noship = -% "CASE WHEN ( ship_last IS NULL OR ship_last = '' ) THEN "; -% -% $czip = "$casewhen_noship zip ELSE ship_zip END"; -% -% if ( $cgi->param('ignore_plus4') ) { -% $zip = $casewhen_noship. strip_plus4('zip'). -% " ELSE ". strip_plus4('ship_zip'). ' END'; -% -% } else { -% $zip = $casewhen_noship. fieldorempty('zip'). -% " ELSE ". fieldorempty('ship_zip'). ' END'; -% } -% -%} else { -% -% $czip = 'zip'; -% -% if ( $cgi->param('ignore_plus4') ) { -% $zip = strip_plus4('zip'); -% } else { -% $zip = fieldorempty('zip'); -% } -% -%} -% -%# construct the queries and send 'em off -% -%my $sql_query = -% "SELECT $zip AS zipcode, -% COUNT(*) AS num_cust -% FROM cust_main -% $where -% GROUP BY zipcode -% ORDER BY num_cust DESC -% "; -% -%my $count_sql = "select count(distinct $czip) from cust_main $where"; -% -%# XXX should link... -% -% <% include( 'elements/search.html', 'title' => 'Zip code Search Results', 'name' => 'zip codes', @@ -94,3 +8,103 @@ 'links' => [ '', sub { 'somewhere'; } ], ) %> +<%init> + +die "access denied" + unless $FS::CurrentUser::CurrentUser->access_right('List zip codes'); + +# XXX link to customers + +my @where = (); + +# select status + +if ( $cgi->param('status') =~ /^(prospect|uncancel|active|susp|cancel)$/ ) { + my $method = $1.'_sql'; + push @where, FS::cust_main->$method(); +} + +# select agent +# XXX this needs to be virtualized by agent too (like lots of stuff) + +my $agentnum = ''; +if ( $cgi->param('agentnum') =~ /^(\d+)$/ ) { + $agentnum = $1; + push @where, "cust_main.agentnum = $agentnum"; +} + +# select svcdb + +if ( $cgi->param('svcdb') =~ /^(\w+)$/ ) { + my $svcdb = $1; + push @where, "EXISTS( SELECT 1 FROM $svcdb LEFT JOIN cust_svc USING ( svcnum ) + LEFT JOIN cust_pkg USING ( pkgnum ) + WHERE cust_pkg.custnum = cust_main.custnum + )"; +} + +my $where = scalar(@where) ? 'WHERE '. join(' AND ', @where) : ''; + +# bill zip vs ship zip + +sub fieldorempty { + my $field = shift; + "CASE WHEN $field IS NULL THEN '' ELSE $field END"; +} + +sub strip_plus4 { + my $field = shift; + "CASE WHEN $field is NULL + THEN '' + ELSE CASE WHEN $field LIKE '_____-____' + THEN SUBSTRING($field FROM 1 FOR 5) + ELSE $field + END + END"; +} + +my( $zip, $czip); +if ( $cgi->param('column') eq 'ship_zip' ) { + + my $casewhen_noship = + "CASE WHEN ( ship_last IS NULL OR ship_last = '' ) THEN "; + + $czip = "$casewhen_noship zip ELSE ship_zip END"; + + if ( $cgi->param('ignore_plus4') ) { + $zip = $casewhen_noship. strip_plus4('zip'). + " ELSE ". strip_plus4('ship_zip'). ' END'; + + } else { + $zip = $casewhen_noship. fieldorempty('zip'). + " ELSE ". fieldorempty('ship_zip'). ' END'; + } + +} else { + + $czip = 'zip'; + + if ( $cgi->param('ignore_plus4') ) { + $zip = strip_plus4('zip'); + } else { + $zip = fieldorempty('zip'); + } + +} + +# construct the queries and send 'em off + +my $sql_query = + "SELECT $zip AS zipcode, + COUNT(*) AS num_cust + FROM cust_main + $where + GROUP BY zipcode + ORDER BY num_cust DESC + "; + +my $count_sql = "select count(distinct $czip) from cust_main $where"; + +# XXX should link... + +