Files
NodeBB/src/middleware/render.js

112 lines
3.2 KiB
JavaScript
Raw Normal View History

2015-10-11 23:05:33 -04:00
'use strict';
var nconf = require('nconf');
2016-07-08 17:09:47 -04:00
var validator = require('validator');
2016-04-30 10:47:28 +03:00
var plugins = require('../plugins');
2015-10-11 23:05:33 -04:00
var translator = require('../../public/src/modules/translator');
module.exports = function(middleware) {
middleware.processRender = function(req, res, next) {
// res.render post-processing, modified from here: https://gist.github.com/mrlannigan/5051687
var render = res.render;
res.render = function(template, options, fn) {
2016-04-30 10:47:28 +03:00
var self = this;
var req = this.req;
var defaultFn = function(err, str) {
if (err) {
return next(err);
}
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
self.send(str);
};
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
options = options || {};
2015-10-11 23:05:33 -04:00
if ('function' === typeof options) {
fn = options;
options = {};
}
2016-04-30 10:47:28 +03:00
plugins.fireHook('filter:' + template + '.build', {req: req, res: res, templateData: options}, function(err, data) {
if (err) {
return next(err);
}
2015-10-16 18:43:40 -04:00
2016-04-30 10:47:28 +03:00
options = data.templateData;
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
options.loggedIn = !!req.uid;
options.relative_path = nconf.get('relative_path');
options.template = {name: template};
options.template[template] = true;
2016-07-06 20:31:23 +03:00
options.url = (req.baseUrl + req.path).replace(/^\/api/, '');
2016-04-30 10:47:28 +03:00
options.bodyClass = buildBodyClass(req);
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
res.locals.template = template;
options._locals = undefined;
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
if (res.locals.isAPI) {
if (req.route && req.route.path === '/api/') {
options.title = '[[pages:home]]';
}
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
return res.json(options);
}
2015-11-17 12:25:46 -05:00
2016-04-30 10:47:28 +03:00
if ('function' !== typeof fn) {
fn = defaultFn;
2015-10-11 23:05:33 -04:00
}
2015-11-17 12:25:46 -05:00
2016-04-30 10:47:28 +03:00
var ajaxifyData = JSON.stringify(options);
ajaxifyData = ajaxifyData.replace(/<\//g, '<\\/');
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
render.call(self, template, options, function(err, str) {
if (err) {
return fn(err);
}
2015-10-11 23:05:33 -04:00
2016-04-30 10:47:28 +03:00
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';
2016-07-08 17:17:59 -04:00
language = req.query.lang ? validator.escape(req.query.lang) : language;
2016-04-30 10:47:28 +03:00
translator.translate(str, language, function(translated) {
translated = translator.unescape(translated);
translated = translated + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
fn(err, translated);
});
2015-10-11 23:05:33 -04:00
});
2016-04-30 10:47:28 +03:00
} else {
str = str + '<script id="ajaxify-data" type="application/json">' + ajaxifyData + '</script>';
fn(err, str);
}
});
2015-10-11 23:05:33 -04:00
});
};
next();
};
2015-10-16 18:43:40 -04:00
function buildBodyClass(req) {
var clean = req.path.replace(/^\/api/, '').replace(/^\/|\/$/g, '');
2015-10-16 18:43:40 -04:00
var parts = clean.split('/').slice(0, 3);
parts.forEach(function(p, index) {
2015-10-30 15:43:04 -04:00
parts[index] = index ? parts[0] + '-' + p : 'page-' + (p || 'home');
2015-10-16 18:43:40 -04:00
});
return parts.join(' ');
}
2016-03-20 15:11:32 -05:00
};