-
-
Notifications
You must be signed in to change notification settings - Fork 6.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Mermaid diagrams broken due to DOMPurify release v3.1.7 (empty <foreignObject
)
#5904
Mermaid diagrams broken due to DOMPurify release v3.1.7 (empty <foreignObject
)
#5904
Comments
Is this issue being fixed? Pinning dependency versions is not a good idea :) |
The maintainer of DOMPurify doesn't plan to revert the behavior so in the meantime the best option is to pin the dependency in Mermaid. In the next version (v3.1.8) they plan to add an option that allows Mermaid to restore the previous behavior. See discussions here: cure53/DOMPurify#1002 (comment) So to me the plan for Mermaid should be:
|
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: mermaid-js#5904
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: mermaid-js#5904
🚀 Thanks for the help @slorber! I've made #5914 that will pin DOMPurify to: mermaid/packages/mermaid/package.json Line 80 in de2c05c
I'm guessing DOMPurify 3.1.8 will require some config/code changes, so we'd have to make a new Mermaid release that supports |
Thanks! Not sure what's your plan but it may be useful for the community to backport these changes to v10.x patch as well. Although technically v11 was quite easy to adopt for us we only allow 11.x on upcoming Docusaurus v3.6+ and not v2.0-3.5. |
[DOMPurify v3.1.7][1] forbids the use of `<foreignElement>` for HTML inside of an `<svg>` element, which breaks many mermaid diagrams. It is likely that v3.1.8 will add a new option that will allow us to re-enable this behaviour, but v3.1.7 definitely does not work. (cherry picked from commit de2c05c) [1]: https://github.com/cure53/DOMPurify/releases/tag/3.1.7 See: cure53/DOMPurify#1002 Fix: #5904
Thanks 👍 Docusaurus users will thank you without knowing any of this ever happened 😄 |
Should
https://www.npmjs.com/package/@types/dompurify/v/3.2.0 shows:
It seems |
Description
Upgrade transitive dependency DOMPurify from 3.1.6 to 3.1.7
See flowchart diagram labels being empty, because
<foreignObject>
tags are emptySteps to reproduce
Upgrade transitive dependency DOMPurify from 3.1.6 to 3.1.7
Screenshots
Code Sample
No response
Setup
Suggested Solutions
Convince DOMPurify to revert breaking change.
DOMPurify report here: cure53/DOMPurify#1002
Workaround, force resolution to v3.1.6
Additional Context
I'm the maintainer of Docusaurus and this issue affects all our newly initialized sites. The problematic version was published 1 day ago and we already got 2 bug reports that Mermaid diagrams do not work well.
foreignObject
) facebook/docusaurus#10526I'm opening this issue mostly to let you know of the problem.
I don't really know how Mermaid uses that lib exactly, nor if it's possible for you to patch usage on your side to make Mermaid code compatible with v3.1.7+. You could also decide to pin the dependency.
Personally I consider it a breaking change and they should rather revert it, but it's their responsibility to decide.
The text was updated successfully, but these errors were encountered: