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
91 lines
2.4 KiB
TypeScript
91 lines
2.4 KiB
TypeScript
import * as React from 'react';
|
|
import { Theme, useTheme } from '@mui/material/styles';
|
|
import Box from '@mui/material/Box';
|
|
import OutlinedInput from '@mui/material/OutlinedInput';
|
|
import InputLabel from '@mui/material/InputLabel';
|
|
import MenuItem from '@mui/material/MenuItem';
|
|
import FormControl from '@mui/material/FormControl';
|
|
import Select, { SelectChangeEvent } from '@mui/material/Select';
|
|
import Chip from '@mui/material/Chip';
|
|
|
|
const ITEM_HEIGHT = 48;
|
|
const ITEM_PADDING_TOP = 8;
|
|
const MenuProps = {
|
|
PaperProps: {
|
|
style: {
|
|
maxHeight: ITEM_HEIGHT * 4.5 + ITEM_PADDING_TOP,
|
|
width: 250,
|
|
},
|
|
},
|
|
};
|
|
|
|
const names = [
|
|
'Oliver Hansen',
|
|
'Van Henry',
|
|
'April Tucker',
|
|
'Ralph Hubbard',
|
|
'Omar Alexander',
|
|
'Carlos Abbott',
|
|
'Miriam Wagner',
|
|
'Bradley Wilkerson',
|
|
'Virginia Andrews',
|
|
'Kelly Snyder',
|
|
];
|
|
|
|
function getStyles(name: string, personName: readonly string[], theme: Theme) {
|
|
return {
|
|
fontWeight: personName.includes(name)
|
|
? theme.typography.fontWeightMedium
|
|
: theme.typography.fontWeightRegular,
|
|
};
|
|
}
|
|
|
|
export default function MultipleSelectChip() {
|
|
const theme = useTheme();
|
|
const [personName, setPersonName] = React.useState<string[]>([]);
|
|
|
|
const handleChange = (event: SelectChangeEvent<typeof personName>) => {
|
|
const {
|
|
target: { value },
|
|
} = event;
|
|
setPersonName(
|
|
// On autofill we get a stringified value.
|
|
typeof value === 'string' ? value.split(',') : value,
|
|
);
|
|
};
|
|
|
|
return (
|
|
<div>
|
|
<FormControl sx={{ m: 1, width: 300 }}>
|
|
<InputLabel id="demo-multiple-chip-label">Chip</InputLabel>
|
|
<Select
|
|
labelId="demo-multiple-chip-label"
|
|
id="demo-multiple-chip"
|
|
multiple
|
|
value={personName}
|
|
onChange={handleChange}
|
|
input={<OutlinedInput id="select-multiple-chip" label="Chip" />}
|
|
renderValue={(selected) => (
|
|
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 0.5 }}>
|
|
{selected.map((value) => (
|
|
<Chip key={value} label={value} />
|
|
))}
|
|
</Box>
|
|
)}
|
|
MenuProps={MenuProps}
|
|
>
|
|
{names.map((name) => (
|
|
<MenuItem
|
|
key={name}
|
|
value={name}
|
|
style={getStyles(name, personName, theme)}
|
|
>
|
|
{name}
|
|
</MenuItem>
|
|
))}
|
|
</Select>
|
|
</FormControl>
|
|
</div>
|
|
);
|
|
}
|