aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorilyayudovin <ilyayudovin123@gmail.com>2020-06-26 02:49:13 +0300
committerilyayudovin <ilyayudovin123@gmail.com>2020-06-26 02:49:13 +0300
commitc5b771b87b92260e19f0c43ed83151c8e3d49f73 (patch)
treed0bb715e5e3c2e55a0b4356ac09e31c6811bc3be
parent9852ed44fca2c71e6992e583d4cd3b874b6b18fa (diff)
downloadwhich-ui-c5b771b87b92260e19f0c43ed83151c8e3d49f73.tar.gz
feat: add more menu button to profile
-rw-r--r--src/pages/ProfilePage/MoreMenu.tsx66
-rw-r--r--src/pages/ProfilePage/ProfileInfo.tsx74
2 files changed, 112 insertions, 28 deletions
diff --git a/src/pages/ProfilePage/MoreMenu.tsx b/src/pages/ProfilePage/MoreMenu.tsx
new file mode 100644
index 0000000..a4bc993
--- /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(null);
+ const open = Boolean(anchorEl);
+
+ const handleClick = (event: any) => {
+ 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;
diff --git a/src/pages/ProfilePage/ProfileInfo.tsx b/src/pages/ProfilePage/ProfileInfo.tsx
index 18a9fca..7489bc5 100644
--- a/src/pages/ProfilePage/ProfileInfo.tsx
+++ b/src/pages/ProfilePage/ProfileInfo.tsx
@@ -1,9 +1,9 @@
import React from 'react';
import {Avatar, Badge, withStyles} from '@material-ui/core/';
-import { makeStyles } from '@material-ui/core/styles';
-import Button from '@material-ui/core/Button/Button';
-import { User } from 'which-types';
+import {makeStyles} from '@material-ui/core/styles';
+import {User} from 'which-types';
import CameraAltIcon from '@material-ui/icons/CameraAlt';
+import MoreMenu from "./MoreMenu";
interface PropTypes {
user: User | undefined;
@@ -11,6 +11,9 @@ interface PropTypes {
}
const useStyles = makeStyles({
+ root: {
+ position: 'relative'
+ },
avatar: {
width: 150,
height: 150,
@@ -31,7 +34,6 @@ const useStyles = makeStyles({
menuButton: {
width: 200,
height: 50,
- paddingTop: 15,
textAlign: 'center'
},
badge: {
@@ -40,7 +42,18 @@ const useStyles = makeStyles({
avatarContainer: {
position: 'relative',
textAlign: 'center'
- }
+ },
+ menuNumber: {
+ fontWeight: 800,
+ color: 'black'
+ },
+ menuText: {
+ color: 'darkgray'
+ },
+ status: {
+ textAlign: 'center',
+ color: 'darkgray'
+ },
});
@@ -54,45 +67,50 @@ const StyledBadge = withStyles((theme) => ({
},
}))(Badge);
-const ProfileInfo: React.FC<PropTypes> = ({ user, logOut }) => {
+const ProfileInfo: React.FC<PropTypes> = ({user, logOut}) => {
const classes = useStyles();
return (
- <div>
+ <div className={classes.root}>
{
user?._id === localStorage.getItem('userId')
- ? <div className={classes.avatarContainer}>
- <StyledBadge
- overlap="circle"
- anchorOrigin={{
- vertical: 'bottom',
- horizontal: 'right',
- }}
- badgeContent={<CameraAltIcon />}
- >
- <Avatar className={classes.avatar} src={user?.avatarUrl} />
- </StyledBadge>
+ ?
+ <div>
+ <MoreMenu logOut={logOut}/>
+ <div className={classes.avatarContainer}>
+ <StyledBadge
+ overlap="circle"
+ anchorOrigin={{
+ vertical: 'bottom',
+ horizontal: 'right',
+ }}
+ badgeContent={<CameraAltIcon/>}
+ >
+ <Avatar className={classes.avatar} src={user?.avatarUrl}/>
+ </StyledBadge>
+ </div>
</div>
- : <Avatar className={classes.avatar} src={user?.avatarUrl} />
+ : <Avatar className={classes.avatar} src={user?.avatarUrl}/>
}
<div className={classes.name}>
{user?.username}
</div>
+ <div className={classes.status}>
+ I am not alcoholic
+ </div>
<div className={classes.profileMenu}>
- <div style={{ borderBottom: '1px solid green', color: 'green' }} className={classes.menuButton}>
- Polls
+ <div className={classes.menuButton}>
+ <div className={classes.menuNumber}>11</div>
+ <div className={classes.menuText}>Polls</div>
</div>
<div className={classes.menuButton}>
- Followers
+ <div className={classes.menuNumber}>05.05.2020</div>
+ <div className={classes.menuText}>Since</div>
</div>
<div className={classes.menuButton}>
- Following
+ <div className={classes.menuNumber}>17</div>
+ <div className={classes.menuText}>Total votes</div>
</div>
</div>
- {
- user?._id === localStorage.getItem('userId')
- ? <Button variant="contained" onClick={logOut}>Log Out</Button>
- : null
- }
</div>
);
};