diff --git a/public/assets/js/admin-stats.js b/public/assets/js/admin-stats.js
index 82421af..91d383e 100644
--- a/public/assets/js/admin-stats.js
+++ b/public/assets/js/admin-stats.js
@@ -50,6 +50,47 @@
+ '';
}
+ function trendChart(totals) {
+ var trendEl = document.getElementById('stats-trend-container');
+ if (!trendEl || !totals.length) { return; }
+
+ var days = totals.length;
+ var maxV = Math.max.apply(null, totals) || 1;
+ var W = 1000; // viewBox, s'adapte en CSS
+ var H = 80;
+ var padX = 4;
+ var padY = 8;
+ var barW = Math.floor((W - 2 * padX) / days) - 2;
+
+ // Dates des jours (index 0 = il y a 13 jours)
+ var now = new Date();
+ var labels = totals.map(function (_, i) {
+ var d = new Date(now);
+ d.setDate(d.getDate() - (days - 1 - i));
+ return d.toLocaleDateString('fr-FR', { day: 'numeric', month: 'short' });
+ });
+
+ var bars = totals.map(function (v, i) {
+ var x = padX + i * (W - 2 * padX) / days + 1;
+ var bh = Math.max(2, (v / maxV) * (H - padY - 16));
+ var y = H - padY - bh;
+ var lx = x + barW / 2;
+ var label = labels[i];
+ var showLabel = (i === 0 || i === days - 1 || i === Math.floor(days / 2));
+ return '
Trafic total — 14 derniers jours
' + + ''; + } + fetch('/trending?period=14d') .then(function (r) { return r.ok ? r.text() : Promise.reject(); }) .then(function (xml) { @@ -70,7 +111,15 @@ var daily = pm ? (pagesByDay[pm[0]] || null) : null; return { title: title, link: link, slug: slug, vis: vis, daily: daily }; }); - var maxV = Math.max.apply(null, rows.map(function (r) { return r.vis; })) || 1; + + // Graphique global : somme de tous les articles par jour + var nDays = 14; + var totals = new Array(nDays).fill(0); + Object.values(pagesByDay).forEach(function (arr) { + arr.forEach(function (v, i) { if (i < nDays) { totals[i] += v; } }); + }); + trendChart(totals); + var html = '