1 import axios from 'axios';
2 import React, { useEffect, useState } from 'react';
3 import { Helmet } from 'react-helmet';
4 import { useTranslation } from 'react-i18next';
5 import { BrowserRouter, Navigate, Route, Routes } from 'react-router-dom';
7 import Footer from './common/Footer';
8 import Header from './common/Header';
9 import AlttpSeed from './pages/AlttpSeed';
10 import Front from './pages/Front';
11 import Map from './pages/Map';
12 import Schedule from './pages/Schedule';
13 import Technique from './pages/Technique';
14 import Techniques from './pages/Techniques';
15 import Tournament from './pages/Tournament';
16 import User from './pages/User';
17 import AlttpBaseRomProvider from '../helpers/AlttpBaseRomContext';
18 import UserContext from '../helpers/UserContext';
19 import i18n from '../i18n';
22 const [user, setUser] = useState(null);
24 const { t } = useTranslation();
26 const checkAuth = async () => {
28 const response = await axios.get('/api/user');
29 setUser(response.data);
35 const doLogout = async () => {
36 await axios.post('/logout');
43 .get('/sanctum/csrf-cookie')
46 timer = setInterval(checkAuth, 15 * 60 * 1000);
49 if (timer) clearInterval(timer);
54 window.Echo.channel('App.Control')
55 .listen('PleaseRefresh', () => {
59 window.Echo.leave('App.Control');
63 return <BrowserRouter>
64 <AlttpBaseRomProvider>
65 <UserContext.Provider value={user}>
67 <html lang={i18n.language} />
68 <title>{t('general.appName')}</title>
69 <meta name="description" content={t('general.appDescription')} />
71 <Header doLogout={doLogout} />
75 element={<Techniques namespace="dungeons" type="dungeon" />}
79 element={<Technique namespace="dungeons" type="dungeon" />}
81 <Route path="h/:hash" element={<AlttpSeed />} />
84 element={<Techniques namespace="locations" type="location" />}
87 path="locations/:name"
88 element={<Technique namespace="locations" type="location" />}
90 <Route path="map" element={<Map />} />
93 element={<Techniques namespace="modes" type="mode" />}
97 element={<Technique namespace="modes" type="mode" />}
101 element={<Techniques namespace="rulesets" type="ruleset" />}
104 path="rulesets/:name"
105 element={<Technique namespace="rulesets" type="ruleset" />}
107 <Route path="schedule" element={<Schedule />} />
110 element={<Techniques namespace="techniques" type="tech" />}
114 element={<Technique namespace="techniques" type="tech" />}
116 <Route path="tournaments/:id" element={<Tournament />} />
117 <Route path="users/:id" element={<User />} />
118 <Route path="/" element={<Front />} />
119 <Route path="*" element={<Navigate to="/" />} />
122 </UserContext.Provider>
123 </AlttpBaseRomProvider>