diff --git a/.changeset/brown-pugs-pump.md b/.changeset/brown-pugs-pump.md new file mode 100644 index 000000000..4c62f5513 --- /dev/null +++ b/.changeset/brown-pugs-pump.md @@ -0,0 +1,5 @@ +--- +'@xyflow/system': patch +--- + +Refactor isInputDOMNode so that it handles non-html objects diff --git a/packages/system/src/utils/dom.ts b/packages/system/src/utils/dom.ts index 886547725..b3648ede3 100644 --- a/packages/system/src/utils/dom.ts +++ b/packages/system/src/utils/dom.ts @@ -40,7 +40,7 @@ const inputTags = ['INPUT', 'SELECT', 'TEXTAREA']; export function isInputDOMNode(event: KeyboardEvent): boolean { // using composed path for handling shadow dom const target = (event.composedPath?.()?.[0] || event.target) as HTMLElement; - const isInput = inputTags.includes(target?.nodeName) || target?.hasAttribute('contenteditable'); + const isInput = inputTags.includes(target?.nodeName) || target?.hasAttribute?.('contenteditable'); // when an input field is focused we don't want to trigger deletion or movement of nodes return isInput || !!target?.closest('.nokey');