836d591617
🔍 Lint / 🪄 Check lint (pull_request) Has been cancelled
🔍 Lint / 🎨 Check format (pull_request) Has been cancelled
🔍 Lint / 🔎 Typecheck (pull_request) Has been cancelled
🔍 Lint / 🏗 Build (pull_request) Has been cancelled
📊 Quality / 🔒 Security Audit (pull_request) Has been cancelled
📊 Quality / 📋 Dependency Freshness (pull_request) Has been cancelled
📊 Quality / 📦 Bundle Size (pull_request) Has been cancelled
95 lines
3.0 KiB
TypeScript
95 lines
3.0 KiB
TypeScript
import { Suspense, lazy } from "react";
|
|
|
|
function lazyNamed<T extends Record<string, React.ComponentType>>(
|
|
loader: () => Promise<T>,
|
|
exportName: keyof T,
|
|
): React.LazyExoticComponent<T[keyof T]> {
|
|
return lazy(() =>
|
|
loader().then((module) => ({ default: module[exportName] })),
|
|
);
|
|
}
|
|
|
|
function withDocsSuspense(
|
|
Component: React.LazyExoticComponent<React.ComponentType>,
|
|
): React.JSX.Element {
|
|
return (
|
|
<Suspense fallback={null}>
|
|
<Component />
|
|
</Suspense>
|
|
);
|
|
}
|
|
|
|
function createDocsRoute(
|
|
Component: React.LazyExoticComponent<React.ComponentType>,
|
|
): () => React.JSX.Element {
|
|
return function DocsRoute(): React.JSX.Element {
|
|
return withDocsSuspense(Component);
|
|
};
|
|
}
|
|
|
|
const LazyDocsLayout = lazyNamed(
|
|
() => import("@/components/docs/DocsLayout"),
|
|
"DocsLayout",
|
|
);
|
|
const LazyDocsReadmePage = lazyNamed(
|
|
() => import("@/pages/docs/page"),
|
|
"DocsReadmePage",
|
|
);
|
|
const LazyDocsArchitecturePage = lazyNamed(
|
|
() => import("@/pages/docs/architecture/page"),
|
|
"DocsArchitecturePage",
|
|
);
|
|
const LazyDocsTargetArchitecturePage = lazyNamed(
|
|
() => import("@/pages/docs/target-architecture/page"),
|
|
"DocsTargetArchitecturePage",
|
|
);
|
|
const LazyDocsTechnicalEditorPage = lazyNamed(
|
|
() => import("@/pages/docs/technical-editor/page"),
|
|
"DocsTechnicalEditorPage",
|
|
);
|
|
const LazyDocsHandTrackingPage = lazyNamed(
|
|
() => import("@/pages/docs/hand-tracking/page"),
|
|
"DocsHandTrackingPage",
|
|
);
|
|
const LazyDocsZustandPage = lazyNamed(
|
|
() => import("@/pages/docs/zustand/page"),
|
|
"DocsZustandPage",
|
|
);
|
|
const LazyDocsMissionFlowPage = lazyNamed(
|
|
() => import("@/pages/docs/mission-flow/page"),
|
|
"DocsMissionFlowPage",
|
|
);
|
|
const LazyDocsFeaturesPage = lazyNamed(
|
|
() => import("@/pages/docs/features/page"),
|
|
"DocsFeaturesPage",
|
|
);
|
|
const LazyDocsMainFeaturePage = lazyNamed(
|
|
() => import("@/pages/docs/main-feature/page"),
|
|
"DocsMainFeaturePage",
|
|
);
|
|
const LazyDocsEditorPage = lazyNamed(
|
|
() => import("@/pages/docs/editor/page"),
|
|
"DocsEditorPage",
|
|
);
|
|
const LazyDocsAnimationPage = lazyNamed(
|
|
() => import("@/pages/docs/animation/page"),
|
|
"DocsAnimationPage",
|
|
);
|
|
|
|
export const DocsLayoutRoute = createDocsRoute(LazyDocsLayout);
|
|
export const DocsReadmeRoute = createDocsRoute(LazyDocsReadmePage);
|
|
export const DocsArchitectureRoute = createDocsRoute(LazyDocsArchitecturePage);
|
|
export const DocsTargetArchitectureRoute = createDocsRoute(
|
|
LazyDocsTargetArchitecturePage,
|
|
);
|
|
export const DocsTechnicalEditorRoute = createDocsRoute(
|
|
LazyDocsTechnicalEditorPage,
|
|
);
|
|
export const DocsHandTrackingRoute = createDocsRoute(LazyDocsHandTrackingPage);
|
|
export const DocsZustandRoute = createDocsRoute(LazyDocsZustandPage);
|
|
export const DocsMissionFlowRoute = createDocsRoute(LazyDocsMissionFlowPage);
|
|
export const DocsFeaturesRoute = createDocsRoute(LazyDocsFeaturesPage);
|
|
export const DocsMainFeatureRoute = createDocsRoute(LazyDocsMainFeaturePage);
|
|
export const DocsEditorRoute = createDocsRoute(LazyDocsEditorPage);
|
|
export const DocsAnimationRoute = createDocsRoute(LazyDocsAnimationPage);
|