Files
core/panel/ui/ProtectedRoute.tsx

47 lines
1.2 KiB
TypeScript
Raw Normal View History

2025-07-25 12:27:04 +03:00
import { createEffect, Show } from 'solid-js'
2025-07-02 22:30:21 +03:00
import { useAuth } from '../context/auth'
import { DataProvider } from '../context/data'
import { TableSortProvider } from '../context/sort'
import AdminPage from '../routes/admin'
/**
* Компонент защищенного маршрута
*/
export const ProtectedRoute = () => {
const auth = useAuth()
2025-07-25 12:26:31 +03:00
createEffect(() => {
if (auth.isReady() && !auth.isAuthenticated()) {
window.location.href = '/login'
}
})
2025-07-25 09:42:43 +03:00
2025-07-02 22:30:21 +03:00
return (
2025-07-25 12:26:31 +03:00
<Show
when={auth.isReady()}
fallback={
<div class="loading-screen">
<div class="loading-spinner" />
<div>Инициализация авторизации...</div>
</div>
}
>
<Show
when={auth.isAuthenticated()}
fallback={
<div class="loading-screen">
<div class="loading-spinner" />
<div>Перенаправление на страницу входа...</div>
</div>
}
>
<DataProvider>
<TableSortProvider>
<AdminPage apiUrl={`${location.origin}/graphql`} />
</TableSortProvider>
</DataProvider>
</Show>
</Show>
2025-07-02 22:30:21 +03:00
)
}