aboutsummaryrefslogtreecommitdiff
path: root/src/Pages/ProfilePage/ProfileInfo.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/Pages/ProfilePage/ProfileInfo.tsx')
-rw-r--r--src/Pages/ProfilePage/ProfileInfo.tsx75
1 files changed, 75 insertions, 0 deletions
diff --git a/src/Pages/ProfilePage/ProfileInfo.tsx b/src/Pages/ProfilePage/ProfileInfo.tsx
new file mode 100644
index 0000000..8fce8df
--- /dev/null
+++ b/src/Pages/ProfilePage/ProfileInfo.tsx
@@ -0,0 +1,75 @@
+import React, { useState } from 'react';
+import { Avatar } from '@material-ui/core/';
+import { makeStyles } from '@material-ui/core/styles';
+import Button from '@material-ui/core/Button/Button';
+import { User } from '../../types';
+import { get } from '../../requests';
+
+interface PropTypes {
+ id: string;
+ setUser: (newUser: User | undefined) => void;
+}
+
+const useStyles = makeStyles({
+ avatar: {
+ margin: '0 auto',
+ width: 150,
+ height: 150,
+ marginBottom: 10
+ },
+ name: {
+ fontSize: 20,
+ textAlign: 'center'
+ },
+ profileMenu: {
+ display: 'flex',
+ width: '100%',
+ height: 50,
+ borderBottom: '1px solid lightgray',
+ margin: '50px 0'
+ },
+ menuButton: {
+ width: 200,
+ height: 50,
+ paddingTop: 15,
+ textAlign: 'center'
+ }
+});
+
+const ProfileInfo: React.FC<PropTypes> = ({ id, setUser }) => {
+ const [userInfo, setUserInfo] = useState<User>();
+
+ get(`/users/${id}`).then(response => {
+ setUserInfo(response.data);
+ });
+
+ const classes = useStyles();
+
+ const LogOut = () => {
+ localStorage.clear();
+ setUser(undefined);
+ };
+
+ return (
+ <div>
+ <Avatar className={classes.avatar} src={userInfo?.avatarUrl} />
+ <div className={classes.name}>
+ {userInfo?.name}
+ </div>
+ <div className={classes.profileMenu}>
+ <div style={{ borderBottom: '1px solid green', color: 'green' }} className={classes.menuButton}>
+ Polls
+ </div>
+ <div className={classes.menuButton}>
+ Followers
+ </div>
+ <div className={classes.menuButton}>
+ Following
+ </div>
+ </div>
+ <Button variant="contained" onClick={LogOut}>Log Out</Button>
+ </div>
+ );
+};
+
+export default ProfileInfo;