mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
feat: req.query parsing and dynamically loading data instead
This commit is contained in:
@@ -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,
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user