handle pinned topics

v1.18.x
barisusakli 11 years ago
parent 5292bdad5a
commit 2bf38ec84b

@ -24,21 +24,47 @@ module.exports = function(Categories) {
}; };
Categories.getRecentTopicReplies = function(cid, uid, count, callback) { Categories.getRecentTopicReplies = function(cid, uid, count, callback) {
if (!parseInt(count, 10)) { count = parseInt(count, 10);
if (!count) {
return callback(null, []); return callback(null, []);
} }
db.getSortedSetRevRange('categories:' + cid + ':tid', 0, count - 1, function(err, tids) { db.getSortedSetRevRange('categories:recent_posts:cid:' + cid, 0, 0, function(err, pids) {
if (err || !tids || !tids.length) { if (err || !pids || !pids.length) {
return callback(err, []); return callback(err, []);
} }
async.map(tids, topics.getLatestUndeletedPid, function(err, pids) { if (count === 1) {
pids = pids.filter(function(pid) { return posts.getPostSummaryByPids(pids, {stripTags: true}, callback);
return !!pid; }
});
posts.getPostSummaryByPids(pids, {stripTags: true}, callback); async.parallel({
pinnedTids: function(next) {
db.getSortedSetRevRangeByScore('categories:' + cid + ':tid', 0, -1, Infinity, Date.now(), next);
},
tids: function(next) {
db.getSortedSetRevRangeByScore('categories:' + cid + ':tid', 0, Math.max(0, count - 1), Date.now(), 0, next);
}
}, function(err, results) {
if (err) {
return callback(err);
}
results.tids = results.tids.concat(results.pinnedTids);
async.map(results.tids, topics.getLatestUndeletedPid, function(err, topicPids) {
pids = pids.concat(topicPids).filter(function(pid, index, array) {
return !!pid && array.indexOf(pid) === index;
});
posts.getPostSummaryByPids(pids, {stripTags: true}, function(err, posts) {
posts = posts.sort(function(a, b) {
return parseInt(b.timestamp, 10) - parseInt(a.timestamp, 10);
}).slice(0, count);
callback(err, posts);
});
});
}); });
}); });
}; };

@ -134,16 +134,25 @@ module.exports = function(Topics) {
}; };
Topics.getLatestUndeletedPid = function(tid, callback) { Topics.getLatestUndeletedPid = function(tid, callback) {
db.getSortedSetRevRange('tid:' + tid + ':posts', 0, -1, function(err, pids) { async.parallel({
mainPid: function(next) {
Topics.getTopicField(tid, 'mainPid', next);
},
pids: function(next) {
db.getSortedSetRevRange('tid:' + tid + ':posts', 0, -1, next);
}
}, function(err, results) {
if(err) { if(err) {
return callback(err); return callback(err);
} }
if (!pids || !pids.length) { if (!results.mainPid && (!Array.isArray(results.pids) || !results.pids.length)) {
return callback(null, null); return callback(null, null);
} }
async.detectSeries(pids, function(pid, next) { results.pids.push(results.mainPid);
async.detectSeries(results.pids, function(pid, next) {
posts.getPostField(pid, 'deleted', function(err, deleted) { posts.getPostField(pid, 'deleted', function(err, deleted) {
next(parseInt(deleted, 10) === 0); next(parseInt(deleted, 10) === 0);
}); });

Loading…
Cancel
Save