polen 0.10.0-next.13 → 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 +2 -23
- 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 +4 -2
- 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 +184 -111
- package/build/api/vite/plugins/pages.js.map +1 -1
- package/build/api/vite/plugins/serve.js +5 -5
- 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/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 -54
- package/build/lib/kit-temp.d.ts.map +1 -1
- package/build/lib/kit-temp.js +14 -82
- 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/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 +1 -1
- package/build/template/components/{Link.js → Link.jsx} +6 -5
- 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} +33 -16
- 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} +6 -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.js +1 -1
- package/build/template/server/app.js.map +1 -1
- package/build/template/server/{render-page.js → render-page.jsx} +4 -3
- package/build/template/server/render-page.jsx.map +1 -0
- package/build/template/server/ssg/generate.js +1 -1
- 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 +8 -71
- 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 +1 -1
- 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 +1 -25
- package/src/api/vite/plugins/core.ts +8 -5
- package/src/api/vite/plugins/pages.ts +208 -132
- package/src/api/vite/plugins/serve.ts +5 -5
- package/src/cli/_/self-contained-mode.ts +5 -5
- 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 -128
- 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/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 +3 -3
- 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 +12 -12
- package/src/template/entry.client.tsx +2 -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 +57 -220
- package/src/template/routes.tsx +1 -1
- package/src/template/server/app.ts +1 -1
- package/src/template/server/ssg/generate.ts +1 -1
- 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 -130
- 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 -68
- package/build/lib/graphql-document/positioning-simple.d.ts.map +0 -1
- package/build/lib/graphql-document/positioning-simple.js +0 -197
- 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 -16
- 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 -62
- 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/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 -286
- 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/render-page.js.map +0 -1
- 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 -250
- 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 -252
- package/src/lib/graphql-document/positioning-simple.ts +0 -271
- 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 -127
- 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 -18
- package/src/template/components/content/GraphQLDocumentWrapper.tsx +0 -82
- package/src/template/contexts/ThemeContext.tsx +0 -60
- /package/build/lib/{graphql-document → file-router/sidebar}/types.js +0 -0
@@ -0,0 +1,110 @@
|
|
1
|
+
import { Tree } from '#lib/tree/index'
|
2
|
+
import { Str } from '@wollybeard/kit'
|
3
|
+
import * as FileRouter from '../file-router.ts'
|
4
|
+
import type { RouteTreeNode } from '../scan-tree.ts'
|
5
|
+
import type { ItemLink, ItemSection, Sidebar } from './types.ts'
|
6
|
+
|
7
|
+
export * from './types.ts'
|
8
|
+
|
9
|
+
/**
|
10
|
+
* Build sidebar from tree structure
|
11
|
+
*/
|
12
|
+
export const buildFromTree = (routeTree: RouteTreeNode, basePath: FileRouter.Path): Sidebar => {
|
13
|
+
const links: ItemLink[] = []
|
14
|
+
const sections: ItemSection[] = []
|
15
|
+
|
16
|
+
// Process only the children of the root node
|
17
|
+
for (const child of routeTree.children) {
|
18
|
+
processNode(child, basePath, [], links, sections)
|
19
|
+
}
|
20
|
+
|
21
|
+
const items = [...links, ...sections]
|
22
|
+
|
23
|
+
return {
|
24
|
+
items,
|
25
|
+
}
|
26
|
+
}
|
27
|
+
|
28
|
+
const processNode = (
|
29
|
+
node: RouteTreeNode,
|
30
|
+
basePath: FileRouter.Path,
|
31
|
+
parentPath: string[],
|
32
|
+
links: ItemLink[],
|
33
|
+
sections: ItemSection[],
|
34
|
+
): void => {
|
35
|
+
const currentPath = [...parentPath, node.value.name]
|
36
|
+
|
37
|
+
if (node.value.type === 'directory') {
|
38
|
+
// This is a directory - create a section
|
39
|
+
const sectionPath = [...basePath, ...currentPath]
|
40
|
+
const sectionPathExp = FileRouter.pathToExpression(sectionPath)
|
41
|
+
const sectionTitle = Str.titlizeSlug(node.value.name)
|
42
|
+
|
43
|
+
const section: ItemSection = {
|
44
|
+
type: `ItemSection`,
|
45
|
+
title: sectionTitle,
|
46
|
+
pathExp: sectionPathExp.startsWith('/') ? sectionPathExp.slice(1) : sectionPathExp,
|
47
|
+
isLinkToo: false,
|
48
|
+
links: [],
|
49
|
+
}
|
50
|
+
|
51
|
+
// Check if this directory has an index file
|
52
|
+
const indexChild = node.children.find(child => child.value.type === 'file' && child.value.name === 'index')
|
53
|
+
if (indexChild) {
|
54
|
+
section.isLinkToo = true
|
55
|
+
}
|
56
|
+
|
57
|
+
// Process all non-index children as links for this section
|
58
|
+
for (const child of node.children) {
|
59
|
+
if (child.value.type === 'file' && child.value.name !== 'index' && child.value.route) {
|
60
|
+
// Pass the parent path of the route, not the section path
|
61
|
+
const routeParentPath = child.value.route.logical.path.slice(0, -1)
|
62
|
+
section.links.push(routeToItemLink(child.value.route, routeParentPath))
|
63
|
+
} else if (child.value.type === 'directory') {
|
64
|
+
// Recursively process subdirectories
|
65
|
+
// Note: This creates nested sections which the original implementation doesn't support
|
66
|
+
// For now, we'll just add the files from subdirectories to the parent section
|
67
|
+
collectFilesFromDirectory(child, child.value.route?.logical.path || [], section.links)
|
68
|
+
}
|
69
|
+
}
|
70
|
+
|
71
|
+
sections.push(section)
|
72
|
+
} else if (node.value.type === 'file' && node.value.route) {
|
73
|
+
// This is a top-level file - add as nav
|
74
|
+
if (node.value.name !== 'index') {
|
75
|
+
links.push(routeToItemLink(node.value.route, basePath))
|
76
|
+
}
|
77
|
+
}
|
78
|
+
}
|
79
|
+
|
80
|
+
const collectFilesFromDirectory = (
|
81
|
+
node: RouteTreeNode,
|
82
|
+
basePath: FileRouter.Path,
|
83
|
+
links: ItemLink[],
|
84
|
+
): void => {
|
85
|
+
Tree.visit(node, (n) => {
|
86
|
+
if (n.value.type === 'file' && n.value.route && n.value.name !== 'index') {
|
87
|
+
// Use the route's parent path for relative title generation
|
88
|
+
const routeParentPath = n.value.route.logical.path.slice(0, -1)
|
89
|
+
links.push(routeToItemLink(n.value.route, routeParentPath))
|
90
|
+
}
|
91
|
+
})
|
92
|
+
}
|
93
|
+
|
94
|
+
const routeToItemLink = (route: FileRouter.Route, basePath: FileRouter.Path): ItemLink => {
|
95
|
+
const pagePathExp = FileRouter.routeToPathExpression(route)
|
96
|
+
const pageRelative = FileRouter.makeRelativeUnsafe(route, basePath)
|
97
|
+
const pageRelativePathExp = FileRouter.routeToPathExpression(pageRelative)
|
98
|
+
|
99
|
+
// Remove leading slash for title generation
|
100
|
+
const titlePath = pageRelativePathExp.startsWith('/') ? pageRelativePathExp.slice(1) : pageRelativePathExp
|
101
|
+
|
102
|
+
// Use only the last segment for the title
|
103
|
+
const titleSegment = pageRelative.logical.path[pageRelative.logical.path.length - 1] || titlePath
|
104
|
+
|
105
|
+
return {
|
106
|
+
type: `ItemLink`,
|
107
|
+
pathExp: pagePathExp.startsWith('/') ? pagePathExp.slice(1) : pagePathExp,
|
108
|
+
title: Str.titlizeSlug(titleSegment),
|
109
|
+
}
|
110
|
+
}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
export interface Sidebar {
|
2
|
+
items: Item[]
|
3
|
+
}
|
4
|
+
|
5
|
+
export type Item = ItemLink | ItemSection
|
6
|
+
|
7
|
+
export interface ItemLink {
|
8
|
+
type: `ItemLink`
|
9
|
+
title: string
|
10
|
+
pathExp: string
|
11
|
+
}
|
12
|
+
|
13
|
+
export interface ItemSection {
|
14
|
+
type: `ItemSection`
|
15
|
+
title: string
|
16
|
+
pathExp: string
|
17
|
+
isLinkToo: boolean
|
18
|
+
links: ItemLink[]
|
19
|
+
}
|
package/src/lib/helpers.ts
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
import {
|
1
|
+
import { Manifest } from '@wollybeard/kit'
|
2
2
|
|
3
3
|
/**
|
4
4
|
* Check if a project has a package installed by examining its package.json
|
@@ -9,9 +9,8 @@ export async function checkIsProjectHasPackageInstalled(
|
|
9
9
|
): Promise<boolean> {
|
10
10
|
const packageJson = await Manifest.resource.read(projectRoot)
|
11
11
|
|
12
|
-
if (
|
13
|
-
|
14
|
-
throw packageJson
|
12
|
+
if (!packageJson) {
|
13
|
+
return false
|
15
14
|
}
|
16
15
|
|
17
16
|
// Check if React is in dependencies or devDependencies
|
package/src/lib/kit-temp.ts
CHANGED
@@ -12,10 +12,8 @@
|
|
12
12
|
//
|
13
13
|
//
|
14
14
|
|
15
|
-
import {
|
16
|
-
import { never } from '@wollybeard/kit/language'
|
15
|
+
import { Fs, Http, Path, Undefined } from '@wollybeard/kit'
|
17
16
|
import type { ResolveHookContext } from 'node:module'
|
18
|
-
import type { IsNever } from 'type-fest'
|
19
17
|
|
20
18
|
export const arrayEquals = (a: any[], b: any[]) => {
|
21
19
|
if (a.length !== b.length) return false
|
@@ -62,103 +60,23 @@ export interface ImportEvent {
|
|
62
60
|
context: ResolveHookContext
|
63
61
|
}
|
64
62
|
|
65
|
-
// dprint-ignore
|
66
|
-
export type ObjPolicyFilter<
|
67
|
-
$Object extends object,
|
68
|
-
$Key extends Keyof<$Object>,
|
69
|
-
Mode extends 'allow' | 'deny',
|
70
|
-
> = Mode extends 'allow'
|
71
|
-
? Pick<$Object, Extract<$Key, keyof $Object>>
|
72
|
-
: Omit<$Object, Extract<$Key, keyof $Object>>
|
73
|
-
|
74
|
-
/**
|
75
|
-
* Like keyof but returns PropertyKey for object
|
76
|
-
*/
|
77
|
-
type Keyof<$Object extends object> = object extends $Object ? PropertyKey : (keyof $Object)
|
78
|
-
|
79
|
-
/**
|
80
|
-
* Filter object properties based on a policy mode and set of keys
|
81
|
-
*
|
82
|
-
* @param mode - 'allow' to keep only specified keys, 'deny' to remove specified keys
|
83
|
-
* @param obj - The object to filter
|
84
|
-
* @param keys - The keys to process
|
85
|
-
* @returns A filtered object with proper type inference
|
86
|
-
*
|
87
|
-
* @example
|
88
|
-
* ```ts
|
89
|
-
* const obj = { a: 1, b: 2, c: 3 }
|
90
|
-
*
|
91
|
-
* // Allow mode: keep only 'a' and 'c'
|
92
|
-
* objPolicyFilter('allow', obj, ['a', 'c']) // { a: 1, c: 3 }
|
93
|
-
*
|
94
|
-
* // Deny mode: remove 'a' and 'c'
|
95
|
-
* objPolicyFilter('deny', obj, ['a', 'c']) // { b: 2 }
|
96
|
-
* ```
|
97
|
-
*/
|
98
|
-
export const objPolicyFilter = <
|
99
|
-
obj extends object,
|
100
|
-
keyUnion extends Keyof<obj>,
|
101
|
-
mode extends 'allow' | 'deny',
|
102
|
-
>(
|
103
|
-
mode: mode,
|
104
|
-
obj: obj,
|
105
|
-
keys: readonly keyUnion[],
|
106
|
-
): ObjPolicyFilter<obj, keyUnion, mode> => {
|
107
|
-
const result: any = mode === 'deny' ? { ...obj } : {}
|
108
|
-
|
109
|
-
if (mode === 'allow') {
|
110
|
-
// For allow mode, only add specified keys
|
111
|
-
for (const key of keys) {
|
112
|
-
if (key in obj) {
|
113
|
-
// @ts-expect-error
|
114
|
-
result[key] = obj[key]
|
115
|
-
}
|
116
|
-
}
|
117
|
-
} else {
|
118
|
-
// For deny mode, remove specified keys
|
119
|
-
for (const key of keys) {
|
120
|
-
delete result[key]
|
121
|
-
}
|
122
|
-
}
|
123
|
-
|
124
|
-
return result
|
125
|
-
}
|
126
|
-
|
127
|
-
/**
|
128
|
-
* Filter an object using a predicate function
|
129
|
-
*
|
130
|
-
* @param obj - The object to filter
|
131
|
-
* @param predicate - Function that returns true to keep a key/value pair
|
132
|
-
* @returns A new object with only the key/value pairs where predicate returned true
|
133
|
-
*
|
134
|
-
* @example
|
135
|
-
* ```ts
|
136
|
-
* const obj = { a: 1, b: 2, c: 3 }
|
137
|
-
* objFilter(obj, (k, v) => v > 1) // { b: 2, c: 3 }
|
138
|
-
* objFilter(obj, k => k !== 'b') // { a: 1, c: 3 }
|
139
|
-
* ```
|
140
|
-
*/
|
141
|
-
export const objFilter = <T extends object>(
|
142
|
-
obj: T,
|
143
|
-
predicate: (key: keyof T, value: T[keyof T], obj: T) => boolean,
|
144
|
-
): Partial<T> => {
|
145
|
-
const result = {} as Partial<T>
|
146
|
-
// Use Object.keys to get all enumerable own properties
|
147
|
-
// This matches the behavior of for...in but only for own properties
|
148
|
-
for (const key of Object.keys(obj) as (keyof T)[]) {
|
149
|
-
if (predicate(key, obj[key], obj)) {
|
150
|
-
result[key] = obj[key]
|
151
|
-
}
|
152
|
-
}
|
153
|
-
return result
|
154
|
-
}
|
155
|
-
|
156
63
|
export const ObjPick = <T extends object, K extends keyof T>(obj: T, keys: readonly K[]): Pick<T, K> => {
|
157
|
-
return
|
64
|
+
return keys.reduce((acc, key) => {
|
65
|
+
if (key in obj) {
|
66
|
+
acc[key] = obj[key]
|
67
|
+
}
|
68
|
+
return acc
|
69
|
+
}, {} as Pick<T, K>)
|
158
70
|
}
|
159
71
|
|
160
72
|
export const ObjOmit = <T extends object, K extends keyof T>(obj: T, keys: readonly K[]): Omit<T, K> => {
|
161
|
-
return
|
73
|
+
return keys.reduce((acc, key) => {
|
74
|
+
if (key in acc) {
|
75
|
+
// @ts-expect-error omitted already at type level
|
76
|
+
delete acc[key]
|
77
|
+
}
|
78
|
+
return acc
|
79
|
+
}, { ...obj } as Omit<T, K>)
|
162
80
|
}
|
163
81
|
|
164
82
|
export const ObjPartition = <T extends object, K extends keyof T>(
|
@@ -188,35 +106,3 @@ export const ResponseInternalServerError = () =>
|
|
188
106
|
status: Http.Status.InternalServerError.code,
|
189
107
|
statusText: Http.Status.InternalServerError.description,
|
190
108
|
})
|
191
|
-
|
192
|
-
/**
|
193
|
-
* Execute an operation on multiple items, continuing even if some fail
|
194
|
-
*/
|
195
|
-
export async function tryCatchMany<item, result>(
|
196
|
-
items: item[],
|
197
|
-
operation: (item: item) => Promise<result>,
|
198
|
-
): Promise<[result[], (Error & { context: { item: item } })[]]> {
|
199
|
-
const partitionedResults = await Promise.all(items.map(async (item) => {
|
200
|
-
const result = await Err.tryCatch(() => operation(item))
|
201
|
-
if (Err.is(result)) {
|
202
|
-
const error = result as Error & { context: { item: item } }
|
203
|
-
error.context = { item }
|
204
|
-
return error
|
205
|
-
}
|
206
|
-
return result
|
207
|
-
})).then(Arr.partitionErrors)
|
208
|
-
return partitionedResults as any
|
209
|
-
}
|
210
|
-
|
211
|
-
/**
|
212
|
-
* Type-level helper to check if two types are exactly the same (invariant).
|
213
|
-
*/
|
214
|
-
export type IsExact<T, U> = T extends U ? U extends T ? true : false : false
|
215
|
-
|
216
|
-
// dprint-ignore
|
217
|
-
export type ExtendsExact<$Input, $Constraint> =
|
218
|
-
$Input extends $Constraint
|
219
|
-
? $Constraint extends $Input
|
220
|
-
? $Input
|
221
|
-
: never
|
222
|
-
: never
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { expect, test } from 'vitest'
|
2
|
-
import { getHighlighter, highlightCode } from './shiki.
|
2
|
+
import { getHighlighter, highlightCode } from './shiki.js'
|
3
3
|
|
4
4
|
test(`getHighlighter returns singleton instance`, async () => {
|
5
5
|
const highlighter1 = await getHighlighter()
|
@@ -0,0 +1,117 @@
|
|
1
|
+
import { describe, expect, test } from 'vitest'
|
2
|
+
import * as Tree from './tree.ts'
|
3
|
+
|
4
|
+
describe('Tree', () => {
|
5
|
+
const sampleTree = Tree.node('root', [
|
6
|
+
Tree.node('a', [
|
7
|
+
Tree.node('a1'),
|
8
|
+
Tree.node('a2'),
|
9
|
+
]),
|
10
|
+
Tree.node('b', [
|
11
|
+
Tree.node('b1'),
|
12
|
+
]),
|
13
|
+
Tree.node('c'),
|
14
|
+
])
|
15
|
+
|
16
|
+
test('node creates a tree node', () => {
|
17
|
+
const leaf = Tree.node('leaf')
|
18
|
+
expect(leaf).toEqual({ value: 'leaf', children: [] })
|
19
|
+
|
20
|
+
const parent = Tree.node('parent', [leaf])
|
21
|
+
expect(parent).toEqual({ value: 'parent', children: [leaf] })
|
22
|
+
})
|
23
|
+
|
24
|
+
test('map transforms node values', () => {
|
25
|
+
const upperTree = Tree.map(sampleTree, value => value.toUpperCase())
|
26
|
+
|
27
|
+
expect(upperTree.value).toBe('ROOT')
|
28
|
+
expect(upperTree.children[0]!.value).toBe('A')
|
29
|
+
expect(upperTree.children[0]!.children[0]!.value).toBe('A1')
|
30
|
+
})
|
31
|
+
|
32
|
+
test('map provides depth and path', () => {
|
33
|
+
const depths: number[] = []
|
34
|
+
const paths: string[][] = []
|
35
|
+
|
36
|
+
Tree.map(sampleTree, (value, depth, path) => {
|
37
|
+
depths.push(depth)
|
38
|
+
paths.push(path)
|
39
|
+
return value
|
40
|
+
})
|
41
|
+
|
42
|
+
expect(depths).toEqual([0, 1, 2, 2, 1, 2, 1])
|
43
|
+
expect(paths[0]).toEqual([])
|
44
|
+
expect(paths[1]).toEqual(['root'])
|
45
|
+
expect(paths[2]).toEqual(['root', 'a'])
|
46
|
+
})
|
47
|
+
|
48
|
+
test('visit traverses all nodes', () => {
|
49
|
+
const visited: string[] = []
|
50
|
+
Tree.visit(sampleTree, node => visited.push(node.value))
|
51
|
+
|
52
|
+
expect(visited).toEqual(['root', 'a', 'a1', 'a2', 'b', 'b1', 'c'])
|
53
|
+
})
|
54
|
+
|
55
|
+
test('find locates node', () => {
|
56
|
+
const found = Tree.find(sampleTree, value => value === 'b1')
|
57
|
+
expect(found?.value).toBe('b1')
|
58
|
+
|
59
|
+
const notFound = Tree.find(sampleTree, value => value === 'x')
|
60
|
+
expect(notFound).toBeUndefined()
|
61
|
+
})
|
62
|
+
|
63
|
+
test('filter removes non-matching nodes', () => {
|
64
|
+
const filtered = Tree.filter(sampleTree, value => !value.includes('2'))
|
65
|
+
|
66
|
+
expect(filtered).toBeDefined()
|
67
|
+
expect(Tree.flatten(filtered!)).toEqual(['root', 'a', 'a1', 'b', 'b1', 'c'])
|
68
|
+
})
|
69
|
+
|
70
|
+
test('sort orders children', () => {
|
71
|
+
const sorted = Tree.sort(sampleTree, (a, b) => b.localeCompare(a))
|
72
|
+
|
73
|
+
expect(sorted.children.map(c => c.value)).toEqual(['c', 'b', 'a'])
|
74
|
+
expect(sorted.children[2]!.children.map(c => c.value)).toEqual(['a2', 'a1'])
|
75
|
+
})
|
76
|
+
|
77
|
+
test('flatten returns all values', () => {
|
78
|
+
const flat = Tree.flatten(sampleTree)
|
79
|
+
expect(flat).toEqual(['root', 'a', 'a1', 'a2', 'b', 'b1', 'c'])
|
80
|
+
})
|
81
|
+
|
82
|
+
test('depth calculates tree depth', () => {
|
83
|
+
expect(Tree.depth(Tree.node('single'))).toBe(0)
|
84
|
+
expect(Tree.depth(sampleTree)).toBe(2)
|
85
|
+
})
|
86
|
+
|
87
|
+
test('count counts all nodes', () => {
|
88
|
+
expect(Tree.count(Tree.node('single'))).toBe(1)
|
89
|
+
expect(Tree.count(sampleTree)).toBe(7)
|
90
|
+
})
|
91
|
+
|
92
|
+
test('isLeaf identifies leaf nodes', () => {
|
93
|
+
expect(Tree.isLeaf(sampleTree)).toBe(false)
|
94
|
+
expect(Tree.isLeaf(sampleTree.children[0]!)).toBe(false)
|
95
|
+
expect(Tree.isLeaf(sampleTree.children[0]!.children[0]!)).toBe(true)
|
96
|
+
})
|
97
|
+
|
98
|
+
test('leaves gets all leaf nodes', () => {
|
99
|
+
const leafNodes = Tree.leaves(sampleTree)
|
100
|
+
expect(leafNodes.map(n => n.value)).toEqual(['a1', 'a2', 'b1', 'c'])
|
101
|
+
})
|
102
|
+
|
103
|
+
test('fromList builds tree from flat list', () => {
|
104
|
+
const items = [
|
105
|
+
{ id: '1', name: 'root' },
|
106
|
+
{ id: '2', parentId: '1', name: 'child1' },
|
107
|
+
{ id: '3', parentId: '1', name: 'child2' },
|
108
|
+
{ id: '4', parentId: '2', name: 'grandchild' },
|
109
|
+
]
|
110
|
+
|
111
|
+
const trees = Tree.fromList(items, undefined)
|
112
|
+
expect(trees).toHaveLength(1)
|
113
|
+
expect(trees[0]!.value.name).toBe('root')
|
114
|
+
expect(trees[0]!.children).toHaveLength(2)
|
115
|
+
expect(trees[0]!.children[0]!.children[0]!.value.name).toBe('grandchild')
|
116
|
+
})
|
117
|
+
})
|
@@ -0,0 +1,183 @@
|
|
1
|
+
/**
|
2
|
+
* Generic tree data structure and utilities
|
3
|
+
*/
|
4
|
+
|
5
|
+
export interface TreeNode<T> {
|
6
|
+
value: T
|
7
|
+
children: TreeNode<T>[]
|
8
|
+
}
|
9
|
+
|
10
|
+
export type TreeVisitor<T, R = void> = (node: TreeNode<T>, depth: number, path: T[]) => R
|
11
|
+
|
12
|
+
export type TreeMapper<T, U> = (value: T, depth: number, path: T[]) => U
|
13
|
+
|
14
|
+
export type TreePredicate<T> = (value: T, depth: number, path: T[]) => boolean
|
15
|
+
|
16
|
+
/**
|
17
|
+
* Create a new tree node
|
18
|
+
*/
|
19
|
+
export const node = <T>(value: T, children: TreeNode<T>[] = []): TreeNode<T> => ({
|
20
|
+
value,
|
21
|
+
children,
|
22
|
+
})
|
23
|
+
|
24
|
+
/**
|
25
|
+
* Map over a tree, transforming each node's value
|
26
|
+
*/
|
27
|
+
export const map = <T, U>(
|
28
|
+
tree: TreeNode<T>,
|
29
|
+
mapper: TreeMapper<T, U>,
|
30
|
+
depth = 0,
|
31
|
+
path: T[] = [],
|
32
|
+
): TreeNode<U> => {
|
33
|
+
const newPath = [...path, tree.value]
|
34
|
+
return {
|
35
|
+
value: mapper(tree.value, depth, path),
|
36
|
+
children: tree.children.map(child => map(child, mapper, depth + 1, newPath)),
|
37
|
+
}
|
38
|
+
}
|
39
|
+
|
40
|
+
/**
|
41
|
+
* Visit each node in the tree (depth-first)
|
42
|
+
*/
|
43
|
+
export const visit = <T>(
|
44
|
+
tree: TreeNode<T>,
|
45
|
+
visitor: TreeVisitor<T>,
|
46
|
+
depth = 0,
|
47
|
+
path: T[] = [],
|
48
|
+
): void => {
|
49
|
+
visitor(tree, depth, path)
|
50
|
+
const newPath = [...path, tree.value]
|
51
|
+
tree.children.forEach(child => visit(child, visitor, depth + 1, newPath))
|
52
|
+
}
|
53
|
+
|
54
|
+
/**
|
55
|
+
* Find a node in the tree
|
56
|
+
*/
|
57
|
+
export const find = <T>(
|
58
|
+
tree: TreeNode<T>,
|
59
|
+
predicate: TreePredicate<T>,
|
60
|
+
depth = 0,
|
61
|
+
path: T[] = [],
|
62
|
+
): TreeNode<T> | undefined => {
|
63
|
+
if (predicate(tree.value, depth, path)) {
|
64
|
+
return tree
|
65
|
+
}
|
66
|
+
const newPath = [...path, tree.value]
|
67
|
+
for (const child of tree.children) {
|
68
|
+
const found = find(child, predicate, depth + 1, newPath)
|
69
|
+
if (found) return found
|
70
|
+
}
|
71
|
+
return undefined
|
72
|
+
}
|
73
|
+
|
74
|
+
/**
|
75
|
+
* Filter tree nodes (keeps structure, removes non-matching nodes)
|
76
|
+
*/
|
77
|
+
export const filter = <T>(
|
78
|
+
tree: TreeNode<T>,
|
79
|
+
predicate: TreePredicate<T>,
|
80
|
+
depth = 0,
|
81
|
+
path: T[] = [],
|
82
|
+
): TreeNode<T> | undefined => {
|
83
|
+
const newPath = [...path, tree.value]
|
84
|
+
const filteredChildren = tree.children
|
85
|
+
.map(child => filter(child, predicate, depth + 1, newPath))
|
86
|
+
.filter((child): child is TreeNode<T> => child !== undefined)
|
87
|
+
|
88
|
+
// Keep node if it matches or has matching children
|
89
|
+
if (predicate(tree.value, depth, path) || filteredChildren.length > 0) {
|
90
|
+
return {
|
91
|
+
value: tree.value,
|
92
|
+
children: filteredChildren,
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
return undefined
|
97
|
+
}
|
98
|
+
|
99
|
+
/**
|
100
|
+
* Sort a tree's children at each level
|
101
|
+
*/
|
102
|
+
export const sort = <T>(
|
103
|
+
tree: TreeNode<T>,
|
104
|
+
compareFn: (a: T, b: T) => number,
|
105
|
+
): TreeNode<T> => ({
|
106
|
+
value: tree.value,
|
107
|
+
children: tree.children
|
108
|
+
.map(child => sort(child, compareFn))
|
109
|
+
.sort((a, b) => compareFn(a.value, b.value)),
|
110
|
+
})
|
111
|
+
|
112
|
+
/**
|
113
|
+
* Flatten a tree into an array (depth-first)
|
114
|
+
*/
|
115
|
+
export const flatten = <T>(tree: TreeNode<T>): T[] => {
|
116
|
+
const result: T[] = [tree.value]
|
117
|
+
tree.children.forEach(child => {
|
118
|
+
result.push(...flatten(child))
|
119
|
+
})
|
120
|
+
return result
|
121
|
+
}
|
122
|
+
|
123
|
+
/**
|
124
|
+
* Get the depth of the tree
|
125
|
+
*/
|
126
|
+
export const depth = <T>(tree: TreeNode<T>): number => {
|
127
|
+
if (tree.children.length === 0) return 0
|
128
|
+
return 1 + Math.max(...tree.children.map(depth))
|
129
|
+
}
|
130
|
+
|
131
|
+
/**
|
132
|
+
* Count total nodes in the tree
|
133
|
+
*/
|
134
|
+
export const count = <T>(tree: TreeNode<T>): number => {
|
135
|
+
return 1 + tree.children.reduce((sum, child) => sum + count(child), 0)
|
136
|
+
}
|
137
|
+
|
138
|
+
/**
|
139
|
+
* Check if a node is a leaf (has no children)
|
140
|
+
*/
|
141
|
+
export const isLeaf = <T>(node: TreeNode<T>): boolean => {
|
142
|
+
return node.children.length === 0
|
143
|
+
}
|
144
|
+
|
145
|
+
/**
|
146
|
+
* Get all leaf nodes
|
147
|
+
*/
|
148
|
+
export const leaves = <T>(tree: TreeNode<T>): TreeNode<T>[] => {
|
149
|
+
if (isLeaf(tree)) return [tree]
|
150
|
+
return tree.children.flatMap(leaves)
|
151
|
+
}
|
152
|
+
|
153
|
+
/**
|
154
|
+
* Build a tree from a flat list with parent references
|
155
|
+
*/
|
156
|
+
export const fromList = <T extends { id: string; parentId?: string }>(
|
157
|
+
items: T[],
|
158
|
+
rootId?: string,
|
159
|
+
): TreeNode<T>[] => {
|
160
|
+
const itemMap = new Map(items.map(item => [item.id, item]))
|
161
|
+
const roots: TreeNode<T>[] = []
|
162
|
+
const nodeMap = new Map<string, TreeNode<T>>()
|
163
|
+
|
164
|
+
// Create all nodes
|
165
|
+
items.forEach(item => {
|
166
|
+
nodeMap.set(item.id, node(item))
|
167
|
+
})
|
168
|
+
|
169
|
+
// Build hierarchy
|
170
|
+
items.forEach(item => {
|
171
|
+
const itemNode = nodeMap.get(item.id)!
|
172
|
+
if (item.parentId === rootId) {
|
173
|
+
roots.push(itemNode)
|
174
|
+
} else if (item.parentId) {
|
175
|
+
const parent = nodeMap.get(item.parentId)
|
176
|
+
if (parent) {
|
177
|
+
parent.children.push(itemNode)
|
178
|
+
}
|
179
|
+
}
|
180
|
+
})
|
181
|
+
|
182
|
+
return roots
|
183
|
+
}
|
package/src/singletons/debug.ts
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
import { Box, Flex, Text } from '@radix-ui/themes'
|
2
2
|
import type { GraphQLArgument } from 'graphql'
|
3
3
|
import type { FC } from 'react'
|
4
|
-
import { TypeAnnotation } from './TypeAnnotation.
|
4
|
+
import { TypeAnnotation } from './TypeAnnotation.jsx'
|
5
5
|
|
6
6
|
export interface Props {
|
7
7
|
data: GraphQLArgument
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { Box, Flex, Heading, Text } from '@radix-ui/themes'
|
2
2
|
import type { GraphQLArgument } from 'graphql'
|
3
3
|
import type { FC } from 'react'
|
4
|
-
import { TypeAnnotation } from './TypeAnnotation.
|
4
|
+
import { TypeAnnotation } from './TypeAnnotation.jsx'
|
5
5
|
|
6
6
|
export interface Props {
|
7
7
|
args: readonly GraphQLArgument[]
|
@@ -2,8 +2,8 @@ import { GrafaidOld } from '#lib/grafaid-old/index'
|
|
2
2
|
import { Box, Text } from '@radix-ui/themes'
|
3
3
|
import type { GraphQLField } from 'graphql'
|
4
4
|
import type { FC } from 'react'
|
5
|
-
import { ArgumentAnnotation } from './ArgumentAnnotation.
|
6
|
-
import { FieldList } from './FieldList.
|
5
|
+
import { ArgumentAnnotation } from './ArgumentAnnotation.jsx'
|
6
|
+
import { FieldList } from './FieldList.jsx'
|
7
7
|
|
8
8
|
export interface Props {
|
9
9
|
field: GraphQLField<any, any>
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import type { GrafaidOld } from '#lib/grafaid-old/index'
|
2
2
|
import { Text } from '@radix-ui/themes'
|
3
3
|
import type { FC } from 'react'
|
4
|
-
import { Markdown } from './Markdown.
|
4
|
+
import { Markdown } from './Markdown.jsx'
|
5
5
|
|
6
6
|
export const DeprecationReason: FC<{ data: GrafaidOld.GraphQLField }> = ({ data }) => {
|
7
7
|
if (!data.deprecationReason) return null
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Text } from '@radix-ui/themes'
|
2
2
|
import type { FC } from 'react'
|
3
|
-
import { Markdown } from './Markdown.
|
3
|
+
import { Markdown } from './Markdown.jsx'
|
4
4
|
// import type { Grafaid } from '#lib/grafaid'
|
5
5
|
import type { GrafaidOld } from '#lib/grafaid-old/index'
|
6
6
|
import type { GraphQLNamedType } from 'graphql'
|