I have a Flutter app that displays an animation. I want the animation to pause if there is an open Drawer or a modal dialog (like showModalBottomSheet
) displayed anywhere in the App.
I could handle the events of a specific Drawer directly and manage the state on my own. However, I have multiple drawers in my app that I have to track and it feels like a lot of work. Is there a global place were I can check whether a Drawer (or modal dialog) is open anywhere in the app?
Both
showModalBottomSheet
and modal dialogs are pusing a route to theNavigator
. This way one can check viaModalRoute.of(context)?.isCurrent != true
whether another route (or dialog) is in front of the current route.Sadly, the open
Drawer
of aScaffold
is not a route. However it isn't required to have a key on the scaffold, but one can check viaScaffold.of(context).isDrawerOpen
if the next parentDrawer
is open.By combining the two state I can check whether the animation should be paused.