@mantine/hooks
Version:
A collection of 50+ hooks for state and UI management
30 lines (27 loc) • 932 B
JavaScript
'use client';
import { useState } from 'react';
function useClipboard(options = { timeout: 2e3 }) {
const [error, setError] = useState(null);
const [copied, setCopied] = useState(false);
const [copyTimeout, setCopyTimeout] = useState(null);
const handleCopyResult = (value) => {
window.clearTimeout(copyTimeout);
setCopyTimeout(window.setTimeout(() => setCopied(false), options.timeout));
setCopied(value);
};
const copy = (value) => {
if ("clipboard" in navigator) {
navigator.clipboard.writeText(value).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 };
}
export { useClipboard };
//# sourceMappingURL=use-clipboard.mjs.map