diff options
Diffstat (limited to 'src/components/Drawer/Drawer.tsx')
-rw-r--r-- | src/components/Drawer/Drawer.tsx | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/src/components/Drawer/Drawer.tsx b/src/components/Drawer/Drawer.tsx index eded40c..76b5120 100644 --- a/src/components/Drawer/Drawer.tsx +++ b/src/components/Drawer/Drawer.tsx @@ -1,4 +1,4 @@ -import React, { useMemo } from 'react'; +import React, { useMemo, useEffect, useCallback } from 'react'; import { useHistory } from 'react-router-dom'; import { SwipeableDrawer, @@ -33,23 +33,27 @@ const Drawer: React.FC<PropTypes> = React.memo(({ isOpen, setIsOpen }) => { const history = useHistory(); const { user, logout } = useAuth(); - const handleOpen = () => { + const handleOpen = useCallback(() => { setIsOpen(true); - }; + }, [setIsOpen]); - const handleClose = () => { + const handleClose = useCallback(() => { setIsOpen(false); - }; + }, [setIsOpen]); - const handleLogout = () => { + useEffect(() => { + // Close drawer on navigations + return history.listen(() => handleClose()); + }, [history, handleClose]) + + const handleLogout = useCallback(() => { logout(); - handleClose(); - }; + history.push('/login'); + }, [logout, history]); - const handleAbout = () => { + const handleAbout = useCallback(() => { history.push('/'); - handleClose(); - }; + }, [history]); const iOS = useMemo(() => { return /iPad|iPhone|iPod/.test(navigator.userAgent); |