frontPanel/src/utils/useDisclosure.ts

14 lines
361 B
TypeScript
Raw Normal View History

2023-12-02 09:35:35 +00:00
import { useState, useCallback } from "react";
export function useDisclosure(initialState = false) {
const [opened, setOpened] = useState(initialState);
return [
opened,
useCallback(() => setOpened(true), []),
useCallback(() => setOpened(false), []),
useCallback(() => setOpened(prev => !prev), []),
] as const;
}