]> git.localhorst.tv Git - alttp.git/blob - resources/js/components/App.js
new front page
[alttp.git] / resources / js / components / App.js
1 import axios from 'axios';
2 import React, { useEffect, useState } from 'react';
3 import { BrowserRouter, Navigate, Route, Routes } from 'react-router-dom';
4
5 import Header from './common/Header';
6 import AlttpSeed from './pages/AlttpSeed';
7 import Front from './pages/Front';
8 import Technique from './pages/Technique';
9 import Tournament from './pages/Tournament';
10 import User from './pages/User';
11 import AlttpBaseRomProvider from '../helpers/AlttpBaseRomContext';
12 import UserContext from '../helpers/UserContext';
13
14 const App = () => {
15         const [user, setUser] = useState(null);
16
17         const checkAuth = async () => {
18                 try {
19                         const response = await axios.get('/api/user');
20                         setUser(response.data);
21                 } catch (e) {
22                         setUser(null);
23                 }
24         };
25
26         const doLogout = async () => {
27                 await axios.post('/logout');
28                 await checkAuth();
29         };
30
31         useEffect(() => {
32                 let timer = null;
33                 axios
34                         .get('/sanctum/csrf-cookie')
35                         .then(() => {
36                                 checkAuth();
37                                 timer = setInterval(checkAuth, 15 * 60 * 1000);
38                         });
39                 return () => {
40                         if (timer) clearInterval(timer);
41                 };
42         }, []);
43
44         useEffect(() => {
45                 window.Echo.channel('App.Control')
46                         .listen('PleaseRefresh', () => {
47                                 location.reload();
48                         });
49                 return () => {
50                         window.Echo.leave('App.Control');
51                 };
52         }, []);
53
54         return <BrowserRouter>
55                 <AlttpBaseRomProvider>
56                         <UserContext.Provider value={user}>
57                                 <Header doLogout={doLogout} />
58                                 <Routes>
59                                         <Route path="h/:hash" element={<AlttpSeed />} />
60                                         <Route path="tech/:name" element={<Technique />} />
61                                         <Route path="tournaments/:id" element={<Tournament />} />
62                                         <Route path="users/:id" element={<User />} />
63                                         <Route path="/" element={<Front />} />
64                                         <Route path="*" element={<Navigate to="/" />} />
65                                 </Routes>
66                         </UserContext.Provider>
67                 </AlttpBaseRomProvider>
68         </BrowserRouter>;
69 };
70
71 export default App;