You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
18 lines
421 B
18 lines
421 B
import { useCallback, useState } from 'react';
|
|
|
|
export default function useModalOpenState(
|
|
initialState: boolean
|
|
): [boolean, () => void, () => void] {
|
|
const [isOpen, setOpen] = useState(initialState);
|
|
|
|
const setModalOpen = useCallback(() => {
|
|
setOpen(true);
|
|
}, [setOpen]);
|
|
|
|
const setModalClosed = useCallback(() => {
|
|
setOpen(false);
|
|
}, [setOpen]);
|
|
|
|
return [isOpen, setModalOpen, setModalClosed];
|
|
}
|