import axios from 'axios'; import { CSSProperties, useContext, useEffect, useState } from 'react'; import { userInfo } from '../api/api'; import { LogoDark } from '../components/logo'; import { AccountAvatar } from './account'; import { NotificationsArea } from './notificationsArea'; import { SocketContext } from './socketContext'; import ExtensionIcon from '@material-ui/icons/Extension'; import Home from '@material-ui/icons/Home'; import NotificationsIcon from '@material-ui/icons/Notifications'; import PersonIcon from '@material-ui/icons/Person'; import SearchIcon from '@material-ui/icons/Search'; import SettingsIcon from '@material-ui/icons/Settings'; import VideogameAssetIcon from '@material-ui/icons/VideogameAsset'; var NavBarItemStyle: CSSProperties = { margin: 12, marginBottom: 16, display: 'block', }; export function NavBar() { var [loggedIn, setLoggedIn] = useState(false); var [gotData, setGotData] = useState(false); var [friendRequests, setFriendRequests] = useState>(null); var [notificationsAreaVisible, setNotificationsAreaVisible] = useState(false); var [gotNotifications, setGotNotifications] = useState(false); var { io } = useContext(SocketContext); async function getNotifications() { var friendRequestsReq = await axios.request<{ requests: Array; }>({ method: 'get', url: `/api/social/list/requests`, }); setFriendRequests(friendRequestsReq.data.requests); setGotNotifications(friendRequestsReq.data.requests.length > 0); } useEffect(() => { (async () => { if (gotData) return; if (typeof window === 'undefined') return; var loggedIn = document.cookie.includes('token'); setLoggedIn(loggedIn); if (loggedIn) { await getNotifications(); io.on('incomingFriendRequest', getNotifications); io.on('changedRelation', getNotifications); } setGotData(true); })(); }, []); return
{false && }
{loggedIn &&
setNotificationsAreaVisible(!notificationsAreaVisible)} > {gotNotifications &&
}
} {loggedIn ? : } {loggedIn && }
; }