UNPKG

@mantine/hooks

Version:

A collection of 50+ hooks for state and UI management

33 lines (30 loc) 806 B
'use client'; import { useState, useCallback } from 'react'; function useDisclosure(initialState = false, callbacks) { const { onOpen, onClose } = callbacks || {}; const [opened, setOpened] = useState(initialState); const open = useCallback(() => { setOpened((isOpened) => { if (!isOpened) { onOpen?.(); return true; } return isOpened; }); }, [onOpen]); const close = useCallback(() => { setOpened((isOpened) => { if (isOpened) { onClose?.(); return false; } return isOpened; }); }, [onClose]); const toggle = useCallback(() => { opened ? close() : open(); }, [close, open, opened]); return [opened, { open, close, toggle }]; } export { useDisclosure }; //# sourceMappingURL=use-disclosure.mjs.map