@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,94 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file Codemod: Remove size prop from XDSStatusDot and XDSProgressBar
|
|
5
|
+
* @see https://github.com/facebookexperimental/xds/issues/904
|
|
6
|
+
*
|
|
7
|
+
* StatusDot and ProgressBar now have a single fixed size (8px).
|
|
8
|
+
* The `size` prop has been removed from both components.
|
|
9
|
+
*
|
|
10
|
+
* This codemod handles:
|
|
11
|
+
* 1. JSX prop removal: <XDSStatusDot size="sm" /> → <XDSStatusDot />
|
|
12
|
+
* 2. JSX prop removal: <XDSProgressBar size="md" /> → <XDSProgressBar />
|
|
13
|
+
* 3. Object property removal in spread patterns: { size: "sm", ...rest } → { ...rest }
|
|
14
|
+
* 4. Destructuring removal: const { size, ...rest } = props → const { ...rest } = props
|
|
15
|
+
* 5. Type reference cleanup: XDSStatusDotSize, XDSProgressBarSize imports removed
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
const TARGET_COMPONENTS = new Set([
|
|
19
|
+
'XDSStatusDot',
|
|
20
|
+
'XDSProgressBar',
|
|
21
|
+
]);
|
|
22
|
+
|
|
23
|
+
const SIZE_TYPE_IMPORTS = new Set([
|
|
24
|
+
'XDSStatusDotSize',
|
|
25
|
+
'XDSProgressBarSize',
|
|
26
|
+
]);
|
|
27
|
+
|
|
28
|
+
export const meta = {
|
|
29
|
+
title: 'Remove size prop from StatusDot and ProgressBar',
|
|
30
|
+
description:
|
|
31
|
+
'StatusDot and ProgressBar now have a single fixed size (8px). Removes the `size` prop from JSX, object literals, destructuring patterns, and cleans up size type imports.',
|
|
32
|
+
pr: '#966',
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export default function transformer(file, api) {
|
|
36
|
+
const j = api.jscodeshift;
|
|
37
|
+
const root = j(file.source);
|
|
38
|
+
let hasChanges = false;
|
|
39
|
+
|
|
40
|
+
// 1. Remove size JSX prop from target components
|
|
41
|
+
root
|
|
42
|
+
.find(j.JSXOpeningElement)
|
|
43
|
+
.filter((path) => {
|
|
44
|
+
const name = path.node.name;
|
|
45
|
+
// Handle simple names like <XDSStatusDot>
|
|
46
|
+
if (name.type === 'JSXIdentifier') {
|
|
47
|
+
return TARGET_COMPONENTS.has(name.name);
|
|
48
|
+
}
|
|
49
|
+
return false;
|
|
50
|
+
})
|
|
51
|
+
.forEach((path) => {
|
|
52
|
+
const attrs = path.node.attributes;
|
|
53
|
+
const sizeIdx = attrs.findIndex(
|
|
54
|
+
(attr) =>
|
|
55
|
+
attr.type === 'JSXAttribute' &&
|
|
56
|
+
attr.name &&
|
|
57
|
+
attr.name.name === 'size',
|
|
58
|
+
);
|
|
59
|
+
if (sizeIdx !== -1) {
|
|
60
|
+
attrs.splice(sizeIdx, 1);
|
|
61
|
+
hasChanges = true;
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
// 2. Remove size type imports (XDSStatusDotSize, XDSProgressBarSize)
|
|
66
|
+
root.find(j.ImportDeclaration).forEach((path) => {
|
|
67
|
+
const specifiers = path.node.specifiers;
|
|
68
|
+
if (!specifiers) return;
|
|
69
|
+
|
|
70
|
+
const toRemove = [];
|
|
71
|
+
for (let i = 0; i < specifiers.length; i++) {
|
|
72
|
+
const spec = specifiers[i];
|
|
73
|
+
const importedName =
|
|
74
|
+
spec.imported?.name || spec.local?.name;
|
|
75
|
+
if (importedName && SIZE_TYPE_IMPORTS.has(importedName)) {
|
|
76
|
+
toRemove.push(i);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
if (toRemove.length > 0) {
|
|
81
|
+
// Remove in reverse order to preserve indices
|
|
82
|
+
for (let i = toRemove.length - 1; i >= 0; i--) {
|
|
83
|
+
specifiers.splice(toRemove[i], 1);
|
|
84
|
+
}
|
|
85
|
+
// If no specifiers left, remove entire import
|
|
86
|
+
if (specifiers.length === 0) {
|
|
87
|
+
j(path).remove();
|
|
88
|
+
}
|
|
89
|
+
hasChanges = true;
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
return hasChanges ? root.toSource() : undefined;
|
|
94
|
+
}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
import {describe, it, expect} from 'vitest';
|
|
4
|
+
|
|
5
|
+
async function applyTransform(source, filePath = 'test.tsx') {
|
|
6
|
+
const {default: transform} = await import('../add-is-icon-only.mjs');
|
|
7
|
+
const jscodeshift = (await import('jscodeshift')).default;
|
|
8
|
+
const j = filePath.endsWith('.ts') || filePath.endsWith('.tsx') ? jscodeshift.withParser('tsx') : jscodeshift;
|
|
9
|
+
const api = {jscodeshift: j, stats: () => {}, report: () => {}};
|
|
10
|
+
return transform({source, path: filePath}, api) ?? source;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
describe('add-is-icon-only', () => {
|
|
14
|
+
it('converts icon-only button to XDSIconButton', async () => {
|
|
15
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
16
|
+
<XDSButton label="Settings" icon={<GearIcon />} variant="ghost" />`;
|
|
17
|
+
const output = await applyTransform(input);
|
|
18
|
+
expect(output).toContain('XDSIconButton');
|
|
19
|
+
expect(output).not.toContain('XDSButton');
|
|
20
|
+
expect(output).toContain('@xds/core/IconButton');
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it('skips button with JSX children', async () => {
|
|
24
|
+
const input = '<XDSButton label="Save" icon={<SaveIcon />}>Save</XDSButton>';
|
|
25
|
+
expect(await applyTransform(input)).not.toContain('XDSIconButton');
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
it('skips button with children prop', async () => {
|
|
29
|
+
const input = '<XDSButton label="Save" icon={<SaveIcon />} children="Save" />';
|
|
30
|
+
expect(await applyTransform(input)).not.toContain('XDSIconButton');
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it('skips button without icon', async () => {
|
|
34
|
+
const input = '<XDSButton label="Submit" variant="primary" />';
|
|
35
|
+
expect(await applyTransform(input)).not.toContain('XDSIconButton');
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('skips button that already has isIconOnly', async () => {
|
|
39
|
+
const input = '<XDSButton label="Settings" icon={<GearIcon />} isIconOnly />';
|
|
40
|
+
expect(await applyTransform(input)).toBe(input);
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
it('handles multiple buttons — converts only icon-only ones', async () => {
|
|
44
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
45
|
+
<>
|
|
46
|
+
<XDSButton label="A" icon={<I />} />
|
|
47
|
+
<XDSButton label="B" />
|
|
48
|
+
<XDSButton label="C" icon={<I />} />
|
|
49
|
+
</>`;
|
|
50
|
+
const output = await applyTransform(input);
|
|
51
|
+
expect((output.match(/XDSIconButton/g) || []).length).toBeGreaterThanOrEqual(2);
|
|
52
|
+
// XDSButton should remain for the non-icon-only one
|
|
53
|
+
expect(output).toContain('XDSButton');
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it('does NOT convert XDSToggleButton', async () => {
|
|
57
|
+
const input = '<XDSToggleButton label="Bold" icon={<B />} value="bold" />';
|
|
58
|
+
expect(await applyTransform(input)).not.toContain('XDSIconButton');
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it('removes redundant children matching label', async () => {
|
|
62
|
+
const input = '<XDSButton label="Save" icon={<SaveIcon />}>Save</XDSButton>';
|
|
63
|
+
const output = await applyTransform(input);
|
|
64
|
+
expect(output).not.toContain('>Save<');
|
|
65
|
+
expect(output).toContain('/>');
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it('preserves children differing from label', async () => {
|
|
69
|
+
const input = '<XDSButton label="Close dialog" icon={<X />}>Close</XDSButton>';
|
|
70
|
+
expect(await applyTransform(input)).toContain('>Close<');
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it('adds isIconOnly to DropdownMenu button object', async () => {
|
|
74
|
+
const input = "<XDSDropdownMenu button={{ label: 'More', icon: <I /> }} items={[]} />";
|
|
75
|
+
expect(await applyTransform(input)).toContain('isIconOnly: true');
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it('skips DropdownMenu button object with children', async () => {
|
|
79
|
+
const input = "<XDSDropdownMenu button={{ label: 'X', icon: <I />, children: 'X' }} items={[]} />";
|
|
80
|
+
expect(await applyTransform(input)).not.toContain('isIconOnly');
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it('skips unrelated components', async () => {
|
|
84
|
+
const input = '<XDSAvatar icon={<P />} name="U" />';
|
|
85
|
+
expect(await applyTransform(input)).not.toContain('XDSIconButton');
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it('returns undefined when no changes needed', async () => {
|
|
89
|
+
const {default: transform} = await import('../add-is-icon-only.mjs');
|
|
90
|
+
const jscodeshift = (await import('jscodeshift')).default;
|
|
91
|
+
const j = jscodeshift.withParser('tsx');
|
|
92
|
+
const result = transform({source: '<XDSButton label="X" />', path: 'test.tsx'}, {jscodeshift: j, stats: () => {}, report: () => {}});
|
|
93
|
+
expect(result).toBeUndefined();
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it('removes endContent when converting to XDSIconButton', async () => {
|
|
97
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
98
|
+
<XDSButton label="X" icon={<I />} endContent={<Badge />} />`;
|
|
99
|
+
const output = await applyTransform(input);
|
|
100
|
+
expect(output).toContain('XDSIconButton');
|
|
101
|
+
expect(output).not.toContain('endContent');
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it('replaces Button import when no XDSButton usage remains', async () => {
|
|
105
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
106
|
+
<XDSButton label="X" icon={<I />} />`;
|
|
107
|
+
const output = await applyTransform(input);
|
|
108
|
+
expect(output).toContain('@xds/core/IconButton');
|
|
109
|
+
expect(output).not.toContain('@xds/core/Button');
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it('keeps Button import when XDSButton still used', async () => {
|
|
113
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
114
|
+
<><XDSButton label="A" icon={<I />} /><XDSButton label="B" variant="primary" /></>`;
|
|
115
|
+
const output = await applyTransform(input);
|
|
116
|
+
expect(output).toContain('@xds/core/Button');
|
|
117
|
+
expect(output).toContain('@xds/core/IconButton');
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
it('adds XDSIconButton to barrel import', async () => {
|
|
121
|
+
const input = `import {XDSButton, XDSBadge} from '@xds/core';
|
|
122
|
+
<XDSButton label="X" icon={<I />} />`;
|
|
123
|
+
const output = await applyTransform(input);
|
|
124
|
+
expect(output).toContain('XDSIconButton');
|
|
125
|
+
expect(output).toContain("from '@xds/core'");
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it('updates closing tag for non-self-closing elements', async () => {
|
|
129
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
130
|
+
<XDSButton label="X" icon={<I />}></XDSButton>`;
|
|
131
|
+
const output = await applyTransform(input);
|
|
132
|
+
expect(output).toContain('</XDSIconButton>');
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
// Bug fixes (#1346)
|
|
136
|
+
|
|
137
|
+
it('does not produce double semicolons after use client directive', async () => {
|
|
138
|
+
const input = `'use client';
|
|
139
|
+
|
|
140
|
+
import {XDSButton} from '@xds/core/Button';
|
|
141
|
+
|
|
142
|
+
function Foo() {
|
|
143
|
+
return <XDSButton label="X" icon={<I />} />;
|
|
144
|
+
}`;
|
|
145
|
+
const output = await applyTransform(input);
|
|
146
|
+
expect(output).not.toContain(';;');
|
|
147
|
+
expect(output).toContain("'use client'");
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
it('may produce double semicolons from jscodeshift bug (runner fixes this)', async () => {
|
|
151
|
+
// jscodeshift has a known bug where inserting new imports corrupts
|
|
152
|
+
// directive prologues. The runner's fixDirectiveCorruption() handles
|
|
153
|
+
// this — see validation.test.mjs for runner-level tests.
|
|
154
|
+
const input = `'use client';
|
|
155
|
+
|
|
156
|
+
import {XDSButton} from '@xds/core/Button';
|
|
157
|
+
import {SomeIcon} from '@heroicons/react/24/outline';
|
|
158
|
+
|
|
159
|
+
export function F() {
|
|
160
|
+
return <><XDSButton label="X" icon={<I />} /><XDSButton label="Y" variant="primary" /></>;
|
|
161
|
+
}`;
|
|
162
|
+
const output = await applyTransform(input);
|
|
163
|
+
// The transform itself works correctly
|
|
164
|
+
expect(output).toContain('XDSIconButton');
|
|
165
|
+
expect(output).toContain('XDSButton');
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
it('splits type imports to correct module when replacing Button import', async () => {
|
|
169
|
+
const input = `import {XDSButton, type XDSButtonProps} from '@xds/core/Button';
|
|
170
|
+
|
|
171
|
+
function Foo(props: XDSButtonProps) {
|
|
172
|
+
return <XDSButton label="X" icon={<I />} />;
|
|
173
|
+
}`;
|
|
174
|
+
const output = await applyTransform(input);
|
|
175
|
+
// Type import should stay on @xds/core/Button
|
|
176
|
+
expect(output).toContain("XDSButtonProps");
|
|
177
|
+
expect(output).toContain("'@xds/core/Button'");
|
|
178
|
+
// Component import should be on @xds/core/IconButton
|
|
179
|
+
expect(output).toContain("XDSIconButton");
|
|
180
|
+
expect(output).toContain("'@xds/core/IconButton'");
|
|
181
|
+
// XDSButton should NOT be in any import (it was the only value import)
|
|
182
|
+
expect(output).not.toMatch(/import.*XDSButton[^P]/);
|
|
183
|
+
});
|
|
184
|
+
|
|
185
|
+
it('uses single quotes for new imports', async () => {
|
|
186
|
+
const input = `import {XDSButton} from '@xds/core/Button';
|
|
187
|
+
<><XDSButton label="A" icon={<I />} /><XDSButton label="B" variant="primary" /></>`;
|
|
188
|
+
const output = await applyTransform(input);
|
|
189
|
+
// New IconButton import should use single quotes
|
|
190
|
+
expect(output).toContain("from '@xds/core/IconButton'");
|
|
191
|
+
expect(output).not.toContain('from "@xds/core/IconButton"');
|
|
192
|
+
});
|
|
193
|
+
});
|
|
@@ -0,0 +1,316 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file Codemod: Migrate pre-v0.0.12 icon-only XDSButton to XDSIconButton
|
|
5
|
+
* @see https://github.com/facebookexperimental/xds/issues/1321
|
|
6
|
+
*
|
|
7
|
+
* Migration codemod for code written against v0.0.11 or earlier.
|
|
8
|
+
*
|
|
9
|
+
* Prior to v0.0.12, XDSButton inferred icon-only mode when `icon` was
|
|
10
|
+
* present and no `children` were provided — the label was used as
|
|
11
|
+
* aria-label only and the button rendered as a square icon button.
|
|
12
|
+
*
|
|
13
|
+
* In v0.0.12, that implicit inference is removed. `label` is always
|
|
14
|
+
* rendered as visible text. Without this codemod, existing icon-only
|
|
15
|
+
* buttons will start showing their label text alongside the icon.
|
|
16
|
+
*
|
|
17
|
+
* This codemod converts those implicit icon-only usages to the new
|
|
18
|
+
* explicit `<XDSIconButton>` component, which is always icon-only by
|
|
19
|
+
* design — no boolean prop to forget, visible in JSX, greppable.
|
|
20
|
+
*
|
|
21
|
+
* Detection: a JSX element was implicitly icon-only when it has:
|
|
22
|
+
* 1. An `icon` prop (any value)
|
|
23
|
+
* 2. No `children` prop AND no JSX children (self-closing or empty)
|
|
24
|
+
* 3. No existing `isIconOnly` prop (already migrated)
|
|
25
|
+
*
|
|
26
|
+
* Also handles:
|
|
27
|
+
* - Object literals in forwarding components (XDSDropdownMenu, XDSMoreMenu)
|
|
28
|
+
* — these get `isIconOnly: true` since they pass props internally
|
|
29
|
+
* - Removing redundant `children` that duplicate `label` on icon+text buttons
|
|
30
|
+
*
|
|
31
|
+
* Run on demand: `astryx upgrade --from 0.0.11 --to 0.0.12 --codemod add-is-icon-only`
|
|
32
|
+
*/
|
|
33
|
+
|
|
34
|
+
const TARGET_COMPONENTS = new Set([
|
|
35
|
+
'XDSButton',
|
|
36
|
+
]);
|
|
37
|
+
|
|
38
|
+
/** Components whose button-like object props get isIconOnly: true added. */
|
|
39
|
+
const FORWARDING_COMPONENTS = new Set([
|
|
40
|
+
'XDSDropdownMenu',
|
|
41
|
+
'XDSMoreMenu',
|
|
42
|
+
]);
|
|
43
|
+
|
|
44
|
+
export const meta = {
|
|
45
|
+
title: 'Migrate pre-v0.0.12 icon-only buttons to XDSIconButton',
|
|
46
|
+
description:
|
|
47
|
+
'Converts implicit icon-only <XDSButton icon={...} label="..." /> (v0.0.11 pattern) ' +
|
|
48
|
+
'to the explicit <XDSIconButton> component introduced in v0.0.12. ' +
|
|
49
|
+
'Also adds isIconOnly to forwarding component object configs.',
|
|
50
|
+
pr: '#1321',
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
export default function transformer(file, api) {
|
|
54
|
+
const j = api.jscodeshift;
|
|
55
|
+
const root = j(file.source);
|
|
56
|
+
let hasChanges = false;
|
|
57
|
+
let needsIconButtonImport = false;
|
|
58
|
+
let hasRemainingXDSButton = false;
|
|
59
|
+
|
|
60
|
+
// Insert a new node after a target node in the program body.
|
|
61
|
+
// Uses direct body manipulation instead of jscodeshift's insertAfter(),
|
|
62
|
+
// which has a known bug that corrupts 'use client' directives into
|
|
63
|
+
// double semicolons ('use client';;).
|
|
64
|
+
function insertAfterInBody(targetPath, newNode) {
|
|
65
|
+
const body = root.get().node.program.body;
|
|
66
|
+
const targetIndex = body.indexOf(targetPath.node);
|
|
67
|
+
if (targetIndex !== -1) {
|
|
68
|
+
body.splice(targetIndex + 1, 0, newNode);
|
|
69
|
+
} else {
|
|
70
|
+
// Fallback: insert after all imports
|
|
71
|
+
const lastImportIdx = body.findLastIndex(
|
|
72
|
+
(n) => n.type === 'ImportDeclaration',
|
|
73
|
+
);
|
|
74
|
+
body.splice(lastImportIdx + 1, 0, newNode);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// ---- 1. JSX elements: convert icon-only XDSButton to XDSIconButton ----
|
|
79
|
+
root.find(j.JSXOpeningElement).forEach((path) => {
|
|
80
|
+
const name = path.node.name;
|
|
81
|
+
const componentName =
|
|
82
|
+
name.type === 'JSXIdentifier' ? name.name : null;
|
|
83
|
+
if (!componentName || !TARGET_COMPONENTS.has(componentName)) return;
|
|
84
|
+
|
|
85
|
+
const attrs = path.node.attributes;
|
|
86
|
+
|
|
87
|
+
const hasIcon = attrs.some(
|
|
88
|
+
(a) => a.type === 'JSXAttribute' && a.name?.name === 'icon',
|
|
89
|
+
);
|
|
90
|
+
const hasChildren = attrs.some(
|
|
91
|
+
(a) => a.type === 'JSXAttribute' && a.name?.name === 'children',
|
|
92
|
+
);
|
|
93
|
+
const hasIsIconOnly = attrs.some(
|
|
94
|
+
(a) => a.type === 'JSXAttribute' && a.name?.name === 'isIconOnly',
|
|
95
|
+
);
|
|
96
|
+
|
|
97
|
+
if (!hasIcon || hasChildren || hasIsIconOnly) return;
|
|
98
|
+
|
|
99
|
+
// Check for JSX children (non-whitespace text or elements)
|
|
100
|
+
const parent = path.parent.node;
|
|
101
|
+
const hasJSXChildren =
|
|
102
|
+
parent.type === 'JSXElement' &&
|
|
103
|
+
parent.children &&
|
|
104
|
+
parent.children.some((child) => {
|
|
105
|
+
if (child.type === 'JSXText') return child.value.trim() !== '';
|
|
106
|
+
return true;
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
if (hasJSXChildren) return;
|
|
110
|
+
|
|
111
|
+
// This is an icon-only button — convert to XDSIconButton
|
|
112
|
+
name.name = 'XDSIconButton';
|
|
113
|
+
|
|
114
|
+
// Remove endContent prop (XDSIconButton doesn't accept it)
|
|
115
|
+
for (let i = attrs.length - 1; i >= 0; i--) {
|
|
116
|
+
if (attrs[i].type === 'JSXAttribute' && attrs[i].name?.name === 'endContent') {
|
|
117
|
+
attrs.splice(i, 1);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// Update closing element if present
|
|
122
|
+
if (parent.type === 'JSXElement' && parent.closingElement) {
|
|
123
|
+
parent.closingElement.name.name = 'XDSIconButton';
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
needsIconButtonImport = true;
|
|
127
|
+
hasChanges = true;
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
// ---- 2. Remove redundant children that match label ----
|
|
131
|
+
root.find(j.JSXElement).forEach((path) => {
|
|
132
|
+
const opening = path.node.openingElement;
|
|
133
|
+
const name = opening.name;
|
|
134
|
+
const componentName =
|
|
135
|
+
name.type === 'JSXIdentifier' ? name.name : null;
|
|
136
|
+
if (!componentName || !TARGET_COMPONENTS.has(componentName)) return;
|
|
137
|
+
|
|
138
|
+
const attrs = opening.attributes;
|
|
139
|
+
const hasIcon = attrs.some(
|
|
140
|
+
(a) => a.type === 'JSXAttribute' && a.name?.name === 'icon',
|
|
141
|
+
);
|
|
142
|
+
if (!hasIcon) return;
|
|
143
|
+
|
|
144
|
+
// Get label value
|
|
145
|
+
const labelAttr = attrs.find(
|
|
146
|
+
(a) => a.type === 'JSXAttribute' && a.name?.name === 'label',
|
|
147
|
+
);
|
|
148
|
+
if (!labelAttr || !labelAttr.value) return;
|
|
149
|
+
|
|
150
|
+
let labelValue = null;
|
|
151
|
+
if (labelAttr.value.type === 'StringLiteral' || labelAttr.value.type === 'Literal') {
|
|
152
|
+
labelValue = labelAttr.value.value;
|
|
153
|
+
}
|
|
154
|
+
if (!labelValue) return;
|
|
155
|
+
|
|
156
|
+
// Check if children is a single text node matching label
|
|
157
|
+
const children = path.node.children;
|
|
158
|
+
if (!children || children.length !== 1) return;
|
|
159
|
+
|
|
160
|
+
const child = children[0];
|
|
161
|
+
if (child.type === 'JSXText' && child.value.trim() === labelValue) {
|
|
162
|
+
path.node.children = [];
|
|
163
|
+
path.node.closingElement = null;
|
|
164
|
+
opening.selfClosing = true;
|
|
165
|
+
hasChanges = true;
|
|
166
|
+
}
|
|
167
|
+
if (
|
|
168
|
+
child.type === 'JSXExpressionContainer' &&
|
|
169
|
+
(child.expression.type === 'StringLiteral' || child.expression.type === 'Literal') &&
|
|
170
|
+
child.expression.value === labelValue
|
|
171
|
+
) {
|
|
172
|
+
path.node.children = [];
|
|
173
|
+
path.node.closingElement = null;
|
|
174
|
+
opening.selfClosing = true;
|
|
175
|
+
hasChanges = true;
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
// ---- 3. Object literals: add isIconOnly to button config objects ----
|
|
180
|
+
root.find(j.JSXOpeningElement).forEach((path) => {
|
|
181
|
+
const name = path.node.name;
|
|
182
|
+
const componentName =
|
|
183
|
+
name.type === 'JSXIdentifier' ? name.name : null;
|
|
184
|
+
if (!componentName || !FORWARDING_COMPONENTS.has(componentName)) return;
|
|
185
|
+
|
|
186
|
+
const attrs = path.node.attributes;
|
|
187
|
+
const buttonAttr = attrs.find(
|
|
188
|
+
(a) =>
|
|
189
|
+
a.type === 'JSXAttribute' &&
|
|
190
|
+
a.name?.name === 'button' &&
|
|
191
|
+
a.value?.type === 'JSXExpressionContainer' &&
|
|
192
|
+
a.value.expression.type === 'ObjectExpression',
|
|
193
|
+
);
|
|
194
|
+
if (!buttonAttr) return;
|
|
195
|
+
|
|
196
|
+
const obj = buttonAttr.value.expression;
|
|
197
|
+
const props = obj.properties;
|
|
198
|
+
|
|
199
|
+
const hasIcon = props.some(
|
|
200
|
+
(p) => (p.type === 'Property' || p.type === 'ObjectProperty') && p.key?.name === 'icon',
|
|
201
|
+
);
|
|
202
|
+
const hasChildren = props.some(
|
|
203
|
+
(p) => (p.type === 'Property' || p.type === 'ObjectProperty') && p.key?.name === 'children',
|
|
204
|
+
);
|
|
205
|
+
const hasIsIconOnly = props.some(
|
|
206
|
+
(p) => (p.type === 'Property' || p.type === 'ObjectProperty') && p.key?.name === 'isIconOnly',
|
|
207
|
+
);
|
|
208
|
+
|
|
209
|
+
if (hasIcon && !hasChildren && !hasIsIconOnly) {
|
|
210
|
+
props.push(
|
|
211
|
+
j.property('init', j.identifier('isIconOnly'), j.literal(true)),
|
|
212
|
+
);
|
|
213
|
+
hasChanges = true;
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
if (!hasChanges) return undefined;
|
|
218
|
+
|
|
219
|
+
// ---- 4. Update imports ----
|
|
220
|
+
// Check if any XDSButton JSX usage remains
|
|
221
|
+
root.find(j.JSXIdentifier, {name: 'XDSButton'}).forEach(() => {
|
|
222
|
+
hasRemainingXDSButton = true;
|
|
223
|
+
});
|
|
224
|
+
// Also check for XDSButton in type annotations (e.g. typeof XDSButton)
|
|
225
|
+
root.find(j.Identifier, {name: 'XDSButton'}).forEach((path) => {
|
|
226
|
+
// Skip JSX identifiers (already counted above) and import specifiers
|
|
227
|
+
if (path.parent.node.type === 'JSXOpeningElement' ||
|
|
228
|
+
path.parent.node.type === 'JSXClosingElement' ||
|
|
229
|
+
path.parent.node.type === 'ImportSpecifier') return;
|
|
230
|
+
hasRemainingXDSButton = true;
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
if (needsIconButtonImport) {
|
|
234
|
+
let alreadyImported = false;
|
|
235
|
+
root.find(j.ImportDeclaration).forEach((path) => {
|
|
236
|
+
if (path.node.specifiers.some(
|
|
237
|
+
(s) => s.type === 'ImportSpecifier' && s.imported.name === 'XDSIconButton',
|
|
238
|
+
)) {
|
|
239
|
+
alreadyImported = true;
|
|
240
|
+
}
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
if (!alreadyImported) {
|
|
244
|
+
// Handle @xds/core/Button import — may need splitting if it has
|
|
245
|
+
// other specifiers (type imports, other components)
|
|
246
|
+
if (!hasRemainingXDSButton) {
|
|
247
|
+
root.find(j.ImportDeclaration).forEach((path) => {
|
|
248
|
+
if (alreadyImported) return;
|
|
249
|
+
const source = path.node.source.value;
|
|
250
|
+
if (source !== '@xds/core/Button') return;
|
|
251
|
+
const specs = path.node.specifiers;
|
|
252
|
+
const btnIdx = specs.findIndex(
|
|
253
|
+
(s) => s.type === 'ImportSpecifier' && s.imported.name === 'XDSButton',
|
|
254
|
+
);
|
|
255
|
+
if (btnIdx === -1) return;
|
|
256
|
+
|
|
257
|
+
// Remove XDSButton from this import
|
|
258
|
+
specs.splice(btnIdx, 1);
|
|
259
|
+
|
|
260
|
+
if (specs.length === 0) {
|
|
261
|
+
// No other specifiers — replace the entire import
|
|
262
|
+
specs.push(j.importSpecifier(j.identifier('XDSIconButton')));
|
|
263
|
+
path.node.source = j.stringLiteral('@xds/core/IconButton');
|
|
264
|
+
} else {
|
|
265
|
+
// Other specifiers remain (type imports, etc.) — keep this import
|
|
266
|
+
// for them and add a new one for XDSIconButton
|
|
267
|
+
const newImport = j.importDeclaration(
|
|
268
|
+
[j.importSpecifier(j.identifier('XDSIconButton'))],
|
|
269
|
+
j.stringLiteral('@xds/core/IconButton'),
|
|
270
|
+
);
|
|
271
|
+
insertAfterInBody(path, newImport);
|
|
272
|
+
}
|
|
273
|
+
alreadyImported = true;
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
// For barrel imports, add the specifier
|
|
278
|
+
if (!alreadyImported) {
|
|
279
|
+
root.find(j.ImportDeclaration).forEach((path) => {
|
|
280
|
+
if (alreadyImported) return;
|
|
281
|
+
if (path.node.source.value === '@xds/core') {
|
|
282
|
+
path.node.specifiers.push(
|
|
283
|
+
j.importSpecifier(j.identifier('XDSIconButton')),
|
|
284
|
+
);
|
|
285
|
+
alreadyImported = true;
|
|
286
|
+
}
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
// Otherwise add a new import after the last @xds import
|
|
291
|
+
if (!alreadyImported) {
|
|
292
|
+
const newImport = j.importDeclaration(
|
|
293
|
+
[j.importSpecifier(j.identifier('XDSIconButton'))],
|
|
294
|
+
j.stringLiteral('@xds/core/IconButton'),
|
|
295
|
+
);
|
|
296
|
+
|
|
297
|
+
const xdsImports = root
|
|
298
|
+
.find(j.ImportDeclaration)
|
|
299
|
+
.filter((p) => p.node.source.value.startsWith('@xds/'));
|
|
300
|
+
|
|
301
|
+
if (xdsImports.length > 0) {
|
|
302
|
+
insertAfterInBody(xdsImports.at(-1), newImport);
|
|
303
|
+
} else {
|
|
304
|
+
const allImports = root.find(j.ImportDeclaration);
|
|
305
|
+
if (allImports.length > 0) {
|
|
306
|
+
insertAfterInBody(allImports.at(-1), newImport);
|
|
307
|
+
} else {
|
|
308
|
+
root.get().node.program.body.unshift(newImport);
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
return root.toSource({quote: 'single'});
|
|
316
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @file v0.0.12 transform manifest
|
|
5
|
+
*
|
|
6
|
+
* Lists all codemods for the v0.0.12 release in the order they should run.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import addIsIconOnly, {
|
|
10
|
+
meta as addIsIconOnlyMeta,
|
|
11
|
+
} from './add-is-icon-only.mjs';
|
|
12
|
+
|
|
13
|
+
export default [
|
|
14
|
+
{
|
|
15
|
+
name: 'add-is-icon-only',
|
|
16
|
+
transform: addIsIconOnly,
|
|
17
|
+
meta: addIsIconOnlyMeta,
|
|
18
|
+
// Optional: heuristic-based detection can produce false positives.
|
|
19
|
+
// A button with icon + no children might intentionally show the label
|
|
20
|
+
// in v0.0.12. Run explicitly with --codemod add-is-icon-only after
|
|
21
|
+
// visually verifying the results.
|
|
22
|
+
optional: true,
|
|
23
|
+
},
|
|
24
|
+
];
|