mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-27 17:16:14 +01:00
closes #4587
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
'use strict';
|
||||
|
||||
var nconf = require('nconf');
|
||||
|
||||
var plugins = require('../plugins');
|
||||
var translator = require('../../public/src/modules/translator');
|
||||
|
||||
module.exports = function(middleware) {
|
||||
@@ -9,78 +11,86 @@ module.exports = function(middleware) {
|
||||
// res.render post-processing, modified from here: https://gist.github.com/mrlannigan/5051687
|
||||
var render = res.render;
|
||||
res.render = function(template, options, fn) {
|
||||
var self = this,
|
||||
req = this.req,
|
||||
defaultFn = function(err, str){
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
var self = this;
|
||||
var req = this.req;
|
||||
var defaultFn = function(err, str) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
|
||||
self.send(str);
|
||||
};
|
||||
|
||||
self.send(str);
|
||||
};
|
||||
options = options || {};
|
||||
|
||||
if ('function' === typeof options) {
|
||||
fn = options;
|
||||
options = {};
|
||||
}
|
||||
|
||||
options.loggedIn = !!req.uid;
|
||||
options.relative_path = nconf.get('relative_path');
|
||||
options.template = {name: template};
|
||||
options.template[template] = true;
|
||||
options.bodyClass = buildBodyClass(req);
|
||||
|
||||
res.locals.template = template;
|
||||
options._locals = undefined;
|
||||
|
||||
if (res.locals.isAPI) {
|
||||
if (req.route && req.route.path === '/api/') {
|
||||
options.title = '[[pages:home]]';
|
||||
}
|
||||
|
||||
return res.json(options);
|
||||
}
|
||||
|
||||
if ('function' !== typeof fn) {
|
||||
fn = defaultFn;
|
||||
}
|
||||
|
||||
var ajaxifyData = JSON.stringify(options);
|
||||
ajaxifyData = ajaxifyData.replace(/<\//g, '<\\/');
|
||||
|
||||
render.call(self, template, options, function(err, str) {
|
||||
plugins.fireHook('filter:' + template + '.build', {req: req, res: res, templateData: options}, function(err, data) {
|
||||
if (err) {
|
||||
return fn(err);
|
||||
return next(err);
|
||||
}
|
||||
|
||||
str = (res.locals.postHeader ? res.locals.postHeader : '') + str + (res.locals.preFooter ? res.locals.preFooter : '');
|
||||
options = data.templateData;
|
||||
|
||||
if (res.locals.footer) {
|
||||
str = str + res.locals.footer;
|
||||
} else if (res.locals.adminFooter) {
|
||||
str = str + res.locals.adminFooter;
|
||||
options.loggedIn = !!req.uid;
|
||||
options.relative_path = nconf.get('relative_path');
|
||||
options.template = {name: template};
|
||||
options.template[template] = true;
|
||||
options.bodyClass = buildBodyClass(req);
|
||||
|
||||
res.locals.template = template;
|
||||
options._locals = undefined;
|
||||
|
||||
if (res.locals.isAPI) {
|
||||
if (req.route && req.route.path === '/api/') {
|
||||
options.title = '[[pages:home]]';
|
||||
}
|
||||
|
||||
return res.json(options);
|
||||
}
|
||||
|
||||
if (res.locals.renderHeader || res.locals.renderAdminHeader) {
|
||||
var method = res.locals.renderHeader ? middleware.renderHeader : middleware.admin.renderHeader;
|
||||
method(req, res, options, function(err, template) {
|
||||
if (err) {
|
||||
return fn(err);
|
||||
}
|
||||
str = template + str;
|
||||
var language = res.locals.config ? res.locals.config.userLang || 'en_GB' : 'en_GB';
|
||||
language = req.query.lang || language;
|
||||
translator.translate(str, language, function(translated) {
|
||||
translated = translator.unescape(translated);
|
||||
translated = translated + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
|
||||
fn(err, translated);
|
||||
if ('function' !== typeof fn) {
|
||||
fn = defaultFn;
|
||||
}
|
||||
|
||||
var ajaxifyData = JSON.stringify(options);
|
||||
ajaxifyData = ajaxifyData.replace(/<\//g, '<\\/');
|
||||
|
||||
render.call(self, template, options, function(err, str) {
|
||||
if (err) {
|
||||
return fn(err);
|
||||
}
|
||||
|
||||
str = (res.locals.postHeader ? res.locals.postHeader : '') + str + (res.locals.preFooter ? res.locals.preFooter : '');
|
||||
|
||||
if (res.locals.footer) {
|
||||
str = str + res.locals.footer;
|
||||
} else if (res.locals.adminFooter) {
|
||||
str = str + res.locals.adminFooter;
|
||||
}
|
||||
|
||||
if (res.locals.renderHeader || res.locals.renderAdminHeader) {
|
||||
var method = res.locals.renderHeader ? middleware.renderHeader : middleware.admin.renderHeader;
|
||||
method(req, res, options, function(err, template) {
|
||||
if (err) {
|
||||
return fn(err);
|
||||
}
|
||||
str = template + str;
|
||||
var language = res.locals.config ? res.locals.config.userLang || 'en_GB' : 'en_GB';
|
||||
language = req.query.lang || language;
|
||||
translator.translate(str, language, function(translated) {
|
||||
translated = translator.unescape(translated);
|
||||
translated = translated + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
|
||||
fn(err, translated);
|
||||
});
|
||||
});
|
||||
});
|
||||
} else {
|
||||
str = str + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
|
||||
fn(err, str);
|
||||
}
|
||||
} else {
|
||||
str = str + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
|
||||
fn(err, str);
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user