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 const variables = { ...testVariables, ...params }; const { data: emailTestData, subject, html: builtHtml } = await VulcanEmail.build({ emailName: key, variables, locale }); // remove Strings object to avoid echoing it out delete emailTestData.__; html = ` ${builtHtml}
Subject: ${subject}
${JSON.stringify(emailTestData, null, 2)}