blob: b6859364c254e96acf2971215a9ad611bd2a51ad [file] [log] [blame]
Larbi Gharibe9af9732021-03-31 15:08:01 +01001/*
2 Company: Savoir-faire Linux
3 Author: Larbi Gharib <larbi.gharib@savoirfairelinux.com>
Larbi Gharibe9af9732021-03-31 15:08:01 +01004 License: AGPL-3
5*/
idillon-sfl837ea0b2022-08-25 11:35:29 -04006import { ThemeProvider } from '@mui/material/styles';
Adrien Béraude74741b2021-04-19 13:22:54 -04007import React, { useState, useEffect } from 'react'
idillon-sfl5d174552022-08-23 14:34:24 -04008import { Route, Routes, Navigate } from 'react-router-dom'
Adrien Béraud6ecaa402021-04-06 17:37:25 -04009import authManager from './AuthManager'
Larbi Gharibe9af9732021-03-31 15:08:01 +010010
Adrien Béraud35e7d7c2021-04-13 03:28:39 -040011import SignInPage from "./pages/loginDialog.jsx"
Adrien Béraud6c934962021-06-07 10:13:26 -040012import JamiMessenger from "./pages/JamiMessenger.jsx"
Adrien Béraud6ecaa402021-04-06 17:37:25 -040013import AccountSettings from "./pages/accountSettings.jsx"
14import AccountSelection from "./pages/accountSelection.jsx"
Adrien Béraude74741b2021-04-19 13:22:54 -040015import ServerSetup from "./pages/serverSetup.jsx"
Adrien Béraud88a52442021-04-26 12:11:41 -040016import AccountCreationDialog from "./pages/accountCreation.jsx"
Larbi Gharibe9af9732021-03-31 15:08:01 +010017import NotFoundPage from "./pages/404.jsx"
Adrien Béraud88a52442021-04-26 12:11:41 -040018import JamiAccountDialog from './pages/jamiAccountCreation.jsx'
Adrien Béraud34995902021-06-07 10:12:00 -040019import WelcomeAnimation from './components/welcome'
idillon-sfl837ea0b2022-08-25 11:35:29 -040020import defaultTheme from './themes/default'
Adrien Béraudab519ff2022-05-03 15:34:48 -040021
22const Home = (props) => {
23 console.log(`home ${props}`)
Adrien Béraudab519ff2022-05-03 15:34:48 -040024
25 return <Navigate to="/account" />
26}
27
Adrien Béraude74741b2021-04-19 13:22:54 -040028const App = (props) => {
Adrien Béraude74741b2021-04-19 13:22:54 -040029 const [state, setState] = useState({
30 loaded: false,
31 auth: authManager.getState()
32 })
Adrien Béraud34995902021-06-07 10:12:00 -040033 const [displayWelcome, setDisplayWelcome] = useState(true)
34
Adrien Béraude74741b2021-04-19 13:22:54 -040035 useEffect(() => {
36 authManager.init(auth => {
Adrien Béraud6c934962021-06-07 10:13:26 -040037 setState({ loaded: false, auth })
Adrien Béraude74741b2021-04-19 13:22:54 -040038 })
39 return () => authManager.deinit()
40 }, []);
Larbi Gharibe9af9732021-03-31 15:08:01 +010041
Adrien Béraud34995902021-06-07 10:12:00 -040042 console.log("App render")
43 if (displayWelcome) {
44 return <WelcomeAnimation showSetup={!state.auth.setupComplete} onComplete={() => setDisplayWelcome(false)} />
Adrien Béraude74741b2021-04-19 13:22:54 -040045 } else if (!state.auth.setupComplete) {
Adrien Béraudab519ff2022-05-03 15:34:48 -040046 return <Routes>
47 <Route path="/setup" element={<ServerSetup />} />
48 <Route path="/" element={<Navigate to="/setup" replace />} />
49 <Route index path="*" element={<Navigate to="/setup" replace />} />
50 </Routes>
Adrien Béraude74741b2021-04-19 13:22:54 -040051 }
Adrien Béraud6c934962021-06-07 10:13:26 -040052
idillon-sfl837ea0b2022-08-25 11:35:29 -040053 return <ThemeProvider theme={defaultTheme}>
Adrien Béraudab519ff2022-05-03 15:34:48 -040054 <Routes>
55 <Route path="/account">
56 <Route index element={<AccountSelection />} />
57 <Route path=":accountId">
58 <Route index path="*" element={<JamiMessenger />} />
59 <Route path="settings" element={<AccountSettings />} />
60 </Route>
61 </Route>
62 <Route path="/newAccount" element={<AccountCreationDialog />}>
63 <Route path="jami" element={<JamiAccountDialog />} />
64 </Route>
65 <Route path="/setup" element={<ServerSetup />} />
66 <Route path="/" index element={<Home />} />
67 <Route path="*" element={<NotFoundPage />} />
68 </Routes>
69 {!state.auth.authenticated && <SignInPage key="signin" open={!state.auth.authenticated}/>}
70 </ThemeProvider>
Larbi Gharibe9af9732021-03-31 15:08:01 +010071}
72
Adrien Béraude74741b2021-04-19 13:22:54 -040073export default App