Popover
Popovers are containers used to display transient content such as menus, options, additional actions, and more. They visually stand out through stroke and drop shadow and float on top of the interface.
data:image/s3,"s3://crabby-images/2929f/2929f46eae1113dd0dadbbf75723694244e09869" alt="2 examples of a popover. An action button, label Settings, with popover with avatar, label Lisa Wilson and 3 menu options under a divider, Language, Notifications, Badges. Popover with tip triggered by a color swatch, 2 menu options, Edit and Delete."
data:image/s3,"s3://crabby-images/efbbf/efbbf666d91a82721c68ca5e4fc1851d56b984e9" alt="2 examples of a popover. An action button, label Settings, with popover with avatar, label Lisa Wilson and 3 menu options under a divider, Language, Notifications, Badges. Popover with tip triggered by a color swatch, 2 menu options, Edit and Delete."
Table of contents#
Anatomy#
data:image/s3,"s3://crabby-images/2aeb3/2aeb339e1a722522c668e15162c796a4f281519c" alt="Image illustrating through labels the component anatomy of a popover, including its content area, and optional tip."
Options#
Table of options#
From the design point of view, each component has a number of options. These options and their names are platform agnostic, and each implementation should adapt these to fit into their framework.
Behaviors#
data:image/s3,"s3://crabby-images/4e58f/4e58f6f3d4278a6de6255e3cac1b343c7d39ad1c" alt="Animation showing the behavior of a popover from its opening to its closing. A picker labeled Country opens to show 3 menu options: Canada, Mexico, and United States. Selected option, United States."
Animation#
When displaying a popover, it should animate from its source to reinforce the connection between popover and source. It fades in and slides with a subtle motion from the source.
Dismissing a popover#
A popover can be dismissed by either clicking or tapping anywhere outside of the popover (including clicking or tapping the source again), or by selecting an option or taking an action inside the popover.
Usage guidelines#
Popovers or trays?#
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/a33ce/a33ceb4e01cc97a1b90cd90c75dc1f127f0b8d21" alt="Key example of the correct use of a popover on a mobile device. Icon-only action button, label More options. 3 menu options, Share with..., Edit, Delete."
Show tip when source is ambiguous#
When the source that triggers the popover does not have a visually distinct down state, use a popover with a tip to clearly indicate the connection to its source.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/214f3/214f3d75172f8da5c9a45c437da0dde1a5eb787d" alt="2 key examples of correct usage of popovers with and without tips. First example, an icon-only action button, label More options, in a selected down state, with 3 menu options, Rename, Delete, Share with…, no tip. A swatch group of 6 swatches with a popover with a tip pointing to the third swatch from the left, 2 menu options, Edit, Delete."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/54bd4/54bd4fe5ea097c4820985f947bf78adc889efdb8" alt="Key example of incorrect usage of a popover. A swatch group of 6 swatches with a popover with no tip, 2 menu options, Edit, Delete. Source is not clear because there is no tip on the popover."
Changelog#
- Default offset value updated to spacing-100 (8 px)
- Background color updated to background-layer-2-color (no change in light theme, changed from gray-50 to gray-100 in dark/darkest themes)
- Migrated to latest token system
- Updated all colors to 6.0.0
- Removed top and bottom padding
- Added options (width, height, show tip, placement, offset, cross offset, container padding)
- This component is now individually versioned (individual versions of existing items start at 5.0.0)
Design checklist#
All interactive states
Includes all interactive states that are applicable (hover, down, focus, keyboard focus, disabled).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All color themes
Works properly across all four color themes (lightest, light, dark, darkest).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All platform scales
Includes a desktop scale (UWP, macOS, web desktop) and a mobile scale (iOS, Android, web mobile).
Accessible use of color
Color is not used as the only visual means of conveying information (WCAG 2.0 1.4.1).
Accessible contrast for text
Text has a contrast ratio of at least 4.5:1 for small text and at least 3:1 for large text (WCAG 2.0 1.4.3).
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
Accessible contrast for UI components
Visual information required to identify components and states (except inactive components) has a contrast ratio of at least 3:1 (WCAG 2.1 1.4.11).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Content design
UI language and information design considerations have been incorporated into component design.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined options
Includes relevant options (variant, style, size, orientation, optional iconography, decorations, selection, error state, etc.)
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined behaviors
Includes guidelines for keyboard focus, layout (wrapping, truncation, overflow), animation, interactions, etc.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Usage guidelines
Includes a list of dos and don'ts that highlight best practices and common mistakes.
Writing guidelines
Includes content standards or usage guidelines for how to write or format in-product content for the component.
Internationalization guidelines
Works properly across various locales and includes guidelines for bi-directionality (RTL).
Keyboard interactions
Follows WCAG 2.0 standards for keyboard accessibility guidelines and includes a description of the keyboard interactions.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Design tokens
All design attributes (color, typography, layout, animation, etc.) are available as design tokens.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
UI kit
Includes a downloadable XD file that shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
Generated UI kit
Includes a downloadable XD file, generated by code using design tokens defined in Spectrum DNA, and shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.