35 lines
898 B
TypeScript
35 lines
898 B
TypeScript
/**
|
|
* Copyright (c) 2023-present Plane Software, Inc. and contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
* See the LICENSE file for details.
|
|
*/
|
|
|
|
import { useState, useEffect } from "react";
|
|
|
|
const useClipboardWritePermission = () => {
|
|
const [isClipboardWriteAllowed, setClipboardWriteAllowed] = useState(false);
|
|
|
|
useEffect(() => {
|
|
const checkClipboardWriteAccess = () => {
|
|
navigator.permissions
|
|
|
|
.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;
|