Overview
Menus allow users to make a selection from a list of options. We use two types of menus: Dropdown and Filter.
Dropdown menu
Allow users to discover and access complex actions. They can be generated from buttons, icons, and in some cases by right-clicking a location.
data:image/s3,"s3://crabby-images/80b35/80b359d21925a3b9412fcf374ba3b922835c20dd" alt=""
Filter menu
Filter menus allow users to filter information by selecting from a long list of options. They can be generated by clicking a text field.
data:image/s3,"s3://crabby-images/b38f2/b38f23eddfeee8f4c276b559e9bb3b4ed5bcfaae" alt=""
Menu text
- Menu options can be user-generated text
- Menu text is 2-3 words by default
- Menu option text may have a disabled style
✔ Do
data:image/s3,"s3://crabby-images/d2576/d25768e6491319c0aae9a357d8c5a1381c699b62" alt=""
Minimize text and rely on interface clarity
✘ Don't
data:image/s3,"s3://crabby-images/af372/af372f792a6ae7274da691ea0b5a45bb05ac4b43" alt=""
Write repetitive menu option text
Layout
- Menus appear above all other UI elements
- Menus appear directly below the element that generated it
- Menus do not move from their original location when scrolling through the page
- Menus should never touch the edge of the browser screen. Apply an offset of 8px.
Guidelines
- Menus can contain icons
- Menus can have dividers to group relevant options together
- By default only one menu item can be selected at a time
- Multiple menu options can be selected in special cases
✔ Do
data:image/s3,"s3://crabby-images/a97c6/a97c6e47fb13b44efce8fb6dd05fedb32d68ce49" alt=""
Use iconography as a visual aid for important actions
✘ Don't
data:image/s3,"s3://crabby-images/eb7b7/eb7b769275a9b550359245eea882d6a3f14da75a" alt=""
Use repetitive iconography in filter menus
Specifications
- Min width: 128px
- Menu elevation: 4dp
-
Background color:
tokens.surface
-
Option text color:
tokens.text
-
Option text hover color:
palette.grey.v_200
-
Iconography color:
palette.grey.v_800
Dropdown menu
- Width: matches the width of the longest text option
- Menu option height: 32px
Filter menu
- Width: width: matches the width of the text field that generates it
- Menu option height: 48px