undkonsorten / html-mail-utility
Mail Utility: css inlining and plaintext
Installs: 70
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 0
Open Issues: 0
Type:typo3-cms-extension
pkg:composer/undkonsorten/html-mail-utility
Requires
- php: ^7.4 || ^8.1
- html2text/html2text: ^4.0
- lorenzo/pinky: ^1.1
- tijsverkoyen/css-to-inline-styles: ^2.2
- typo3/cms-core: ^11.5 || ^12.4 || ^13.3
This package is auto-updated.
Last update: 2025-10-21 07:54:16 UTC
README
What does it do?
Extension html_mail_utility bundles a couple of
third-party libraries which are needed for a HTML newsletter
campaign. Each of them ship with a Fluid view helper or
a Class suitable for USER
or USER_INT
.
-
Inky is a set of tags like
<container>
or<row>
that will be transformed to the beloved stone-age<table>
markup. This extension makes use of the PHP implementation hampe/inky -
CSS inlining is another common task for newsletter mailings. tijsverkoyen/css-to-inline-styles is integrated for this purpose.
-
For html and plaintext multipart messages, html2text/html2text is bundled so you can convert HTML to plaintext at the very end of your newsletter build process.
All three dependencies are decoupled by interfaces. Concrete implementations can thus be switched by configuration or at runtime.
Installation
Composer install
Just require the extension. Dependencies will be installed automatically.
composer require undkonsorten/html-mail-utility
Non-Composer mode
Using without composer ist not supported!
Fluid ViewHelpers
To start using the ViewHelpers, don‘t forget to include the corresponding namespace in your template files:
<html xmlns:m="http://typo3.org/ns/Undkonsorten/HtmlMailUtility/ViewHelpers">
Inky view helper
<m:format.inky gridColumns="16" aliases="{bricks:'column'}">
Parameters:
- markup (string, optional): You can pass markup in this attribute. Leave unset to use tag content instead.
- gridColums (int, optional): Set this to change the underlying grid system column calculations are based on. Defaults to 12.
- aliases (array, optional): Aliases allow you to define aliases
for inky tags, e.g. write
<bricks>
instead of<column>
in the example above.
Output:
Markup with inky tags transformed to table legacy.
Beware of uncached actions!!!
Uncached Action will not be rendered with Inky. The transforming won't work and the complete output of this action won't be shown! You have no output of uncached action!
CSS Inline view helper
<m:css.inline cssFile="EXT:my_ext/Resources/Public/Css/Mail.css">
Parameters:
- html (string, optional): You can pass HTML markup in this attribute. Leave unset to use tag content instead.
- css (string, optional): Put additional CSS styles here.
- cssFile (string, optional): You can specify a CSS file for
inlining. You can use
EXT:
syntax.
Output:
HTML markup with inline style
attributes according to
matching CSS rules.
Plain text view helper
<m:format.plainText>
- html (string, optional): You can pass HTML markup in this attribute. Leave unset to use tag content instead.
- baseUrl (string, optional): If set, this value will be prepended to all on-site links to make them accessible from plain text. Not needed if your markup ships with absolute links.