Email themes
Email themes are available on the Growth plan and higher.
An email theme renders a notification email message. You can edit an email theme from the Themes page of your TalkJS dashboard, in the section Email themes.
Each email theme has a single built-in component, Email. You can use HTML and CSS to customize the built-in Email component. The markup and styling are rendered directly into the body of the notification email.
In addition, you can also create your own custom components for your notification emails, which you can use from inside the Email component.
The Email component receives the following props:
| Name | Type | Description | 
|---|---|---|
| messages | Message | The messages that the user is notified about | 
| app | { name: string } | The name configured in the main settings page of your TalkJS dashboard | 
| sender | User | Sender of the message that triggered this notification | 
| recipient | User | The recipient of the notification | 
| conversation | Conversation | The conversation that the messages were sent in | 
Represents a user.
Represents a conversation.
Represents a message in a conversation.
Represents a file attached to a message.
TalkJS converts all CSS classes to inline styles using a library called juice. This means that you can freely use classes, and the result usually works, even inside quirky email clients.
You can customize the headers of an email notification from the Headers tab of your email theme editor.

You can use the following macros in the email notification header:
- app.name
- app.id
- app.locale
- app.custom.<CUSTOM_FIELD>
- sender.id
- sender.name
- sender.custom.<CUSTOM_FIELD>
- recipient.id
- recipient.name
- recipient.custom.<CUSTOM_FIELD>
- conversation.id
- conversation.subject
- conversation.topicId
- conversation.custom.<CUSTOM_FIELD>
Replace <CUSTOM_FIELD> with the name of the custom field that you would like to use.