Picker
Pickers (sometimes known as "dropdowns" or "selects") allow users to choose from a list of options in a limited space. The list of options can change based on the context.
data:image/s3,"s3://crabby-images/6ace4/6ace470c33507077d3b9c374d6461693ea0f19bc" alt="Image illustrating pickers in open and closed states. Picker in closed state, label Transition selected value None. Picker in open state, label Easing, selected value Ease out, other menu options Ease in, Ease out, Ease in-out, None."
Anatomy#
data:image/s3,"s3://crabby-images/00747/0074710bd4394338478dfc559d1b3c2befc8d39b" alt="Image illustrating through labels the component parts of a picker in its open and closed states, including its label, required asterisk, field button, chevron, menu, menu options, and help text with description or error message."
data:image/s3,"s3://crabby-images/b331e/b331e2afcf0b204cacccad5b2918dd4539832b6b" alt="Image illustrating through labels the component parts of a picker in its open and closed states, including its label, required asterisk, field button, chevron, menu, menu options, and help text with description or error message."
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/92bca/92bcafdca8160ff130ce620e29041055eec5dbd9" alt="Key example of regular and quiet pickers illustrating the minimum width. A regular picker with the label State and the selected value of CA. A quiet picker with the label State and the selected value of CA."
Minimum width#
The minimum width for a picker is 2× the height of the field button. This guarantees that small pickers are readable and easy to target on touch devices. Quiet pickers do not have a minimum width; their width depends on the length of the text.
data:image/s3,"s3://crabby-images/c0f3d/c0f3d50b87e92b381f09178366049f36bbadde58" alt="Key example of text overflow behavior in a dropdown. A label with the wrapping text Select the size you want this export to be. A dropdown with the truncated selected value of Large select this followed by ellipsis. A menu with the wrapping text Small works best for mobile phones."
Text overflow#
When the field label and menu text are too long for the available horizontal space, they wrap to form another line. The field text itself truncates at the end, but the text can be shown in full in the menu.
data:image/s3,"s3://crabby-images/cb5cc/cb5cc8be9313da7a306b8a0b0de861810df54277" alt="Key example of a picker’s help text in overflow, wrapping to two lines. Picker label, Preferred contact method. Prompt text, Select contact method… Help text shown in gray color, Select the best way to contact you in case there’s an issue with your account."
Help text overflow#
When the help text is too long for the available horizontal space, it wraps to form another line.
data:image/s3,"s3://crabby-images/4e6ad/4e6ad81b3b609f8d26c1fec0665c646344591b39" alt="Key example of showing the menu height of a picker. Picker label, Country. Selected option, United States. 11 options, Tunisia, Turkey, Turkmenistan, Tuvalu, Uganda, Ukraine, United Arab Emirates, United Kingdom, United States, Uruguay, Uzbekistan."
Menu height#
The picker menu can be as tall as necessary to show as many options as possible in the available space. There is no maximum height.
data:image/s3,"s3://crabby-images/41f7b/41f7bfd4ba89845c22c9ea3cceb271959db8b709" alt="Key example of pickers in Windows “high contrast black” theme with label “Picker”, disabled picker with label “Disabled picker”, and selected picker with menu displaying options labeled “Option”, “Selected option” in selected state, and “Disabled option” in disabled state."
Windows high contrast mode#
In Windows high contrast mode, picker should be displayed using the high contrast theme-specified colors for buttons. By default, border color should be the same as the button text color and labels should use default text color. In hover and keyboard focus states, the border color should display as the button border color. In the disabled state, border and text color should display as the disabled color. Items in a picker menu should display with default text color. A selected item should have the background and text colors defined for selected text.
Usage guidelines#
Include a label#
Every picker should have a label. A picker without a label is ambiguous and not accessible.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c4a56/c4a56d60a9ba59d56251895a7f183f254a903bfa" alt="Key example showing the correct usage of a picker label. A picker with the label Country of birth and the selected value of United States."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/0173a/0173a4959ed0c37da4dd65bdc3f1f852549eca11" alt="Key example showing the correct usage of a picker without a label. A picker with no label and the selected value of United States."
Review label-less designs#
In rare cases where context is sufficient and a label could be absent, make sure to have the design reviewed and approved by an accessibility expert. These should still include an aria-label in HTML (depending on the context, “aria-label” or “aria-labelledby”).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c97a3/c97a3ca86975d2a6a2f7bc19cd1bf00d64751ebe" alt="Key example showing the correct usage of a picker without a label. A quiet picker with the selected value of Sort by date."
Keep menu items concise#
Keep menu items short and concise. Long menu items that cause text to wrap to multiple lines are discouraged. If text wrapping becomes a frequent concern, consider revising the text or use alternative UI patterns that will give your content more space.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/b445e/b445e9319b2a162416a60d606bf8384f1339a997" alt="A key example showing correct picker menu item text length. A picker in the open state with the label size and placeholder text Select an option followed by ellipsis, a menu with the items Small, Medium, and Large."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/c2877/c28770c42283f86b7292f11a5eb60e3f6a9cfc16" alt="A key example showing incorrect picker menu item text length. A picker in the open state with the label size and placeholder text Select an option followed by ellipsis, a menu with the items Small (works best for mobile phones), Medium (all-purpose), and Large (select this one for printing)."
Choose an appropriate width#
When possible, the field button width should be wide enough so that any chosen menu items can be displayed in full.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/59789/59789e2a590a214c22da91643d957a848aca3c97" alt="Key example showing the correct width of a picker. A picker with the label Country and the selected value of United States of America."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/813f2/813f2e58bb9fbe3432acb4d2bd4b3e09ad1647a5" alt="Key example showing the a picker with incorrect width. A picker with the label Country and the selected value of United Sta followed by ellipsis to show the truncation of the words United States."
Follow capitalization rules#
Field labels, placeholder text, and menu items should be in sentence case.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/8d890/8d89016ff920393d7ebe58faf3cf7a279885ea03" alt="A key example of a picker with correct sentence case capitalization. A picker with the label Country of birth and the placeholder text Select a country followed by ellipsis."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/693af/693aff9305099a40712b1521230056077b42e38e" alt="A key example of a picker with incorrect title case capitalization. A picker with the label Country of Birth and the placeholder text Select a Country followed by ellipsis."
Mark the minority of pickers in a form as required or optional#
In a single form, mark only the required fields or only the optional fields, depending on whichever is less frequent in the entire form. If most of the pickers are optional, only the required fields should be given an asterisk or have labels appended with “(required)”. If most of the pickers are required, only the optional fields should be appended with “(optional)”. An asterisk should never be used to note that a picker is optional.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/5510c/5510c91b289f211ec477f549a1477082871e240f" alt="A key example showing correct usage of required and optional pickers. A picker with the label View by and the placeholder text Select an option followed by ellipsis. A picker with the label View by and the placeholder text Select an option followed by ellipsis. A picker with the label Country (optional) and the placeholder text Select an option followed by ellipsis."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/f670a/f670a408688b2aabc01032cd41d99ffc0f2821c1" alt="A key example showing incorrect usage of required and optional pickers. A picker with the label View by (required) and the placeholder text Select an option followed by ellipsis. A picker with the label View by (required) and the placeholder text Select an option followed by ellipsis. A picker with the label Country and the placeholder text Select an option followed by ellipsis."
Use help text to show context#
A picker’s description in the help text is can communicate what to select or how to select an option. This includes information such as:
- An overall description of the picker options
- Hints for what kind of information to choose
- More context for why a user needs to make a selection
The help text’s message should not simply restate the same information in the label in order to prompt someone to interact with a picker. Don’t add help text if it isn’t actually relevant or meaningful to a user in order to try to maintain layout continuity with other inputs that require help text.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/ce428/ce4283886d4fc11ba41012906eebb72ebe3eff30" alt="Key example of correct usage of help text with a picker. Picker label, Preferred contact method. Prompt text, Select contact method… Help text shown in gray color, Select the best way to contact you in case there’s an issue with your account."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/6d5b5/6d5b5451b9912b958f037ef1b7e958d381ec4cd5" alt="Key example of incorrect usage of help text with a picker. Picker label, Preferred contact method. Prompt text, Select contact method… Help text shown in gray color, Choose your preferred contact method."
Switch help text with error text#
The help text area also displays an error message. When a picker already includes help text and an error is triggered, the help text is replaced with error text. Once the error is resolved, the help text description reappears below the picker.
Since one gets replaced by the other, the language of the help text and error text need to work together to convey the same messaging. Help text explains the requirement or adds supplementary context for how to complete the interaction. Error text tells a user how to fix the error by re-stating the selection requirements or describing the necessary interaction. Make sure that the help text and the error text include the same essential information so that it isn’t lost if one replaces the other (e.g., minimum requirements).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/47bee/47beeca48d893cc7dc494c79054c7e276c9c45de" alt="Key example of correct usage of switching help text with error text in a picker. Required picker label, Preferred contact method. Prompt text, Select contact method… Help text shown in gray color, Select the best way to contact you in case there’s an issue with your account. Error message shown in red color, Select a contact method."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/dcecb/dcecb96c7237b32e935c51f8d1408866565e007f" alt="Key example of incorrect usage of switching help text with error text in a picker. Required picker label, Preferred contact method. Prompt text, Select contact method… Help text shown in gray color, Select a contact method. Error text shown in red color, Select a contact method."
Write error text that shows a solution#
Write error messaging in a human-centered way by guiding a user and showing them a solution — don’t simply state what’s wrong and then leave them guessing as to how to resolve it. Ambiguous error messages can be frustrating and even shame-inducing for users. Also, keep in mind that something that a system may deem an error may not actually be perceived as an error to a user.
Error text should be written in 1-2 short, complete sentences and in a clear and straightforward way. End sentences with a period, and never with an exclamation point. For pickers, the nature of the error is often related to something that needs to be fixed for in-line validation, so a
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/5e6d0/5e6d05988a7ff69e251bce8aa0728f688b9d42b3" alt="Key example of correct way of writing an error message. Required picker, label Preferred contact method. Placeholder text prompt, Select contact method… Error text shown in red color, Select a contact method."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/6a62c/6a62c2278e9567d6047d499deeb9b24eba502698" alt="Key example of correct way of writing an error message. Required picker, label Preferred contact method. Placeholder text prompt, Select contact method… Error text shown in red color, Invalid field."
Internationalization#
Keyboard interactions#
When the popover menu is closed:
When the popover menu is open:
Changelog#
- Updated read-only option design
- Updated all colors to 6.0.0
- Added size option
- Updated read-only option design
- Moved placement of checkmark to left side of menu items
- Updated placeholder text color for higher contrast
- "Dropdown" has been renamed to "picker"
- Added read-only option
- Updated border color to be more accessible
- Added text overflow behavior
- Changed selected item text color from blue 500 to gray 800
- This component is now individually versioned (individual versions of existing components start at 5.0.0)
- Added RTL (right-to-left) guidelines
Design checklist#
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible use of color
Color is not used as the only visual means of conveying information (WCAG 2.0 1.4.1).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Writing guidelines
Includes content standards or usage guidelines for how to write or format in-product content for the component.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Internationalization guidelines
Works properly across various locales and includes guidelines for bi-directionality (RTL).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.