mirror of
https://github.com/SomboChea/ui
synced 2024-09-28 20:37:47 +07:00
87 lines
2.4 KiB
TypeScript
87 lines
2.4 KiB
TypeScript
/* 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 AppContextProvider from './AppContextProvider';
|
|
import AppRoute, { history } from './AppRoute';
|
|
import loadDayJSLocale from './load-dayjs-locale';
|
|
|
|
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: <Header />
|
|
*/
|
|
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 (
|
|
<Suspense fallback={<Loading />}>
|
|
<StyleBaseline />
|
|
<StyledBox display="flex" flexDirection="column" height="100%">
|
|
<>
|
|
<Router history={history}>
|
|
<AppContextProvider user={user}>
|
|
<Header />
|
|
<StyledBoxContent flexGrow={1}>
|
|
<AppRoute />
|
|
</StyledBoxContent>
|
|
</AppContextProvider>
|
|
</Router>
|
|
<Footer />
|
|
</>
|
|
</StyledBox>
|
|
</Suspense>
|
|
);
|
|
};
|
|
|
|
export default App;
|