30 lines
785 B
TypeScript
30 lines
785 B
TypeScript
import { useState, useEffect } from "react";
|
|
|
|
const useClipboardWritePermission = () => {
|
|
const [isClipboardWriteAllowed, setClipboardWriteAllowed] = useState(false);
|
|
|
|
useEffect(() => {
|
|
const checkClipboardWriteAccess = () => {
|
|
navigator.permissions
|
|
//eslint-disable-next-line no-undef
|
|
.query({ name: "clipboard-write" as PermissionName })
|
|
.then((result) => {
|
|
if (result.state === "granted") {
|
|
setClipboardWriteAllowed(true);
|
|
} else {
|
|
setClipboardWriteAllowed(false);
|
|
}
|
|
})
|
|
.catch(() => {
|
|
setClipboardWriteAllowed(false);
|
|
});
|
|
};
|
|
|
|
checkClipboardWriteAccess();
|
|
}, []);
|
|
|
|
return isClipboardWriteAllowed;
|
|
};
|
|
|
|
export default useClipboardWritePermission;
|