Some checks failed
No response / noResponse (push) Has been cancelled
CI / Continuous releases (push) Has been cancelled
CI / test-dev (macos-latest) (push) Has been cancelled
CI / test-dev (ubuntu-latest) (push) Has been cancelled
CI / test-dev (windows-latest) (push) Has been cancelled
Maintenance / main (push) Has been cancelled
Scorecards supply-chain security / Scorecards analysis (push) Has been cancelled
CodeQL / Analyze (push) Has been cancelled
67 lines
1.9 KiB
JavaScript
67 lines
1.9 KiB
JavaScript
import * as React from 'react';
|
|
import Box from '@mui/joy/Box';
|
|
import Button from '@mui/joy/Button';
|
|
import IconButton from '@mui/joy/IconButton';
|
|
import ToggleButtonGroup from '@mui/joy/ToggleButtonGroup';
|
|
import FormatItalicIcon from '@mui/icons-material/FormatItalic';
|
|
import FormatUnderlinedIcon from '@mui/icons-material/FormatUnderlined';
|
|
import JoyUsageDemo from 'docs/src/modules/components/JoyUsageDemo';
|
|
|
|
export default function ToggleGroupUsage() {
|
|
const [value, setValue] = React.useState('bold');
|
|
const [values, setValues] = React.useState([value]);
|
|
return (
|
|
<JoyUsageDemo
|
|
componentName="ToggleButtonGroup"
|
|
data={[
|
|
{
|
|
propName: 'variant',
|
|
knob: 'radio',
|
|
defaultValue: 'outlined',
|
|
options: ['plain', 'outlined', 'soft', 'solid'],
|
|
},
|
|
{
|
|
propName: 'color',
|
|
knob: 'color',
|
|
defaultValue: 'neutral',
|
|
},
|
|
{
|
|
propName: 'size',
|
|
knob: 'radio',
|
|
options: ['sm', 'md', 'lg'],
|
|
defaultValue: 'md',
|
|
},
|
|
{
|
|
propName: 'children',
|
|
defaultValue: `<Button />
|
|
<IconButton />
|
|
<IconButton />`,
|
|
},
|
|
]}
|
|
renderDemo={(props) => (
|
|
<Box sx={{ display: 'flex', gap: 2 }}>
|
|
<ToggleButtonGroup
|
|
value={props.exclusive ? value : values}
|
|
onChange={(event, newValue) => {
|
|
if (Array.isArray(newValue)) {
|
|
setValues(newValue);
|
|
} else {
|
|
setValue(newValue);
|
|
}
|
|
}}
|
|
{...props}
|
|
>
|
|
<Button value="bold">Bold</Button>
|
|
<IconButton value="italic">
|
|
<FormatItalicIcon />
|
|
</IconButton>
|
|
<IconButton value="underlined">
|
|
<FormatUnderlinedIcon />
|
|
</IconButton>
|
|
</ToggleButtonGroup>
|
|
</Box>
|
|
)}
|
|
/>
|
|
);
|
|
}
|