@mantine/hooks
Version:
A collection of 50+ hooks for state and UI management
35 lines (31 loc) • 841 B
JavaScript
'use client';
;
var React = require('react');
function useDisclosure(initialState = false, callbacks) {
const { onOpen, onClose } = callbacks || {};
const [opened, setOpened] = React.useState(initialState);
const open = React.useCallback(() => {
setOpened((isOpened) => {
if (!isOpened) {
onOpen?.();
return true;
}
return isOpened;
});
}, [onOpen]);
const close = React.useCallback(() => {
setOpened((isOpened) => {
if (isOpened) {
onClose?.();
return false;
}
return isOpened;
});
}, [onClose]);
const toggle = React.useCallback(() => {
opened ? close() : open();
}, [close, open, opened]);
return [opened, { open, close, toggle }];
}
exports.useDisclosure = useDisclosure;
//# sourceMappingURL=use-disclosure.cjs.map