mirror of https://github.com/zulip/zulip.git
2f203f4de1
Previously, we had an architecture where CSS inlining for emails was done at provision time in inline_email_css.py. This was necessary because the library we were using for this, Premailer, was extremely slow, and doing the inlining for every outgoing email would have been prohibitively expensive. Now that we've migrated to a more modern library that inlines the small amount of CSS we have into emails nearly instantly, we are able to remove the complex architecture built to work around Premailer being slow and just do the CSS inlining as the final step in sending each individual email. This has several significant benefits: * Removes a fiddly provisioning step that made the edit/refresh cycle for modifying email templates confusing; there's no longer a CSS inlining step that, if you forget to do it, results in your testing a stale variant of the email templates. * Fixes internationalization problems related to translators working with pre-CSS-inlined emails, and then Django trying to apply the translators to the post-CSS-inlined version. * Makes the send_custom_email pipeline simpler and easier to improve. Signed-off-by: Daniil Fadeev <fadeevd@zulip.com> |
||
---|---|---|
.. | ||
apple | ||
import_fixtures | ||
ldap | ||
mattermost_fixtures | ||
rocketchat_fixtures | ||
saml | ||
slack_fixtures | ||
.gitignore | ||
authors.json | ||
config.generate_data.json | ||
csp_report.json | ||
example_jwk | ||
gitter_data.json | ||
markdown_test_cases.json | ||
narrow.json | ||
slack_message_conversion.json | ||
user_agents_unique |