fix: authorization / registration
This commit is contained in:
11
src/app/providers/GuestRoute.tsx
Normal file
11
src/app/providers/GuestRoute.tsx
Normal file
@@ -0,0 +1,11 @@
|
||||
import { Navigate, Outlet } from 'react-router-dom'
|
||||
import { useIsAuthenticated } from '@features/auth'
|
||||
import { ROUTES } from '@shared/config/routes'
|
||||
|
||||
export function GuestRoute() {
|
||||
const { isAuthenticated, isLoading } = useIsAuthenticated()
|
||||
|
||||
if (isLoading) return null
|
||||
if (isAuthenticated) return <Navigate to={ROUTES.WALLET} replace />
|
||||
return <Outlet />
|
||||
}
|
||||
@@ -9,6 +9,7 @@ import { SeedPhrasePage } from '@pages/seed-phrase'
|
||||
import { ROUTES } from '@shared/config/routes'
|
||||
import { ScrollToTop } from './ScrollToTop'
|
||||
import { ProtectedRoute } from './ProtectedRoute'
|
||||
import { GuestRoute } from './GuestRoute'
|
||||
|
||||
export function RouterProvider() {
|
||||
return (
|
||||
@@ -16,8 +17,11 @@ export function RouterProvider() {
|
||||
<ScrollToTop />
|
||||
<Routes>
|
||||
<Route path={ROUTES.HOME} element={<HomePage />} />
|
||||
<Route path={ROUTES.LOGIN} element={<LoginPage />} />
|
||||
<Route path={ROUTES.REGISTER} element={<RegisterPage />} />
|
||||
|
||||
<Route element={<GuestRoute />}>
|
||||
<Route path={ROUTES.LOGIN} element={<LoginPage />} />
|
||||
<Route path={ROUTES.REGISTER} element={<RegisterPage />} />
|
||||
</Route>
|
||||
|
||||
<Route element={<ProtectedRoute />}>
|
||||
<Route path={ROUTES.WALLET} element={<WalletPage />} />
|
||||
|
||||
Reference in New Issue
Block a user