From 02f60fafaf4d1aeff8dd416377845b6012836512 Mon Sep 17 00:00:00 2001 From: Keith Cirkel Date: Thu, 29 Sep 2022 16:25:32 +0100 Subject: [PATCH] use shadowroot.host instead of weakmap --- src/targetable.ts | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/src/targetable.ts b/src/targetable.ts index 88aa8fd1..1f5cd888 100644 --- a/src/targetable.ts +++ b/src/targetable.ts @@ -56,9 +56,8 @@ const [targets, getTargets, initializeTargets] = createMark( function setTarget(el: Element, controller: Element | ShadowRoot, tag: string, key: string): void { const get = tag === 'data-targets' ? getTargets : getTarget - if (controller instanceof ShadowRoot) { - controller = controllers.get(controller)! - } + if (controller instanceof ShadowRoot) controller = controller.host + if (controller && get(controller)?.has(key)) { ;(controller as unknown as Record)[key] = {} } @@ -67,7 +66,6 @@ function setTarget(el: Element, controller: Element | ShadowRoot, tag: string, k registerTag('data-target', (str: string) => str.split('.'), setTarget) registerTag('data-targets', (str: string) => str.split('.'), setTarget) const shadows = new WeakMap() -const controllers = new WeakMap() const findTarget = (controller: Element, selector: string, many: boolean) => () => { const nodes = [] @@ -113,7 +111,6 @@ export const targetable = createAbility( [attachShadowCallback](root: ShadowRoot) { super[attachShadowCallback]?.(root) shadows.set(this, root) - controllers.set(root, this) observeElementForTags(root) } }