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
@@ -1,283 +0,0 @@
|
|
1
|
-
import { FileRouter } from '#lib/file-router/index'
|
2
|
-
import { Str } from '@wollybeard/kit'
|
3
|
-
import type { Page } from './page.ts'
|
4
|
-
import type { ScanResult } from './scan.ts'
|
5
|
-
|
6
|
-
/**
|
7
|
-
* Represents a complete sidebar structure with navigation items.
|
8
|
-
* This is the main data structure used to render sidebars in the UI.
|
9
|
-
*/
|
10
|
-
export interface Sidebar {
|
11
|
-
/** Array of navigation items that can be either direct links or sections containing multiple links */
|
12
|
-
items: Item[]
|
13
|
-
}
|
14
|
-
|
15
|
-
/**
|
16
|
-
* A sidebar navigation item that can be either a direct link or a section containing multiple links.
|
17
|
-
* @see {@link ItemLink} for direct navigation links
|
18
|
-
* @see {@link ItemSection} for grouped navigation sections
|
19
|
-
*/
|
20
|
-
export type Item = ItemLink | ItemSection
|
21
|
-
|
22
|
-
/**
|
23
|
-
* A direct navigation link in the sidebar.
|
24
|
-
* Used for pages that don't have child pages.
|
25
|
-
*
|
26
|
-
* @example
|
27
|
-
* ```ts
|
28
|
-
* const link: ItemLink = {
|
29
|
-
* type: 'ItemLink',
|
30
|
-
* title: 'Getting Started',
|
31
|
-
* pathExp: 'guide/getting-started'
|
32
|
-
* }
|
33
|
-
* ```
|
34
|
-
*/
|
35
|
-
export interface ItemLink {
|
36
|
-
/** Discriminator for TypeScript union types */
|
37
|
-
type: `ItemLink`
|
38
|
-
/** Display title for the link (e.g., "Getting Started") */
|
39
|
-
title: string
|
40
|
-
/** Path expression relative to the base path, without leading slash (e.g., "guide/getting-started") */
|
41
|
-
pathExp: string
|
42
|
-
}
|
43
|
-
|
44
|
-
/**
|
45
|
-
* A collapsible section in the sidebar that groups related links.
|
46
|
-
* Used for directories that contain multiple pages.
|
47
|
-
*
|
48
|
-
* @example
|
49
|
-
* ```ts
|
50
|
-
* const section: ItemSection = {
|
51
|
-
* type: 'ItemSection',
|
52
|
-
* title: 'Guide',
|
53
|
-
* pathExp: 'guide',
|
54
|
-
* isLinkToo: true, // Has an index page
|
55
|
-
* links: [
|
56
|
-
* { type: 'ItemLink', title: 'Installation', pathExp: 'guide/installation' },
|
57
|
-
* { type: 'ItemLink', title: 'Configuration', pathExp: 'guide/configuration' }
|
58
|
-
* ]
|
59
|
-
* }
|
60
|
-
* ```
|
61
|
-
*/
|
62
|
-
export interface ItemSection {
|
63
|
-
/** Discriminator for TypeScript union types */
|
64
|
-
type: `ItemSection`
|
65
|
-
/** Display title for the section (e.g., "Guide", "API Reference") */
|
66
|
-
title: string
|
67
|
-
/** Path expression for the section's index page, if it exists (e.g., "guide") */
|
68
|
-
pathExp: string
|
69
|
-
/** Whether this section also acts as a link (true if the directory has an index page) */
|
70
|
-
isLinkToo: boolean
|
71
|
-
/** Child navigation links within this section */
|
72
|
-
links: ItemLink[]
|
73
|
-
}
|
74
|
-
|
75
|
-
/**
|
76
|
-
* A mapping of route paths to their corresponding sidebar structures.
|
77
|
-
* Used to store different sidebars for different sections of a site.
|
78
|
-
*
|
79
|
-
* @example
|
80
|
-
* ```ts
|
81
|
-
* const sidebarIndex: SidebarIndex = {
|
82
|
-
* '/guide': { items: [...] }, // Sidebar for /guide section
|
83
|
-
* '/api': { items: [...] }, // Sidebar for /api section
|
84
|
-
* '/reference': { items: [...] } // Sidebar for /reference section
|
85
|
-
* }
|
86
|
-
* ```
|
87
|
-
*/
|
88
|
-
export type SidebarIndex = Record<string, Sidebar>
|
89
|
-
|
90
|
-
/**
|
91
|
-
* Builds sidebars for all top-level directories that contain both an index page and nested content.
|
92
|
-
*
|
93
|
-
* This function analyzes a scan result to identify which directories should have sidebars.
|
94
|
-
* A directory gets a sidebar if it meets these criteria:
|
95
|
-
* 1. It's a top-level directory (e.g., /guide, /api, /docs)
|
96
|
-
* 2. It has an index page (e.g., /guide/index.md)
|
97
|
-
* 3. It has nested pages (e.g., /guide/getting-started.md, /guide/configuration.md)
|
98
|
-
*
|
99
|
-
* @param scanResult - The result of scanning pages, containing both a flat list and tree structure
|
100
|
-
* @returns A mapping of route paths to sidebar structures
|
101
|
-
*
|
102
|
-
* @example
|
103
|
-
* ```ts
|
104
|
-
* const scanResult = await Content.scan({ dir: './pages' })
|
105
|
-
* const sidebars = buildSidebarIndex(scanResult)
|
106
|
-
* // Returns: {
|
107
|
-
* // '/guide': { items: [...] },
|
108
|
-
* // '/api': { items: [...] }
|
109
|
-
* // }
|
110
|
-
* ```
|
111
|
-
*/
|
112
|
-
export const buildSidebarIndex = (scanResult: ScanResult): SidebarIndex => {
|
113
|
-
const sidebarIndex: SidebarIndex = {}
|
114
|
-
|
115
|
-
// Group pages by their top-level directory
|
116
|
-
const pagesByTopLevelDir = new Map<string, Page[]>()
|
117
|
-
|
118
|
-
for (const page of scanResult.list) {
|
119
|
-
const topLevelDir = page.route.logical.path[0]
|
120
|
-
|
121
|
-
// Skip pages that are not in a directory or are hidden
|
122
|
-
if (!topLevelDir || page.metadata.hidden) continue
|
123
|
-
|
124
|
-
if (!pagesByTopLevelDir.has(topLevelDir)) {
|
125
|
-
pagesByTopLevelDir.set(topLevelDir, [])
|
126
|
-
}
|
127
|
-
pagesByTopLevelDir.get(topLevelDir)!.push(page)
|
128
|
-
}
|
129
|
-
|
130
|
-
// Build sidebar for each directory that has an index page
|
131
|
-
for (const [topLevelDir, pages] of pagesByTopLevelDir) {
|
132
|
-
const hasIndexPage = pages.some(page =>
|
133
|
-
page.route.logical.path.length === 1
|
134
|
-
&& FileRouter.routeIsFromIndexFile(page.route)
|
135
|
-
)
|
136
|
-
|
137
|
-
// Skip directories without index pages
|
138
|
-
if (!hasIndexPage) continue
|
139
|
-
|
140
|
-
const pathExp = `/${topLevelDir}`
|
141
|
-
const sidebar = buildSidebarForDirectory(topLevelDir, pages)
|
142
|
-
|
143
|
-
if (sidebar.items.length > 0) {
|
144
|
-
sidebarIndex[pathExp] = sidebar
|
145
|
-
}
|
146
|
-
}
|
147
|
-
|
148
|
-
return sidebarIndex
|
149
|
-
}
|
150
|
-
|
151
|
-
/**
|
152
|
-
* Builds a sidebar for a specific directory from its pages
|
153
|
-
*/
|
154
|
-
const buildSidebarForDirectory = (topLevelDir: string, pages: Page[]): Sidebar => {
|
155
|
-
const items: Item[] = []
|
156
|
-
|
157
|
-
// Group pages by their immediate parent path
|
158
|
-
const pagesByParent = new Map<string, Page[]>()
|
159
|
-
|
160
|
-
for (const page of pages) {
|
161
|
-
// Skip the index page at the top level directory
|
162
|
-
if (page.route.logical.path.length === 1 && FileRouter.routeIsFromIndexFile(page.route)) {
|
163
|
-
continue
|
164
|
-
}
|
165
|
-
|
166
|
-
// Get the immediate parent path (e.g., for ['guide', 'advanced', 'tips'], parent is ['guide', 'advanced'])
|
167
|
-
const parentPath = page.route.logical.path.slice(0, -1).join('/')
|
168
|
-
|
169
|
-
if (!pagesByParent.has(parentPath)) {
|
170
|
-
pagesByParent.set(parentPath, [])
|
171
|
-
}
|
172
|
-
pagesByParent.get(parentPath)!.push(page)
|
173
|
-
}
|
174
|
-
|
175
|
-
// Process top-level pages (direct children of the directory)
|
176
|
-
const topLevelPages = pagesByParent.get(topLevelDir) || []
|
177
|
-
|
178
|
-
// Sort pages by their directory order (extracted from file path)
|
179
|
-
const sortedTopLevelPages = [...topLevelPages].sort((a, b) => {
|
180
|
-
// For sections, we need to look at the directory name in the file path
|
181
|
-
const dirA = a.route.file.path.relative.dir.split('/').pop() || ''
|
182
|
-
const dirB = b.route.file.path.relative.dir.split('/').pop() || ''
|
183
|
-
|
184
|
-
// Extract order from directory names like "10_b", "20_c"
|
185
|
-
const orderMatchA = dirA.match(/^(\d+)[_-]/)
|
186
|
-
const orderMatchB = dirB.match(/^(\d+)[_-]/)
|
187
|
-
|
188
|
-
const orderA = orderMatchA ? parseInt(orderMatchA[1]!, 10) : Number.MAX_SAFE_INTEGER
|
189
|
-
const orderB = orderMatchB ? parseInt(orderMatchB[1]!, 10) : Number.MAX_SAFE_INTEGER
|
190
|
-
|
191
|
-
if (orderA !== orderB) return orderA - orderB
|
192
|
-
|
193
|
-
// Fall back to alphabetical order
|
194
|
-
return dirA.localeCompare(dirB)
|
195
|
-
})
|
196
|
-
|
197
|
-
for (const page of sortedTopLevelPages) {
|
198
|
-
const pageName = page.route.logical.path[page.route.logical.path.length - 1]!
|
199
|
-
const childPath = page.route.logical.path.join('/')
|
200
|
-
const childPages = pagesByParent.get(childPath) || []
|
201
|
-
|
202
|
-
if (childPages.length > 0 || FileRouter.routeIsFromIndexFile(page.route)) {
|
203
|
-
// This is a section (has children or is an index page for a subdirectory)
|
204
|
-
const hasIndex = FileRouter.routeIsFromIndexFile(page.route)
|
205
|
-
|
206
|
-
const section: ItemSection = {
|
207
|
-
type: 'ItemSection',
|
208
|
-
title: Str.titlizeSlug(pageName),
|
209
|
-
pathExp: childPath,
|
210
|
-
isLinkToo: hasIndex,
|
211
|
-
links: [],
|
212
|
-
}
|
213
|
-
|
214
|
-
// Add direct children as links (sorted by order)
|
215
|
-
const sortedChildPages = [...childPages].sort((a, b) => {
|
216
|
-
const orderA = a.route.logical.order ?? Number.MAX_SAFE_INTEGER
|
217
|
-
const orderB = b.route.logical.order ?? Number.MAX_SAFE_INTEGER
|
218
|
-
return orderA - orderB
|
219
|
-
})
|
220
|
-
|
221
|
-
for (const childPage of sortedChildPages) {
|
222
|
-
if (!FileRouter.routeIsFromIndexFile(childPage.route)) {
|
223
|
-
section.links.push({
|
224
|
-
type: 'ItemLink',
|
225
|
-
title: Str.titlizeSlug(childPage.route.logical.path[childPage.route.logical.path.length - 1]!),
|
226
|
-
pathExp: childPage.route.logical.path.join('/'),
|
227
|
-
})
|
228
|
-
}
|
229
|
-
}
|
230
|
-
|
231
|
-
// Also add any deeper descendants as flat links
|
232
|
-
const allDescendants: Page[] = []
|
233
|
-
for (const [parentPath, pagesInParent] of pagesByParent) {
|
234
|
-
// Check if this path is a descendant (but not direct child)
|
235
|
-
if (parentPath.startsWith(childPath + '/')) {
|
236
|
-
for (const descendantPage of pagesInParent) {
|
237
|
-
if (!FileRouter.routeIsFromIndexFile(descendantPage.route)) {
|
238
|
-
allDescendants.push(descendantPage)
|
239
|
-
}
|
240
|
-
}
|
241
|
-
}
|
242
|
-
}
|
243
|
-
|
244
|
-
// Sort all descendants by their full path order
|
245
|
-
allDescendants.sort((a, b) => {
|
246
|
-
// Compare paths segment by segment, considering order at each level
|
247
|
-
const pathA = a.route.logical.path
|
248
|
-
const pathB = b.route.logical.path
|
249
|
-
const minLength = Math.min(pathA.length, pathB.length)
|
250
|
-
|
251
|
-
for (let i = 0; i < minLength; i++) {
|
252
|
-
const segmentCompare = pathA[i]!.localeCompare(pathB[i]!)
|
253
|
-
if (segmentCompare !== 0) return segmentCompare
|
254
|
-
}
|
255
|
-
|
256
|
-
return pathA.length - pathB.length
|
257
|
-
})
|
258
|
-
|
259
|
-
for (const descendantPage of allDescendants) {
|
260
|
-
section.links.push({
|
261
|
-
type: 'ItemLink',
|
262
|
-
title: Str.titlizeSlug(
|
263
|
-
descendantPage.route.logical.path[descendantPage.route.logical.path.length - 1]!,
|
264
|
-
),
|
265
|
-
pathExp: descendantPage.route.logical.path.join('/'),
|
266
|
-
})
|
267
|
-
}
|
268
|
-
|
269
|
-
if (section.links.length > 0 || section.isLinkToo) {
|
270
|
-
items.push(section)
|
271
|
-
}
|
272
|
-
} else {
|
273
|
-
// This is a simple link
|
274
|
-
items.push({
|
275
|
-
type: 'ItemLink',
|
276
|
-
title: Str.titlizeSlug(pageName),
|
277
|
-
pathExp: page.route.logical.path.join('/'),
|
278
|
-
})
|
279
|
-
}
|
280
|
-
}
|
281
|
-
|
282
|
-
return { items }
|
283
|
-
}
|
package/src/api/content/utils.ts
DELETED
package/src/api/static/index.ts
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
export * as Static from './static.ts'
|
@@ -1,106 +0,0 @@
|
|
1
|
-
import { Err, Fs, Path } from '@wollybeard/kit'
|
2
|
-
import { afterEach, beforeEach, describe, expect, test } from 'vitest'
|
3
|
-
import { buildManifest, type PolenBuildManifest } from './manifest.ts'
|
4
|
-
|
5
|
-
describe('validate-build', () => {
|
6
|
-
let testDir: string
|
7
|
-
let manifestPath: string
|
8
|
-
|
9
|
-
beforeEach(async () => {
|
10
|
-
testDir = await Fs.makeTemporaryDirectory()
|
11
|
-
manifestPath = Path.join(testDir, '.polen', 'build.json')
|
12
|
-
})
|
13
|
-
|
14
|
-
afterEach(async () => {
|
15
|
-
if (testDir && await Fs.exists(testDir)) {
|
16
|
-
await Fs.remove(testDir)
|
17
|
-
}
|
18
|
-
})
|
19
|
-
|
20
|
-
describe('readBuildManifest', () => {
|
21
|
-
test('reads valid manifest', async () => {
|
22
|
-
const manifest: PolenBuildManifest = {
|
23
|
-
type: 'ssr',
|
24
|
-
version: '2.1.0',
|
25
|
-
basePath: '/docs/',
|
26
|
-
}
|
27
|
-
await Fs.write({
|
28
|
-
path: manifestPath,
|
29
|
-
content: JSON.stringify(manifest, null, 2),
|
30
|
-
})
|
31
|
-
|
32
|
-
const result = await buildManifest.read(testDir)
|
33
|
-
expect(Err.is(result)).toBe(false)
|
34
|
-
expect(result).toEqual(manifest)
|
35
|
-
})
|
36
|
-
|
37
|
-
test('returns error when manifest does not exist', async () => {
|
38
|
-
// Verify the file doesn't exist
|
39
|
-
const manifestExists = await Fs.exists(manifestPath)
|
40
|
-
expect(manifestExists).toBe(false)
|
41
|
-
|
42
|
-
const result = await buildManifest.read(testDir)
|
43
|
-
expect(Err.is(result)).toBe(true)
|
44
|
-
})
|
45
|
-
|
46
|
-
test('returns error for invalid manifest structure', async () => {
|
47
|
-
await Fs.write({
|
48
|
-
path: manifestPath,
|
49
|
-
content: JSON.stringify({ invalid: 'data' }, null, 2),
|
50
|
-
})
|
51
|
-
const result = await buildManifest.read(testDir)
|
52
|
-
expect(Err.is(result)).toBe(true)
|
53
|
-
})
|
54
|
-
|
55
|
-
test('returns error for invalid build type', async () => {
|
56
|
-
await Fs.write({
|
57
|
-
path: manifestPath,
|
58
|
-
content: JSON.stringify(
|
59
|
-
{
|
60
|
-
type: 'invalid',
|
61
|
-
version: '1.0.0',
|
62
|
-
basePath: '/',
|
63
|
-
},
|
64
|
-
null,
|
65
|
-
2,
|
66
|
-
),
|
67
|
-
})
|
68
|
-
const result = await buildManifest.read(testDir)
|
69
|
-
expect(Err.is(result)).toBe(true)
|
70
|
-
})
|
71
|
-
|
72
|
-
test('returns error when version is not a string', async () => {
|
73
|
-
await Fs.write({
|
74
|
-
path: manifestPath,
|
75
|
-
content: JSON.stringify(
|
76
|
-
{
|
77
|
-
type: 'ssg',
|
78
|
-
version: 123,
|
79
|
-
basePath: '/',
|
80
|
-
},
|
81
|
-
null,
|
82
|
-
2,
|
83
|
-
),
|
84
|
-
})
|
85
|
-
const result = await buildManifest.read(testDir)
|
86
|
-
expect(Err.is(result)).toBe(true)
|
87
|
-
})
|
88
|
-
|
89
|
-
test('returns error when basePath is not a string', async () => {
|
90
|
-
await Fs.write({
|
91
|
-
path: manifestPath,
|
92
|
-
content: JSON.stringify(
|
93
|
-
{
|
94
|
-
type: 'ssg',
|
95
|
-
version: '1.0.0',
|
96
|
-
basePath: null,
|
97
|
-
},
|
98
|
-
null,
|
99
|
-
2,
|
100
|
-
),
|
101
|
-
})
|
102
|
-
const result = await buildManifest.read(testDir)
|
103
|
-
expect(Err.is(result)).toBe(true)
|
104
|
-
})
|
105
|
-
})
|
106
|
-
})
|
@@ -1,16 +0,0 @@
|
|
1
|
-
import { Codec, Resource } from '@wollybeard/kit'
|
2
|
-
import { z } from 'zod/v4'
|
3
|
-
|
4
|
-
export const PolenBuildManifestSchema = z.object({
|
5
|
-
type: z.enum(['ssg', 'ssr']),
|
6
|
-
version: z.string(),
|
7
|
-
basePath: z.string(),
|
8
|
-
}).loose()
|
9
|
-
|
10
|
-
export type PolenBuildManifest = z.infer<typeof PolenBuildManifestSchema>
|
11
|
-
|
12
|
-
export const buildManifest = Resource.create({
|
13
|
-
name: 'polen-build-manifest',
|
14
|
-
path: '.polen/build.json',
|
15
|
-
codec: Codec.fromZod(PolenBuildManifestSchema),
|
16
|
-
})
|
@@ -1,229 +0,0 @@
|
|
1
|
-
import { Fs, Path } from '@wollybeard/kit'
|
2
|
-
import { afterEach, beforeEach, describe, expect, test } from 'vitest'
|
3
|
-
import { rebase, type RebasePlan } from './rebase.ts'
|
4
|
-
|
5
|
-
const testDir = 'temp/rebase-test'
|
6
|
-
|
7
|
-
const createTestBuild = async (dir: string, basePath: string = '/') => {
|
8
|
-
await Fs.makeDirectory(dir)
|
9
|
-
|
10
|
-
// Create Polen build manifest
|
11
|
-
const polenDir = Path.join(dir, '.polen')
|
12
|
-
await Fs.makeDirectory(polenDir)
|
13
|
-
|
14
|
-
const manifest = {
|
15
|
-
type: 'ssg' as const,
|
16
|
-
version: '1.0.0',
|
17
|
-
basePath,
|
18
|
-
}
|
19
|
-
|
20
|
-
await Fs.write({
|
21
|
-
path: Path.join(polenDir, 'build.json'),
|
22
|
-
content: JSON.stringify(manifest, null, 2),
|
23
|
-
})
|
24
|
-
|
25
|
-
// Create some HTML files
|
26
|
-
await Fs.write({
|
27
|
-
path: Path.join(dir, 'index.html'),
|
28
|
-
content: `<!DOCTYPE html>
|
29
|
-
<html>
|
30
|
-
<head>
|
31
|
-
<base href="${basePath}">
|
32
|
-
<title>Test</title>
|
33
|
-
</head>
|
34
|
-
<body>
|
35
|
-
<h1>Test Page</h1>
|
36
|
-
</body>
|
37
|
-
</html>`,
|
38
|
-
})
|
39
|
-
|
40
|
-
// Create nested HTML file
|
41
|
-
const nestedDir = Path.join(dir, 'docs')
|
42
|
-
await Fs.makeDirectory(nestedDir)
|
43
|
-
|
44
|
-
await Fs.write({
|
45
|
-
path: Path.join(nestedDir, 'page.html'),
|
46
|
-
content: `<!DOCTYPE html>
|
47
|
-
<html>
|
48
|
-
<head>
|
49
|
-
<title>Nested</title>
|
50
|
-
</head>
|
51
|
-
<body>
|
52
|
-
<h1>Nested Page</h1>
|
53
|
-
</body>
|
54
|
-
</html>`,
|
55
|
-
})
|
56
|
-
}
|
57
|
-
|
58
|
-
describe('rebase', () => {
|
59
|
-
beforeEach(async () => {
|
60
|
-
await Fs.remove(testDir)
|
61
|
-
})
|
62
|
-
|
63
|
-
afterEach(async () => {
|
64
|
-
await Fs.remove(testDir)
|
65
|
-
})
|
66
|
-
|
67
|
-
test('mutate mode updates base paths in place', async () => {
|
68
|
-
const buildDir = Path.join(testDir, 'build')
|
69
|
-
await createTestBuild(buildDir, '/old/')
|
70
|
-
|
71
|
-
const plan: RebasePlan = {
|
72
|
-
sourcePath: buildDir,
|
73
|
-
newBasePath: '/new/',
|
74
|
-
changeMode: 'mutate',
|
75
|
-
}
|
76
|
-
|
77
|
-
await rebase(plan)
|
78
|
-
|
79
|
-
// Check updated manifest
|
80
|
-
const manifest = await Fs.readJson(Path.join(buildDir, '.polen', 'build.json'))
|
81
|
-
expect(manifest).toMatchObject({
|
82
|
-
type: 'ssg',
|
83
|
-
version: '1.0.0',
|
84
|
-
basePath: '/new/',
|
85
|
-
})
|
86
|
-
|
87
|
-
// Check updated HTML file
|
88
|
-
const indexContent = await Fs.read(Path.join(buildDir, 'index.html'))
|
89
|
-
expect(indexContent).toContain('<base href="/new/">')
|
90
|
-
|
91
|
-
// Check nested HTML file (should have base tag inserted)
|
92
|
-
const nestedContent = await Fs.read(Path.join(buildDir, 'docs', 'page.html'))
|
93
|
-
expect(nestedContent).toContain('<base href="/new/">')
|
94
|
-
})
|
95
|
-
|
96
|
-
test('copy mode creates new build with updated base paths', async () => {
|
97
|
-
const buildDir = Path.join(testDir, 'build')
|
98
|
-
const copyDir = Path.join(testDir, 'copy')
|
99
|
-
|
100
|
-
await createTestBuild(buildDir, '/old/')
|
101
|
-
|
102
|
-
const plan: RebasePlan = {
|
103
|
-
sourcePath: buildDir,
|
104
|
-
targetPath: copyDir,
|
105
|
-
newBasePath: '/new/',
|
106
|
-
changeMode: 'copy',
|
107
|
-
}
|
108
|
-
|
109
|
-
await rebase(plan)
|
110
|
-
|
111
|
-
// Original should be unchanged
|
112
|
-
const originalManifest = await Fs.readJson(Path.join(buildDir, '.polen', 'build.json'))
|
113
|
-
expect(originalManifest).toMatchObject({
|
114
|
-
basePath: '/old/',
|
115
|
-
})
|
116
|
-
|
117
|
-
// Copy should be updated
|
118
|
-
const copyManifest = await Fs.readJson(Path.join(copyDir, '.polen', 'build.json'))
|
119
|
-
expect(copyManifest).toMatchObject({
|
120
|
-
basePath: '/new/',
|
121
|
-
})
|
122
|
-
|
123
|
-
const copyIndexContent = await Fs.read(Path.join(copyDir, 'index.html'))
|
124
|
-
expect(copyIndexContent).toContain('<base href="/new/">')
|
125
|
-
})
|
126
|
-
|
127
|
-
test('throws error for invalid base path', async () => {
|
128
|
-
const buildDir = Path.join(testDir, 'build')
|
129
|
-
await createTestBuild(buildDir)
|
130
|
-
|
131
|
-
const plan: RebasePlan = {
|
132
|
-
sourcePath: buildDir,
|
133
|
-
newBasePath: 'invalid-path',
|
134
|
-
changeMode: 'mutate',
|
135
|
-
}
|
136
|
-
|
137
|
-
await expect(rebase(plan)).rejects.toThrow('Invalid base path: invalid-path')
|
138
|
-
})
|
139
|
-
|
140
|
-
test('throws error when source is not a Polen build', async () => {
|
141
|
-
const buildDir = Path.join(testDir, 'not-polen')
|
142
|
-
await Fs.makeDirectory(buildDir)
|
143
|
-
|
144
|
-
const plan: RebasePlan = {
|
145
|
-
sourcePath: buildDir,
|
146
|
-
newBasePath: '/new/',
|
147
|
-
changeMode: 'mutate',
|
148
|
-
}
|
149
|
-
|
150
|
-
await expect(rebase(plan)).rejects.toThrow('Polen build manifest not found')
|
151
|
-
})
|
152
|
-
|
153
|
-
test('throws error when copy target exists and is not empty', async () => {
|
154
|
-
const buildDir = Path.join(testDir, 'build')
|
155
|
-
const copyDir = Path.join(testDir, 'copy')
|
156
|
-
|
157
|
-
await createTestBuild(buildDir)
|
158
|
-
|
159
|
-
// Create non-empty target
|
160
|
-
await Fs.makeDirectory(copyDir)
|
161
|
-
await Fs.write({
|
162
|
-
path: Path.join(copyDir, 'existing.txt'),
|
163
|
-
content: 'existing file',
|
164
|
-
})
|
165
|
-
|
166
|
-
const plan: RebasePlan = {
|
167
|
-
sourcePath: buildDir,
|
168
|
-
targetPath: copyDir,
|
169
|
-
newBasePath: '/new/',
|
170
|
-
changeMode: 'copy',
|
171
|
-
}
|
172
|
-
|
173
|
-
await expect(rebase(plan)).rejects.toThrow('Target path already exists and is not empty')
|
174
|
-
})
|
175
|
-
|
176
|
-
test('handles HTML file without existing base tag', async () => {
|
177
|
-
const buildDir = Path.join(testDir, 'build')
|
178
|
-
await createTestBuild(buildDir)
|
179
|
-
|
180
|
-
// Create HTML without base tag
|
181
|
-
await Fs.write({
|
182
|
-
path: Path.join(buildDir, 'no-base.html'),
|
183
|
-
content: `<!DOCTYPE html>
|
184
|
-
<html>
|
185
|
-
<head>
|
186
|
-
<title>No Base</title>
|
187
|
-
</head>
|
188
|
-
<body>
|
189
|
-
<h1>No Base Tag</h1>
|
190
|
-
</body>
|
191
|
-
</html>`,
|
192
|
-
})
|
193
|
-
|
194
|
-
const plan: RebasePlan = {
|
195
|
-
sourcePath: buildDir,
|
196
|
-
newBasePath: '/new/',
|
197
|
-
changeMode: 'mutate',
|
198
|
-
}
|
199
|
-
|
200
|
-
await rebase(plan)
|
201
|
-
|
202
|
-
const content = await Fs.read(Path.join(buildDir, 'no-base.html'))
|
203
|
-
expect(content).toContain('<base href="/new/">')
|
204
|
-
})
|
205
|
-
|
206
|
-
test('throws error for HTML file without head tag', async () => {
|
207
|
-
const buildDir = Path.join(testDir, 'build')
|
208
|
-
await createTestBuild(buildDir)
|
209
|
-
|
210
|
-
// Create invalid HTML without head
|
211
|
-
await Fs.write({
|
212
|
-
path: Path.join(buildDir, 'invalid.html'),
|
213
|
-
content: `<!DOCTYPE html>
|
214
|
-
<html>
|
215
|
-
<body>
|
216
|
-
<h1>Invalid HTML</h1>
|
217
|
-
</body>
|
218
|
-
</html>`,
|
219
|
-
})
|
220
|
-
|
221
|
-
const plan: RebasePlan = {
|
222
|
-
sourcePath: buildDir,
|
223
|
-
newBasePath: '/new/',
|
224
|
-
changeMode: 'mutate',
|
225
|
-
}
|
226
|
-
|
227
|
-
await expect(rebase(plan)).rejects.toThrow('Could not find <head> tag in HTML file')
|
228
|
-
})
|
229
|
-
})
|