Markerb allows you to render multipart e-mails from a single template. The template is written in Markdown, which is delivered as a text part, but also rendered and delivered as an HTML part.
The usage is quite simple. Assuming you have a notifier as below:
class Notifier < ActionMailer::Base def contact(recipient) @recipient = recipient mail(:to => @recipient, :from => "[email protected]") do |format| format.text format.html end end end
If you create a template at
Multipart templates **rocks**, right <%= @recipient %>?!
It will generate two parts, one in text and another in html when delivered. Before we finish, here are a few things you might need to know:
contact.markerbtemplate should not have a format in its name. Adding a format would make it unavailable to be rendered in different formats;
The order of the parts matter. It is important for e-mail clients that you call
format.textbefore you call
Notice you can normally use ERb inside the template.
Add it to your Gemfile, with either the
gem 'markerb' gem 'redcarpet', '>= 2.0' # gem 'kramdown'
Run the following command to install it:
If you discover any bugs, feel free to create an issue on GitHub. Please add as much information as possible to help us fixing the possible bug. We also encourage you to help even more by forking and sending us a pull request.
- José Valim (https://github.com/josevalim)
MIT License. Copyright 2011-2015 Plataformatec. http://plataformatec.com.br