mirror of
https://github.com/penxio/penx.git
synced 2026-01-14 16:07:58 -05:00
44 lines
1022 B
TypeScript
44 lines
1022 B
TypeScript
import { useState } from 'react'
|
|
|
|
type CopiedValue = string | null
|
|
type CopyFn = (text: string) => Promise<boolean> // Return success
|
|
|
|
export function useCopyToClipboard() {
|
|
const [copiedText, setCopiedText] = useState<CopiedValue>(null)
|
|
|
|
const copy: CopyFn = async (text) => {
|
|
if (!navigator?.clipboard) {
|
|
console.warn('Clipboard not supported')
|
|
return false
|
|
}
|
|
|
|
// Try to save to clipboard then save it in the state if worked
|
|
try {
|
|
await navigator.clipboard.writeText(text)
|
|
setCopiedText(text)
|
|
return true
|
|
} catch (error) {
|
|
console.warn('Copy failed', error)
|
|
setCopiedText(null)
|
|
return false
|
|
}
|
|
}
|
|
|
|
return { copiedText, copy }
|
|
}
|
|
|
|
export const copy = async (text: string): Promise<boolean> => {
|
|
if (!navigator?.clipboard) {
|
|
console.warn('Clipboard not supported')
|
|
return false
|
|
}
|
|
|
|
try {
|
|
await navigator.clipboard.writeText(text)
|
|
return true
|
|
} catch (error) {
|
|
console.warn('Copy failed', error)
|
|
return false
|
|
}
|
|
}
|