removed handlebars dependency for emailer, using ANDREWBARS now

This commit is contained in:
Julian Lam
2014-01-04 18:03:54 -05:00
parent 5c048ac20a
commit b6fdc5595d
9 changed files with 21 additions and 88 deletions

View File

@@ -2,57 +2,27 @@ var User = require('./user'),
Plugins = require('./plugins'),
Meta = require('./meta'),
Handlebars = require('handlebars'),
fs = require('fs'),
async = require('async'),
path = require('path'),
Emailer = {},
templates = {};
var prepareTemplate = function(template, callback) {
if (templates[template] === undefined) {
var templatePath = path.join(__dirname, '../public/templates/emails/' + template + '.hbs');
fs.exists(templatePath, function(exists) {
if (exists) {
fs.readFile(templatePath, function(err, fileStream) {
if (!err) {
templates[template] = Handlebars.compile(fileStream.toString());
} else {
templates[template] = null;
}
callback();
});
} else {
templates[template] = null;
callback();
}
});
} else {
// Template loaded already
callback();
}
}
Emailer = {};
var render = function(template, params, callback) {
prepareTemplate(template, function() {
if (templates[template] !== null) {
callback(null, templates[template](params));
} else {
callback(null, null);
}
});
if (templates[template] !== null) {
callback(null, templates[template].parse(params));
} else {
callback(null, null);
}
}
Emailer.send = function(template, uid, params) {
async.parallel({
html: function(next) {
render(template, params, next);
render('emails/' + template, params, next);
},
plaintext: function(next) {
render(template + '_plaintext', params, next);
render('emails/' + template + '_plaintext', params, next);
}
}, function(err, results) {
User.getUserField(uid, 'email', function(err, email) {