Merge pull request #4504 from BenLubar/unread-topics

Add /unread/new, which is the same as /unread but does not show topics that were already partially read by the user.
v1.18.x
Barış Soner Uşaklı 9 years ago
commit 35ac64db7f

@ -13,6 +13,12 @@ define('forum/footer', ['notifications', 'chat', 'components', 'translator'], fu
.attr('data-content', count > 99 ? '99+' : count); .attr('data-content', count > 99 ? '99+' : count);
} }
function updateUnreadNewTopicCount(count) {
$('#unread-new-count i')
.toggleClass('unread-count', count > 0)
.attr('data-content', count > 99 ? '99+' : count);
}
function updateUnreadChatCount(count) { function updateUnreadChatCount(count) {
components.get('chat/icon') components.get('chat/icon')
.toggleClass('unread-count', count > 0) .toggleClass('unread-count', count > 0)
@ -61,6 +67,7 @@ define('forum/footer', ['notifications', 'chat', 'components', 'translator'], fu
} }
updateUnreadTopicCount(data.unreadTopicCount); updateUnreadTopicCount(data.unreadTopicCount);
updateUnreadNewTopicCount(data.unreadNewTopicCount);
updateUnreadChatCount(data.unreadChatCount); updateUnreadChatCount(data.unreadChatCount);
Notifications.updateNotifCount(data.unreadNotificationCount); Notifications.updateNotifCount(data.unreadNotificationCount);
}); });

@ -12,10 +12,17 @@ var plugins = require('../plugins');
var unreadController = {}; var unreadController = {};
var validFilter = {'': true, 'new': true};
unreadController.get = function(req, res, next) { unreadController.get = function(req, res, next) {
var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1; var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1;
var results; var results;
var cid = req.query.cid; var cid = req.query.cid;
var filter = req.params.filter || '';
if (!validFilter[filter]) {
return next();
}
async.waterfall([ async.waterfall([
function(next) { function(next) {
@ -24,7 +31,7 @@ unreadController.get = function(req, res, next) {
user.getWatchedCategories(req.uid, next); user.getWatchedCategories(req.uid, next);
}, },
unreadTopics: function(next) { unreadTopics: function(next) {
topics.getUnreadTopics(cid, req.uid, 0, stop, next); topics.getUnreadTopics(cid, req.uid, 0, stop, filter, next);
} }
}, next); }, next);
}, },
@ -64,7 +71,13 @@ unreadController.get = function(req, res, next) {
unreadController.unreadTotal = function(req, res, next) { unreadController.unreadTotal = function(req, res, next) {
topics.getTotalUnread(req.uid, function (err, data) { var filter = req.params.filter || '';
if (!validFilter[filter]) {
return next();
}
topics.getTotalUnread(req.uid, filter, function (err, data) {
if (err) { if (err) {
return next(err); return next(err);
} }

@ -22,7 +22,7 @@ module.exports = function(app, middleware, controllers) {
router.get('/categories/:cid/moderators', controllers.api.getModerators); router.get('/categories/:cid/moderators', controllers.api.getModerators);
router.get('/recent/posts/:term?', controllers.api.getRecentPosts); router.get('/recent/posts/:term?', controllers.api.getRecentPosts);
router.get('/unread/total', middleware.authenticate, controllers.unread.unreadTotal); router.get('/unread/:filter?/total', middleware.authenticate, controllers.unread.unreadTotal);
router.get('/topic/teaser/:topic_id', controllers.topics.teaser); router.get('/topic/teaser/:topic_id', controllers.topics.teaser);
var multipart = require('connect-multiparty'); var multipart = require('connect-multiparty');

@ -55,7 +55,7 @@ function categoryRoutes(app, middleware, controllers) {
setupPageRoute(app, '/categories', middleware, [], controllers.categories.list); setupPageRoute(app, '/categories', middleware, [], controllers.categories.list);
setupPageRoute(app, '/popular/:term?', middleware, [], controllers.popular.get); setupPageRoute(app, '/popular/:term?', middleware, [], controllers.popular.get);
setupPageRoute(app, '/recent', middleware, [], controllers.recent.get); setupPageRoute(app, '/recent', middleware, [], controllers.recent.get);
setupPageRoute(app, '/unread', middleware, [middleware.authenticate], controllers.unread.get); setupPageRoute(app, '/unread/:filter?', middleware, [middleware.authenticate], controllers.unread.get);
setupPageRoute(app, '/category/:category_id/:slug/:topic_index', middleware, [], controllers.category.get); setupPageRoute(app, '/category/:category_id/:slug/:topic_index', middleware, [], controllers.category.get);
setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.category.get); setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.category.get);

@ -245,6 +245,7 @@ SocketUser.getUnreadCounts = function(socket, data, callback) {
} }
async.parallel({ async.parallel({
unreadTopicCount: async.apply(topics.getTotalUnread, socket.uid), unreadTopicCount: async.apply(topics.getTotalUnread, socket.uid),
unreadNewTopicCount: async.apply(topics.getTotalUnread, socket.uid, 'new'),
unreadChatCount: async.apply(messaging.getUnreadCount, socket.uid), unreadChatCount: async.apply(messaging.getUnreadCount, socket.uid),
unreadNotificationCount: async.apply(user.notifications.getUnreadCount, socket.uid) unreadNotificationCount: async.apply(user.notifications.getUnreadCount, socket.uid)
}, callback); }, callback);

@ -14,13 +14,23 @@ var utils = require('../../public/src/utils');
module.exports = function(Topics) { module.exports = function(Topics) {
Topics.getTotalUnread = function(uid, callback) { Topics.getTotalUnread = function(uid, filter, callback) {
Topics.getUnreadTids(0, uid, 0, 99, function(err, tids) { if (!callback) {
callback = filter;
filter = '';
}
Topics.getUnreadTids(0, uid, 0, 99, filter, function(err, tids) {
callback(err, tids ? tids.length : 0); callback(err, tids ? tids.length : 0);
}); });
}; };
Topics.getUnreadTopics = function(cid, uid, start, stop, callback) { Topics.getUnreadTopics = function(cid, uid, start, stop, filter, callback) {
if (!callback) {
callback = filter;
filter = '';
}
var unreadTopics = { var unreadTopics = {
showSelect: true, showSelect: true,
@ -30,7 +40,7 @@ module.exports = function(Topics) {
async.waterfall([ async.waterfall([
function(next) { function(next) {
Topics.getUnreadTids(cid, uid, start, stop, next); Topics.getUnreadTids(cid, uid, start, stop, filter, next);
}, },
function(tids, next) { function(tids, next) {
if (!tids.length) { if (!tids.length) {
@ -54,7 +64,12 @@ module.exports = function(Topics) {
return Date.now() - (parseInt(meta.config.unreadCutoff, 10) || 2) * 86400000; return Date.now() - (parseInt(meta.config.unreadCutoff, 10) || 2) * 86400000;
}; };
Topics.getUnreadTids = function(cid, uid, start, stop, callback) { Topics.getUnreadTids = function(cid, uid, start, stop, filter, callback) {
if (!callback) {
callback = filter;
filter = '';
}
uid = parseInt(uid, 10); uid = parseInt(uid, 10);
if (uid === 0) { if (uid === 0) {
return callback(null, []); return callback(null, []);
@ -95,7 +110,12 @@ module.exports = function(Topics) {
}); });
var tids = results.recentTids.filter(function(recentTopic) { var tids = results.recentTids.filter(function(recentTopic) {
return !userRead[recentTopic.value] || recentTopic.score > userRead[recentTopic.value]; switch (filter) {
default:
return !userRead[recentTopic.value] || recentTopic.score > userRead[recentTopic.value];
case 'new':
return !userRead[recentTopic.value];
}
}).map(function(topic) { }).map(function(topic) {
return topic.value; return topic.value;
}).filter(function(tid, index, array) { }).filter(function(tid, index, array) {

Loading…
Cancel
Save