1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/freshrss_ynh.git synced 2024-09-03 18:36:33 +02:00
freshrss_ynh/sources/app/views/stats/repartition.phtml

138 lines
4.2 KiB
PHTML
Raw Normal View History

2014-09-21 12:12:35 +02:00
<?php $this->partial('aside_stats'); ?>
2014-09-27 10:10:43 +02:00
<div class="post ">
2015-02-08 18:55:48 +01:00
<a href="<?php echo _url('index', 'index'); ?>"><?php echo _t('gen.action.back_to_rss_feeds'); ?></a>
2014-09-21 12:12:35 +02:00
2015-02-08 18:55:48 +01:00
<h1><?php echo _t('admin.stats.repartition'); ?></h1>
2014-09-21 12:12:35 +02:00
2015-02-08 18:55:48 +01:00
<select id="feed_select" class="select-change">
<option data-url="<?php echo _url('stats', 'repartition')?>"><?php echo _t('admin.stats.all_feeds')?></option>
2014-09-21 12:12:35 +02:00
<?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) {?>
2015-02-08 18:55:48 +01:00
<a class="btn" href="<?php echo _url('subscription', 'index', 'id', $this->feed->id()); ?>">
<?php echo _i('configure'); ?> <?php echo _t('gen.action.manage'); ?>
2014-09-21 12:12:35 +02:00
</a>
<?php }?>
<div class="stat">
2015-02-08 18:55:48 +01:00
<table>
<tr>
<th><?php echo _t('admin.stats.status_total'); ?></th>
<th><?php echo _t('admin.stats.status_read'); ?></th>
<th><?php echo _t('admin.stats.status_unread'); ?></th>
<th><?php echo _t('admin.stats.status_favorites'); ?></th>
</tr>
<tr>
<td class="numeric"><?php echo $this->repartition['total']; ?></td>
<td class="numeric"><?php echo $this->repartition['read']; ?></td>
<td class="numeric"><?php echo $this->repartition['unread']; ?></td>
<td class="numeric"><?php echo $this->repartition['favorite']; ?></td>
</tr>
</table>
</div>
<div class="stat">
<h2><?php echo _t('admin.stats.entry_per_hour', $this->averageHour); ?></h2>
2014-09-21 12:12:35 +02:00
<div id="statsEntryPerHour" style="height: 300px"></div>
</div>
2014-09-27 10:10:43 +02:00
<div class="stat half">
2015-02-08 18:55:48 +01:00
<h2><?php echo _t('admin.stats.entry_per_day_of_week', $this->averageDayOfWeek); ?></h2>
2014-09-21 12:12:35 +02:00
<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">
2015-02-08 18:55:48 +01:00
<h2><?php echo _t('admin.stats.entry_per_month', $this->averageMonth); ?></h2>
2014-09-21 12:12:35 +02:00
<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
Flotr.draw(document.getElementById('statsEntryPerHour'),
2014-09-27 10:10:43 +02:00
[{
data: <?php echo $this->repartitionHour ?>,
bars: {horizontal: false, show: true}
}],
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},
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
});
// Entry per day of week
Flotr.draw(document.getElementById('statsEntryPerDayOfWeek'),
2014-09-27 10:10:43 +02:00
[{
data: <?php echo $this->repartitionDayOfWeek ?>,
bars: {horizontal: false, show: true}
}],
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},
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
});
// Entry per month
Flotr.draw(document.getElementById('statsEntryPerMonth'),
2014-09-27 10:10:43 +02:00
[{
data: <?php echo $this->repartitionMonth ?>,
bars: {horizontal: false, show: true}
}],
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},
mouse: {relative: true, track: true, trackDecimals: 0, trackFormatter: function(obj) {return numberFormat(obj.y);}}
});
}
initStats();
</script>