Files
automatisch/packages/web/src/components/SplitButton/index.jsx

119 lines
3.4 KiB
JavaScript

import PropTypes from 'prop-types';
import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
import Button from '@mui/material/Button';
import ButtonGroup from '@mui/material/ButtonGroup';
import { ClickAwayListener } from '@mui/base/ClickAwayListener';
import Grow from '@mui/material/Grow';
import MenuItem from '@mui/material/MenuItem';
import MenuList from '@mui/material/MenuList';
import Paper from '@mui/material/Paper';
import Popper from '@mui/material/Popper';
import * as React from 'react';
import { Link } from 'react-router-dom';
export default function SplitButton(props) {
const { options, disabled, defaultActionIndex = 0 } = props;
const [open, setOpen] = React.useState(false);
const anchorRef = React.useRef(null);
const multiOptions = options.length > 1;
const selectedOption = options[defaultActionIndex];
const handleToggle = () => {
setOpen((prevOpen) => !prevOpen);
};
const handleClose = (event) => {
if (anchorRef.current && anchorRef.current.contains(event.target)) {
return;
}
setOpen(false);
};
return (
<React.Fragment>
<ButtonGroup
variant="contained"
ref={anchorRef}
aria-label="split button"
disabled={disabled}
>
<Button
size="large"
data-test={selectedOption['data-test']}
component={Link}
to={selectedOption.to}
sx={{
// Link component causes style loss in ButtonGroup
borderRadius: 0,
borderRight: '1px solid #bdbdbd',
}}
disabled={selectedOption.disabled}
>
{selectedOption.label}
</Button>
{multiOptions && (
<Button size="small" onClick={handleToggle} sx={{ borderRadius: 0 }}>
<ArrowDropDownIcon />
</Button>
)}
</ButtonGroup>
{multiOptions && (
<Popper
sx={{
zIndex: 1,
}}
open={open}
anchorEl={anchorRef.current}
transition
disablePortal
>
{({ TransitionProps, placement }) => (
<Grow
{...TransitionProps}
style={{
transformOrigin:
placement === 'bottom' ? 'center top' : 'center bottom',
}}
>
<Paper>
<ClickAwayListener onClickAway={handleClose}>
<MenuList autoFocusItem>
{options.map((option, index) => (
<MenuItem
key={option.key}
selected={index === defaultActionIndex}
component={Link}
to={option.to}
disabled={option.disabled}
>
{option.label}
</MenuItem>
))}
</MenuList>
</ClickAwayListener>
</Paper>
</Grow>
)}
</Popper>
)}
</React.Fragment>
);
}
SplitButton.propTypes = {
options: PropTypes.arrayOf(
PropTypes.shape({
label: PropTypes.string.isRequired,
key: PropTypes.string.isRequired,
'data-test': PropTypes.string.isRequired,
to: PropTypes.string.isRequired,
disabled: PropTypes.bool.isRequired,
}).isRequired,
).isRequired,
disabled: PropTypes.bool,
defaultActionIndex: PropTypes.number,
};