if(!check_perms('site_view_flow')) { error(403); } //Timeline generation if(!isset($_GET['page'])) { if (!list($Labels,$InFlow,$OutFlow,$Max) = $Cache->get_value('users_timeline')) { $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"); $TimelineIn = array_reverse($DB->to_array()); $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"); $TimelineOut = array_reverse($DB->to_array()); foreach($TimelineIn as $Month) { list($Label,$Amount) = $Month; if ($Amount > $Max) { $Max = $Amount; } } foreach($TimelineOut as $Month) { list($Label,$Amount) = $Month; if ($Amount > $Max) { $Max = $Amount; } } foreach($TimelineIn as $Month) { list($Label,$Amount) = $Month; $Labels[] = $Label; $InFlow[] = number_format(($Amount/$Max)*100,4); } foreach($TimelineOut as $Month) { list($Label,$Amount) = $Month; $OutFlow[] = number_format(($Amount/$Max)*100,4); } $Cache->cache_value('users_timeline',array($Labels,$InFlow,$OutFlow,$Max),mktime(0,0,0,date('n')+1,2)); } } //End timeline generation define('DAYS_PER_PAGE', 100); list($Page,$Limit) = Format::page_limit(DAYS_PER_PAGE); $RS = $DB->query("SELECT SQL_CALC_FOUND_ROWS j.Date, DATE_FORMAT(j.Date,'%Y-%m') AS Month, CASE ISNULL(j.Flow) WHEN 0 THEN j.Flow ELSE '0' END AS Joined, CASE ISNULL(m.Flow) WHEN 0 THEN m.Flow ELSE '0' END AS Manual, CASE ISNULL(r.Flow) WHEN 0 THEN r.Flow ELSE '0' END AS Ratio, CASE ISNULL(i.Flow) WHEN 0 THEN i.Flow ELSE '0' END AS Inactivity FROM ( SELECT DATE_FORMAT(JoinDate,'%Y-%m-%d') AS Date, COUNT(UserID) AS Flow FROM users_info WHERE JoinDate != '0000-00-00 00:00:00' GROUP BY Date ) AS j LEFT JOIN ( SELECT DATE_FORMAT(BanDate,'%Y-%m-%d') AS Date, COUNT(UserID) AS Flow FROM users_info WHERE BanDate != '0000-00-00 00:00:00' AND BanReason = '1' GROUP BY Date ) AS m ON j.Date=m.Date LEFT JOIN ( SELECT DATE_FORMAT(BanDate,'%Y-%m-%d') AS Date, COUNT(UserID) AS Flow FROM users_info WHERE BanDate != '0000-00-00 00:00:00' AND BanReason = '2' GROUP BY Date ) AS r ON j.Date=r.Date LEFT JOIN ( SELECT DATE_FORMAT(BanDate,'%Y-%m-%d') AS Date, COUNT(UserID) AS Flow FROM users_info WHERE BanDate != '0000-00-00 00:00:00' AND BanReason = '3' GROUP BY Date ) AS i ON j.Date=i.Date ORDER BY j.Date DESC LIMIT $Limit"); $DB->query("SELECT FOUND_ROWS()"); list($Results) = $DB->next_record(); View::show_header('User Flow'); $DB->set_query_id($RS); ?>
Date | (+) Joined | (-) Manual | (-) Ratio | (-) Inactivity | (-) Total | Net Growth |
=$Date?> | =number_format($Joined)?> | =number_format($Manual)?> | =number_format((double) $Ratio)?> | =number_format($Inactivity)?> | =number_format($TotalOut)?> | =number_format($TotalGrowth)?> |