Email as a CMS block overview

Edit on GitHub

Back Office users can manage the content of emails sent to customers through CMS Blocks in the Back Office. To use a CMS Block as an email, the Back Office user applies an email template.

Types of email templates

There are two types of emails used to manage CMS Blocks as emails: CMS Block email template and the actual email template.

CMS block email template

CMS Block email template is a Twig file that defines the design and layout of CMS Block in a way suitable for using it as an email. The following CMS Block email templates are available by default:

  • HTML email template with header and footer.
  • Text email template with header and footer.
  • Empty email template.

To learn how a Back Office User applies a CMS Block email template, see Create email CMS blocks.

A Developer can create more CMS Block email templates.

Email template

Email Template is a Twig file that defines the content of a system email sent to customers. You can edit the template by editing the assigned Email CMS Block in the Back Office.

Naming of email CMS blocks

Being a multi-purpose entity, CMS Blocks relies strongly on its naming when used as an email. The CMS Block name defines the email template it’s assigned to.

Template assignment

When a developer creates an email template, inside the file, they enter the CMS Block’s name, which is assigned to the template. If the name of an Email CMS Block changes, a developer must update it in the respective email template. For example, the availability-notification-subscription--html Email CMS Block is assigned to the subscribed.html.twig default email template.

Email format

There are two email formats by default: HTML and pure text. The format of the default email templates is identified by one of the respective tales in the name of an Email CMS Block: --html or --text. For example, Email CMS Blocks with the following names are assigned to the customer registration email template:

  • customer-registration--html
  • customer-registration--text

The email format itself is defined on the code level, the tales serving as identifiers. If you create new email templates, you don’t have to add them to their Email CMS Block names.

Default email templates

There is a number of email templates with the respective Email CMS Blocks available in the Demo Shops.

The following table contains the list of the default email templates, their Email CMS Blocks, and their purpose.

Default email templates
WHEN THE EMAIL IS SENT EMAIL CMS BLOCK NAME TWIG TEMPLATE
Customer registered in the shop. customer-registration–html Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_registration.html.twig
Customer registered in the shop. customer-registration–text Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_registration.html.twig
Customer confirmed the email address by clicking the link in the registration email. customer-registration_token–html Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_registration_token.html.twig
Customer confirmed the email address by clicking the link in the registration email. customer-registration_token–text Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_registration_token.text.twig
Customer submitted the password change form. customer-restore-password–html Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_restore_password.html.twig
Customer submitted the password change form. customer-restore-password–text Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_restore_password.text.twig
Customer clicked the password change link in the email and set up a new password. customer-restored-password-confirmation–html Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_reset_password_confirmation.html.twig
Customer clicked the password change link in the email and set up a new password. customer-restored-password-confirmation–text Customer/src/Spryker/Zed/Customer/Presentation/Mail/customer_reset_password_confirmation.text.twig
Customer subscribed to a newsletter. newsletter-subscribed–html Newsletter/src/Spryker/Zed/Newsletter/Presentation/Mail/subscribed.html.twig
Customer subscribed to a newsletter. newsletter-subscribed–text Newsletter/src/Spryker/Zed/Newsletter/Presentation/Mail/subscribed.text.twig
Customer unsubscribed from a newsletter. newsletter-unsubscribed–html Newsletter/src/Spryker/Zed/Newsletter/Presentation/Mail/unsubscribed.html.twig
Customer unsubscribed from a newsletter. newsletter-unsubscribed–text Newsletter/src/Spryker/Zed/Newsletter/Presentation/Mail/unsubscribed.text.twig
Order was placed successfully. order-confirmation–html Oms/src/Spryker/Zed/Oms/Presentation/Mail/order_confirmation.html.twig
Order was placed successfully. order-confirmation–text Oms/src/Spryker/Zed/Oms/Presentation/Mail/order_confirmation.text.twig
Order was shipped. order-shipped–html Oms/src/Spryker/Zed/Oms/Presentation/Mail/order_shipped.html.twig
Order was shipped. order-shipped–text Oms/src/Spryker/Zed/Oms/Presentation/Mail/order_shipped.text.twig
Customer invited a new company user. The invited user receives the email. company-user-invitation–html CompanyUserInvitation/src/Spryker/Zed/CompanyUserInvitation/Presentation/Mail/invitation.html.twig
Customer invited a new company user. The invited user receives the email. company-user-invitation–text CompanyUserInvitation/src/Spryker/Zed/CompanyUserInvitation/Presentation/Mail/invitation.text.twig
Company’s status changed. company-status–html CompanyMailConnector/src/Spryker/Zed/CompanyMailConnector/Presentation/Mail/company_status.html.twig
Company’s status changed. company-status–text CompanyMailConnector/src/Spryker/Zed/CompanyMailConnector/Presentation/Mail/company_status.text.twig
Customer subscribed to notifications about product availability. availability-notification-subscription–html AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/subscribed.html.twig
Customer subscribed to notifications about product availability. availability-notification-subscription–text AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/subscribed.text.twig
Customer unsubscribed from notifications about product availability. availability-notification-unsubscribed–html AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/unsubscribed.html.twig
Customer unsubscribed from notifications about product availability. availability-notification-unsubscribed–text AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/unsubscribed.text.twig
A product that was unavailable becomes available. Customers who subscribed to availability notifications receive the email. availability-notification–html AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/notification.html.twig
A product that was unavailable becomes available. Customers who subscribed to availability notifications receive the email. availability-notification–text AvailabilityNotification/src/Spryker/Zed/AvailabilityNotification/Presentation/Mail/notification.text.twig
Back Office user submitted the password change form. restore-password–html AuthMailConnector/src/Spryker/Zed/AuthMailConnector/Presentation/Mail/restore_password.html.twig
Back Office user submitted the password change form. restore-password–text AuthMailConnector/src/Spryker/Zed/AuthMailConnector/Presentation/Mail/restore_password.text.twig
Gift Card was delivered to a customer. gift-card-delivery–html GiftCardMailConnector/src/Spryker/Zed/GiftCardMailConnector/Presentation/Mail/gift_card_delivery.html.twig
Gift Card was delivered to a customer. gift-card-delivery–text GiftCardMailConnector/src/Spryker/Zed/GiftCardMailConnector/Presentation/Mail/gift_card_delivery.text.twig
Customer used a gift card. gift-card-usage–html GiftCardMailConnector/src/Spryker/Zed/GiftCardMailConnector/Presentation/Mail/gift_card_usage.html.twig
Customer used a gift card. gift-card-usage–text GiftCardMailConnector/src/Spryker/Zed/GiftCardMailConnector/Presentation/Mail/gift_card_usage.text.twig
Merchant relation request was created. cms-block-email–merchant_notification_of_merchant_relation_request_creation–html MerchantRelationRequestMerchantPortalGui/src/Spryker/Zed/MerchantRelationRequestMerchantPortalGui/Presentation/Mail/merchant_notification_of_merchant_relation_request_creation.html.twig
Merchant relation request was created. cms-block-email–merchant_notification_of_merchant_relation_request_creation–text MerchantRelationRequestMerchantPortalGui/src/Spryker/Zed/MerchantRelationRequestMerchantPortalGui/Presentation/Mail/merchant_notification_of_merchant_relation_request_creation.text.twig
Merchant relation request status was changed. cms-block-email–merchant_relation_request_status_change–html MerchantRelationRequest/src/Spryker/Zed/MerchantRelationRequest/Presentation/Mail/merchant_relation_request_status_change.html.twig
Merchant relation request status was changed. cms-block-email–merchant_relation_request_status_change–text MerchantRelationRequest/src/Spryker/Zed/MerchantRelationRequest/Presentation/Mail/merchant_relation_request_status_change.text.twig
Merchant relation was deleted. cms-block-email–merchant_relationship_delete–html MerchantRelationship/src/Spryker/Zed/MerchantRelationship/Presentation/Mail/merchant_relationship_delete.html.twig
Merchant relation was deleted. cms-block-email–merchant_relationship_delete–text MerchantRelationship/src/Spryker/Zed/MerchantRelationship/Presentation/Mail/merchant_relationship_delete.text.twig

To learn how a Back Office User manages the content of email templates by editing Email CMS Block, see Edit placeholders in CMS blocks.

After creating email templates, a developer can import their assigned Email CMS Blocks. See an example of the import file with the Email CMS Blocks in Spryker Master Suite.

Email content

When editing an email template using email CMS block, you work in the WYSIWYG editor. Apart from the regular WYSIWYG editor tools, you can add glossary keys and variables.

You can use the functionalities described in this section, regardless of the email format.

Glossary keys in email templates

You can add glossary keys directly to email templates, and the respective translations are fetched automatically. When an email with a glossary key is sent, the key is replaced with the translation you defined for the locale selected by the customer. For example, you add the cart.price.grand.total glossary key to an email template. When the email is sent to the customer with the de_DE locale, the key is replaced with Summe.

To learn how a Back Office User creates translations, see Managing Glossary.

Variables in Email Templates

Also, you can use variables to adjust details like a customer name in the emails automatically. For example, if you add the firstName variable, when the email is sent, the variable is replaced with the first name of the customer it’s sent to. Unlike glossary keys, variables are defined on the code level, namely in the transfer object definition.

A developer can provide a full list of variables and create new ones.

Content items in email templates

The CMS capability in Spryker lets you add content items into CMS Blocks. Unlike the regular CMS Blocks, the Email CMS Blocks do not support content items. If you insert one, its content is not rendered when the email is sent.

BACK OFFICE USER GUIDES
Create email CMS Blocks