Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | import { useDispatch, useSelector } from "react-redux"; import { closeDrawer, drawersSelector, openDrawer, toggleDrawer, setAdditionalState, } from "../../store/features/drawers/drawersSlice.ts"; import { DrawerTypesKeys, PermanentDrawerTypesKeys, } from "../../store/features/drawers/initialState.ts"; type DrawerState = { isOpen: boolean; toggle: () => void; openDrawer: () => void; closeDrawer: () => void; addAdditionalData: (data: any) => void; }; function useDrawerState(id: DrawerTypesKeys): DrawerState { const drawers = useSelector(drawersSelector); const dispatch = useDispatch(); const isOpen = drawers[id] ?? false; const openDrawerFunction = () => { dispatch(openDrawer(id)); }; const closeDrawerFunction = (resetState = true) => { dispatch(closeDrawer({ id, resetState })); }; const toggle = () => { dispatch(toggleDrawer(id as PermanentDrawerTypesKeys)); }; const addAdditionalData = (data: any) => { dispatch(setAdditionalState(data)); }; return { isOpen, toggle, openDrawer: openDrawerFunction, closeDrawer: closeDrawerFunction, addAdditionalData, }; } export default useDrawerState; |