mirror of
https://github.com/NodeBB/NodeBB.git
synced 2026-01-17 21:12:50 +01:00
62 lines
2.2 KiB
JavaScript
62 lines
2.2 KiB
JavaScript
'use strict';
|
|
|
|
const _ = require('lodash');
|
|
|
|
const db = require('../../database');
|
|
const groups = require('../../groups');
|
|
const categories = require('../../categories');
|
|
const user = require('../../user');
|
|
const meta = require('../../meta');
|
|
const pagination = require('../../pagination');
|
|
const categoriesController = require('./categories');
|
|
|
|
const AdminsMods = module.exports;
|
|
|
|
AdminsMods.get = async function (req, res) {
|
|
const rootCid = parseInt(req.query.cid, 10) || 0;
|
|
|
|
const cidsCount = await db.sortedSetCard(`cid:${rootCid}:children`);
|
|
|
|
const pageCount = Math.max(1, Math.ceil(cidsCount / meta.config.categoriesPerPage));
|
|
const page = Math.min(parseInt(req.query.page, 10) || 1, pageCount);
|
|
const start = Math.max(0, (page - 1) * meta.config.categoriesPerPage);
|
|
const stop = start + meta.config.categoriesPerPage - 1;
|
|
|
|
const cids = await db.getSortedSetRange(`cid:${rootCid}:children`, start, stop);
|
|
|
|
const selectedCategory = rootCid ? await categories.getCategoryData(rootCid) : null;
|
|
const pageCategories = await categories.getCategoriesData(cids);
|
|
|
|
const [admins, globalMods, moderators, crumbs] = await Promise.all([
|
|
groups.get('administrators', { uid: req.uid }),
|
|
groups.get('Global Moderators', { uid: req.uid }),
|
|
getModeratorsOfCategories(pageCategories),
|
|
categoriesController.buildBreadCrumbs(selectedCategory, '/admin/manage/admins-mods'),
|
|
]);
|
|
|
|
res.render('admin/manage/admins-mods', {
|
|
admins: admins,
|
|
globalMods: globalMods,
|
|
categoryMods: moderators,
|
|
selectedCategory: selectedCategory,
|
|
pagination: pagination.create(page, pageCount, req.query),
|
|
breadcrumbs: crumbs,
|
|
});
|
|
};
|
|
|
|
async function getModeratorsOfCategories(categoryData) {
|
|
const [moderatorUids, childrenCounts] = await Promise.all([
|
|
categories.getModeratorUids(categoryData.map(c => c.cid)),
|
|
db.sortedSetsCard(categoryData.map(c => `cid:${c.cid}:children`)),
|
|
]);
|
|
|
|
const uids = _.uniq(_.flatten(moderatorUids));
|
|
const moderatorData = await user.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture']);
|
|
const moderatorMap = _.zipObject(uids, moderatorData);
|
|
categoryData.forEach((c, index) => {
|
|
c.moderators = moderatorUids[index].map(uid => moderatorMap[uid]);
|
|
c.subCategoryCount = childrenCounts[index];
|
|
});
|
|
return categoryData;
|
|
}
|