Is there a way to detect if there is any open drawer?

1.5k Views Asked by At

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?

2

There are 2 best solutions below

0
On BEST ANSWER

Both showModalBottomSheet and modal dialogs are pusing a route to the Navigator. This way one can check via ModalRoute.of(context)?.isCurrent != true whether another route (or dialog) is in front of the current route.

Sadly, the open Drawer of a Scaffold is not a route. However it isn't required to have a key on the scaffold, but one can check via Scaffold.of(context).isDrawerOpen if the next parent Drawer is open.

By combining the two state I can check whether the animation should be paused.

3
On

Yes, there is way to know whether navigation drawer is opened or not

1. Declare GlobalKey

  GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();

2. Assign a key to Scaffold Widget

 return Scaffold(
      key: _scaffoldKey,

3. Used wherever you want to know drawer status

_scaffoldKey.currentState.isDrawerOpen   // This return bool value True-Open, False-Close