v1.18.x
Barış Soner Uşaklı 10 years ago
parent 1bf6c1fd46
commit 4af8a5ec02

@ -5,6 +5,7 @@ var tagsController = {},
nconf = require('nconf'), nconf = require('nconf'),
validator = require('validator'), validator = require('validator'),
meta = require('../meta'), meta = require('../meta'),
user = require('../user'),
topics = require('../topics'), topics = require('../topics'),
helpers = require('./helpers'); helpers = require('./helpers');
@ -12,21 +13,36 @@ tagsController.getTag = function(req, res, next) {
var tag = validator.escape(req.params.tag); var tag = validator.escape(req.params.tag);
var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1; var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1;
topics.getTagTids(tag, 0, stop, function(err, tids) { async.waterfall([
if (err) { function(next) {
return next(err); topics.getTagTids(tag, 0, stop, next);
} },
function(tids, next) {
if (Array.isArray(tids) && !tids.length) { if (Array.isArray(tids) && !tids.length) {
topics.deleteTag(tag); topics.deleteTag(tag);
return res.render('tag', {topics: [], tag: tag}); return res.render('tag', {
topics: [],
tag: tag,
breadcrumbs: helpers.buildBreadcrumbs([{text: '[[tags:tags]]', url: '/tags'}, {text: tag}])
});
} }
topics.getTopics(tids, req.uid, function(err, topics) { async.parallel({
isAdmin: async.apply(user.isAdministrator, req.uid),
topics: async.apply(topics.getTopics, tids, req.uid)
}, next);
}
], function(err, results) {
if (err) { if (err) {
return next(err); return next(err);
} }
if (!results.isAdmin) {
results.topics = results.topics.filter(function(topic) {
return topic && !topic.deleted;
});
}
res.locals.metaTags = [ res.locals.metaTags = [
{ {
name: 'title', name: 'title',
@ -41,15 +57,15 @@ tagsController.getTag = function(req, res, next) {
content: nconf.get('url') + '/tags/' + tag content: nconf.get('url') + '/tags/' + tag
} }
]; ];
var data = { var data = {
topics: topics, topics: results.topics,
tag: tag, tag: tag,
nextStart: stop + 1, nextStart: stop + 1,
breadcrumbs: helpers.buildBreadcrumbs([{text: '[[tags:tags]]', url: '/tags'}, {text: tag}]) breadcrumbs: helpers.buildBreadcrumbs([{text: '[[tags:tags]]', url: '/tags'}, {text: tag}])
}; };
res.render('tag', data); res.render('tag', data);
}); });
});
}; };
tagsController.getTags = function(req, res, next) { tagsController.getTags = function(req, res, next) {

Loading…
Cancel
Save