# HG changeset patch # User Dan # Date 1230635814 18000 # Node ID c3cbefda414abe8f905ca0bf73fa99de7fdc2fdf # Parent a7d884914a74df7acf62e349cb8145b9024430b9# Parent a76ae7eaa2eb47ee12bd4b0508823e6d979807c7 Merging apparently split branches diff -r a7d884914a74 -r c3cbefda414a htdocs/24hours.php --- a/htdocs/24hours.php Tue Dec 30 06:16:28 2008 -0500 +++ b/htdocs/24hours.php Tue Dec 30 06:16:54 2008 -0500 @@ -1,61 +1,5 @@ = 0; $i-- ) -{ - $basetime = $this_hour - ( $i * 3600 ); - $ts = date('H:i', $basetime); - $basetime += 3600; - $graphdata[$ts] = stats_message_count($channel, 60, $basetime); -} - -$max = max($graphdata); +$_GET['mode'] = 'lastday'; +require('graph.php'); -// Determine axis interval -$interval = 2; -if ( $max > 20 ) - $interval = 4; -if ( $max > 25 ) - $interval = 5; -if ( $max > 50 ) - $interval = 10; -if ( $max > 200 ) - $interval = 40; -if ( $max > 500 ) - $interval = 80; -if ( $max > 1000 ) - $interval = 100; -if ( $max > 2000 ) - $interval = 200; -if ( $max > 5000 ) - $interval = 1000; -if ( $max > 15000 ) - $interval = 1500; -if ( $max > 30000 ) - $interval = round($max / 10); - -$g = new GraphMaker(); // _Compat(); - -$g->SetGraphPadding(20, 30, 20, 15); -$g->SetGraphAreaHeight(200); -$g->SetBarDimensions(26, 0); -$g->SetBarPadding(7); -$g->SetBarData($graphdata); -$g->SetGraphBackgroundTransparent(240, 250, 255, 0); -$g->SetGraphTransparency(25); -$g->SetAxisStep($interval); -$g->SetGraphTitle($channel . ' message count - last 24 hours'); - -$g->DrawGraph(); diff -r a7d884914a74 -r c3cbefda414a htdocs/graph.php --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/htdocs/graph.php Tue Dec 30 06:16:54 2008 -0500 @@ -0,0 +1,102 @@ +SetGraphPadding(20, 30, 20, 15); +$g->SetGraphAreaHeight(200); +$g->SetBarDimensions(26, 0); +$g->SetBarPadding(7); +$g->SetGraphBackgroundTransparent(240, 250, 255, 0); +$g->SetGraphTransparency(25); + +// generate the data +// we're doing this by absolute hours, not by strictly "24 hours ago", e.g. on-the-hour stats +$mode = ( isset($_GET['mode']) ) ? $_GET['mode'] : 'lastday'; +switch ( $mode ) +{ + case 'lastday': + default: + $graph_title = $channel . ' message count - last 24 hours'; + $this_hour = gmmktime(gmdate('H'), 0, 0); + $graphdata = array(); + + for ( $i = 23; $i >= 0; $i-- ) + { + $basetime = $this_hour - ( $i * 3600 ); + $ts = date('H:i', $basetime); + $basetime += 3600; + $graphdata[$ts] = stats_message_count($channel, 60, $basetime); + } + break; + case 'lastweek': + $graph_title = $channel . ' activity - last 14 days'; + $this_day = gmmktime(0, 0, 0); + $graphdata = array(); + + for ( $i = 13; $i >= 0; $i-- ) + { + $basetime = $this_day - ( $i * 86400 ); + $ts = date('D n/j', $basetime); + $basetime += 86400; + $graphdata[$ts] = stats_message_count($channel, 1440, $basetime); + } + $g->SetBarPadding(12); + break; + case 'lastmonth': + $graph_title = $channel . ' activity - last 30 days'; + $this_day = gmmktime(0, 0, 0); + $graphdata = array(); + + for ( $i = 29; $i >= 0; $i-- ) + { + $basetime = $this_day - ( $i * 86400 ); + $ts = date('Y-m-d', $basetime); + $basetime += 86400; + $graphdata[$ts] = stats_message_count($channel, 1440, $basetime); + } + $g->SetBarPadding(15); + break; +} + +$max = max($graphdata); + +// Determine axis interval +$interval = 2; +if ( $max > 20 ) + $interval = 4; +if ( $max > 25 ) + $interval = 5; +if ( $max > 50 ) + $interval = 10; +if ( $max > 200 ) + $interval = 40; +if ( $max > 500 ) + $interval = 80; +if ( $max > 1000 ) + $interval = 100; +if ( $max > 2000 ) + $interval = 200; +if ( $max > 3200 ) + $interval = 300; +if ( $max > 4000 ) + $interval = 500; +if ( $max > 5000 ) + $interval = 1000; +if ( $max > 15000 ) + $interval = 1500; +if ( $max > 30000 ) + $interval = round($max / 10); + +$g->SetBarData($graphdata); +$g->SetAxisStep($interval); +$g->SetGraphTitle($graph_title); + +$g->DrawGraph(); + diff -r a7d884914a74 -r c3cbefda414a htdocs/index.php --- a/htdocs/index.php Tue Dec 30 06:16:28 2008 -0500 +++ b/htdocs/index.php Tue Dec 30 06:16:54 2008 -0500 @@ -83,7 +83,9 @@ ?>