blob: 77bf4ea73e0b1285c0d0f590a6ca869b433b265d [file] [log] [blame]
/*
Company: Savoir-faire Linux
Author: Larbi Gharib <larbi.gharib@savoirfairelinux.com>
License: AGPL-3
*/
import { ThemeProvider } from '@mui/material/styles';
import React, { useState, useEffect } from 'react'
import { Route, Routes, Navigate } from 'react-router-dom'
import authManager from './AuthManager'
import SignInPage from "./pages/loginDialog.jsx"
import JamiMessenger from "./pages/JamiMessenger.jsx"
import AccountSettings from "./pages/accountSettings.jsx"
import AccountSelection from "./pages/accountSelection.jsx"
import ServerSetup from "./pages/serverSetup.jsx"
import AccountCreationDialog from "./pages/accountCreation.jsx"
import NotFoundPage from "./pages/404.jsx"
import JamiAccountDialog from './pages/jamiAccountCreation.jsx'
import WelcomeAnimation from './components/welcome'
import defaultTheme from './themes/default'
import ContactList from './components/ContactList';
import { ThemeDemonstrator } from './themes/ThemeDemonstrator';
// import { useSelector, useDispatch } from 'react-redux'
// import { useAppSelector, useAppDispatch } from '../redux/hooks'
const Home = (props) => {
console.log(`home ${props}`)
return <Navigate to="/account" />
}
const App = (props) => {
// const count = useSelector(state => state.counter.value)
// const dispatch = useDispatch();
// const count = useAppSelector((state) => state.counter.value);
// const dispatch = useAppDispatch();
const [state, setState] = useState({
loaded: false,
auth: authManager.getState(),
});
const [displayWelcome, setDisplayWelcome] = useState(true);
useEffect(() => {
authManager.init((auth) => {
setState({ loaded: false, auth });
});
return () => authManager.deinit();
}, []);
console.log("App render");
if (displayWelcome) {
return (
<WelcomeAnimation
showSetup={!state.auth.setupComplete}
onComplete={() => setDisplayWelcome(false)}
/>
);
} else if (!state.auth.setupComplete) {
return (
<Routes>
<Route path="/setup" element={<ServerSetup />} />
<Route path="/" element={<Navigate to="/setup" replace />} />
<Route index path="*" element={<Navigate to="/setup" replace />} />
</Routes>
);
}
return (
<ThemeProvider theme={defaultTheme}>
<Routes>
<Route path="/account">
<Route index element={<AccountSelection />} />
<Route path=":accountId">
<Route index path="*" element={<JamiMessenger />} />
<Route path="settings" element={<AccountSettings />} />
</Route>
</Route>
<Route path="/newAccount" element={<AccountCreationDialog />}>
<Route path="jami" element={<JamiAccountDialog />} />
</Route>
<Route path="/Contacts" element={<ContactList />} />
<Route path="/Theme" element={<ThemeDemonstrator />} />
<Route path="/setup" element={<ServerSetup />} />
<Route path="/" index element={<Home />} />
<Route path="*" element={<NotFoundPage />} />
</Routes>
{!state.auth.authenticated && (
<SignInPage key="signin" open={!state.auth.authenticated} />
)}
</ThemeProvider>
);
};
export default App