Files
LangBot/web/src/router.tsx
RockChinQ c40354f838 feat(web): dynamic document title per route
The browser tab title was hard-coded to 'LangBot' in index.html and never
changed. Add a useDocumentTitle hook that maps the active route to an
existing i18n key and sets document.title to '<page> · LangBot', driven by
a new top-level RootLayout route element. Re-runs on navigation and on
language change so the title stays localized. Falls back to the bare app
name for unmapped routes.
2026-06-06 12:07:41 -04:00

180 lines
4.5 KiB
TypeScript

import React, { Suspense } from 'react';
import { createBrowserRouter, Navigate } from 'react-router-dom';
// Layouts
import LoginLayout from '@/app/login/layout';
import RegisterLayout from '@/app/register/layout';
import ResetPasswordLayout from '@/app/reset-password/layout';
import HomeLayout from '@/app/home/layout';
// Pages
import LoginPage from '@/app/login/page';
import RegisterPage from '@/app/register/page';
import ResetPasswordPage from '@/app/reset-password/page';
import WizardPage from '@/app/wizard/page';
import SpaceCallbackPage from '@/app/auth/space/callback/page';
import HomePage from '@/app/home/page';
import MonitoringPage from '@/app/home/monitoring/page';
import BotsPage from '@/app/home/bots/page';
import PipelinesPage from '@/app/home/pipelines/page';
import PluginsPage from '@/app/home/plugins/page';
import AddExtensionPage from '@/app/home/add-extension/page';
import MCPPage from '@/app/home/mcp/page';
import KnowledgePage from '@/app/home/knowledge/page';
import SkillsPage from '@/app/home/skills/page';
import ErrorPage from '@/components/ErrorPage';
import BackendUnavailablePage from '@/components/BackendUnavailablePage';
import PluginPagesPage from '@/app/home/plugin-pages/page';
import RootLayout from '@/app/RootLayout';
const Loading = () => <div>Loading...</div>;
export const router = createBrowserRouter([
{
element: <RootLayout />,
errorElement: <ErrorPage />,
children: [
{
path: '/',
element: <Navigate to="/login" replace />,
},
{
path: '/login',
element: (
<LoginLayout>
<LoginPage />
</LoginLayout>
),
},
{
path: '/register',
element: (
<RegisterLayout>
<RegisterPage />
</RegisterLayout>
),
},
{
path: '/reset-password',
element: (
<ResetPasswordLayout>
<ResetPasswordPage />
</ResetPasswordLayout>
),
},
{
path: '/wizard',
element: <WizardPage />,
},
{
path: '/backend-unavailable',
element: <BackendUnavailablePage />,
},
{
path: '/auth/space/callback',
element: <SpaceCallbackPage />,
},
{
path: '/home',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<HomePage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/monitoring',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<MonitoringPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/bots',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<BotsPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/pipelines',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<PipelinesPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/extensions',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<PluginsPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/add-extension',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<AddExtensionPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/mcp',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<MCPPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/knowledge',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<KnowledgePage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/skills',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<SkillsPage />
</HomeLayout>
</Suspense>
),
},
{
path: '/home/plugin-pages',
element: (
<Suspense fallback={<Loading />}>
<HomeLayout>
<PluginPagesPage />
</HomeLayout>
</Suspense>
),
},
],
},
]);