apps/docs/content/docs/en/react/components/(buttons)/toggle-button-group.mdx
import { ToggleButtonGroup, ToggleButton } from '@heroui/react';
<ComponentPreview name="toggle-button-group-basic" />
Import the ToggleButtonGroup component and access all parts using dot notation.
import { ToggleButtonGroup, ToggleButton } from '@heroui/react';
export default () => (
<ToggleButtonGroup selectionMode="multiple">
<ToggleButton id="first">First</ToggleButton>
<ToggleButton id="second">
<ToggleButtonGroup.Separator />
Second
</ToggleButton>
<ToggleButton id="third">
<ToggleButtonGroup.Separator />
Third
</ToggleButton>
</ToggleButtonGroup>
);
<ComponentPreview name="toggle-button-group-sizes" />
<ComponentPreview name="toggle-button-group-orientation" />
Use isDetached to separate buttons with gaps instead of connecting them.
<ComponentPreview name="toggle-button-group-attached" />
<ComponentPreview name="toggle-button-group-full-width" />
Use selectionMode="single" for mutually exclusive choices or selectionMode="multiple" for independent toggles.
<ComponentPreview name="toggle-button-group-selection-mode" />
<ComponentPreview name="toggle-button-group-controlled" />
<ComponentPreview name="toggle-button-group-disabled" />
Simply omit the <ToggleButtonGroup.Separator /> component from your buttons.
<ComponentPreview name="toggle-button-group-without-separator" />
<RelatedComponents component="toggle-button-group" />import { ToggleButtonGroup, ToggleButton } from '@heroui/react';
function CustomToggleButtonGroup() {
return (
<ToggleButtonGroup className="bg-purple-100" selectionMode="single">
<ToggleButton id="a">Option A</ToggleButton>
<ToggleButton id="b">
<ToggleButtonGroup.Separator />
Option B
</ToggleButton>
</ToggleButtonGroup>
);
}
To customize the ToggleButtonGroup component classes, you can use the @layer components directive.
@layer components {
.toggle-button-group {
@apply rounded-lg;
}
.toggle-button-group__separator {
@apply opacity-25;
}
.toggle-button-group--full-width {
@apply w-full;
}
}
HeroUI follows the BEM methodology to ensure component variants and states are reusable and easy to customize.
The ToggleButtonGroup component uses these CSS classes (View source styles):
.toggle-button-group - Base container styles.toggle-button-group--horizontal - Horizontal orientation.toggle-button-group--vertical - Vertical orientation.toggle-button-group--full-width - Full width modifier.toggle-button-group__separator - Separator element between buttons.toggle-button-group--detached - Detached mode (separated buttons with gaps)Inherits from React Aria ToggleButtonGroup.
| Prop | Type | Default | Description |
|---|---|---|---|
selectionMode | "single" | "multiple" | "single" | Whether one or multiple buttons can be selected |
selectedKeys | Iterable<Key> | - | Controlled selection state |
defaultSelectedKeys | Iterable<Key> | - | Default selected keys (uncontrolled) |
onSelectionChange | (keys: Set<Key>) => void | - | Called when selection changes |
disallowEmptySelection | boolean | false | Prevents clearing all selections |
orientation | "horizontal" | "vertical" | "horizontal" | Layout direction |
size | "sm" | "md" | "lg" | "md" | Size propagated to child ToggleButtons |
isDetached | boolean | false | Whether buttons are visually separated with gaps |
fullWidth | boolean | false | Whether the group fills available width |
isDisabled | boolean | false | Disables all buttons in the group |
className | string | - | Additional CSS classes |
| Prop | Type | Default | Description |
|---|---|---|---|
className | string | - | Additional CSS classes |
size to all child ToggleButton componentsid prop that corresponds to the keys used in selectedKeys / defaultSelectedKeysisDisabled prop is handled natively by React Aria and disables all child ToggleButtons — individual buttons can override this by setting isDisabled={false}<ToggleButtonGroup.Separator /> inside each ToggleButton (except the first) to show dividers between buttonsdisallowEmptySelection with selectionMode="single" to ensure one option is always selected