Description
The ToggleButton component should be used to toggle on or off a limited number of choices.
You can use the React component <ToggleButton.Group>
to wrap several ToggleButton
. This makes it easier to handle the event on_change
on a higher level - as well as several other context related properties.
By default the ToggleButton.Group
is single-select, like a Radio button. But You can easily enable multiselect
as well.
How to use
You can use the ToggleButton in different modes. Either as a stand-alone component or together with the ToggleButton.Group
context.
Multi select
If multiselect
is enabled on the group, several items can be enabled/disabled by the user.
You would have to decide if you want to track the state by yourself by using the checked
property, or you want just to listen to the internal state with on_change(({ values } => console.log(values)))
. You have then to give every item also a value
property.
Demos
Unchecked ToggleButton
<ToggleButtonlabel="Label:"text="Toggle Me"/>
Checked ToggleButton
<ToggleButtonlabel="Label:"text="Checked ToggleButton"checkedon_change={({ checked }) => { console.log('on_change', checked) }}/>
Default ToggleButton group
<ToggleButton.Grouplabel="ToggleButton Group:"value="first"on_change={({ value }) => { console.log('on_change', value) }}><ToggleButton text="First" value="first" /><ToggleButton text="Second" value="second" /><ToggleButtontext="Third"value="third"/></ToggleButton.Group>
Multi-select ToggleButton group
<ToggleButton.Grouplabel="Multi-select:"multiselect="true"values={['first', 'third']}on_change={({ values }) => { console.log('on_change', values) }}><ToggleButton text="First" value="first" /><ToggleButton text="Second" value="second" /><ToggleButtontext="Third"value="third"/></ToggleButton.Group>
checkbox
variant and multiselect
Vertical aligned ToggleButton group with <ToggleButton.Grouplabel="Vertical Group:"layout_direction="column"multiselect={true}variant="checkbox"on_change={({ values }) => { console.log('on_change', values) }}><ToggleButton text="First" value="first" /><ToggleButton text="Second" value="second" /><ToggleButtontext="Third"value="third"checked/></ToggleButton.Group>
multiselect
with a status message
ToggleButton group as <ToggleButton.Grouplabel="ToggleButton Group with status:"status="Error message"multiselect={true}on_change={({ values }) => { console.log('on_change', values) }}><ToggleButtontext="First"value="first"/><ToggleButtontext="Second"value="second"checked/><ToggleButtontext="Third"value="third"checked="true"/></ToggleButton.Group>
radio
ToggleButton with status messages and a group variant as <ToggleButton.Grouplabel="ToggleButtons with status:"variant="radio"on_change={({ value }) => { console.log('on_change', value) }}><ToggleButtontext="First"value="first"status="error"/><ToggleButtontext="Second"value="second"checkedstatus="Error message"/><ToggleButtontext="Third"value="third"status="Info message"status_state="info"/></ToggleButton.Group>
Disabled ToggleButton group
<ToggleButton.Grouplabel="Disabled Group:"disabledvariant="checkbox"><ToggleButton text="First" value="first" /><ToggleButton text="Second" value="second" /><ToggleButtontext="Third"value="third"checked/></ToggleButton.Group>
ToggleButtons with a suffix
<ToggleButton.Grouplabel="With suffixes:"suffix={<HelpButton title="Group suffix">Group suffix</HelpButton>}><ToggleButton text="First" value="first" /><ToggleButtontext="Second"value="second"status="Error message"suffix={<HelpButton title="Button suffix">Button suffix</HelpButton>}/><ToggleButtontext="Third"value="third"checked/></ToggleButton.Group>
ToggleButtons with icons only
<ToggleButton.Group label="Icons only:"><ToggleButton icon="bell" value="first" checked /><ToggleButton icon="loupe" value="second" /><ToggleButton icon="calendar" value="third" /></ToggleButton.Group>