/* Copyright 2024 New Vector Ltd. Copyright 2022 Šimon Brandner Copyright 2019-2022 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ import React, { useState } from "react"; import classNames from "classnames"; import { _t } from "../../../languageHandler"; import { copyPlaintext } from "../../../utils/strings"; import AccessibleButton, { ButtonEvent } from "./AccessibleButton"; interface IProps extends React.HTMLAttributes { children?: React.ReactNode; getTextToCopy: () => string | null; border?: boolean; className?: string; } export const CopyTextButton: React.FC> = ({ getTextToCopy, className }) => { const [tooltip, setTooltip] = useState(undefined); const onCopyClickInternal = async (e: ButtonEvent): Promise => { e.preventDefault(); const text = getTextToCopy(); const successful = !!text && (await copyPlaintext(text)); setTooltip(successful ? _t("common|copied") : _t("error|failed_copy")); }; const onHideTooltip = (): void => { if (tooltip) { setTooltip(undefined); } }; return ( { if (!open) onHideTooltip(); }} /> ); }; const CopyableText: React.FC = ({ children, getTextToCopy, border = true, className, ...props }) => { const combinedClassName = classNames("mx_CopyableText", className, { mx_CopyableText_border: border, }); return (
{children}
); }; export default CopyableText;