import { Picker } from 'meteor/meteorhacks:picker'; import { runQuery, Strings, getSetting } from 'meteor/vulcan:lib'; import VulcanEmail from '../namespace.js'; Meteor.startup(function () { _.forEach(VulcanEmail.emails, (email, key) => { // template live preview routes Picker.route(email.path, async (params, req, res) => { let html; // if email has a custom way of generating test HTML, use it if (typeof email.getTestHTML !== "undefined") { html = email.getTestHTML.bind(email)(params); } else { const locale = params.query.locale || getSetting('locale'); // else get test object (sample post, comment, user, etc.) const testVariables = (typeof email.testVariables === 'function' ? email.testVariables() : email.testVariables) || {}; // delete params.query so we don't pass it to GraphQL query delete params.query; // merge test variables with params from URL // TODO: this is currently hardcoded to work with the SingleXYZInput type, maybe bad idea? const variables = { input: { selector: { ...testVariables, ...params } } }; const result = email.query ? await runQuery(email.query, variables, { locale }) : {data: {}}; // if email has a data() function, merge it with results of query const emailTestData = email.data ? {...result.data, ...email.data(variables)} : result.data; const subject = typeof email.subject === 'function' ? email.subject(emailTestData) : email.subject; emailTestData.__ = Strings[locale]; const template = VulcanEmail.getTemplate(email.template); const htmlContent = template(emailTestData) // then apply email template to properties, and wrap it with buildTemplate html = VulcanEmail.buildTemplate(htmlContent, emailTestData); // remove Strings object to avoid echoing it out delete emailTestData.__; html += `

Subject: ${subject}

${JSON.stringify(emailTestData, null, 2)}
` } // return html res.end(html); }); // raw template Picker.route("/email/template/:template", (params, req, res) => { res.end(VulcanEmail.templates[params.template]); }); }); });