diff options
Diffstat (limited to 'src/index.tsx')
-rw-r--r-- | src/index.tsx | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/src/index.tsx b/src/index.tsx new file mode 100644 index 0000000..360ca89 --- /dev/null +++ b/src/index.tsx @@ -0,0 +1,88 @@ +import React, { useState, useEffect } 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'; + + +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> + ); +}; + +document.body.style.overflow = 'hidden'; +ReactDOM.render(<App />, document.getElementById('root')); |