2021-05-31 13:40:49 +03:00
|
|
|
import React, { useState, Suspense, lazy } from 'react';
|
2021-05-27 17:44:11 +03:00
|
|
|
import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';
|
|
|
|
import 'bootstrap/dist/css/bootstrap.min.css';
|
|
|
|
import './fonts/stylesheet.css';
|
2021-05-25 14:50:01 +03:00
|
|
|
|
2021-05-27 17:44:11 +03:00
|
|
|
const AuthPage = lazy(() => import('./pages/AuthPage'));
|
|
|
|
const HomePage = lazy(() => import('./pages/HomePage'));
|
|
|
|
const CandidatePage = lazy(() => import('./pages/CandidatePage'));
|
2021-05-26 13:35:57 +03:00
|
|
|
|
|
|
|
const App = () => {
|
2021-05-31 13:40:49 +03:00
|
|
|
const [isAuth, setIsAuth] = useState(false);
|
|
|
|
|
2021-05-25 14:50:01 +03:00
|
|
|
return (
|
2021-05-26 13:35:57 +03:00
|
|
|
<Router>
|
|
|
|
<Suspense fallback={<div>Loading...</div>}>
|
|
|
|
{isAuth ? (
|
|
|
|
<Switch>
|
|
|
|
<Route path="/" exact component={HomePage} />
|
|
|
|
<Route path="/candidate/:id" component={CandidatePage} />
|
2021-05-31 13:40:49 +03:00
|
|
|
<Route component={<div>Not found page</div>} />
|
2021-05-26 13:35:57 +03:00
|
|
|
</Switch>
|
|
|
|
) : (
|
2021-05-31 13:40:49 +03:00
|
|
|
<Route path="/" exact component={(props) => <AuthPage {...props} setAuth={setIsAuth} />} />
|
2021-05-26 13:35:57 +03:00
|
|
|
)}
|
|
|
|
</Suspense>
|
|
|
|
</Router>
|
2021-05-27 17:44:11 +03:00
|
|
|
);
|
|
|
|
};
|
2021-05-25 14:50:01 +03:00
|
|
|
|
2021-05-27 17:44:11 +03:00
|
|
|
export default App;
|