/* eslint-disable @typescript-eslint/no-explicit-any */ import { useState } from 'react' export function useClipboard({ timeout = 2000 } = {}) { const [error, setError] = useState(null) const [copied, setCopied] = useState(false) const [copyTimeout, setCopyTimeout] = useState(null) const handleCopyResult = (value: boolean) => { window.clearTimeout(copyTimeout!) setCopyTimeout(window.setTimeout(() => setCopied(false), timeout)) setCopied(value) } const copy = (valueToCopy: any) => { if ('clipboard' in navigator) { navigator.clipboard .writeText(valueToCopy) .then(() => handleCopyResult(true)) .catch((err) => setError(err)) } else { setError(new Error('useClipboard: navigator.clipboard is not supported')) } } const reset = () => { setCopied(false) setError(null) window.clearTimeout(copyTimeout!) } return { copy, reset, error, copied } }