(Available as an npm package)
ProjectileGenerate HTML email content for Slinger.
How it works
- Create CSS File with definitions for Headings and body
- Create HTML template file with a link to where the CSS is and a special template string that will be replaced.
- Write markdown file
- Render HTML from markdown file with "markdown-it" library
- Parse HTML Template and replace a special template string with rendered content from markdown file e.g
{{slinger_content}}
. - Now with the string from the last step, apply inline the css into style attributes using the inline-css library.
- The final HTML string generated will be put added into a new HTML file output. The generated file in the output directory will be used to send emails via slinger.
How to use
You can just call generate
and it will automatically get files from index.css
, index.html
and index.md
the /src
directory within your current one, then generate the final html file called index.html
in the /output
directory within your current one.
Example:
import { generate } from "slinger-projectile";
generate();
If you would like to modify this behaviour call generate(options)
.
If you don't specify a field, the default behaviour will occur for for that option.
Full options object possible values
{
templatePath: string,
useCssFile: bool,
cssPath: string,
markdownPath: string,
outputDirectory: string,
outputFileName: string
}
Important Notes
CSS support in emails is different from the rest of the web.
Contributing
Found a bug or would like to help out with the project? Check this out: Contributing to the project.
Read these for more info: https://www.campaignmonitor.com/dev-resources/guides/coding-html-emails/
https://www.campaignmonitor.com/css/style-element/style-in-head/