From c3680f2d10dd086ecf4efd476c8b5e98ddca5650 Mon Sep 17 00:00:00 2001 From: Alex Date: Sun, 18 Feb 2024 23:20:12 +0200 Subject: [PATCH] unmount react root --- cli/plasmo/src/type.ts | 3 +++ cli/plasmo/templates/static/common/csui.ts | 4 +++- .../templates/static/react18/content-script-ui-mount.tsx | 1 + 3 files changed, 7 insertions(+), 1 deletion(-) diff --git a/cli/plasmo/src/type.ts b/cli/plasmo/src/type.ts index a7ae39371..466c5f70f 100644 --- a/cli/plasmo/src/type.ts +++ b/cli/plasmo/src/type.ts @@ -1,4 +1,5 @@ import type { ManifestContentScript } from "@plasmo/constants/manifest/content-script" +import type { Root } from "react-dom/client" // See https://www.plasmo.com/engineering/log/2022.04#update-2022.04.23 export type PlasmoCSConfig = Omit, "js"> @@ -16,12 +17,14 @@ type GetElement = Getter type PlasmoCSUIOverlayAnchor = { element: Element + root?: Root type: "overlay" } type PlasmoCSUIInlineAnchor = { element: Element type: "inline" + root?: Root insertPosition?: "beforebegin" | "afterbegin" | "beforeend" | "afterend" } diff --git a/cli/plasmo/templates/static/common/csui.ts b/cli/plasmo/templates/static/common/csui.ts index 118161bb2..8a35c2dfc 100644 --- a/cli/plasmo/templates/static/common/csui.ts +++ b/cli/plasmo/templates/static/common/csui.ts @@ -158,7 +158,7 @@ export function createAnchorObserver(Mount: PlasmoCSUI) { // Go through mounted sets and check if they are still mounted for (const el of mountState.hostSet) { - if (isMounted(el)) { + if (isMounted(el)) { const anchor = mountState.hostMap.get(el) if (!!anchor) { if (anchor.type === "inline") { @@ -168,6 +168,8 @@ export function createAnchorObserver(Mount: PlasmoCSUI) { } } } else { + const anchor = mountState.hostMap.get(el) + anchor.root?.unmount(); mountState.hostSet.delete(el) } } diff --git a/cli/plasmo/templates/static/react18/content-script-ui-mount.tsx b/cli/plasmo/templates/static/react18/content-script-ui-mount.tsx index 70f499039..fbcaf5a80 100644 --- a/cli/plasmo/templates/static/react18/content-script-ui-mount.tsx +++ b/cli/plasmo/templates/static/react18/content-script-ui-mount.tsx @@ -28,6 +28,7 @@ const render = createRender( observer?.mountState, async (anchor, rootContainer) => { const root = createRoot(rootContainer) + anchor.root = root const Layout = getLayout(RawMount)