prev-cli 0.1.7 → 0.1.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/theme/Layout.tsx +17 -1
package/package.json
CHANGED
package/src/theme/Layout.tsx
CHANGED
|
@@ -67,6 +67,17 @@ async function renderD2Diagrams() {
|
|
|
67
67
|
}
|
|
68
68
|
}
|
|
69
69
|
|
|
70
|
+
// Clean up rendered diagrams (for navigation)
|
|
71
|
+
function cleanupDiagrams() {
|
|
72
|
+
// Remove all rendered diagram containers
|
|
73
|
+
document.querySelectorAll('.mermaid-diagram, .d2-diagram').forEach(el => el.remove())
|
|
74
|
+
// Reset rendered state on pre elements and restore visibility
|
|
75
|
+
document.querySelectorAll('pre[data-rendered="true"]').forEach(el => {
|
|
76
|
+
delete (el as HTMLElement).dataset.rendered;
|
|
77
|
+
(el as HTMLElement).style.display = ''
|
|
78
|
+
})
|
|
79
|
+
}
|
|
80
|
+
|
|
70
81
|
// Render all diagrams
|
|
71
82
|
async function renderDiagrams() {
|
|
72
83
|
await Promise.all([
|
|
@@ -79,9 +90,14 @@ export function Layout() {
|
|
|
79
90
|
const location = useLocation()
|
|
80
91
|
|
|
81
92
|
useEffect(() => {
|
|
93
|
+
// Clean up old diagrams before rendering new ones
|
|
94
|
+
cleanupDiagrams()
|
|
82
95
|
// Render diagrams after content loads
|
|
83
96
|
const timer = setTimeout(renderDiagrams, 100)
|
|
84
|
-
return () =>
|
|
97
|
+
return () => {
|
|
98
|
+
clearTimeout(timer)
|
|
99
|
+
cleanupDiagrams()
|
|
100
|
+
}
|
|
85
101
|
}, [location.pathname])
|
|
86
102
|
|
|
87
103
|
return (
|