diff options
Diffstat (limited to 'src/index.tsx')
-rw-r--r-- | src/index.tsx | 83 |
1 files changed, 3 insertions, 80 deletions
diff --git a/src/index.tsx b/src/index.tsx index 360ca89..2b8d92d 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -1,87 +1,10 @@ -import React, { useState, useEffect } from 'react'; +import React from 'react'; import ReactDOM from 'react-dom'; -import { - BenzinThemeProvider, - Header, -} from 'react-benzin'; -import { User, Solution } from './types'; - -import 'typeface-roboto'; - -import Timer from './pages/Timer/Timer'; -import Scoreboard from './pages/Scoreboard/Scoreboard'; -import Contribute from './pages/Contribute/Contribute'; -import Profile from './pages/Profile/Profile'; - -import TimerIcon from '@material-ui/icons/Timer'; -import AccountCircleIcon from '@material-ui/icons/AccountCircle'; -import AssignmentIcon from '@material-ui/icons/Assignment'; -import GitHubIcon from '@material-ui/icons/GitHub'; - -import { get } from './requests'; - +import Timer from './components/Timer'; const App: React.FC = () => { - const [page, setPage] = useState<string>('app'); - const [user, setUser] = useState<User>({ username: 'anonymous', id: null }); - const [recentSolutions, setRecentSolutions] = useState<Solution[]>([]); - - const headerContents = { - app: (<TimerIcon />), - profile: (<AccountCircleIcon />), - scoreboard: (<AssignmentIcon />), - contribute: (<GitHubIcon />), - }; - - useEffect(() => { - const userId = localStorage.getItem('userId'); - if (userId) { - get('users/').then(response => { - setUser(response.data.filter((user: User) => user.id === +userId)[0]); - }); - } - }, []); - - const Page: React.FC<{ page: string }> = ({ page }) => { - switch (page) { - case 'app': - return ( - <Timer - user={user} - recentSolutions={recentSolutions} - setRecentSolutions={setRecentSolutions} - setPage={setPage} - /> - ); - - case 'profile': - return <Profile user={user} setUser={setUser} />; - - case 'scoreboard': - return <Scoreboard />; - - case 'contribute': - return <Contribute />; - - default: - return <Contribute />; - } - }; - - return ( - <BenzinThemeProvider> - <Header - logo={{ - title: 'ChronoCube', - icon: null - }} - contents={headerContents} - page={page} - setPage={setPage}/> - <Page page={page} /> - </BenzinThemeProvider> - ); + return (<Timer />); }; document.body.style.overflow = 'hidden'; |