- const shouldShowMenu = useMemo(
- () => Object.values(visibilityMap).some((v) => v === false),
- [visibilityMap]
- );
- if (!shouldShowMenu) {
- return null;
- }
- return (
- <div className={className}>
- <IconButton
- aria-label="more"
- aria-controls="long-menu"
- aria-haspopup="true"
- onClick={handleClick}
- >
- <MoreVertIcon />
- </IconButton>
- <Menu
- id="long-menu"
- anchorEl={anchorEl}
- keepMounted
- open={open}
- onClose={handleClose}
- >
- {React.Children.map(children, (child:any) => {
- if (!visibilityMap[child.props["data-targetid"]]) {
- return (
- <MenuItem key={child} onClick={handleClose}>
- {React.cloneElement(child, {
- className: classnames(child.className, classes.inOverflowMenu)
+export const OverflowMenu = withStyles(styles)((props: OverflowMenuProps & WithStyles<CssRules>) => {
+ const { children, className, visibilityMap, classes } = props;
+ const [anchorEl, setAnchorEl] = useState(null);
+ const open = Boolean(anchorEl);
+ const handleClick = (event) => {
+ setAnchorEl(event.currentTarget);
+ };
+
+ const handleClose = () => {
+ setAnchorEl(null);
+ };
+
+ const shouldShowMenu = useMemo(() => Object.values(visibilityMap).some((v) => v === false), [visibilityMap]);
+ if (!shouldShowMenu) {
+ return null;
+ }
+ return (
+ <div className={className}>
+ <Tooltip title="More Options" disableFocusListener>
+ <IconButton
+ aria-label='more'
+ aria-controls='long-menu'
+ aria-haspopup='true'
+ onClick={handleClick}
+ className={classes.openMenuButton}
+ >
+ <DoubleRightArrows />
+ </IconButton>
+ </Tooltip>
+ <Menu
+ id='long-menu'
+ anchorEl={anchorEl}
+ keepMounted
+ open={open}
+ onClose={handleClose}
+ disableAutoFocusItem
+ className={classes.menu}
+ >
+ {React.Children.map(children, (child: any) => {
+ if (!visibilityMap[child.props['data-targetid']]) {
+ return <MenuItem
+ key={child}
+ onClick={handleClose}
+ className={classes.menuItem}
+ >
+ {React.cloneElement(child, {
+ className: classnames(classes.menuElement),
+ })}
+ </MenuItem>
+ }
+ return null;