From 798057fd12ea5b1a8031e946fb77cee15c20adeb Mon Sep 17 00:00:00 2001 From: Marek Mihok Date: Thu, 17 Aug 2023 14:42:46 +0200 Subject: [PATCH] chore: fix saving text to clipboard for input, show button in markdown codeblocks #2025 --- ui/src/copyable_text.tsx | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/ui/src/copyable_text.tsx b/ui/src/copyable_text.tsx index f5e1917a75..d015453793 100644 --- a/ui/src/copyable_text.tsx +++ b/ui/src/copyable_text.tsx @@ -68,8 +68,8 @@ export const ClipboardCopyButton = ({ value, anchorElement, showOnHoverOnly = fa onClick = async () => { if (!anchorElement) return try { - if (document.queryCommandSupported('copy') && anchorElement.tagName === 'input') { - (anchorElement as HTMLInputElement).select() + if (document.queryCommandSupported('copy')) { + anchorElement.select() document.execCommand('copy') window.getSelection()?.removeAllRanges() } @@ -91,7 +91,7 @@ export const ClipboardCopyButton = ({ value, anchorElement, showOnHoverOnly = fa setVisible(false) }) } - }, [value, anchorElement]) + }, [anchorElement]) React.useEffect(() => () => window.clearTimeout(timeoutRef.current), []) @@ -111,7 +111,7 @@ export const XCopyableText = ({ model }: { model: CopyableText }) => { heightStyle = multiline && height === '1' ? fullHeightStyle : undefined, [inputEl, setInputEl] = React.useState(), domRef = React.useCallback(node => { - const inputEl = node?.children[0]?.children[1] + const inputEl = node?.children[0]?.children[1]?.children[0] if (inputEl) setInputEl(inputEl) }, []) @@ -137,7 +137,8 @@ export const XCopyableText = ({ model }: { model: CopyableText }) => { /> )