2014-09-21 12:12:35 +02:00
|
|
|
<?php $this->partial('aside_stats'); ?>
|
|
|
|
|
2014-09-27 10:10:43 +02:00
|
|
|
<div class="post ">
|
2014-09-21 12:12:35 +02:00
|
|
|
<a href="<?php echo _url('index', 'index'); ?>"><?php echo _t('back_to_rss_feeds'); ?></a>
|
|
|
|
|
|
|
|
<h1><?php echo _t('stats_repartition'); ?></h1>
|
|
|
|
|
|
|
|
<select id="feed_select">
|
|
|
|
<option data-url="<?php echo _url('stats', 'repartition')?>"><?php echo _t('all_feeds')?></option>
|
|
|
|
<?php foreach ($this->categories as $category) {
|
|
|
|
$feeds = $category->feeds();
|
|
|
|
if (!empty($feeds)) {
|
2014-09-27 10:10:43 +02:00
|
|
|
echo '<optgroup label="', $category->name(), '">';
|
2014-09-21 12:12:35 +02:00
|
|
|
foreach ($feeds as $feed) {
|
|
|
|
if ($this->feed && $feed->id() == $this->feed->id()){
|
2014-09-27 10:10:43 +02:00
|
|
|
echo '<option value="', $feed->id(), '" selected="selected" data-url="', _url('stats', 'repartition', 'id', $feed->id()), '">', $feed->name(), '</option>';
|
2014-09-21 12:12:35 +02:00
|
|
|
} else {
|
2014-09-27 10:10:43 +02:00
|
|
|
echo '<option value="', $feed->id(), '" data-url="', _url('stats', 'repartition', 'id', $feed->id()), '">', $feed->name(), '</option>';
|
2014-09-21 12:12:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
echo '</optgroup>';
|
|
|
|
}
|
|
|
|
}?>
|
|
|
|
</select>
|
|
|
|
|
|
|
|
<?php if ($this->feed) {?>
|
2014-09-27 10:10:43 +02:00
|
|
|
<a class="btn" href="<?php echo _url('configure', 'feed', 'id', $this->feed->id()); ?>">
|
|
|
|
<?php echo _i('configure'); ?> <?php echo _t('administration'); ?>
|
2014-09-21 12:12:35 +02:00
|
|
|
</a>
|
|
|
|
<?php }?>
|
|
|
|
|
|
|
|
<div class="stat">
|
|
|
|
<h2><?php echo _t('stats_entry_per_hour'); ?></h2>
|
|
|
|
<div id="statsEntryPerHour" style="height: 300px"></div>
|
|
|
|
</div>
|
|
|
|
|
2014-09-27 10:10:43 +02:00
|
|
|
<div class="stat half">
|
2014-09-21 12:12:35 +02:00
|
|
|
<h2><?php echo _t('stats_entry_per_day_of_week'); ?></h2>
|
|
|
|
<div id="statsEntryPerDayOfWeek" style="height: 300px"></div>
|
2014-09-27 10:10:43 +02:00
|
|
|
</div><!--
|
2014-09-21 12:12:35 +02:00
|
|
|
|
2014-09-27 10:10:43 +02:00
|
|
|
--><div class="stat half">
|
2014-09-21 12:12:35 +02:00
|
|
|
<h2><?php echo _t('stats_entry_per_month'); ?></h2>
|
|
|
|
<div id="statsEntryPerMonth" style="height: 300px"></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
"use strict";
|
|
|
|
function initStats() {
|
|
|
|
if (!window.Flotr) {
|
|
|
|
if (window.console) {
|
|
|
|
console.log('FreshRSS waiting for Flotr…');
|
|
|
|
}
|
|
|
|
window.setTimeout(initStats, 50);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Entry per hour
|
2014-09-27 10:10:43 +02:00
|
|
|
var avg_h = [];
|
|
|
|
for (var i = -1; i <= 24; i++) {
|
|
|
|
avg_h.push([i, <?php echo $this->averageHour?>]);
|
|
|
|
}
|
2014-09-21 12:12:35 +02:00
|
|
|
Flotr.draw(document.getElementById('statsEntryPerHour'),
|
2014-09-27 10:10:43 +02:00
|
|
|
[{
|
|
|
|
data: <?php echo $this->repartitionHour ?>,
|
|
|
|
bars: {horizontal: false, show: true}
|
|
|
|
}, {
|
|
|
|
data: avg_h,
|
|
|
|
lines: {show: true},
|
|
|
|
label: <?php echo $this->averageHour?>,
|
|
|
|
yaxis: 2
|
|
|
|
}],
|
2014-09-21 12:12:35 +02:00
|
|
|
{
|
|
|
|
grid: {verticalLines: false},
|
|
|
|
xaxis: {noTicks: 23,
|
|
|
|
tickFormatter: function(x) {
|
|
|
|
var x = parseInt(x);
|
|
|
|
return x + 1;
|
|
|
|
},
|
|
|
|
min: -0.9,
|
|
|
|
max: 23.9,
|
|
|
|
tickDecimals: 0},
|
|
|
|
yaxis: {min: 0},
|
2014-09-27 10:10:43 +02:00
|
|
|
y2axis: {showLabels: false},
|
2014-09-21 12:12:35 +02:00
|
|
|
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
|
|
|
|
});
|
|
|
|
// Entry per day of week
|
2014-09-27 10:10:43 +02:00
|
|
|
var avg_dow = [];
|
|
|
|
for (var i = -1; i <= 7; i++) {
|
|
|
|
avg_dow.push([i, <?php echo $this->averageDayOfWeek?>]);
|
|
|
|
}
|
2014-09-21 12:12:35 +02:00
|
|
|
Flotr.draw(document.getElementById('statsEntryPerDayOfWeek'),
|
2014-09-27 10:10:43 +02:00
|
|
|
[{
|
|
|
|
data: <?php echo $this->repartitionDayOfWeek ?>,
|
|
|
|
bars: {horizontal: false, show: true}
|
|
|
|
}, {
|
|
|
|
data: avg_dow,
|
|
|
|
lines: {show: true},
|
|
|
|
label: <?php echo $this->averageDayOfWeek?>,
|
|
|
|
yaxis: 2
|
|
|
|
}],
|
2014-09-21 12:12:35 +02:00
|
|
|
{
|
|
|
|
grid: {verticalLines: false},
|
|
|
|
xaxis: {noTicks: 6,
|
|
|
|
tickFormatter: function(x) {
|
|
|
|
var x = parseInt(x),
|
|
|
|
days = <?php echo $this->days?>;
|
|
|
|
return days[x];
|
|
|
|
},
|
|
|
|
min: -0.9,
|
|
|
|
max: 6.9,
|
|
|
|
tickDecimals: 0},
|
|
|
|
yaxis: {min: 0},
|
2014-09-27 10:10:43 +02:00
|
|
|
y2axis: {showLabels: false},
|
2014-09-21 12:12:35 +02:00
|
|
|
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
|
|
|
|
});
|
|
|
|
// Entry per month
|
2014-09-27 10:10:43 +02:00
|
|
|
var avg_m = [];
|
|
|
|
for (var i = 0; i <= 13; i++) {
|
|
|
|
avg_m.push([i, <?php echo $this->averageMonth?>]);
|
|
|
|
}
|
2014-09-21 12:12:35 +02:00
|
|
|
Flotr.draw(document.getElementById('statsEntryPerMonth'),
|
2014-09-27 10:10:43 +02:00
|
|
|
[{
|
|
|
|
data: <?php echo $this->repartitionMonth ?>,
|
|
|
|
bars: {horizontal: false, show: true}
|
|
|
|
}, {
|
|
|
|
data: avg_m,
|
|
|
|
lines: {show: true},
|
|
|
|
label: <?php echo $this->averageMonth?>,
|
|
|
|
yaxis: 2
|
|
|
|
}],
|
2014-09-21 12:12:35 +02:00
|
|
|
{
|
|
|
|
grid: {verticalLines: false},
|
|
|
|
xaxis: {noTicks: 12,
|
|
|
|
tickFormatter: function(x) {
|
|
|
|
var x = parseInt(x),
|
|
|
|
months = <?php echo $this->months?>;
|
|
|
|
return months[(x - 1)];
|
|
|
|
},
|
|
|
|
min: 0.1,
|
|
|
|
max: 12.9,
|
|
|
|
tickDecimals: 0},
|
|
|
|
yaxis: {min: 0},
|
2014-09-27 10:10:43 +02:00
|
|
|
y2axis: {showLabels: false},
|
2014-09-21 12:12:35 +02:00
|
|
|
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
initStats();
|
|
|
|
</script>
|