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,144 +0,0 @@
|
|
1
|
-
import { Ts } from '@wollybeard/kit'
|
2
|
-
import { Mask } from './$.ts'
|
3
|
-
import type { InferOptions, Mask as MaskType, PropertiesMask } from './mask.ts'
|
4
|
-
|
5
|
-
// Test 1: InferOptions with unknown should accept all option types
|
6
|
-
{
|
7
|
-
type Options = InferOptions<unknown>
|
8
|
-
|
9
|
-
// This is a type-level assertion - we need to use a different pattern
|
10
|
-
type _Test = Ts.AssertEqual<Options, boolean | string[] | Record<string, boolean>>
|
11
|
-
|
12
|
-
// All of these should be valid options
|
13
|
-
const option1: Options = true
|
14
|
-
const option2: Options = false
|
15
|
-
const option3: Options = ['name', 'age']
|
16
|
-
const option4: Options = []
|
17
|
-
const option5: Options = { name: true, age: false }
|
18
|
-
const option6: Options = {}
|
19
|
-
}
|
20
|
-
|
21
|
-
// Test 2: Mask.create with unknown data type should accept all option types
|
22
|
-
{
|
23
|
-
// Boolean options
|
24
|
-
const mask1 = Mask.create(true)
|
25
|
-
const mask2 = Mask.create(false)
|
26
|
-
// Without explicit type parameter, returns union type
|
27
|
-
Ts.assertEqual<MaskType<unknown>>()(mask1)
|
28
|
-
Ts.assertEqual<MaskType<unknown>>()(mask2)
|
29
|
-
|
30
|
-
// Array options (no type parameter needed)
|
31
|
-
const mask3 = Mask.create(['name', 'age'])
|
32
|
-
const mask4 = Mask.create([])
|
33
|
-
const mask5 = Mask.create(['a', 'b', 'c'])
|
34
|
-
// Returns union type with inferred properties
|
35
|
-
Ts.assertEqual<MaskType<{ name: any; age: any }>>()(mask3)
|
36
|
-
Ts.assertEqual<MaskType<unknown>>()(mask4)
|
37
|
-
Ts.assertEqual<MaskType<{ a: any; b: any; c: any }>>()(mask5)
|
38
|
-
|
39
|
-
// Object options
|
40
|
-
const mask6 = Mask.create({ name: true, age: false })
|
41
|
-
const mask7 = Mask.create({})
|
42
|
-
const mask8 = Mask.create({ foo: true, bar: true, baz: false })
|
43
|
-
// Returns union type with inferred properties
|
44
|
-
Ts.assertEqual<MaskType<unknown>>()(mask6)
|
45
|
-
Ts.assertEqual<MaskType<unknown>>()(mask7)
|
46
|
-
Ts.assertEqual<MaskType<unknown>>()(mask8)
|
47
|
-
}
|
48
|
-
|
49
|
-
// Test 3: With specific data type, options are constrained
|
50
|
-
{
|
51
|
-
type User = { name: string; age: number; email: string }
|
52
|
-
|
53
|
-
// Valid options
|
54
|
-
const mask1 = Mask.create<User>(true)
|
55
|
-
const mask2 = Mask.create<User>(['name', 'age'])
|
56
|
-
const mask3 = Mask.create<User>({ name: true, age: false, email: true })
|
57
|
-
|
58
|
-
// With explicit type parameter, still returns union type
|
59
|
-
Ts.assertEqual<MaskType<User>>()(mask1)
|
60
|
-
Ts.assertEqual<MaskType<User>>()(mask2)
|
61
|
-
Ts.assertEqual<MaskType<User>>()(mask3)
|
62
|
-
|
63
|
-
// Invalid cases would be compile errors
|
64
|
-
// const mask4 = Mask.create<User>(['invalid']) // Error: 'invalid' is not a key of User
|
65
|
-
// const mask5 = Mask.create<User>({ invalid: true }) // Error: 'invalid' is not a property of User
|
66
|
-
}
|
67
|
-
|
68
|
-
// Test 4: Non-object types only accept boolean
|
69
|
-
{
|
70
|
-
const mask1 = Mask.create<string>(true)
|
71
|
-
const mask2 = Mask.create<string>(false)
|
72
|
-
|
73
|
-
Ts.assertEqual<MaskType<string>>()(mask1)
|
74
|
-
Ts.assertEqual<MaskType<string>>()(mask2)
|
75
|
-
|
76
|
-
// Invalid cases would be compile errors
|
77
|
-
// const mask3 = Mask.create<string>(['prop']) // Error: string is not an object
|
78
|
-
// const mask4 = Mask.create<string>({ prop: true }) // Error: string is not an object
|
79
|
-
}
|
80
|
-
|
81
|
-
// Test 5: Test inference in practical scenarios
|
82
|
-
{
|
83
|
-
// Should infer PropertiesMask with object data type
|
84
|
-
const userMask = Mask.create(['name', 'email', 'password'])
|
85
|
-
Ts.assertEqual<MaskType<{ name: any; email: any; password: any }>>()(userMask)
|
86
|
-
|
87
|
-
// When mask is a union type, apply returns a union of possible results
|
88
|
-
const user1 = { name: 'John', email: 'john@example.com', password: 'secret', extra: 'data' }
|
89
|
-
const maskedUser1 = Mask.apply(user1, userMask)
|
90
|
-
// Result is a union type that includes the properties mask result
|
91
|
-
type MaskedUser1 = typeof maskedUser1
|
92
|
-
// Can't use assertSub with union types
|
93
|
-
|
94
|
-
// For partial data, use applyPartial
|
95
|
-
const user2 = { name: 'Jane', email: 'jane@example.com' }
|
96
|
-
const maskedUser2 = Mask.applyPartial(user2, userMask)
|
97
|
-
// Result is a union type
|
98
|
-
type MaskedUser2 = typeof maskedUser2
|
99
|
-
}
|
100
|
-
|
101
|
-
// Test 6: Pick and omit helpers
|
102
|
-
{
|
103
|
-
const pick1 = Mask.pick(['name', 'email'])
|
104
|
-
const omit1 = Mask.omit(['password', 'secret'])
|
105
|
-
|
106
|
-
// Infers specific property types
|
107
|
-
Ts.assertEqual<PropertiesMask<{ name: any; email: any }>>()(pick1)
|
108
|
-
Ts.assertEqual<PropertiesMask<{ password: any; secret: any }>>()(omit1)
|
109
|
-
|
110
|
-
type User = { name: string; email: string; password: string }
|
111
|
-
const pick2 = Mask.pick<User>(['name', 'email'])
|
112
|
-
const omit2 = Mask.omit<User>(['password'])
|
113
|
-
|
114
|
-
Ts.assertEqual<PropertiesMask<User>>()(pick2)
|
115
|
-
Ts.assertEqual<PropertiesMask<User>>()(omit2)
|
116
|
-
}
|
117
|
-
|
118
|
-
// Test 7: Apply type transformations
|
119
|
-
{
|
120
|
-
type User = { name: string; email: string; password: string }
|
121
|
-
const user: User = { name: 'John', email: 'john@example.com', password: 'secret' }
|
122
|
-
|
123
|
-
// Binary mask
|
124
|
-
const showMask = Mask.create<User>(true)
|
125
|
-
const hideMask = Mask.create<User>(false)
|
126
|
-
const shown = Mask.apply(user, showMask)
|
127
|
-
const hidden = Mask.apply(user, hideMask)
|
128
|
-
|
129
|
-
// showMask and hideMask are MaskType<User> (union types), so results are unions
|
130
|
-
type ShownType = typeof shown // Omit<User, keyof User> | undefined
|
131
|
-
type HiddenType = typeof hidden // Omit<User, keyof User> | undefined
|
132
|
-
|
133
|
-
// Properties mask - allow mode
|
134
|
-
const allowMask = Mask.create<User>(['name', 'email'])
|
135
|
-
const allowed = Mask.apply(user, allowMask)
|
136
|
-
// Result is a union due to mask being a union type
|
137
|
-
type AllowedType = typeof allowed
|
138
|
-
|
139
|
-
// Properties mask - deny mode
|
140
|
-
const denyMask = Mask.create<User>({ password: false })
|
141
|
-
const denied = Mask.apply(user, denyMask)
|
142
|
-
// Result is a union due to mask being a union type
|
143
|
-
type DeniedType = typeof denied
|
144
|
-
}
|
package/src/lib/mask/mask.ts
DELETED
@@ -1,244 +0,0 @@
|
|
1
|
-
//
|
2
|
-
//
|
3
|
-
//
|
4
|
-
//
|
5
|
-
// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ • Mask
|
6
|
-
//
|
7
|
-
//
|
8
|
-
|
9
|
-
/**
|
10
|
-
* A mask that can either hide/show data entirely (BinaryMask) or
|
11
|
-
* selectively hide/show object properties (PropertiesMask).
|
12
|
-
*
|
13
|
-
* @template $Data - The data type being masked
|
14
|
-
*/
|
15
|
-
export type Mask<$Data = any> = BinaryMask<$Data> | PropertiesMask<$Data extends object ? $Data : object>
|
16
|
-
|
17
|
-
/**
|
18
|
-
* Create a mask based on the provided options.
|
19
|
-
*
|
20
|
-
* @param options - Mask configuration:
|
21
|
-
* - `boolean`: Creates a binary mask (true = show, false = hide)
|
22
|
-
* - `string[]`: Creates a properties mask that allows only the specified keys
|
23
|
-
* - `object`: Creates a properties mask based on true/false values per key
|
24
|
-
*
|
25
|
-
* @returns A mask that can be applied to data
|
26
|
-
*
|
27
|
-
* @example
|
28
|
-
* ```ts
|
29
|
-
* // Binary mask
|
30
|
-
* const showAll = create(true)
|
31
|
-
* const hideAll = create(false)
|
32
|
-
*
|
33
|
-
* // Properties mask with array
|
34
|
-
* const allowMask = create<User>(['name', 'email'])
|
35
|
-
*
|
36
|
-
* // Properties mask with object
|
37
|
-
* const objectMask = create<User>({
|
38
|
-
* name: true,
|
39
|
-
* email: true,
|
40
|
-
* password: false
|
41
|
-
* })
|
42
|
-
* ```
|
43
|
-
*/
|
44
|
-
export const create = <$Data = unknown>(
|
45
|
-
options: InferOptions<$Data>,
|
46
|
-
): Mask<$Data> => {
|
47
|
-
if (typeof options === 'boolean') {
|
48
|
-
return createBinary(options) as any
|
49
|
-
}
|
50
|
-
|
51
|
-
// Array input -> PropertiesMask with 'allow' mode
|
52
|
-
if (Array.isArray(options)) {
|
53
|
-
return createProperties('allow', options as any) as any
|
54
|
-
}
|
55
|
-
|
56
|
-
// Object input -> PropertiesMask based on true/false values
|
57
|
-
const entries = Object.entries(options)
|
58
|
-
|
59
|
-
const allowedKeys = entries
|
60
|
-
.filter(([_, include]) => include === true)
|
61
|
-
.map(([key]) => key)
|
62
|
-
|
63
|
-
const deniedKeys = entries
|
64
|
-
.filter(([_, include]) => include === false)
|
65
|
-
.map(([key]) => key)
|
66
|
-
|
67
|
-
// If we have denied keys, use deny mode
|
68
|
-
if (deniedKeys.length > 0 && allowedKeys.length === 0) {
|
69
|
-
return createProperties('deny', deniedKeys) as any
|
70
|
-
}
|
71
|
-
|
72
|
-
// Default to allow mode with allowed keys
|
73
|
-
return createProperties('allow', allowedKeys) as any
|
74
|
-
}
|
75
|
-
|
76
|
-
/**
|
77
|
-
* Valid options for creating a mask for the given data type.
|
78
|
-
*
|
79
|
-
* @template $Data - The data type to be masked
|
80
|
-
*/
|
81
|
-
export type InferOptions<$Data> = unknown extends $Data ? boolean | string[] | Record<string, boolean>
|
82
|
-
: $Data extends object ? (
|
83
|
-
| boolean
|
84
|
-
| (keyof $Data)[]
|
85
|
-
| Partial<
|
86
|
-
{
|
87
|
-
[K in keyof $Data]: boolean
|
88
|
-
}
|
89
|
-
>
|
90
|
-
)
|
91
|
-
: boolean
|
92
|
-
|
93
|
-
//
|
94
|
-
//
|
95
|
-
//
|
96
|
-
//
|
97
|
-
// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ • PropertiesMask
|
98
|
-
//
|
99
|
-
//
|
100
|
-
|
101
|
-
/**
|
102
|
-
* A mask that selectively shows or hides object properties.
|
103
|
-
*
|
104
|
-
* @template $Data - The object type being masked
|
105
|
-
*/
|
106
|
-
export interface PropertiesMask<$Data extends object = object> {
|
107
|
-
type: 'properties'
|
108
|
-
/** Whether to allow only specified properties or deny them */
|
109
|
-
mode: 'allow' | 'deny'
|
110
|
-
/** The list of property keys to allow or deny */
|
111
|
-
properties: (keyof $Data)[]
|
112
|
-
}
|
113
|
-
|
114
|
-
/**
|
115
|
-
* Create a properties mask.
|
116
|
-
*
|
117
|
-
* @param mode - 'allow' to show only specified properties, 'deny' to hide them
|
118
|
-
* @param properties - Array of property keys to allow or deny
|
119
|
-
* @returns A PropertiesMask
|
120
|
-
*/
|
121
|
-
export const createProperties = <$Data extends object = object>(
|
122
|
-
mode: 'allow' | 'deny',
|
123
|
-
properties: (keyof $Data)[],
|
124
|
-
): PropertiesMask<$Data> => ({
|
125
|
-
type: 'properties',
|
126
|
-
mode,
|
127
|
-
properties,
|
128
|
-
})
|
129
|
-
|
130
|
-
//
|
131
|
-
//
|
132
|
-
//
|
133
|
-
//
|
134
|
-
// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ • BinaryMask
|
135
|
-
//
|
136
|
-
//
|
137
|
-
|
138
|
-
/**
|
139
|
-
* A mask that either shows or hides data entirely.
|
140
|
-
*
|
141
|
-
* @template _$Data - The data type being masked (used for type inference)
|
142
|
-
*/
|
143
|
-
export type BinaryMask<_$Data = any> = {
|
144
|
-
type: 'binary'
|
145
|
-
/** Whether to show (true) or hide (false) the data */
|
146
|
-
show: boolean
|
147
|
-
}
|
148
|
-
|
149
|
-
/**
|
150
|
-
* Create a binary mask.
|
151
|
-
*
|
152
|
-
* @param show - Whether to show (true) or hide (false) the data
|
153
|
-
* @returns A BinaryMask
|
154
|
-
*/
|
155
|
-
export const createBinary = <$Data = any>(show: boolean): BinaryMask<$Data> => ({
|
156
|
-
type: 'binary',
|
157
|
-
show,
|
158
|
-
})
|
159
|
-
|
160
|
-
//
|
161
|
-
//
|
162
|
-
//
|
163
|
-
//
|
164
|
-
// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ • Convenience Constructors with Semantic Names
|
165
|
-
//
|
166
|
-
//
|
167
|
-
|
168
|
-
/**
|
169
|
-
* Create a mask that shows all data.
|
170
|
-
* @returns A BinaryMask with show=true
|
171
|
-
*/
|
172
|
-
export const show = (): BinaryMask => ({
|
173
|
-
type: 'binary',
|
174
|
-
show: true,
|
175
|
-
})
|
176
|
-
|
177
|
-
/**
|
178
|
-
* Create a mask that hides all data.
|
179
|
-
* @returns A BinaryMask with show=false
|
180
|
-
*/
|
181
|
-
export const hide = (): BinaryMask => ({
|
182
|
-
type: 'binary',
|
183
|
-
show: false,
|
184
|
-
})
|
185
|
-
|
186
|
-
/**
|
187
|
-
* Create a mask that shows only the specified properties.
|
188
|
-
*
|
189
|
-
* @param properties - Array of property keys to show
|
190
|
-
* @returns A PropertiesMask in 'allow' mode
|
191
|
-
*
|
192
|
-
* @example
|
193
|
-
* ```ts
|
194
|
-
* const userMask = pick<User>(['name', 'email'])
|
195
|
-
* // Only 'name' and 'email' will be shown
|
196
|
-
* ```
|
197
|
-
*/
|
198
|
-
export const pick = <$Data extends object = object>(
|
199
|
-
properties: (keyof $Data)[],
|
200
|
-
): PropertiesMask<$Data> => ({
|
201
|
-
type: 'properties',
|
202
|
-
mode: 'allow',
|
203
|
-
properties,
|
204
|
-
})
|
205
|
-
|
206
|
-
/**
|
207
|
-
* Create a mask that hides the specified properties.
|
208
|
-
*
|
209
|
-
* @param properties - Array of property keys to hide
|
210
|
-
* @returns A PropertiesMask in 'deny' mode
|
211
|
-
*
|
212
|
-
* @example
|
213
|
-
* ```ts
|
214
|
-
* const userMask = omit<User>(['password', 'ssn'])
|
215
|
-
* // Everything except 'password' and 'ssn' will be shown
|
216
|
-
* ```
|
217
|
-
*/
|
218
|
-
export const omit = <$Data extends object = object>(
|
219
|
-
properties: (keyof $Data)[],
|
220
|
-
): PropertiesMask<$Data> => ({
|
221
|
-
type: 'properties',
|
222
|
-
mode: 'deny',
|
223
|
-
properties,
|
224
|
-
})
|
225
|
-
|
226
|
-
//
|
227
|
-
//
|
228
|
-
//
|
229
|
-
//
|
230
|
-
// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ • Utilities
|
231
|
-
//
|
232
|
-
//
|
233
|
-
|
234
|
-
/**
|
235
|
-
* Extract the data type from a mask.
|
236
|
-
*
|
237
|
-
* @template $Mask - The mask type
|
238
|
-
* @returns The data type the mask is designed for
|
239
|
-
*/
|
240
|
-
// dprint-ignore
|
241
|
-
export type GetDataType<$Mask extends Mask<any>> =
|
242
|
-
$Mask extends BinaryMask<infer $Data> ? $Data :
|
243
|
-
$Mask extends PropertiesMask<infer $Data> ? $Data
|
244
|
-
: never
|
package/src/lib/task/$$.ts
DELETED
package/src/lib/task/$.test.ts
DELETED
@@ -1,209 +0,0 @@
|
|
1
|
-
import * as fc from 'fast-check'
|
2
|
-
import { describe, expect, test, vi } from 'vitest'
|
3
|
-
import { Task } from './$.ts'
|
4
|
-
|
5
|
-
describe('create', () => {
|
6
|
-
test('executes async function and captures timing', async () => {
|
7
|
-
const double = Task.create(
|
8
|
-
async (x: number) => x * 2,
|
9
|
-
{ name: 'double' },
|
10
|
-
)
|
11
|
-
|
12
|
-
const report = await double(5)
|
13
|
-
|
14
|
-
expect(report.task.name).toBe('double')
|
15
|
-
expect(report.execution.input).toBe(5)
|
16
|
-
expect(report.execution.output).toBe(10)
|
17
|
-
expect(report.execution.timings.duration).toBeGreaterThan(0)
|
18
|
-
})
|
19
|
-
|
20
|
-
test('captures errors', async () => {
|
21
|
-
const failing = Task.create(
|
22
|
-
async () => {
|
23
|
-
throw new Error('Failed')
|
24
|
-
},
|
25
|
-
{ name: 'failing' },
|
26
|
-
)
|
27
|
-
|
28
|
-
const report = await failing(null)
|
29
|
-
|
30
|
-
expect(report.execution.output).toBeInstanceOf(Error)
|
31
|
-
expect((report.execution.output as Error).message).toBe('Failed')
|
32
|
-
})
|
33
|
-
})
|
34
|
-
|
35
|
-
describe('formatReport', () => {
|
36
|
-
test('masks sensitive data', async () => {
|
37
|
-
const createUser = Task.create(
|
38
|
-
async (data: any) => ({
|
39
|
-
email: data.email,
|
40
|
-
token: 'abc123',
|
41
|
-
}),
|
42
|
-
{
|
43
|
-
name: 'create-user',
|
44
|
-
mask: {
|
45
|
-
input: { password: false }, // Hide password
|
46
|
-
output: { token: false }, // Hide token
|
47
|
-
},
|
48
|
-
},
|
49
|
-
)
|
50
|
-
|
51
|
-
const report = await createUser({
|
52
|
-
email: 'user@example.com',
|
53
|
-
password: 'secret',
|
54
|
-
})
|
55
|
-
|
56
|
-
// Uses mask from task definition by default
|
57
|
-
const formatted = Task.formatReport(report)
|
58
|
-
|
59
|
-
expect(formatted).toContain('create-user')
|
60
|
-
expect(formatted).toContain('user@example.com')
|
61
|
-
expect(formatted).not.toContain('secret')
|
62
|
-
expect(formatted).not.toContain('abc123')
|
63
|
-
})
|
64
|
-
|
65
|
-
test('debug mode reveals all data', async () => {
|
66
|
-
const createUser = Task.create(
|
67
|
-
async (data: any) => ({
|
68
|
-
email: data.email,
|
69
|
-
token: 'abc123',
|
70
|
-
}),
|
71
|
-
{
|
72
|
-
name: 'create-user',
|
73
|
-
mask: {
|
74
|
-
input: { password: false }, // Hide password
|
75
|
-
output: { token: false }, // Hide token
|
76
|
-
},
|
77
|
-
},
|
78
|
-
)
|
79
|
-
|
80
|
-
const report = await createUser({
|
81
|
-
email: 'user@example.com',
|
82
|
-
password: 'secret',
|
83
|
-
})
|
84
|
-
|
85
|
-
const formatted = Task.formatReport(report, { debug: true })
|
86
|
-
|
87
|
-
expect(formatted).toContain('secret')
|
88
|
-
expect(formatted).toContain('abc123')
|
89
|
-
})
|
90
|
-
})
|
91
|
-
|
92
|
-
describe('exitWithReport', () => {
|
93
|
-
test('exits with code 0 on success', async () => {
|
94
|
-
const mockExit = vi.spyOn(process, 'exit').mockImplementation(() => {
|
95
|
-
throw new Error('process.exit called')
|
96
|
-
})
|
97
|
-
const mockLog = vi.spyOn(console, 'log').mockImplementation(() => {})
|
98
|
-
|
99
|
-
const success = Task.create(async () => 'result')
|
100
|
-
const report = await success(null)
|
101
|
-
|
102
|
-
expect(() => Task.exitWithReport(report)).toThrow('process.exit called')
|
103
|
-
expect(mockExit).toHaveBeenCalledWith(0)
|
104
|
-
expect(mockLog).toHaveBeenCalled()
|
105
|
-
|
106
|
-
mockExit.mockRestore()
|
107
|
-
mockLog.mockRestore()
|
108
|
-
})
|
109
|
-
|
110
|
-
test('exits with code 1 on error', async () => {
|
111
|
-
const mockExit = vi.spyOn(process, 'exit').mockImplementation(() => {
|
112
|
-
throw new Error('process.exit called')
|
113
|
-
})
|
114
|
-
const mockLog = vi.spyOn(console, 'log').mockImplementation(() => {})
|
115
|
-
|
116
|
-
const failing = Task.create(async () => {
|
117
|
-
throw new Error('Failed')
|
118
|
-
})
|
119
|
-
const report = await failing(null)
|
120
|
-
|
121
|
-
expect(() => Task.exitWithReport(report)).toThrow('process.exit called')
|
122
|
-
expect(mockExit).toHaveBeenCalledWith(1)
|
123
|
-
expect(mockLog).toHaveBeenCalled()
|
124
|
-
|
125
|
-
mockExit.mockRestore()
|
126
|
-
mockLog.mockRestore()
|
127
|
-
})
|
128
|
-
})
|
129
|
-
|
130
|
-
describe('runAndExit', () => {
|
131
|
-
test('combines create, execute, and exit into one call', async () => {
|
132
|
-
const mockExit = vi.spyOn(process, 'exit').mockImplementation(() => {
|
133
|
-
throw new Error('process.exit called')
|
134
|
-
})
|
135
|
-
const mockLog = vi.spyOn(console, 'log').mockImplementation(() => {})
|
136
|
-
|
137
|
-
const double = async (x: number) => x * 2
|
138
|
-
|
139
|
-
await expect(() => Task.runAndExit(double, 5, { name: 'double' })).rejects.toThrow('process.exit called')
|
140
|
-
|
141
|
-
expect(mockExit).toHaveBeenCalledWith(0)
|
142
|
-
expect(mockLog).toHaveBeenCalled()
|
143
|
-
|
144
|
-
// Verify the logged output contains expected content
|
145
|
-
const loggedOutput = mockLog.mock.calls[0]?.[0]
|
146
|
-
expect(loggedOutput).toContain('double')
|
147
|
-
expect(loggedOutput).toContain('10') // Result of 5 * 2
|
148
|
-
|
149
|
-
mockExit.mockRestore()
|
150
|
-
mockLog.mockRestore()
|
151
|
-
})
|
152
|
-
|
153
|
-
test('exits with error code on failure', async () => {
|
154
|
-
const mockExit = vi.spyOn(process, 'exit').mockImplementation(() => {
|
155
|
-
throw new Error('process.exit called')
|
156
|
-
})
|
157
|
-
const mockLog = vi.spyOn(console, 'log').mockImplementation(() => {})
|
158
|
-
|
159
|
-
const failing = async () => {
|
160
|
-
throw new Error('Task failed')
|
161
|
-
}
|
162
|
-
|
163
|
-
await expect(() => Task.runAndExit(failing, null, { name: 'failing' })).rejects.toThrow('process.exit called')
|
164
|
-
|
165
|
-
expect(mockExit).toHaveBeenCalledWith(1)
|
166
|
-
expect(mockLog).toHaveBeenCalled()
|
167
|
-
|
168
|
-
mockExit.mockRestore()
|
169
|
-
mockLog.mockRestore()
|
170
|
-
})
|
171
|
-
})
|
172
|
-
|
173
|
-
describe('property-based tests', () => {
|
174
|
-
test('duration is always positive', async () => {
|
175
|
-
await fc.assert(
|
176
|
-
fc.asyncProperty(
|
177
|
-
fc.integer(),
|
178
|
-
async (input) => {
|
179
|
-
const identity = Task.create(
|
180
|
-
async (x: any) => x,
|
181
|
-
{ name: 'identity' },
|
182
|
-
)
|
183
|
-
|
184
|
-
const report = await identity(input)
|
185
|
-
|
186
|
-
expect(report.execution.timings.duration).toBeGreaterThanOrEqual(0)
|
187
|
-
expect(report.execution.output).toBe(input)
|
188
|
-
},
|
189
|
-
),
|
190
|
-
)
|
191
|
-
})
|
192
|
-
|
193
|
-
test('timing fields are consistent', async () => {
|
194
|
-
await fc.assert(
|
195
|
-
fc.asyncProperty(
|
196
|
-
fc.anything(),
|
197
|
-
async (input) => {
|
198
|
-
const noop = Task.create(async (_: any) => null)
|
199
|
-
const report = await noop(input)
|
200
|
-
|
201
|
-
const { start, end, duration } = report.execution.timings
|
202
|
-
|
203
|
-
expect(end).toBeGreaterThanOrEqual(start)
|
204
|
-
expect(duration).toBeCloseTo(end - start, 5)
|
205
|
-
},
|
206
|
-
),
|
207
|
-
)
|
208
|
-
})
|
209
|
-
})
|
package/src/lib/task/$.ts
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
export * as Task from './$$.ts'
|
package/src/lib/task/report.ts
DELETED
@@ -1,72 +0,0 @@
|
|
1
|
-
import { Mask } from '#lib/mask'
|
2
|
-
import { Err, Str } from '@wollybeard/kit'
|
3
|
-
import type { Definition, MaskOptions } from './task.ts'
|
4
|
-
|
5
|
-
export interface Report<$Input, $Output> {
|
6
|
-
task: Definition<$Input, $Output>
|
7
|
-
execution: {
|
8
|
-
input: $Input
|
9
|
-
output: $Output | Error
|
10
|
-
timings: {
|
11
|
-
start: number
|
12
|
-
end: number
|
13
|
-
duration: number
|
14
|
-
}
|
15
|
-
}
|
16
|
-
}
|
17
|
-
|
18
|
-
export interface FormatOptions<$Input, $Output> {
|
19
|
-
/**
|
20
|
-
* Force masks to reveal all data
|
21
|
-
*/
|
22
|
-
debug?: boolean
|
23
|
-
/**
|
24
|
-
* A mask to apply to the input (if any) and successful return (if any).
|
25
|
-
*
|
26
|
-
* @default Uses the mask bundled with the task, if any.
|
27
|
-
*/
|
28
|
-
mask?: MaskOptions<$Input, $Output>
|
29
|
-
}
|
30
|
-
|
31
|
-
export const formatReport = <$Input, $Output>(
|
32
|
-
report: Report<$Input, $Output>,
|
33
|
-
options?: FormatOptions<$Input, $Output>,
|
34
|
-
): string => {
|
35
|
-
const maskOptions = options?.debug
|
36
|
-
? undefined
|
37
|
-
: (options?.mask ?? report.task.mask)
|
38
|
-
|
39
|
-
// Apply masks
|
40
|
-
const maskedInput = maskOptions?.input
|
41
|
-
? Mask.apply(report.execution.input, Mask.create(maskOptions.input))
|
42
|
-
: report.execution.input
|
43
|
-
|
44
|
-
const maskedOutput = report.execution.output instanceof Error || !maskOptions?.output
|
45
|
-
? report.execution.output
|
46
|
-
: Mask.apply(report.execution.output, Mask.create(maskOptions.output))
|
47
|
-
|
48
|
-
// Format report
|
49
|
-
const s = Str.Builder()
|
50
|
-
|
51
|
-
s`Task: ${report.task.name}`
|
52
|
-
s`Duration: ${report.execution.timings.duration.toFixed(2)}ms`
|
53
|
-
s`Input: ${JSON.stringify(maskedInput, null, 2)}`
|
54
|
-
|
55
|
-
if (report.execution.output instanceof Error) {
|
56
|
-
s(Err.inspect(report.execution.output))
|
57
|
-
} else {
|
58
|
-
s`Output: ${JSON.stringify(maskedOutput, null, 2)}`
|
59
|
-
}
|
60
|
-
|
61
|
-
return s.render()
|
62
|
-
}
|
63
|
-
|
64
|
-
export const exitWithReport = <$Input, $Output>(
|
65
|
-
report: Report<$Input, $Output>,
|
66
|
-
options?: FormatOptions<$Input, $Output>,
|
67
|
-
): never => {
|
68
|
-
const isError = Err.is(report.execution.output)
|
69
|
-
const exitCode = isError ? 1 : 0
|
70
|
-
console.log(formatReport(report, options))
|
71
|
-
process.exit(exitCode)
|
72
|
-
}
|