This repository has been merged into ReHackt.Framework
ReHackt.RazorEmails allows you to easily create email templates using ASP.NET Core's Razor syntax. The generated HTML will be compatible with all existing email clients. It includes a service based on MailKit to send them using SMTP.
Get it on NuGet
PM> Install-Package ReHackt.RazorEmails
> dotnet add package ReHackt.RazorEmails
If you are familiar with ASP.NET Core, this summary may be sufficient.
-
Add the
ReHackt.RazorEmails
NuGet package to your ASP.NET Core application project. -
Add a configuration section in your
appsettings.json
file containing the required options (EmailOptions
class). -
Register RazorEmails services and configuration to the service collection:
services.AddRazorEmails(Configuration.GetSection("Email"));
-
Create an Emails folder in the Views folder and add the following code to a
_ViewImports.cshtml
file in that folder:@using ReHackt.RazorEmails @addTagHelper *, ReHackt.RazorEmails
//TODO other folder name
-
Create Razor views in the Emails folder
-
using Tag Helpers instead of raw HTML markup (
<email-a>
,<email-button>
,<email-h2>
,<email-img>
,<email-p>
) -
using
EmailViewDataKeys
constants asViewData
collection keys to pass the necessary data to the layout
Example
@model MyEmailViewModel @{ ViewData[EmailViewDataKeys.Title] = "My Email Title"; } <email-p>This is my email content.</email-p> <email-button href="@Model.Link">Click here</email-button>
-
-
Send an email using
IEmailService
.SendRazorViewEmailAsync
(email
,subject
,viewName
,viewModel
)Example
await _emailService.SendRazorViewEmailAsync(email, "My Email Subject", "/Views/Emails/MyEmail.cshtml", myEmailViewModel);
-
That's all. Congratulations!
First of all, you must register ReHackt.RazorEmails services to the dependency injection container in the Startup.ConfigureServices
method. A service collection extension method is available to register all services (and their dependent services): AddRazorEmails
.
public void ConfigureServices(IServiceCollection services)
{
// ...
services.AddRazorEmails();
// ...
}
Then, the configuration is done using ASP.NET Core's options pattern.
So you need to add an EmailOptions
class to the service container and bound to configuration:
-
as a parameter of
AddRazorEmails
:services.AddRazorEmails(Configuration);
-
or, with
Configure
:services.Configure<EmailOptions>(Configuration);
You can add a new section to your appsettings.json
file:
{
"Email": {
"Sender": "[email protected]"
}
}
services.AddRazorEmails(Configuration.GetSection("Email"));
You can configure simple options with a delegate:
services..AddRazorEmails(options => options.Sender.Name = "[email protected]");
{
"EmailOptions": {
// [Sender]
"Sender": {
"Email": "",
"Name": ""
},
// [SMTP server]
"Smtp": {
"EnableSsl": true,
"Host": "",
"Port": 0,
"Username": "",
"Password": ""
},
// [Email template]
"Template": {
"Address": "",
"ContactEmail": "",
"FooterLinks": [
{
"Text": "",
"Url": ""
}
],
"HeaderLink": "",
"HeaderLogoUrl": "",
"SupportLink": "",
// [Colors (optional)]
"ButtonBackgroundColor": "", // (default: "#7FA5DB")
"ButtonTextColor": "", // (default: "#FFFFFF")
"HeaderBackgroundColor": "", // (default: "#203279")
"HeadlineColor": "", // (default: "#111111")
"LinkColor": "", // (default: "#203279")
"SupportBackgroundColor": "", // (default: "#D8E8FF")
"SupportLinkColor": "", // (default: "#203279")
"TextColor": "" // (default: "#666666")
}
}
}
To send an email, use the IEmailService
from the dependency injection container and call:
-
the
SendEmailAsync
method, if your HTML content is already prepared. -
the
SendRazorViewEmailAsync
method, if you want to generate content from a Razor template.
public interface IEmailService
{
Task SendEmailAsync(string email, string subject, string htmlMessage);
Task SendRazorViewEmailAsync<TModel>(string email, string subject, string viewName, TModel model);
}
// Documentation under construction