blob: cc1b5bfacf45fab1521c5695a7dea61ab6ae3b53 [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*/
Adrien Béraude74741b2021-04-19 13:22:54 -04006import React, { useState, useEffect } from 'react'
7import { Route, Switch, Redirect, useHistory, useLocation } from 'react-router-dom'
8import { CircularProgress, Container, CssBaseline } from '@material-ui/core'
Adrien Béraud6ecaa402021-04-06 17:37:25 -04009import authManager from './AuthManager'
Adrien Béraude74741b2021-04-19 13:22:54 -040010//import logo from './logo.svg'
11import './App.scss'
Larbi Gharibe9af9732021-03-31 15:08:01 +010012
Adrien Béraud35e7d7c2021-04-13 03:28:39 -040013import SignInPage from "./pages/loginDialog.jsx"
Adrien Béraud6ecaa402021-04-06 17:37:25 -040014import JamiMessenger from "./pages/messenger.jsx"
15import AccountSettings from "./pages/accountSettings.jsx"
16import AccountSelection from "./pages/accountSelection.jsx"
Adrien Béraude74741b2021-04-19 13:22:54 -040017import ServerSetup from "./pages/serverSetup.jsx"
Larbi Gharibe9af9732021-03-31 15:08:01 +010018import NotFoundPage from "./pages/404.jsx"
19
Adrien Béraude74741b2021-04-19 13:22:54 -040020const App = (props) => {
21 const history = useHistory()
22 const { location } = useLocation()
23 const [state, setState] = useState({
24 loaded: false,
25 auth: authManager.getState()
26 })
27 useEffect(() => {
28 authManager.init(auth => {
29 setState({ loaded: true, auth })
30 })
31 return () => authManager.deinit()
32 }, []);
Larbi Gharibe9af9732021-03-31 15:08:01 +010033
Adrien Béraud35e7d7c2021-04-13 03:28:39 -040034 console.log("App render")
Adrien Béraude74741b2021-04-19 13:22:54 -040035 console.log(state)
36 console.log(location)
Adrien Béraud35e7d7c2021-04-13 03:28:39 -040037
Adrien Béraude74741b2021-04-19 13:22:54 -040038 if (!state.loaded) {
39 return <Container><CircularProgress /></Container>
40 } else if (!state.auth.setupComplete) {
41 return <Switch>
42 <Route path="/setup" component={ServerSetup} />
43 <Route><Redirect to="/setup" /></Route>
44 </Switch>
45 }
46 return <React.Fragment>
47 <CssBaseline />
48 <Switch>
49 <Route exact path="/"><Redirect to="/account" /></Route>
50 <Route path="/account/:accountId/settings" component={AccountSettings} />
51 <Route path="/account/:accountId/addContact/:contactId" component={JamiMessenger} />
52 <Route path="/account/:accountId/conversation/:conversationId" component={JamiMessenger} />
53 <Route path="/account/:accountId" component={JamiMessenger} />
54 <Route path="/account" component={AccountSelection} />
55 <Route component={NotFoundPage} />
56 </Switch>
57 {!state.auth.authenticated && <SignInPage open={!state.auth.authenticated}/>}
58 </React.Fragment>
Larbi Gharibe9af9732021-03-31 15:08:01 +010059}
60
Adrien Béraude74741b2021-04-19 13:22:54 -040061export default App