|
|
|
@ -12,8 +12,25 @@ interface Props {}
|
|
|
|
|
const UserBanner: React.FC<Props> = () => {
|
|
|
|
|
const user = useAppSelector((state) => state.user.user);
|
|
|
|
|
const [shouldShowPopupBtns, setShouldShowPopupBtns] = useState(false);
|
|
|
|
|
const [username, setUsername] = useState("Memos");
|
|
|
|
|
const isVisitorMode = userService.isVisitorMode();
|
|
|
|
|
|
|
|
|
|
const [username, setUsername] = useState(user ? user.name : "Memos");
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
const currentUserId = userService.getUserIdFromPath();
|
|
|
|
|
if (isVisitorMode && currentUserId) {
|
|
|
|
|
api
|
|
|
|
|
.getUserNameById(currentUserId)
|
|
|
|
|
.then(({ data }) => {
|
|
|
|
|
const { data: username } = data;
|
|
|
|
|
setUsername(username);
|
|
|
|
|
})
|
|
|
|
|
.catch(() => {
|
|
|
|
|
toastHelper.error("User not found");
|
|
|
|
|
});
|
|
|
|
|
} else if (user) {
|
|
|
|
|
setUsername(user.name);
|
|
|
|
|
}
|
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
const handleUsernameClick = useCallback(() => {
|
|
|
|
|
locationService.clearQuery();
|
|
|
|
@ -23,35 +40,11 @@ const UserBanner: React.FC<Props> = () => {
|
|
|
|
|
setShouldShowPopupBtns(true);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
if (username === "Memos") {
|
|
|
|
|
if (locationService.getState().pathname === "/") {
|
|
|
|
|
api.getSystemStatus().then(({ data }) => {
|
|
|
|
|
const { data: status } = data;
|
|
|
|
|
setUsername(status.host.name);
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
const currentUserId = userService.getCurrentUserId();
|
|
|
|
|
if (currentUserId) {
|
|
|
|
|
api
|
|
|
|
|
.getUserNameById(currentUserId)
|
|
|
|
|
.then(({ data }) => {
|
|
|
|
|
const { data: username } = data;
|
|
|
|
|
setUsername(username);
|
|
|
|
|
})
|
|
|
|
|
.catch(() => {
|
|
|
|
|
toastHelper.error("User not found");
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className="user-banner-container">
|
|
|
|
|
<div className="username-container" onClick={handleUsernameClick}>
|
|
|
|
|
<span className="username-text">{username}</span>
|
|
|
|
|
{user?.role === "HOST" ? <span className="tag">MOD</span> : null}
|
|
|
|
|
{!isVisitorMode && user?.role === "HOST" ? <span className="tag">MOD</span> : null}
|
|
|
|
|
</div>
|
|
|
|
|
<span className="action-btn menu-popup-btn" onClick={handlePopupBtnClick}>
|
|
|
|
|
<img src="/icons/more.svg" className="icon-img" />
|
|
|
|
|