Files
admin-frontend-domain/src/components/copy-button.tsx
T
UUBulb a45e789178 improve: replace long line of words with clipboard button (#95)
* improve: replace long line of words with clipboard button

* change module path
2025-01-06 21:02:39 +08:00

46 lines
1.1 KiB
TypeScript

import { ButtonProps } from "@/components/ui/button"
import { copyToClipboard } from "@/lib/utils"
import { forwardRef } from "react"
import { useState } from "react"
import { useTranslation } from "react-i18next"
import { toast } from "sonner"
import { IconButton } from "./xui/icon-button"
interface CopyButtonProps extends ButtonProps {
text?: string
}
export const CopyButton = forwardRef<HTMLButtonElement, CopyButtonProps>((props, ref) => {
const { t } = useTranslation()
const [copy, setCopy] = useState(false)
const switchState = async (text?: string) => {
if (!text) {
toast("Warning", {
description: t("EmptyText"),
})
return
}
if (!copy) {
setCopy(true)
await copyToClipboard(text)
setTimeout(() => {
setCopy(false)
}, 2 * 1000)
}
}
return (
<IconButton
{...props}
ref={ref}
variant="outline"
size="icon"
icon={copy ? "check" : "clipboard"}
onClick={() => switchState(props.text)}
/>
)
})