Gazelle/sections/stats/users.php

187 lines
7.5 KiB
PHP
Raw Normal View History

2011-03-28 14:21:28 +00:00
<?
if (!list($Countries,$Rank,$CountryUsers,$CountryMax,$CountryMin,$LogIncrements) = $Cache->get_value('geodistribution')) {
include_once(SERVER_ROOT.'/classes/class_charts.php');
$DB->query('SELECT Code, Users FROM users_geodistribution');
$Data = $DB->to_array();
2013-04-30 18:18:07 +00:00
$Count = $DB->record_count() - 1;
2013-02-22 08:00:24 +00:00
2013-04-30 18:18:07 +00:00
if ($Count < 30) {
2011-03-28 14:21:28 +00:00
$CountryMinThreshold = $Count;
} else {
$CountryMinThreshold = 30;
}
2013-02-22 08:00:24 +00:00
2013-04-30 18:18:07 +00:00
$CountryMax = ceil(log(Max(1, $Data[0][1])) / log(2)) + 1;
$CountryMin = floor(log(Max(1, $Data[$CountryMinThreshold][1])) / log(2));
2011-03-28 14:21:28 +00:00
2011-09-30 08:00:12 +00:00
$CountryRegions = array('RS' => array('RS-KM')); // Count Kosovo as Serbia as it doesn't have a TLD
2011-03-28 14:21:28 +00:00
foreach ($Data as $Key => $Item) {
list($Country,$UserCount) = $Item;
$Countries[] = $Country;
2013-04-30 18:18:07 +00:00
$CountryUsers[] = number_format((((log($UserCount) / log(2)) - $CountryMin) / ($CountryMax - $CountryMin)) * 100, 2);
$Rank[] = round((1 - ($Key / $Count)) * 100);
2011-09-30 08:00:12 +00:00
2013-04-30 18:18:07 +00:00
if (isset($CountryRegions[$Country])) {
foreach ($CountryRegions[$Country] as $Region) {
2011-09-30 08:00:12 +00:00
$Countries[] = $Region;
$Rank[] = end($Rank);
}
}
2011-03-28 14:21:28 +00:00
}
2011-09-30 08:00:12 +00:00
reset($Rank);
2013-02-22 08:00:24 +00:00
2013-04-30 18:18:07 +00:00
for ($i = $CountryMin; $i <= $CountryMax; $i++) {
$LogIncrements[] = Format::human_format(pow(2, $i));
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
$Cache->cache_value('geodistribution',array($Countries, $Rank, $CountryUsers, $CountryMax, $CountryMin, $LogIncrements), 0);
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
if (!$ClassDistribution = $Cache->get_value('class_distribution')) {
2011-03-28 14:21:28 +00:00
include_once(SERVER_ROOT.'/classes/class_charts.php');
2013-05-07 08:00:23 +00:00
$DB->query("
SELECT p.Name, COUNT(m.ID) AS Users
FROM users_main AS m
JOIN permissions AS p ON m.PermissionID=p.ID
WHERE m.Enabled='1'
GROUP BY p.Name
ORDER BY Users DESC");
2012-01-27 08:00:19 +00:00
$ClassSizes = $DB->to_array();
2011-03-28 14:21:28 +00:00
$Pie = new PIE_CHART(750,400,array('Other'=>1,'Percentage'=>1));
2013-04-30 18:18:07 +00:00
foreach ($ClassSizes as $ClassSize) {
list($Label, $Users) = $ClassSize;
$Pie->add($Label, $Users);
2011-03-28 14:21:28 +00:00
}
$Pie->transparent();
$Pie->color('FF33CC');
$Pie->generate();
$ClassDistribution = $Pie->url();
2013-05-07 08:00:23 +00:00
$Cache->cache_value('class_distribution', $ClassDistribution, 3600 * 24 * 14);
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
if (!$PlatformDistribution = $Cache->get_value('platform_distribution')) {
2011-03-28 14:21:28 +00:00
include_once(SERVER_ROOT.'/classes/class_charts.php');
2013-05-16 16:15:57 +00:00
2013-05-07 08:00:23 +00:00
$DB->query("
SELECT OperatingSystem, COUNT(UserID) AS Users
FROM users_sessions
GROUP BY OperatingSystem
ORDER BY Users DESC");
2013-05-16 16:15:57 +00:00
2011-03-28 14:21:28 +00:00
$Platforms = $DB->to_array();
$Pie = new PIE_CHART(750,400,array('Other'=>1,'Percentage'=>1));
2013-04-30 18:18:07 +00:00
foreach ($Platforms as $Platform) {
2011-03-28 14:21:28 +00:00
list($Label,$Users) = $Platform;
$Pie->add($Label,$Users);
}
$Pie->transparent();
$Pie->color('8A00B8');
$Pie->generate();
$PlatformDistribution = $Pie->url();
2013-05-07 08:00:23 +00:00
$Cache->cache_value('platform_distribution', $PlatformDistribution, 3600 * 24 * 14);
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
if (!$BrowserDistribution = $Cache->get_value('browser_distribution')) {
2011-03-28 14:21:28 +00:00
include_once(SERVER_ROOT.'/classes/class_charts.php');
2013-05-16 16:15:57 +00:00
2012-01-27 08:00:19 +00:00
2013-05-07 08:00:23 +00:00
$DB->query("
SELECT Browser, COUNT(UserID) AS Users
FROM users_sessions
GROUP BY Browser
ORDER BY Users DESC");
2012-01-27 08:00:19 +00:00
2011-03-28 14:21:28 +00:00
$Browsers = $DB->to_array();
$Pie = new PIE_CHART(750,400,array('Other'=>1,'Percentage'=>1));
2013-04-30 18:18:07 +00:00
foreach ($Browsers as $Browser) {
2011-03-28 14:21:28 +00:00
list($Label,$Users) = $Browser;
$Pie->add($Label,$Users);
}
$Pie->transparent();
$Pie->color('008AB8');
$Pie->generate();
$BrowserDistribution = $Pie->url();
2013-05-07 08:00:23 +00:00
$Cache->cache_value('browser_distribution', $BrowserDistribution, 3600 * 24 * 14);
2011-03-28 14:21:28 +00:00
}
//Timeline generation
if (!list($Labels,$InFlow,$OutFlow,$Max) = $Cache->get_value('users_timeline')) {
2013-05-07 08:00:23 +00:00
$DB->query("
SELECT DATE_FORMAT(JoinDate,'%b \\'%y') AS Month, COUNT(UserID)
FROM users_info
GROUP BY Month
ORDER BY JoinDate DESC
LIMIT 1, 12");
2011-03-28 14:21:28 +00:00
$TimelineIn = array_reverse($DB->to_array());
2013-05-07 08:00:23 +00:00
$DB->query("
SELECT DATE_FORMAT(BanDate,'%b \\'%y') AS Month, COUNT(UserID)
FROM users_info
GROUP BY Month
ORDER BY BanDate DESC
LIMIT 1, 12");
2011-03-28 14:21:28 +00:00
$TimelineOut = array_reverse($DB->to_array());
2013-04-30 18:18:07 +00:00
foreach ($TimelineIn as $Month) {
2011-03-28 14:21:28 +00:00
list($Label,$Amount) = $Month;
if ($Amount > $Max) {
$Max = $Amount;
}
}
2013-04-30 18:18:07 +00:00
foreach ($TimelineOut as $Month) {
2011-03-28 14:21:28 +00:00
list($Label,$Amount) = $Month;
if ($Amount > $Max) {
$Max = $Amount;
}
}
$Labels = array();
2013-04-30 18:18:07 +00:00
foreach ($TimelineIn as $Month) {
2011-03-28 14:21:28 +00:00
list($Label,$Amount) = $Month;
$Labels[] = $Label;
2013-04-30 18:18:07 +00:00
$InFlow[] = number_format(($Amount / $Max) * 100, 4);
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
foreach ($TimelineOut as $Month) {
2011-03-28 14:21:28 +00:00
list($Label,$Amount) = $Month;
2013-04-30 18:18:07 +00:00
$OutFlow[] = number_format(($Amount / $Max) * 100, 4);
2011-03-28 14:21:28 +00:00
}
2013-04-30 18:18:07 +00:00
$Cache->cache_value('users_timeline',array($Labels,$InFlow,$OutFlow,$Max),mktime(0,0,0,date('n') + 1, 2)); //Tested: fine for dec -> jan
2011-03-28 14:21:28 +00:00
}
//End timeline generation
2012-10-11 08:00:15 +00:00
View::show_header('Detailed User Statistics');
2011-03-28 14:21:28 +00:00
?>
2012-12-27 08:00:27 +00:00
<h3 id="User_Flow"><a href="#User_Flow">User Flow</a></h3>
2011-03-28 14:21:28 +00:00
<div class="box pad center">
2012-09-09 08:00:26 +00:00
<img src="http://chart.apis.google.com/chart?cht=lc&amp;chs=880x160&amp;chco=000D99,99000D&amp;chg=0,-1,1,1&amp;chxt=y,x&amp;chxs=0,h&amp;chxl=1:|<?=implode('|',$Labels)?>&amp;chxr=0,0,<?=$Max?>&amp;chd=t:<?=implode(',',$InFlow)?>|<?=implode(',',$OutFlow)?>&amp;chls=2,4,0&amp;chdl=New+Registrations|Disabled+Users&amp;chf=bg,s,FFFFFF00" alt="User Flow Chart" />
2011-03-28 14:21:28 +00:00
</div>
<br />
2012-12-27 08:00:27 +00:00
<h3 id="User_Classes"><a href="#User_Classes">User Classes</a></h3>
2011-03-28 14:21:28 +00:00
<div class="box pad center">
2012-08-29 08:00:17 +00:00
<img src="<?=$ClassDistribution?>" alt="User Class Distribution" />
2011-03-28 14:21:28 +00:00
</div>
<br />
2012-12-27 08:00:27 +00:00
<h3 id="User_Platforms"><a href="#User_Platforms">User Platforms</a></h3>
2011-03-28 14:21:28 +00:00
<div class="box pad center">
2012-08-29 08:00:17 +00:00
<img src="<?=$PlatformDistribution?>" alt="User Platform Distribution" />
2011-03-28 14:21:28 +00:00
</div>
<br />
2012-12-27 08:00:27 +00:00
<h3 id="User_Browsers"><a href="#User_Browsers">User Browsers</a></h3>
2011-03-28 14:21:28 +00:00
<div class="box pad center">
2012-08-29 08:00:17 +00:00
<img src="<?=$BrowserDistribution?>" alt="User Browsers Market Share" />
2011-03-28 14:21:28 +00:00
</div>
<br />
2012-12-27 08:00:27 +00:00
<h3 id="Geo_Dist_Map"><a href="#Geo_Dist_Map">Geographical Distribution Map</a></h3>
<div class="box center">
2012-09-09 08:00:26 +00:00
<img src="http://chart.apis.google.com/chart?cht=map:fixed=-55,-180,73,180&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - Worldwide" />
<img src="http://chart.apis.google.com/chart?cht=map:fixed=37,-26,65,67&amp;chs=440x220&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - Europe" />
<br />
2012-09-09 08:00:26 +00:00
<img src="http://chart.apis.google.com/chart?cht=map:fixed=-46,-132,24,21.5&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - South America" />
<img src="http://chart.apis.google.com/chart?cht=map:fixed=-11,22,50,160&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - Asia" />
<br />
2012-09-09 08:00:26 +00:00
<img src="http://chart.apis.google.com/chart?cht=map:fixed=-36,-57,37,100&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - Africa" />
<img src="http://chart.apis.google.com/chart?cht=map:fixed=14.8,15,45,86&amp;chs=440x220&amp;chd=t:<?=implode(',',$Rank)?>&amp;chco=FFFFFF,EDEDED,1F0066&amp;chld=<?=implode('|',$Countries)?>&amp;chf=bg,s,CCD6FF" alt="Geographical Distribution Map - Middle East" />
<br />
2012-09-09 08:00:26 +00:00
<img src="http://chart.apis.google.com/chart?chxt=y,x&amp;chg=0,-1,1,1&amp;chxs=0,h&amp;cht=bvs&amp;chco=76A4FB&amp;chs=880x300&amp;chd=t:<?=implode(',',array_slice($CountryUsers,0,31))?>&amp;chxl=1:|<?=implode('|',array_slice($Countries,0,31))?>|0:|<?=implode('|',$LogIncrements)?>&amp;chf=bg,s,FFFFFF00" alt="Number of users by country" />
</div>
2011-03-28 14:21:28 +00:00
<?
2012-10-11 08:00:15 +00:00
View::show_footer();