Skip to content

🏭 A small html templating engine built to make building email templates more enjoyable.

License

Notifications You must be signed in to change notification settings

lukethacoder/gulp-email-template-builder

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

3 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

🏭 Gulp Email Template Builder

A small html templating engine built to make building email templates more enjoyable.

The purpose of this small engine is to "componentise" html blocks and allow you to build reusable HTML components to be used by a suite of email templates.

Under to hood we're using Gulp, PostHTML (with posthtml-include) and BrowserSync.

Any css added to style.css will be pulled inline when compiled

πŸ”₯ Features

  • HTML Components
  • BrowserSync/Hot Reload
  • CSS Inlining

πŸš€ Getting started

yarn
# or npm i

yarn dev
# or npm run dev

NOTE: make sure you have the Gulp cli installed.

πŸ¦• Example

Included in the src folder is an example setup. All blocks are in a separate folder and are being referenced by the index.html file.

<table width="650" border="0" cellspacing="0" cellpadding="0" class="mobile-shell">
  <tr>
    <td class="td" style="width: 650px; min-width: 650px; font-size: 0pt; line-height: 0pt; padding: 0; margin: 0; font-weight: normal">
      <!-- The include markup is where the magic happens -->
      <include src="blocks/header.html"></include>
      <include src="blocks/feature-one.html"></include>
      <!-- include more blocks here -->
      <include src="blocks/footer.html"></include>
    </td>
  </tr>
</table>

Pass Props to Blocks

To pass props use the locals props on the <include/>, then on the child, use {{ VARIABLE_NAME }}.

<!-- Parent Component -->
<table width="650" border="0" cellspacing="0" cellpadding="0" class="mobile-shell">
  <tr>
    <td class="td" style="width: 650px; min-width: 650px; font-size: 0pt; line-height: 0pt; padding: 0; margin: 0; font-weight: normal">
      <!-- The include markup is where the magic happens -->
      <include src="blocks/header.html"></include>
      <include
        src="blocks/feature-one.html"
        locals='{ "primaryColor": "#1e52bd", "secondaryColor": "#e85711"}'
      ></include>
      <!-- include more blocks here -->
      <include src="blocks/footer.html"></include>
    </td>
  </tr>
</table>

<!-- Child Component -->
<table width="100%" border="0" cellspacing="0" cellpadding="0">
  <tr>
    <td style="color:{{ primaryColor }};">
      <multiline>Primary Color Goes Here</multiline>
    </td>
  </tr>
  <tr>
    <td style="color:{{ secondaryColor }};">
      <multiline>Secondary Color Goes Here</multiline>
    </td>
  </tr>
</table>

πŸ“ License

Licensed under the MIT License.

About

🏭 A small html templating engine built to make building email templates more enjoyable.

Topics

Resources

License

Stars

Watchers

Forks

Languages