From 8b0c6ba5dfb0233b32f5f156ca6e4073fb0d90f9 Mon Sep 17 00:00:00 2001 From: Henrik Giesel Date: Fri, 7 May 2021 16:50:17 +0200 Subject: [PATCH] Check for id when inserting dynamic elements * I'm not sure it behaved, if there were multiple elements inserted by different add-ons into the same container --- qt/aqt/browser/browser.py | 2 +- ts/components/registration.ts | 23 +++++++++++++++-------- 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/qt/aqt/browser/browser.py b/qt/aqt/browser/browser.py index 72eb654dd..47eb23bb6 100644 --- a/qt/aqt/browser/browser.py +++ b/qt/aqt/browser/browser.py @@ -382,7 +382,7 @@ class Browser(QMainWindow): editor._links["preview"] = lambda _editor: self.onTogglePreview() editor.web.eval( - "$editorToolbar.then(({ notetypeButtons }) => notetypeButtons.appendButton({ component: editorToolbar.PreviewButton }));" + "$editorToolbar.then(({ notetypeButtons }) => notetypeButtons.appendButton({ component: editorToolbar.PreviewButton, id: 'preview' }));" ) gui_hooks.editor_did_init.append(add_preview_button) diff --git a/ts/components/registration.ts b/ts/components/registration.ts index 8faf67be1..06f03c009 100644 --- a/ts/components/registration.ts +++ b/ts/components/registration.ts @@ -8,7 +8,7 @@ import { find } from "./identifier"; export interface SvelteComponent { component: SvelteComponentTyped; - id: string | undefined; + id: string; props: Record | undefined; } @@ -32,6 +32,10 @@ export interface DynamicRegistrationAPI { ) => void; } +export function nodeIsElement(node: Node): node is Element { + return node.nodeType === Node.ELEMENT_NODE; +} + export function makeInterface(makeRegistration: () => T): RegistrationAPI { const registrations: T[] = []; const items = writable(registrations); @@ -60,18 +64,21 @@ export function makeInterface(makeRegistration: () => T): RegistrationAPI observer: MutationObserver ): void => { for (const mutation of mutations) { - const addedNode = mutation.addedNodes[0]; + for (const addedNode of mutation.addedNodes) { + if ( + nodeIsElement(addedNode) && + (!component.id || addedNode.id === component.id) + ) { + const index = add(addedNode, elementRef); - if (addedNode.nodeType === Node.ELEMENT_NODE) { - const index = add(addedNode as Element, elementRef); + if (index >= 0) { + registerComponent(index, registration); + } - if (index >= 0) { - registerComponent(index, registration); + return observer.disconnect(); } } } - - observer.disconnect(); }; const observer = new MutationObserver(callback);