mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-01-15 05:33:29 +01:00
82 lines
2.0 KiB
TypeScript
82 lines
2.0 KiB
TypeScript
import { createBrowserRouter, Navigate, Outlet, RouterProvider } from 'react-router-dom';
|
|
import { routePaths, useAppRoutes } from '../hooks/useAppRoutes';
|
|
import { useRecentRequests } from '../hooks/useRecentRequests';
|
|
import { useRequests } from '../hooks/useRequests';
|
|
import { GlobalHooks } from './GlobalHooks';
|
|
import Workspace from './Workspace';
|
|
import Workspaces from './Workspaces';
|
|
import { DialogProvider } from './DialogContext';
|
|
import { useActiveEnvironmentId } from '../hooks/useActiveEnvironmentId';
|
|
import RouteError from './RouteError';
|
|
|
|
const router = createBrowserRouter([
|
|
{
|
|
path: '/',
|
|
errorElement: <RouteError />,
|
|
element: <Layout />,
|
|
children: [
|
|
{
|
|
path: '/',
|
|
element: <Navigate to={routePaths.workspaces()} replace={true} />,
|
|
},
|
|
{
|
|
path: routePaths.workspaces(),
|
|
element: <Workspaces />,
|
|
},
|
|
{
|
|
path: routePaths.workspace({
|
|
workspaceId: ':workspaceId',
|
|
environmentId: ':environmentId',
|
|
}),
|
|
element: <WorkspaceOrRedirect />,
|
|
},
|
|
{
|
|
path: routePaths.request({
|
|
workspaceId: ':workspaceId',
|
|
environmentId: ':environmentId',
|
|
requestId: ':requestId',
|
|
}),
|
|
element: <Workspace />,
|
|
},
|
|
],
|
|
},
|
|
]);
|
|
|
|
export function AppRouter() {
|
|
return <RouterProvider router={router} />;
|
|
}
|
|
|
|
function WorkspaceOrRedirect() {
|
|
const recentRequests = useRecentRequests();
|
|
const activeEnvironmentId = useActiveEnvironmentId();
|
|
const requests = useRequests();
|
|
const request = requests.find((r) => r.id === recentRequests[0]);
|
|
const routes = useAppRoutes();
|
|
|
|
if (request === undefined) {
|
|
return <Workspace />;
|
|
}
|
|
|
|
const { id: requestId, workspaceId } = request;
|
|
const environmentId = activeEnvironmentId ?? undefined;
|
|
|
|
return (
|
|
<Navigate
|
|
to={routes.paths.request({
|
|
workspaceId,
|
|
environmentId,
|
|
requestId,
|
|
})}
|
|
/>
|
|
);
|
|
}
|
|
|
|
function Layout() {
|
|
return (
|
|
<DialogProvider>
|
|
<Outlet />
|
|
<GlobalHooks />
|
|
</DialogProvider>
|
|
);
|
|
}
|