2024-02-28 16:49:44 +00:00
|
|
|
import { useEffect } from 'react'
|
2024-11-04 12:35:06 +00:00
|
|
|
import { useAppSelector } from './hooks'
|
2024-04-08 12:45:51 +00:00
|
|
|
import { Navigate, Route, Routes } from 'react-router-dom'
|
2024-10-05 12:56:34 +00:00
|
|
|
import { AuthController } from './controllers'
|
2024-02-28 16:49:44 +00:00
|
|
|
import { MainLayout } from './layouts/Main'
|
2024-11-18 16:29:46 +00:00
|
|
|
import { appPrivateRoutes, appPublicRoutes } from './routes'
|
|
|
|
import './App.scss'
|
2024-04-08 12:45:51 +00:00
|
|
|
import {
|
|
|
|
privateRoutes,
|
2024-07-26 11:15:14 +00:00
|
|
|
publicRoutes,
|
|
|
|
recursiveRouteRenderer
|
2024-11-18 16:29:46 +00:00
|
|
|
} from './routes/util'
|
2024-02-27 14:03:15 +00:00
|
|
|
|
2024-02-28 16:49:44 +00:00
|
|
|
const App = () => {
|
2024-10-08 15:08:43 +00:00
|
|
|
const authState = useAppSelector((state) => state.auth)
|
2024-02-28 16:49:44 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
2024-05-29 14:03:00 +00:00
|
|
|
if (window.location.hostname === '0.0.0.0') {
|
2024-05-29 14:06:47 +00:00
|
|
|
// A change of the host is needed to make library available in windows object
|
2024-05-29 14:08:38 +00:00
|
|
|
// the app can't encrypt files without the crypto library
|
|
|
|
// which is only available on https or localhost
|
2024-05-29 14:03:00 +00:00
|
|
|
window.location.hostname = 'localhost'
|
|
|
|
}
|
|
|
|
|
2024-03-19 10:27:18 +00:00
|
|
|
const authController = new AuthController()
|
|
|
|
authController.checkSession()
|
2024-02-28 16:49:44 +00:00
|
|
|
}, [])
|
|
|
|
|
2024-05-17 13:28:35 +00:00
|
|
|
const handleRootRedirect = () => {
|
|
|
|
if (authState.loggedIn) return appPrivateRoutes.homePage
|
2024-11-04 12:35:06 +00:00
|
|
|
|
2024-05-17 13:28:47 +00:00
|
|
|
const callbackPathEncoded = btoa(
|
|
|
|
window.location.href.split(`${window.location.origin}/#`)[1]
|
|
|
|
)
|
2024-11-04 12:35:06 +00:00
|
|
|
|
2024-05-17 13:28:35 +00:00
|
|
|
return `${appPublicRoutes.login}?callbackPath=${callbackPathEncoded}`
|
|
|
|
}
|
|
|
|
|
2024-07-31 11:48:57 +00:00
|
|
|
// Hide route only if loggedIn and r.hiddenWhenLoggedIn are both true
|
|
|
|
const publicRoutesList = recursiveRouteRenderer(publicRoutes, (r) => {
|
|
|
|
return !authState.loggedIn || !r.hiddenWhenLoggedIn
|
2024-07-26 11:15:14 +00:00
|
|
|
})
|
|
|
|
|
2024-07-31 11:48:57 +00:00
|
|
|
const privateRouteList = recursiveRouteRenderer(privateRoutes)
|
2024-07-26 11:15:14 +00:00
|
|
|
|
2024-02-27 14:03:15 +00:00
|
|
|
return (
|
2024-02-28 16:49:44 +00:00
|
|
|
<Routes>
|
|
|
|
<Route element={<MainLayout />}>
|
2024-07-26 11:15:14 +00:00
|
|
|
{authState?.loggedIn && privateRouteList}
|
|
|
|
{publicRoutesList}
|
2024-05-17 13:28:47 +00:00
|
|
|
<Route path="*" element={<Navigate to={handleRootRedirect()} />} />
|
2024-02-28 16:49:44 +00:00
|
|
|
</Route>
|
|
|
|
</Routes>
|
2024-02-27 14:03:15 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default App
|