X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fsearch%2Fcust_main-zip.html;h=e22d3ea2e8ae1213c2d983d50daa36cba3aa6dea;hb=992c6d61adaaf658a52d1bdcc87b6e1780663a64;hp=9790c0fefa2f46d4196f7a3c9f5e1d6963d84d44;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e;p=freeside.git diff --git a/httemplate/search/cust_main-zip.html b/httemplate/search/cust_main-zip.html index 9790c0fef..e22d3ea2e 100644 --- a/httemplate/search/cust_main-zip.html +++ b/httemplate/search/cust_main-zip.html @@ -1,96 +1,96 @@ -% -% -%# 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', +<& elements/search.html, 'title' => 'Zip code Search Results', 'name' => 'zip codes', 'query' => $sql_query, 'count_query' => $count_sql, 'header' => [ 'Zip code', 'Customers', ], - #'fields' => [ 'zip', 'num_cust', ], - 'links' => [ '', sub { 'somewhere'; } ], - ) -%> + 'links' => [ '', $link ], +&> +<%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"; +} + +$cgi->param('column') =~ /^(bill|ship)$/; +my $location = $1 || 'bill'; +$location .= '_locationnum'; + +my $zip; +if ( $cgi->param('ignore_plus4') ) { + $zip = strip_plus4('cust_location.zip'); +} else { + $zip = fieldorempty('cust_location.zip'); +} + +# construct the queries and send 'em off + +my $join = "JOIN cust_location ON (cust_main.$location = cust_location.locationnum)"; + +my $sql_query = + "SELECT $zip AS zipcode, + COUNT(*) AS num_cust + FROM cust_main + $join + $where + GROUP BY zipcode + ORDER BY num_cust DESC, $zip ASC + "; + +my $count_sql = + "SELECT COUNT(DISTINCT cust_location.zip) + FROM cust_main $join $where"; + +my $link = [ $p.'search/cust_main.html?zip=', + sub { $_[0]->[0] } ]; + +