@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,160 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file Codemod: Rename on*Action props to *Action (React 19 Action prop convention)
|
|
5
|
+
*
|
|
6
|
+
* Transforms:
|
|
7
|
+
* - onChangeAction → changeAction
|
|
8
|
+
* - onClickAction → clickAction
|
|
9
|
+
* - onPressedChangeAction → pressedChangeAction
|
|
10
|
+
* - onScrollToTopAction → scrollToTopAction
|
|
11
|
+
*
|
|
12
|
+
* Applies to JSX attributes on any component. The "Action" suffix signals
|
|
13
|
+
* that the function runs inside a React transition — the `on` prefix is
|
|
14
|
+
* dropped to align with the React 19 convention (e.g. `<form action={...}>`).
|
|
15
|
+
*
|
|
16
|
+
* @see https://react.dev/reference/react/useActionState#using-with-action-props
|
|
17
|
+
* @see https://aurorascharff.no/posts/building-design-components-with-action-props-using-async-react/
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
export const meta = {
|
|
21
|
+
title: 'Rename on*Action props to *Action',
|
|
22
|
+
description:
|
|
23
|
+
'Renames `onChangeAction` → `changeAction`, `onClickAction` → `clickAction`, ' +
|
|
24
|
+
'`onPressedChangeAction` → `pressedChangeAction`, ' +
|
|
25
|
+
'and `onScrollToTopAction` → `scrollToTopAction` to align with the React 19 ' +
|
|
26
|
+
'Action prop naming convention.',
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Map of old prop names → new prop names.
|
|
31
|
+
* Ordered longest-first to avoid partial matches during iteration.
|
|
32
|
+
*/
|
|
33
|
+
const PROP_RENAMES = {
|
|
34
|
+
onPressedChangeAction: 'pressedChangeAction',
|
|
35
|
+
onScrollToTopAction: 'scrollToTopAction',
|
|
36
|
+
onChangeAction: 'changeAction',
|
|
37
|
+
onClickAction: 'clickAction',
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export default function transformer(file, api) {
|
|
41
|
+
const j = api.jscodeshift;
|
|
42
|
+
const root = j(file.source);
|
|
43
|
+
let hasChanges = false;
|
|
44
|
+
|
|
45
|
+
// --- 1. Rename JSX attributes ---
|
|
46
|
+
root.find(j.JSXAttribute).forEach((path) => {
|
|
47
|
+
const name = path.node.name;
|
|
48
|
+
if (name.type !== 'JSXIdentifier') return;
|
|
49
|
+
|
|
50
|
+
const newName = PROP_RENAMES[name.name];
|
|
51
|
+
if (newName) {
|
|
52
|
+
name.name = newName;
|
|
53
|
+
hasChanges = true;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
// --- 2. Rename destructured parameter names (before general ObjectProperty) ---
|
|
58
|
+
// Covers: function MyComponent({ onChangeAction, ...rest }) → { changeAction, ...rest }
|
|
59
|
+
// Must run before step 3 so the ObjectPattern keys are renamed first and tracked.
|
|
60
|
+
const renamedBindings = new Map(); // oldLocalName → newLocalName
|
|
61
|
+
|
|
62
|
+
root.find(j.ObjectPattern).forEach((path) => {
|
|
63
|
+
for (const prop of path.node.properties) {
|
|
64
|
+
if (prop.type !== 'ObjectProperty') continue;
|
|
65
|
+
const key = prop.key;
|
|
66
|
+
if (key.type !== 'Identifier') continue;
|
|
67
|
+
|
|
68
|
+
const newName = PROP_RENAMES[key.name];
|
|
69
|
+
if (!newName) continue;
|
|
70
|
+
|
|
71
|
+
if (
|
|
72
|
+
prop.shorthand &&
|
|
73
|
+
prop.value.type === 'Identifier' &&
|
|
74
|
+
prop.value.name === key.name
|
|
75
|
+
) {
|
|
76
|
+
// Shorthand: { onChangeAction } → { changeAction }
|
|
77
|
+
const oldLocal = key.name;
|
|
78
|
+
key.name = newName;
|
|
79
|
+
prop.value.name = newName;
|
|
80
|
+
renamedBindings.set(oldLocal, newName);
|
|
81
|
+
hasChanges = true;
|
|
82
|
+
} else if (prop.value.type === 'Identifier' && prop.value.name === key.name) {
|
|
83
|
+
// Non-shorthand same name: { onChangeAction: onChangeAction }
|
|
84
|
+
const oldLocal = prop.value.name;
|
|
85
|
+
key.name = newName;
|
|
86
|
+
prop.value.name = newName;
|
|
87
|
+
renamedBindings.set(oldLocal, newName);
|
|
88
|
+
hasChanges = true;
|
|
89
|
+
} else {
|
|
90
|
+
// Aliased: { onChangeAction: myHandler } → { changeAction: myHandler }
|
|
91
|
+
key.name = newName;
|
|
92
|
+
hasChanges = true;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
// --- 3. Rename object property keys (e.g. { onChangeAction: fn }) ---
|
|
98
|
+
// Covers cases like useXDSImperativeAlertDialog({ onAction: ... })
|
|
99
|
+
// Skips ObjectProperty inside ObjectPattern (already handled in step 2).
|
|
100
|
+
root.find(j.ObjectProperty).forEach((path) => {
|
|
101
|
+
// Skip if inside a destructuring pattern
|
|
102
|
+
if (path.parent.node.type === 'ObjectPattern') return;
|
|
103
|
+
|
|
104
|
+
const key = path.node.key;
|
|
105
|
+
if (key.type === 'Identifier') {
|
|
106
|
+
const newName = PROP_RENAMES[key.name];
|
|
107
|
+
if (newName) {
|
|
108
|
+
key.name = newName;
|
|
109
|
+
// Also rename value if it's the same identifier (shorthand)
|
|
110
|
+
if (
|
|
111
|
+
path.node.shorthand &&
|
|
112
|
+
path.node.value.type === 'Identifier' &&
|
|
113
|
+
path.node.value.name !== newName
|
|
114
|
+
) {
|
|
115
|
+
path.node.value.name = newName;
|
|
116
|
+
}
|
|
117
|
+
hasChanges = true;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
// --- 4. Rename interface/type property signatures ---
|
|
123
|
+
// Covers: interface Props { onChangeAction?: ... } → { changeAction?: ... }
|
|
124
|
+
root.find(j.TSPropertySignature).forEach((path) => {
|
|
125
|
+
const key = path.node.key;
|
|
126
|
+
if (key.type === 'Identifier') {
|
|
127
|
+
const newName = PROP_RENAMES[key.name];
|
|
128
|
+
if (newName) {
|
|
129
|
+
key.name = newName;
|
|
130
|
+
hasChanges = true;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
// --- 5. Rename identifier references from renamed destructured bindings ---
|
|
136
|
+
// When { onChangeAction } was renamed to { changeAction }, all references
|
|
137
|
+
// to the local variable `onChangeAction` must become `changeAction`.
|
|
138
|
+
if (renamedBindings.size > 0) {
|
|
139
|
+
root.find(j.Identifier).forEach((path) => {
|
|
140
|
+
const newName = renamedBindings.get(path.node.name);
|
|
141
|
+
if (!newName) return;
|
|
142
|
+
|
|
143
|
+
// Skip if this is the destructuring site itself (already renamed)
|
|
144
|
+
const parent = path.parent.node;
|
|
145
|
+
if (parent.type === 'ObjectProperty') return;
|
|
146
|
+
// Skip import specifiers
|
|
147
|
+
if (parent.type === 'ImportSpecifier') return;
|
|
148
|
+
// Skip JSX attribute names (handled in step 1)
|
|
149
|
+
if (parent.type === 'JSXAttribute' && path.name === 'name') return;
|
|
150
|
+
// Skip object keys in non-pattern contexts (handled in step 2)
|
|
151
|
+
if (parent.type === 'Property' && path.name === 'key') return;
|
|
152
|
+
|
|
153
|
+
path.node.name = newName;
|
|
154
|
+
hasChanges = true;
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
if (!hasChanges) return undefined;
|
|
159
|
+
return root.toSource({quote: 'single'});
|
|
160
|
+
}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file Codemod: Rename Section/Toolbar variant "wash" to "muted"
|
|
5
|
+
* @see https://github.com/facebookexperimental/xds/pull/2063
|
|
6
|
+
*
|
|
7
|
+
* XDSSection and XDSToolbar renamed the `variant="wash"` value to
|
|
8
|
+
* `variant="muted"` for consistency with XDSCard, which already uses
|
|
9
|
+
* `muted` for the same `--color-background-muted` token.
|
|
10
|
+
*
|
|
11
|
+
* Transforms:
|
|
12
|
+
* - <XDSSection variant="wash" /> → <XDSSection variant="muted" />
|
|
13
|
+
* - <XDSToolbar variant="wash" /> → <XDSToolbar variant="muted" />
|
|
14
|
+
* - Object properties: { variant: 'wash' } → { variant: 'muted' }
|
|
15
|
+
* (only in files that import XDSSection or XDSToolbar)
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
export const meta = {
|
|
19
|
+
title: 'Rename Section/Toolbar variant "wash" to "muted"',
|
|
20
|
+
description:
|
|
21
|
+
'Renames `variant="wash"` to `variant="muted"` on XDSSection and XDSToolbar ' +
|
|
22
|
+
'to align with XDSCard which already uses `muted` for the same background token.',
|
|
23
|
+
pr: '#2063',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
/** Components affected by this rename. */
|
|
27
|
+
const TARGET_COMPONENTS = new Set(['XDSSection', 'XDSToolbar']);
|
|
28
|
+
|
|
29
|
+
export default function transformer(file, api) {
|
|
30
|
+
const j = api.jscodeshift;
|
|
31
|
+
const root = j(file.source);
|
|
32
|
+
let hasChanges = false;
|
|
33
|
+
|
|
34
|
+
// 1. Rename JSX attribute value: variant="wash" → variant="muted"
|
|
35
|
+
// Only on XDSSection and XDSToolbar.
|
|
36
|
+
root.find(j.JSXOpeningElement).forEach((path) => {
|
|
37
|
+
const name = path.node.name;
|
|
38
|
+
const componentName = name.type === 'JSXIdentifier' ? name.name : null;
|
|
39
|
+
if (!componentName || !TARGET_COMPONENTS.has(componentName)) return;
|
|
40
|
+
|
|
41
|
+
path.node.attributes.forEach((attr) => {
|
|
42
|
+
if (attr.type !== 'JSXAttribute') return;
|
|
43
|
+
if (attr.name.name !== 'variant') return;
|
|
44
|
+
|
|
45
|
+
const value = attr.value;
|
|
46
|
+
|
|
47
|
+
// variant="wash" (string literal)
|
|
48
|
+
if (
|
|
49
|
+
value &&
|
|
50
|
+
(value.type === 'StringLiteral' || value.type === 'Literal') &&
|
|
51
|
+
value.value === 'wash'
|
|
52
|
+
) {
|
|
53
|
+
value.value = 'muted';
|
|
54
|
+
if (value.raw) value.raw = undefined;
|
|
55
|
+
hasChanges = true;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// variant={'wash'} (expression container with string literal)
|
|
59
|
+
if (
|
|
60
|
+
value &&
|
|
61
|
+
value.type === 'JSXExpressionContainer' &&
|
|
62
|
+
value.expression &&
|
|
63
|
+
(value.expression.type === 'StringLiteral' || value.expression.type === 'Literal') &&
|
|
64
|
+
value.expression.value === 'wash'
|
|
65
|
+
) {
|
|
66
|
+
value.expression.value = 'muted';
|
|
67
|
+
if (value.expression.raw) value.expression.raw = undefined;
|
|
68
|
+
hasChanges = true;
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
// 2. Object properties in files that import XDSSection or XDSToolbar.
|
|
74
|
+
// Handles Storybook args like: { variant: 'wash' } → { variant: 'muted' }
|
|
75
|
+
// Also handles options arrays inside variant argTypes config objects.
|
|
76
|
+
const importsTarget =
|
|
77
|
+
root.find(j.ImportSpecifier, {imported: {name: 'XDSSection'}}).length > 0 ||
|
|
78
|
+
root.find(j.ImportSpecifier, {imported: {name: 'XDSToolbar'}}).length > 0;
|
|
79
|
+
|
|
80
|
+
if (importsTarget) {
|
|
81
|
+
const PropertyType = j.ObjectProperty ?? j.Property;
|
|
82
|
+
root.find(PropertyType, {key: {name: 'variant'}}).forEach((path) => {
|
|
83
|
+
const value = path.node.value;
|
|
84
|
+
|
|
85
|
+
// variant: 'wash' → variant: 'muted'
|
|
86
|
+
if (
|
|
87
|
+
(value.type === 'StringLiteral' || value.type === 'Literal') &&
|
|
88
|
+
value.value === 'wash'
|
|
89
|
+
) {
|
|
90
|
+
value.value = 'muted';
|
|
91
|
+
if (value.raw) value.raw = undefined;
|
|
92
|
+
hasChanges = true;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// variant: { options: ['...', 'wash', '...'] } → replace 'wash' with 'muted'
|
|
96
|
+
if (value.type === 'ObjectExpression') {
|
|
97
|
+
const optionsProp = value.properties.find(
|
|
98
|
+
(p) => p.key && p.key.name === 'options',
|
|
99
|
+
);
|
|
100
|
+
if (optionsProp && optionsProp.value.type === 'ArrayExpression') {
|
|
101
|
+
optionsProp.value.elements.forEach((el) => {
|
|
102
|
+
if (
|
|
103
|
+
el &&
|
|
104
|
+
(el.type === 'StringLiteral' || el.type === 'Literal') &&
|
|
105
|
+
el.value === 'wash'
|
|
106
|
+
) {
|
|
107
|
+
el.value = 'muted';
|
|
108
|
+
if (el.raw) el.raw = undefined;
|
|
109
|
+
hasChanges = true;
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// 3. JSX text children: replace "wash" text content adjacent to target components.
|
|
118
|
+
// Covers labels like <h4>wash</h4> that describe the variant in Storybook stories.
|
|
119
|
+
if (importsTarget) {
|
|
120
|
+
root.find(j.JSXText).forEach((path) => {
|
|
121
|
+
if (path.node.value.trim() === 'wash') {
|
|
122
|
+
path.node.value = path.node.value.replace('wash', 'muted');
|
|
123
|
+
if (path.node.raw) path.node.raw = path.node.raw.replace('wash', 'muted');
|
|
124
|
+
hasChanges = true;
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
if (!hasChanges) return undefined;
|
|
130
|
+
return root.toSource({quote: 'single'});
|
|
131
|
+
}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file Codemod: Rename status variants positive/negative → success/error
|
|
5
|
+
* @see https://github.com/facebookexperimental/xds/issues/996
|
|
6
|
+
*
|
|
7
|
+
* Converges component APIs to match the token layer naming:
|
|
8
|
+
* - `positive` → `success` (maps to --color-success)
|
|
9
|
+
* - `negative` → `error` (maps to --color-error)
|
|
10
|
+
* - `info` → `accent` (maps to --color-accent)
|
|
11
|
+
*
|
|
12
|
+
* Affected components:
|
|
13
|
+
* - XDSStatusDot: variant="positive|negative|info" → variant="success|error|accent"
|
|
14
|
+
* - XDSAvatarStatusDot: variant="positive|negative" → variant="success|error"
|
|
15
|
+
* - XDSIcon: color="positive|negative" → color="success|error"
|
|
16
|
+
* - XDSProgressBar: variant="positive|negative" → variant="success|error"
|
|
17
|
+
*
|
|
18
|
+
* Transforms JSX attributes, object properties (in files importing affected
|
|
19
|
+
* components), TypeScript type annotations, and Storybook argType options.
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
export const meta = {
|
|
23
|
+
title: 'Rename status variants positive/negative → success/error',
|
|
24
|
+
description:
|
|
25
|
+
'Renames `positive` to `success`, `negative` to `error`, and `info` to `accent` ' +
|
|
26
|
+
'on StatusDot, AvatarStatusDot, Icon, SVGIcon, and ProgressBar to align with token naming. ' +
|
|
27
|
+
'The `info` -> `accent` rename is only applied to direct JSX attributes on these ' +
|
|
28
|
+
'components (where the component is known); in context-blind locations (object ' +
|
|
29
|
+
'properties, type unions) `info` is left untouched because it is a valid variant on ' +
|
|
30
|
+
'other components such as Badge.',
|
|
31
|
+
pr: '#996',
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
/** Rename mappings. */
|
|
35
|
+
const RENAMES = new Map([
|
|
36
|
+
['positive', 'success'],
|
|
37
|
+
['negative', 'error'],
|
|
38
|
+
['info', 'accent'],
|
|
39
|
+
]);
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Ambiguous renames that are only safe when the target component is known.
|
|
43
|
+
*
|
|
44
|
+
* `info` is a VALID variant on non-target components (notably XDSBadge, whose
|
|
45
|
+
* BadgeVariantMap still has `info`). `positive`/`negative` are not retained by
|
|
46
|
+
* any component post-migration, so renaming them is always safe. Therefore the
|
|
47
|
+
* context-blind heuristic paths (object properties, type unions, and suffixed
|
|
48
|
+
* props on wrapper components) must NOT rewrite `info` — only the precise path,
|
|
49
|
+
* a direct JSX attribute on a known target component, may. Otherwise a
|
|
50
|
+
* `variant: 'info'` on an unrelated Badge config in a file that merely also
|
|
51
|
+
* imports e.g. XDSIcon gets wrongly rewritten to the invalid `accent`.
|
|
52
|
+
*/
|
|
53
|
+
const AMBIGUOUS_VALUES = new Set(['info']);
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Components and which props are affected.
|
|
58
|
+
* Key: component name. Value: set of prop names to check.
|
|
59
|
+
*/
|
|
60
|
+
const COMPONENT_PROPS = new Map([
|
|
61
|
+
['XDSStatusDot', new Set(['variant'])],
|
|
62
|
+
['XDSAvatarStatusDot', new Set(['variant'])],
|
|
63
|
+
['XDSIcon', new Set(['color'])],
|
|
64
|
+
['XDSProgressBar', new Set(['variant'])],
|
|
65
|
+
]);
|
|
66
|
+
|
|
67
|
+
/** All affected component names for quick lookup. */
|
|
68
|
+
const TARGET_COMPONENTS = new Set(COMPONENT_PROPS.keys());
|
|
69
|
+
|
|
70
|
+
/** All affected prop names (variant, color). */
|
|
71
|
+
const TARGET_PROP_NAMES = new Set();
|
|
72
|
+
for (const props of COMPONENT_PROPS.values()) {
|
|
73
|
+
for (const p of props) TARGET_PROP_NAMES.add(p);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Check if a key matches a target prop — exact or case-insensitive suffix.
|
|
78
|
+
* e.g. "dotVariant" matches because it ends with "variant".
|
|
79
|
+
*/
|
|
80
|
+
function matchesPropName(keyName) {
|
|
81
|
+
if (TARGET_PROP_NAMES.has(keyName)) return true;
|
|
82
|
+
const lower = keyName.toLowerCase();
|
|
83
|
+
for (const prop of TARGET_PROP_NAMES) {
|
|
84
|
+
if (lower.endsWith(prop.toLowerCase()) && lower !== prop.toLowerCase()) return true;
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
export default function transformer(file, api) {
|
|
90
|
+
const j = api.jscodeshift;
|
|
91
|
+
const root = j(file.source);
|
|
92
|
+
let hasChanges = false;
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* Rename a string literal value if it matches our renames.
|
|
96
|
+
* Unwraps TSAsExpression (e.g. 'positive' as const) to reach the literal.
|
|
97
|
+
* @returns {boolean} whether a rename occurred
|
|
98
|
+
*/
|
|
99
|
+
function renameValue(node, {precise = false} = {}) {
|
|
100
|
+
if (!node) return false;
|
|
101
|
+
|
|
102
|
+
// Unwrap TSAsExpression (e.g. 'positive' as const → StringLiteral)
|
|
103
|
+
const target = node.type === 'TSAsExpression' ? node.expression : node;
|
|
104
|
+
|
|
105
|
+
const isString =
|
|
106
|
+
target.type === 'StringLiteral' || target.type === 'Literal';
|
|
107
|
+
if (!isString || typeof target.value !== 'string') return false;
|
|
108
|
+
|
|
109
|
+
const replacement = RENAMES.get(target.value);
|
|
110
|
+
if (!replacement) return false;
|
|
111
|
+
|
|
112
|
+
// Ambiguous values (e.g. `info`) are only renamed in a precise context
|
|
113
|
+
// where the target component is known (a direct JSX attribute on a target).
|
|
114
|
+
// In context-blind paths they may belong to a component that legitimately
|
|
115
|
+
// keeps the value (e.g. Badge's `info`), so leave them untouched.
|
|
116
|
+
if (!precise && AMBIGUOUS_VALUES.has(target.value)) return false;
|
|
117
|
+
|
|
118
|
+
target.value = replacement;
|
|
119
|
+
if (target.raw) target.raw = undefined;
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Rename elements in an array (handles TSAsExpression wrapping).
|
|
125
|
+
*/
|
|
126
|
+
function renameArrayElements(node, {precise = false} = {}) {
|
|
127
|
+
let arrayNode = node;
|
|
128
|
+
if (arrayNode.type === 'TSAsExpression') arrayNode = arrayNode.expression;
|
|
129
|
+
if (arrayNode.type !== 'ArrayExpression') return;
|
|
130
|
+
arrayNode.elements.forEach((el) => {
|
|
131
|
+
if (renameValue(el, {precise})) hasChanges = true;
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Determine early: does this file import any target component?
|
|
136
|
+
const importsTarget = [...TARGET_COMPONENTS].some(
|
|
137
|
+
(name) =>
|
|
138
|
+
root.find(j.ImportSpecifier, {imported: {name}}).length > 0,
|
|
139
|
+
);
|
|
140
|
+
|
|
141
|
+
// 1. JSX attributes on target components
|
|
142
|
+
root.find(j.JSXOpeningElement).forEach((path) => {
|
|
143
|
+
const name = path.node.name;
|
|
144
|
+
const componentName = name.type === 'JSXIdentifier' ? name.name : null;
|
|
145
|
+
if (!componentName) return;
|
|
146
|
+
|
|
147
|
+
const isDirectTarget = TARGET_COMPONENTS.has(componentName);
|
|
148
|
+
// For non-target components, only check suffixed props if file imports targets
|
|
149
|
+
if (!isDirectTarget && !importsTarget) return;
|
|
150
|
+
|
|
151
|
+
path.node.attributes.forEach((attr) => {
|
|
152
|
+
if (attr.type !== 'JSXAttribute') return;
|
|
153
|
+
const attrName = attr.name.name;
|
|
154
|
+
|
|
155
|
+
if (isDirectTarget) {
|
|
156
|
+
// Direct targets: only their specific props
|
|
157
|
+
const targetProps = COMPONENT_PROPS.get(componentName);
|
|
158
|
+
if (!targetProps.has(attrName)) return;
|
|
159
|
+
} else {
|
|
160
|
+
// Non-target components: suffixed prop names only
|
|
161
|
+
// (e.g. dotVariant on ChangelogSection wrapping XDSStatusDot)
|
|
162
|
+
if (!matchesPropName(attrName) || TARGET_PROP_NAMES.has(attrName)) return;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
// Only a direct JSX attribute on a target component is a precise context
|
|
166
|
+
// where the component (and thus the validity of `info`) is known. The
|
|
167
|
+
// wrapper/suffixed-prop case is a heuristic and must not touch ambiguous
|
|
168
|
+
// values.
|
|
169
|
+
const precise = isDirectTarget;
|
|
170
|
+
const value = attr.value;
|
|
171
|
+
|
|
172
|
+
// variant="positive" (string literal)
|
|
173
|
+
if (renameValue(value, {precise})) {
|
|
174
|
+
hasChanges = true;
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
// variant={'positive'} (expression container)
|
|
179
|
+
if (
|
|
180
|
+
value &&
|
|
181
|
+
value.type === 'JSXExpressionContainer' &&
|
|
182
|
+
value.expression
|
|
183
|
+
) {
|
|
184
|
+
if (renameValue(value.expression, {precise})) {
|
|
185
|
+
hasChanges = true;
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
// variant={condition ? 'positive' : 'negative'} (ternary)
|
|
190
|
+
if (value.expression.type === 'ConditionalExpression') {
|
|
191
|
+
if (renameValue(value.expression.consequent, {precise}))
|
|
192
|
+
hasChanges = true;
|
|
193
|
+
if (renameValue(value.expression.alternate, {precise}))
|
|
194
|
+
hasChanges = true;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
// 2. Object properties in files importing target components.
|
|
201
|
+
// Handles args objects, config objects, Storybook argTypes, etc.
|
|
202
|
+
if (importsTarget) {
|
|
203
|
+
const PropertyType = j.ObjectProperty ?? j.Property;
|
|
204
|
+
root.find(PropertyType).forEach((path) => {
|
|
205
|
+
const key = path.node.key;
|
|
206
|
+
const keyName =
|
|
207
|
+
key.type === 'Identifier'
|
|
208
|
+
? key.name
|
|
209
|
+
: key.type === 'StringLiteral' || key.type === 'Literal'
|
|
210
|
+
? key.value
|
|
211
|
+
: null;
|
|
212
|
+
|
|
213
|
+
if (!keyName || !matchesPropName(keyName)) return;
|
|
214
|
+
|
|
215
|
+
const value = path.node.value;
|
|
216
|
+
|
|
217
|
+
// variant: 'positive' → variant: 'success'
|
|
218
|
+
if (renameValue(value)) {
|
|
219
|
+
hasChanges = true;
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// variant: { options: ['positive', 'negative', ...] }
|
|
224
|
+
if (value.type === 'ObjectExpression') {
|
|
225
|
+
const optionsProp = value.properties.find(
|
|
226
|
+
(p) => p.key && (p.key.name === 'options' || p.key.value === 'options'),
|
|
227
|
+
);
|
|
228
|
+
if (optionsProp) {
|
|
229
|
+
renameArrayElements(optionsProp.value);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// variant: ['positive', 'negative'] or [...] as Type[]
|
|
234
|
+
renameArrayElements(value);
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
// 3. TypeScript type references: 'positive' | 'negative' in union types
|
|
239
|
+
if (importsTarget) {
|
|
240
|
+
root.find(j.TSLiteralType).forEach((path) => {
|
|
241
|
+
const lit = path.node.literal;
|
|
242
|
+
if (renameValue(lit)) hasChanges = true;
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
if (!hasChanges) return undefined;
|
|
247
|
+
return root.toSource({quote: 'single'});
|
|
248
|
+
}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
import {describe, it, expect} from 'vitest';
|
|
4
|
+
|
|
5
|
+
async function applyTransform(source) {
|
|
6
|
+
const {default: transform} = await import('../drop-xds-prefix-imports.mjs');
|
|
7
|
+
const jscodeshift = (await import('jscodeshift')).default;
|
|
8
|
+
const j = jscodeshift.withParser('tsx');
|
|
9
|
+
const api = {jscodeshift: j, stats: () => {}, report: () => {}};
|
|
10
|
+
const file = {source, path: 'test.tsx'};
|
|
11
|
+
const result = transform(file, api);
|
|
12
|
+
return result ?? source;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
describe('drop-xds-prefix-imports', () => {
|
|
16
|
+
it('renames a named import + its JSX usage', async () => {
|
|
17
|
+
const input = [
|
|
18
|
+
`import {XDSButton} from '@xds/core';`,
|
|
19
|
+
`export const App = () => <XDSButton label="Hi" />;`,
|
|
20
|
+
].join('\n');
|
|
21
|
+
const output = await applyTransform(input);
|
|
22
|
+
expect(output).toContain(`import {Button} from '@xds/core';`);
|
|
23
|
+
expect(output).toContain('<Button label="Hi" />');
|
|
24
|
+
expect(output).not.toContain('XDSButton');
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
it('renames subpath imports and keeps the source path', async () => {
|
|
28
|
+
const input = `import {XDSButton} from '@xds/core/Button';`;
|
|
29
|
+
const output = await applyTransform(input);
|
|
30
|
+
expect(output).toContain('Button');
|
|
31
|
+
// The subpath dir is NOT renamed by this codemod.
|
|
32
|
+
expect(output).toContain(`from '@xds/core/Button'`);
|
|
33
|
+
expect(output).not.toContain('XDSButton');
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it('renames hooks (useXDS -> use)', async () => {
|
|
37
|
+
const input = [
|
|
38
|
+
`import {useXDSTheme} from '@xds/core';`,
|
|
39
|
+
`const t = useXDSTheme();`,
|
|
40
|
+
].join('\n');
|
|
41
|
+
const output = await applyTransform(input);
|
|
42
|
+
expect(output).toContain('import {useTheme}');
|
|
43
|
+
expect(output).toContain('const t = useTheme();');
|
|
44
|
+
expect(output).not.toContain('useXDSTheme');
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
it('renames type-only imports and type references', async () => {
|
|
48
|
+
const input = [
|
|
49
|
+
`import type {XDSButtonProps} from '@xds/core';`,
|
|
50
|
+
`type Props = XDSButtonProps & {extra: true};`,
|
|
51
|
+
].join('\n');
|
|
52
|
+
const output = await applyTransform(input);
|
|
53
|
+
expect(output).toContain('ButtonProps');
|
|
54
|
+
expect(output).not.toContain('XDSButtonProps');
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it('renames type references in generic type-argument positions', async () => {
|
|
58
|
+
const input = [
|
|
59
|
+
`import {XDSTableColumn} from '@xds/core/Table';`,
|
|
60
|
+
`const cols = useMemo<XDSTableColumn<Issue>[]>(() => [], []);`,
|
|
61
|
+
].join('\n');
|
|
62
|
+
const output = await applyTransform(input);
|
|
63
|
+
expect(output).toContain(`import {TableColumn} from '@xds/core/Table';`);
|
|
64
|
+
expect(output).toContain('useMemo<TableColumn<Issue>[]>');
|
|
65
|
+
// The unrelated generic argument `Issue` must be left alone.
|
|
66
|
+
expect(output).toContain('<Issue>');
|
|
67
|
+
expect(output).not.toContain('XDSTableColumn');
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('rewrites the imported name but keeps a custom local alias', async () => {
|
|
71
|
+
const input = [
|
|
72
|
+
`import {XDSButton as Btn} from '@xds/core';`,
|
|
73
|
+
`export const App = () => <Btn />;`,
|
|
74
|
+
].join('\n');
|
|
75
|
+
const output = await applyTransform(input);
|
|
76
|
+
expect(output).toContain('Button as Btn');
|
|
77
|
+
expect(output).toContain('<Btn />');
|
|
78
|
+
expect(output).not.toContain('XDSButton');
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
it('does NOT touch identifiers that are not imported from @xds/core', async () => {
|
|
82
|
+
const input = [
|
|
83
|
+
`import {XDSButton} from '@my/other-lib';`,
|
|
84
|
+
`const XDSCustomThing = 1;`,
|
|
85
|
+
`export const App = () => <XDSButton />;`,
|
|
86
|
+
].join('\n');
|
|
87
|
+
const output = await applyTransform(input);
|
|
88
|
+
// Neither the third-party import nor the local symbol should change.
|
|
89
|
+
expect(output).toContain(`import {XDSButton} from '@my/other-lib';`);
|
|
90
|
+
expect(output).toContain('const XDSCustomThing = 1;');
|
|
91
|
+
expect(output).toContain('<XDSButton />');
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
it('does NOT touch strings that merely start with XDS', async () => {
|
|
95
|
+
const input = [
|
|
96
|
+
`import {XDSButton} from '@xds/core';`,
|
|
97
|
+
`const label = 'XDSButton is great';`,
|
|
98
|
+
`export const App = () => <XDSButton label={label} />;`,
|
|
99
|
+
].join('\n');
|
|
100
|
+
const output = await applyTransform(input);
|
|
101
|
+
expect(output).toContain(`'XDSButton is great'`);
|
|
102
|
+
expect(output).toContain('<Button label={label} />');
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('handles multiple specifiers and a mix of components, hooks, and types', async () => {
|
|
106
|
+
const input = [
|
|
107
|
+
`import {XDSButton, XDSCard, useXDSToast} from '@xds/core';`,
|
|
108
|
+
`import type {XDSCardProps} from '@xds/core';`,
|
|
109
|
+
`export function App() {`,
|
|
110
|
+
` const toast = useXDSToast();`,
|
|
111
|
+
` const p: XDSCardProps = {};`,
|
|
112
|
+
` return <XDSCard><XDSButton /></XDSCard>;`,
|
|
113
|
+
`}`,
|
|
114
|
+
].join('\n');
|
|
115
|
+
const output = await applyTransform(input);
|
|
116
|
+
expect(output).toContain('import {Button, Card, useToast}');
|
|
117
|
+
expect(output).toContain('CardProps');
|
|
118
|
+
expect(output).toContain('const toast = useToast();');
|
|
119
|
+
expect(output).toContain('<Card><Button /></Card>');
|
|
120
|
+
expect(output).not.toContain('XDS');
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
it('rewrites re-exports from @xds/core', async () => {
|
|
124
|
+
const input = `export {XDSButton} from '@xds/core/Button';`;
|
|
125
|
+
const output = await applyTransform(input);
|
|
126
|
+
expect(output).toContain('Button');
|
|
127
|
+
expect(output).toContain(`from '@xds/core/Button'`);
|
|
128
|
+
expect(output).not.toContain('XDSButton');
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
it('returns source unchanged when there is nothing to rename', async () => {
|
|
132
|
+
const input = `import {useState} from 'react';\nconst x = 1;`;
|
|
133
|
+
const output = await applyTransform(input);
|
|
134
|
+
expect(output).toContain(`import {useState} from 'react';`);
|
|
135
|
+
expect(output).toContain('const x = 1;');
|
|
136
|
+
});
|
|
137
|
+
});
|