mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-17 03:01:08 +01:00
moved recent popular
This commit is contained in:
@@ -9,70 +9,12 @@ var categoriesController = {},
|
|||||||
privileges = require('../privileges'),
|
privileges = require('../privileges'),
|
||||||
user = require('../user'),
|
user = require('../user'),
|
||||||
categories = require('../categories'),
|
categories = require('../categories'),
|
||||||
topics = require('../topics'),
|
|
||||||
meta = require('../meta'),
|
meta = require('../meta'),
|
||||||
plugins = require('../plugins'),
|
plugins = require('../plugins'),
|
||||||
pagination = require('../pagination'),
|
pagination = require('../pagination'),
|
||||||
helpers = require('./helpers'),
|
helpers = require('./helpers'),
|
||||||
utils = require('../../public/src/utils');
|
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) {
|
categoriesController.list = function(req, res, next) {
|
||||||
async.parallel({
|
async.parallel({
|
||||||
|
|||||||
@@ -19,6 +19,8 @@ var Controllers = {
|
|||||||
topics: require('./topics'),
|
topics: require('./topics'),
|
||||||
categories: require('./categories'),
|
categories: require('./categories'),
|
||||||
unread: require('./unread'),
|
unread: require('./unread'),
|
||||||
|
recent: require('./recent'),
|
||||||
|
popular: require('./popular'),
|
||||||
tags: require('./tags'),
|
tags: require('./tags'),
|
||||||
search: require('./search'),
|
search: require('./search'),
|
||||||
users: require('./users'),
|
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 = {};
|
var unreadController = {};
|
||||||
|
|
||||||
|
unreadController.get = function(req, res, next) {
|
||||||
unreadController.unread = 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;
|
||||||
|
|||||||
@@ -47,9 +47,9 @@ function tagRoutes(app, middleware, controllers) {
|
|||||||
|
|
||||||
function categoryRoutes(app, middleware, controllers) {
|
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.categories.popular);
|
setupPageRoute(app, '/popular/:term?', middleware, [], controllers.popular.get);
|
||||||
setupPageRoute(app, '/recent', middleware, [], controllers.categories.recent);
|
setupPageRoute(app, '/recent', middleware, [], controllers.recent.get);
|
||||||
setupPageRoute(app, '/unread', middleware, [middleware.authenticate], controllers.unread.unread);
|
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/:topic_index', middleware, [], controllers.categories.get);
|
||||||
setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.categories.get);
|
setupPageRoute(app, '/category/:category_id/:slug?', middleware, [], controllers.categories.get);
|
||||||
|
|||||||
Reference in New Issue
Block a user