Navigation drawer
Navigation drawers provide access to destinations in your app.
Usage
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
Use a navigation drawer for five or more primary destinations.
Avoid using a navigation drawer with other primary navigation components, such as a bottom navigation bar.
Principles
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.
Types
Standard drawer
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 drawer
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 drawer
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.
Anatomy
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)
Sheet
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.
A navigation drawer sheet can open from the left side of the screen for left-to-right languages (1), or from the bottom of the screen when paired with a bottom app bar (2).
Destinations
Destinations in a navigation drawer take the form of actionable list items. Each item describes its destination using a text label and optional iconography.
Destination labels
Text labels should be clear and short enough that they aren’t cut off by the sheet.
Navigation drawers can use text labels without icons.
Keep text labels concise, but truncate them if they extend beyond the container width.
Destination iconography (optional)
Icons can supplement labels as indicators of a destination. Whe used, they should always be placed before text. Other app components and content should reference these icons.
Use recognizable icons when conventions exist.
Secondary destinations can be represented by the same icon, especially if they are part of a collection (1).
Dividers (optional)
Horizontal dividers can be used to separate groups of navigation destinations within the list. They extend across the full width of the drawer.
Use full-width dividers (1) to separate groups of destinations (2).
Header (optional)
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.
If access to account switching is a priority, an account switcher can be placed in the header area of a navigation drawer.
If a navigation drawer is the full vertical height of the page, you can place a branding element or product name in the header area.
Scrim (modal and bottom only)
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.
Scrims applied to a modal side navigation drawer (1) and bottom navigation drawer (2).
Standard drawer
Usage
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.
Alternatives
- 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.
A dismissible drawer.
Behavior
Scrolling
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.
Visibility
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 dismissible navigation drawer is opened and closed by tapping the navigation menu icon in the top app bar (1), and remains open until the menu icon is tapped again (2).
A permanent navigation drawer on desktop
Elevation
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)
Full-height
A full-height navigation drawer is at the same elevation as a top app bar.
Clipped
A clipped navigation drawer is at the same elevation as content that scrolls beneath a top app bar.
Modal drawer
Usage
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.
A modal drawer on mobile.
Behavior
Opening and closing
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)
A modal drawer is always opened by a navigation menu icon (1).
Modal drawers can be dismissed by tapping its scrim (1) or swiping the drawer toward its anchoring screen edge (2).
Scrolling
If the list of navigation destinations is longer than the height of the drawer, the list can vertically scroll in the drawer.
Bottom drawer
Usage
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.
Bottom navigation drawer.
Behavior
Opening on mobile (portrait orientation)
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)
Open bottom navigation drawers that contain only a few items to their full height (A).
Adjust the opening position of your bottom navigation drawer so the last list item in view is clipped by the bottom of the screen. This can inform users that there are more items to view.
Opening on mobile (landscape orientation)
In landscape orientation on mobile, taller bottom navigation drawers automatically open to full-screen mode.
A bottom drawer opens to full-screen mode on mobile in a landscape orientation.
Scrolling
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.
Allow a bottom drawer’s contents to be scrolled when at full height.
Content hierarchy
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
States
The destinations within a navigation drawer take the form of list items. Each item can be activated, inactive, hovered, focused, and pressed.
1. Activated
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.
2. Inactive
Inactive is the default state for items in a navigation drawer.
3. Focus
4. Pressed
5. Hover
Only one drawer item can be activated at a time.
Implementation
Related components:
Full-bleed dividers
Placing a divider inside any container will cover the whole available width.