polen 0.10.0-next.14 → 0.10.0-next.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +375 -49
- package/build/api/api.d.ts +0 -1
- package/build/api/api.d.ts.map +1 -1
- package/build/api/api.js +0 -1
- package/build/api/api.js.map +1 -1
- package/build/api/builder/builder.js +1 -1
- package/build/api/builder/builder.js.map +1 -1
- package/build/api/config/load.js +6 -6
- package/build/api/config/load.js.map +1 -1
- package/build/api/config-resolver/resolve.js +2 -2
- package/build/api/config-resolver/resolve.js.map +1 -1
- package/build/api/schema/data-sources/schema-directory/schema-directory.js +1 -1
- package/build/api/schema/data-sources/schema-directory/schema-directory.js.map +1 -1
- package/build/api/vite/plugins/branding/index.js +4 -4
- package/build/api/vite/plugins/branding/index.js.map +1 -1
- package/build/api/vite/plugins/build.d.ts.map +1 -1
- package/build/api/vite/plugins/build.js +4 -33
- package/build/api/vite/plugins/build.js.map +1 -1
- package/build/api/vite/plugins/core.d.ts +2 -2
- package/build/api/vite/plugins/core.d.ts.map +1 -1
- package/build/api/vite/plugins/core.js +13 -13
- package/build/api/vite/plugins/core.js.map +1 -1
- package/build/api/vite/plugins/pages.d.ts +14 -8
- package/build/api/vite/plugins/pages.d.ts.map +1 -1
- package/build/api/vite/plugins/pages.js +185 -111
- package/build/api/vite/plugins/pages.js.map +1 -1
- package/build/api/vite/plugins/serve.d.ts.map +1 -1
- package/build/api/vite/plugins/serve.js +12 -52
- package/build/api/vite/plugins/serve.js.map +1 -1
- package/build/cli/_/self-contained-mode.js +5 -5
- package/build/cli/_/self-contained-mode.js.map +1 -1
- package/build/lib/file-router/diagnostic-reporter.js +2 -2
- package/build/lib/file-router/diagnostic-reporter.js.map +1 -1
- package/build/lib/file-router/file-router.d.ts +2 -0
- package/build/lib/file-router/file-router.d.ts.map +1 -1
- package/build/lib/file-router/file-router.js +2 -0
- package/build/lib/file-router/file-router.js.map +1 -1
- package/build/lib/file-router/route.d.ts +0 -2
- package/build/lib/file-router/route.d.ts.map +1 -1
- package/build/lib/file-router/route.js.map +1 -1
- package/build/lib/file-router/scan-tree.d.ts +20 -0
- package/build/lib/file-router/scan-tree.d.ts.map +1 -0
- package/build/lib/file-router/scan-tree.js +158 -0
- package/build/lib/file-router/scan-tree.js.map +1 -0
- package/build/lib/file-router/scan.d.ts.map +1 -1
- package/build/lib/file-router/scan.js +13 -22
- package/build/lib/file-router/scan.js.map +1 -1
- package/build/lib/file-router/sidebar/index.d.ts +3 -0
- package/build/lib/file-router/sidebar/index.d.ts.map +1 -0
- package/build/lib/file-router/sidebar/index.js +4 -0
- package/build/lib/file-router/sidebar/index.js.map +1 -0
- package/build/lib/file-router/sidebar/sidebar-tree.d.ts +9 -0
- package/build/lib/file-router/sidebar/sidebar-tree.d.ts.map +1 -0
- package/build/lib/file-router/sidebar/sidebar-tree.js +85 -0
- package/build/lib/file-router/sidebar/sidebar-tree.js.map +1 -0
- package/build/lib/file-router/sidebar/types.d.ts +17 -0
- package/build/lib/file-router/sidebar/types.d.ts.map +1 -0
- package/build/lib/file-router/sidebar/types.js.map +1 -0
- package/build/lib/helpers.d.ts.map +1 -1
- package/build/lib/helpers.js +3 -5
- package/build/lib/helpers.js.map +1 -1
- package/build/lib/kit-temp.d.ts +0 -157
- package/build/lib/kit-temp.d.ts.map +1 -1
- package/build/lib/kit-temp.js +14 -316
- package/build/lib/kit-temp.js.map +1 -1
- package/build/lib/tree/index.d.ts +3 -0
- package/build/lib/tree/index.d.ts.map +1 -0
- package/build/lib/tree/index.js +2 -0
- package/build/lib/tree/index.js.map +1 -0
- package/build/lib/tree/tree.d.ts +62 -0
- package/build/lib/tree/tree.d.ts.map +1 -0
- package/build/lib/tree/tree.js +134 -0
- package/build/lib/tree/tree.js.map +1 -0
- package/build/lib/vite-plugin-reactive-data/vite-plugin-reactive-data.d.ts +8 -1
- package/build/lib/vite-plugin-reactive-data/vite-plugin-reactive-data.d.ts.map +1 -1
- package/build/lib/vite-plugin-reactive-data/vite-plugin-reactive-data.js +53 -48
- package/build/lib/vite-plugin-reactive-data/vite-plugin-reactive-data.js.map +1 -1
- package/build/package-paths.js +3 -3
- package/build/package-paths.js.map +1 -1
- package/build/singletons/debug.d.ts +1 -1
- package/build/singletons/debug.d.ts.map +1 -1
- package/build/singletons/debug.js +1 -1
- package/build/singletons/debug.js.map +1 -1
- package/build/template/components/ArgumentAnnotation.jsx +16 -0
- package/build/template/components/ArgumentAnnotation.jsx.map +1 -0
- package/build/template/components/ArgumentList.jsx +16 -0
- package/build/template/components/ArgumentList.jsx.map +1 -0
- package/build/template/components/ArgumentListAnnotation.jsx +23 -0
- package/build/template/components/ArgumentListAnnotation.jsx.map +1 -0
- package/build/template/components/Changelog.jsx +68 -0
- package/build/template/components/Changelog.jsx.map +1 -0
- package/build/template/components/{CodeBlock.js → CodeBlock.jsx} +5 -4
- package/build/template/components/{CodeBlock.js.map → CodeBlock.jsx.map} +1 -1
- package/build/template/components/DeprecationReason.jsx +10 -0
- package/build/template/components/DeprecationReason.jsx.map +1 -0
- package/build/template/components/Description.jsx +10 -0
- package/build/template/components/Description.jsx.map +1 -0
- package/build/template/components/Field.jsx +22 -0
- package/build/template/components/Field.jsx.map +1 -0
- package/build/template/components/{FieldList.js → FieldList.jsx} +5 -4
- package/build/template/components/FieldList.jsx.map +1 -0
- package/build/template/components/{FieldListSection.js → FieldListSection.jsx} +6 -4
- package/build/template/components/FieldListSection.jsx.map +1 -0
- package/build/template/components/Link.d.ts +2 -2
- package/build/template/components/Link.d.ts.map +1 -1
- package/build/template/components/{Link.js → Link.jsx} +10 -18
- package/build/template/components/Link.jsx.map +1 -0
- package/build/template/components/Logo.jsx +29 -0
- package/build/template/components/Logo.jsx.map +1 -0
- package/build/template/components/{Markdown.js → Markdown.jsx} +2 -3
- package/build/template/components/Markdown.jsx.map +1 -0
- package/build/template/components/MissingSchema.d.ts +1 -1
- package/build/template/components/MissingSchema.d.ts.map +1 -1
- package/build/template/components/MissingSchema.jsx +4 -0
- package/build/template/components/MissingSchema.jsx.map +1 -0
- package/build/template/components/NamedType.jsx +17 -0
- package/build/template/components/NamedType.jsx.map +1 -0
- package/build/template/components/{RadixLink.js → RadixLink.jsx} +1 -1
- package/build/template/components/RadixLink.jsx.map +1 -0
- package/build/template/components/Texts/{MinorHeading.js → MinorHeading.jsx} +3 -4
- package/build/template/components/Texts/MinorHeading.jsx.map +1 -0
- package/build/template/components/Texts/texts.js +1 -1
- package/build/template/components/Texts/texts.js.map +1 -1
- package/build/template/components/{TypeAnnotation.js → TypeAnnotation.jsx} +18 -8
- package/build/template/components/TypeAnnotation.jsx.map +1 -0
- package/build/template/components/TypeFieldsLinkList.jsx +17 -0
- package/build/template/components/TypeFieldsLinkList.jsx.map +1 -0
- package/build/template/components/TypeIndex.jsx +27 -0
- package/build/template/components/TypeIndex.jsx.map +1 -0
- package/build/template/components/graphql/graphql.d.ts +2 -2
- package/build/template/components/graphql/graphql.jsx +3 -0
- package/build/template/components/graphql/graphql.jsx.map +1 -0
- package/build/template/components/graphql/index.d.ts +1 -1
- package/build/template/components/graphql/index.js +1 -1
- package/build/template/components/graphql/index.js.map +1 -1
- package/build/template/components/graphql/{type-kind-icon.js → type-kind-icon.jsx} +2 -3
- package/build/template/components/graphql/type-kind-icon.jsx.map +1 -0
- package/build/template/components/graphql/type-link.jsx +16 -0
- package/build/template/components/graphql/type-link.jsx.map +1 -0
- package/build/template/components/sidebar/Sidebar.d.ts +3 -3
- package/build/template/components/sidebar/Sidebar.d.ts.map +1 -1
- package/build/template/components/sidebar/Sidebar.jsx +15 -0
- package/build/template/components/sidebar/Sidebar.jsx.map +1 -0
- package/build/template/components/sidebar/SidebarItem.d.ts +3 -3
- package/build/template/components/sidebar/SidebarItem.d.ts.map +1 -1
- package/build/template/components/sidebar/{SidebarItem.js → SidebarItem.jsx} +35 -18
- package/build/template/components/sidebar/SidebarItem.jsx.map +1 -0
- package/build/template/components/sidebar/ToggleButton.d.ts +1 -1
- package/build/template/components/sidebar/ToggleButton.d.ts.map +1 -1
- package/build/template/components/sidebar/ToggleButton.jsx +6 -0
- package/build/template/components/sidebar/ToggleButton.jsx.map +1 -0
- package/build/template/entry.client.d.ts +0 -1
- package/build/template/entry.client.d.ts.map +1 -1
- package/build/template/{entry.client.js → entry.client.jsx} +9 -5
- package/build/template/entry.client.jsx.map +1 -0
- package/build/template/routes/changelog.d.ts +1 -1
- package/build/template/routes/{changelog.js → changelog.jsx} +4 -5
- package/build/template/routes/changelog.jsx.map +1 -0
- package/build/template/routes/{index.js → index.jsx} +2 -3
- package/build/template/routes/index.jsx.map +1 -0
- package/build/template/routes/reference.$type.$field.d.ts +1 -1
- package/build/template/routes/{reference.$type.$field.js → reference.$type.$field.jsx} +5 -6
- package/build/template/routes/reference.$type.$field.jsx.map +1 -0
- package/build/template/routes/reference.$type.d.ts +1 -1
- package/build/template/routes/{reference.$type.js → reference.$type.jsx} +5 -6
- package/build/template/routes/reference.$type.jsx.map +1 -0
- package/build/template/routes/reference.d.ts +2 -2
- package/build/template/routes/reference.d.ts.map +1 -1
- package/build/template/routes/{reference.js → reference.jsx} +12 -7
- package/build/template/routes/reference.jsx.map +1 -0
- package/build/template/routes/root.d.ts +2 -2
- package/build/template/routes/root.d.ts.map +1 -1
- package/build/template/routes/root.jsx +188 -0
- package/build/template/routes/root.jsx.map +1 -0
- package/build/template/routes.jsx +5 -0
- package/build/template/routes.jsx.map +1 -0
- package/build/template/server/app.d.ts +1 -8
- package/build/template/server/app.d.ts.map +1 -1
- package/build/template/server/app.js +21 -21
- package/build/template/server/app.js.map +1 -1
- package/build/template/server/main.js +1 -2
- package/build/template/server/main.js.map +1 -1
- package/build/template/server/render-page.d.ts +3 -0
- package/build/template/server/render-page.d.ts.map +1 -0
- package/build/template/server/{create-page-html-response.js → render-page.jsx} +17 -11
- package/build/template/server/render-page.jsx.map +1 -0
- package/build/template/server/ssg/generate.d.ts.map +1 -1
- package/build/template/server/ssg/generate.js +34 -33
- package/build/template/server/ssg/generate.js.map +1 -1
- package/build/template/server/ssg/get-route-paths.js +1 -1
- package/build/template/server/ssg/get-route-paths.js.map +1 -1
- package/build/template/server/view.js +1 -1
- package/build/template/server/view.js.map +1 -1
- package/package.json +9 -73
- package/src/api/api.ts +0 -1
- package/src/api/config/load.ts +5 -5
- package/src/api/config-resolver/resolve.ts +2 -2
- package/src/api/schema/data-sources/schema-directory/schema-directory.ts +1 -1
- package/src/api/singletons/markdown/markdown.test.ts +2 -2
- package/src/api/utils/asset-url/asset-url.test.ts +4 -4
- package/src/api/vite/plugins/branding/index.ts +4 -4
- package/src/api/vite/plugins/build.ts +89 -121
- package/src/api/vite/plugins/core.ts +17 -19
- package/src/api/vite/plugins/pages.ts +209 -135
- package/src/api/vite/plugins/serve.ts +14 -67
- package/src/cli/_/self-contained-mode.ts +5 -5
- package/src/lib/file-router/diagnostic-reporter.ts +2 -2
- package/src/lib/file-router/file-router.ts +2 -0
- package/src/lib/file-router/linter.test.ts +0 -2
- package/src/lib/file-router/route.ts +0 -2
- package/src/lib/file-router/scan-tree.test.ts +189 -0
- package/src/lib/file-router/scan-tree.ts +205 -0
- package/src/lib/file-router/scan.ts +14 -26
- package/src/lib/file-router/sidebar/index.ts +3 -0
- package/src/lib/file-router/sidebar/sidebar-tree.test.ts +123 -0
- package/src/lib/file-router/sidebar/sidebar-tree.ts +110 -0
- package/src/lib/file-router/sidebar/types.ts +19 -0
- package/src/lib/helpers.ts +3 -4
- package/src/lib/kit-temp.ts +14 -428
- package/src/lib/shiki/shiki.test.ts +1 -1
- package/src/lib/tree/index.ts +2 -0
- package/src/lib/tree/tree.test.ts +117 -0
- package/src/lib/tree/tree.ts +183 -0
- package/src/lib/vite-plugin-reactive-data/vite-plugin-reactive-data.ts +58 -52
- package/src/package-paths.ts +3 -3
- package/src/singletons/debug.ts +1 -1
- package/src/template/components/ArgumentAnnotation.tsx +1 -1
- package/src/template/components/ArgumentList.tsx +1 -1
- package/src/template/components/ArgumentListAnnotation.tsx +2 -2
- package/src/template/components/DeprecationReason.tsx +1 -1
- package/src/template/components/Description.tsx +1 -1
- package/src/template/components/Field.tsx +4 -4
- package/src/template/components/FieldList.tsx +1 -1
- package/src/template/components/FieldListSection.tsx +1 -1
- package/src/template/components/Link.tsx +15 -23
- package/src/template/components/NamedType.tsx +2 -2
- package/src/template/components/TypeAnnotation.tsx +1 -1
- package/src/template/components/TypeFieldsLinkList.tsx +1 -1
- package/src/template/components/TypeIndex.tsx +1 -1
- package/src/template/components/graphql/graphql.tsx +2 -2
- package/src/template/components/graphql/index.ts +1 -1
- package/src/template/components/graphql/type-link.tsx +2 -2
- package/src/template/components/sidebar/Sidebar.tsx +2 -2
- package/src/template/components/sidebar/SidebarItem.tsx +14 -14
- package/src/template/entry.client.tsx +5 -2
- package/src/template/routes/changelog.tsx +1 -1
- package/src/template/routes/reference.$type.$field.tsx +3 -3
- package/src/template/routes/reference.$type.tsx +3 -3
- package/src/template/routes/reference.tsx +10 -6
- package/src/template/routes/root.tsx +108 -112
- package/src/template/routes.tsx +1 -1
- package/src/template/server/app.ts +23 -33
- package/src/template/server/main.ts +1 -2
- package/src/template/server/{create-page-html-response.ts → render-page.tsx} +16 -19
- package/src/template/server/ssg/generate.ts +72 -68
- package/src/template/server/ssg/get-route-paths.ts +1 -1
- package/src/template/server/view.ts +1 -1
- package/src/template/styles/code-block.css +0 -32
- package/build/api/content/$$.d.ts +0 -7
- package/build/api/content/$$.d.ts.map +0 -1
- package/build/api/content/$$.js +0 -7
- package/build/api/content/$$.js.map +0 -1
- package/build/api/content/$.d.ts +0 -2
- package/build/api/content/$.d.ts.map +0 -1
- package/build/api/content/$.js +0 -2
- package/build/api/content/$.js.map +0 -1
- package/build/api/content/metadata.d.ts +0 -10
- package/build/api/content/metadata.d.ts.map +0 -1
- package/build/api/content/metadata.js +0 -9
- package/build/api/content/metadata.js.map +0 -1
- package/build/api/content/navbar.d.ts +0 -10
- package/build/api/content/navbar.d.ts.map +0 -1
- package/build/api/content/navbar.js +0 -45
- package/build/api/content/navbar.js.map +0 -1
- package/build/api/content/page.d.ts +0 -11
- package/build/api/content/page.d.ts.map +0 -1
- package/build/api/content/page.js +0 -2
- package/build/api/content/page.js.map +0 -1
- package/build/api/content/scan.d.ts +0 -19
- package/build/api/content/scan.d.ts.map +0 -1
- package/build/api/content/scan.js +0 -90
- package/build/api/content/scan.js.map +0 -1
- package/build/api/content/sidebar.d.ts +0 -104
- package/build/api/content/sidebar.d.ts.map +0 -1
- package/build/api/content/sidebar.js +0 -166
- package/build/api/content/sidebar.js.map +0 -1
- package/build/api/content/utils.d.ts +0 -5
- package/build/api/content/utils.d.ts.map +0 -1
- package/build/api/content/utils.js +0 -8
- package/build/api/content/utils.js.map +0 -1
- package/build/api/static/index.d.ts +0 -2
- package/build/api/static/index.d.ts.map +0 -1
- package/build/api/static/index.js +0 -2
- package/build/api/static/index.js.map +0 -1
- package/build/api/static/manifest.d.ts +0 -18
- package/build/api/static/manifest.d.ts.map +0 -1
- package/build/api/static/manifest.js +0 -13
- package/build/api/static/manifest.js.map +0 -1
- package/build/api/static/rebase.d.ts +0 -14
- package/build/api/static/rebase.d.ts.map +0 -1
- package/build/api/static/rebase.js +0 -110
- package/build/api/static/rebase.js.map +0 -1
- package/build/api/static/static.d.ts +0 -3
- package/build/api/static/static.d.ts.map +0 -1
- package/build/api/static/static.js +0 -3
- package/build/api/static/static.js.map +0 -1
- package/build/cli/commands/static/$default.d.ts +0 -3
- package/build/cli/commands/static/$default.d.ts.map +0 -1
- package/build/cli/commands/static/$default.js +0 -38
- package/build/cli/commands/static/$default.js.map +0 -1
- package/build/cli/commands/static/rebase.d.ts +0 -2
- package/build/cli/commands/static/rebase.d.ts.map +0 -1
- package/build/cli/commands/static/rebase.js +0 -26
- package/build/cli/commands/static/rebase.js.map +0 -1
- package/build/cli/commands/static.d.ts +0 -3
- package/build/cli/commands/static.d.ts.map +0 -1
- package/build/cli/commands/static.js +0 -5
- package/build/cli/commands/static.js.map +0 -1
- package/build/exports/components.d.ts +0 -5
- package/build/exports/components.d.ts.map +0 -1
- package/build/exports/components.js +0 -5
- package/build/exports/components.js.map +0 -1
- package/build/lib/demos/builder.d.ts +0 -83
- package/build/lib/demos/builder.d.ts.map +0 -1
- package/build/lib/demos/builder.js +0 -237
- package/build/lib/demos/builder.js.map +0 -1
- package/build/lib/demos/config-schema.d.ts +0 -243
- package/build/lib/demos/config-schema.d.ts.map +0 -1
- package/build/lib/demos/config-schema.js +0 -52
- package/build/lib/demos/config-schema.js.map +0 -1
- package/build/lib/demos/config.d.ts +0 -40
- package/build/lib/demos/config.d.ts.map +0 -1
- package/build/lib/demos/config.js +0 -180
- package/build/lib/demos/config.js.map +0 -1
- package/build/lib/demos/index.d.ts +0 -9
- package/build/lib/demos/index.d.ts.map +0 -1
- package/build/lib/demos/index.js +0 -8
- package/build/lib/demos/index.js.map +0 -1
- package/build/lib/demos/ui/components.d.ts +0 -33
- package/build/lib/demos/ui/components.d.ts.map +0 -1
- package/build/lib/demos/ui/components.js +0 -699
- package/build/lib/demos/ui/components.js.map +0 -1
- package/build/lib/demos/ui/data-collector.d.ts +0 -88
- package/build/lib/demos/ui/data-collector.d.ts.map +0 -1
- package/build/lib/demos/ui/data-collector.js +0 -174
- package/build/lib/demos/ui/data-collector.js.map +0 -1
- package/build/lib/demos/ui/landing-page-cli.d.ts +0 -3
- package/build/lib/demos/ui/landing-page-cli.d.ts.map +0 -1
- package/build/lib/demos/ui/landing-page-cli.js +0 -21
- package/build/lib/demos/ui/landing-page-cli.js.map +0 -1
- package/build/lib/demos/ui/landing-page.d.ts +0 -32
- package/build/lib/demos/ui/landing-page.d.ts.map +0 -1
- package/build/lib/demos/ui/landing-page.js +0 -83
- package/build/lib/demos/ui/landing-page.js.map +0 -1
- package/build/lib/demos/ui/page-renderer.d.ts +0 -26
- package/build/lib/demos/ui/page-renderer.d.ts.map +0 -1
- package/build/lib/demos/ui/page-renderer.js +0 -104
- package/build/lib/demos/ui/page-renderer.js.map +0 -1
- package/build/lib/demos/utils.d.ts +0 -14
- package/build/lib/demos/utils.d.ts.map +0 -1
- package/build/lib/demos/utils.js +0 -37
- package/build/lib/demos/utils.js.map +0 -1
- package/build/lib/deployment/$$.d.ts +0 -3
- package/build/lib/deployment/$$.d.ts.map +0 -1
- package/build/lib/deployment/$$.js +0 -3
- package/build/lib/deployment/$$.js.map +0 -1
- package/build/lib/deployment/$.d.ts +0 -2
- package/build/lib/deployment/$.d.ts.map +0 -1
- package/build/lib/deployment/$.js +0 -2
- package/build/lib/deployment/$.js.map +0 -1
- package/build/lib/deployment/metadata.d.ts +0 -32
- package/build/lib/deployment/metadata.d.ts.map +0 -1
- package/build/lib/deployment/metadata.js +0 -37
- package/build/lib/deployment/metadata.js.map +0 -1
- package/build/lib/deployment/path-manager.d.ts +0 -41
- package/build/lib/deployment/path-manager.d.ts.map +0 -1
- package/build/lib/deployment/path-manager.js +0 -157
- package/build/lib/deployment/path-manager.js.map +0 -1
- package/build/lib/github-actions/git-controller.d.ts +0 -50
- package/build/lib/github-actions/git-controller.d.ts.map +0 -1
- package/build/lib/github-actions/git-controller.js +0 -90
- package/build/lib/github-actions/git-controller.js.map +0 -1
- package/build/lib/github-actions/github-actions.d.ts +0 -7
- package/build/lib/github-actions/github-actions.d.ts.map +0 -1
- package/build/lib/github-actions/github-actions.js +0 -7
- package/build/lib/github-actions/github-actions.js.map +0 -1
- package/build/lib/github-actions/index.d.ts +0 -2
- package/build/lib/github-actions/index.d.ts.map +0 -1
- package/build/lib/github-actions/index.js +0 -2
- package/build/lib/github-actions/index.js.map +0 -1
- package/build/lib/github-actions/lib/get-pr-deployments.d.ts +0 -12
- package/build/lib/github-actions/lib/get-pr-deployments.d.ts.map +0 -1
- package/build/lib/github-actions/lib/get-pr-deployments.js +0 -51
- package/build/lib/github-actions/lib/get-pr-deployments.js.map +0 -1
- package/build/lib/github-actions/pr-controller.d.ts +0 -39
- package/build/lib/github-actions/pr-controller.d.ts.map +0 -1
- package/build/lib/github-actions/pr-controller.js +0 -122
- package/build/lib/github-actions/pr-controller.js.map +0 -1
- package/build/lib/github-actions/run-step-cli.d.ts +0 -9
- package/build/lib/github-actions/run-step-cli.d.ts.map +0 -1
- package/build/lib/github-actions/run-step-cli.js +0 -71
- package/build/lib/github-actions/run-step-cli.js.map +0 -1
- package/build/lib/github-actions/runner.d.ts +0 -17
- package/build/lib/github-actions/runner.d.ts.map +0 -1
- package/build/lib/github-actions/runner.js +0 -195
- package/build/lib/github-actions/runner.js.map +0 -1
- package/build/lib/github-actions/schemas/context.d.ts +0 -933
- package/build/lib/github-actions/schemas/context.d.ts.map +0 -1
- package/build/lib/github-actions/schemas/context.js +0 -407
- package/build/lib/github-actions/schemas/context.js.map +0 -1
- package/build/lib/github-actions/schemas/index.d.ts +0 -5
- package/build/lib/github-actions/schemas/index.d.ts.map +0 -1
- package/build/lib/github-actions/schemas/index.js +0 -5
- package/build/lib/github-actions/schemas/index.js.map +0 -1
- package/build/lib/github-actions/search-module.d.ts +0 -38
- package/build/lib/github-actions/search-module.d.ts.map +0 -1
- package/build/lib/github-actions/search-module.js +0 -40
- package/build/lib/github-actions/search-module.js.map +0 -1
- package/build/lib/github-actions/step.d.ts +0 -163
- package/build/lib/github-actions/step.d.ts.map +0 -1
- package/build/lib/github-actions/step.js +0 -121
- package/build/lib/github-actions/step.js.map +0 -1
- package/build/lib/graphql-document/$$.d.ts +0 -5
- package/build/lib/graphql-document/$$.d.ts.map +0 -1
- package/build/lib/graphql-document/$$.js +0 -5
- package/build/lib/graphql-document/$$.js.map +0 -1
- package/build/lib/graphql-document/$.d.ts +0 -2
- package/build/lib/graphql-document/$.d.ts.map +0 -1
- package/build/lib/graphql-document/$.js +0 -2
- package/build/lib/graphql-document/$.js.map +0 -1
- package/build/lib/graphql-document/analysis.d.ts +0 -44
- package/build/lib/graphql-document/analysis.d.ts.map +0 -1
- package/build/lib/graphql-document/analysis.js +0 -361
- package/build/lib/graphql-document/analysis.js.map +0 -1
- package/build/lib/graphql-document/components/CopyButton.d.ts +0 -19
- package/build/lib/graphql-document/components/CopyButton.d.ts.map +0 -1
- package/build/lib/graphql-document/components/CopyButton.js +0 -43
- package/build/lib/graphql-document/components/CopyButton.js.map +0 -1
- package/build/lib/graphql-document/components/GraphQLDocument.d.ts +0 -38
- package/build/lib/graphql-document/components/GraphQLDocument.d.ts.map +0 -1
- package/build/lib/graphql-document/components/GraphQLDocument.js +0 -142
- package/build/lib/graphql-document/components/GraphQLDocument.js.map +0 -1
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts +0 -7
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts.map +0 -1
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js +0 -45
- package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js.map +0 -1
- package/build/lib/graphql-document/components/GraphQLIdentifierPopover.d.ts +0 -33
- package/build/lib/graphql-document/components/GraphQLIdentifierPopover.d.ts.map +0 -1
- package/build/lib/graphql-document/components/GraphQLIdentifierPopover.js +0 -48
- package/build/lib/graphql-document/components/GraphQLIdentifierPopover.js.map +0 -1
- package/build/lib/graphql-document/components/IdentifierLink.d.ts +0 -39
- package/build/lib/graphql-document/components/IdentifierLink.d.ts.map +0 -1
- package/build/lib/graphql-document/components/IdentifierLink.js +0 -75
- package/build/lib/graphql-document/components/IdentifierLink.js.map +0 -1
- package/build/lib/graphql-document/components/graphql-document-styles.d.ts +0 -5
- package/build/lib/graphql-document/components/graphql-document-styles.d.ts.map +0 -1
- package/build/lib/graphql-document/components/graphql-document-styles.js +0 -167
- package/build/lib/graphql-document/components/graphql-document-styles.js.map +0 -1
- package/build/lib/graphql-document/components/index.d.ts +0 -6
- package/build/lib/graphql-document/components/index.d.ts.map +0 -1
- package/build/lib/graphql-document/components/index.js +0 -6
- package/build/lib/graphql-document/components/index.js.map +0 -1
- package/build/lib/graphql-document/example.d.ts +0 -25
- package/build/lib/graphql-document/example.d.ts.map +0 -1
- package/build/lib/graphql-document/example.js +0 -140
- package/build/lib/graphql-document/example.js.map +0 -1
- package/build/lib/graphql-document/graphql-document.d.ts +0 -35
- package/build/lib/graphql-document/graphql-document.d.ts.map +0 -1
- package/build/lib/graphql-document/graphql-document.js +0 -36
- package/build/lib/graphql-document/graphql-document.js.map +0 -1
- package/build/lib/graphql-document/hooks/use-tooltip-state.d.ts +0 -43
- package/build/lib/graphql-document/hooks/use-tooltip-state.d.ts.map +0 -1
- package/build/lib/graphql-document/hooks/use-tooltip-state.js +0 -132
- package/build/lib/graphql-document/hooks/use-tooltip-state.js.map +0 -1
- package/build/lib/graphql-document/positioning-simple.d.ts +0 -63
- package/build/lib/graphql-document/positioning-simple.d.ts.map +0 -1
- package/build/lib/graphql-document/positioning-simple.js +0 -185
- package/build/lib/graphql-document/positioning-simple.js.map +0 -1
- package/build/lib/graphql-document/schema-context.d.ts +0 -8
- package/build/lib/graphql-document/schema-context.d.ts.map +0 -1
- package/build/lib/graphql-document/schema-context.js +0 -11
- package/build/lib/graphql-document/schema-context.js.map +0 -1
- package/build/lib/graphql-document/schema-integration-example.d.ts +0 -27
- package/build/lib/graphql-document/schema-integration-example.d.ts.map +0 -1
- package/build/lib/graphql-document/schema-integration-example.js +0 -297
- package/build/lib/graphql-document/schema-integration-example.js.map +0 -1
- package/build/lib/graphql-document/schema-integration.d.ts +0 -135
- package/build/lib/graphql-document/schema-integration.d.ts.map +0 -1
- package/build/lib/graphql-document/schema-integration.js +0 -328
- package/build/lib/graphql-document/schema-integration.js.map +0 -1
- package/build/lib/graphql-document/types.d.ts +0 -117
- package/build/lib/graphql-document/types.d.ts.map +0 -1
- package/build/lib/graphql-document/types.js.map +0 -1
- package/build/lib/kit-temp.test-d.d.ts +0 -2
- package/build/lib/kit-temp.test-d.d.ts.map +0 -1
- package/build/lib/kit-temp.test-d.js +0 -75
- package/build/lib/kit-temp.test-d.js.map +0 -1
- package/build/lib/mask/$$.d.ts +0 -3
- package/build/lib/mask/$$.d.ts.map +0 -1
- package/build/lib/mask/$$.js +0 -3
- package/build/lib/mask/$$.js.map +0 -1
- package/build/lib/mask/$.d.ts +0 -2
- package/build/lib/mask/$.d.ts.map +0 -1
- package/build/lib/mask/$.js +0 -2
- package/build/lib/mask/$.js.map +0 -1
- package/build/lib/mask/apply.d.ts +0 -86
- package/build/lib/mask/apply.d.ts.map +0 -1
- package/build/lib/mask/apply.js +0 -86
- package/build/lib/mask/apply.js.map +0 -1
- package/build/lib/mask/mask.d.ts +0 -124
- package/build/lib/mask/mask.d.ts.map +0 -1
- package/build/lib/mask/mask.js +0 -137
- package/build/lib/mask/mask.js.map +0 -1
- package/build/lib/mask/mask.test-d.d.ts +0 -2
- package/build/lib/mask/mask.test-d.d.ts.map +0 -1
- package/build/lib/mask/mask.test-d.js +0 -102
- package/build/lib/mask/mask.test-d.js.map +0 -1
- package/build/lib/task/$$.d.ts +0 -3
- package/build/lib/task/$$.d.ts.map +0 -1
- package/build/lib/task/$$.js +0 -3
- package/build/lib/task/$$.js.map +0 -1
- package/build/lib/task/$.d.ts +0 -2
- package/build/lib/task/$.d.ts.map +0 -1
- package/build/lib/task/$.js +0 -2
- package/build/lib/task/$.js.map +0 -1
- package/build/lib/task/report.d.ts +0 -28
- package/build/lib/task/report.d.ts.map +0 -1
- package/build/lib/task/report.js +0 -33
- package/build/lib/task/report.js.map +0 -1
- package/build/lib/task/task.d.ts +0 -44
- package/build/lib/task/task.d.ts.map +0 -1
- package/build/lib/task/task.js +0 -63
- package/build/lib/task/task.js.map +0 -1
- package/build/lib/version-history/index.d.ts +0 -3
- package/build/lib/version-history/index.d.ts.map +0 -1
- package/build/lib/version-history/index.js +0 -2
- package/build/lib/version-history/index.js.map +0 -1
- package/build/lib/version-history/types.d.ts +0 -64
- package/build/lib/version-history/types.d.ts.map +0 -1
- package/build/lib/version-history/types.js +0 -5
- package/build/lib/version-history/types.js.map +0 -1
- package/build/lib/version-history/version-history.d.ts +0 -85
- package/build/lib/version-history/version-history.d.ts.map +0 -1
- package/build/lib/version-history/version-history.js +0 -248
- package/build/lib/version-history/version-history.js.map +0 -1
- package/build/sandbox.d.ts +0 -2
- package/build/sandbox.d.ts.map +0 -1
- package/build/sandbox.js +0 -18
- package/build/sandbox.js.map +0 -1
- package/build/template/components/ArgumentAnnotation.js +0 -10
- package/build/template/components/ArgumentAnnotation.js.map +0 -1
- package/build/template/components/ArgumentList.js +0 -9
- package/build/template/components/ArgumentList.js.map +0 -1
- package/build/template/components/ArgumentListAnnotation.js +0 -15
- package/build/template/components/ArgumentListAnnotation.js.map +0 -1
- package/build/template/components/Changelog.js +0 -44
- package/build/template/components/Changelog.js.map +0 -1
- package/build/template/components/CodeBlockEnhancer.d.ts +0 -2
- package/build/template/components/CodeBlockEnhancer.d.ts.map +0 -1
- package/build/template/components/CodeBlockEnhancer.js +0 -175
- package/build/template/components/CodeBlockEnhancer.js.map +0 -1
- package/build/template/components/DeprecationReason.js +0 -9
- package/build/template/components/DeprecationReason.js.map +0 -1
- package/build/template/components/Description.js +0 -9
- package/build/template/components/Description.js.map +0 -1
- package/build/template/components/Field.js +0 -14
- package/build/template/components/Field.js.map +0 -1
- package/build/template/components/FieldList.js.map +0 -1
- package/build/template/components/FieldListSection.js.map +0 -1
- package/build/template/components/HamburgerMenu.d.ts +0 -9
- package/build/template/components/HamburgerMenu.d.ts.map +0 -1
- package/build/template/components/HamburgerMenu.js +0 -30
- package/build/template/components/HamburgerMenu.js.map +0 -1
- package/build/template/components/Link.js.map +0 -1
- package/build/template/components/Logo.js +0 -20
- package/build/template/components/Logo.js.map +0 -1
- package/build/template/components/MDXComponents.d.ts +0 -11
- package/build/template/components/MDXComponents.d.ts.map +0 -1
- package/build/template/components/MDXComponents.js +0 -70
- package/build/template/components/MDXComponents.js.map +0 -1
- package/build/template/components/Markdown.js.map +0 -1
- package/build/template/components/MissingSchema.js +0 -5
- package/build/template/components/MissingSchema.js.map +0 -1
- package/build/template/components/NamedType.js +0 -12
- package/build/template/components/NamedType.js.map +0 -1
- package/build/template/components/NotFound.d.ts +0 -2
- package/build/template/components/NotFound.d.ts.map +0 -1
- package/build/template/components/NotFound.js +0 -7
- package/build/template/components/NotFound.js.map +0 -1
- package/build/template/components/RadixLink.js.map +0 -1
- package/build/template/components/TestComponent.d.ts +0 -5
- package/build/template/components/TestComponent.d.ts.map +0 -1
- package/build/template/components/TestComponent.js +0 -7
- package/build/template/components/TestComponent.js.map +0 -1
- package/build/template/components/Texts/MinorHeading.js.map +0 -1
- package/build/template/components/ThemeToggle.d.ts +0 -3
- package/build/template/components/ThemeToggle.d.ts.map +0 -1
- package/build/template/components/ThemeToggle.js +0 -9
- package/build/template/components/ThemeToggle.js.map +0 -1
- package/build/template/components/TypeAnnotation.js.map +0 -1
- package/build/template/components/TypeFieldsLinkList.js +0 -9
- package/build/template/components/TypeFieldsLinkList.js.map +0 -1
- package/build/template/components/TypeIndex.js +0 -17
- package/build/template/components/TypeIndex.js.map +0 -1
- package/build/template/components/content/$$.d.ts +0 -3
- package/build/template/components/content/$$.d.ts.map +0 -1
- package/build/template/components/content/$$.js +0 -3
- package/build/template/components/content/$$.js.map +0 -1
- package/build/template/components/content/GraphQLDocumentWithSchema.d.ts +0 -8
- package/build/template/components/content/GraphQLDocumentWithSchema.d.ts.map +0 -1
- package/build/template/components/content/GraphQLDocumentWithSchema.js +0 -13
- package/build/template/components/content/GraphQLDocumentWithSchema.js.map +0 -1
- package/build/template/components/content/GraphQLDocumentWrapper.d.ts +0 -7
- package/build/template/components/content/GraphQLDocumentWrapper.d.ts.map +0 -1
- package/build/template/components/content/GraphQLDocumentWrapper.js +0 -63
- package/build/template/components/content/GraphQLDocumentWrapper.js.map +0 -1
- package/build/template/components/graphql/graphql.js +0 -3
- package/build/template/components/graphql/graphql.js.map +0 -1
- package/build/template/components/graphql/type-kind-icon.js.map +0 -1
- package/build/template/components/graphql/type-link.js +0 -11
- package/build/template/components/graphql/type-link.js.map +0 -1
- package/build/template/components/sidebar/Sidebar.js +0 -11
- package/build/template/components/sidebar/Sidebar.js.map +0 -1
- package/build/template/components/sidebar/SidebarItem.js.map +0 -1
- package/build/template/components/sidebar/ToggleButton.js +0 -5
- package/build/template/components/sidebar/ToggleButton.js.map +0 -1
- package/build/template/contexts/ThemeContext.d.ts +0 -12
- package/build/template/contexts/ThemeContext.d.ts.map +0 -1
- package/build/template/contexts/ThemeContext.js +0 -40
- package/build/template/contexts/ThemeContext.js.map +0 -1
- package/build/template/entry.client.js.map +0 -1
- package/build/template/hooks/useClientOnly.d.ts +0 -9
- package/build/template/hooks/useClientOnly.d.ts.map +0 -1
- package/build/template/hooks/useClientOnly.js +0 -16
- package/build/template/hooks/useClientOnly.js.map +0 -1
- package/build/template/routes/changelog.js.map +0 -1
- package/build/template/routes/index.js.map +0 -1
- package/build/template/routes/reference.$type.$field.js.map +0 -1
- package/build/template/routes/reference.$type.js.map +0 -1
- package/build/template/routes/reference.js.map +0 -1
- package/build/template/routes/root.js +0 -138
- package/build/template/routes/root.js.map +0 -1
- package/build/template/routes.js +0 -5
- package/build/template/routes.js.map +0 -1
- package/build/template/server/create-page-html-response.d.ts +0 -7
- package/build/template/server/create-page-html-response.d.ts.map +0 -1
- package/build/template/server/create-page-html-response.js.map +0 -1
- package/build/template/server/middleware/page.d.ts +0 -4
- package/build/template/server/middleware/page.d.ts.map +0 -1
- package/build/template/server/middleware/page.js +0 -15
- package/build/template/server/middleware/page.js.map +0 -1
- package/build/template/server/middleware/unsupported-assets.d.ts +0 -10
- package/build/template/server/middleware/unsupported-assets.d.ts.map +0 -1
- package/build/template/server/middleware/unsupported-assets.js +0 -21
- package/build/template/server/middleware/unsupported-assets.js.map +0 -1
- package/build/template/styles/code-block.css +0 -218
- package/src/api/content/$$.ts +0 -6
- package/src/api/content/$.test.ts +0 -72
- package/src/api/content/$.ts +0 -1
- package/src/api/content/metadata.ts +0 -11
- package/src/api/content/navbar.test.ts +0 -55
- package/src/api/content/navbar.ts +0 -61
- package/src/api/content/page.ts +0 -12
- package/src/api/content/scan.ts +0 -117
- package/src/api/content/sidebar.test.ts +0 -297
- package/src/api/content/sidebar.ts +0 -283
- package/src/api/content/utils.ts +0 -7
- package/src/api/static/index.ts +0 -1
- package/src/api/static/manifest.test.ts +0 -106
- package/src/api/static/manifest.ts +0 -16
- package/src/api/static/rebase.test.ts +0 -229
- package/src/api/static/rebase.ts +0 -140
- package/src/api/static/static.ts +0 -2
- package/src/cli/commands/static/$default.ts +0 -43
- package/src/cli/commands/static/rebase.ts +0 -37
- package/src/cli/commands/static.ts +0 -6
- package/src/exports/components.ts +0 -4
- package/src/lib/demos/builder.ts +0 -298
- package/src/lib/demos/config-schema.ts +0 -56
- package/src/lib/demos/config.test.ts +0 -193
- package/src/lib/demos/config.ts +0 -205
- package/src/lib/demos/index.ts +0 -9
- package/src/lib/demos/ui/components.ts +0 -739
- package/src/lib/demos/ui/data-collector.ts +0 -246
- package/src/lib/demos/ui/landing-page-cli.ts +0 -23
- package/src/lib/demos/ui/landing-page.ts +0 -126
- package/src/lib/demos/ui/page-renderer.ts +0 -124
- package/src/lib/demos/utils.ts +0 -43
- package/src/lib/deployment/$$.ts +0 -2
- package/src/lib/deployment/$.test.ts +0 -53
- package/src/lib/deployment/$.ts +0 -1
- package/src/lib/deployment/metadata.ts +0 -40
- package/src/lib/deployment/path-manager.ts +0 -186
- package/src/lib/github-actions/git-controller.ts +0 -151
- package/src/lib/github-actions/github-actions.ts +0 -6
- package/src/lib/github-actions/index.ts +0 -1
- package/src/lib/github-actions/lib/get-pr-deployments.ts +0 -76
- package/src/lib/github-actions/pr-controller.test.ts +0 -172
- package/src/lib/github-actions/pr-controller.ts +0 -183
- package/src/lib/github-actions/run-step-cli.ts +0 -84
- package/src/lib/github-actions/runner.test.ts +0 -192
- package/src/lib/github-actions/runner.ts +0 -226
- package/src/lib/github-actions/schemas/context.ts +0 -424
- package/src/lib/github-actions/schemas/index.ts +0 -5
- package/src/lib/github-actions/search-module.test.ts +0 -110
- package/src/lib/github-actions/search-module.ts +0 -76
- package/src/lib/github-actions/step.test.ts +0 -149
- package/src/lib/github-actions/step.ts +0 -232
- package/src/lib/graphql-document/$$.ts +0 -4
- package/src/lib/graphql-document/$.test.ts +0 -132
- package/src/lib/graphql-document/$.ts +0 -1
- package/src/lib/graphql-document/README.md +0 -102
- package/src/lib/graphql-document/analysis.ts +0 -415
- package/src/lib/graphql-document/components/CopyButton.tsx +0 -76
- package/src/lib/graphql-document/components/GraphQLDocument.tsx +0 -262
- package/src/lib/graphql-document/components/GraphQLDocument.unit.test.ts +0 -188
- package/src/lib/graphql-document/components/GraphQLDocumentWithSchema.tsx +0 -70
- package/src/lib/graphql-document/components/GraphQLIdentifierPopover.tsx +0 -197
- package/src/lib/graphql-document/components/IdentifierLink.tsx +0 -160
- package/src/lib/graphql-document/components/graphql-document-styles.ts +0 -167
- package/src/lib/graphql-document/components/index.ts +0 -5
- package/src/lib/graphql-document/demo.md +0 -155
- package/src/lib/graphql-document/example.ts +0 -163
- package/src/lib/graphql-document/graphql-document.ts +0 -37
- package/src/lib/graphql-document/hooks/use-tooltip-state.test.ts +0 -76
- package/src/lib/graphql-document/hooks/use-tooltip-state.ts +0 -191
- package/src/lib/graphql-document/positioning-simple.test.ts +0 -248
- package/src/lib/graphql-document/positioning-simple.ts +0 -260
- package/src/lib/graphql-document/schema-context.tsx +0 -20
- package/src/lib/graphql-document/schema-integration-example.ts +0 -341
- package/src/lib/graphql-document/schema-integration.test.ts +0 -365
- package/src/lib/graphql-document/schema-integration.ts +0 -497
- package/src/lib/graphql-document/types.ts +0 -129
- package/src/lib/kit-temp.test-d.ts +0 -115
- package/src/lib/kit-temp.test.ts +0 -139
- package/src/lib/mask/$$.ts +0 -2
- package/src/lib/mask/$.test.ts +0 -248
- package/src/lib/mask/$.ts +0 -1
- package/src/lib/mask/apply.ts +0 -134
- package/src/lib/mask/mask.test-d.ts +0 -144
- package/src/lib/mask/mask.ts +0 -244
- package/src/lib/task/$$.ts +0 -2
- package/src/lib/task/$.test.ts +0 -209
- package/src/lib/task/$.ts +0 -1
- package/src/lib/task/report.ts +0 -72
- package/src/lib/task/task.ts +0 -112
- package/src/lib/version-history/index.test.ts +0 -196
- package/src/lib/version-history/index.ts +0 -4
- package/src/lib/version-history/types.ts +0 -68
- package/src/lib/version-history/version-history.ts +0 -293
- package/src/sandbox.ts +0 -20
- package/src/template/components/CodeBlockEnhancer.tsx +0 -192
- package/src/template/components/HamburgerMenu.tsx +0 -96
- package/src/template/components/MDXComponents.tsx +0 -101
- package/src/template/components/NotFound.tsx +0 -28
- package/src/template/components/TestComponent.tsx +0 -6
- package/src/template/components/ThemeToggle.tsx +0 -21
- package/src/template/components/content/$$.ts +0 -2
- package/src/template/components/content/GraphQLDocumentWithSchema.tsx +0 -13
- package/src/template/components/content/GraphQLDocumentWrapper.tsx +0 -89
- package/src/template/contexts/ThemeContext.tsx +0 -60
- package/src/template/hooks/useClientOnly.ts +0 -21
- package/src/template/server/middleware/page.ts +0 -19
- package/src/template/server/middleware/unsupported-assets.ts +0 -25
- /package/build/lib/{graphql-document → file-router/sidebar}/types.js +0 -0
@@ -36,8 +36,6 @@ export const pathToExpression = (path: Path) => {
|
|
36
36
|
export interface Route {
|
37
37
|
logical: RouteLogical
|
38
38
|
file: RouteFile
|
39
|
-
id: string // Absolute file path for unique identification
|
40
|
-
parentId: string | null // Parent directory path, null for root-level files
|
41
39
|
}
|
42
40
|
|
43
41
|
export interface RouteLogical {
|
@@ -0,0 +1,189 @@
|
|
1
|
+
import { Tree } from '#lib/tree/index'
|
2
|
+
import { describe, expect, test } from 'vitest'
|
3
|
+
import type { RouteTreeNode } from './scan-tree.ts'
|
4
|
+
|
5
|
+
// Helper to create a mock route tree structure for testing
|
6
|
+
const mockRouteTree = (structure: Record<string, any>): RouteTreeNode => {
|
7
|
+
const sortNodes = (nodes: RouteTreeNode[]): RouteTreeNode[] => {
|
8
|
+
return nodes.sort((a, b) => {
|
9
|
+
// If both have orders, sort by order
|
10
|
+
if (a.value.order !== undefined && b.value.order !== undefined) {
|
11
|
+
return a.value.order - b.value.order
|
12
|
+
}
|
13
|
+
// If only one has order, it comes first
|
14
|
+
if (a.value.order !== undefined) return -1
|
15
|
+
if (b.value.order !== undefined) return 1
|
16
|
+
// Otherwise sort alphabetically
|
17
|
+
return a.value.name.localeCompare(b.value.name)
|
18
|
+
})
|
19
|
+
}
|
20
|
+
|
21
|
+
const buildNode = (name: string, value: any): RouteTreeNode => {
|
22
|
+
const parsed = name.match(/^(?<order>\d+)[_-](?<name>.+)$/)
|
23
|
+
const nodeName = parsed?.groups?.[`name`] ?? name
|
24
|
+
const order = parsed?.groups?.[`order`] ? parseInt(parsed.groups[`order`], 10) : undefined
|
25
|
+
|
26
|
+
if (typeof value === 'object' && !value.isFile) {
|
27
|
+
// Directory node
|
28
|
+
const children = Object.entries(value).map(([childName, childValue]) => buildNode(childName, childValue))
|
29
|
+
return Tree.node(
|
30
|
+
{ name: nodeName, order, type: 'directory' },
|
31
|
+
sortNodes(children),
|
32
|
+
)
|
33
|
+
} else {
|
34
|
+
// File node - strip extension (but keep 'index' as is)
|
35
|
+
const nameWithoutExtension = nodeName.replace(/\.(md|mdx)$/, '')
|
36
|
+
return Tree.node({ name: nameWithoutExtension, order, type: 'file', route: value })
|
37
|
+
}
|
38
|
+
}
|
39
|
+
|
40
|
+
const children = Object.entries(structure).map(([name, value]) => buildNode(name, value))
|
41
|
+
return Tree.node(
|
42
|
+
{ name: 'root', type: 'directory' },
|
43
|
+
sortNodes(children),
|
44
|
+
)
|
45
|
+
}
|
46
|
+
|
47
|
+
describe('scan-tree structure', () => {
|
48
|
+
test('builds tree from flat file structure', () => {
|
49
|
+
const tree = mockRouteTree({
|
50
|
+
'getting-started.md': { isFile: true },
|
51
|
+
'guide': {
|
52
|
+
'introduction.md': { isFile: true },
|
53
|
+
'basics.md': { isFile: true },
|
54
|
+
},
|
55
|
+
'api': {
|
56
|
+
'reference.md': { isFile: true },
|
57
|
+
},
|
58
|
+
})
|
59
|
+
|
60
|
+
expect(tree.value.name).toBe('root')
|
61
|
+
expect(tree.children).toHaveLength(3)
|
62
|
+
|
63
|
+
const guide = tree.children.find(c => c.value.name === 'guide')
|
64
|
+
expect(guide).toBeDefined()
|
65
|
+
expect(guide!.children).toHaveLength(2)
|
66
|
+
})
|
67
|
+
|
68
|
+
test('handles numbered prefixes on files', () => {
|
69
|
+
const tree = mockRouteTree({
|
70
|
+
'10_getting-started.md': { isFile: true },
|
71
|
+
'20_configuration.md': { isFile: true },
|
72
|
+
'30_advanced.md': { isFile: true },
|
73
|
+
})
|
74
|
+
|
75
|
+
const children = tree.children
|
76
|
+
expect(children[0]!.value).toMatchObject({ name: 'getting-started', order: 10 })
|
77
|
+
expect(children[1]!.value).toMatchObject({ name: 'configuration', order: 20 })
|
78
|
+
expect(children[2]!.value).toMatchObject({ name: 'advanced', order: 30 })
|
79
|
+
})
|
80
|
+
|
81
|
+
test('handles numbered prefixes on directories', () => {
|
82
|
+
const tree = mockRouteTree({
|
83
|
+
'10_guide': {
|
84
|
+
'intro.md': { isFile: true },
|
85
|
+
},
|
86
|
+
'20_api': {
|
87
|
+
'reference.md': { isFile: true },
|
88
|
+
},
|
89
|
+
'05_quickstart': {
|
90
|
+
'index.md': { isFile: true },
|
91
|
+
},
|
92
|
+
})
|
93
|
+
|
94
|
+
const children = tree.children
|
95
|
+
expect(children[0]!.value).toMatchObject({ name: 'quickstart', order: 5 })
|
96
|
+
expect(children[1]!.value).toMatchObject({ name: 'guide', order: 10 })
|
97
|
+
expect(children[2]!.value).toMatchObject({ name: 'api', order: 20 })
|
98
|
+
})
|
99
|
+
|
100
|
+
test('handles mixed numbered and non-numbered items', () => {
|
101
|
+
const tree = mockRouteTree({
|
102
|
+
'10_guide': {
|
103
|
+
'intro.md': { isFile: true },
|
104
|
+
},
|
105
|
+
'troubleshooting': {
|
106
|
+
'common.md': { isFile: true },
|
107
|
+
},
|
108
|
+
'05_quickstart': {
|
109
|
+
'index.md': { isFile: true },
|
110
|
+
},
|
111
|
+
'api': {
|
112
|
+
'reference.md': { isFile: true },
|
113
|
+
},
|
114
|
+
})
|
115
|
+
|
116
|
+
// After sorting: numbered items first (5, 10), then alphabetical (api, troubleshooting)
|
117
|
+
const childNames = tree.children.map(c => c.value.name)
|
118
|
+
expect(childNames).toEqual(['quickstart', 'guide', 'api', 'troubleshooting'])
|
119
|
+
})
|
120
|
+
|
121
|
+
test('handles nested numbered prefixes', () => {
|
122
|
+
const tree = mockRouteTree({
|
123
|
+
'10_guide': {
|
124
|
+
'10_getting-started.md': { isFile: true },
|
125
|
+
'20_basics.md': { isFile: true },
|
126
|
+
'troubleshooting.md': { isFile: true },
|
127
|
+
'05_prerequisites.md': { isFile: true },
|
128
|
+
},
|
129
|
+
})
|
130
|
+
|
131
|
+
const guide = tree.children[0]!
|
132
|
+
expect(guide.value.name).toBe('guide')
|
133
|
+
|
134
|
+
const guideChildNames = guide.children.map(c => c.value.name)
|
135
|
+
expect(guideChildNames).toEqual(['prerequisites', 'getting-started', 'basics', 'troubleshooting'])
|
136
|
+
})
|
137
|
+
|
138
|
+
test('handles index files', () => {
|
139
|
+
const tree = mockRouteTree({
|
140
|
+
'guide': {
|
141
|
+
'index.md': { isFile: true },
|
142
|
+
'intro.md': { isFile: true },
|
143
|
+
},
|
144
|
+
})
|
145
|
+
|
146
|
+
const guide = tree.children[0]!
|
147
|
+
expect(guide.children).toHaveLength(2)
|
148
|
+
expect(guide.children.map(c => c.value.name)).toContain('index')
|
149
|
+
expect(guide.children.map(c => c.value.name)).toContain('intro')
|
150
|
+
})
|
151
|
+
|
152
|
+
test('creates directory nodes with correct type', () => {
|
153
|
+
const tree = mockRouteTree({
|
154
|
+
'10_guide': {
|
155
|
+
'intro.md': { isFile: true },
|
156
|
+
},
|
157
|
+
'api-reference.md': { isFile: true },
|
158
|
+
})
|
159
|
+
|
160
|
+
expect(tree.value.type).toBe('directory')
|
161
|
+
|
162
|
+
const guide = tree.children.find(c => c.value.name === 'guide')
|
163
|
+
expect(guide?.value.type).toBe('directory')
|
164
|
+
expect(guide?.value.order).toBe(10)
|
165
|
+
|
166
|
+
const apiRef = tree.children.find(c => c.value.name === 'api-reference')
|
167
|
+
expect(apiRef?.value.type).toBe('file')
|
168
|
+
})
|
169
|
+
|
170
|
+
test('handles file collisions with same order number - last wins', () => {
|
171
|
+
// This test simulates what would happen if the scanner processes files in order
|
172
|
+
// The mock doesn't actually test the scanner logic but documents expected behavior
|
173
|
+
const tree = mockRouteTree({
|
174
|
+
'10_about.md': { isFile: true, processedFirst: true },
|
175
|
+
'10-about.md': { isFile: true, processedLast: true }, // Same order, same logical name
|
176
|
+
})
|
177
|
+
|
178
|
+
// In the real scanner, only one 'about' node would exist
|
179
|
+
// The test structure above would result in duplicate nodes in our mock
|
180
|
+
// Document the expected behavior: last processed file should win
|
181
|
+
const aboutNodes = tree.children.filter(c => c.value.name === 'about')
|
182
|
+
|
183
|
+
// Note: This mock creates duplicates; real scanner would replace
|
184
|
+
expect(aboutNodes.length).toBeGreaterThan(0)
|
185
|
+
|
186
|
+
// Document that when orders are equal, last file processed wins
|
187
|
+
// This aligns with the linter message about "file processed later is being kept"
|
188
|
+
})
|
189
|
+
})
|
@@ -0,0 +1,205 @@
|
|
1
|
+
import { TinyGlobby } from '#dep/tiny-globby/index'
|
2
|
+
import { Tree, type TreeNode } from '#lib/tree/index'
|
3
|
+
import { Path, Str } from '@wollybeard/kit'
|
4
|
+
import type { Diagnostic } from './linter.ts'
|
5
|
+
import type { Route, RouteFile } from './route.ts'
|
6
|
+
|
7
|
+
//
|
8
|
+
// Types
|
9
|
+
//
|
10
|
+
|
11
|
+
export type RouteTreeNodeType = 'directory' | 'file'
|
12
|
+
|
13
|
+
export interface RouteTreeNodeValue {
|
14
|
+
name: string
|
15
|
+
order?: number
|
16
|
+
type: RouteTreeNodeType
|
17
|
+
route?: Route // Only present for file nodes
|
18
|
+
}
|
19
|
+
|
20
|
+
export type RouteTreeNode = TreeNode<RouteTreeNodeValue>
|
21
|
+
|
22
|
+
export interface ScanTreeResult {
|
23
|
+
routeTree: RouteTreeNode
|
24
|
+
diagnostics: Diagnostic[]
|
25
|
+
}
|
26
|
+
|
27
|
+
//
|
28
|
+
// Constants
|
29
|
+
//
|
30
|
+
|
31
|
+
const conventions = {
|
32
|
+
index: {
|
33
|
+
name: `index`,
|
34
|
+
},
|
35
|
+
numberedPrefix: {
|
36
|
+
pattern: Str.pattern<{ groups: ['order', 'name'] }>(/^(?<order>\d+)[_-](?<name>.+)$/),
|
37
|
+
},
|
38
|
+
}
|
39
|
+
|
40
|
+
//
|
41
|
+
// Helpers
|
42
|
+
//
|
43
|
+
|
44
|
+
const parseSegment = (segment: string): { name: string; order?: number } => {
|
45
|
+
const match = Str.match(segment, conventions.numberedPrefix.pattern)
|
46
|
+
if (match) {
|
47
|
+
return {
|
48
|
+
name: match.groups.name,
|
49
|
+
order: parseInt(match.groups.order, 10),
|
50
|
+
}
|
51
|
+
}
|
52
|
+
return { name: segment }
|
53
|
+
}
|
54
|
+
|
55
|
+
const buildRouteTreeFromPaths = async (paths: string[], rootDir: string): Promise<RouteTreeNode> => {
|
56
|
+
// Root node (represents the pages directory itself)
|
57
|
+
const root = Tree.node<RouteTreeNodeValue>({
|
58
|
+
name: 'root',
|
59
|
+
type: 'directory',
|
60
|
+
})
|
61
|
+
|
62
|
+
// Process each file path
|
63
|
+
for (const filePath of paths) {
|
64
|
+
const relativePath = Path.relative(rootDir, filePath)
|
65
|
+
|
66
|
+
// Split the path into segments
|
67
|
+
const segments = relativePath.split(Path.sep).filter(s => s.length > 0)
|
68
|
+
if (segments.length === 0) continue // Skip root directory
|
69
|
+
|
70
|
+
// Navigate/create path in tree
|
71
|
+
let currentNode = root
|
72
|
+
|
73
|
+
for (let i = 0; i < segments.length; i++) {
|
74
|
+
const segment = segments[i]!
|
75
|
+
const isLast = i === segments.length - 1
|
76
|
+
|
77
|
+
// Parse segment for ordering
|
78
|
+
let segmentName = segment
|
79
|
+
// Strip extension for files
|
80
|
+
if (isLast && (segment.endsWith('.md') || segment.endsWith('.mdx'))) {
|
81
|
+
segmentName = segment.replace(/\.(md|mdx)$/, '')
|
82
|
+
}
|
83
|
+
const parsed = parseSegment(segmentName)
|
84
|
+
|
85
|
+
// Find existing child
|
86
|
+
const existingChildIndex = currentNode.children.findIndex(child => child.value.name === parsed.name)
|
87
|
+
let childNode = existingChildIndex >= 0 ? currentNode.children[existingChildIndex] : undefined
|
88
|
+
|
89
|
+
if (!childNode) {
|
90
|
+
// Create new node
|
91
|
+
if (isLast) {
|
92
|
+
// This is a file
|
93
|
+
const route = filePathToRoute(filePath, rootDir)
|
94
|
+
childNode = Tree.node<RouteTreeNodeValue>({
|
95
|
+
name: parsed.name,
|
96
|
+
order: parsed.order,
|
97
|
+
type: 'file',
|
98
|
+
route,
|
99
|
+
})
|
100
|
+
} else {
|
101
|
+
// This is a directory (implicit from file path)
|
102
|
+
childNode = Tree.node<RouteTreeNodeValue>({
|
103
|
+
name: parsed.name,
|
104
|
+
order: parsed.order,
|
105
|
+
type: 'directory',
|
106
|
+
})
|
107
|
+
}
|
108
|
+
currentNode.children.push(childNode)
|
109
|
+
} else if (isLast && childNode.value.type === 'file') {
|
110
|
+
// Handle collision for files with same name
|
111
|
+
// If new file has higher or equal order, replace the existing one (last wins for ties)
|
112
|
+
if (
|
113
|
+
parsed.order !== undefined
|
114
|
+
&& (childNode.value.order === undefined || parsed.order >= childNode.value.order)
|
115
|
+
) {
|
116
|
+
const route = filePathToRoute(filePath, rootDir)
|
117
|
+
const newNode = Tree.node<RouteTreeNodeValue>({
|
118
|
+
name: parsed.name,
|
119
|
+
order: parsed.order,
|
120
|
+
type: 'file',
|
121
|
+
route,
|
122
|
+
})
|
123
|
+
currentNode.children[existingChildIndex] = newNode
|
124
|
+
childNode = newNode
|
125
|
+
}
|
126
|
+
// Otherwise keep the existing node (when existing has higher order)
|
127
|
+
}
|
128
|
+
|
129
|
+
currentNode = childNode
|
130
|
+
}
|
131
|
+
}
|
132
|
+
|
133
|
+
// Sort the tree
|
134
|
+
return sortRouteTree(root)
|
135
|
+
}
|
136
|
+
|
137
|
+
const sortRouteTree = (tree: RouteTreeNode): RouteTreeNode => {
|
138
|
+
return Tree.sort(tree, (a, b) => {
|
139
|
+
// If both have orders, sort by order
|
140
|
+
if (a.order !== undefined && b.order !== undefined) {
|
141
|
+
return a.order - b.order
|
142
|
+
}
|
143
|
+
// If only one has order, it comes first
|
144
|
+
if (a.order !== undefined) return -1
|
145
|
+
if (b.order !== undefined) return 1
|
146
|
+
// Otherwise sort alphabetically
|
147
|
+
return a.name.localeCompare(b.name)
|
148
|
+
})
|
149
|
+
}
|
150
|
+
|
151
|
+
//
|
152
|
+
// Main scan function
|
153
|
+
//
|
154
|
+
|
155
|
+
export const scanTree = async (parameters: {
|
156
|
+
dir: string
|
157
|
+
glob?: string
|
158
|
+
}): Promise<ScanTreeResult> => {
|
159
|
+
const { dir, glob = `**/*` } = parameters
|
160
|
+
|
161
|
+
// Get all files
|
162
|
+
const filePaths = await TinyGlobby.glob(glob, {
|
163
|
+
absolute: true,
|
164
|
+
cwd: dir,
|
165
|
+
onlyFiles: true,
|
166
|
+
})
|
167
|
+
|
168
|
+
// Build tree structure (directories will be created implicitly)
|
169
|
+
const routeTree = await buildRouteTreeFromPaths(filePaths, dir)
|
170
|
+
|
171
|
+
// TODO: Implement tree-based linting
|
172
|
+
const diagnostics: Diagnostic[] = []
|
173
|
+
|
174
|
+
return {
|
175
|
+
routeTree,
|
176
|
+
diagnostics,
|
177
|
+
}
|
178
|
+
}
|
179
|
+
|
180
|
+
// Reuse existing route creation logic
|
181
|
+
const filePathToRoute = (filePathExpression: string, rootDir: string): Route => {
|
182
|
+
const file: RouteFile = {
|
183
|
+
path: {
|
184
|
+
absolute: Path.parse(filePathExpression),
|
185
|
+
relative: Path.parse(Path.relative(rootDir, filePathExpression)),
|
186
|
+
},
|
187
|
+
}
|
188
|
+
|
189
|
+
const dirPath = Str.split(Str.removeSurrounding(file.path.relative.dir, Path.sep), Path.sep)
|
190
|
+
|
191
|
+
// Parse numbered prefix from filename
|
192
|
+
const prefixMatch = file.path.relative.name.match(conventions.numberedPrefix.pattern)
|
193
|
+
const order = prefixMatch?.groups?.[`order`] ? parseInt(prefixMatch.groups[`order`], 10) : undefined
|
194
|
+
const nameWithoutPrefix = prefixMatch?.groups?.[`name`] ?? file.path.relative.name
|
195
|
+
|
196
|
+
const logical = {
|
197
|
+
path: nameWithoutPrefix === conventions.index.name ? dirPath : dirPath.concat(nameWithoutPrefix),
|
198
|
+
order,
|
199
|
+
}
|
200
|
+
|
201
|
+
return {
|
202
|
+
logical,
|
203
|
+
file,
|
204
|
+
}
|
205
|
+
}
|
@@ -1,7 +1,9 @@
|
|
1
1
|
import { TinyGlobby } from '#dep/tiny-globby/index'
|
2
|
+
import { Tree } from '#lib/tree/index'
|
2
3
|
import { Path, Str } from '@wollybeard/kit'
|
3
4
|
import { type Diagnostic, lint } from './linter.ts'
|
4
|
-
import { type Route, type RouteFile, type RouteLogical } from './route.ts'
|
5
|
+
import { type Route, type RouteFile, type RouteLogical, routeToPathExpression } from './route.ts'
|
6
|
+
import { scanTree } from './scan-tree.ts'
|
5
7
|
|
6
8
|
//
|
7
9
|
//
|
@@ -45,21 +47,21 @@ export const scan = async (parameters: {
|
|
45
47
|
dir: string
|
46
48
|
glob?: string
|
47
49
|
}): Promise<ScanResult> => {
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
50
|
+
// Use tree-based scanner
|
51
|
+
const treeResult = await scanTree(parameters)
|
52
|
+
|
53
|
+
// Flatten tree to get routes
|
54
|
+
const routes: Route[] = []
|
55
|
+
Tree.visit(treeResult.routeTree, (node) => {
|
56
|
+
if (node.value.type === 'file' && node.value.route) {
|
57
|
+
routes.push(node.value.route)
|
58
|
+
}
|
55
59
|
})
|
56
60
|
|
57
|
-
// Convert to routes
|
58
|
-
const routes = filePaths.map(filePath => filePathToRoute(filePath, dir))
|
59
|
-
|
60
61
|
// Apply linting
|
61
62
|
const lintResult = lint(routes)
|
62
63
|
|
64
|
+
// Routes are already sorted by the tree structure
|
63
65
|
return lintResult
|
64
66
|
}
|
65
67
|
|
@@ -72,28 +74,14 @@ export const filePathToRoute = (filePathExpression: string, rootDir: string): Ro
|
|
72
74
|
}
|
73
75
|
const logical = filePathToRouteLogical(file.path.relative)
|
74
76
|
|
75
|
-
// Generate id and parentId for tree building
|
76
|
-
const id = filePathExpression // Use absolute path as unique ID
|
77
|
-
const relativePath = Path.relative(rootDir, filePathExpression)
|
78
|
-
const parentDir = Path.dirname(relativePath)
|
79
|
-
const parentId = parentDir === '.' ? null : Path.join(rootDir, parentDir)
|
80
|
-
|
81
77
|
return {
|
82
78
|
logical,
|
83
79
|
file,
|
84
|
-
id,
|
85
|
-
parentId,
|
86
80
|
}
|
87
81
|
}
|
88
82
|
|
89
83
|
export const filePathToRouteLogical = (filePath: Path.Parsed): RouteLogical => {
|
90
|
-
const
|
91
|
-
|
92
|
-
// Parse numbered prefixes from directory segments
|
93
|
-
const dirPath = dirSegments.map(segment => {
|
94
|
-
const prefixMatch = Str.match(segment, conventions.numberedPrefix.pattern)
|
95
|
-
return prefixMatch?.groups.name ?? segment
|
96
|
-
})
|
84
|
+
const dirPath = Str.split(Str.removeSurrounding(filePath.dir, Path.sep), Path.sep)
|
97
85
|
|
98
86
|
// Parse numbered prefix from filename
|
99
87
|
const prefixMatch = Str.match(filePath.name, conventions.numberedPrefix.pattern)
|
@@ -0,0 +1,123 @@
|
|
1
|
+
import { Tree } from '#lib/tree/index'
|
2
|
+
import { describe, expect, test } from 'vitest'
|
3
|
+
import type { RouteTreeNode, RouteTreeNodeValue } from '../scan-tree.ts'
|
4
|
+
import { buildFromTree } from './sidebar-tree.ts'
|
5
|
+
|
6
|
+
// Helper to create mock routes
|
7
|
+
const mockRoute = (path: string[]) => ({
|
8
|
+
logical: { path },
|
9
|
+
file: {
|
10
|
+
path: {
|
11
|
+
absolute: { root: '/', dir: '/', base: 'file.md', ext: '.md', name: 'file' },
|
12
|
+
relative: { root: '', dir: '', base: 'file.md', ext: '.md', name: 'file' },
|
13
|
+
},
|
14
|
+
},
|
15
|
+
})
|
16
|
+
|
17
|
+
// Helper to create file node
|
18
|
+
const fileNode = (name: string, route: any): RouteTreeNode =>
|
19
|
+
Tree.node<RouteTreeNodeValue>({ name, type: 'file', route })
|
20
|
+
|
21
|
+
// Helper to create directory node
|
22
|
+
const dirNode = (name: string, children: RouteTreeNode[] = []): RouteTreeNode =>
|
23
|
+
Tree.node<RouteTreeNodeValue>({ name, type: 'directory' }, children)
|
24
|
+
|
25
|
+
describe('sidebar-tree', () => {
|
26
|
+
test('builds sidebar from simple tree', () => {
|
27
|
+
const tree = dirNode('root', [
|
28
|
+
fileNode('getting-started', mockRoute(['getting-started'])),
|
29
|
+
dirNode('guide', [
|
30
|
+
fileNode('introduction', mockRoute(['guide', 'introduction'])),
|
31
|
+
fileNode('basics', mockRoute(['guide', 'basics'])),
|
32
|
+
]),
|
33
|
+
])
|
34
|
+
|
35
|
+
const sidebar = buildFromTree(tree, [])
|
36
|
+
|
37
|
+
expect(sidebar.items).toHaveLength(2)
|
38
|
+
expect(sidebar.items[0]).toMatchObject({
|
39
|
+
type: 'ItemLink',
|
40
|
+
pathExp: 'getting-started',
|
41
|
+
title: 'Getting Started',
|
42
|
+
})
|
43
|
+
const section = sidebar.items[1]
|
44
|
+
expect(section).toBeDefined()
|
45
|
+
expect(section!.type).toBe('ItemSection')
|
46
|
+
if (section!.type === 'ItemSection') {
|
47
|
+
expect(section).toMatchObject({
|
48
|
+
type: 'ItemSection',
|
49
|
+
title: 'Guide',
|
50
|
+
pathExp: 'guide',
|
51
|
+
isLinkToo: false,
|
52
|
+
})
|
53
|
+
expect(section!.links).toHaveLength(2)
|
54
|
+
}
|
55
|
+
})
|
56
|
+
|
57
|
+
test('handles index files correctly', () => {
|
58
|
+
const tree = dirNode('root', [
|
59
|
+
dirNode('guide', [
|
60
|
+
fileNode('index', mockRoute(['guide'])),
|
61
|
+
fileNode('introduction', mockRoute(['guide', 'introduction'])),
|
62
|
+
]),
|
63
|
+
])
|
64
|
+
|
65
|
+
const sidebar = buildFromTree(tree, [])
|
66
|
+
|
67
|
+
expect(sidebar.items).toHaveLength(1)
|
68
|
+
const section = sidebar.items[0]
|
69
|
+
expect(section).toBeDefined()
|
70
|
+
expect(section!.type).toBe('ItemSection')
|
71
|
+
if (section!.type === 'ItemSection') {
|
72
|
+
expect(section).toMatchObject({
|
73
|
+
type: 'ItemSection',
|
74
|
+
title: 'Guide',
|
75
|
+
pathExp: 'guide',
|
76
|
+
isLinkToo: true, // Should be true because of index file
|
77
|
+
})
|
78
|
+
expect(section!.links).toHaveLength(1) // Only introduction, not index
|
79
|
+
}
|
80
|
+
})
|
81
|
+
|
82
|
+
test('respects node ordering from tree', () => {
|
83
|
+
const tree = dirNode('root', [
|
84
|
+
Tree.node<RouteTreeNodeValue>({ name: 'quickstart', order: 5, type: 'file', route: mockRoute(['quickstart']) }),
|
85
|
+
Tree.node<RouteTreeNodeValue>({ name: 'guide', order: 10, type: 'file', route: mockRoute(['guide']) }),
|
86
|
+
fileNode('api', mockRoute(['api'])),
|
87
|
+
fileNode('troubleshooting', mockRoute(['troubleshooting'])),
|
88
|
+
])
|
89
|
+
|
90
|
+
const sidebar = buildFromTree(tree, [])
|
91
|
+
|
92
|
+
// Tree should already be sorted, so sidebar should maintain that order
|
93
|
+
const titles = sidebar.items.map(item => item.title)
|
94
|
+
expect(titles).toEqual(['Quickstart', 'Guide', 'Api', 'Troubleshooting'])
|
95
|
+
})
|
96
|
+
|
97
|
+
test('handles nested directories', () => {
|
98
|
+
const tree = dirNode('root', [
|
99
|
+
dirNode('guide', [
|
100
|
+
fileNode('intro', mockRoute(['guide', 'intro'])),
|
101
|
+
dirNode('advanced', [
|
102
|
+
fileNode('performance', mockRoute(['guide', 'advanced', 'performance'])),
|
103
|
+
fileNode('optimization', mockRoute(['guide', 'advanced', 'optimization'])),
|
104
|
+
]),
|
105
|
+
]),
|
106
|
+
])
|
107
|
+
|
108
|
+
const sidebar = buildFromTree(tree, [])
|
109
|
+
|
110
|
+
expect(sidebar.items).toHaveLength(1)
|
111
|
+
const guideSection = sidebar.items[0]
|
112
|
+
expect(guideSection).toBeDefined()
|
113
|
+
expect(guideSection!.type).toBe('ItemSection')
|
114
|
+
if (guideSection!.type === 'ItemSection') {
|
115
|
+
expect(guideSection!.links).toHaveLength(3) // intro + 2 from advanced subdirectory
|
116
|
+
|
117
|
+
const navTitles = guideSection!.links.map(nav => nav.title)
|
118
|
+
expect(navTitles).toContain('Intro')
|
119
|
+
expect(navTitles).toContain('Performance')
|
120
|
+
expect(navTitles).toContain('Optimization')
|
121
|
+
}
|
122
|
+
})
|
123
|
+
})
|