mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 11:35:55 +01:00
closes #3762
This commit is contained in:
@@ -20,6 +20,7 @@ categoryController.get = function(req, res, callback) {
|
||||
var currentPage = parseInt(req.query.page, 10) || 1;
|
||||
var pageCount = 1;
|
||||
var userPrivileges;
|
||||
var settings;
|
||||
|
||||
if ((req.params.topic_index && !utils.isNumber(req.params.topic_index)) || !utils.isNumber(cid)) {
|
||||
return callback();
|
||||
@@ -54,7 +55,7 @@ categoryController.get = function(req, res, callback) {
|
||||
return helpers.redirect(res, '/category/' + results.categoryData.slug);
|
||||
}
|
||||
|
||||
var settings = results.userSettings;
|
||||
settings = results.userSettings;
|
||||
var topicIndex = utils.isNumber(req.params.topic_index) ? parseInt(req.params.topic_index, 10) - 1 : 0;
|
||||
var topicCount = parseInt(results.categoryData.topic_count, 10);
|
||||
pageCount = Math.max(1, Math.ceil(topicCount / settings.topicsPerPage));
|
||||
@@ -89,7 +90,7 @@ categoryController.get = function(req, res, callback) {
|
||||
var start = (currentPage - 1) * settings.topicsPerPage + topicIndex;
|
||||
var stop = start + settings.topicsPerPage - 1;
|
||||
|
||||
next(null, {
|
||||
var payload = {
|
||||
cid: cid,
|
||||
set: set,
|
||||
reverse: reverse,
|
||||
@@ -97,19 +98,24 @@ categoryController.get = function(req, res, callback) {
|
||||
stop: stop,
|
||||
uid: req.uid,
|
||||
settings: settings
|
||||
});
|
||||
},
|
||||
function (payload, next) {
|
||||
user.getUidByUserslug(req.query.author, function(err, uid) {
|
||||
payload.targetUid = uid;
|
||||
if (uid) {
|
||||
payload.set = 'cid:' + cid + ':uid:' + uid + ':tids';
|
||||
};
|
||||
|
||||
async.waterfall([
|
||||
function(next) {
|
||||
user.getUidByUserslug(req.query.author, next);
|
||||
},
|
||||
function(uid, next) {
|
||||
payload.targetUid = uid;
|
||||
if (uid) {
|
||||
payload.set = 'cid:' + cid + ':uid:' + uid + ':tids';
|
||||
}
|
||||
|
||||
if (req.query.tag) {
|
||||
payload.set = [payload.set, 'tag:' + req.query.tag + ':topics'];
|
||||
}
|
||||
categories.getCategoryById(payload, next);
|
||||
}
|
||||
next(err, payload);
|
||||
});
|
||||
},
|
||||
function (payload, next) {
|
||||
categories.getCategoryById(payload, next);
|
||||
], next);
|
||||
},
|
||||
function (categoryData, next) {
|
||||
|
||||
@@ -190,9 +196,14 @@ categoryController.get = function(req, res, callback) {
|
||||
}
|
||||
];
|
||||
|
||||
if (parseInt(req.uid, 10)) {
|
||||
categories.markAsRead([cid], req.uid);
|
||||
}
|
||||
|
||||
categoryData['feeds:disableRSS'] = parseInt(meta.config['feeds:disableRSS'], 10) === 1;
|
||||
categoryData.rssFeedUrl = nconf.get('relative_path') + '/category/' + categoryData.cid + '.rss';
|
||||
categoryData.title = categoryData.name;
|
||||
pageCount = Math.max(1, Math.ceil(categoryData.topic_count / settings.topicsPerPage));
|
||||
categoryData.pagination = pagination.create(currentPage, pageCount, req.query);
|
||||
categoryData.pagination.rel.forEach(function(rel) {
|
||||
rel.href = nconf.get('url') + '/category/' + categoryData.slug + rel.href;
|
||||
|
||||
Reference in New Issue
Block a user