retropilot-client/src/App.js

55 lines
1.3 KiB
JavaScript

import React, { useState } from 'react';
import CssBaseline from '@mui/material/CssBaseline';
import { createTheme, ThemeProvider } from '@mui/material/styles';
import { getSession } from './api/auth';
import Login from './components/views/Login';
import UserAdmin from './components/views/UserAdmin';
import GlobalSnack from './components/widgets/globalSnack';
import DevicesProvider from './context/devices';
import ToastProvider from './context/toast';
import UserProvider from './context/users';
function App() {
const [isAuthenticated, setAuthenticated] = useState(false);
getSession().then((session) => {
const { authenticated } = session.data;
setAuthenticated(authenticated);
}).catch(console.error);
const theme = React.useMemo(
() => createTheme({
palette: {
mode: window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light',
},
}),
[],
);
return (
<div className="App">
<ThemeProvider theme={theme}>
<CssBaseline />
<UserProvider>
<DevicesProvider>
<ToastProvider>
<GlobalSnack />
{isAuthenticated ? <UserAdmin /> : <Login />}
</ToastProvider>
</DevicesProvider>
</UserProvider>
</ThemeProvider>
</div>
);
}
export default App;