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
50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
import List from '@mui/joy/List';
|
|
import ListItem from '@mui/joy/ListItem';
|
|
import ListItemDecorator from '@mui/joy/ListItemDecorator';
|
|
import Radio from '@mui/joy/Radio';
|
|
import RadioGroup from '@mui/joy/RadioGroup';
|
|
import Person from '@mui/icons-material/Person';
|
|
import People from '@mui/icons-material/People';
|
|
import Apartment from '@mui/icons-material/Apartment';
|
|
|
|
export default function RadioPositionEnd() {
|
|
return (
|
|
<RadioGroup aria-label="Your plan" name="people" defaultValue="Individual">
|
|
<List
|
|
sx={{
|
|
minWidth: 240,
|
|
'--List-gap': '0.5rem',
|
|
'--ListItem-paddingY': '1rem',
|
|
'--ListItem-radius': '8px',
|
|
'--ListItemDecorator-size': '32px',
|
|
}}
|
|
>
|
|
{['Individual', 'Team', 'Enterprise'].map((item, index) => (
|
|
<ListItem variant="outlined" key={item} sx={{ boxShadow: 'sm' }}>
|
|
<ListItemDecorator>
|
|
{[<Person />, <People />, <Apartment />][index]}
|
|
</ListItemDecorator>
|
|
<Radio
|
|
overlay
|
|
value={item}
|
|
label={item}
|
|
sx={{ flexGrow: 1, flexDirection: 'row-reverse' }}
|
|
slotProps={{
|
|
action: ({ checked }) => ({
|
|
sx: (theme) => ({
|
|
...(checked && {
|
|
inset: -1,
|
|
border: '2px solid',
|
|
borderColor: theme.vars.palette.primary[500],
|
|
}),
|
|
}),
|
|
}),
|
|
}}
|
|
/>
|
|
</ListItem>
|
|
))}
|
|
</List>
|
|
</RadioGroup>
|
|
);
|
|
}
|