Navigation drawer
Navigation drawers provide access to destinations in your app.
Last updated
Navigation drawers provide access to destinations in your app.
Last updated
Navigation drawers provide access to destinations and app functionality, such as switching accounts. They can either be permanently on-screen or controlled by a navigation menu icon.
Navigation drawers are recommended for:
Apps with five or more top-level destinations
Apps with two or more levels of navigation hierarchy
Quick navigation between unrelated destinations
Identifiable
The placement and list-style content of navigation drawers clearly identify them as navigation.
Organized
Navigation drawers order destinations according to user importance, with frequent destinations first and related ones grouped together.
Contextual
Navigation drawers can be shown or hidden to accommodate different app layouts.
Standard navigation drawers allow users to simultaneously access drawer destinations and app content. They are often co-planar with app content and affect the screen’s layout grid.
Standard drawers can be permanently visible or opened and closed by tapping a navigation menu icon. They can be used on tablet and desktop only. On mobile, modal drawers are used instead.
Modal navigation drawers use a scrim to block interaction with the rest of an app’s content. They are elevated above most app elements and don’t affect the screen’s layout grid.
They are primarily for use on mobile, where screen space is limited. They can be replaced by standard drawers on tablet and desktop.
Bottom navigation drawers are a specialized type of modal drawer for use with a bottom app bar.
For increased reachability from the bottom app bar’s menu icon, they open from the bottom of the screen rather than the side.
Navigation drawers contain a list embedded within a sheet. They can be enhanced with headers and dividers to organize longer lists.
Container
Header (optional)
Divider (optional)
Active text overlay
Active text
Inactive text
Subtitle
Scrim (modal only)
The contents of a navigation drawer are contained within a side or bottom sheet. Navigation drawers that open from the side are placed on the left of the screen for left-to-right languages, and on the right of the screen for right-to-left languages.
Destinations in a navigation drawer take the form of actionable list items. Each item describes its destination using a text label and optional iconography.
Text labels should be clear and short enough that they aren’t cut off by the sheet.
Icons can supplement labels as indicators of a destination. When used, they should always be placed before text. Other app components and content should reference these icons.
Horizontal dividers can be used to separate groups of navigation destinations within the list. They extend across the full width of the drawer.
Horizontal dividers can be used to separate groups of navigation destinations within the list. They extend across the full width of the drawer.
The header area of a navigation drawer is a flexible space that can be used for brand expression (such as an app title or logo), an account switcher, and more.
Modal navigation drawers use a scrim to block interaction with the rest of the app. The scrim is placed directly below the drawer’s sheet and can be tapped or clicked to dismiss the drawer.
Standard navigation drawers allow interaction with both screen content and the drawer at the same time. They can be used on tablet and desktop, but they aren’t suitable for mobile due to limited screen size.
Modal drawer: In a responsive layout grid, at a defined minimum breakpoint of at least 600dp width, a standard drawer should be replaced with a modal drawer.
Permanently visible drawer: When users need to switch destinations frequently (and screen size allows), a permanently visible drawer can be used.
Dismissible drawer: A dismissible drawer can be used when users are likely to focus on screen content and require less frequent access to its navigation destinations.
Navigation drawers can be vertically scrolled, independent of the rest of the screen’s content and UI. If the list of navigation destinations is longer than the height of the drawer, the drawer’s contents can be scrolled within the drawer.
The visibility of a standard navigation drawer depends on screen size, app layout, and frequency of use.
Dismissible standard drawers can be used for layouts that prioritize content (such as a photo gallery) or for apps where users are unlikely to switch destinations often. They should use a visible navigation menu icon to open and close the drawer.
Permanently visible standard drawers allow quick pivoting between unrelated destinations. They require a menu icon for control because they can’t be dismissed by the user.
A standard navigation drawer can use one of these elevation positions:
At the same elevation as a top app bar (full-height)
At a lower elevation than a top app bar (clipped)
A full-height navigation drawer is at the same elevation as a top app bar.
A clipped navigation drawer is at the same elevation as content that scrolls beneath a top app bar.
Modal navigation drawers block interaction with the rest of an app’s content with a scrim. They are elevated above most of the app’s UI and don’t affect the screen’s layout grid.
They are primarily for use on mobile where screen space is limited, and can be replaced by standard drawers on tablet and desktop.
Modal navigation drawers are always opened by an affordance outside of the drawer, such as a navigation menu icon in a top app bar.
Modal drawers can be dismissed by:
Selecting a drawer item
Tapping the scrim
Swiping toward the drawer’s anchoring edge (e.g. swiping right-to-left for a left-aligned navigation drawer)
If the list of navigation destinations is longer than the height of the drawer, the list can vertically scroll in the drawer.
Bottom navigation drawers are modal drawers that are anchored to the bottom of the screen instead of the left or right edge. They are only used with bottom app bars.
These drawers open upon tapping the navigation menu icon in the bottom app bar. They are only for use on mobile.
As with other modal bottom sheets, the initial vertical position of a bottom navigation drawer is based on its content and screen height. They initially cannot open above 50% of the screen’s height.
If drawer contents are under 50% of screen height, open the drawer to full height at all times
If drawer contents are greater than 50% of screen height, open them to 50% initially, then allow a user to drag the drawer upward to its full height or screen height (whichever comes first)
In landscape orientation on mobile, taller bottom navigation drawers automatically open to full-screen mode.
Bottom navigation drawers can be internally scrolled once they have been opened to full screen height.
When initially opened to 50% of the screen height, the drawer must be dragged to screen height before additional items are revealed. Upon scroll, the drawer's header becomes an elevated top app bar with a close affordance.
Because the number of bottom navigation drawer content items aren’t all visible at first, the content of the drawer should be ordered as follows:
List items first that are most likely to be frequently accessed by users
If an account switcher is used, place it at the top of the drawer
The destinations within a navigation drawer take the form of list items. Each item can be activated, inactive, hovered, focused, and pressed.
The current screen, or its parent, is represented with an activated state. Only one item in a navigation drawer can be activated at a time. This state should have strong visual contrast from unactivated items.
Inactive is the default state for items in a navigation drawer.