diff options
author | ilyayudovin <46264063+ilyayudovin@users.noreply.github.com> | 2020-06-27 19:18:33 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-27 19:18:33 +0300 |
commit | 5057fe763d423be607336d6b839909843c5a2567 (patch) | |
tree | 83356dd3ee0871e5226aa9ed67d9905f35e323f2 /src/pages/ProfilePage/MoreMenu.tsx | |
parent | 9c4d6400ae83a32853d4437236f42796f08dbde7 (diff) | |
parent | 5b08023e0aa0e626264673ebb86dc82299a3b54b (diff) | |
download | which-ui-5057fe763d423be607336d6b839909843c5a2567.tar.gz |
Merge pull request #46 from which-ecosystem/profile
profile
Diffstat (limited to 'src/pages/ProfilePage/MoreMenu.tsx')
-rw-r--r-- | src/pages/ProfilePage/MoreMenu.tsx | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/pages/ProfilePage/MoreMenu.tsx b/src/pages/ProfilePage/MoreMenu.tsx new file mode 100644 index 0000000..bf3347b --- /dev/null +++ b/src/pages/ProfilePage/MoreMenu.tsx @@ -0,0 +1,66 @@ +import React from 'react'; +import IconButton from '@material-ui/core/IconButton'; +import Menu from '@material-ui/core/Menu'; +import MenuItem from '@material-ui/core/MenuItem'; +import MoreHorizIcon from '@material-ui/icons/MoreHoriz'; +import { makeStyles } from '@material-ui/core'; + +interface PropTypes { + logOut: () => void; +} + +const ITEM_HEIGHT = 48; + +const useStyles = makeStyles({ + moreMenu: { + position: 'absolute', + right: 10, + zIndex: 100 + } +}); + +const MoreMenu: React.FC<PropTypes> = ({ logOut }) => { + const classes = useStyles(); + const [anchorEl, setAnchorEl] = React.useState<HTMLButtonElement | null>(null); + const open = Boolean(anchorEl); + + const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => { + setAnchorEl(event.currentTarget); + }; + + const handleClose = () => { + setAnchorEl(null); + }; + + return ( + <div className={classes.moreMenu}> + <div> + <IconButton + aria-label="more" + aria-controls="long-menu" + aria-haspopup="true" + onClick={handleClick} + > + <MoreHorizIcon /> + </IconButton> + <Menu + id="long-menu" + anchorEl={anchorEl} + keepMounted + open={open} + onClose={handleClose} + PaperProps={{ + style: { + maxHeight: ITEM_HEIGHT * 4.5, + width: '20ch' + } + }} + > + <MenuItem onClick={logOut}>Log out</MenuItem> + </Menu> + </div> + </div> + ); +}; + +export default MoreMenu; |