diff --git a/docs/data/material/components/drawers/ResponsiveDrawer.js b/docs/data/material/components/drawers/ResponsiveDrawer.js index 1f02058cad5453..89a66c9e5e4163 100644 --- a/docs/data/material/components/drawers/ResponsiveDrawer.js +++ b/docs/data/material/components/drawers/ResponsiveDrawer.js @@ -22,9 +22,21 @@ const drawerWidth = 240; function ResponsiveDrawer(props) { const { window } = props; const [mobileOpen, setMobileOpen] = React.useState(false); + const [isClosing, setIsClosing] = React.useState(false); + + const handleDrawerClose = () => { + setIsClosing(true); + setMobileOpen(false); + }; + + const handleDrawerTransitionEnd = () => { + setIsClosing(false); + }; const handleDrawerToggle = () => { - setMobileOpen(!mobileOpen); + if (!isClosing) { + setMobileOpen(!mobileOpen); + } }; const drawer = ( @@ -97,7 +109,8 @@ function ResponsiveDrawer(props) { container={container} variant="temporary" open={mobileOpen} - onClose={handleDrawerToggle} + onTransitionEnd={handleDrawerTransitionEnd} + onClose={handleDrawerClose} ModalProps={{ keepMounted: true, // Better open performance on mobile. }} diff --git a/docs/data/material/components/drawers/ResponsiveDrawer.tsx b/docs/data/material/components/drawers/ResponsiveDrawer.tsx index e6363a1136e21b..a06f4aa609ffee 100644 --- a/docs/data/material/components/drawers/ResponsiveDrawer.tsx +++ b/docs/data/material/components/drawers/ResponsiveDrawer.tsx @@ -29,9 +29,21 @@ interface Props { export default function ResponsiveDrawer(props: Props) { const { window } = props; const [mobileOpen, setMobileOpen] = React.useState(false); + const [isClosing, setIsClosing] = React.useState(false); + + const handleDrawerClose = () => { + setIsClosing(true); + setMobileOpen(false); + }; + + const handleDrawerTransitionEnd = () => { + setIsClosing(false); + }; const handleDrawerToggle = () => { - setMobileOpen(!mobileOpen); + if (!isClosing) { + setMobileOpen(!mobileOpen); + } }; const drawer = ( @@ -104,7 +116,8 @@ export default function ResponsiveDrawer(props: Props) { container={container} variant="temporary" open={mobileOpen} - onClose={handleDrawerToggle} + onTransitionEnd={handleDrawerTransitionEnd} + onClose={handleDrawerClose} ModalProps={{ keepMounted: true, // Better open performance on mobile. }}