aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/packages/docs/app/components/mermaid.tsx
diff options
context:
space:
mode:
authorNatsuu <natsukawa247@outlook.com>2026-04-01 11:28:27 +0800
committerGitHub <noreply@github.com>2026-04-01 11:28:27 +0800
commitbf0634ab5091bb8c585b574c5ed175a2a231df5e (patch)
tree6424355eb47fefa1f60029dab82fbcc69d0bb5d9 /packages/docs/app/components/mermaid.tsx
parent408df90aa804116ef82e5e40a79430820a1ed502 (diff)
parent61c576ee502bf8929cd881cc40302be7b1c10b85 (diff)
downloadDropOut-bf0634ab5091bb8c585b574c5ed175a2a231df5e.tar.gz
DropOut-bf0634ab5091bb8c585b574c5ed175a2a231df5e.zip
Merge branch 'main' into feat/docs-build-test
Diffstat (limited to 'packages/docs/app/components/mermaid.tsx')
-rw-r--r--packages/docs/app/components/mermaid.tsx27
1 files changed, 20 insertions, 7 deletions
diff --git a/packages/docs/app/components/mermaid.tsx b/packages/docs/app/components/mermaid.tsx
index 2df47cc..fe153ec 100644
--- a/packages/docs/app/components/mermaid.tsx
+++ b/packages/docs/app/components/mermaid.tsx
@@ -6,24 +6,37 @@ import { useEffect, useRef } from "react";
mermaid.initialize({
startOnLoad: false,
theme: "default",
+ securityLevel: "strict",
});
export function Mermaid({ chart }: { chart: string }) {
const ref = useRef<HTMLDivElement>(null);
useEffect(() => {
- if (ref.current) {
- mermaid.run({
- nodes: [ref.current],
+ let current = true;
+ const id = `mermaid-${Math.random().toString(36).slice(2, 9)}`;
+ mermaid
+ .render(id, chart)
+ .then(({ svg }) => {
+ if (!current) return;
+ const parser = new DOMParser();
+ const doc = parser.parseFromString(svg, "image/svg+xml");
+ const svgEl = doc.querySelector("svg");
+ if (ref.current && svgEl) {
+ ref.current.replaceChildren(svgEl);
+ }
+ })
+ .catch(() => {
+ if (current) ref.current?.replaceChildren();
});
- }
+ return () => {
+ current = false;
+ };
}, [chart]);
return (
<div className="not-prose my-6">
- <div ref={ref} className="mermaid">
- {chart}
- </div>
+ <div ref={ref} className="mermaid" />
</div>
);
}