Button group
A button group is a grouping of buttons whose actions are related to each other.
data:image/s3,"s3://crabby-images/deb4f/deb4ff557bac151d811a2343fb75f2a7700de268" alt="Text field with label Email address, value email@adobe.com, and two buttons underneath aligned to the right of the text field. A accent (blue) fill button with label Submit on the right, and a secondary outline button with label Cancel on the left."
data:image/s3,"s3://crabby-images/a34d1/a34d16444dafe60b14c08fab566f0483c0d7b803" alt="Text field with label Email address, value email@adobe.com, and two buttons underneath aligned to the right of the text field. A accent (blue) fill button with label Submit on the right, and a secondary outline button with label Cancel on the left."
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.
Usage guidelines#
Use the recommended option for subsequent actions#
The most critical action within a button group should be an
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/af966/af96650dc1078b37f389363c196576628d8fc79b" alt="Key example showing correct usage of button styles within a button group. From right to left: accent fill button, label Continue; secondary outline button, label Edit; secondary outline button, label Cancel."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/ded8e/ded8e24ef03d351d19f4ee5fcf48315570f8dcc0" alt="Key examples showing incorrect usage of button styles within a button group. First example, 2 different styles combined from right to left: accent fill button, label Continue; accent outline button, label Edit; accent outline button, label Cancel. Second example, 2 different styles combined from right to left: primary fill button, label Continue; primary outline button, label Edit; primary outline button, label Cancel. Third example, 3 different styles combined from right to left: primary fill button, label Continue; primary outline button, label Edit; negative outline button, label Cancel. Fourth example, 2 different styles combined from right to left: secondary fill button, label Continue; secondary outline button, label Edit; secondary outline button, label Cancel."
Align button groups based on content#
Button groups are aligned contextually. In general, button groups are left-aligned to follow content such as a block of text. They are center-aligned in the context of an empty state. And, they should be right-aligned inside container components such as dialogs, popovers, or cards.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/d65b9/d65b9350a619db3e928b677bf340e59e26c78ba2" alt="Key examples showing correct button group alignment. Left-aligned button group following page content. Right-aligned button group inside a container."
Respect button order within a group#
The order of button priority should match the alignment of surrounding text. When text is left-aligned, buttons should be arranged so that the leftmost button is the most critical. When text is right- or center- aligned, the most critical action should be the furthest right.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/8df25/8df25ea25791dc888b4db0be4d766ec885d57ab2" alt="Key examples showing correct button order within a button group. Left-aligned button group to follow left-aligned content with main action on the left-most as accent fill button, label Submit, secondary outline button, label Cancel. Center-aligned button group to follow center-aligned content with main action on the right-most as accent fill button, label Upload, secondary outline button on the left, label Search library. Right-aligned button group within a container with main action on the right-most as accent fill button, label Confirm, secondary outline button on the left, label Cancel."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/a9d00/a9d0013e57960ce1c0ba4382ddc12bcec390af60" alt="Key example showing incorrect button order within a button group. Left-aligned button group to follow left-aligned content, with main action on the right-most as accent fill button, label Submit, secondary outline button, label Cancel."
Use icons only for the most critical actions#
Not all buttons in a group require an icon, but buttons with icons should always be of a higher priority than ones without icons. If the most critical action in a group doesn’t have an icon, don’t use icons in the remaining lower-level actions.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/1dbee/1dbeee41b19c3c78566009003d63141b537c692c" alt="Key example showing correct usage of icons within a button group. Main action as accent fill button with icon, label Share. Secondary outline button without an icon, label Edit."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/d930c/d930c813053bb43da66146437c37663c55706eb3" alt="Key example showing incorrect usage of icons within a button group. Main action as accent fill button without icon, label Confirm. Secondary outline button with icon, label Share. Secondary outline button without icon, label Edit."
Use a button group to show additional actions#
Instead of a single split button (now a deprecated component), use a button group to show any additional actions related to the most critical action.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/d1385/d13850be7b76da68ce82a75057755be0abf0f94e" alt="Key example of the correct way to use a button group to show additional actions. A button group contains an accent button, label Open, and an icon-only More actions button."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/fd3da/fd3dacb3a94792cdcd0a3834445f7f1513ac122f" alt="Key example of an incorrect way to show additional actions. Two split buttons, both labeled Open, one with an icon-only expand affordance and the other with a More actions affordance."
Internationalization#
Keyboard interactions#
Changelog#
- Updated disabled text color (from gray-500 to gray-400) and disabled border color (from gray-200 to gray-300)
- Updated all colors to 6.0.0
- Added size option
- This component has been added to the website
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/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
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).
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.
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/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/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.