Button group
An EuiButtonGroup is for indicating selection only. They utilize the type="single" or "multi" prop to determine whether multiple or only single selections are allowed per group.
Accessibility recommendation
In order for groups to be properly read as groups with a title, the legend prop is required. This is only for accessibility, however, so it will be visibly hidden.
Icon only button group
Use the isIconOnly prop when displaying a group of icon-only buttons.
Button group tooltips
Buttons within a button group will automatically display a default browser tooltip containing the button label text. This can be customized or unset via the title property in your options button configuration.
To instead display an EuiToolTip around your button(s), pass the toolTipContent property. You can also use toolTipProps to customize tooltip placement, title, and any other prop that EuiToolTip accepts.
Button group in forms
PatternWhen using button groups within compressed forms, match the form elements by adding buttonSize="compressed". Compressed groups should always be fullWidth so they line up nicely in their small container unless they are icon only.
For a more detailed example of how to integrate with forms, see the "Complex example" on the compressed forms page.
Props
EuiButtonGroup
| Prop | Description and type | Default value | 
|---|---|---|
| Prop legend# | Description and type A hidden group title (required for accessibility) string | Default value Required | 
| Prop onChange# | Description and type Single: Returns the  ((id: string, value?: any) => void) | ((id: string) => void) | Default value Required | 
| Prop className# | Description and type Type:  string | Default value | 
| Prop aria-label# | Description and type Defines a string value that labels the current element. string | Default value | 
| Prop data-test-subj# | Description and type Type:  string | Default value | 
| Prop css# | Description and type Type:  Interpolation<Theme> | Default value | 
| Prop buttonSize# | Description and type Typical sizing is  "s" | "m" | "compressed" | Default value s | 
| Prop isDisabled# | Description and type Type:  boolean | Default value false | 
| Prop isFullWidth# | Description and type Expands the whole group to the full width of the container. boolean | Default value false | 
| Prop isIconOnly# | Description and type Hides the label to only show the  boolean | Default value false | 
| Prop color# | Description and type Any of the named color palette options. Do not use the following colors for standalone buttons directly, 
 "primary" | "danger" | "text" | "accent" | "accentSecondary" | "success" | "warning" | Default value text | 
| Prop type# | Description and type Actual type is  "single" | "multi" | Default value single | 
| Prop options# | Description and type An array of EuiButtonGroupOptionProps EuiButtonGroupOptionProps[] | Default value [] | 
| Prop name# | Description and type @deprecated No longer needed. You can safely remove this prop entirely string | Default value | 
| Prop idSelected# | Description and type Styles the selected option to look selected (usually with  string | Default value | 
| Prop idToSelectedMap# | Description and type A map of  { [id: string]: boolean; } | Default value {} |