feat: req.query parsing and dynamically loading data instead

v1.18.x
Julian Lam 4 years ago
parent f561799f74
commit 6fdcae7320

@ -29,7 +29,7 @@ define('admin/modules/dashboard-line-graph', ['Chart', 'translator', 'benchpress
pointHoverBackgroundColor: 'rgba(151,187,205,1)', pointHoverBackgroundColor: 'rgba(151,187,205,1)',
pointBorderColor: '#fff', pointBorderColor: '#fff',
pointHoverBorderColor: 'rgba(151,187,205,1)', pointHoverBorderColor: 'rgba(151,187,205,1)',
data: dataset, data: dataset || [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
}, },
], ],
}; };
@ -66,6 +66,10 @@ define('admin/modules/dashboard-line-graph', ['Chart', 'translator', 'benchpress
}, },
}, },
}); });
if (!dataset) {
Graph.update(set);
}
}); });
$('[data-action="updateGraph"]:not([data-units="custom"])').on('click', function () { $('[data-action="updateGraph"]:not([data-units="custom"])').on('click', function () {
@ -146,7 +150,12 @@ define('admin/modules/dashboard-line-graph', ['Chart', 'translator', 'benchpress
}); });
}; };
Graph.update = (set, units, until, amount) => { Graph.update = (
set,
units = ajaxify.data.query.units || 'hours',
until = ajaxify.data.query.until,
amount = ajaxify.data.query.amount
) => {
if (!Graph._current) { if (!Graph._current) {
return; return;
} }
@ -162,7 +171,7 @@ define('admin/modules/dashboard-line-graph', ['Chart', 'translator', 'benchpress
Graph._current.data.labels = Graph._current.data.xLabels; Graph._current.data.labels = Graph._current.data.xLabels;
Graph._current.update(); Graph._current.update();
// Update the View as JSON button url // Update address bar and "View as JSON" button url
var apiEl = $('#view-as-json'); var apiEl = $('#view-as-json');
var newHref = $.param({ var newHref = $.param({
units: units || 'hours', units: units || 'hours',
@ -170,6 +179,7 @@ define('admin/modules/dashboard-line-graph', ['Chart', 'translator', 'benchpress
count: amount, count: amount,
}); });
apiEl.attr('href', `${config.relative_path}/api/v3/admin/analytics/${ajaxify.data.set}?${newHref}`); apiEl.attr('href', `${config.relative_path}/api/v3/admin/analytics/${ajaxify.data.set}?${newHref}`);
ajaxify.updateHistory(`${ajaxify.data.url.slice(1)}?${newHref}`, true);
}); });
}; };

@ -231,7 +231,6 @@ async function getLastRestart() {
dashboardController.getLogins = async (req, res) => { dashboardController.getLogins = async (req, res) => {
let stats = await getStats(); let stats = await getStats();
const dataset = await analytics.getHourlyStatsForSet('analytics:logins', Date.now(), 24);
stats = stats.filter(stat => stat.name === '[[admin/dashboard:logins]]').map(({ ...stat }) => { stats = stats.filter(stat => stat.name === '[[admin/dashboard:logins]]').map(({ ...stat }) => {
delete stat.href; delete stat.href;
return stat; return stat;
@ -244,15 +243,14 @@ dashboardController.getLogins = async (req, res) => {
res.render('admin/dashboard/logins', { res.render('admin/dashboard/logins', {
set: 'logins', set: 'logins',
query: req.query,
stats, stats,
dataset,
summary, summary,
}); });
}; };
dashboardController.getUsers = async (req, res) => { dashboardController.getUsers = async (req, res) => {
let stats = await getStats(); let stats = await getStats();
const dataset = await analytics.getHourlyStatsForSet('analytics:registrations', Date.now(), 24);
stats = stats.filter(stat => stat.name === '[[admin/dashboard:new-users]]').map(({ ...stat }) => { stats = stats.filter(stat => stat.name === '[[admin/dashboard:new-users]]').map(({ ...stat }) => {
delete stat.href; delete stat.href;
return stat; return stat;
@ -263,17 +261,18 @@ dashboardController.getUsers = async (req, res) => {
month: stats[0].thismonth, month: stats[0].thismonth,
}; };
// List of recently registered users
res.render('admin/dashboard/users', { res.render('admin/dashboard/users', {
set: 'registrations', set: 'registrations',
query: req.query,
stats, stats,
dataset,
summary, summary,
}); });
}; };
dashboardController.getTopics = async (req, res) => { dashboardController.getTopics = async (req, res) => {
let stats = await getStats(); let stats = await getStats();
const dataset = await analytics.getHourlyStatsForSet('analytics:topics', Date.now(), 24);
stats = stats.filter(stat => stat.name === '[[admin/dashboard:topics]]').map(({ ...stat }) => { stats = stats.filter(stat => stat.name === '[[admin/dashboard:topics]]').map(({ ...stat }) => {
delete stat.href; delete stat.href;
return stat; return stat;
@ -286,8 +285,8 @@ dashboardController.getTopics = async (req, res) => {
res.render('admin/dashboard/topics', { res.render('admin/dashboard/topics', {
set: 'topics', set: 'topics',
query: req.query,
stats, stats,
dataset,
summary, summary,
}); });
}; };

Loading…
Cancel
Save