1 | package NPEMap::Postcodes; |
---|
2 | |
---|
3 | use vars qw(@ISA @EXPORT); |
---|
4 | use warnings; |
---|
5 | use strict; |
---|
6 | |
---|
7 | use vars qw($tt_config); |
---|
8 | |
---|
9 | use Template; |
---|
10 | use NPEMap::Config; |
---|
11 | |
---|
12 | require Exporter; |
---|
13 | @ISA = qw(Exporter); |
---|
14 | @EXPORT = qw(build_home_stats); |
---|
15 | |
---|
16 | sub _getAllStats { |
---|
17 | my $dbh = shift; |
---|
18 | my $sql = <<"HERE"; |
---|
19 | SELECT COUNT(*) AS all, |
---|
20 | SUM(CASE WHEN source = 0 THEN 1 ELSE 0 END) AS us, |
---|
21 | COUNT(DISTINCT outward) AS all_out, |
---|
22 | COUNT(DISTINCT CASE WHEN source = 0 THEN outward ELSE '' END) - 1 AS us_out |
---|
23 | FROM postcodes WHERE deleted = 'f'; |
---|
24 | HERE |
---|
25 | |
---|
26 | my $sth = $dbh->prepare($sql); |
---|
27 | |
---|
28 | $sth->execute(); |
---|
29 | |
---|
30 | return $sth->fetchrow_hashref; |
---|
31 | } |
---|
32 | |
---|
33 | sub _getDateStats { |
---|
34 | my $dbh = shift; |
---|
35 | my $sql = <<"HERE"; |
---|
36 | SELECT TO_CHAR(DATE_TRUNC('day', created_at), 'YYYY-MM-DD') AS day, |
---|
37 | COUNT(*) AS all, |
---|
38 | SUM(CASE WHEN source=0 THEN 1 ELSE 0 END) AS us |
---|
39 | FROM postcodes WHERE deleted ='f' |
---|
40 | GROUP BY date_trunc('day', created_at) |
---|
41 | ORDER BY date_trunc('day', created_at); |
---|
42 | |
---|
43 | HERE |
---|
44 | |
---|
45 | my $sth = $dbh->prepare($sql); |
---|
46 | $sth->execute(); |
---|
47 | return $sth->fetchrow_hashref; |
---|
48 | } |
---|
49 | |
---|
50 | =pod |
---|
51 | |
---|
52 | =head build_home_stats |
---|
53 | |
---|
54 | build_home_stats takes a database handle as a parameter and builds the |
---|
55 | HTML stats for inclusion into the home page |
---|
56 | |
---|
57 | =cut |
---|
58 | |
---|
59 | sub build_home_stats { |
---|
60 | my $dbh = shift; |
---|
61 | my $template = Template->new($tt_config); |
---|
62 | |
---|
63 | my $allStats = _getAllStats($dbh); |
---|
64 | my $dateStats = _getDateStats($dbh); |
---|
65 | |
---|
66 | my $vars = { |
---|
67 | allstats => $allStats, |
---|
68 | datestats => $dateStats |
---|
69 | }; |
---|
70 | $template->process('home_stats.tt', $vars) or die $template->error(); |
---|
71 | } |
---|
72 | |
---|
73 | 1; |
---|