1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
import React from 'react';
import { Link as RouterLink } from 'react-router-dom';
import {
Button,
ClickAwayListener,
Grow,
Link,
MenuItem,
MenuList,
Paper,
Popper,
} from '@material-ui/core';
import Avatar from '@material-ui/core/Avatar';
import { makeStyles } from '@material-ui/core/styles';
import LockIcon from '@material-ui/icons/Lock';
import { useCurrentIdentityQuery } from './CurrentIdentity.generated';
const useStyles = makeStyles((theme) => ({
displayName: {
marginLeft: theme.spacing(2),
},
hidden: {
display: 'none',
},
profileLink: {
...theme.typography.button,
},
popupButton: {
textTransform: 'none',
color: theme.palette.primary.contrastText,
},
}));
const CurrentIdentity = () => {
const classes = useStyles();
const { loading, error, data } = useCurrentIdentityQuery();
const [open, setOpen] = React.useState(false);
const anchorRef = React.useRef<HTMLButtonElement>(null);
if (error || loading || !data?.repository?.userIdentity) return null;
const user = data.repository.userIdentity;
const handleToggle = () => {
setOpen((prevOpen) => !prevOpen);
};
const handleClose = (event: any) => {
if (anchorRef.current && anchorRef.current.contains(event.target)) {
return;
}
setOpen(false);
};
return (
<>
<Button
ref={anchorRef}
aria-controls={open ? 'menu-list-grow' : undefined}
aria-haspopup="true"
onClick={handleToggle}
className={classes.popupButton}
>
<Avatar src={user.avatarUrl ? user.avatarUrl : undefined}>
{user.displayName.charAt(0).toUpperCase()}
</Avatar>
<div className={classes.displayName}>{user.displayName}</div>
<LockIcon
color="secondary"
className={user.isProtected ? '' : classes.hidden}
/>
</Button>
<Popper
open={open}
anchorEl={anchorRef.current}
role={undefined}
transition
disablePortal
>
{({ TransitionProps, placement }) => (
<Grow
{...TransitionProps}
style={{
transformOrigin:
placement === 'bottom' ? 'center top' : 'center bottom',
}}
>
<Paper>
<ClickAwayListener onClickAway={handleClose}>
<MenuList autoFocusItem={open} id="menu-list-grow">
<MenuItem>
<Link
color="inherit"
className={classes.profileLink}
component={RouterLink}
to={`/user/${user.id}`}
>
Open profile
</Link>
</MenuItem>
</MenuList>
</ClickAwayListener>
</Paper>
</Grow>
)}
</Popper>
</>
);
};
export default CurrentIdentity;
|