@astryxdesign/cli 0.0.0-bootstrap.0 → 0.0.15
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/CHANGELOG.md +266 -0
- package/LICENSE +21 -0
- package/README.md +397 -1
- package/bin/astryx.mjs +87 -0
- package/docs/color.doc.mjs +88 -0
- package/docs/elevation.doc.mjs +86 -0
- package/docs/getting-started.doc.mjs +180 -0
- package/docs/icons.doc.mjs +121 -0
- package/docs/illustrations.doc.mjs +86 -0
- package/docs/migration.doc.mjs +250 -0
- package/docs/motion.doc.mjs +158 -0
- package/docs/principles.doc.dense.mjs +14 -0
- package/docs/principles.doc.mjs +93 -0
- package/docs/principles.doc.zh.mjs +14 -0
- package/docs/shape.doc.mjs +76 -0
- package/docs/spacing.doc.mjs +86 -0
- package/docs/styling-libraries.doc.mjs +465 -0
- package/docs/styling.doc.mjs +360 -0
- package/docs/theme.doc.dense.mjs +21 -0
- package/docs/theme.doc.mjs +584 -0
- package/docs/theme.doc.zh.mjs +19 -0
- package/docs/tokens.doc.dense.mjs +16 -0
- package/docs/tokens.doc.mjs +1076 -0
- package/docs/tokens.doc.zh.mjs +16 -0
- package/docs/typography.doc.mjs +228 -0
- package/docs/working-with-ai.doc.mjs +198 -0
- package/package.json +80 -5
- package/src/api/component.mjs +394 -0
- package/src/api/discover.mjs +165 -0
- package/src/api/docs.mjs +163 -0
- package/src/api/doctor.mjs +537 -0
- package/src/api/error.mjs +38 -0
- package/src/api/hook.mjs +196 -0
- package/src/api/index.mjs +29 -0
- package/src/api/search.mjs +363 -0
- package/src/api/template.mjs +567 -0
- package/src/api/template.test.mjs +78 -0
- package/src/cli-exit-codes.test.mjs +177 -0
- package/src/codemods/__tests__/registry.test.mjs +60 -0
- package/src/codemods/__tests__/rename-imperative-ref-to-handleRef.test.mjs +65 -0
- package/src/codemods/__tests__/rename-isStreaming-to-isStopShown.test.mjs +58 -0
- package/src/codemods/__tests__/rename-section-wash-to-muted.test.mjs +103 -0
- package/src/codemods/__tests__/toolbar-density-to-size.test.mjs +69 -0
- package/src/codemods/__tests__/validation.test.mjs +108 -0
- package/src/codemods/ensure-jscodeshift.mjs +86 -0
- package/src/codemods/registry.mjs +60 -0
- package/src/codemods/runner.mjs +380 -0
- package/src/codemods/transforms/v0.0.10/__tests__/remove-size-props.test.mjs +144 -0
- package/src/codemods/transforms/v0.0.10/index.mjs +19 -0
- package/src/codemods/transforms/v0.0.10/remove-size-props.mjs +94 -0
- package/src/codemods/transforms/v0.0.12/__tests__/add-is-icon-only.test.mjs +193 -0
- package/src/codemods/transforms/v0.0.12/add-is-icon-only.mjs +316 -0
- package/src/codemods/transforms/v0.0.12/index.mjs +24 -0
- package/src/codemods/transforms/v0.0.13/__tests__/icon-name-deprecations.test.mjs +81 -0
- package/src/codemods/transforms/v0.0.13/__tests__/rename-attachments-to-drawer.test.mjs +126 -0
- package/src/codemods/transforms/v0.0.13/icon-name-deprecations.mjs +130 -0
- package/src/codemods/transforms/v0.0.13/index.mjs +37 -0
- package/src/codemods/transforms/v0.0.13/rename-attachments-to-drawer.mjs +166 -0
- package/src/codemods/transforms/v0.0.13/toolbar-density-to-size.mjs +159 -0
- package/src/codemods/transforms/v0.0.14/__tests__/rename-action-props.test.mjs +129 -0
- package/src/codemods/transforms/v0.0.14/__tests__/rename-status-variants.test.mjs +205 -0
- package/src/codemods/transforms/v0.0.14/index.mjs +37 -0
- package/src/codemods/transforms/v0.0.14/rename-action-props.mjs +160 -0
- package/src/codemods/transforms/v0.0.14/rename-section-wash-to-muted.mjs +131 -0
- package/src/codemods/transforms/v0.0.14/rename-status-variants.mjs +248 -0
- package/src/codemods/transforms/v0.0.15/__tests__/drop-xds-prefix-imports.test.mjs +137 -0
- package/src/codemods/transforms/v0.0.15/__tests__/migrate-item-children-to-endcontent.test.mjs +95 -0
- package/src/codemods/transforms/v0.0.15/__tests__/migrate-selector-children-to-render-option.test.mjs +109 -0
- package/src/codemods/transforms/v0.0.15/__tests__/migrate-theme-selectors-to-data-attrs.test.mjs +44 -0
- package/src/codemods/transforms/v0.0.15/__tests__/rename-date-picker-to-input.test.mjs +110 -0
- package/src/codemods/transforms/v0.0.15/__tests__/rename-stack-element-to-as.test.mjs +71 -0
- package/src/codemods/transforms/v0.0.15/drop-xds-prefix-imports.mjs +226 -0
- package/src/codemods/transforms/v0.0.15/index.mjs +87 -0
- package/src/codemods/transforms/v0.0.15/migrate-item-children-to-endcontent.mjs +129 -0
- package/src/codemods/transforms/v0.0.15/migrate-selector-children-to-render-option.mjs +189 -0
- package/src/codemods/transforms/v0.0.15/migrate-theme-selectors-to-data-attrs.mjs +235 -0
- package/src/codemods/transforms/v0.0.15/rename-date-picker-to-input.mjs +114 -0
- package/src/codemods/transforms/v0.0.15/rename-imperative-ref-to-handleRef.mjs +67 -0
- package/src/codemods/transforms/v0.0.15/rename-isStreaming-to-isStopShown.mjs +51 -0
- package/src/codemods/transforms/v0.0.15/rename-stack-element-to-as.mjs +41 -0
- package/src/codemods/transforms/v0.0.2/__tests__/migrate-badge-dot-to-statusdot.test.mjs +137 -0
- package/src/codemods/transforms/v0.0.2/__tests__/migrate-gap-to-numeric.test.mjs +161 -0
- package/src/codemods/transforms/v0.0.2/__tests__/migrate-isFullBleed-to-padding.test.mjs +137 -0
- package/src/codemods/transforms/v0.0.2/__tests__/migrate-useXDSIcon-to-getIcon.test.mjs +110 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-banner-endButton-to-endContent.test.mjs +61 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-form-tooltip-startIcon.test.mjs +130 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-isShown-to-isOpen.test.mjs +89 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-selector-items-to-options.test.mjs +74 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-sidenav-header-to-heading.test.mjs +140 -0
- package/src/codemods/transforms/v0.0.2/__tests__/rename-topnav-title-to-heading.test.mjs +116 -0
- package/src/codemods/transforms/v0.0.2/__tests__/unify-uncontrolled-to-defaultX.test.mjs +79 -0
- package/src/codemods/transforms/v0.0.2/__tests__/unify-visibility-to-onOpenChange.test.mjs +130 -0
- package/src/codemods/transforms/v0.0.2/index.mjs +106 -0
- package/src/codemods/transforms/v0.0.2/migrate-badge-dot-to-statusdot.mjs +228 -0
- package/src/codemods/transforms/v0.0.2/migrate-gap-to-numeric.mjs +121 -0
- package/src/codemods/transforms/v0.0.2/migrate-isFullBleed-to-padding.mjs +106 -0
- package/src/codemods/transforms/v0.0.2/migrate-useXDSIcon-to-getIcon.mjs +122 -0
- package/src/codemods/transforms/v0.0.2/rename-banner-endButton-to-endContent.mjs +33 -0
- package/src/codemods/transforms/v0.0.2/rename-form-tooltip-startIcon.mjs +53 -0
- package/src/codemods/transforms/v0.0.2/rename-isShown-to-isOpen.mjs +38 -0
- package/src/codemods/transforms/v0.0.2/rename-selector-items-to-options.mjs +34 -0
- package/src/codemods/transforms/v0.0.2/rename-sidenav-header-to-heading.mjs +84 -0
- package/src/codemods/transforms/v0.0.2/rename-topnav-title-to-heading.mjs +73 -0
- package/src/codemods/transforms/v0.0.2/unify-uncontrolled-to-defaultX.mjs +56 -0
- package/src/codemods/transforms/v0.0.2/unify-visibility-to-onOpenChange.mjs +102 -0
- package/src/codemods/transforms/v0.0.6/__tests__/migrate-collapse-to-collapsible.test.mjs +72 -0
- package/src/codemods/transforms/v0.0.6/__tests__/migrate-radius-tokens.test.mjs +86 -0
- package/src/codemods/transforms/v0.0.6/__tests__/migrate-shadow-tokens.test.mjs +107 -0
- package/src/codemods/transforms/v0.0.6/__tests__/migrate-skeleton-radius.test.mjs +75 -0
- package/src/codemods/transforms/v0.0.6/__tests__/migrate-token-names.test.mjs +267 -0
- package/src/codemods/transforms/v0.0.6/index.mjs +62 -0
- package/src/codemods/transforms/v0.0.6/migrate-badge-children-to-label.mjs +91 -0
- package/src/codemods/transforms/v0.0.6/migrate-collapse-to-collapsible.mjs +145 -0
- package/src/codemods/transforms/v0.0.6/migrate-radius-tokens.mjs +82 -0
- package/src/codemods/transforms/v0.0.6/migrate-shadow-tokens.mjs +111 -0
- package/src/codemods/transforms/v0.0.6/migrate-skeleton-radius.mjs +77 -0
- package/src/codemods/transforms/v0.0.6/migrate-token-names.mjs +158 -0
- package/src/codemods/transforms/v0.0.7/__tests__/rename-banner-variant-to-container.test.mjs +85 -0
- package/src/codemods/transforms/v0.0.7/index.mjs +19 -0
- package/src/codemods/transforms/v0.0.7/rename-banner-variant-to-container.mjs +53 -0
- package/src/codemods/transforms/v0.0.8/__tests__/migrate-token-renames.test.mjs +321 -0
- package/src/codemods/transforms/v0.0.8/__tests__/rename-endslot-to-endcontent.test.mjs +98 -0
- package/src/codemods/transforms/v0.0.8/index.mjs +28 -0
- package/src/codemods/transforms/v0.0.8/migrate-token-renames.mjs +307 -0
- package/src/codemods/transforms/v0.0.8/rename-endslot-to-endcontent.mjs +59 -0
- package/src/commands/agent-docs.mjs +492 -0
- package/src/commands/agent-docs.path-safety.test.mjs +66 -0
- package/src/commands/agent-docs.test.mjs +495 -0
- package/src/commands/build-theme.import-path.test.mjs +115 -0
- package/src/commands/build-theme.mjs +874 -0
- package/src/commands/build-theme.path-safety.test.mjs +117 -0
- package/src/commands/build-theme.prose.test.mjs +135 -0
- package/src/commands/component/index.mjs +224 -0
- package/src/commands/component-package.test.mjs +123 -0
- package/src/commands/component-resolution.test.mjs +177 -0
- package/src/commands/component.test.mjs +659 -0
- package/src/commands/detail-levels.test.mjs +133 -0
- package/src/commands/discover.mjs +143 -0
- package/src/commands/docs.mjs +149 -0
- package/src/commands/docs.test.mjs +101 -0
- package/src/commands/doctor.mjs +85 -0
- package/src/commands/doctor.test.mjs +292 -0
- package/src/commands/external-showcase.test.mjs +121 -0
- package/src/commands/gap-report.mjs +456 -0
- package/src/commands/gap-report.test.mjs +163 -0
- package/src/commands/hook/index.mjs +163 -0
- package/src/commands/import-hint-correctness.test.mjs +182 -0
- package/src/commands/init.mjs +254 -0
- package/src/commands/interactive-guard.test.mjs +69 -0
- package/src/commands/json-contract.test.mjs +227 -0
- package/src/commands/search.mjs +100 -0
- package/src/commands/search.test.mjs +202 -0
- package/src/commands/swizzle-gap-safety.test.mjs +273 -0
- package/src/commands/swizzle.mjs +389 -0
- package/src/commands/swizzle.path-safety.test.mjs +117 -0
- package/src/commands/swizzle.test.mjs +53 -0
- package/src/commands/template.mjs +196 -0
- package/src/commands/template.path-safety.test.mjs +82 -0
- package/src/commands/template.test.mjs +62 -0
- package/src/commands/upgrade.mjs +353 -0
- package/src/commands/upgrade.test.mjs +146 -0
- package/src/index.mjs +334 -0
- package/src/lib/cli-error.mjs +162 -0
- package/src/lib/cli-error.test.mjs +199 -0
- package/src/lib/component-discovery.mjs +485 -0
- package/src/lib/component-format.mjs +545 -0
- package/src/lib/component-format.test.mjs +53 -0
- package/src/lib/component-loader.mjs +107 -0
- package/src/lib/component-loader.test.mjs +107 -0
- package/src/lib/config.mjs +74 -0
- package/src/lib/error-codes.mjs +197 -0
- package/src/lib/error-codes.test.mjs +152 -0
- package/src/lib/hook-discovery.mjs +228 -0
- package/src/lib/hook-format.mjs +247 -0
- package/src/lib/json-contract.test.mjs +168 -0
- package/src/lib/json-shim.mjs +321 -0
- package/src/lib/json-shim.test.mjs +226 -0
- package/src/lib/json.mjs +147 -0
- package/src/lib/manifest.mjs +248 -0
- package/src/lib/manifest.test.mjs +176 -0
- package/src/lib/node-version.mjs +69 -0
- package/src/lib/node-version.test.mjs +91 -0
- package/src/lib/package-scanner.mjs +94 -0
- package/src/lib/parse.mjs +43 -0
- package/src/lib/resolve-theme.mjs +147 -0
- package/src/lib/string-utils.mjs +192 -0
- package/src/types/api.contract.assert.ts +97 -0
- package/src/types/api.d.ts +206 -0
- package/src/types/base.d.ts +164 -0
- package/src/types/component.d.ts +93 -0
- package/src/types/discover.d.ts +59 -0
- package/src/types/docs.d.ts +40 -0
- package/src/types/doctor.d.ts +42 -0
- package/src/types/error-codes.d.ts +58 -0
- package/src/types/gap-report.d.ts +29 -0
- package/src/types/hook.d.ts +59 -0
- package/src/types/index.d.ts +16 -0
- package/src/types/manifest.d.ts +73 -0
- package/src/types/search.d.ts +53 -0
- package/src/types/swizzle.d.ts +30 -0
- package/src/types/template.d.ts +70 -0
- package/src/types/theme.d.ts +23 -0
- package/src/types/upgrade.d.ts +35 -0
- package/src/update-hint-commands.test.mjs +54 -0
- package/src/utils/github.mjs +274 -0
- package/src/utils/interactive.mjs +76 -0
- package/src/utils/interactive.test.mjs +68 -0
- package/src/utils/package-manager.mjs +74 -0
- package/src/utils/package-manager.test.mjs +113 -0
- package/src/utils/path-safety.mjs +185 -0
- package/src/utils/path-safety.test.mjs +137 -0
- package/src/utils/paths.mjs +159 -0
- package/src/utils/paths.test.mjs +211 -0
- package/src/utils/semver.mjs +72 -0
- package/src/utils/semver.test.mjs +67 -0
- package/src/utils/update-check.mjs +104 -0
- package/src/utils/update-check.test.mjs +199 -0
- package/templates/blocks/components/AlertDialog/AlertDialogAsyncAction.doc.mjs +14 -0
- package/templates/blocks/components/AlertDialog/AlertDialogAsyncAction.tsx +27 -0
- package/templates/blocks/components/AlertDialog/AlertDialogDeleteConfirmation.doc.mjs +17 -0
- package/templates/blocks/components/AlertDialog/AlertDialogDeleteConfirmation.tsx +35 -0
- package/templates/blocks/components/AppShell/AppShellContentOnly.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellContentOnly.tsx +30 -0
- package/templates/blocks/components/AppShell/AppShellMobileHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellMobileHookUsage.tsx +63 -0
- package/templates/blocks/components/AppShell/AppShellShowcase.doc.mjs +15 -0
- package/templates/blocks/components/AppShell/AppShellShowcase.tsx +72 -0
- package/templates/blocks/components/AppShell/AppShellSideNavOnly.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellSideNavOnly.tsx +76 -0
- package/templates/blocks/components/AppShell/AppShellTopNavOnly.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellTopNavOnly.tsx +57 -0
- package/templates/blocks/components/AppShell/AppShellTopNavWithSideNav.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellTopNavWithSideNav.tsx +83 -0
- package/templates/blocks/components/AppShell/AppShellWithBanner.doc.mjs +14 -0
- package/templates/blocks/components/AppShell/AppShellWithBanner.tsx +93 -0
- package/templates/blocks/components/AspectRatio/AspectRatioCircleImage.doc.mjs +13 -0
- package/templates/blocks/components/AspectRatio/AspectRatioCircleImage.tsx +24 -0
- package/templates/blocks/components/AspectRatio/AspectRatioImageGallery.doc.mjs +13 -0
- package/templates/blocks/components/AspectRatio/AspectRatioImageGallery.tsx +44 -0
- package/templates/blocks/components/AspectRatio/AspectRatioShowcase.doc.mjs +15 -0
- package/templates/blocks/components/AspectRatio/AspectRatioShowcase.tsx +62 -0
- package/templates/blocks/components/AspectRatio/AspectRatioSquareImage.doc.mjs +13 -0
- package/templates/blocks/components/AspectRatio/AspectRatioSquareImage.tsx +24 -0
- package/templates/blocks/components/AspectRatio/AspectRatioWidescreen.doc.mjs +13 -0
- package/templates/blocks/components/AspectRatio/AspectRatioWidescreen.tsx +24 -0
- package/templates/blocks/components/AspectRatio/AspectRatioWithSkeleton.doc.mjs +13 -0
- package/templates/blocks/components/AspectRatio/AspectRatioWithSkeleton.tsx +17 -0
- package/templates/blocks/components/Avatar/AvatarFallbackChain.doc.mjs +14 -0
- package/templates/blocks/components/Avatar/AvatarFallbackChain.tsx +47 -0
- package/templates/blocks/components/Avatar/AvatarGroup.doc.mjs +13 -0
- package/templates/blocks/components/Avatar/AvatarGroup.tsx +62 -0
- package/templates/blocks/components/Avatar/AvatarInitialsFallback.doc.mjs +13 -0
- package/templates/blocks/components/Avatar/AvatarInitialsFallback.tsx +29 -0
- package/templates/blocks/components/Avatar/AvatarShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Avatar/AvatarShowcase.tsx +37 -0
- package/templates/blocks/components/Avatar/AvatarUserCard.doc.mjs +13 -0
- package/templates/blocks/components/Avatar/AvatarUserCard.tsx +57 -0
- package/templates/blocks/components/Avatar/AvatarWithImage.doc.mjs +13 -0
- package/templates/blocks/components/Avatar/AvatarWithImage.tsx +31 -0
- package/templates/blocks/components/Avatar/AvatarWithStatus.doc.mjs +13 -0
- package/templates/blocks/components/Avatar/AvatarWithStatus.tsx +33 -0
- package/templates/blocks/components/AvatarGroup/AvatarGroupShowcase.doc.mjs +14 -0
- package/templates/blocks/components/AvatarGroup/AvatarGroupShowcase.tsx +58 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowCustomText.doc.mjs +13 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowCustomText.tsx +35 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowDefault.doc.mjs +13 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowDefault.tsx +35 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowShowcase.doc.mjs +14 -0
- package/templates/blocks/components/AvatarGroupOverflow/AvatarGroupOverflowShowcase.tsx +48 -0
- package/templates/blocks/components/AvatarStatusDot/AvatarStatusDotShowcase.doc.mjs +15 -0
- package/templates/blocks/components/AvatarStatusDot/AvatarStatusDotShowcase.tsx +28 -0
- package/templates/blocks/components/Badge/BadgeCategoryTags.doc.mjs +13 -0
- package/templates/blocks/components/Badge/BadgeCategoryTags.tsx +37 -0
- package/templates/blocks/components/Badge/BadgeCountBadges.doc.mjs +13 -0
- package/templates/blocks/components/Badge/BadgeCountBadges.tsx +29 -0
- package/templates/blocks/components/Badge/BadgeShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Badge/BadgeShowcase.tsx +27 -0
- package/templates/blocks/components/Badge/BadgeStatusLabels.doc.mjs +13 -0
- package/templates/blocks/components/Badge/BadgeStatusLabels.tsx +33 -0
- package/templates/blocks/components/Banner/BannerCollapsibleContent.doc.mjs +13 -0
- package/templates/blocks/components/Banner/BannerCollapsibleContent.tsx +31 -0
- package/templates/blocks/components/Banner/BannerDismissable.doc.mjs +13 -0
- package/templates/blocks/components/Banner/BannerDismissable.tsx +31 -0
- package/templates/blocks/components/Banner/BannerSectionVariant.doc.mjs +13 -0
- package/templates/blocks/components/Banner/BannerSectionVariant.tsx +30 -0
- package/templates/blocks/components/Banner/BannerShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Banner/BannerShowcase.tsx +32 -0
- package/templates/blocks/components/Banner/BannerStatuses.doc.mjs +13 -0
- package/templates/blocks/components/Banner/BannerStatuses.tsx +33 -0
- package/templates/blocks/components/Banner/BannerWithActionButton.doc.mjs +13 -0
- package/templates/blocks/components/Banner/BannerWithActionButton.tsx +34 -0
- package/templates/blocks/components/Blockquote/BlockquoteShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Blockquote/BlockquoteShowcase.tsx +28 -0
- package/templates/blocks/components/BreadcrumbItem/BreadcrumbItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/BreadcrumbItem/BreadcrumbItemShowcase.tsx +75 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsCustomSeparator.doc.mjs +13 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsCustomSeparator.tsx +32 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsDeepHierarchy.doc.mjs +13 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsDeepHierarchy.tsx +27 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsShowcase.tsx +15 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsSupportingVariant.doc.mjs +13 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsSupportingVariant.tsx +34 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsWithIcons.doc.mjs +13 -0
- package/templates/blocks/components/Breadcrumbs/BreadcrumbsWithIcons.tsx +25 -0
- package/templates/blocks/components/Button/ButtonShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Button/ButtonShowcase.tsx +17 -0
- package/templates/blocks/components/Button/ButtonSizeVariants.doc.mjs +13 -0
- package/templates/blocks/components/Button/ButtonSizeVariants.tsx +45 -0
- package/templates/blocks/components/Button/ButtonVariants.doc.mjs +13 -0
- package/templates/blocks/components/Button/ButtonVariants.tsx +61 -0
- package/templates/blocks/components/Button/ButtonWithEndSlot.doc.mjs +13 -0
- package/templates/blocks/components/Button/ButtonWithEndSlot.tsx +35 -0
- package/templates/blocks/components/Button/ButtonWithIcon.doc.mjs +13 -0
- package/templates/blocks/components/Button/ButtonWithIcon.tsx +46 -0
- package/templates/blocks/components/ButtonGroup/ButtonGroupShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ButtonGroup/ButtonGroupShowcase.tsx +38 -0
- package/templates/blocks/components/Calendar/CalendarConstraints.doc.mjs +13 -0
- package/templates/blocks/components/Calendar/CalendarConstraints.tsx +34 -0
- package/templates/blocks/components/Calendar/CalendarRangeWithValue.doc.mjs +13 -0
- package/templates/blocks/components/Calendar/CalendarRangeWithValue.tsx +31 -0
- package/templates/blocks/components/Calendar/CalendarShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Calendar/CalendarShowcase.tsx +13 -0
- package/templates/blocks/components/Calendar/CalendarSingle.doc.mjs +13 -0
- package/templates/blocks/components/Calendar/CalendarSingle.tsx +26 -0
- package/templates/blocks/components/Calendar/CalendarTwoMonths.doc.mjs +13 -0
- package/templates/blocks/components/Calendar/CalendarTwoMonths.tsx +32 -0
- package/templates/blocks/components/Card/CardCallout.doc.mjs +13 -0
- package/templates/blocks/components/Card/CardCallout.tsx +30 -0
- package/templates/blocks/components/Card/CardShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Card/CardShowcase.tsx +21 -0
- package/templates/blocks/components/Card/CardVariants.doc.mjs +13 -0
- package/templates/blocks/components/Card/CardVariants.tsx +39 -0
- package/templates/blocks/components/Card/CardWithInnerLayout.doc.mjs +13 -0
- package/templates/blocks/components/Card/CardWithInnerLayout.tsx +44 -0
- package/templates/blocks/components/Card/CardWithSimpleContent.doc.mjs +13 -0
- package/templates/blocks/components/Card/CardWithSimpleContent.tsx +24 -0
- package/templates/blocks/components/Card/ClickableCardShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Card/ClickableCardShowcase.tsx +21 -0
- package/templates/blocks/components/Card/ClickableCardWithNestedButton.doc.mjs +14 -0
- package/templates/blocks/components/Card/ClickableCardWithNestedButton.tsx +24 -0
- package/templates/blocks/components/Card/SelectableCardMulti.doc.mjs +14 -0
- package/templates/blocks/components/Card/SelectableCardMulti.tsx +48 -0
- package/templates/blocks/components/Card/SelectableCardShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Card/SelectableCardShowcase.tsx +46 -0
- package/templates/blocks/components/Carousel/CarouselCards.doc.mjs +13 -0
- package/templates/blocks/components/Carousel/CarouselCards.tsx +55 -0
- package/templates/blocks/components/Carousel/CarouselShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Carousel/CarouselShowcase.tsx +48 -0
- package/templates/blocks/components/Carousel/CarouselSnap.doc.mjs +13 -0
- package/templates/blocks/components/Carousel/CarouselSnap.tsx +43 -0
- package/templates/blocks/components/Center/CenterHorizontal.doc.mjs +13 -0
- package/templates/blocks/components/Center/CenterHorizontal.tsx +65 -0
- package/templates/blocks/components/Center/CenterInsideACard.doc.mjs +13 -0
- package/templates/blocks/components/Center/CenterInsideACard.tsx +28 -0
- package/templates/blocks/components/Center/CenterShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Center/CenterShowcase.tsx +20 -0
- package/templates/blocks/components/ChatComposer/ChatComposerAttachments.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerAttachments.tsx +29 -0
- package/templates/blocks/components/ChatComposer/ChatComposerFooterActions.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerFooterActions.tsx +76 -0
- package/templates/blocks/components/ChatComposer/ChatComposerFullFeatured.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerFullFeatured.tsx +124 -0
- package/templates/blocks/components/ChatComposer/ChatComposerShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerShowcase.tsx +17 -0
- package/templates/blocks/components/ChatComposer/ChatComposerSimple.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerSimple.tsx +18 -0
- package/templates/blocks/components/ChatComposer/ChatComposerStreaming.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerStreaming.tsx +46 -0
- package/templates/blocks/components/ChatComposer/ChatComposerValidation.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposer/ChatComposerValidation.tsx +43 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerAttachments.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerAttachments.tsx +73 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerCollapsible.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerCollapsible.tsx +27 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerFeedback.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerFeedback.tsx +57 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerShowcase.tsx +50 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerWithProgress.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposerDrawer/ChatComposerDrawerWithProgress.tsx +53 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputControlledInput.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputControlledInput.tsx +31 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputDisabled.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputDisabled.tsx +20 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputMentionTrigger.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputMentionTrigger.tsx +63 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputMultipleTriggers.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputMultipleTriggers.tsx +77 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputShowcase.tsx +19 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputSlashCommands.doc.mjs +14 -0
- package/templates/blocks/components/ChatComposerInput/ChatComposerInputSlashCommands.tsx +55 -0
- package/templates/blocks/components/ChatDictation/ChatDictationDictationInComposer.doc.mjs +13 -0
- package/templates/blocks/components/ChatDictation/ChatDictationDictationInComposer.tsx +46 -0
- package/templates/blocks/components/ChatDictation/ChatDictationDictationStates.doc.mjs +13 -0
- package/templates/blocks/components/ChatDictation/ChatDictationDictationStates.tsx +82 -0
- package/templates/blocks/components/ChatDictation/ChatDictationSizes.doc.mjs +13 -0
- package/templates/blocks/components/ChatDictation/ChatDictationSizes.tsx +63 -0
- package/templates/blocks/components/ChatDictationButton/ChatDictationButtonShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatDictationButton/ChatDictationButtonShowcase.tsx +72 -0
- package/templates/blocks/components/ChatLayout/ChatLayoutPanelChat.doc.mjs +13 -0
- package/templates/blocks/components/ChatLayout/ChatLayoutPanelChat.tsx +63 -0
- package/templates/blocks/components/ChatLayout/ChatLayoutShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ChatLayout/ChatLayoutShowcase.tsx +44 -0
- package/templates/blocks/components/ChatLayoutScrollButton/ChatLayoutScrollButtonLabels.doc.mjs +13 -0
- package/templates/blocks/components/ChatLayoutScrollButton/ChatLayoutScrollButtonLabels.tsx +33 -0
- package/templates/blocks/components/ChatLayoutScrollButton/ChatLayoutScrollButtonStates.doc.mjs +14 -0
- package/templates/blocks/components/ChatLayoutScrollButton/ChatLayoutScrollButtonStates.tsx +42 -0
- package/templates/blocks/components/ChatMessage/ChatMessageAvatarName.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessage/ChatMessageAvatarName.tsx +72 -0
- package/templates/blocks/components/ChatMessage/ChatMessageGhost.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessage/ChatMessageGhost.tsx +63 -0
- package/templates/blocks/components/ChatMessage/ChatMessageMultiBubble.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessage/ChatMessageMultiBubble.tsx +66 -0
- package/templates/blocks/components/ChatMessage/ChatMessageShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatMessage/ChatMessageShowcase.tsx +55 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleDensity.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleDensity.tsx +41 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleGrouping.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleGrouping.tsx +63 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleMetadata.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleMetadata.tsx +70 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleShowcase.tsx +48 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleVariants.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageBubble/ChatMessageBubbleVariants.tsx +43 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListDensity.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListDensity.tsx +67 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListFullFeatured.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListFullFeatured.tsx +105 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatMessageList/ChatMessageListShowcase.tsx +75 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataFooter.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataFooter.tsx +94 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataShowcase.tsx +129 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataStatus.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataStatus.tsx +41 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataTimestamp.doc.mjs +13 -0
- package/templates/blocks/components/ChatMessageMetadata/ChatMessageMetadataTimestamp.tsx +43 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonCustomIcon.doc.mjs +13 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonCustomIcon.tsx +46 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonInComposer.doc.mjs +13 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonInComposer.tsx +25 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonShowcase.tsx +22 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonStates.doc.mjs +13 -0
- package/templates/blocks/components/ChatSendButton/ChatSendButtonStates.tsx +22 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageShowcase.tsx +21 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageStatusUpdates.doc.mjs +13 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageStatusUpdates.tsx +37 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageVariants.doc.mjs +13 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageVariants.tsx +38 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageWithIcon.doc.mjs +13 -0
- package/templates/blocks/components/ChatSystemMessage/ChatSystemMessageWithIcon.tsx +38 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextBasic.doc.mjs +13 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextBasic.tsx +29 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextColors.doc.mjs +13 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextColors.tsx +30 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ChatTokenizedText/ChatTokenizedTextShowcase.tsx +30 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsInteractiveToolCalls.doc.mjs +13 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsInteractiveToolCalls.tsx +70 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsShowcase.tsx +35 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsStatuses.doc.mjs +13 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsStatuses.tsx +44 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsToolCallsWithNodes.doc.mjs +13 -0
- package/templates/blocks/components/ChatToolCalls/ChatToolCallsToolCallsWithNodes.tsx +49 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputBasic.doc.mjs +13 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputBasic.tsx +46 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputIndeterminateState.doc.mjs +13 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputIndeterminateState.tsx +64 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputShowcase.tsx +27 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputStatusVariations.doc.mjs +13 -0
- package/templates/blocks/components/CheckboxInput/CheckboxInputStatusVariations.tsx +45 -0
- package/templates/blocks/components/CheckboxList/CheckboxListSelectAllPattern.doc.mjs +14 -0
- package/templates/blocks/components/CheckboxList/CheckboxListSelectAllPattern.tsx +53 -0
- package/templates/blocks/components/CheckboxList/CheckboxListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/CheckboxList/CheckboxListShowcase.tsx +33 -0
- package/templates/blocks/components/CheckboxList/CheckboxListWithEndContent.doc.mjs +14 -0
- package/templates/blocks/components/CheckboxList/CheckboxListWithEndContent.tsx +37 -0
- package/templates/blocks/components/CheckboxListItem/CheckboxListItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/CheckboxListItem/CheckboxListItemShowcase.tsx +40 -0
- package/templates/blocks/components/Citation/CitationInlineText.doc.mjs +14 -0
- package/templates/blocks/components/Citation/CitationInlineText.tsx +42 -0
- package/templates/blocks/components/Citation/CitationShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Citation/CitationShowcase.tsx +62 -0
- package/templates/blocks/components/Citation/CitationSourceList.doc.mjs +14 -0
- package/templates/blocks/components/Citation/CitationSourceList.tsx +49 -0
- package/templates/blocks/components/Code/CodeAcrossTextSizes.doc.mjs +14 -0
- package/templates/blocks/components/Code/CodeAcrossTextSizes.tsx +27 -0
- package/templates/blocks/components/Code/CodeInlineInParagraph.doc.mjs +14 -0
- package/templates/blocks/components/Code/CodeInlineInParagraph.tsx +23 -0
- package/templates/blocks/components/Code/CodeShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Code/CodeShowcase.tsx +22 -0
- package/templates/blocks/components/Code/CodeVariousContent.doc.mjs +14 -0
- package/templates/blocks/components/Code/CodeVariousContent.tsx +29 -0
- package/templates/blocks/components/CodeBlock/CodeBlockBashCommand.doc.mjs +14 -0
- package/templates/blocks/components/CodeBlock/CodeBlockBashCommand.tsx +25 -0
- package/templates/blocks/components/CodeBlock/CodeBlockHighlightedLines.doc.mjs +14 -0
- package/templates/blocks/components/CodeBlock/CodeBlockHighlightedLines.tsx +30 -0
- package/templates/blocks/components/CodeBlock/CodeBlockJSONConfig.doc.mjs +14 -0
- package/templates/blocks/components/CodeBlock/CodeBlockJSONConfig.tsx +29 -0
- package/templates/blocks/components/CodeBlock/CodeBlockScrollableBlock.doc.mjs +14 -0
- package/templates/blocks/components/CodeBlock/CodeBlockScrollableBlock.tsx +22 -0
- package/templates/blocks/components/CodeBlock/CodeBlockShowcase.doc.mjs +15 -0
- package/templates/blocks/components/CodeBlock/CodeBlockShowcase.tsx +31 -0
- package/templates/blocks/components/Collapsible/CollapsibleControlledAccordion.doc.mjs +13 -0
- package/templates/blocks/components/Collapsible/CollapsibleControlledAccordion.tsx +43 -0
- package/templates/blocks/components/Collapsible/CollapsibleHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/Collapsible/CollapsibleHookUsage.tsx +46 -0
- package/templates/blocks/components/Collapsible/CollapsibleMultipleAccordion.doc.mjs +13 -0
- package/templates/blocks/components/Collapsible/CollapsibleMultipleAccordion.tsx +41 -0
- package/templates/blocks/components/Collapsible/CollapsibleShowcase.doc.mjs +16 -0
- package/templates/blocks/components/Collapsible/CollapsibleShowcase.tsx +34 -0
- package/templates/blocks/components/Collapsible/CollapsibleSingleAccordion.doc.mjs +13 -0
- package/templates/blocks/components/Collapsible/CollapsibleSingleAccordion.tsx +40 -0
- package/templates/blocks/components/Collapsible/CollapsibleWithoutCard.doc.mjs +13 -0
- package/templates/blocks/components/Collapsible/CollapsibleWithoutCard.tsx +35 -0
- package/templates/blocks/components/CollapsibleGroup/CollapsibleGroupShowcase.doc.mjs +15 -0
- package/templates/blocks/components/CollapsibleGroup/CollapsibleGroupShowcase.tsx +43 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteAsyncSearch.doc.mjs +14 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteAsyncSearch.tsx +47 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteAutoGrouped.doc.mjs +14 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteAutoGrouped.tsx +33 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteCustomFooter.doc.mjs +13 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteCustomFooter.tsx +36 -0
- package/templates/blocks/components/CommandPalette/CommandPalettePickerMode.doc.mjs +14 -0
- package/templates/blocks/components/CommandPalette/CommandPalettePickerMode.tsx +41 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteRichItems.doc.mjs +14 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteRichItems.tsx +61 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteShowcase.doc.mjs +14 -0
- package/templates/blocks/components/CommandPalette/CommandPaletteShowcase.tsx +31 -0
- package/templates/blocks/components/CommandPaletteFooter/CommandPaletteFooterShowcase.doc.mjs +14 -0
- package/templates/blocks/components/CommandPaletteFooter/CommandPaletteFooterShowcase.tsx +39 -0
- package/templates/blocks/components/CommandPaletteGroup/CommandPaletteGroupShowcase.doc.mjs +14 -0
- package/templates/blocks/components/CommandPaletteGroup/CommandPaletteGroupShowcase.tsx +68 -0
- package/templates/blocks/components/CommandPaletteItem/CommandPaletteItemShowcase.doc.mjs +14 -0
- package/templates/blocks/components/CommandPaletteItem/CommandPaletteItemShowcase.tsx +85 -0
- package/templates/blocks/components/ContextMenu/ContextMenuShowcase.doc.mjs +14 -0
- package/templates/blocks/components/ContextMenu/ContextMenuShowcase.tsx +31 -0
- package/templates/blocks/components/DateInput/DateInputClearable.doc.mjs +14 -0
- package/templates/blocks/components/DateInput/DateInputClearable.tsx +33 -0
- package/templates/blocks/components/DateInput/DateInputDateRange.doc.mjs +14 -0
- package/templates/blocks/components/DateInput/DateInputDateRange.tsx +45 -0
- package/templates/blocks/components/DateInput/DateInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DateInput/DateInputShowcase.tsx +26 -0
- package/templates/blocks/components/DateInput/DateInputWithDescription.doc.mjs +14 -0
- package/templates/blocks/components/DateInput/DateInputWithDescription.tsx +30 -0
- package/templates/blocks/components/DateInput/DateInputWithValidation.doc.mjs +14 -0
- package/templates/blocks/components/DateInput/DateInputWithValidation.tsx +45 -0
- package/templates/blocks/components/DateRangeInput/DateRangeInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DateRangeInput/DateRangeInputShowcase.tsx +39 -0
- package/templates/blocks/components/DateTimeInput/DateTimeInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DateTimeInput/DateTimeInputShowcase.tsx +26 -0
- package/templates/blocks/components/Dialog/DialogConfirmationDialog.doc.mjs +16 -0
- package/templates/blocks/components/Dialog/DialogConfirmationDialog.tsx +67 -0
- package/templates/blocks/components/Dialog/DialogFormDialog.doc.mjs +15 -0
- package/templates/blocks/components/Dialog/DialogFormDialog.tsx +84 -0
- package/templates/blocks/components/Dialog/DialogFullscreenDialog.doc.mjs +14 -0
- package/templates/blocks/components/Dialog/DialogFullscreenDialog.tsx +99 -0
- package/templates/blocks/components/Dialog/DialogScrollingContent.doc.mjs +15 -0
- package/templates/blocks/components/Dialog/DialogScrollingContent.tsx +84 -0
- package/templates/blocks/components/Dialog/DialogShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Dialog/DialogShowcase.tsx +23 -0
- package/templates/blocks/components/Dialog/DialogWithSubtitle.doc.mjs +15 -0
- package/templates/blocks/components/Dialog/DialogWithSubtitle.tsx +62 -0
- package/templates/blocks/components/DialogHeader/DialogHeaderShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DialogHeader/DialogHeaderShowcase.tsx +32 -0
- package/templates/blocks/components/Divider/DividerFullBleed.doc.mjs +14 -0
- package/templates/blocks/components/Divider/DividerFullBleed.tsx +39 -0
- package/templates/blocks/components/Divider/DividerShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Divider/DividerShowcase.tsx +23 -0
- package/templates/blocks/components/Divider/DividerVariants.doc.mjs +14 -0
- package/templates/blocks/components/Divider/DividerVariants.tsx +37 -0
- package/templates/blocks/components/Divider/DividerVertical.doc.mjs +14 -0
- package/templates/blocks/components/Divider/DividerVertical.tsx +57 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuActions.doc.mjs +14 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuActions.tsx +33 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuNoChevron.doc.mjs +14 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuNoChevron.tsx +40 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuShowcase.tsx +24 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuWithDisabledItems.doc.mjs +14 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuWithDisabledItems.tsx +35 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuWithSections.doc.mjs +14 -0
- package/templates/blocks/components/DropdownMenu/DropdownMenuWithSections.tsx +51 -0
- package/templates/blocks/components/DropdownMenuItem/DropdownMenuItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/DropdownMenuItem/DropdownMenuItemShowcase.tsx +94 -0
- package/templates/blocks/components/EmptyState/EmptyStateActions.doc.mjs +14 -0
- package/templates/blocks/components/EmptyState/EmptyStateActions.tsx +24 -0
- package/templates/blocks/components/EmptyState/EmptyStateCompact.doc.mjs +14 -0
- package/templates/blocks/components/EmptyState/EmptyStateCompact.tsx +26 -0
- package/templates/blocks/components/EmptyState/EmptyStateContainer.doc.mjs +14 -0
- package/templates/blocks/components/EmptyState/EmptyStateContainer.tsx +27 -0
- package/templates/blocks/components/EmptyState/EmptyStateShowcase.doc.mjs +15 -0
- package/templates/blocks/components/EmptyState/EmptyStateShowcase.tsx +19 -0
- package/templates/blocks/components/Field/FieldRequired.doc.mjs +14 -0
- package/templates/blocks/components/Field/FieldRequired.tsx +34 -0
- package/templates/blocks/components/Field/FieldShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Field/FieldShowcase.tsx +43 -0
- package/templates/blocks/components/Field/FieldStatusVariants.doc.mjs +14 -0
- package/templates/blocks/components/Field/FieldStatusVariants.tsx +48 -0
- package/templates/blocks/components/Field/FieldWithDescription.doc.mjs +14 -0
- package/templates/blocks/components/Field/FieldWithDescription.tsx +34 -0
- package/templates/blocks/components/FieldLabel/FieldLabelShowcase.doc.mjs +15 -0
- package/templates/blocks/components/FieldLabel/FieldLabelShowcase.tsx +42 -0
- package/templates/blocks/components/FieldStatus/FieldStatusShowcase.doc.mjs +15 -0
- package/templates/blocks/components/FieldStatus/FieldStatusShowcase.tsx +28 -0
- package/templates/blocks/components/FileInput/FileInputShowcase.doc.mjs +12 -0
- package/templates/blocks/components/FileInput/FileInputShowcase.tsx +18 -0
- package/templates/blocks/components/FormLayout/FormLayoutHorizontal.doc.mjs +13 -0
- package/templates/blocks/components/FormLayout/FormLayoutHorizontal.tsx +24 -0
- package/templates/blocks/components/FormLayout/FormLayoutHorizontalLabels.doc.mjs +13 -0
- package/templates/blocks/components/FormLayout/FormLayoutHorizontalLabels.tsx +38 -0
- package/templates/blocks/components/FormLayout/FormLayoutMixedControls.doc.mjs +13 -0
- package/templates/blocks/components/FormLayout/FormLayoutMixedControls.tsx +39 -0
- package/templates/blocks/components/FormLayout/FormLayoutNested.doc.mjs +13 -0
- package/templates/blocks/components/FormLayout/FormLayoutNested.tsx +31 -0
- package/templates/blocks/components/FormLayout/FormLayoutShowcase.doc.mjs +15 -0
- package/templates/blocks/components/FormLayout/FormLayoutShowcase.tsx +31 -0
- package/templates/blocks/components/Grid/GridDashboardLayout.doc.mjs +13 -0
- package/templates/blocks/components/Grid/GridDashboardLayout.tsx +51 -0
- package/templates/blocks/components/Grid/GridGalleryExample.doc.mjs +13 -0
- package/templates/blocks/components/Grid/GridGalleryExample.tsx +40 -0
- package/templates/blocks/components/Grid/GridResponsiveAutoFit.doc.mjs +13 -0
- package/templates/blocks/components/Grid/GridResponsiveAutoFit.tsx +82 -0
- package/templates/blocks/components/Grid/GridShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Grid/GridShowcase.tsx +16 -0
- package/templates/blocks/components/Grid/GridWithGridSpan.doc.mjs +13 -0
- package/templates/blocks/components/Grid/GridWithGridSpan.tsx +96 -0
- package/templates/blocks/components/GridSpan/GridSpanShowcase.doc.mjs +15 -0
- package/templates/blocks/components/GridSpan/GridSpanShowcase.tsx +52 -0
- package/templates/blocks/components/HStack/HStackShowcase.doc.mjs +14 -0
- package/templates/blocks/components/HStack/HStackShowcase.tsx +44 -0
- package/templates/blocks/components/Heading/HeadingCardGrid.doc.mjs +14 -0
- package/templates/blocks/components/Heading/HeadingCardGrid.tsx +24 -0
- package/templates/blocks/components/Heading/HeadingPageLayout.doc.mjs +14 -0
- package/templates/blocks/components/Heading/HeadingPageLayout.tsx +34 -0
- package/templates/blocks/components/Heading/HeadingShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Heading/HeadingShowcase.tsx +19 -0
- package/templates/blocks/components/Heading/HeadingTruncation.doc.mjs +14 -0
- package/templates/blocks/components/Heading/HeadingTruncation.tsx +23 -0
- package/templates/blocks/components/Hooks/useStreamingTextHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/Hooks/useStreamingTextHookUsage.tsx +31 -0
- package/templates/blocks/components/HoverCard/HoverCardHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/HoverCard/HoverCardHookUsage.tsx +41 -0
- package/templates/blocks/components/HoverCard/HoverCardInlineTextHoverCard.doc.mjs +14 -0
- package/templates/blocks/components/HoverCard/HoverCardInlineTextHoverCard.tsx +47 -0
- package/templates/blocks/components/HoverCard/HoverCardInteractiveContent.doc.mjs +14 -0
- package/templates/blocks/components/HoverCard/HoverCardInteractiveContent.tsx +42 -0
- package/templates/blocks/components/HoverCard/HoverCardProfileHoverCard.doc.mjs +14 -0
- package/templates/blocks/components/HoverCard/HoverCardProfileHoverCard.tsx +43 -0
- package/templates/blocks/components/HoverCard/HoverCardShowcase.doc.mjs +16 -0
- package/templates/blocks/components/HoverCard/HoverCardShowcase.tsx +41 -0
- package/templates/blocks/components/Icon/IconNonSemanticColors.doc.mjs +14 -0
- package/templates/blocks/components/Icon/IconNonSemanticColors.tsx +33 -0
- package/templates/blocks/components/Icon/IconSemanticColors.doc.mjs +14 -0
- package/templates/blocks/components/Icon/IconSemanticColors.tsx +46 -0
- package/templates/blocks/components/Icon/IconShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Icon/IconShowcase.tsx +9 -0
- package/templates/blocks/components/Icon/IconSizes.doc.mjs +14 -0
- package/templates/blocks/components/Icon/IconSizes.tsx +30 -0
- package/templates/blocks/components/Icon/IconStatusIcons.doc.mjs +14 -0
- package/templates/blocks/components/Icon/IconStatusIcons.tsx +27 -0
- package/templates/blocks/components/IconButton/IconButtonActionBar.doc.mjs +13 -0
- package/templates/blocks/components/IconButton/IconButtonActionBar.tsx +39 -0
- package/templates/blocks/components/IconButton/IconButtonLoadingToggle.doc.mjs +13 -0
- package/templates/blocks/components/IconButton/IconButtonLoadingToggle.tsx +42 -0
- package/templates/blocks/components/IconButton/IconButtonShowcase.doc.mjs +15 -0
- package/templates/blocks/components/IconButton/IconButtonShowcase.tsx +15 -0
- package/templates/blocks/components/IconButton/IconButtonTooltipIconButton.doc.mjs +13 -0
- package/templates/blocks/components/IconButton/IconButtonTooltipIconButton.tsx +32 -0
- package/templates/blocks/components/InputGroup/InputGroupShowcase.doc.mjs +13 -0
- package/templates/blocks/components/InputGroup/InputGroupShowcase.tsx +39 -0
- package/templates/blocks/components/Item/ItemBasicItem.doc.mjs +14 -0
- package/templates/blocks/components/Item/ItemBasicItem.tsx +29 -0
- package/templates/blocks/components/Item/ItemShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Item/ItemShowcase.tsx +47 -0
- package/templates/blocks/components/Item/ItemWithMedia.doc.mjs +14 -0
- package/templates/blocks/components/Item/ItemWithMedia.tsx +38 -0
- package/templates/blocks/components/Item/ItemWithMetadata.doc.mjs +14 -0
- package/templates/blocks/components/Item/ItemWithMetadata.tsx +36 -0
- package/templates/blocks/components/Kbd/KbdInlineInstructions.doc.mjs +13 -0
- package/templates/blocks/components/Kbd/KbdInlineInstructions.tsx +27 -0
- package/templates/blocks/components/Kbd/KbdMenuShortcuts.doc.mjs +13 -0
- package/templates/blocks/components/Kbd/KbdMenuShortcuts.tsx +31 -0
- package/templates/blocks/components/Kbd/KbdModifierCombos.doc.mjs +13 -0
- package/templates/blocks/components/Kbd/KbdModifierCombos.tsx +33 -0
- package/templates/blocks/components/Kbd/KbdShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Kbd/KbdShowcase.tsx +9 -0
- package/templates/blocks/components/Layer/LayerHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/Layer/LayerHookUsage.tsx +37 -0
- package/templates/blocks/components/Layout/LayoutBasicCardLayout.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutBasicCardLayout.tsx +65 -0
- package/templates/blocks/components/Layout/LayoutContentOnlyLayout.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutContentOnlyLayout.tsx +28 -0
- package/templates/blocks/components/Layout/LayoutContentWidth.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutContentWidth.tsx +54 -0
- package/templates/blocks/components/Layout/LayoutDualPanelLayout.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutDualPanelLayout.tsx +66 -0
- package/templates/blocks/components/Layout/LayoutFullBleedContent.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutFullBleedContent.tsx +49 -0
- package/templates/blocks/components/Layout/LayoutShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Layout/LayoutShowcase.tsx +64 -0
- package/templates/blocks/components/Layout/LayoutSidebarLayout.doc.mjs +14 -0
- package/templates/blocks/components/Layout/LayoutSidebarLayout.tsx +65 -0
- package/templates/blocks/components/LayoutContent/LayoutContentShowcase.doc.mjs +15 -0
- package/templates/blocks/components/LayoutContent/LayoutContentShowcase.tsx +56 -0
- package/templates/blocks/components/LayoutFooter/LayoutFooterShowcase.doc.mjs +15 -0
- package/templates/blocks/components/LayoutFooter/LayoutFooterShowcase.tsx +53 -0
- package/templates/blocks/components/LayoutHeader/LayoutHeaderShowcase.doc.mjs +15 -0
- package/templates/blocks/components/LayoutHeader/LayoutHeaderShowcase.tsx +57 -0
- package/templates/blocks/components/LayoutPanel/LayoutPanelShowcase.doc.mjs +15 -0
- package/templates/blocks/components/LayoutPanel/LayoutPanelShowcase.tsx +50 -0
- package/templates/blocks/components/Lightbox/LightboxShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Lightbox/LightboxShowcase.tsx +22 -0
- package/templates/blocks/components/Link/LinkExternalLinks.doc.mjs +14 -0
- package/templates/blocks/components/Link/LinkExternalLinks.tsx +32 -0
- package/templates/blocks/components/Link/LinkInlineLink.doc.mjs +13 -0
- package/templates/blocks/components/Link/LinkInlineLink.tsx +16 -0
- package/templates/blocks/components/Link/LinkShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Link/LinkShowcase.tsx +12 -0
- package/templates/blocks/components/Link/LinksWithTooltips.doc.mjs +14 -0
- package/templates/blocks/components/Link/LinksWithTooltips.tsx +32 -0
- package/templates/blocks/components/List/ListBasicList.doc.mjs +13 -0
- package/templates/blocks/components/List/ListBasicList.tsx +15 -0
- package/templates/blocks/components/List/ListBulletedFeatures.doc.mjs +13 -0
- package/templates/blocks/components/List/ListBulletedFeatures.tsx +15 -0
- package/templates/blocks/components/List/ListMessageList.doc.mjs +14 -0
- package/templates/blocks/components/List/ListMessageList.tsx +34 -0
- package/templates/blocks/components/List/ListOrderedSteps.doc.mjs +13 -0
- package/templates/blocks/components/List/ListOrderedSteps.tsx +24 -0
- package/templates/blocks/components/List/ListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/List/ListShowcase.tsx +15 -0
- package/templates/blocks/components/ListItem/ListItemBasicItem.doc.mjs +14 -0
- package/templates/blocks/components/ListItem/ListItemBasicItem.tsx +18 -0
- package/templates/blocks/components/ListItem/ListItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/ListItem/ListItemShowcase.tsx +40 -0
- package/templates/blocks/components/ListItem/ListItemWithMedia.doc.mjs +14 -0
- package/templates/blocks/components/ListItem/ListItemWithMedia.tsx +35 -0
- package/templates/blocks/components/ListItem/ListItemWithMetadata.doc.mjs +14 -0
- package/templates/blocks/components/ListItem/ListItemWithMetadata.tsx +37 -0
- package/templates/blocks/components/Markdown/MarkdownCitedContent.doc.mjs +13 -0
- package/templates/blocks/components/Markdown/MarkdownCitedContent.tsx +54 -0
- package/templates/blocks/components/Markdown/MarkdownCompactAIResponse.doc.mjs +13 -0
- package/templates/blocks/components/Markdown/MarkdownCompactAIResponse.tsx +34 -0
- package/templates/blocks/components/Markdown/MarkdownDataTable.doc.mjs +13 -0
- package/templates/blocks/components/Markdown/MarkdownDataTable.tsx +25 -0
- package/templates/blocks/components/Markdown/MarkdownRichContent.doc.mjs +13 -0
- package/templates/blocks/components/Markdown/MarkdownRichContent.tsx +32 -0
- package/templates/blocks/components/Markdown/MarkdownShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Markdown/MarkdownShowcase.tsx +28 -0
- package/templates/blocks/components/MediaTheme/MediaThemeImageOverlay.doc.mjs +21 -0
- package/templates/blocks/components/MediaTheme/MediaThemeImageOverlay.tsx +57 -0
- package/templates/blocks/components/MediaTheme/MediaThemeLightScrim.doc.mjs +21 -0
- package/templates/blocks/components/MediaTheme/MediaThemeLightScrim.tsx +55 -0
- package/templates/blocks/components/MediaTheme/MediaThemeShowcase.doc.mjs +23 -0
- package/templates/blocks/components/MediaTheme/MediaThemeShowcase.tsx +55 -0
- package/templates/blocks/components/MetadataList/MetadataListBasicMetadata.doc.mjs +13 -0
- package/templates/blocks/components/MetadataList/MetadataListBasicMetadata.tsx +15 -0
- package/templates/blocks/components/MetadataList/MetadataListCollapsibleMetadata.doc.mjs +14 -0
- package/templates/blocks/components/MetadataList/MetadataListCollapsibleMetadata.tsx +18 -0
- package/templates/blocks/components/MetadataList/MetadataListHorizontalMetadata.doc.mjs +14 -0
- package/templates/blocks/components/MetadataList/MetadataListHorizontalMetadata.tsx +16 -0
- package/templates/blocks/components/MetadataList/MetadataListMultiColumnMetadata.doc.mjs +14 -0
- package/templates/blocks/components/MetadataList/MetadataListMultiColumnMetadata.tsx +25 -0
- package/templates/blocks/components/MetadataList/MetadataListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/MetadataList/MetadataListShowcase.tsx +15 -0
- package/templates/blocks/components/MetadataListItem/MetadataListItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/MetadataListItem/MetadataListItemShowcase.tsx +28 -0
- package/templates/blocks/components/MobileNav/MobileNavBasicMobileNav.doc.mjs +13 -0
- package/templates/blocks/components/MobileNav/MobileNavBasicMobileNav.tsx +58 -0
- package/templates/blocks/components/MobileNav/MobileNavEndSideMobileNav.doc.mjs +13 -0
- package/templates/blocks/components/MobileNav/MobileNavEndSideMobileNav.tsx +32 -0
- package/templates/blocks/components/MobileNav/MobileNavShowcase.doc.mjs +13 -0
- package/templates/blocks/components/MobileNav/MobileNavShowcase.tsx +38 -0
- package/templates/blocks/components/MobileNav/MobileNavWithoutTitleMobileNav.doc.mjs +13 -0
- package/templates/blocks/components/MobileNav/MobileNavWithoutTitleMobileNav.tsx +36 -0
- package/templates/blocks/components/MobileNavToggle/MobileNavToggleShowcase.doc.mjs +14 -0
- package/templates/blocks/components/MobileNavToggle/MobileNavToggleShowcase.tsx +42 -0
- package/templates/blocks/components/MoreMenu/MoreMenuDefaultMoreMenu.doc.mjs +14 -0
- package/templates/blocks/components/MoreMenu/MoreMenuDefaultMoreMenu.tsx +17 -0
- package/templates/blocks/components/MoreMenu/MoreMenuInToolbar.doc.mjs +14 -0
- package/templates/blocks/components/MoreMenu/MoreMenuInToolbar.tsx +67 -0
- package/templates/blocks/components/MoreMenu/MoreMenuShowcase.doc.mjs +15 -0
- package/templates/blocks/components/MoreMenu/MoreMenuShowcase.tsx +23 -0
- package/templates/blocks/components/MoreMenu/MoreMenuWithDividers.doc.mjs +14 -0
- package/templates/blocks/components/MoreMenu/MoreMenuWithDividers.tsx +24 -0
- package/templates/blocks/components/MoreMenu/MoreMenuWithSections.doc.mjs +14 -0
- package/templates/blocks/components/MoreMenu/MoreMenuWithSections.tsx +38 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorColumnVisibilitySelector.doc.mjs +14 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorColumnVisibilitySelector.tsx +40 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorForm.doc.mjs +14 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorForm.tsx +44 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorSearchableMultiSelector.doc.mjs +14 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorSearchableMultiSelector.tsx +36 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorSectionedMultiSelector.doc.mjs +14 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorSectionedMultiSelector.tsx +39 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorShowcase.doc.mjs +13 -0
- package/templates/blocks/components/MultiSelector/MultiSelectorShowcase.tsx +17 -0
- package/templates/blocks/components/NavIcon/NavIconShowcase.doc.mjs +14 -0
- package/templates/blocks/components/NavIcon/NavIconShowcase.tsx +17 -0
- package/templates/blocks/components/NumberInput/NumberInputClearableNumberInput.doc.mjs +13 -0
- package/templates/blocks/components/NumberInput/NumberInputClearableNumberInput.tsx +23 -0
- package/templates/blocks/components/NumberInput/NumberInputRangeNumberInput.doc.mjs +13 -0
- package/templates/blocks/components/NumberInput/NumberInputRangeNumberInput.tsx +23 -0
- package/templates/blocks/components/NumberInput/NumberInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/NumberInput/NumberInputShowcase.tsx +16 -0
- package/templates/blocks/components/NumberInput/NumberInputStatuses.doc.mjs +13 -0
- package/templates/blocks/components/NumberInput/NumberInputStatuses.tsx +38 -0
- package/templates/blocks/components/NumberInput/NumberInputWithUnits.doc.mjs +13 -0
- package/templates/blocks/components/NumberInput/NumberInputWithUnits.tsx +23 -0
- package/templates/blocks/components/Outline/OutlineControlled.doc.mjs +14 -0
- package/templates/blocks/components/Outline/OutlineControlled.tsx +54 -0
- package/templates/blocks/components/Outline/OutlineDeepNesting.doc.mjs +14 -0
- package/templates/blocks/components/Outline/OutlineDeepNesting.tsx +26 -0
- package/templates/blocks/components/Outline/OutlineDensity.doc.mjs +14 -0
- package/templates/blocks/components/Outline/OutlineDensity.tsx +43 -0
- package/templates/blocks/components/OverflowList/OverflowListCollapseFromStartList.doc.mjs +13 -0
- package/templates/blocks/components/OverflowList/OverflowListCollapseFromStartList.tsx +33 -0
- package/templates/blocks/components/OverflowList/OverflowListOverflowBadges.doc.mjs +13 -0
- package/templates/blocks/components/OverflowList/OverflowListOverflowBadges.tsx +35 -0
- package/templates/blocks/components/OverflowList/OverflowListOverflowDropdownActions.doc.mjs +13 -0
- package/templates/blocks/components/OverflowList/OverflowListOverflowDropdownActions.tsx +50 -0
- package/templates/blocks/components/OverflowList/OverflowListShowcase.doc.mjs +15 -0
- package/templates/blocks/components/OverflowList/OverflowListShowcase.tsx +28 -0
- package/templates/blocks/components/Overlay/OverlayBottomStrip.doc.mjs +14 -0
- package/templates/blocks/components/Overlay/OverlayBottomStrip.tsx +51 -0
- package/templates/blocks/components/Overlay/OverlayHoverReveal.doc.mjs +14 -0
- package/templates/blocks/components/Overlay/OverlayHoverReveal.tsx +39 -0
- package/templates/blocks/components/Overlay/OverlayShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Overlay/OverlayShowcase.tsx +50 -0
- package/templates/blocks/components/Pagination/PaginationDotsCarousel.doc.mjs +14 -0
- package/templates/blocks/components/Pagination/PaginationDotsCarousel.tsx +103 -0
- package/templates/blocks/components/Pagination/PaginationPageSize.doc.mjs +14 -0
- package/templates/blocks/components/Pagination/PaginationPageSize.tsx +68 -0
- package/templates/blocks/components/Pagination/PaginationVariants.doc.mjs +15 -0
- package/templates/blocks/components/Pagination/PaginationVariants.tsx +52 -0
- package/templates/blocks/components/Pagination/PaginationWithTable.doc.mjs +14 -0
- package/templates/blocks/components/Pagination/PaginationWithTable.tsx +66 -0
- package/templates/blocks/components/Popover/PopoverConfirmAction.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverConfirmAction.tsx +48 -0
- package/templates/blocks/components/Popover/PopoverFilterPanel.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverFilterPanel.tsx +82 -0
- package/templates/blocks/components/Popover/PopoverHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverHookUsage.tsx +37 -0
- package/templates/blocks/components/Popover/PopoverKeyboardShortcuts.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverKeyboardShortcuts.tsx +39 -0
- package/templates/blocks/components/Popover/PopoverSettingsPanel.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverSettingsPanel.tsx +49 -0
- package/templates/blocks/components/Popover/PopoverShowcase.doc.mjs +14 -0
- package/templates/blocks/components/Popover/PopoverShowcase.tsx +37 -0
- package/templates/blocks/components/PowerSearch/PowerSearchContentSearch.doc.mjs +14 -0
- package/templates/blocks/components/PowerSearch/PowerSearchContentSearch.tsx +74 -0
- package/templates/blocks/components/PowerSearch/PowerSearchFullFeatured.doc.mjs +14 -0
- package/templates/blocks/components/PowerSearch/PowerSearchFullFeatured.tsx +102 -0
- package/templates/blocks/components/PowerSearch/PowerSearchPresetFilters.doc.mjs +14 -0
- package/templates/blocks/components/PowerSearch/PowerSearchPresetFilters.tsx +77 -0
- package/templates/blocks/components/PowerSearch/PowerSearchSearchWithTable.doc.mjs +14 -0
- package/templates/blocks/components/PowerSearch/PowerSearchSearchWithTable.tsx +103 -0
- package/templates/blocks/components/PowerSearch/PowerSearchShowcase.doc.mjs +15 -0
- package/templates/blocks/components/PowerSearch/PowerSearchShowcase.tsx +63 -0
- package/templates/blocks/components/ProgressBar/ProgressBarCustomFormat.doc.mjs +14 -0
- package/templates/blocks/components/ProgressBar/ProgressBarCustomFormat.tsx +28 -0
- package/templates/blocks/components/ProgressBar/ProgressBarIndeterminate.doc.mjs +14 -0
- package/templates/blocks/components/ProgressBar/ProgressBarIndeterminate.tsx +9 -0
- package/templates/blocks/components/ProgressBar/ProgressBarSemanticVariants.doc.mjs +14 -0
- package/templates/blocks/components/ProgressBar/ProgressBarSemanticVariants.tsx +43 -0
- package/templates/blocks/components/ProgressBar/ProgressBarShowcase.doc.mjs +15 -0
- package/templates/blocks/components/ProgressBar/ProgressBarShowcase.tsx +9 -0
- package/templates/blocks/components/ProgressBar/ProgressBarWithValueLabel.doc.mjs +14 -0
- package/templates/blocks/components/ProgressBar/ProgressBarWithValueLabel.tsx +16 -0
- package/templates/blocks/components/RadioList/RadioListHorizontalLayout.doc.mjs +14 -0
- package/templates/blocks/components/RadioList/RadioListHorizontalLayout.tsx +22 -0
- package/templates/blocks/components/RadioList/RadioListPricingTier.doc.mjs +14 -0
- package/templates/blocks/components/RadioList/RadioListPricingTier.tsx +43 -0
- package/templates/blocks/components/RadioList/RadioListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/RadioList/RadioListShowcase.tsx +13 -0
- package/templates/blocks/components/RadioList/RadioListWithDescriptions.doc.mjs +14 -0
- package/templates/blocks/components/RadioList/RadioListWithDescriptions.tsx +34 -0
- package/templates/blocks/components/RadioList/RadioListWithValidation.doc.mjs +14 -0
- package/templates/blocks/components/RadioList/RadioListWithValidation.tsx +27 -0
- package/templates/blocks/components/RadioListItem/RadioListItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/RadioListItem/RadioListItemShowcase.tsx +36 -0
- package/templates/blocks/components/Resizable/ResizableShowcase.doc.mjs +17 -0
- package/templates/blocks/components/Resizable/ResizableShowcase.tsx +57 -0
- package/templates/blocks/components/Section/SectionVariants.doc.mjs +15 -0
- package/templates/blocks/components/Section/SectionVariants.tsx +46 -0
- package/templates/blocks/components/Section/SectionWashHighlight.doc.mjs +14 -0
- package/templates/blocks/components/Section/SectionWashHighlight.tsx +57 -0
- package/templates/blocks/components/Section/SectionWithDividers.doc.mjs +14 -0
- package/templates/blocks/components/Section/SectionWithDividers.tsx +38 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlDisabledItem.doc.mjs +14 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlDisabledItem.tsx +23 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlFillLayout.doc.mjs +14 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlFillLayout.tsx +26 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlIconOnly.doc.mjs +14 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlIconOnly.tsx +53 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlShowcase.doc.mjs +13 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlShowcase.tsx +18 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlWithIcons.doc.mjs +14 -0
- package/templates/blocks/components/SegmentedControl/SegmentedControlWithIcons.tsx +53 -0
- package/templates/blocks/components/SegmentedControlItem/SegmentedControlItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/SegmentedControlItem/SegmentedControlItemShowcase.tsx +43 -0
- package/templates/blocks/components/Selector/SelectorClearable.doc.mjs +14 -0
- package/templates/blocks/components/Selector/SelectorClearable.tsx +26 -0
- package/templates/blocks/components/Selector/SelectorShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Selector/SelectorShowcase.tsx +17 -0
- package/templates/blocks/components/Selector/SelectorWithSections.doc.mjs +14 -0
- package/templates/blocks/components/Selector/SelectorWithSections.tsx +46 -0
- package/templates/blocks/components/Selector/SelectorWithStatus.doc.mjs +14 -0
- package/templates/blocks/components/Selector/SelectorWithStatus.tsx +53 -0
- package/templates/blocks/components/SelectorOption/SelectorOptionShowcase.doc.mjs +15 -0
- package/templates/blocks/components/SelectorOption/SelectorOptionShowcase.tsx +43 -0
- package/templates/blocks/components/SideNav/SideNavEndContent.doc.mjs +14 -0
- package/templates/blocks/components/SideNav/SideNavEndContent.tsx +93 -0
- package/templates/blocks/components/SideNav/SideNavNestedItems.doc.mjs +14 -0
- package/templates/blocks/components/SideNav/SideNavNestedItems.tsx +46 -0
- package/templates/blocks/components/SideNav/SideNavShowcase.doc.mjs +13 -0
- package/templates/blocks/components/SideNav/SideNavShowcase.tsx +76 -0
- package/templates/blocks/components/SideNav/SideNavWithHeaderMenu.doc.mjs +14 -0
- package/templates/blocks/components/SideNav/SideNavWithHeaderMenu.tsx +73 -0
- package/templates/blocks/components/SideNavCollapseButton/SideNavCollapseButtonShowcase.doc.mjs +14 -0
- package/templates/blocks/components/SideNavCollapseButton/SideNavCollapseButtonShowcase.tsx +43 -0
- package/templates/blocks/components/SideNavHeading/SideNavHeadingShowcase.doc.mjs +14 -0
- package/templates/blocks/components/SideNavHeading/SideNavHeadingShowcase.tsx +43 -0
- package/templates/blocks/components/SideNavItem/SideNavItemShowcase.doc.mjs +14 -0
- package/templates/blocks/components/SideNavItem/SideNavItemShowcase.tsx +57 -0
- package/templates/blocks/components/SideNavSection/SideNavSectionShowcase.doc.mjs +14 -0
- package/templates/blocks/components/SideNavSection/SideNavSectionShowcase.tsx +58 -0
- package/templates/blocks/components/Skeleton/SkeletonCardSkeleton.doc.mjs +14 -0
- package/templates/blocks/components/Skeleton/SkeletonCardSkeleton.tsx +26 -0
- package/templates/blocks/components/Skeleton/SkeletonShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Skeleton/SkeletonShowcase.tsx +25 -0
- package/templates/blocks/components/Skeleton/SkeletonStaggeredList.doc.mjs +14 -0
- package/templates/blocks/components/Skeleton/SkeletonStaggeredList.tsx +18 -0
- package/templates/blocks/components/Skeleton/SkeletonTableRowSkeleton.doc.mjs +14 -0
- package/templates/blocks/components/Skeleton/SkeletonTableRowSkeleton.tsx +21 -0
- package/templates/blocks/components/Slider/SliderFormattedValue.doc.mjs +14 -0
- package/templates/blocks/components/Slider/SliderFormattedValue.tsx +23 -0
- package/templates/blocks/components/Slider/SliderRangeSlider.doc.mjs +14 -0
- package/templates/blocks/components/Slider/SliderRangeSlider.tsx +18 -0
- package/templates/blocks/components/Slider/SliderShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Slider/SliderShowcase.tsx +9 -0
- package/templates/blocks/components/Slider/SliderWithMarks.doc.mjs +14 -0
- package/templates/blocks/components/Slider/SliderWithMarks.tsx +25 -0
- package/templates/blocks/components/Slider/SliderWithStatus.doc.mjs +14 -0
- package/templates/blocks/components/Slider/SliderWithStatus.tsx +37 -0
- package/templates/blocks/components/Spinner/SpinnerOnMedia.doc.mjs +14 -0
- package/templates/blocks/components/Spinner/SpinnerOnMedia.tsx +22 -0
- package/templates/blocks/components/Spinner/SpinnerShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Spinner/SpinnerShowcase.tsx +9 -0
- package/templates/blocks/components/Spinner/SpinnerSizes.doc.mjs +13 -0
- package/templates/blocks/components/Spinner/SpinnerSizes.tsx +17 -0
- package/templates/blocks/components/Spinner/SpinnerWithLabel.doc.mjs +14 -0
- package/templates/blocks/components/Spinner/SpinnerWithLabel.tsx +29 -0
- package/templates/blocks/components/Stack/StackAlignment.doc.mjs +14 -0
- package/templates/blocks/components/Stack/StackAlignment.tsx +48 -0
- package/templates/blocks/components/Stack/StackDirections.doc.mjs +15 -0
- package/templates/blocks/components/Stack/StackDirections.tsx +23 -0
- package/templates/blocks/components/Stack/StackFillItem.doc.mjs +14 -0
- package/templates/blocks/components/Stack/StackFillItem.tsx +45 -0
- package/templates/blocks/components/StackItem/StackItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/StackItem/StackItemShowcase.tsx +35 -0
- package/templates/blocks/components/StatusDot/StatusDotPulsing.doc.mjs +14 -0
- package/templates/blocks/components/StatusDot/StatusDotPulsing.tsx +18 -0
- package/templates/blocks/components/StatusDot/StatusDotShowcase.doc.mjs +15 -0
- package/templates/blocks/components/StatusDot/StatusDotShowcase.tsx +18 -0
- package/templates/blocks/components/StatusDot/StatusDotStatusIndicators.doc.mjs +15 -0
- package/templates/blocks/components/StatusDot/StatusDotStatusIndicators.tsx +27 -0
- package/templates/blocks/components/StatusDot/StatusDotVariants.doc.mjs +14 -0
- package/templates/blocks/components/StatusDot/StatusDotVariants.tsx +18 -0
- package/templates/blocks/components/Switch/SwitchDisabled.doc.mjs +13 -0
- package/templates/blocks/components/Switch/SwitchDisabled.tsx +19 -0
- package/templates/blocks/components/Switch/SwitchSettingsPanel.doc.mjs +14 -0
- package/templates/blocks/components/Switch/SwitchSettingsPanel.tsx +42 -0
- package/templates/blocks/components/Switch/SwitchShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Switch/SwitchShowcase.tsx +17 -0
- package/templates/blocks/components/Switch/SwitchWithDescription.doc.mjs +13 -0
- package/templates/blocks/components/Switch/SwitchWithDescription.tsx +18 -0
- package/templates/blocks/components/Switch/SwitchWithStatus.doc.mjs +14 -0
- package/templates/blocks/components/Switch/SwitchWithStatus.tsx +47 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeDarkPreset.doc.mjs +14 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeDarkPreset.tsx +19 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeLightPreset.doc.mjs +14 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeLightPreset.tsx +18 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeShowcase.doc.mjs +15 -0
- package/templates/blocks/components/SyntaxTheme/SyntaxThemeShowcase.tsx +30 -0
- package/templates/blocks/components/Tab/TabShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Tab/TabShowcase.tsx +18 -0
- package/templates/blocks/components/TabList/TabListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/TabList/TabListShowcase.tsx +15 -0
- package/templates/blocks/components/TabList/TabListTabsFillLayout.doc.mjs +14 -0
- package/templates/blocks/components/TabList/TabListTabsFillLayout.tsx +19 -0
- package/templates/blocks/components/TabList/TabListTabsWithActions.doc.mjs +14 -0
- package/templates/blocks/components/TabList/TabListTabsWithActions.tsx +71 -0
- package/templates/blocks/components/TabList/TabListTabsWithBadge.doc.mjs +14 -0
- package/templates/blocks/components/TabList/TabListTabsWithBadge.tsx +26 -0
- package/templates/blocks/components/TabList/TabListTabsWithIcons.doc.mjs +13 -0
- package/templates/blocks/components/TabList/TabListTabsWithIcons.tsx +32 -0
- package/templates/blocks/components/TabList/TabListTabsWithMenu.doc.mjs +14 -0
- package/templates/blocks/components/TabList/TabListTabsWithMenu.tsx +24 -0
- package/templates/blocks/components/TabList/TabListTabsWithStatusDot.doc.mjs +14 -0
- package/templates/blocks/components/TabList/TabListTabsWithStatusDot.tsx +26 -0
- package/templates/blocks/components/TabMenu/TabMenuShowcase.doc.mjs +15 -0
- package/templates/blocks/components/TabMenu/TabMenuShowcase.tsx +22 -0
- package/templates/blocks/components/Table/TableColumnSettingsTable.doc.mjs +16 -0
- package/templates/blocks/components/Table/TableColumnSettingsTable.tsx +129 -0
- package/templates/blocks/components/Table/TableFilterableTable.doc.mjs +16 -0
- package/templates/blocks/components/Table/TableFilterableTable.tsx +108 -0
- package/templates/blocks/components/Table/TableGridDividersTable.doc.mjs +14 -0
- package/templates/blocks/components/Table/TableGridDividersTable.tsx +57 -0
- package/templates/blocks/components/Table/TableInCard.doc.mjs +14 -0
- package/templates/blocks/components/Table/TableInCard.tsx +45 -0
- package/templates/blocks/components/Table/TableInlineFilterTable.doc.mjs +15 -0
- package/templates/blocks/components/Table/TableInlineFilterTable.tsx +109 -0
- package/templates/blocks/components/Table/TablePaginatedTable.doc.mjs +16 -0
- package/templates/blocks/components/Table/TablePaginatedTable.tsx +81 -0
- package/templates/blocks/components/Table/TableResizableTable.doc.mjs +14 -0
- package/templates/blocks/components/Table/TableResizableTable.tsx +59 -0
- package/templates/blocks/components/Table/TableRichCellTable.doc.mjs +14 -0
- package/templates/blocks/components/Table/TableRichCellTable.tsx +87 -0
- package/templates/blocks/components/Table/TableSelectableTable.doc.mjs +16 -0
- package/templates/blocks/components/Table/TableSelectableTable.tsx +54 -0
- package/templates/blocks/components/Table/TableShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Table/TableShowcase.tsx +54 -0
- package/templates/blocks/components/Table/TableSortableTable.doc.mjs +16 -0
- package/templates/blocks/components/Table/TableSortableTable.tsx +71 -0
- package/templates/blocks/components/Table/TableStripedTable.doc.mjs +14 -0
- package/templates/blocks/components/Table/TableStripedTable.tsx +63 -0
- package/templates/blocks/components/Text/TextColors.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextColors.tsx +26 -0
- package/templates/blocks/components/Text/TextHeadingLevels.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextHeadingLevels.tsx +20 -0
- package/templates/blocks/components/Text/TextInline.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextInline.tsx +14 -0
- package/templates/blocks/components/Text/TextShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextShowcase.tsx +18 -0
- package/templates/blocks/components/Text/TextTruncation.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextTruncation.tsx +39 -0
- package/templates/blocks/components/Text/TextTypes.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextTypes.tsx +37 -0
- package/templates/blocks/components/Text/TextWeight.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextWeight.tsx +25 -0
- package/templates/blocks/components/Text/TextWordBreak.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextWordBreak.tsx +38 -0
- package/templates/blocks/components/Text/TextWrap.doc.mjs +13 -0
- package/templates/blocks/components/Text/TextWrap.tsx +66 -0
- package/templates/blocks/components/TextArea/TextAreaCharacterCount.doc.mjs +13 -0
- package/templates/blocks/components/TextArea/TextAreaCharacterCount.tsx +25 -0
- package/templates/blocks/components/TextArea/TextAreaShowcase.doc.mjs +15 -0
- package/templates/blocks/components/TextArea/TextAreaShowcase.tsx +18 -0
- package/templates/blocks/components/TextArea/TextAreaStates.doc.mjs +13 -0
- package/templates/blocks/components/TextArea/TextAreaStates.tsx +36 -0
- package/templates/blocks/components/TextArea/TextAreaValidation.doc.mjs +13 -0
- package/templates/blocks/components/TextArea/TextAreaValidation.tsx +54 -0
- package/templates/blocks/components/TextArea/TextAreaWithIcon.doc.mjs +13 -0
- package/templates/blocks/components/TextArea/TextAreaWithIcon.tsx +24 -0
- package/templates/blocks/components/TextInput/TextInputIcon.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputIcon.tsx +48 -0
- package/templates/blocks/components/TextInput/TextInputSearch.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputSearch.tsx +36 -0
- package/templates/blocks/components/TextInput/TextInputShowcase.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputShowcase.tsx +18 -0
- package/templates/blocks/components/TextInput/TextInputSizes.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputSizes.tsx +41 -0
- package/templates/blocks/components/TextInput/TextInputStates.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputStates.tsx +68 -0
- package/templates/blocks/components/TextInput/TextInputTypes.doc.mjs +13 -0
- package/templates/blocks/components/TextInput/TextInputTypes.tsx +65 -0
- package/templates/blocks/components/Theme/ThemeApply.doc.mjs +14 -0
- package/templates/blocks/components/Theme/ThemeApply.tsx +39 -0
- package/templates/blocks/components/Theme/ThemeNested.doc.mjs +14 -0
- package/templates/blocks/components/Theme/ThemeNested.tsx +64 -0
- package/templates/blocks/components/Theme/ThemeShowcase.doc.mjs +24 -0
- package/templates/blocks/components/Theme/ThemeShowcase.tsx +75 -0
- package/templates/blocks/components/Theme/ThemeSwitcher.doc.mjs +22 -0
- package/templates/blocks/components/Theme/ThemeSwitcher.tsx +73 -0
- package/templates/blocks/components/Theme/useThemeHookUsage.doc.mjs +14 -0
- package/templates/blocks/components/Theme/useThemeHookUsage.tsx +47 -0
- package/templates/blocks/components/Thumbnail/ThumbnailDisabled.doc.mjs +13 -0
- package/templates/blocks/components/Thumbnail/ThumbnailDisabled.tsx +43 -0
- package/templates/blocks/components/Thumbnail/ThumbnailGallery.doc.mjs +13 -0
- package/templates/blocks/components/Thumbnail/ThumbnailGallery.tsx +47 -0
- package/templates/blocks/components/Thumbnail/ThumbnailRemovable.doc.mjs +13 -0
- package/templates/blocks/components/Thumbnail/ThumbnailRemovable.tsx +44 -0
- package/templates/blocks/components/Thumbnail/ThumbnailShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Thumbnail/ThumbnailShowcase.tsx +15 -0
- package/templates/blocks/components/Thumbnail/ThumbnailStates.doc.mjs +13 -0
- package/templates/blocks/components/Thumbnail/ThumbnailStates.tsx +54 -0
- package/templates/blocks/components/TimeInput/TimeInputConstrained.doc.mjs +13 -0
- package/templates/blocks/components/TimeInput/TimeInputConstrained.tsx +26 -0
- package/templates/blocks/components/TimeInput/TimeInputFormats.doc.mjs +13 -0
- package/templates/blocks/components/TimeInput/TimeInputFormats.tsx +35 -0
- package/templates/blocks/components/TimeInput/TimeInputIncrement.doc.mjs +13 -0
- package/templates/blocks/components/TimeInput/TimeInputIncrement.tsx +24 -0
- package/templates/blocks/components/TimeInput/TimeInputShowcase.doc.mjs +15 -0
- package/templates/blocks/components/TimeInput/TimeInputShowcase.tsx +18 -0
- package/templates/blocks/components/TimeInput/TimeInputStates.doc.mjs +13 -0
- package/templates/blocks/components/TimeInput/TimeInputStates.tsx +43 -0
- package/templates/blocks/components/Timestamp/TimestampAutoFormat.doc.mjs +13 -0
- package/templates/blocks/components/Timestamp/TimestampAutoFormat.tsx +34 -0
- package/templates/blocks/components/Timestamp/TimestampColors.doc.mjs +14 -0
- package/templates/blocks/components/Timestamp/TimestampColors.tsx +40 -0
- package/templates/blocks/components/Timestamp/TimestampFormats.doc.mjs +13 -0
- package/templates/blocks/components/Timestamp/TimestampFormats.tsx +36 -0
- package/templates/blocks/components/Timestamp/TimestampRelativeFormat.doc.mjs +13 -0
- package/templates/blocks/components/Timestamp/TimestampRelativeFormat.tsx +26 -0
- package/templates/blocks/components/Timestamp/TimestampShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Timestamp/TimestampShowcase.tsx +9 -0
- package/templates/blocks/components/Timestamp/TimestampTimezone.doc.mjs +13 -0
- package/templates/blocks/components/Timestamp/TimestampTimezone.tsx +34 -0
- package/templates/blocks/components/Toast/ToastAction.doc.mjs +13 -0
- package/templates/blocks/components/Toast/ToastAction.tsx +48 -0
- package/templates/blocks/components/Toast/ToastDeduplication.doc.mjs +13 -0
- package/templates/blocks/components/Toast/ToastDeduplication.tsx +54 -0
- package/templates/blocks/components/Toast/ToastDismiss.doc.mjs +13 -0
- package/templates/blocks/components/Toast/ToastDismiss.tsx +50 -0
- package/templates/blocks/components/Toast/ToastShowcase.doc.mjs +17 -0
- package/templates/blocks/components/Toast/ToastShowcase.tsx +30 -0
- package/templates/blocks/components/Toast/ToastStacking.doc.mjs +13 -0
- package/templates/blocks/components/Toast/ToastStacking.tsx +47 -0
- package/templates/blocks/components/Toast/ToastTypes.doc.mjs +13 -0
- package/templates/blocks/components/Toast/ToastTypes.tsx +54 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonColor.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonColor.tsx +140 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonGroup.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonGroup.tsx +81 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonIconSwap.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonIconSwap.tsx +51 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonLabel.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonLabel.tsx +58 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonShowcase.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonShowcase.tsx +45 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonStates.doc.mjs +13 -0
- package/templates/blocks/components/ToggleButton/ToggleButtonStates.tsx +105 -0
- package/templates/blocks/components/ToggleButtonGroup/ToggleButtonGroupShowcase.doc.mjs +15 -0
- package/templates/blocks/components/ToggleButtonGroup/ToggleButtonGroupShowcase.tsx +45 -0
- package/templates/blocks/components/Token/TokenClickable.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenClickable.tsx +23 -0
- package/templates/blocks/components/Token/TokenColors.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenColors.tsx +52 -0
- package/templates/blocks/components/Token/TokenEndContent.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenEndContent.tsx +35 -0
- package/templates/blocks/components/Token/TokenIcon.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenIcon.tsx +46 -0
- package/templates/blocks/components/Token/TokenRemovable.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenRemovable.tsx +34 -0
- package/templates/blocks/components/Token/TokenShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Token/TokenShowcase.tsx +22 -0
- package/templates/blocks/components/Tokenizer/TokenizerClear.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerClear.tsx +49 -0
- package/templates/blocks/components/Tokenizer/TokenizerCreatable.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerCreatable.tsx +72 -0
- package/templates/blocks/components/Tokenizer/TokenizerEndContent.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerEndContent.tsx +51 -0
- package/templates/blocks/components/Tokenizer/TokenizerIcon.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerIcon.tsx +50 -0
- package/templates/blocks/components/Tokenizer/TokenizerMaxEntries.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerMaxEntries.tsx +59 -0
- package/templates/blocks/components/Tokenizer/TokenizerOverflow.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerOverflow.tsx +67 -0
- package/templates/blocks/components/Tokenizer/TokenizerShowcase.doc.mjs +15 -0
- package/templates/blocks/components/Tokenizer/TokenizerShowcase.tsx +32 -0
- package/templates/blocks/components/Tokenizer/TokenizerStates.doc.mjs +13 -0
- package/templates/blocks/components/Tokenizer/TokenizerStates.tsx +82 -0
- package/templates/blocks/components/Toolbar/ToolbarBulkActions.doc.mjs +14 -0
- package/templates/blocks/components/Toolbar/ToolbarBulkActions.tsx +83 -0
- package/templates/blocks/components/Toolbar/ToolbarCardHeader.doc.mjs +14 -0
- package/templates/blocks/components/Toolbar/ToolbarCardHeader.tsx +49 -0
- package/templates/blocks/components/Toolbar/ToolbarSizes.doc.mjs +14 -0
- package/templates/blocks/components/Toolbar/ToolbarSizes.tsx +51 -0
- package/templates/blocks/components/Toolbar/ToolbarTableFilter.doc.mjs +14 -0
- package/templates/blocks/components/Toolbar/ToolbarTableFilter.tsx +83 -0
- package/templates/blocks/components/Toolbar/ToolbarThreeSlot.doc.mjs +15 -0
- package/templates/blocks/components/Toolbar/ToolbarThreeSlot.tsx +47 -0
- package/templates/blocks/components/Toolbar/ToolbarWithTabs.doc.mjs +14 -0
- package/templates/blocks/components/Toolbar/ToolbarWithTabs.tsx +49 -0
- package/templates/blocks/components/Tooltip/TooltipActionBarTooltips.doc.mjs +14 -0
- package/templates/blocks/components/Tooltip/TooltipActionBarTooltips.tsx +26 -0
- package/templates/blocks/components/Tooltip/TooltipHookUsage.doc.mjs +16 -0
- package/templates/blocks/components/Tooltip/TooltipHookUsage.tsx +25 -0
- package/templates/blocks/components/Tooltip/TooltipInlineTextTooltips.doc.mjs +14 -0
- package/templates/blocks/components/Tooltip/TooltipInlineTextTooltips.tsx +21 -0
- package/templates/blocks/components/Tooltip/TooltipShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Tooltip/TooltipShowcase.tsx +14 -0
- package/templates/blocks/components/TopNav/TopNavCenteredNavigation.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavCenteredNavigation.tsx +47 -0
- package/templates/blocks/components/TopNav/TopNavEnterpriseDashboard.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavEnterpriseDashboard.tsx +61 -0
- package/templates/blocks/components/TopNav/TopNavHoverMenu.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavHoverMenu.tsx +79 -0
- package/templates/blocks/components/TopNav/TopNavMegaMenu.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavMegaMenu.tsx +97 -0
- package/templates/blocks/components/TopNav/TopNavMultipleDropdowns.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavMultipleDropdowns.tsx +62 -0
- package/templates/blocks/components/TopNav/TopNavShowcase.doc.mjs +13 -0
- package/templates/blocks/components/TopNav/TopNavShowcase.tsx +53 -0
- package/templates/blocks/components/TopNav/TopNavWithLogo.doc.mjs +14 -0
- package/templates/blocks/components/TopNav/TopNavWithLogo.tsx +39 -0
- package/templates/blocks/components/TopNavHeading/TopNavHeadingShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavHeading/TopNavHeadingShowcase.tsx +51 -0
- package/templates/blocks/components/TopNavItem/TopNavItemShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavItem/TopNavItemShowcase.tsx +48 -0
- package/templates/blocks/components/TopNavMegaMenu/TopNavMegaMenuShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavMegaMenu/TopNavMegaMenuShowcase.tsx +74 -0
- package/templates/blocks/components/TopNavMegaMenuFeaturedCard/TopNavMegaMenuFeaturedCardShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavMegaMenuFeaturedCard/TopNavMegaMenuFeaturedCardShowcase.tsx +16 -0
- package/templates/blocks/components/TopNavMegaMenuItem/TopNavMegaMenuItemShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavMegaMenuItem/TopNavMegaMenuItemShowcase.tsx +69 -0
- package/templates/blocks/components/TopNavMenu/TopNavMenuShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TopNavMenu/TopNavMenuShowcase.tsx +63 -0
- package/templates/blocks/components/TreeList/TreeListFileTreeWithIcons.doc.mjs +14 -0
- package/templates/blocks/components/TreeList/TreeListFileTreeWithIcons.tsx +42 -0
- package/templates/blocks/components/TreeList/TreeListInteractiveSettings.doc.mjs +14 -0
- package/templates/blocks/components/TreeList/TreeListInteractiveSettings.tsx +40 -0
- package/templates/blocks/components/TreeList/TreeListMailboxTree.doc.mjs +14 -0
- package/templates/blocks/components/TreeList/TreeListMailboxTree.tsx +39 -0
- package/templates/blocks/components/TreeList/TreeListNavigationTree.doc.mjs +14 -0
- package/templates/blocks/components/TreeList/TreeListNavigationTree.tsx +26 -0
- package/templates/blocks/components/TreeList/TreeListShowcase.doc.mjs +13 -0
- package/templates/blocks/components/TreeList/TreeListShowcase.tsx +44 -0
- package/templates/blocks/components/TreeListBranches/TreeListBranchesShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TreeListBranches/TreeListBranchesShowcase.tsx +64 -0
- package/templates/blocks/components/TreeListItem/TreeListItemShowcase.doc.mjs +14 -0
- package/templates/blocks/components/TreeListItem/TreeListItemShowcase.tsx +60 -0
- package/templates/blocks/components/Typeahead/TypeaheadLimitedResults.doc.mjs +14 -0
- package/templates/blocks/components/Typeahead/TypeaheadLimitedResults.tsx +42 -0
- package/templates/blocks/components/Typeahead/TypeaheadSearchField.doc.mjs +14 -0
- package/templates/blocks/components/Typeahead/TypeaheadSearchField.tsx +43 -0
- package/templates/blocks/components/Typeahead/TypeaheadShowcase.doc.mjs +13 -0
- package/templates/blocks/components/Typeahead/TypeaheadShowcase.tsx +35 -0
- package/templates/blocks/components/Typeahead/TypeaheadWithHelperText.doc.mjs +14 -0
- package/templates/blocks/components/Typeahead/TypeaheadWithHelperText.tsx +41 -0
- package/templates/blocks/components/Typeahead/TypeaheadWithValidation.doc.mjs +14 -0
- package/templates/blocks/components/Typeahead/TypeaheadWithValidation.tsx +41 -0
- package/templates/blocks/components/TypeaheadItem/TypeaheadItemShowcase.doc.mjs +15 -0
- package/templates/blocks/components/TypeaheadItem/TypeaheadItemShowcase.tsx +50 -0
- package/templates/blocks/components/VStack/VStackShowcase.doc.mjs +14 -0
- package/templates/blocks/components/VStack/VStackShowcase.tsx +38 -0
- package/templates/pages/ai-chat/page.tsx +751 -0
- package/templates/pages/ai-chat/template.doc.mjs +11 -0
- package/templates/pages/ai-chat-landing/page.tsx +482 -0
- package/templates/pages/ai-chat-landing/template.doc.mjs +11 -0
- package/templates/pages/blank/page.tsx +18 -0
- package/templates/pages/blank/template.doc.mjs +12 -0
- package/templates/pages/centered-hero/page.tsx +84 -0
- package/templates/pages/centered-hero/template.doc.mjs +12 -0
- package/templates/pages/classic-gallery/page.tsx +168 -0
- package/templates/pages/classic-gallery/template.doc.mjs +12 -0
- package/templates/pages/contact-form/page.tsx +298 -0
- package/templates/pages/contact-form/template.doc.mjs +12 -0
- package/templates/pages/dashboard/page.tsx +808 -0
- package/templates/pages/dashboard/template.doc.mjs +12 -0
- package/templates/pages/dashboard-portfolio/page.tsx +775 -0
- package/templates/pages/dashboard-portfolio/template.doc.mjs +12 -0
- package/templates/pages/detail-page/page.tsx +638 -0
- package/templates/pages/detail-page/template.doc.mjs +11 -0
- package/templates/pages/documentation/page.tsx +291 -0
- package/templates/pages/documentation/template.doc.mjs +11 -0
- package/templates/pages/documentation-design/page.tsx +735 -0
- package/templates/pages/documentation-design/template.doc.mjs +11 -0
- package/templates/pages/documentation-technical/page.tsx +215 -0
- package/templates/pages/documentation-technical/template.doc.mjs +11 -0
- package/templates/pages/editor/page.tsx +982 -0
- package/templates/pages/editor/template.doc.mjs +11 -0
- package/templates/pages/file-explorer/page.tsx +537 -0
- package/templates/pages/file-explorer/template.doc.mjs +11 -0
- package/templates/pages/form-two-column/page.tsx +261 -0
- package/templates/pages/form-two-column/template.doc.mjs +11 -0
- package/templates/pages/gallery-hero/page.tsx +105 -0
- package/templates/pages/gallery-hero/template.doc.mjs +12 -0
- package/templates/pages/ide/page.tsx +544 -0
- package/templates/pages/ide/template.doc.mjs +12 -0
- package/templates/pages/library/page.tsx +521 -0
- package/templates/pages/library/template.doc.mjs +11 -0
- package/templates/pages/login/page.tsx +104 -0
- package/templates/pages/login/template.doc.mjs +12 -0
- package/templates/pages/login-card/page.tsx +218 -0
- package/templates/pages/login-card/template.doc.mjs +11 -0
- package/templates/pages/login-split/page.tsx +273 -0
- package/templates/pages/login-split/template.doc.mjs +11 -0
- package/templates/pages/login-sso/page.tsx +289 -0
- package/templates/pages/login-sso/template.doc.mjs +11 -0
- package/templates/pages/mixed-gallery/page.tsx +153 -0
- package/templates/pages/mixed-gallery/template.doc.mjs +11 -0
- package/templates/pages/payment-form/page.tsx +989 -0
- package/templates/pages/payment-form/template.doc.mjs +11 -0
- package/templates/pages/product-detail/page.tsx +312 -0
- package/templates/pages/product-detail/template.doc.mjs +11 -0
- package/templates/pages/product-gallery/page.tsx +165 -0
- package/templates/pages/product-gallery/template.doc.mjs +12 -0
- package/templates/pages/settings/page.tsx +230 -0
- package/templates/pages/settings/template.doc.mjs +11 -0
- package/templates/pages/settings-dialog/page.tsx +846 -0
- package/templates/pages/settings-dialog/template.doc.mjs +13 -0
- package/templates/pages/settings-sidebar/page.tsx +863 -0
- package/templates/pages/settings-sidebar/template.doc.mjs +12 -0
- package/templates/pages/side-gallery/page.tsx +153 -0
- package/templates/pages/side-gallery/template.doc.mjs +11 -0
- package/templates/pages/table/page.tsx +85 -0
- package/templates/pages/table/template.doc.mjs +12 -0
- package/templates/pages/table-grouped/page.tsx +1220 -0
- package/templates/pages/table-grouped/template.doc.mjs +12 -0
- package/templates/pages/table-page/page.tsx +441 -0
- package/templates/pages/table-page/template.doc.mjs +12 -0
- package/templates/pages/table-page-chart/page.tsx +587 -0
- package/templates/pages/table-page-chart/template.doc.mjs +13 -0
- package/templates/pages/table-page-heatmap-status/page.tsx +475 -0
- package/templates/pages/table-page-heatmap-status/template.doc.mjs +13 -0
- package/templates/pages/table-page-shoe-store-heatmap/page.tsx +945 -0
- package/templates/pages/table-page-shoe-store-heatmap/template.doc.mjs +13 -0
- package/templates/pages/theme-showcase/page.tsx +1288 -0
- package/templates/pages/theme-showcase/template.doc.mjs +16 -0
|
@@ -0,0 +1,874 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file theme build command — Compile a defineTheme file to CSS
|
|
5
|
+
*
|
|
6
|
+
* Takes a theme file that uses defineTheme() and outputs:
|
|
7
|
+
* - A CSS file with token overrides and component styles
|
|
8
|
+
* - An updated JS module that references the built className
|
|
9
|
+
*
|
|
10
|
+
* Usage:
|
|
11
|
+
* npx astryx theme build ./src/themes/ocean.ts
|
|
12
|
+
* npx astryx theme build ./src/themes/ocean.ts --out ./dist/ocean.css
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
import * as fs from 'node:fs';
|
|
16
|
+
import * as path from 'node:path';
|
|
17
|
+
import {pathToFileURL, fileURLToPath} from 'node:url';
|
|
18
|
+
import {createJiti} from 'jiti';
|
|
19
|
+
import {getRunPrefix} from '../utils/package-manager.mjs';
|
|
20
|
+
import {sanitizeName, PathSafetyError} from '../utils/path-safety.mjs';
|
|
21
|
+
import {jsonOut, humanLog} from '../lib/json.mjs';
|
|
22
|
+
import {cliError} from '../lib/cli-error.mjs';
|
|
23
|
+
import {ERROR_CODES} from '../lib/error-codes.mjs';
|
|
24
|
+
|
|
25
|
+
// Import shared theme processing from core. `astryx theme build` MUST produce the
|
|
26
|
+
// exact same CSS as the `<Theme>` runtime, so it has exactly one generation
|
|
27
|
+
// path: core's generator. There is no in-CLI fallback implementation — if this
|
|
28
|
+
// import fails, the build fails (see the ERR_CORE_NOT_FOUND guard in the theme
|
|
29
|
+
// action). A built, resolvable `@astryxdesign/core` is a hard requirement.
|
|
30
|
+
let _defineTheme = null;
|
|
31
|
+
let _generateThemeRulesSplit = null;
|
|
32
|
+
let _generateOnMediaCSS = null;
|
|
33
|
+
let _coreImportError = null;
|
|
34
|
+
try {
|
|
35
|
+
const coreTheme = await import('@astryxdesign/core/theme');
|
|
36
|
+
_defineTheme = coreTheme.defineTheme;
|
|
37
|
+
_generateThemeRulesSplit = coreTheme.generateThemeRulesSplit;
|
|
38
|
+
_generateOnMediaCSS = coreTheme.generateOnMediaCSS;
|
|
39
|
+
} catch (e) {
|
|
40
|
+
// Capture the reason so the theme action can surface a precise, actionable
|
|
41
|
+
// error. We don't throw here: this module is imported eagerly by the CLI
|
|
42
|
+
// entrypoint for every command, and a throw at load time would break
|
|
43
|
+
// unrelated commands (the entry wraps loads in try/catch and degrades the
|
|
44
|
+
// command to a stub). The hard failure happens when `theme build` runs.
|
|
45
|
+
_coreImportError = e;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Build a @generated attribution header for generated files.
|
|
50
|
+
* @param {string} sourceFile - Relative path to the source theme file
|
|
51
|
+
* @param {'css'|'js'|'ts'} lang - File language (determines comment syntax)
|
|
52
|
+
* @param {string} [command] - The full CLI command used to generate this file
|
|
53
|
+
*/
|
|
54
|
+
function generatedHeader(sourceFile, lang = 'js', command) {
|
|
55
|
+
const timestamp = new Date().toISOString();
|
|
56
|
+
const body = [
|
|
57
|
+
`@generated by \`astryx theme build\` — do not edit manually.`,
|
|
58
|
+
`Source: ${sourceFile}`,
|
|
59
|
+
];
|
|
60
|
+
if (command) {
|
|
61
|
+
body.push(`Command: ${command}`);
|
|
62
|
+
}
|
|
63
|
+
body.push(`Generated: ${timestamp}`);
|
|
64
|
+
if (lang === 'css') {
|
|
65
|
+
return `/*\n * ${body.join('\n * ')}\n */\n\n`;
|
|
66
|
+
}
|
|
67
|
+
return `/**\n * ${body.join('\n * ')}\n */\n\n`;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Convert a theme name to a valid JS identifier.
|
|
72
|
+
* e.g. 'default-minimal' → 'defaultMinimal', 'ocean' → 'ocean'
|
|
73
|
+
*/
|
|
74
|
+
function toIdentifier(name) {
|
|
75
|
+
return name.replace(/-([a-z])/g, (_, c) => c.toUpperCase());
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Convert a kebab-case component name to PascalCase.
|
|
80
|
+
* e.g. 'button' → 'Button', 'progress-bar' → 'ProgressBar', 'avatar-status-dot' → 'AvatarStatusDot'
|
|
81
|
+
*/
|
|
82
|
+
function toPascalCase(name) {
|
|
83
|
+
return name
|
|
84
|
+
.split('-')
|
|
85
|
+
.map(part => part.charAt(0).toUpperCase() + part.slice(1))
|
|
86
|
+
.join('');
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Load known built-in values for a component's visual props from its .doc.mjs file.
|
|
91
|
+
* Parses the type string (e.g. "'info' | 'warning' | 'error' | 'success'") to extract values.
|
|
92
|
+
* Returns a map of { propName: string[] } for props that are visual (listed in theming targets).
|
|
93
|
+
*/
|
|
94
|
+
async function loadKnownValues(componentName) {
|
|
95
|
+
// Resolve core src relative to the CLI package, not cwd (which may be a theme package)
|
|
96
|
+
const cliDir = path.dirname(fileURLToPath(import.meta.url));
|
|
97
|
+
const coreSrc = path.resolve(cliDir, '../../../core/src');
|
|
98
|
+
if (!fs.existsSync(coreSrc)) return {};
|
|
99
|
+
// Map component name to directory (e.g. 'banner' → 'Banner', 'dropdownmenu' → 'DropdownMenu')
|
|
100
|
+
const dirs = fs.readdirSync(coreSrc, { withFileTypes: true })
|
|
101
|
+
.filter(d => d.isDirectory())
|
|
102
|
+
.map(d => d.name);
|
|
103
|
+
const dir = dirs.find(d => d.toLowerCase() === componentName.toLowerCase()
|
|
104
|
+
|| d.toLowerCase().replace(/[^a-z]/g, '') === componentName.toLowerCase());
|
|
105
|
+
if (!dir) return {};
|
|
106
|
+
|
|
107
|
+
const docPath = path.join(coreSrc, dir, `${dir}.doc.mjs`);
|
|
108
|
+
if (!fs.existsSync(docPath)) return {};
|
|
109
|
+
|
|
110
|
+
try {
|
|
111
|
+
const docModule = await import(pathToFileURL(docPath).href);
|
|
112
|
+
const doc = docModule.docs;
|
|
113
|
+
if (!doc?.theming?.targets) return {};
|
|
114
|
+
|
|
115
|
+
// Collect all props — from doc.props or doc.components[].props
|
|
116
|
+
const allProps = [];
|
|
117
|
+
if (doc.props) allProps.push(...doc.props);
|
|
118
|
+
if (doc.components) {
|
|
119
|
+
for (const comp of doc.components) {
|
|
120
|
+
if (comp.props) allProps.push(...comp.props);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (allProps.length === 0) return {};
|
|
124
|
+
|
|
125
|
+
// Collect visual prop names from theming targets
|
|
126
|
+
const visualProps = new Set();
|
|
127
|
+
for (const target of doc.theming.targets) {
|
|
128
|
+
if (target.visualProps) {
|
|
129
|
+
for (const vp of target.visualProps) visualProps.add(vp);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// Extract values from prop type strings
|
|
134
|
+
const result = {};
|
|
135
|
+
for (const prop of allProps) {
|
|
136
|
+
if (!visualProps.has(prop.name)) continue;
|
|
137
|
+
if (!prop.type || typeof prop.type !== 'string') continue;
|
|
138
|
+
|
|
139
|
+
// Parse union type: "'info' | 'warning' | 'error' | 'success'" → ['info', 'warning', 'error', 'success']
|
|
140
|
+
const matches = prop.type.match(/'([^']+)'/g);
|
|
141
|
+
if (matches) {
|
|
142
|
+
result[prop.name] = matches.map(m => m.replace(/'/g, ''));
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
return result;
|
|
146
|
+
} catch {
|
|
147
|
+
return {};
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// Cache for loaded known values
|
|
152
|
+
const _knownValuesCache = new Map();
|
|
153
|
+
async function getKnownValues(componentName) {
|
|
154
|
+
if (!_knownValuesCache.has(componentName)) {
|
|
155
|
+
_knownValuesCache.set(componentName, await loadKnownValues(componentName));
|
|
156
|
+
}
|
|
157
|
+
return _knownValuesCache.get(componentName);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
/**
|
|
161
|
+
* Generate TypeScript declaration content with module augmentation for custom
|
|
162
|
+
* component prop values found in the theme's `components` keys. Reads known
|
|
163
|
+
* values from doc files to filter out base prop values.
|
|
164
|
+
*
|
|
165
|
+
* Interface naming convention: Astryx + PascalCase(component) + PascalCase(prop) + Map
|
|
166
|
+
* banner + status → XDSBannerStatusMap
|
|
167
|
+
* button + variant → XDSButtonVariantMap
|
|
168
|
+
*
|
|
169
|
+
* @param {object} themeDef - Theme definition (resolved by defineTheme)
|
|
170
|
+
* @returns {Promise<string|null>} TypeScript declaration content, or null if no augmentations needed
|
|
171
|
+
*/
|
|
172
|
+
async function generateVariantDeclarationsAsync(themeDef) {
|
|
173
|
+
if (!themeDef.components || Object.keys(themeDef.components).length === 0) {
|
|
174
|
+
return null;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// Collect custom values: { component: { prop: [value, ...] } }
|
|
178
|
+
const customValues = {};
|
|
179
|
+
|
|
180
|
+
for (const [component, rules] of Object.entries(themeDef.components)) {
|
|
181
|
+
const knownForComponent = await getKnownValues(component);
|
|
182
|
+
|
|
183
|
+
for (const key of Object.keys(rules)) {
|
|
184
|
+
if (key === 'base') continue;
|
|
185
|
+
|
|
186
|
+
const pairs = key.split('+');
|
|
187
|
+
for (const pair of pairs) {
|
|
188
|
+
const colonIdx = pair.indexOf(':');
|
|
189
|
+
if (colonIdx === -1) continue;
|
|
190
|
+
const prop = pair.slice(0, colonIdx);
|
|
191
|
+
const value = pair.slice(colonIdx + 1);
|
|
192
|
+
|
|
193
|
+
// Skip known built-in values
|
|
194
|
+
const knownForProp = knownForComponent[prop];
|
|
195
|
+
if (knownForProp && knownForProp.includes(value)) continue;
|
|
196
|
+
|
|
197
|
+
if (!customValues[component]) customValues[component] = {};
|
|
198
|
+
if (!customValues[component][prop]) customValues[component][prop] = new Set();
|
|
199
|
+
customValues[component][prop].add(value);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
// Check if we found any custom values
|
|
205
|
+
const hasCustom = Object.values(customValues).some(
|
|
206
|
+
props => Object.values(props).some(values => values.size > 0)
|
|
207
|
+
);
|
|
208
|
+
if (!hasCustom) return null;
|
|
209
|
+
|
|
210
|
+
const sections = ['// Generated by astryx theme build', 'export {};', ''];
|
|
211
|
+
|
|
212
|
+
for (const [component, props] of Object.entries(customValues)) {
|
|
213
|
+
for (const [prop, values] of Object.entries(props)) {
|
|
214
|
+
if (values.size === 0) continue;
|
|
215
|
+
|
|
216
|
+
const pascal = toPascalCase(component);
|
|
217
|
+
const propPascal = prop.charAt(0).toUpperCase() + prop.slice(1);
|
|
218
|
+
const modulePath = `@astryxdesign/core/${pascal}`;
|
|
219
|
+
const interfaceName = `XDS${pascal}${propPascal}Map`;
|
|
220
|
+
|
|
221
|
+
sections.push(`declare module '${modulePath}' {`);
|
|
222
|
+
sections.push(` interface ${interfaceName} {`);
|
|
223
|
+
for (const v of values) {
|
|
224
|
+
sections.push(` '${v}': true;`);
|
|
225
|
+
}
|
|
226
|
+
sections.push(' }');
|
|
227
|
+
sections.push('}');
|
|
228
|
+
sections.push('');
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
return sections.join('\n');
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Resolve a token value — [light, dark] tuple becomes light-dark()
|
|
237
|
+
*/
|
|
238
|
+
function resolveTokenValue(value) {
|
|
239
|
+
if (Array.isArray(value)) {
|
|
240
|
+
return `light-dark(${value[0]}, ${value[1]})`;
|
|
241
|
+
}
|
|
242
|
+
return value;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
// Theme @scope selector helpers. Keep the `astryx` literal in sync with
|
|
246
|
+
// packages/core/src/naming.ts (NAMESPACE) and generateThemeRules.ts.
|
|
247
|
+
// Theme scopes to data-astryx-theme; the static build path must match.
|
|
248
|
+
const themeScopeStart = name => `[data-astryx-theme="${name}"]`;
|
|
249
|
+
const THEME_SCOPE_TO = `[data-astryx-theme]`;
|
|
250
|
+
|
|
251
|
+
/**
|
|
252
|
+
* Import a theme module using jiti and find the defineTheme() result.
|
|
253
|
+
* Returns the resolved DefinedTheme object.
|
|
254
|
+
*/
|
|
255
|
+
async function importThemeModule(filePath) {
|
|
256
|
+
const jiti = createJiti(import.meta.url, {
|
|
257
|
+
moduleCache: false,
|
|
258
|
+
jsx: true,
|
|
259
|
+
});
|
|
260
|
+
|
|
261
|
+
const mod = await jiti.import(filePath, {default: true});
|
|
262
|
+
|
|
263
|
+
if (isThemeObject(mod)) return mod;
|
|
264
|
+
|
|
265
|
+
if (mod && typeof mod === 'object') {
|
|
266
|
+
for (const value of Object.values(mod)) {
|
|
267
|
+
if (isThemeObject(value)) return value;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
throw new Error(
|
|
272
|
+
`Could not find a defineTheme() result in ${filePath}.\n` +
|
|
273
|
+
`Expected an export like: export const myTheme = defineTheme({ name: '...', tokens: {...} })`,
|
|
274
|
+
);
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
function isThemeObject(value) {
|
|
278
|
+
return (
|
|
279
|
+
value &&
|
|
280
|
+
typeof value === 'object' &&
|
|
281
|
+
typeof value.name === 'string' &&
|
|
282
|
+
value.tokens &&
|
|
283
|
+
typeof value.tokens === 'object'
|
|
284
|
+
);
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
/**
|
|
288
|
+
* Extract the theme definition from a JS/TS file.
|
|
289
|
+
* Tries jiti first (full TS support), falls back to regex+eval.
|
|
290
|
+
*/
|
|
291
|
+
async function extractThemeDefinition(filePath) {
|
|
292
|
+
try {
|
|
293
|
+
return await importThemeModule(filePath);
|
|
294
|
+
} catch (jitiError) {
|
|
295
|
+
try {
|
|
296
|
+
return extractThemeDefinitionLegacy(filePath);
|
|
297
|
+
} catch {
|
|
298
|
+
throw new Error(
|
|
299
|
+
`Failed to load theme from ${filePath}: ${jitiError.message}\n` +
|
|
300
|
+
`Make sure all imports in the theme file are resolvable.`,
|
|
301
|
+
);
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
/**
|
|
307
|
+
* Fallback extraction via regex + eval.
|
|
308
|
+
* Only works for plain object literals — can't follow imports or variables.
|
|
309
|
+
*/
|
|
310
|
+
function extractThemeDefinitionLegacy(filePath) {
|
|
311
|
+
const content = fs.readFileSync(filePath, 'utf8');
|
|
312
|
+
|
|
313
|
+
const defineMatch = content.match(/defineTheme\s*\(\s*({[\s\S]*?})\s*\)/);
|
|
314
|
+
if (!defineMatch) {
|
|
315
|
+
const defaultMatch = content.match(/export\s+default\s+({[\s\S]*?});/);
|
|
316
|
+
if (!defaultMatch) {
|
|
317
|
+
throw new Error(
|
|
318
|
+
`Could not find defineTheme() call or default export in ${filePath}.\n` +
|
|
319
|
+
`Expected: defineTheme({ name: '...', tokens: {...} })`,
|
|
320
|
+
);
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
return eval(`(${defaultMatch[1]})`);
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
let objStr = defineMatch[1];
|
|
327
|
+
objStr = objStr.replace(/\s+as\s+const/g, '');
|
|
328
|
+
objStr = objStr.replace(/icons:\s*[a-zA-Z_][a-zA-Z0-9_]*/g, 'icons: undefined');
|
|
329
|
+
|
|
330
|
+
try {
|
|
331
|
+
|
|
332
|
+
return eval(`(${objStr})`);
|
|
333
|
+
} catch (e) {
|
|
334
|
+
throw new Error(
|
|
335
|
+
`Failed to parse theme definition in ${filePath}: ${e.message}\n` +
|
|
336
|
+
`Make sure the defineTheme() argument is a plain object literal.`,
|
|
337
|
+
{cause: e},
|
|
338
|
+
);
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
/**
|
|
343
|
+
* Extract icon import info from a theme source file.
|
|
344
|
+
* Returns { importPath, exportName } or null if no icons.
|
|
345
|
+
*
|
|
346
|
+
* Looks for patterns like:
|
|
347
|
+
* import { defaultIconRegistry } from './icons';
|
|
348
|
+
* icons: defaultIconRegistry,
|
|
349
|
+
*/
|
|
350
|
+
function extractIconInfo(filePath) {
|
|
351
|
+
const content = fs.readFileSync(filePath, 'utf8');
|
|
352
|
+
|
|
353
|
+
// Find the icons field in defineTheme
|
|
354
|
+
const iconsMatch = content.match(/icons:\s*([a-zA-Z_][a-zA-Z0-9_]*)/);
|
|
355
|
+
if (!iconsMatch) return null;
|
|
356
|
+
|
|
357
|
+
const varName = iconsMatch[1];
|
|
358
|
+
|
|
359
|
+
// Find the import for that variable
|
|
360
|
+
const importRegex = new RegExp(
|
|
361
|
+
`import\\s*{[^}]*\\b${varName}\\b[^}]*}\\s*from\\s*['"]([^'"]+)['"]`,
|
|
362
|
+
);
|
|
363
|
+
const importMatch = content.match(importRegex);
|
|
364
|
+
if (!importMatch) return null;
|
|
365
|
+
|
|
366
|
+
return {
|
|
367
|
+
exportName: varName,
|
|
368
|
+
importPath: importMatch[1],
|
|
369
|
+
};
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
/**
|
|
373
|
+
* Generate a minimal JS module for a built theme.
|
|
374
|
+
* Includes the theme name, marker, and re-exports the icon registry.
|
|
375
|
+
* All styling is in the CSS file.
|
|
376
|
+
*/
|
|
377
|
+
function generateBuiltModule(themeDef, iconInfo) {
|
|
378
|
+
const iconImport = iconInfo
|
|
379
|
+
? `import { ${iconInfo.exportName} } from '${iconInfo.importPath}';\n`
|
|
380
|
+
: '';
|
|
381
|
+
const iconsField = iconInfo ? ` icons: ${iconInfo.exportName},` : '';
|
|
382
|
+
const iconReExport = iconInfo
|
|
383
|
+
? `\nexport { ${iconInfo.exportName} };\n`
|
|
384
|
+
: '';
|
|
385
|
+
|
|
386
|
+
// Resolve token values — tuples become light-dark() strings
|
|
387
|
+
const resolvedTokens = {};
|
|
388
|
+
if (themeDef.tokens) {
|
|
389
|
+
for (const [key, value] of Object.entries(themeDef.tokens)) {
|
|
390
|
+
resolvedTokens[key] = resolveTokenValue(value);
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
const tokensStr = JSON.stringify(resolvedTokens, null, 2)
|
|
395
|
+
.split('\n')
|
|
396
|
+
.map((line, i) => (i === 0 ? line : ' ' + line))
|
|
397
|
+
.join('\n');
|
|
398
|
+
|
|
399
|
+
return `${iconImport}/**
|
|
400
|
+
* ${themeDef.name} theme — built by \`${getRunPrefix()} astryx theme build\`
|
|
401
|
+
* Import the CSS file alongside this module:
|
|
402
|
+
*
|
|
403
|
+
* import { ${toIdentifier(themeDef.name)}Theme } from './${themeDef.name}';
|
|
404
|
+
* import './${themeDef.name}.css';
|
|
405
|
+
*/
|
|
406
|
+
export const ${toIdentifier(themeDef.name)}Theme = {
|
|
407
|
+
name: '${themeDef.name}',
|
|
408
|
+
__built: true,
|
|
409
|
+
tokens: ${tokensStr},
|
|
410
|
+
${iconsField}
|
|
411
|
+
};
|
|
412
|
+
${iconReExport}`;
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
/**
|
|
416
|
+
* Generate TypeScript declarations for a built theme module.
|
|
417
|
+
*/
|
|
418
|
+
function generateBuiltTypes(themeDef, iconInfo) {
|
|
419
|
+
const iconType = iconInfo
|
|
420
|
+
? `import type { IconRegistry } from '@astryxdesign/core/Icon';
|
|
421
|
+
export declare const ${iconInfo.exportName}: IconRegistry;
|
|
422
|
+
`
|
|
423
|
+
: '';
|
|
424
|
+
return `import type { DefinedTheme } from '@astryxdesign/core/theme';
|
|
425
|
+
${iconType}export declare const ${toIdentifier(themeDef.name)}Theme: DefinedTheme;
|
|
426
|
+
`;
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
// =============================================================================
|
|
430
|
+
// Component validation
|
|
431
|
+
// =============================================================================
|
|
432
|
+
|
|
433
|
+
/**
|
|
434
|
+
* Known Astryx component names and their visual props.
|
|
435
|
+
* Used to warn on typos in defineTheme component overrides.
|
|
436
|
+
*/
|
|
437
|
+
const KNOWN_COMPONENTS = {
|
|
438
|
+
appshell: ['position'],
|
|
439
|
+
aspectratio: [],
|
|
440
|
+
avatar: ['size'],
|
|
441
|
+
badge: ['variant', 'color'],
|
|
442
|
+
banner: ['container', 'status'],
|
|
443
|
+
breadcrumbs: ['variant'],
|
|
444
|
+
button: ['variant', 'size'],
|
|
445
|
+
calendar: [],
|
|
446
|
+
card: [],
|
|
447
|
+
center: [],
|
|
448
|
+
checkboxinput: [],
|
|
449
|
+
collapsible: [],
|
|
450
|
+
dateinput: [],
|
|
451
|
+
dialog: ['variant', 'position'],
|
|
452
|
+
divider: ['variant', 'orientation'],
|
|
453
|
+
dropdownmenu: [],
|
|
454
|
+
'empty-state': [],
|
|
455
|
+
field: [],
|
|
456
|
+
formlayout: [],
|
|
457
|
+
grid: ['align'],
|
|
458
|
+
heading: ['level'],
|
|
459
|
+
icon: ['size', 'color'],
|
|
460
|
+
kbd: [],
|
|
461
|
+
layer: [],
|
|
462
|
+
layout: [],
|
|
463
|
+
link: ['color'],
|
|
464
|
+
list: ['type', 'density'],
|
|
465
|
+
mobilenav: [],
|
|
466
|
+
moremenu: [],
|
|
467
|
+
navicon: [],
|
|
468
|
+
numberinput: [],
|
|
469
|
+
pagination: ['variant'],
|
|
470
|
+
progressbar: ['variant', 'size'],
|
|
471
|
+
radiolist: ['orientation'],
|
|
472
|
+
section: ['variant'],
|
|
473
|
+
selector: ['type', 'size', 'color'],
|
|
474
|
+
sidenav: [],
|
|
475
|
+
skeleton: [],
|
|
476
|
+
slider: ['orientation'],
|
|
477
|
+
spinner: ['size'],
|
|
478
|
+
stack: [],
|
|
479
|
+
statusdot: ['variant', 'size'],
|
|
480
|
+
switch: [],
|
|
481
|
+
table: [],
|
|
482
|
+
tablist: ['type'],
|
|
483
|
+
text: ['type', 'color'],
|
|
484
|
+
textarea: [],
|
|
485
|
+
textinput: [],
|
|
486
|
+
timeinput: [],
|
|
487
|
+
token: ['color'],
|
|
488
|
+
tokenizer: [],
|
|
489
|
+
topnav: [],
|
|
490
|
+
typeahead: ['type', 'size', 'color'],
|
|
491
|
+
};
|
|
492
|
+
|
|
493
|
+
/**
|
|
494
|
+
* Validate component overrides in a theme definition.
|
|
495
|
+
* Warns on unknown component names and unknown prop names.
|
|
496
|
+
* Returns array of warning strings.
|
|
497
|
+
*/
|
|
498
|
+
function validateComponentOverrides(themeDef) {
|
|
499
|
+
const warnings = [];
|
|
500
|
+
if (!themeDef.components) return warnings;
|
|
501
|
+
|
|
502
|
+
for (const [component, rules] of Object.entries(themeDef.components)) {
|
|
503
|
+
// Check component name
|
|
504
|
+
if (!(component in KNOWN_COMPONENTS)) {
|
|
505
|
+
const similar = Object.keys(KNOWN_COMPONENTS)
|
|
506
|
+
.filter((k) => {
|
|
507
|
+
if (k.includes(component) || component.includes(k)) return true;
|
|
508
|
+
// Levenshtein distance 1-2 for short names
|
|
509
|
+
if (Math.abs(k.length - component.length) <= 2) {
|
|
510
|
+
let diff = 0;
|
|
511
|
+
const longer = k.length >= component.length ? k : component;
|
|
512
|
+
const shorter = k.length < component.length ? k : component;
|
|
513
|
+
let j = 0;
|
|
514
|
+
for (let i = 0; i < longer.length && diff <= 2; i++) {
|
|
515
|
+
if (longer[i] !== shorter[j]) diff++;
|
|
516
|
+
else j++;
|
|
517
|
+
}
|
|
518
|
+
diff += shorter.length - j;
|
|
519
|
+
return diff <= 2;
|
|
520
|
+
}
|
|
521
|
+
return false;
|
|
522
|
+
})
|
|
523
|
+
.slice(0, 3);
|
|
524
|
+
const hint = similar.length > 0 ? ` Did you mean: ${similar.join(', ')}?` : '';
|
|
525
|
+
warnings.push(`Unknown component "${component}".${hint}`);
|
|
526
|
+
continue;
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
// Check prop names in prop:value keys
|
|
530
|
+
const knownProps = KNOWN_COMPONENTS[component];
|
|
531
|
+
for (const key of Object.keys(rules)) {
|
|
532
|
+
if (key === 'base') continue;
|
|
533
|
+
|
|
534
|
+
// Parse prop:value pairs (e.g. 'variant:secondary' or 'variant:destructive+size:sm')
|
|
535
|
+
const pairs = key.split('+');
|
|
536
|
+
for (const pair of pairs) {
|
|
537
|
+
const [prop] = pair.split(':');
|
|
538
|
+
if (prop && !knownProps.includes(prop)) {
|
|
539
|
+
const hint =
|
|
540
|
+
knownProps.length > 0
|
|
541
|
+
? ` Known props: ${knownProps.join(', ')}`
|
|
542
|
+
: ' This component has no variant props.';
|
|
543
|
+
warnings.push(
|
|
544
|
+
`Unknown prop "${prop}" on component "${component}".${hint}`,
|
|
545
|
+
);
|
|
546
|
+
}
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
|
|
551
|
+
return warnings;
|
|
552
|
+
}
|
|
553
|
+
|
|
554
|
+
/**
|
|
555
|
+
* Validate that themes don't set private (--_*) CSS custom properties directly.
|
|
556
|
+
* Private vars are internal implementation details managed by the derived var
|
|
557
|
+
* expansion pipeline. Theme authors should write standard CSS properties
|
|
558
|
+
* (e.g. borderRadius, padding) instead.
|
|
559
|
+
*
|
|
560
|
+
* Returns array of error strings.
|
|
561
|
+
*/
|
|
562
|
+
function validatePrivateVars(themeDef) {
|
|
563
|
+
const errors = [];
|
|
564
|
+
if (!themeDef.components) return errors;
|
|
565
|
+
|
|
566
|
+
for (const [component, rules] of Object.entries(themeDef.components)) {
|
|
567
|
+
for (const [key, styles] of Object.entries(rules)) {
|
|
568
|
+
for (const prop of Object.keys(styles)) {
|
|
569
|
+
if (typeof prop === 'string' && prop.startsWith('--_')) {
|
|
570
|
+
errors.push(
|
|
571
|
+
`Component "${component}" (${key}) sets private var "${prop}". ` +
|
|
572
|
+
`Private vars (--_*) are internal — use standard CSS properties ` +
|
|
573
|
+
`(e.g. borderRadius, padding) instead. The pipeline expands them automatically.`,
|
|
574
|
+
);
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
}
|
|
578
|
+
}
|
|
579
|
+
|
|
580
|
+
return errors;
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
export function registerTheme(program) {
|
|
584
|
+
const theme = program
|
|
585
|
+
.command('theme')
|
|
586
|
+
.description('Theme tools — build, export, and manage themes')
|
|
587
|
+
.action((options, cmd) => {
|
|
588
|
+
// Parent group has no default behaviour. If the user passed an
|
|
589
|
+
// unknown subcommand (e.g. `astryx theme bogus`), Commander hands it to
|
|
590
|
+
// us as a positional in cmd.args — exit 1 with a clear error.
|
|
591
|
+
const extras = (cmd && cmd.args) || [];
|
|
592
|
+
if (extras.length > 0) {
|
|
593
|
+
const unknown = String(extras[0]);
|
|
594
|
+
const known = (theme.commands || []).map((c) => c.name());
|
|
595
|
+
const suggestions = known.map((name) => ({name, reason: 'available subcommand'}));
|
|
596
|
+
cliError(`unknown subcommand 'theme ${unknown}'`, {suggestions, code: ERROR_CODES.ERR_UNKNOWN_SUBCOMMAND});
|
|
597
|
+
return;
|
|
598
|
+
}
|
|
599
|
+
// Bare `astryx theme` — show the subcommand list. Exit 0 (help is success).
|
|
600
|
+
theme.help();
|
|
601
|
+
});
|
|
602
|
+
|
|
603
|
+
theme
|
|
604
|
+
.command('build <file>')
|
|
605
|
+
.description('Compile a defineTheme file to CSS + JS')
|
|
606
|
+
.option('-o, --out <path>', 'Output CSS file path')
|
|
607
|
+
.action(async (file, options) => {
|
|
608
|
+
const filePath = path.resolve(process.cwd(), file);
|
|
609
|
+
const json = program.opts().json || false;
|
|
610
|
+
|
|
611
|
+
if (!fs.existsSync(filePath)) {
|
|
612
|
+
cliError(`File not found: ${filePath}`, {code: ERROR_CODES.ERR_FILE_NOT_FOUND});
|
|
613
|
+
return;
|
|
614
|
+
}
|
|
615
|
+
|
|
616
|
+
if (!json) humanLog(`\nBuilding theme from ${path.relative(process.cwd(), filePath)}...`);
|
|
617
|
+
|
|
618
|
+
// Extract theme definition
|
|
619
|
+
let themeDef;
|
|
620
|
+
try {
|
|
621
|
+
themeDef = await extractThemeDefinition(filePath);
|
|
622
|
+
} catch (e) {
|
|
623
|
+
cliError(e.message, {code: ERROR_CODES.ERR_THEME_LOAD});
|
|
624
|
+
return;
|
|
625
|
+
}
|
|
626
|
+
|
|
627
|
+
if (!themeDef.name) {
|
|
628
|
+
cliError('Theme must have a name property.', {code: ERROR_CODES.ERR_THEME_INVALID});
|
|
629
|
+
return;
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
// Path-safety: the theme name is used to derive output filenames
|
|
633
|
+
// (e.g. `${name}.css`, `${name}.js`). Reject names containing path
|
|
634
|
+
// separators or traversal markers — `../../escaped` would otherwise
|
|
635
|
+
// write JS modules outside the input directory.
|
|
636
|
+
try {
|
|
637
|
+
sanitizeName(themeDef.name, {label: 'theme name'});
|
|
638
|
+
} catch (err) {
|
|
639
|
+
if (err instanceof PathSafetyError) {
|
|
640
|
+
cliError(err.message, {code: ERROR_CODES.ERR_PATH_TRAVERSAL});
|
|
641
|
+
return;
|
|
642
|
+
}
|
|
643
|
+
throw err;
|
|
644
|
+
}
|
|
645
|
+
|
|
646
|
+
// Validate component overrides
|
|
647
|
+
const warnings = validateComponentOverrides(themeDef);
|
|
648
|
+
const warningMessages = [];
|
|
649
|
+
for (const w of warnings) {
|
|
650
|
+
warningMessages.push(w);
|
|
651
|
+
if (!json) console.warn(` ⚠ ${w}`);
|
|
652
|
+
}
|
|
653
|
+
|
|
654
|
+
// Validate no private vars are set directly
|
|
655
|
+
const privateVarErrors = validatePrivateVars(themeDef);
|
|
656
|
+
for (const e of privateVarErrors) {
|
|
657
|
+
warningMessages.push(e);
|
|
658
|
+
if (!json) console.error(` ✗ ${e}`);
|
|
659
|
+
}
|
|
660
|
+
if (privateVarErrors.length > 0 && !json) {
|
|
661
|
+
console.error(`\n ${privateVarErrors.length} private var error(s). Use standard CSS properties instead.`);
|
|
662
|
+
}
|
|
663
|
+
|
|
664
|
+
// Generate CSS via core's shared generator — the SINGLE source of truth.
|
|
665
|
+
// `astryx theme build` and the `<Theme>` runtime MUST emit identical CSS, so
|
|
666
|
+
// there is exactly one generation path: @astryxdesign/core/theme. If core could not
|
|
667
|
+
// be imported, fail hard rather than silently producing divergent output.
|
|
668
|
+
if (!_defineTheme || !_generateThemeRulesSplit) {
|
|
669
|
+
cliError(
|
|
670
|
+
'Could not load @astryxdesign/core/theme — `astryx theme build` requires a ' +
|
|
671
|
+
'built, resolvable @astryxdesign/core so it emits the same CSS as the ' +
|
|
672
|
+
'runtime <Theme>. Build @astryxdesign/core first (e.g. `pnpm -F @astryxdesign/core ' +
|
|
673
|
+
'build`)' +
|
|
674
|
+
(_coreImportError ? `.\n Import error: ${_coreImportError.message}` : '.'),
|
|
675
|
+
{code: ERROR_CODES.ERR_CORE_NOT_FOUND},
|
|
676
|
+
);
|
|
677
|
+
}
|
|
678
|
+
|
|
679
|
+
let css;
|
|
680
|
+
let resolvedTheme;
|
|
681
|
+
{
|
|
682
|
+
// jiti returns an already-resolved theme; legacy eval returns raw input.
|
|
683
|
+
const isAlreadyResolved =
|
|
684
|
+
!themeDef.typography && !themeDef.motion && !themeDef.radius;
|
|
685
|
+
if (isAlreadyResolved) {
|
|
686
|
+
resolvedTheme = themeDef;
|
|
687
|
+
} else {
|
|
688
|
+
resolvedTheme = _defineTheme({
|
|
689
|
+
name: themeDef.name,
|
|
690
|
+
typography: themeDef.typography,
|
|
691
|
+
motion: themeDef.motion,
|
|
692
|
+
radius: themeDef.radius,
|
|
693
|
+
tokens: themeDef.tokens,
|
|
694
|
+
components: themeDef.components,
|
|
695
|
+
});
|
|
696
|
+
}
|
|
697
|
+
const scopeSelector = themeScopeStart(themeDef.name);
|
|
698
|
+
const scopeTo = THEME_SCOPE_TO;
|
|
699
|
+
|
|
700
|
+
const {component, prose} = _generateThemeRulesSplit(resolvedTheme);
|
|
701
|
+
const cssParts = [];
|
|
702
|
+
// Prose element defaults always ship — the `<Theme>` runtime
|
|
703
|
+
// (generateThemeCSS) always emits them, so the build must too, or the
|
|
704
|
+
// CLI output would diverge from runtime. They go in @layer reset
|
|
705
|
+
// (zero-specificity :where()) so component/Markdown StyleX always wins.
|
|
706
|
+
if (prose.length > 0) {
|
|
707
|
+
const proseInner = prose.join('\n\n');
|
|
708
|
+
cssParts.push(
|
|
709
|
+
`@layer reset {\n@scope (${scopeSelector}) to (${scopeTo}) {\n${proseInner}\n}\n}`,
|
|
710
|
+
);
|
|
711
|
+
}
|
|
712
|
+
if (component.length > 0) {
|
|
713
|
+
const componentInner = component.join('\n\n');
|
|
714
|
+
const componentScope = `@scope (${scopeSelector}) to (${scopeTo}) {\n${componentInner}\n}`;
|
|
715
|
+
const colorSchemeDecl = componentScope.includes('light-dark(')
|
|
716
|
+
? ' :root { color-scheme: light dark; }\n\n'
|
|
717
|
+
: '';
|
|
718
|
+
cssParts.push(
|
|
719
|
+
`@layer astryx-theme {\n${colorSchemeDecl}${componentScope}\n}`,
|
|
720
|
+
);
|
|
721
|
+
}
|
|
722
|
+
// On-media rules (MediaTheme dark/light surface overrides)
|
|
723
|
+
if (_generateOnMediaCSS) {
|
|
724
|
+
const onMediaCss = _generateOnMediaCSS(resolvedTheme);
|
|
725
|
+
if (onMediaCss) {
|
|
726
|
+
cssParts.push(`@layer astryx-theme {\n${onMediaCss}\n}`);
|
|
727
|
+
}
|
|
728
|
+
}
|
|
729
|
+
if (cssParts.length === 0) {
|
|
730
|
+
if (!json) humanLog('No overrides found — nothing to build.');
|
|
731
|
+
return;
|
|
732
|
+
}
|
|
733
|
+
css = cssParts.join('\n\n') + '\n';
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
// Source path relative to cwd — used in @generated headers
|
|
737
|
+
const sourceRelative = path.relative(process.cwd(), filePath);
|
|
738
|
+
const buildCommand = `astryx theme build ${sourceRelative}${options.out ? ' --out ' + path.relative(process.cwd(), path.resolve(process.cwd(), options.out)) : ''}`;
|
|
739
|
+
|
|
740
|
+
// Determine output path
|
|
741
|
+
const outPath = options.out
|
|
742
|
+
? path.resolve(process.cwd(), options.out)
|
|
743
|
+
: filePath.replace(/\.(ts|tsx|js|jsx|mjs)$/, '.css');
|
|
744
|
+
|
|
745
|
+
const displayTheme = resolvedTheme || themeDef;
|
|
746
|
+
const tokenCount = displayTheme.tokens ? Object.keys(displayTheme.tokens).length : 0;
|
|
747
|
+
const componentCount = displayTheme.components ? Object.keys(displayTheme.components).length : 0;
|
|
748
|
+
const size = (Buffer.byteLength(css) / 1024).toFixed(1);
|
|
749
|
+
|
|
750
|
+
// Compute all output paths up front so we can validate them as a
|
|
751
|
+
// group BEFORE writing anything. Previously the CSS would be written
|
|
752
|
+
// first; if the JS write failed (e.g. ENOENT, permission), the CSS
|
|
753
|
+
// was left as orphaned half-built output. Stage-then-commit avoids
|
|
754
|
+
// that.
|
|
755
|
+
const outDir = path.dirname(outPath);
|
|
756
|
+
const baseName = themeDef.name;
|
|
757
|
+
const jsPath = path.join(outDir, `${baseName}.js`);
|
|
758
|
+
const dtsPath = path.join(outDir, `${baseName}.d.ts`);
|
|
759
|
+
|
|
760
|
+
const iconInfo = extractIconInfo(filePath);
|
|
761
|
+
|
|
762
|
+
// Generate all file contents in memory first.
|
|
763
|
+
const cssContent = generatedHeader(sourceRelative, 'css', buildCommand) + css;
|
|
764
|
+
const jsContent = generatedHeader(sourceRelative, 'js', buildCommand) + generateBuiltModule(resolvedTheme || themeDef, iconInfo);
|
|
765
|
+
const dtsContent = generatedHeader(sourceRelative, 'ts', buildCommand) + generateBuiltTypes(themeDef, iconInfo);
|
|
766
|
+
|
|
767
|
+
// Type augmentation .d.ts if theme has custom prop values
|
|
768
|
+
const augmentationSource = resolvedTheme || themeDef;
|
|
769
|
+
const variantDecl = await generateVariantDeclarationsAsync(augmentationSource);
|
|
770
|
+
const variantDtsPath = variantDecl ? path.join(outDir, `${baseName}.variants.d.ts`) : null;
|
|
771
|
+
const variantContent = variantDecl
|
|
772
|
+
? generatedHeader(sourceRelative, 'ts', buildCommand) + variantDecl
|
|
773
|
+
: null;
|
|
774
|
+
|
|
775
|
+
// Atomic-ish write: stage every file as `<dest>.tmp`, then rename
|
|
776
|
+
// each into place. If any stage step fails we clean up partials and
|
|
777
|
+
// exit; if a rename fails mid-way we still have the originals (or
|
|
778
|
+
// nothing) — never a half-built output set.
|
|
779
|
+
const writes = [
|
|
780
|
+
{dest: outPath, content: cssContent},
|
|
781
|
+
{dest: jsPath, content: jsContent},
|
|
782
|
+
{dest: dtsPath, content: dtsContent},
|
|
783
|
+
];
|
|
784
|
+
if (variantDtsPath) {
|
|
785
|
+
writes.push({dest: variantDtsPath, content: variantContent});
|
|
786
|
+
}
|
|
787
|
+
|
|
788
|
+
fs.mkdirSync(outDir, {recursive: true});
|
|
789
|
+
const staged = [];
|
|
790
|
+
try {
|
|
791
|
+
for (const w of writes) {
|
|
792
|
+
const tmp = `${w.dest}.${process.pid}.tmp`;
|
|
793
|
+
fs.writeFileSync(tmp, w.content);
|
|
794
|
+
staged.push({tmp, dest: w.dest});
|
|
795
|
+
}
|
|
796
|
+
for (const s of staged) {
|
|
797
|
+
fs.renameSync(s.tmp, s.dest);
|
|
798
|
+
}
|
|
799
|
+
} catch (err) {
|
|
800
|
+
// Roll back any temp files we managed to create.
|
|
801
|
+
for (const s of staged) {
|
|
802
|
+
try { fs.rmSync(s.tmp, {force: true}); } catch { /* best-effort */ }
|
|
803
|
+
}
|
|
804
|
+
const msg = `Failed to write theme outputs: ${err.message}`;
|
|
805
|
+
cliError(msg, {code: ERROR_CODES.ERR_WRITE_FAILED});
|
|
806
|
+
return;
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
if (!json) {
|
|
810
|
+
humanLog(`\n✓ ${path.relative(process.cwd(), outPath)}`);
|
|
811
|
+
humanLog(` ${tokenCount} token overrides, ${componentCount} component overrides`);
|
|
812
|
+
humanLog(` ${size} KB`);
|
|
813
|
+
humanLog(`✓ ${path.relative(process.cwd(), jsPath)}`);
|
|
814
|
+
humanLog(`✓ ${path.relative(process.cwd(), dtsPath)}`);
|
|
815
|
+
if (variantDtsPath) {
|
|
816
|
+
const augCount = (variantDecl.match(/': true;/g) || []).length;
|
|
817
|
+
humanLog(`✓ ${path.relative(process.cwd(), variantDtsPath)} (${augCount} type augmentations)`);
|
|
818
|
+
}
|
|
819
|
+
}
|
|
820
|
+
|
|
821
|
+
if (json) {
|
|
822
|
+
return jsonOut('theme.build', {
|
|
823
|
+
name: themeDef.name,
|
|
824
|
+
tokenCount,
|
|
825
|
+
componentCount,
|
|
826
|
+
sizeKB: parseFloat(size),
|
|
827
|
+
outputs: {
|
|
828
|
+
css: path.relative(process.cwd(), outPath),
|
|
829
|
+
js: path.relative(process.cwd(), jsPath),
|
|
830
|
+
dts: path.relative(process.cwd(), dtsPath),
|
|
831
|
+
...(variantDecl ? {variantsDts: path.relative(process.cwd(), variantDtsPath)} : {}),
|
|
832
|
+
},
|
|
833
|
+
warnings: warningMessages,
|
|
834
|
+
});
|
|
835
|
+
}
|
|
836
|
+
|
|
837
|
+
// Print install instructions
|
|
838
|
+
const relDir = path.relative(process.cwd(), outDir);
|
|
839
|
+
// When the output dir is the cwd, relDir is empty — avoid emitting a
|
|
840
|
+
// double-slash import path like './/<name>'. Build a './<relDir>/'
|
|
841
|
+
// prefix that collapses to './' when relDir is empty.
|
|
842
|
+
const importPrefix = relDir ? `./${relDir}/` : './';
|
|
843
|
+
const exportName = `${toIdentifier(baseName)}Theme`;
|
|
844
|
+
humanLog(`
|
|
845
|
+
Install in your app:
|
|
846
|
+
|
|
847
|
+
import { ${exportName} } from '${importPrefix}${baseName}';
|
|
848
|
+
import '${importPrefix}${baseName}.css';
|
|
849
|
+
|
|
850
|
+
<Theme theme={${exportName}}>
|
|
851
|
+
<App />
|
|
852
|
+
</Theme>
|
|
853
|
+
|
|
854
|
+
Or with a <link> tag:
|
|
855
|
+
|
|
856
|
+
import { ${exportName} } from '${importPrefix}${baseName}';
|
|
857
|
+
|
|
858
|
+
<link rel="stylesheet" href="${importPrefix}${baseName}.css" />
|
|
859
|
+
<Theme theme={${exportName}}>
|
|
860
|
+
<App />
|
|
861
|
+
</Theme>
|
|
862
|
+
`);
|
|
863
|
+
|
|
864
|
+
// Print font declaration warnings (derived from typography roles)
|
|
865
|
+
if (resolvedTheme && resolvedTheme.fonts && resolvedTheme.fonts.length > 0) {
|
|
866
|
+
humanLog(`\n⚠ Theme "${themeDef.name}" requires fonts not included in the build:`);
|
|
867
|
+
for (const font of resolvedTheme.fonts) {
|
|
868
|
+
humanLog(` ${font.family} — add to your document <head>:`);
|
|
869
|
+
humanLog(` <link rel="stylesheet" href="${font.url}" />`);
|
|
870
|
+
}
|
|
871
|
+
humanLog('');
|
|
872
|
+
}
|
|
873
|
+
});
|
|
874
|
+
}
|