added recompilation of templates to NodeBB Reloading - #2010
parent
eef200be10
commit
fcbdc5e271
@ -0,0 +1,15 @@
|
|||||||
|
define('templates', function() {
|
||||||
|
var Templates = {};
|
||||||
|
|
||||||
|
Templates.refresh = function(callback) {
|
||||||
|
$.getJSON(RELATIVE_PATH + '/api/get_templates_listing', function (data) {
|
||||||
|
Templates.config = data.templatesConfig;
|
||||||
|
Templates.available = data.availableTemplates;
|
||||||
|
|
||||||
|
if (callback) callback();
|
||||||
|
// app.load();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
return Templates;
|
||||||
|
});
|
@ -0,0 +1,89 @@
|
|||||||
|
var mkdirp = require('mkdirp'),
|
||||||
|
rimraf = require('rimraf'),
|
||||||
|
winston = require('winston'),
|
||||||
|
async = require('async'),
|
||||||
|
path = require('path'),
|
||||||
|
fs = require('fs'),
|
||||||
|
nconf = require('nconf'),
|
||||||
|
|
||||||
|
emitter = require('../emitter'),
|
||||||
|
plugins = require('../plugins'),
|
||||||
|
utils = require('../../public/src/utils'),
|
||||||
|
|
||||||
|
Templates = {};
|
||||||
|
|
||||||
|
Templates.compile = function(callback) {
|
||||||
|
var baseTemplatesPath = nconf.get('base_templates_path'),
|
||||||
|
viewsPath = nconf.get('views_dir'),
|
||||||
|
themeTemplatesPath = nconf.get('theme_templates_path');
|
||||||
|
|
||||||
|
plugins.getTemplates(function(err, pluginTemplates) {
|
||||||
|
winston.info('[meta/templates] Compiling templates');
|
||||||
|
rimraf.sync(viewsPath);
|
||||||
|
mkdirp.sync(viewsPath);
|
||||||
|
|
||||||
|
async.parallel({
|
||||||
|
baseTpls: function(next) {
|
||||||
|
utils.walk(baseTemplatesPath, next);
|
||||||
|
},
|
||||||
|
themeTpls: function(next) {
|
||||||
|
utils.walk(themeTemplatesPath, next);
|
||||||
|
}
|
||||||
|
}, function(err, data) {
|
||||||
|
var baseTpls = data.baseTpls,
|
||||||
|
themeTpls = data.themeTpls,
|
||||||
|
paths = {};
|
||||||
|
|
||||||
|
if (!baseTpls || !themeTpls) {
|
||||||
|
winston.warn('[meta/templates] Could not find base template files at: ' + baseTemplatesPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
baseTpls = !baseTpls ? [] : baseTpls.map(function(tpl) { return tpl.replace(baseTemplatesPath, ''); });
|
||||||
|
themeTpls = !themeTpls ? [] : themeTpls.map(function(tpl) { return tpl.replace(themeTemplatesPath, ''); });
|
||||||
|
|
||||||
|
baseTpls.forEach(function(el, i) {
|
||||||
|
paths[baseTpls[i]] = path.join(baseTemplatesPath, baseTpls[i]);
|
||||||
|
});
|
||||||
|
|
||||||
|
themeTpls.forEach(function(el, i) {
|
||||||
|
paths[themeTpls[i]] = path.join(themeTemplatesPath, themeTpls[i]);
|
||||||
|
});
|
||||||
|
|
||||||
|
for (var tpl in pluginTemplates) {
|
||||||
|
if (pluginTemplates.hasOwnProperty(tpl)) {
|
||||||
|
paths[tpl] = pluginTemplates[tpl];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async.each(Object.keys(paths), function(relativePath, next) {
|
||||||
|
var file = fs.readFileSync(paths[relativePath]).toString(),
|
||||||
|
matches = null,
|
||||||
|
regex = /[ \t]*<!-- IMPORT ([\s\S]*?)? -->[ \t]*/;
|
||||||
|
|
||||||
|
while(matches = file.match(regex)) {
|
||||||
|
var partial = "/" + matches[1];
|
||||||
|
|
||||||
|
if (paths[partial] && relativePath !== partial) {
|
||||||
|
file = file.replace(regex, fs.readFileSync(paths[partial]).toString());
|
||||||
|
} else {
|
||||||
|
winston.warn('[themes] Partial not loaded: ' + matches[1]);
|
||||||
|
file = file.replace(regex, "");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mkdirp.sync(path.join(viewsPath, relativePath.split('/').slice(0, -1).join('/')));
|
||||||
|
fs.writeFile(path.join(viewsPath, relativePath), file, next);
|
||||||
|
}, function(err) {
|
||||||
|
if (err) {
|
||||||
|
winston.error(err);
|
||||||
|
} else {
|
||||||
|
winston.info('[themes] Successfully compiled templates.');
|
||||||
|
emitter.emit('templates:compiled');
|
||||||
|
if (callback) callback();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = Templates;
|
Loading…
Reference in New Issue