/* eslint-disable react/jsx-max-depth */ import React, { useState, useEffect, Suspense } from 'react'; import styled from '@emotion/styled'; import isNil from 'lodash/isNil'; import { Router } from 'react-router-dom'; import '../../i18n/config'; import storage from '../utils/storage'; import { isTokenExpire } from '../utils/login'; import Header from '../components/Header'; import Footer from '../components/Footer'; import Loading from '../components/Loading'; import Box from '../muiComponents/Box'; import StyleBaseline from '../design-tokens/StyleBaseline'; import { Theme } from '../design-tokens/theme'; import loadDayJSLocale from '../design-tokens/load-dayjs-locale'; import AppContextProvider from './AppContextProvider'; import AppRoute, { history } from './AppRoute'; const StyledBox = styled(Box)<{ theme?: Theme }>(({ theme }) => ({ backgroundColor: theme?.palette.background.default, })); const StyledBoxContent = styled(Box)<{ theme?: Theme }>(({ theme }) => ({ [`@media screen and (min-width: ${theme && theme.breakPoints.container}px)`]: { maxWidth: theme && theme.breakPoints.container, width: '100%', marginLeft: 'auto', marginRight: 'auto', }, })); /* eslint-disable react/jsx-no-bind */ /* eslint-disable react-hooks/exhaustive-deps */ const App: React.FC = () => { const [user, setUser] = useState(); /** * Logout user * Required by:
*/ const logout = () => { storage.removeItem('username'); storage.removeItem('token'); setUser(undefined); }; const checkUserAlreadyLoggedIn = () => { // checks for token validity const token = storage.getItem('token'); const username = storage.getItem('username'); if (isTokenExpire(token) || isNil(username)) { logout(); return; } setUser({ username }); }; useEffect(() => { checkUserAlreadyLoggedIn(); loadDayJSLocale(); }, []); return ( }> <>