Switch
Switches allow users to turn an individual option on or off. They are usually used to activate or deactivate a specific setting.
data:image/s3,"s3://crabby-images/b9231/b923106dc204b1396ce94b3862b26ceea8dace5c" alt="Group of three switches. The first switch is selected. The label "available offline" is on the right side of the first switch. The track color is blue and the white switch handle is on the right side of the switch."
Anatomy#
data:image/s3,"s3://crabby-images/2c73e/2c73e56aae18406aa26dc62921e871dda0642e9f" alt="Image illustrating through labels the component parts of a switch in selected and unselected state. The unselected switch places the handle on the left side of the switch track. The track color is lighter and an a darker outline is set on the switch handle.
The selected switch features a handle that is on the right side of the switch track and a darker color for the track. The outline of the switch matches the dark track color. A label is placed on the right side for both switches."
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/52f31/52f31d02ee531144379261f4f586ebeb2ee3b676" alt="Switch placeholder labels, off, in focus."
Keyboard focus#
A switch can be navigated using a keyboard. The keyboard focus state takes the switch’s visual hover state and adds a blue ring to the switch in focus.
data:image/s3,"s3://crabby-images/c5e4f/c5e4fc233d359bcf44a5c348d7f98cd3b3f103d6" alt="Key example of the text overflow behavior for switches. A selected and emphasized switch is placed on the left of a long switch label text. The long text breaks into a new line and is flushed-left at the same column as the first word of the label."
Text overflow#
When the label is too long for the horizontal space available, it wraps to form another line.
data:image/s3,"s3://crabby-images/1fb7c/1fb7c6d1577787268fd8a9904c9fcd13da636fae" alt="Key example of switch in Windows “high contrast black” theme with label “Switch”, selected switch with label “Selected switch”, and disabled radio with label “Disabled switch”."
Windows high contrast mode#
In Windows high contrast mode, switches should be displayed using the high contrast theme-specified colors for buttons. By default, borders should be the same as the button text color and labels should use default text color. In hover and keyboard focus states, a border should display as the button border color. A selected switch fill and border should be the same as button border color. In the disabled state, border and text color should display as the disabled color.
Usage guidelines#
Emphasized or not?#
Emphasized switches are optimal for forms, settings, and other scenarios where the switches need to be noticed. Not emphasized switches are optimal for application panels where all the visual components are monochrome in order to direct focus to the canvas.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/a480f/a480f174f5903c36de85568b9c0f9aaba6c92cea" alt="Key example showing the correct usage of emphasized switches. The first switch group in a form enable local storage and wifi features. The two switches are selected and the track color is blue. The second switch group show one switch in the not emphasized option inside an application panel. The switch selected and the track color is dark gray."
When to use a standalone switch?#
Standalone switches should be used in situations where the context is clear without an associated text label. For example, a switch located at the top of a panel next to the panel's title makes it clear that the switch will enable/disable the panel options.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/bbd46/bbd467b08516f70db8c02235304b448925498388" alt="Key example showing the correct usage of a standalone switch. A not emphasized switch without a label is placed inside an application panel. The switch is selected."
Switch or checkbox?#
Switches are best used for communicating activation (e.g., on/off states), while checkboxes are best used for communicating selection (e.g., multiple table rows). Switches, unlike checkboxes, can't have an error state.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/44833/4483305cfdde1338210c315d315d3b80aaa81db4" alt="Key example showing the correct usage for switches. A single switch with the label "Wifi" is selected."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/264ba/264ba04e9e903faf4702f05efa45033b1d918a78" alt="Key example showing the incorrect usage of a switch. A switch labeled "agree to terms" is selected."
Representing mixed values#
When a switch represents multiple values that are not identical, the switch should appear as not selected. Any subsequent click or tap should select the switch, and update all values to be selected. Another click or tap after that should deselect the switch, and update all values to be not selected.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f65a7/f65a78fe9bc83b9f032d5a78e95dece5a95e7b9e" alt="Key example showing correct way to to show multiple switches with mixed values. One switch, label All effects, is in the not selected state. This applies to a group of 3 switches, labels Reverb, Echo, Chorus. Reverb and Chorus are in the selected state, while Echo is not selected, so the All effects switch is also not selected."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/8dec5/8dec5f2312bc7776210beb87ad09a07a17fae5b5" alt="Key example showing incorrect way to show multiple switches with mixed values. One switch, label All effects, is neither in the selected or not selected state. This is shown in context to a group of 3 switches, labels Reverb, Echo, Chorus. Reverb and Chorus are in the selected state, while Echo is not selected."
No partial state#
Switches can only be on or off. Indeterminate switches don’t exist in accessibility APIs, so it’s not possible to make an indeterminate switch accessible. If you need to show a partial state, use a checkbox instead of a switch.
When a parent switch represents a group of switches, it should be turned off unless all of the switches are on (turning the parent switch on turns all of the switches on).
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/95db0/95db009497940ea9fe97f5ce7348a14cb3cd04cd" alt="Key example showing the incorrect usage of a partial state. A single switch on top of a group of three switches has the handle set in the center of the track. Two of the grouped switches are selected and one is unselected."
Content standards#
A label for a switch describes a setting that is either on or off — two mutually exclusive states. Use a short description (1-3 words) of the setting. Try to include all necessary information in the label, but it’s OK to add clarifying text after to supplement if needed.
Keep in mind that when a user takes an action on a switch, that action will often affect other content in an experience. Think systematically to ensure that all labels are paralleling each other in their writing.
Consider if the label should use a verb or a noun#
A switch shows a state of persistence for something — a noun or a proper noun — as either being “on” or “off.” A verb isn’t usually needed to communicate the thing being turned on or off, but there can be instances where phrasing the label as a verb can aid in clarity. Just try to keep switches consistently using either verbs or nouns if you have more than one of them in a single view.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/9fe62/9fe62b03fa5bf490aa259f09cf5fdf594ed2ee77" alt="Correct usage of how to write labels for a switch. Labels, Set date and time automatically. Show admin view."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/ba30c/ba30c1e6c433a18e640ab1a11028f2ebe396eedd" alt="Incorrect usage of how to write labels for a switch. Labels, Date and time automatic. Admin."
Avoid using verb phrases related to a state of activity#
Avoid using verb phrases related to activity states in a switch label, such as “turn on” or “turn off.” A switch is naturally either in a state of being on or off — active or inactive — so repeating in the label that something is “on” or “off” is redundant and clutters an interface.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/facf1/facf1851b0258cd1b55b299effe6c034744bf85c" alt="Correct usage of how to write labels for a switch. Label, Wifi assist."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/1af49/1af490eed9f8067eef3b6780d659dbce33cc35bc" alt="Incorrect usage of how to write labels for a switch. Label, turn on Wifi assist."
Use a neutral tone#
Because switches are used for controls and utility, their labels are written in a neutral, utilitarian way. There’s no need for overly celebratory language.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/488b4/488b443e21f62c9d6c3e2f5037d2dd8d3e9d01d7" alt="Correct usage of how to write labels for a switch. Label, Wifi assist."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/23ef5/23ef52da2a5adbf3944a8e5ffb282e3dbb0647be" alt="Incorrect usage of how to write labels for a switch. Label, Turn on wifi assist for extra speed!"
Use “you” or “your” if needed to refer to the user directly#
Describe switches objectively by using only the names of features or settings, or what those features and settings will do. In the case where it’s necessary to refer to a user directly, do so sparingly and use the second person “you/your.” We aim to be conversational and
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/f3994/f39948cf61874b44fb4b4f0d7e3573e17fe34da4" alt="Correct usage of how to write labels for a switch. Labels, Show unresolved comments. Show your unresolved comments."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/8cc90/8cc909352f05a71e0552cb1e750fa6ee9e3a4a88" alt="Incorrect usage of how to write labels for a switch. Labels, My unresolved. Show my unresolved comments."
Use sentence case#
Following Adobe’s UX writing style, labels for switches are written in
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/8c7f7/8c7f730d45f7c017950db4c4ca77bc8f7620fd93" alt="Correct usage of how to write labels for a switch. Labels, Save cloud documents locally, using sentence case. Always add to Project, using sentence case except for the word “Project,” which is capitalized."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/e06e2/e06e2a2cd4c805c2377a8c17e6f4ecdf7ad4d45e" alt="Incorrect usage of how to write labels for a switch. Labels, Save Cloud Documents Locally. Always Add to Projects. Both label examples using title case where all words are capitalized."
Internationalization#
Keyboard interactions#
Changelog#
- Updated read-only option design
- Updated disabled text color (from gray-500 to gray-400)
- Updated all colors to 6.0.0
- Added size option
- Updated keyboard focus state to be more accessible
- Added read-only option
- Added text overflow behavior
- Replaced “standard/quiet” variants with emphasis (“emphasized/not emphasized”)
- 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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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.
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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.