mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-16 18:56:15 +01:00
moved recent popular
This commit is contained in:
@@ -9,70 +9,12 @@ var categoriesController = {},
|
||||
privileges = require('../privileges'),
|
||||
user = require('../user'),
|
||||
categories = require('../categories'),
|
||||
topics = require('../topics'),
|
||||
meta = require('../meta'),
|
||||
plugins = require('../plugins'),
|
||||
pagination = require('../pagination'),
|
||||
helpers = require('./helpers'),
|
||||
utils = require('../../public/src/utils');
|
||||
|
||||
categoriesController.recent = function(req, res, next) {
|
||||
var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1;
|
||||
topics.getTopicsFromSet('topics:recent', req.uid, 0, stop, function(err, data) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
|
||||
data['feeds:disableRSS'] = parseInt(meta.config['feeds:disableRSS'], 10) === 1;
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/recent.rss';
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs([{text: '[[recent:title]]'}]);
|
||||
|
||||
plugins.fireHook('filter:recent.build', {req: req, res: res, templateData: data}, function(err, data) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
res.render('recent', data.templateData);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
var anonCache = {}, lastUpdateTime = 0;
|
||||
|
||||
categoriesController.popular = function(req, res, next) {
|
||||
var terms = {
|
||||
daily: 'day',
|
||||
weekly: 'week',
|
||||
monthly: 'month',
|
||||
alltime: 'alltime'
|
||||
};
|
||||
var term = terms[req.params.term] || 'day';
|
||||
|
||||
if (!req.uid) {
|
||||
if (anonCache[term] && (Date.now() - lastUpdateTime) < 60 * 60 * 1000) {
|
||||
return res.render('popular', anonCache[term]);
|
||||
}
|
||||
}
|
||||
|
||||
topics.getPopular(term, req.uid, meta.config.topicsPerList, function(err, topics) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
|
||||
var data = {
|
||||
topics: topics,
|
||||
'feeds:disableRSS': parseInt(meta.config['feeds:disableRSS'], 10) === 1,
|
||||
rssFeedUrl: nconf.get('relative_path') + '/popular/' + (req.params.term || 'daily') + '.rss',
|
||||
breadcrumbs: helpers.buildBreadcrumbs([{text: '[[global:header.popular]]'}])
|
||||
};
|
||||
|
||||
if (!req.uid) {
|
||||
anonCache[term] = data;
|
||||
lastUpdateTime = Date.now();
|
||||
}
|
||||
|
||||
res.render('popular', data);
|
||||
});
|
||||
};
|
||||
|
||||
categoriesController.list = function(req, res, next) {
|
||||
async.parallel({
|
||||
|
||||
@@ -19,6 +19,8 @@ var Controllers = {
|
||||
topics: require('./topics'),
|
||||
categories: require('./categories'),
|
||||
unread: require('./unread'),
|
||||
recent: require('./recent'),
|
||||
popular: require('./popular'),
|
||||
tags: require('./tags'),
|
||||
search: require('./search'),
|
||||
users: require('./users'),
|
||||
|
||||
51
src/controllers/popular.js
Normal file
51
src/controllers/popular.js
Normal file
@@ -0,0 +1,51 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var nconf = require('nconf'),
|
||||
topics = require('../topics'),
|
||||
meta = require('../meta'),
|
||||
helpers = require('./helpers');
|
||||
|
||||
var popularController = {};
|
||||
|
||||
var anonCache = {}, lastUpdateTime = 0;
|
||||
|
||||
var terms = {
|
||||
daily: 'day',
|
||||
weekly: 'week',
|
||||
monthly: 'month',
|
||||
alltime: 'alltime'
|
||||
};
|
||||
|
||||
popularController.get = function(req, res, next) {
|
||||
|
||||
var term = terms[req.params.term] || 'day';
|
||||
|
||||
if (!req.uid) {
|
||||
if (anonCache[term] && (Date.now() - lastUpdateTime) < 60 * 60 * 1000) {
|
||||
return res.render('popular', anonCache[term]);
|
||||
}
|
||||
}
|
||||
|
||||
topics.getPopular(term, req.uid, meta.config.topicsPerList, function(err, topics) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
|
||||
var data = {
|
||||
topics: topics,
|
||||
'feeds:disableRSS': parseInt(meta.config['feeds:disableRSS'], 10) === 1,
|
||||
rssFeedUrl: nconf.get('relative_path') + '/popular/' + (req.params.term || 'daily') + '.rss',
|
||||
breadcrumbs: helpers.buildBreadcrumbs([{text: '[[global:header.popular]]'}])
|
||||
};
|
||||
|
||||
if (!req.uid) {
|
||||
anonCache[term] = data;
|
||||
lastUpdateTime = Date.now();
|
||||
}
|
||||
|
||||
res.render('popular', data);
|
||||
});
|
||||
};
|
||||
|
||||
module.exports = popularController;
|
||||
34
src/controllers/recent.js
Normal file
34
src/controllers/recent.js
Normal file
@@ -0,0 +1,34 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var nconf = require('nconf'),
|
||||
topics = require('../topics'),
|
||||
meta = require('../meta'),
|
||||
helpers = require('./helpers'),
|
||||
plugins = require('../plugins');
|
||||
|
||||
var recentController = {};
|
||||
|
||||
recentController.get = function(req, res, next) {
|
||||
|
||||
var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1;
|
||||
|
||||
topics.getTopicsFromSet('topics:recent', req.uid, 0, stop, function(err, data) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
|
||||
data['feeds:disableRSS'] = parseInt(meta.config['feeds:disableRSS'], 10) === 1;
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/recent.rss';
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs([{text: '[[recent:title]]'}]);
|
||||
|
||||
plugins.fireHook('filter:recent.build', {req: req, res: res, templateData: data}, function(err, data) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
res.render('recent', data.templateData);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.exports = recentController;
|
||||
@@ -12,8 +12,7 @@ var async = require('async'),
|
||||
|
||||
var unreadController = {};
|
||||
|
||||
|
||||
unreadController.unread = function(req, res, next) {
|
||||
unreadController.get = function(req, res, next) {
|
||||
var stop = (parseInt(meta.config.topicsPerList, 10) || 20) - 1;
|
||||
var results;
|
||||
var cid = req.query.cid;
|
||||
|
||||
@@ -47,9 +47,9 @@ function tagRoutes(app, middleware, controllers) {
|
||||
|
||||
function categoryRoutes(app, middleware, controllers) {
|
||||
setupPageRoute(app, '/categories', middleware, [], controllers.categories.list);
|
||||
setupPageRoute(app, '/popular/:term?', middleware, [], controllers.categories.popular);
|
||||
setupPageRoute(app, '/recent', middleware, [], controllers.categories.recent);
|
||||
setupPageRoute(app, '/unread', middleware, [middleware.authenticate], controllers.unread.unread);
|
||||
setupPageRoute(app, '/popular/:term?', middleware, [], controllers.popular.get);
|
||||
setupPageRoute(app, '/recent', middleware, [], controllers.recent.get);
|
||||
setupPageRoute(app, '/unread', middleware, [middleware.authenticate], controllers.unread.get);
|
||||
|
||||
setupPageRoute(app, '/category/:category_id/:slug/:topic_index', middleware, [], controllers.categories.get);
|
||||
setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.categories.get);
|
||||
|
||||
Reference in New Issue
Block a user