@yahoo/uds 3.117.0 → 3.117.2
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/dist/automated-config/dist/utils/getConfigVariantComponentStatesMatrix.cjs +2 -3
- package/dist/automated-config/dist/utils/getConfigVariantProperties.cjs +2 -3
- package/dist/automated-config/dist/utils/getConfigVariants.cjs +2 -3
- package/dist/automated-config/dist/utils/index.cjs +3 -6
- package/dist/components/client/Menu/Menu.ItemCheckbox.d.cts +1 -1
- package/dist/components/client/Menu/Menu.ItemCheckbox.d.ts +1 -1
- package/dist/styles/styler.d.cts +53 -53
- package/dist/styles/styler.d.ts +53 -53
- package/dist/tailwind/dist/_virtual/_rolldown/runtime.cjs +27 -8
- package/dist/tailwind/dist/_virtual/_rolldown/runtime.js +3 -6
- package/dist/tailwind/dist/cli.cjs +11 -0
- package/dist/tailwind/dist/cli.d.cts +6 -0
- package/dist/tailwind/dist/cli.d.ts +6 -0
- package/dist/tailwind/dist/cli.js +7 -0
- package/dist/tailwind/dist/commands/css.cjs +36 -37
- package/dist/tailwind/dist/commands/css.d.cts +14 -0
- package/dist/tailwind/dist/commands/css.d.cts.map +1 -0
- package/dist/tailwind/dist/commands/css.d.ts +14 -0
- package/dist/tailwind/dist/commands/css.d.ts.map +1 -0
- package/dist/tailwind/dist/commands/css.helpers.cjs +2 -3
- package/dist/tailwind/dist/commands/css.helpers.js +3 -3
- package/dist/tailwind/dist/commands/css.helpers.js.map +1 -0
- package/dist/tailwind/dist/commands/css.js +5 -6
- package/dist/tailwind/dist/commands/css.js.map +1 -0
- package/dist/tailwind/dist/commands/generateComponentData.cjs +13 -14
- package/dist/tailwind/dist/commands/generateComponentData.d.cts +24 -0
- package/dist/tailwind/dist/commands/generateComponentData.d.cts.map +1 -0
- package/dist/tailwind/dist/commands/generateComponentData.d.ts +22 -1
- package/dist/tailwind/dist/commands/generateComponentData.d.ts.map +1 -0
- package/dist/tailwind/dist/commands/generateComponentData.js +6 -6
- package/dist/tailwind/dist/commands/generateComponentData.js.map +1 -0
- package/dist/tailwind/dist/commands/generatePurgeCSSData.cjs +5 -7
- package/dist/tailwind/dist/commands/generatePurgeCSSData.d.cts +15 -0
- package/dist/tailwind/dist/commands/generatePurgeCSSData.d.cts.map +1 -0
- package/dist/tailwind/dist/commands/generatePurgeCSSData.d.ts +15 -0
- package/dist/tailwind/dist/commands/generatePurgeCSSData.d.ts.map +1 -0
- package/dist/tailwind/dist/commands/generatePurgeCSSData.js +5 -6
- package/dist/tailwind/dist/commands/generatePurgeCSSData.js.map +1 -0
- package/dist/tailwind/dist/commands/purge.cjs +15 -16
- package/dist/tailwind/dist/commands/purge.d.cts +17 -0
- package/dist/tailwind/dist/commands/purge.d.cts.map +1 -0
- package/dist/tailwind/dist/commands/purge.d.ts +17 -0
- package/dist/tailwind/dist/commands/purge.d.ts.map +1 -0
- package/dist/tailwind/dist/commands/purge.js +5 -6
- package/dist/tailwind/dist/commands/purge.js.map +1 -0
- package/dist/tailwind/dist/css/generate.cjs +13 -16
- package/dist/tailwind/dist/css/generate.d.cts +3 -4
- package/dist/tailwind/dist/css/generate.d.cts.map +1 -0
- package/dist/tailwind/dist/css/generate.d.ts +3 -4
- package/dist/tailwind/dist/css/generate.d.ts.map +1 -0
- package/dist/tailwind/dist/css/generate.helpers.cjs +6 -6
- package/dist/tailwind/dist/css/generate.helpers.js +7 -6
- package/dist/tailwind/dist/css/generate.helpers.js.map +1 -0
- package/dist/tailwind/dist/css/generate.js +7 -9
- package/dist/tailwind/dist/css/generate.js.map +1 -0
- package/dist/tailwind/dist/css/nodeUtils.cjs +14 -16
- package/dist/tailwind/dist/css/nodeUtils.js +6 -7
- package/dist/tailwind/dist/css/nodeUtils.js.map +1 -0
- package/dist/tailwind/dist/css/postcss.cjs +2 -3
- package/dist/tailwind/dist/css/postcss.helpers.cjs +2 -3
- package/dist/tailwind/dist/css/postcss.helpers.js +3 -3
- package/dist/tailwind/dist/css/postcss.helpers.js.map +1 -0
- package/dist/tailwind/dist/css/postcss.js +4 -4
- package/dist/tailwind/dist/css/postcss.js.map +1 -0
- package/dist/tailwind/dist/css/runner.cjs +40 -35
- package/dist/tailwind/dist/css/runner.helpers.cjs +3 -4
- package/dist/tailwind/dist/css/runner.helpers.js +4 -4
- package/dist/tailwind/dist/css/runner.helpers.js.map +1 -0
- package/dist/tailwind/dist/css/runner.js +17 -11
- package/dist/tailwind/dist/css/runner.js.map +1 -0
- package/dist/tailwind/dist/css/theme.cjs +2 -3
- package/dist/tailwind/dist/css/theme.d.cts +13 -5
- package/dist/tailwind/dist/css/theme.d.cts.map +1 -0
- package/dist/tailwind/dist/css/theme.d.ts +13 -5
- package/dist/tailwind/dist/css/theme.d.ts.map +1 -0
- package/dist/tailwind/dist/css/theme.js +3 -3
- package/dist/tailwind/dist/css/theme.js.map +1 -0
- package/dist/tailwind/dist/css/utils.cjs +5 -5
- package/dist/tailwind/dist/css/utils.js +5 -5
- package/dist/tailwind/dist/css/utils.js.map +1 -0
- package/dist/tailwind/dist/index.cjs +9 -0
- package/dist/tailwind/dist/index.d.cts +3 -2
- package/dist/tailwind/dist/index.d.ts +3 -2
- package/dist/tailwind/dist/index.js +6 -0
- package/dist/tailwind/dist/plugin.cjs +7 -6
- package/dist/tailwind/dist/plugin.d.cts +3 -3
- package/dist/tailwind/dist/plugin.d.cts.map +1 -0
- package/dist/tailwind/dist/plugin.d.ts +3 -3
- package/dist/tailwind/dist/plugin.d.ts.map +1 -0
- package/dist/tailwind/dist/plugin.js +4 -4
- package/dist/tailwind/dist/plugin.js.map +1 -0
- package/dist/tailwind/dist/purger/legacy/index.d.ts +2 -0
- package/dist/tailwind/dist/purger/legacy/purgeCSS.cjs +25 -24
- package/dist/tailwind/dist/purger/legacy/purgeCSS.d.cts +24 -0
- package/dist/tailwind/dist/purger/legacy/purgeCSS.d.cts.map +1 -0
- package/dist/tailwind/dist/purger/legacy/purgeCSS.d.ts +24 -0
- package/dist/tailwind/dist/purger/legacy/purgeCSS.d.ts.map +1 -0
- package/dist/tailwind/dist/purger/legacy/purgeCSS.js +8 -9
- package/dist/tailwind/dist/purger/legacy/purgeCSS.js.map +1 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.cjs +59 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.d.cts +28 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.d.cts.map +1 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.d.ts +28 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.d.ts.map +1 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.js +59 -0
- package/dist/tailwind/dist/purger/legacy/purgeFromCode.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/ast/expressions.cjs +5 -6
- package/dist/tailwind/dist/purger/optimized/ast/expressions.d.ts +2 -0
- package/dist/tailwind/dist/purger/optimized/ast/expressions.js +5 -5
- package/dist/tailwind/dist/purger/optimized/ast/expressions.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/ast/index.d.ts +5 -0
- package/dist/tailwind/dist/purger/optimized/ast/jsx.cjs +3 -4
- package/dist/tailwind/dist/purger/optimized/ast/jsx.d.ts +3 -0
- package/dist/tailwind/dist/purger/optimized/ast/jsx.js +4 -4
- package/dist/tailwind/dist/purger/optimized/ast/jsx.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/ast/props.d.ts +2 -0
- package/dist/tailwind/dist/purger/optimized/ast/spread.d.ts +3 -0
- package/dist/tailwind/dist/purger/optimized/index.d.ts +6 -0
- package/dist/tailwind/dist/purger/optimized/purge.cjs +5 -6
- package/dist/tailwind/dist/purger/optimized/purge.d.ts +2 -0
- package/dist/tailwind/dist/purger/optimized/purge.js +5 -5
- package/dist/tailwind/dist/purger/optimized/purge.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.cjs +3 -4
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.d.cts +58 -0
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.d.cts.map +1 -0
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.d.ts +58 -0
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.d.ts.map +1 -0
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.js +4 -4
- package/dist/tailwind/dist/purger/optimized/purgeFromCode.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/types.d.cts +22 -0
- package/dist/tailwind/dist/purger/optimized/types.d.cts.map +1 -0
- package/dist/tailwind/dist/purger/optimized/types.d.ts +23 -0
- package/dist/tailwind/dist/purger/optimized/types.d.ts.map +1 -0
- package/dist/tailwind/dist/purger/optimized/utils/componentAnalyzer.cjs +8 -9
- package/dist/tailwind/dist/purger/optimized/utils/componentAnalyzer.js +7 -7
- package/dist/tailwind/dist/purger/optimized/utils/componentAnalyzer.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/utils/files.cjs +3 -4
- package/dist/tailwind/dist/purger/optimized/utils/files.d.ts +2 -0
- package/dist/tailwind/dist/purger/optimized/utils/files.js +4 -4
- package/dist/tailwind/dist/purger/optimized/utils/files.js.map +1 -0
- package/dist/tailwind/dist/purger/optimized/utils/safelist.cjs +7 -8
- package/dist/tailwind/dist/purger/optimized/utils/safelist.js +6 -6
- package/dist/tailwind/dist/purger/optimized/utils/safelist.js.map +1 -0
- package/dist/tailwind/dist/purger.cjs +7 -0
- package/dist/tailwind/dist/purger.d.cts +4 -0
- package/dist/tailwind/dist/purger.d.ts +6 -0
- package/dist/tailwind/dist/purger.js +5 -0
- package/dist/tailwind/dist/tailwind/base/addColorModeVars.cjs +10 -10
- package/dist/tailwind/dist/tailwind/base/addColorModeVars.js +6 -6
- package/dist/tailwind/dist/tailwind/base/addColorModeVars.js.map +1 -0
- package/dist/tailwind/dist/tailwind/base/addColorModeVarsV2.cjs +14 -14
- package/dist/tailwind/dist/tailwind/base/addColorModeVarsV2.js +6 -6
- package/dist/tailwind/dist/tailwind/base/addColorModeVarsV2.js.map +1 -0
- package/dist/tailwind/dist/tailwind/base/addFontFaceDeclarations.cjs +2 -3
- package/dist/tailwind/dist/tailwind/base/addFontFaceDeclarations.js +4 -4
- package/dist/tailwind/dist/tailwind/base/addFontFaceDeclarations.js.map +1 -0
- package/dist/tailwind/dist/tailwind/base/addFontVars.cjs +2 -3
- package/dist/tailwind/dist/tailwind/base/addFontVars.js +4 -4
- package/dist/tailwind/dist/tailwind/base/addFontVars.js.map +1 -0
- package/dist/tailwind/dist/tailwind/base/addMotionVars.cjs +2 -3
- package/dist/tailwind/dist/tailwind/base/addMotionVars.js +4 -4
- package/dist/tailwind/dist/tailwind/base/addMotionVars.js.map +1 -0
- package/dist/tailwind/dist/tailwind/base/addScaleModeVars.cjs +13 -13
- package/dist/tailwind/dist/tailwind/base/addScaleModeVars.js +6 -6
- package/dist/tailwind/dist/tailwind/base/addScaleModeVars.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getFocusRingStyles.cjs +6 -6
- package/dist/tailwind/dist/tailwind/components/getFocusRingStyles.js +5 -5
- package/dist/tailwind/dist/tailwind/components/getFocusRingStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getGroupedTextStyles.cjs +12 -12
- package/dist/tailwind/dist/tailwind/components/getGroupedTextStyles.js +6 -6
- package/dist/tailwind/dist/tailwind/components/getGroupedTextStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getHitTargetStyles.cjs +2 -3
- package/dist/tailwind/dist/tailwind/components/getHitTargetStyles.js +3 -3
- package/dist/tailwind/dist/tailwind/components/getHitTargetStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getIconStyles.cjs +2 -3
- package/dist/tailwind/dist/tailwind/components/getIconStyles.js +3 -3
- package/dist/tailwind/dist/tailwind/components/getIconStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getInputStyles.cjs +2 -3
- package/dist/tailwind/dist/tailwind/components/getInputStyles.d.cts +3 -3
- package/dist/tailwind/dist/tailwind/components/getInputStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getInputStyles.d.ts +3 -3
- package/dist/tailwind/dist/tailwind/components/getInputStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getInputStyles.js +3 -3
- package/dist/tailwind/dist/tailwind/components/getInputStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.cjs +29 -29
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.d.cts +6 -4
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.d.ts +6 -4
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.js +8 -8
- package/dist/tailwind/dist/tailwind/components/getResponsiveTextStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/components/types.d.cts +3 -3
- package/dist/tailwind/dist/tailwind/components/types.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/components/types.d.ts +3 -3
- package/dist/tailwind/dist/tailwind/components/types.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.cjs +2 -3
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.d.cts +6 -6
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.d.ts +6 -6
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.js +3 -3
- package/dist/tailwind/dist/tailwind/defaultTailwindThemeAsUdsConfig.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/a11y.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/a11y.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/a11y.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/blurBgFallback.cjs +7 -8
- package/dist/tailwind/dist/tailwind/plugins/blurBgFallback.js +5 -5
- package/dist/tailwind/dist/tailwind/plugins/blurBgFallback.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/borderRadius.cjs +8 -9
- package/dist/tailwind/dist/tailwind/plugins/borderRadius.js +7 -7
- package/dist/tailwind/dist/tailwind/plugins/borderRadius.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/borderWidth.cjs +8 -9
- package/dist/tailwind/dist/tailwind/plugins/borderWidth.js +7 -7
- package/dist/tailwind/dist/tailwind/plugins/borderWidth.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/breakpoints.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/breakpoints.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/breakpoints.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/colors.cjs +17 -17
- package/dist/tailwind/dist/tailwind/plugins/colors.js +9 -9
- package/dist/tailwind/dist/tailwind/plugins/colors.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/components.cjs +25 -26
- package/dist/tailwind/dist/tailwind/plugins/components.js +7 -7
- package/dist/tailwind/dist/tailwind/plugins/components.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/elevation.cjs +7 -8
- package/dist/tailwind/dist/tailwind/plugins/elevation.js +6 -6
- package/dist/tailwind/dist/tailwind/plugins/elevation.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/getTailwindAsUdsColors.cjs +5 -5
- package/dist/tailwind/dist/tailwind/plugins/getTailwindAsUdsColors.js +5 -5
- package/dist/tailwind/dist/tailwind/plugins/getTailwindAsUdsColors.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/icons.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/icons.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/icons.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/input.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/input.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/input.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/motion.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/motion.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/motion.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/nestedBorderRadius.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/nestedBorderRadius.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/nestedBorderRadius.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/scaleMode.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/scaleMode.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/scaleMode.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/shadows.cjs +8 -9
- package/dist/tailwind/dist/tailwind/plugins/shadows.js +5 -5
- package/dist/tailwind/dist/tailwind/plugins/shadows.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/sizing.cjs +5 -6
- package/dist/tailwind/dist/tailwind/plugins/sizing.js +5 -5
- package/dist/tailwind/dist/tailwind/plugins/sizing.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/spacing.cjs +3 -4
- package/dist/tailwind/dist/tailwind/plugins/spacing.js +4 -4
- package/dist/tailwind/dist/tailwind/plugins/spacing.js.map +1 -0
- package/dist/tailwind/dist/tailwind/plugins/typography.cjs +10 -11
- package/dist/tailwind/dist/tailwind/plugins/typography.js +7 -7
- package/dist/tailwind/dist/tailwind/plugins/typography.js.map +1 -0
- package/dist/tailwind/dist/tailwind/theme/getFontFamilyTheme.cjs +9 -9
- package/dist/tailwind/dist/tailwind/theme/getFontFamilyTheme.js +6 -6
- package/dist/tailwind/dist/tailwind/theme/getFontFamilyTheme.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.cjs +3 -4
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.d.ts +4 -4
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.js +4 -4
- package/dist/tailwind/dist/tailwind/utils/addFontsPlugin.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.cjs +15 -9
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.d.ts +5 -5
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.js +7 -7
- package/dist/tailwind/dist/tailwind/utils/composeTailwindPlugins.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.cjs +2 -3
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.d.cts +3 -3
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.d.ts +3 -3
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.js +3 -3
- package/dist/tailwind/dist/tailwind/utils/getColorModeStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.cjs +9 -9
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.d.ts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.js +5 -5
- package/dist/tailwind/dist/tailwind/utils/getElevationStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.cjs +5 -5
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.d.ts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.js +5 -5
- package/dist/tailwind/dist/tailwind/utils/getFontFaceDeclarations.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.cjs +7 -7
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.d.ts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.js +6 -6
- package/dist/tailwind/dist/tailwind/utils/getFontStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.cjs +7 -7
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.d.cts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.d.ts +4 -4
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.js +6 -6
- package/dist/tailwind/dist/tailwind/utils/getMotionStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getNestedBorderRadiusUtilities.cjs +2 -3
- package/dist/tailwind/dist/tailwind/utils/getNestedBorderRadiusUtilities.js +3 -3
- package/dist/tailwind/dist/tailwind/utils/getNestedBorderRadiusUtilities.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.cjs +2 -3
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.d.cts +3 -3
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.d.ts +3 -3
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.js +3 -3
- package/dist/tailwind/dist/tailwind/utils/getScaleModeStyles.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.cjs +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.d.cts +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.d.ts +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.js +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowPresetValues.js.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.cjs +6 -6
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.d.cts +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.d.cts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.d.ts +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.d.ts.map +1 -0
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.js +5 -5
- package/dist/tailwind/dist/tailwind/utils/getShadowStyles.js.map +1 -0
- package/dist/tailwind/dist/utils/assertUnreachable.cjs +2 -3
- package/dist/tailwind/dist/utils/assertUnreachable.js +3 -3
- package/dist/tailwind/dist/utils/assertUnreachable.js.map +1 -0
- package/dist/tailwind/dist/utils/entries.cjs +2 -3
- package/dist/tailwind/dist/utils/entries.js +3 -3
- package/dist/tailwind/dist/utils/entries.js.map +1 -0
- package/dist/tailwind/dist/utils/entryPoints.cjs +5 -6
- package/dist/tailwind/dist/utils/entryPoints.js +5 -5
- package/dist/tailwind/dist/utils/entryPoints.js.map +1 -0
- package/dist/tailwind/dist/utils/fromEntries.cjs +2 -3
- package/dist/tailwind/dist/utils/fromEntries.js +3 -3
- package/dist/tailwind/dist/utils/fromEntries.js.map +1 -0
- package/dist/tailwind/dist/utils/generatePurgeCSSData.cjs +11 -13
- package/dist/tailwind/dist/utils/generatePurgeCSSData.js +7 -8
- package/dist/tailwind/dist/utils/generatePurgeCSSData.js.map +1 -0
- package/dist/tailwind/dist/utils/mapValues.cjs +2 -3
- package/dist/tailwind/dist/utils/mapValues.js +3 -3
- package/dist/tailwind/dist/utils/mapValues.js.map +1 -0
- package/dist/tailwind/dist/utils/opacity.cjs +6 -6
- package/dist/tailwind/dist/utils/opacity.js +4 -4
- package/dist/tailwind/dist/utils/opacity.js.map +1 -0
- package/dist/tailwind/dist/utils/optimizeCSS.cjs +3 -4
- package/dist/tailwind/dist/utils/optimizeCSS.js +4 -4
- package/dist/tailwind/dist/utils/optimizeCSS.js.map +1 -0
- package/dist/tailwind/dist/utils/parseTokens.cjs +32 -32
- package/dist/tailwind/dist/utils/parseTokens.d.cts +5 -5
- package/dist/tailwind/dist/utils/parseTokens.d.cts.map +1 -0
- package/dist/tailwind/dist/utils/parseTokens.d.ts +5 -5
- package/dist/tailwind/dist/utils/parseTokens.d.ts.map +1 -0
- package/dist/tailwind/dist/utils/parseTokens.js +6 -6
- package/dist/tailwind/dist/utils/parseTokens.js.map +1 -0
- package/dist/tailwind/dist/utils/postcssPreserveVars.cjs +2 -3
- package/dist/tailwind/dist/utils/postcssPreserveVars.js +3 -3
- package/dist/tailwind/dist/utils/postcssPreserveVars.js.map +1 -0
- package/dist/tailwind/dist/utils/tsMorph.cjs +13 -11
- package/dist/tailwind/dist/utils/tsMorph.js +4 -4
- package/dist/tailwind/dist/utils/tsMorph.js.map +1 -0
- package/dist/tailwind/dist/utils.cjs +25 -0
- package/dist/tailwind/dist/utils.d.cts +2 -1
- package/dist/tailwind/dist/utils.d.ts +2 -1
- package/dist/tailwind/dist/utils.js +13 -0
- package/dist/uds/generated/componentData.cjs +145 -145
- package/dist/uds/generated/componentData.js +145 -145
- package/generated/componentData.json +209 -209
- package/package.json +1 -1
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
|
|
2
|
+
import { GeneratedPurgeCSSData } from "./purgeCSS.cjs";
|
|
3
|
+
|
|
4
|
+
//#region src/purger/legacy/purgeFromCode.d.ts
|
|
5
|
+
interface PurgeFromCodeResult {
|
|
6
|
+
safelist: string[];
|
|
7
|
+
imports: string[];
|
|
8
|
+
components: string[];
|
|
9
|
+
error?: string;
|
|
10
|
+
}
|
|
11
|
+
interface PurgeFromCodeOptions {
|
|
12
|
+
colorModes?: ('dark' | 'light')[];
|
|
13
|
+
variants: Record<string, Record<string, string>>;
|
|
14
|
+
packageJson: Record<string, any>;
|
|
15
|
+
generatedPurgeCssData: GeneratedPurgeCSSData;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Run the legacy purger on a code string and return the safelist.
|
|
19
|
+
* This uses the same logic as the CLI `uds purge` command but with in-memory files.
|
|
20
|
+
*
|
|
21
|
+
* @param code - The TypeScript/TSX code to analyze
|
|
22
|
+
* @param options - Configuration options for color modes
|
|
23
|
+
* @returns The purge result containing safelist, imports, and components
|
|
24
|
+
*/
|
|
25
|
+
declare function purgeFromCode(code: string, options: PurgeFromCodeOptions): PurgeFromCodeResult;
|
|
26
|
+
//#endregion
|
|
27
|
+
export { type PurgeFromCodeResult, purgeFromCode };
|
|
28
|
+
//# sourceMappingURL=purgeFromCode.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purgeFromCode.d.cts","names":[],"sources":["../../../src/purger/legacy/purgeFromCode.ts"],"mappings":";;;;UAUU,mBAAA;EACR,QAAA;EACA,OAAA;EACA,UAAA;EACA,KAAA;AAAA;AAAA,UAGQ,oBAAA;EACR,UAAA;EACA,QAAA,EAAU,MAAA,SAAe,MAAA;EAEzB,WAAA,EAAa,MAAA;EACb,qBAAA,EAAuB,qBAAA;AAAA;AARlB;;;;;;;;AAAA,iBAwBE,aAAA,CAAc,IAAA,UAAc,OAAA,EAAS,oBAAA,GAAuB,mBAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
|
|
2
|
+
import { GeneratedPurgeCSSData } from "./purgeCSS.js";
|
|
3
|
+
|
|
4
|
+
//#region src/purger/legacy/purgeFromCode.d.ts
|
|
5
|
+
interface PurgeFromCodeResult {
|
|
6
|
+
safelist: string[];
|
|
7
|
+
imports: string[];
|
|
8
|
+
components: string[];
|
|
9
|
+
error?: string;
|
|
10
|
+
}
|
|
11
|
+
interface PurgeFromCodeOptions {
|
|
12
|
+
colorModes?: ('dark' | 'light')[];
|
|
13
|
+
variants: Record<string, Record<string, string>>;
|
|
14
|
+
packageJson: Record<string, any>;
|
|
15
|
+
generatedPurgeCssData: GeneratedPurgeCSSData;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Run the legacy purger on a code string and return the safelist.
|
|
19
|
+
* This uses the same logic as the CLI `uds purge` command but with in-memory files.
|
|
20
|
+
*
|
|
21
|
+
* @param code - The TypeScript/TSX code to analyze
|
|
22
|
+
* @param options - Configuration options for color modes
|
|
23
|
+
* @returns The purge result containing safelist, imports, and components
|
|
24
|
+
*/
|
|
25
|
+
declare function purgeFromCode(code: string, options: PurgeFromCodeOptions): PurgeFromCodeResult;
|
|
26
|
+
//#endregion
|
|
27
|
+
export { type PurgeFromCodeOptions, type PurgeFromCodeResult, purgeFromCode };
|
|
28
|
+
//# sourceMappingURL=purgeFromCode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purgeFromCode.d.ts","names":[],"sources":["../../../src/purger/legacy/purgeFromCode.ts"],"mappings":";;;;UAUU,mBAAA;EACR,QAAA;EACA,OAAA;EACA,UAAA;EACA,KAAA;AAAA;AAAA,UAGQ,oBAAA;EACR,UAAA;EACA,QAAA,EAAU,MAAA,SAAe,MAAA;EAEzB,WAAA,EAAa,MAAA;EACb,qBAAA,EAAuB,qBAAA;AAAA;AARlB;;;;;;;;AAAA,iBAwBE,aAAA,CAAc,IAAA,UAAc,OAAA,EAAS,oBAAA,GAAuB,mBAAA"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
|
+
import { getComponentsToConvertToTW, getTailwindSafelist, parseFiles } from "./purgeCSS.js";
|
|
3
|
+
import { DARK_COLOR_MODE_CLASSNAME, LARGE_SCALE_MODE_CLASSNAME, LIGHT_COLOR_MODE_CLASSNAME } from "@yahoo/uds-css-tokens";
|
|
4
|
+
import { Project, ts } from "ts-morph";
|
|
5
|
+
|
|
6
|
+
//#region src/purger/legacy/purgeFromCode.ts
|
|
7
|
+
const COLOR_MODE_CLASSES = {
|
|
8
|
+
dark: DARK_COLOR_MODE_CLASSNAME,
|
|
9
|
+
light: LIGHT_COLOR_MODE_CLASSNAME
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Run the legacy purger on a code string and return the safelist.
|
|
13
|
+
* This uses the same logic as the CLI `uds purge` command but with in-memory files.
|
|
14
|
+
*
|
|
15
|
+
* @param code - The TypeScript/TSX code to analyze
|
|
16
|
+
* @param options - Configuration options for color modes
|
|
17
|
+
* @returns The purge result containing safelist, imports, and components
|
|
18
|
+
*/
|
|
19
|
+
function purgeFromCode(code, options) {
|
|
20
|
+
const { colorModes = ["dark", "light"] } = options;
|
|
21
|
+
try {
|
|
22
|
+
const project = new Project({
|
|
23
|
+
useInMemoryFileSystem: true,
|
|
24
|
+
compilerOptions: {
|
|
25
|
+
jsx: ts.JsxEmit.ReactJSX,
|
|
26
|
+
jsxImportSource: "react",
|
|
27
|
+
target: ts.ScriptTarget.ESNext,
|
|
28
|
+
module: ts.ModuleKind.ESNext,
|
|
29
|
+
moduleResolution: ts.ModuleResolutionKind.NodeJs,
|
|
30
|
+
esModuleInterop: true,
|
|
31
|
+
strict: true
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
const imports = parseFiles(project, [project.createSourceFile("user-code.tsx", code).getFilePath()]);
|
|
35
|
+
const components = getComponentsToConvertToTW(imports, options.generatedPurgeCssData);
|
|
36
|
+
const safelist = getTailwindSafelist(project, components, options.variants, options.generatedPurgeCssData, options.packageJson);
|
|
37
|
+
for (const mode of colorModes) {
|
|
38
|
+
const cls = COLOR_MODE_CLASSES[mode];
|
|
39
|
+
if (cls) safelist.push(cls);
|
|
40
|
+
}
|
|
41
|
+
safelist.push(LARGE_SCALE_MODE_CLASSNAME);
|
|
42
|
+
return {
|
|
43
|
+
safelist: Array.from(new Set(safelist)),
|
|
44
|
+
imports,
|
|
45
|
+
components
|
|
46
|
+
};
|
|
47
|
+
} catch (error) {
|
|
48
|
+
return {
|
|
49
|
+
safelist: [],
|
|
50
|
+
imports: [],
|
|
51
|
+
components: [],
|
|
52
|
+
error: error instanceof Error ? error.message : "Unknown error"
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
//#endregion
|
|
58
|
+
export { purgeFromCode };
|
|
59
|
+
//# sourceMappingURL=purgeFromCode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purgeFromCode.js","names":[],"sources":["../../../src/purger/legacy/purgeFromCode.ts"],"sourcesContent":["import {\n DARK_COLOR_MODE_CLASSNAME,\n LARGE_SCALE_MODE_CLASSNAME,\n LIGHT_COLOR_MODE_CLASSNAME,\n} from '@yahoo/uds-css-tokens';\nimport { Project, ts } from 'ts-morph';\n\nimport type { GeneratedPurgeCSSData } from './purgeCSS';\nimport { getComponentsToConvertToTW, getTailwindSafelist, parseFiles } from './purgeCSS';\n\ninterface PurgeFromCodeResult {\n safelist: string[];\n imports: string[];\n components: string[];\n error?: string;\n}\n\ninterface PurgeFromCodeOptions {\n colorModes?: ('dark' | 'light')[];\n variants: Record<string, Record<string, string>>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n packageJson: Record<string, any>;\n generatedPurgeCssData: GeneratedPurgeCSSData;\n}\n\nconst COLOR_MODE_CLASSES: Record<string, string> = {\n dark: DARK_COLOR_MODE_CLASSNAME,\n light: LIGHT_COLOR_MODE_CLASSNAME,\n};\n\n/**\n * Run the legacy purger on a code string and return the safelist.\n * This uses the same logic as the CLI `uds purge` command but with in-memory files.\n *\n * @param code - The TypeScript/TSX code to analyze\n * @param options - Configuration options for color modes\n * @returns The purge result containing safelist, imports, and components\n */\nfunction purgeFromCode(code: string, options: PurgeFromCodeOptions): PurgeFromCodeResult {\n const { colorModes = ['dark', 'light'] } = options;\n\n try {\n const project = new Project({\n useInMemoryFileSystem: true,\n compilerOptions: {\n jsx: ts.JsxEmit.ReactJSX,\n jsxImportSource: 'react',\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.ESNext,\n moduleResolution: ts.ModuleResolutionKind.NodeJs,\n esModuleInterop: true,\n strict: true,\n },\n });\n\n const sourceFile = project.createSourceFile('user-code.tsx', code);\n\n const imports = parseFiles(project, [sourceFile.getFilePath()]);\n const components = getComponentsToConvertToTW(imports, options.generatedPurgeCssData);\n const safelist = getTailwindSafelist(\n project,\n components,\n options.variants,\n options.generatedPurgeCssData,\n options.packageJson,\n );\n\n // Add color mode classes\n for (const mode of colorModes) {\n const cls = COLOR_MODE_CLASSES[mode];\n if (cls) {\n safelist.push(cls);\n }\n }\n\n // Always include large scale mode\n safelist.push(LARGE_SCALE_MODE_CLASSNAME);\n\n return {\n safelist: Array.from(new Set(safelist)),\n imports,\n components,\n };\n } catch (error) {\n return {\n safelist: [],\n imports: [],\n components: [],\n error: error instanceof Error ? error.message : 'Unknown error',\n };\n }\n}\n\nexport type { PurgeFromCodeOptions, PurgeFromCodeResult };\nexport { purgeFromCode };\n"],"mappings":";;;;;;AAyBA,MAAM,qBAA6C;CACjD,MAAM;CACN,OAAO;CACR;;;;;;;;;AAUD,SAAS,cAAc,MAAc,SAAoD;CACvF,MAAM,EAAE,aAAa,CAAC,QAAQ,QAAQ,KAAK;AAE3C,KAAI;EACF,MAAM,UAAU,IAAI,QAAQ;GAC1B,uBAAuB;GACvB,iBAAiB;IACf,KAAK,GAAG,QAAQ;IAChB,iBAAiB;IACjB,QAAQ,GAAG,aAAa;IACxB,QAAQ,GAAG,WAAW;IACtB,kBAAkB,GAAG,qBAAqB;IAC1C,iBAAiB;IACjB,QAAQ;IACT;GACF,CAAC;EAIF,MAAM,UAAU,WAAW,SAAS,CAFjB,QAAQ,iBAAiB,iBAAiB,KAAK,CAElB,aAAa,CAAC,CAAC;EAC/D,MAAM,aAAa,2BAA2B,SAAS,QAAQ,sBAAsB;EACrF,MAAM,WAAW,oBACf,SACA,YACA,QAAQ,UACR,QAAQ,uBACR,QAAQ,YACT;AAGD,OAAK,MAAM,QAAQ,YAAY;GAC7B,MAAM,MAAM,mBAAmB;AAC/B,OAAI,IACF,UAAS,KAAK,IAAI;;AAKtB,WAAS,KAAK,2BAA2B;AAEzC,SAAO;GACL,UAAU,MAAM,KAAK,IAAI,IAAI,SAAS,CAAC;GACvC;GACA;GACD;UACM,OAAO;AACd,SAAO;GACL,UAAU,EAAE;GACZ,SAAS,EAAE;GACX,YAAY,EAAE;GACd,OAAO,iBAAiB,QAAQ,MAAM,UAAU;GACjD"}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
2
|
-
const require_runtime = require('
|
|
3
|
-
let node_path = require("node:path");
|
|
4
|
-
node_path = require_runtime.__toESM(node_path);
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
|
+
const require_runtime = require('../../../_virtual/_rolldown/runtime.cjs');
|
|
5
3
|
let node_fs = require("node:fs");
|
|
6
4
|
node_fs = require_runtime.__toESM(node_fs);
|
|
5
|
+
let node_path = require("node:path");
|
|
6
|
+
node_path = require_runtime.__toESM(node_path);
|
|
7
7
|
let ts_morph = require("ts-morph");
|
|
8
8
|
|
|
9
|
-
//#region
|
|
10
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
9
|
+
//#region src/purger/optimized/ast/expressions.ts
|
|
11
10
|
const importedSourceProject = new ts_morph.Project({ useInMemoryFileSystem: true });
|
|
12
11
|
const importedSourceFileCache = /* @__PURE__ */ new Map();
|
|
13
12
|
const tsConfigPathCache = /* @__PURE__ */ new Map();
|
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
2
|
-
import path from "node:path";
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
3
2
|
import fs from "node:fs";
|
|
3
|
+
import path from "node:path";
|
|
4
4
|
import { Node, Project, SyntaxKind, ts } from "ts-morph";
|
|
5
5
|
|
|
6
|
-
//#region
|
|
7
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
6
|
+
//#region src/purger/optimized/ast/expressions.ts
|
|
8
7
|
const importedSourceProject = new Project({ useInMemoryFileSystem: true });
|
|
9
8
|
const importedSourceFileCache = /* @__PURE__ */ new Map();
|
|
10
9
|
const tsConfigPathCache = /* @__PURE__ */ new Map();
|
|
@@ -286,4 +285,5 @@ const extractLiteralValuesFromType = (node) => {
|
|
|
286
285
|
};
|
|
287
286
|
|
|
288
287
|
//#endregion
|
|
289
|
-
export { extractStringLiterals };
|
|
288
|
+
export { extractStringLiterals };
|
|
289
|
+
//# sourceMappingURL=expressions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expressions.js","names":[],"sources":["../../../../src/purger/optimized/ast/expressions.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { Node, Project, SyntaxKind, ts } from 'ts-morph';\n\nconst importedSourceProject = new Project({ useInMemoryFileSystem: true });\nconst importedSourceFileCache = new Map<string, ReturnType<Project['createSourceFile']>>();\nconst tsConfigPathCache = new Map<string, string | null>();\nconst compilerOptionsCache = new Map<string, ts.CompilerOptions | null>();\nconst hasImportQuery = (moduleSpecifier: string): boolean => moduleSpecifier.includes('?');\n\nconst isExistingFile = (candidate: string): boolean =>\n fs.existsSync(candidate) && fs.statSync(candidate).isFile();\n\nconst resolveRelativeImportPath = (\n sourceFilePath: string,\n moduleSpecifier: string,\n): string | null => {\n if (\n !path.isAbsolute(sourceFilePath) ||\n !moduleSpecifier.startsWith('.') ||\n hasImportQuery(moduleSpecifier)\n ) {\n return null;\n }\n\n const basePath = path.resolve(path.dirname(sourceFilePath), moduleSpecifier);\n const candidates = [\n basePath,\n `${basePath}.ts`,\n `${basePath}.tsx`,\n `${basePath}.js`,\n `${basePath}.jsx`,\n path.join(basePath, 'index.ts'),\n path.join(basePath, 'index.tsx'),\n path.join(basePath, 'index.js'),\n path.join(basePath, 'index.jsx'),\n ];\n\n return candidates.find((candidate) => isExistingFile(candidate)) ?? null;\n};\n\nconst findNearestTypeScriptConfig = (sourceFilePath: string): string | null => {\n const sourceDir = path.dirname(sourceFilePath);\n const cached = tsConfigPathCache.get(sourceDir);\n\n if (cached !== undefined) {\n return cached;\n }\n\n let currentDir = sourceDir;\n\n while (true) {\n const tsConfigPath = path.join(currentDir, 'tsconfig.json');\n if (isExistingFile(tsConfigPath)) {\n tsConfigPathCache.set(sourceDir, tsConfigPath);\n return tsConfigPath;\n }\n\n const jsConfigPath = path.join(currentDir, 'jsconfig.json');\n if (isExistingFile(jsConfigPath)) {\n tsConfigPathCache.set(sourceDir, jsConfigPath);\n return jsConfigPath;\n }\n\n const parentDir = path.dirname(currentDir);\n if (parentDir === currentDir) {\n tsConfigPathCache.set(sourceDir, null);\n return null;\n }\n\n currentDir = parentDir;\n }\n};\n\nconst getCompilerOptionsForSourceFile = (sourceFilePath: string): ts.CompilerOptions | null => {\n const configPath = findNearestTypeScriptConfig(sourceFilePath);\n if (!configPath) {\n return null;\n }\n\n const cached = compilerOptionsCache.get(configPath);\n if (cached !== undefined) {\n return cached;\n }\n\n const readResult = ts.readConfigFile(configPath, ts.sys.readFile);\n if (readResult.error) {\n compilerOptionsCache.set(configPath, null);\n return null;\n }\n\n const parsed = ts.parseJsonConfigFileContent(readResult.config, ts.sys, path.dirname(configPath));\n\n const compilerOptions =\n parsed.options.paths && !parsed.options.baseUrl\n ? { ...parsed.options, baseUrl: path.dirname(configPath) }\n : parsed.options;\n\n compilerOptionsCache.set(configPath, compilerOptions);\n return compilerOptions;\n};\n\nconst resolveConfigImportPath = (\n sourceFilePath: string,\n moduleSpecifier: string,\n): string | null => {\n if (hasImportQuery(moduleSpecifier)) {\n return null;\n }\n\n const compilerOptions = getCompilerOptionsForSourceFile(sourceFilePath);\n if (!compilerOptions) {\n return null;\n }\n\n const resolvedModule = ts.resolveModuleName(\n moduleSpecifier,\n sourceFilePath,\n compilerOptions,\n ts.sys,\n ).resolvedModule;\n\n if (!resolvedModule) {\n return null;\n }\n\n return isExistingFile(resolvedModule.resolvedFileName) ? resolvedModule.resolvedFileName : null;\n};\n\nconst resolveImportPath = (sourceFilePath: string, moduleSpecifier: string): string | null =>\n moduleSpecifier.startsWith('.')\n ? resolveRelativeImportPath(sourceFilePath, moduleSpecifier)\n : resolveConfigImportPath(sourceFilePath, moduleSpecifier);\n\nconst getImportedSourceFile = (filePath: string) => {\n const cached = importedSourceFileCache.get(filePath);\n if (cached) {\n return cached;\n }\n\n if (!fs.existsSync(filePath)) {\n return null;\n }\n\n const sourceFile = importedSourceProject.createSourceFile(\n filePath,\n fs.readFileSync(filePath, 'utf-8'),\n {\n overwrite: true,\n },\n );\n importedSourceFileCache.set(filePath, sourceFile);\n return sourceFile;\n};\n\nconst extractImportedIdentifierValues = (node: Node, visited: Set<Node>): string[] => {\n if (!Node.isIdentifier(node)) {\n return [];\n }\n\n const sourceFile = node.getSourceFile();\n const sourceFilePath = sourceFile.getFilePath();\n const importMatch = sourceFile\n .getImportDeclarations()\n .find((importDecl) =>\n importDecl\n .getNamedImports()\n .some(\n (namedImport) =>\n (namedImport.getAliasNode()?.getText() ?? namedImport.getName()) === node.getText(),\n ),\n );\n\n if (!importMatch) {\n return [];\n }\n\n const namedImport = importMatch\n .getNamedImports()\n .find(\n (candidate) =>\n (candidate.getAliasNode()?.getText() ?? candidate.getName()) === node.getText(),\n );\n\n if (!namedImport) {\n return [];\n }\n\n const resolvedPath = resolveImportPath(sourceFilePath, importMatch.getModuleSpecifierValue());\n if (!resolvedPath) {\n return [];\n }\n\n const importedSourceFile = getImportedSourceFile(resolvedPath);\n if (!importedSourceFile) {\n return [];\n }\n\n const declaration = importedSourceFile.getVariableDeclaration(namedImport.getName());\n const initializer = declaration?.getInitializer();\n return initializer ? extractStringLiterals(initializer, visited) : [];\n};\n\n/**\n * Extracts string literal values from an expression.\n *\n * Handles:\n * - Direct string literals: 'value'\n * - Ternary expressions: condition ? 'a' : 'b' -> ['a', 'b']\n * - Variable references: traces back to initializer\n * - Logical expressions: a || 'fallback', a ?? 'default'\n * - Function calls: traces to return statements\n * - Template literals: `value`\n * - As expressions: value as Type\n *\n * @param node The expression node to extract values from\n * @param visited Set of visited nodes to prevent infinite recursion\n * @returns Array of extracted string literal values\n */\nconst extractStringLiterals = (node: Node, visited: Set<Node> = new Set()): string[] => {\n if (visited.has(node)) {\n return [];\n }\n visited.add(node);\n\n const directValues = extractDirectLiteralValues(node);\n if (directValues) {\n return directValues;\n }\n\n const templateValues = extractTemplateExpressionValues(node, visited);\n if (templateValues) {\n return templateValues;\n }\n\n // Ternary/conditional expression: condition ? 'a' : 'b'\n if (Node.isConditionalExpression(node)) {\n return [\n ...extractStringLiterals(node.getWhenTrue(), visited),\n ...extractStringLiterals(node.getWhenFalse(), visited),\n ];\n }\n\n const binaryValues = extractBinaryExpressionValues(node, visited);\n if (binaryValues) {\n return binaryValues;\n }\n\n const wrappedExpressionValues = extractWrappedExpressionValues(node, visited);\n if (wrappedExpressionValues) {\n return wrappedExpressionValues;\n }\n\n const propertyAccessValues = extractPropertyAccessValues(node, visited);\n if (propertyAccessValues) {\n return propertyAccessValues;\n }\n\n const elementAccessValues = extractElementAccessValues(node);\n if (elementAccessValues) {\n return elementAccessValues;\n }\n\n const callExpressionValues = extractCallExpressionValues(node, visited);\n if (callExpressionValues) {\n return callExpressionValues;\n }\n\n const identifierValues = extractIdentifierValues(node, visited);\n if (identifierValues) {\n return identifierValues;\n }\n\n return [];\n};\n\nconst extractDirectLiteralValues = (node: Node): string[] | null => {\n if (Node.isStringLiteral(node) || Node.isNoSubstitutionTemplateLiteral(node)) {\n return [node.getLiteralValue()];\n }\n\n return null;\n};\n\nconst extractTemplateExpressionValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (!Node.isTemplateExpression(node)) {\n return null;\n }\n\n const parts: string[][] = [[node.getHead().getLiteralText()]];\n\n node.getTemplateSpans().forEach((span) => {\n const exprValues = extractStringLiterals(span.getExpression(), visited);\n const literalText = span.getLiteral().getLiteralText();\n parts.push(\n exprValues.length > 0\n ? exprValues.map((value) => `${value}${literalText}`)\n : ['', literalText],\n );\n });\n\n return parts\n .reduce<\n string[]\n >((acc, segment) => acc.flatMap((base) => segment.map((frag) => `${base}${frag}`)), [''])\n .filter((value) => value.length > 0);\n};\n\nconst extractBinaryExpressionValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (!Node.isBinaryExpression(node)) {\n return null;\n }\n\n const operator = node.getOperatorToken().getText();\n if (operator === '+') {\n const left = extractStringLiterals(node.getLeft(), visited);\n const right = extractStringLiterals(node.getRight(), visited);\n const combined = left.flatMap((l) => right.map((r) => `${l}${r}`));\n return combined.length > 0 ? combined : [];\n }\n\n if (operator === '||' || operator === '??') {\n return [\n ...extractStringLiterals(node.getLeft(), visited),\n ...extractStringLiterals(node.getRight(), visited),\n ];\n }\n\n return [];\n};\n\nconst extractWrappedExpressionValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (Node.isParenthesizedExpression(node) || Node.isAsExpression(node)) {\n return extractStringLiterals(node.getExpression(), visited);\n }\n\n return null;\n};\n\nconst extractPropertyAccessValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (!Node.isPropertyAccessExpression(node)) {\n return null;\n }\n\n const typeValues = extractLiteralValuesFromType(node);\n if (typeValues.length > 0) {\n return typeValues;\n }\n\n const propertyName = node.getName();\n return extractObjectValues(node.getExpression(), visited)\n .filter(\n (value): value is Record<string, unknown> =>\n typeof value === 'object' && value !== null && propertyName in value,\n )\n .map((value) => value[propertyName])\n .filter((value): value is string => typeof value === 'string');\n};\n\nconst extractElementAccessValues = (node: Node): string[] | null => {\n if (!Node.isElementAccessExpression(node)) {\n return null;\n }\n\n return extractLiteralValuesFromType(node);\n};\n\nconst extractCallExpressionValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (!Node.isCallExpression(node)) {\n return null;\n }\n\n const expression = node.getExpression();\n\n const fromDefinitions = Node.isIdentifier(expression)\n ? expression.getDefinitionNodes().flatMap((definition) => {\n if (Node.isFunctionDeclaration(definition)) {\n return definition\n .getDescendantsOfKind(SyntaxKind.ReturnStatement)\n .flatMap((returnStmt) => {\n const expression = returnStmt.getExpression();\n return expression ? extractStringLiterals(expression, visited) : [];\n });\n }\n\n if (Node.isVariableDeclaration(definition)) {\n const initializer = definition.getInitializer();\n return initializer ? extractFromFunctionLike(initializer, visited) : [];\n }\n\n return [];\n })\n : [];\n\n const fromArguments = node.getArguments().flatMap((arg) => extractStringLiterals(arg, visited));\n\n return [...fromDefinitions, ...fromArguments];\n};\n\nconst extractIdentifierValues = (node: Node, visited: Set<Node>): string[] | null => {\n if (!Node.isIdentifier(node)) {\n return null;\n }\n\n const values = node.getDefinitionNodes().flatMap((definition) => {\n if (\n Node.isVariableDeclaration(definition) ||\n Node.isParameterDeclaration(definition) ||\n Node.isBindingElement(definition)\n ) {\n const initializer = definition.getInitializer();\n return initializer ? extractStringLiterals(initializer, visited) : [];\n }\n\n return [];\n });\n\n if (values.length > 0) {\n return values;\n }\n\n const importedValues = extractImportedIdentifierValues(node, visited);\n if (importedValues.length > 0) {\n return importedValues;\n }\n\n return extractLiteralValuesFromType(node);\n};\n\n/**\n * Extract string literals from arrow functions or function expressions\n */\nconst extractFromFunctionLike = (node: Node, visited: Set<Node>): string[] => {\n const values: string[] = [];\n\n if (Node.isArrowFunction(node)) {\n const body = node.getBody();\n if (Node.isBlock(body)) {\n body.getDescendantsOfKind(SyntaxKind.ReturnStatement).forEach((returnStmt) => {\n const returnExpr = returnStmt.getExpression();\n if (returnExpr) {\n values.push(...extractStringLiterals(returnExpr, visited));\n }\n });\n } else {\n values.push(...extractStringLiterals(body, visited));\n }\n } else if (Node.isFunctionExpression(node)) {\n node.getDescendantsOfKind(SyntaxKind.ReturnStatement).forEach((returnStmt) => {\n const returnExpr = returnStmt.getExpression();\n if (returnExpr) {\n values.push(...extractStringLiterals(returnExpr, visited));\n }\n });\n }\n\n return values;\n};\n\n/**\n * Extract object literal values from an expression.\n * Returns an array of all possible object values (for union types or indexed access).\n */\nconst extractObjectValues = (node: Node, visited: Set<Node>): unknown[] => {\n if (visited.has(node)) {\n return [];\n }\n visited.add(node);\n\n const values: unknown[] = [];\n\n // Object literal expression\n if (Node.isObjectLiteralExpression(node)) {\n const obj: Record<string, unknown> = {};\n node.getProperties().forEach((prop) => {\n if (Node.isPropertyAssignment(prop)) {\n const name = prop.getName();\n const init = prop.getInitializer();\n if (init && Node.isStringLiteral(init)) {\n obj[name] = init.getLiteralValue();\n } else if (init && Node.isObjectLiteralExpression(init)) {\n const nestedValues = extractObjectValues(init, visited);\n if (nestedValues.length > 0) {\n obj[name] = nestedValues[0];\n }\n }\n }\n });\n values.push(obj);\n return values;\n }\n\n // Identifier - trace to initializer\n if (Node.isIdentifier(node)) {\n node.getDefinitionNodes().forEach((definition) => {\n if (Node.isVariableDeclaration(definition)) {\n const initializer = definition.getInitializer();\n if (initializer) {\n // Handle 'as const' assertion\n if (Node.isAsExpression(initializer)) {\n const inner = initializer.getExpression();\n values.push(...extractObjectValues(inner, visited));\n } else {\n values.push(...extractObjectValues(initializer, visited));\n }\n }\n }\n });\n return values;\n }\n\n // Element access - return all values from the object\n if (Node.isElementAccessExpression(node)) {\n const expression = node.getExpression();\n const baseObjects = extractObjectValues(expression, visited);\n\n // For indexed access, return all possible values\n baseObjects.forEach((obj) => {\n if (typeof obj === 'object' && obj !== null) {\n Object.values(obj).forEach((value) => values.push(value));\n }\n });\n return values;\n }\n\n return values;\n};\n\n/**\n * Extract literal values from a TypeScript type (for union types like 'brand' | 'secondary')\n */\nexport const extractLiteralValuesFromType = (node: Node): string[] => {\n const values: string[] = [];\n const nodeType = node.getType();\n\n if (nodeType.isUnion()) {\n nodeType.getUnionTypes().forEach((unionMember) => {\n if (unionMember.isStringLiteral()) {\n values.push(unionMember.getLiteralValue() as string);\n }\n });\n } else if (nodeType.isStringLiteral()) {\n values.push(nodeType.getLiteralValue() as string);\n }\n\n return values;\n};\n\nexport { extractStringLiterals };\n"],"mappings":"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"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
2
|
-
const require_runtime = require('
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
|
+
const require_runtime = require('../../../_virtual/_rolldown/runtime.cjs');
|
|
3
3
|
let ts_morph = require("ts-morph");
|
|
4
4
|
|
|
5
|
-
//#region
|
|
6
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
5
|
+
//#region src/purger/optimized/ast/jsx.ts
|
|
7
6
|
/**
|
|
8
7
|
* Find all JSX usages of a component from its identifier
|
|
9
8
|
*/
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
2
|
import { Node, SyntaxKind } from "ts-morph";
|
|
3
3
|
|
|
4
|
-
//#region
|
|
5
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
4
|
+
//#region src/purger/optimized/ast/jsx.ts
|
|
6
5
|
/**
|
|
7
6
|
* Find all JSX usages of a component from its identifier
|
|
8
7
|
*/
|
|
@@ -15,4 +14,5 @@ const findJsxReferences = (identifier) => {
|
|
|
15
14
|
};
|
|
16
15
|
|
|
17
16
|
//#endregion
|
|
18
|
-
export { findJsxReferences };
|
|
17
|
+
export { findJsxReferences };
|
|
18
|
+
//# sourceMappingURL=jsx.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsx.js","names":[],"sources":["../../../../src/purger/optimized/ast/jsx.ts"],"sourcesContent":["import type {\n ArrowFunction,\n CallExpression,\n FunctionDeclaration,\n FunctionExpression,\n Identifier,\n JsxElement,\n JsxSelfClosingElement,\n VariableDeclaration,\n} from 'ts-morph';\nimport { Node, SyntaxKind } from 'ts-morph';\n\nimport type { JsxElementWithAttributes, ParentComponentInfo } from '../types';\n\n/**\n * Check if an expression is using React.forwardRef\n */\nexport const isForwardRefExpression = (node: Node): node is CallExpression => {\n if (!Node.isCallExpression(node)) {\n return false;\n }\n\n const expression = node.getExpression();\n\n if (Node.isIdentifier(expression) && expression.getText() === 'forwardRef') {\n return true;\n }\n\n if (Node.isPropertyAccessExpression(expression) && expression.getText() === 'React.forwardRef') {\n return true;\n }\n\n return false;\n};\n\n/**\n * Check if a node is a JSX component (PascalCase name)\n */\nexport const isJsxComponent = (\n node: Node,\n): node is VariableDeclaration | FunctionDeclaration | FunctionExpression | ArrowFunction => {\n let name: string | undefined;\n\n if (\n Node.isVariableDeclaration(node) ||\n Node.isFunctionDeclaration(node) ||\n Node.isClassDeclaration(node)\n ) {\n name = node.getName();\n } else if (Node.isFunctionExpression(node) || Node.isArrowFunction(node)) {\n const variableDeclaration = node.getFirstAncestorByKind(SyntaxKind.VariableDeclaration);\n name = variableDeclaration?.getName();\n }\n\n return name ? /^[A-Z]/.test(name) : false;\n};\n\n/**\n * Get the function declaration from a component, unwrapping forwardRef if needed\n */\nexport const getReactFunctionDeclaration = (\n declaration: Node,\n): ArrowFunction | FunctionDeclaration | FunctionExpression | null => {\n if (!isJsxComponent(declaration)) {\n return null;\n }\n\n if (Node.isFunctionDeclaration(declaration)) {\n return declaration;\n }\n\n if (Node.isVariableDeclaration(declaration)) {\n const initializer = declaration.getInitializer();\n if (!initializer) {\n return null;\n }\n\n if (isForwardRefExpression(initializer)) {\n const [arg] = initializer.getArguments();\n if (\n Node.isFunctionDeclaration(arg) ||\n Node.isFunctionExpression(arg) ||\n Node.isArrowFunction(arg)\n ) {\n return arg;\n }\n } else if (\n Node.isFunctionDeclaration(initializer) ||\n Node.isFunctionExpression(initializer) ||\n Node.isArrowFunction(initializer)\n ) {\n return initializer;\n }\n }\n\n return null;\n};\n\n/**\n * Get all JSX elements from a node\n */\nexport const getJsxElements = (node: Node): (JsxElement | JsxSelfClosingElement)[] => {\n return node\n .getDescendants()\n .filter((n) => Node.isJsxElement(n) || Node.isJsxSelfClosingElement(n)) as (\n | JsxElement\n | JsxSelfClosingElement\n )[];\n};\n\n/**\n * Find all JSX usages of a component from its identifier\n */\nexport const findJsxReferences = (identifier: Identifier): JsxElementWithAttributes[] => {\n try {\n return identifier\n .findReferencesAsNodes()\n .map((reference) =>\n reference.getFirstAncestor(\n (n) => Node.isJsxOpeningElement(n) || Node.isJsxSelfClosingElement(n),\n ),\n )\n .filter(\n (node): node is JsxElementWithAttributes =>\n Boolean(node) && (Node.isJsxOpeningElement(node) || Node.isJsxSelfClosingElement(node)),\n );\n } catch {\n return [];\n }\n};\n\n/**\n * Get the parent component that contains a JSX reference.\n * Returns information about the component including spread rest identifier.\n */\nexport const getParentComponentInfo = (\n reference: JsxElementWithAttributes,\n): ParentComponentInfo | undefined => {\n // Walk up to find the parent component\n const block = reference.getParentWhile((parent) => !getReactFunctionDeclaration(parent));\n if (!block) {\n return undefined;\n }\n\n const blockParent = block.getParent();\n if (!blockParent) {\n return undefined;\n }\n\n const reactComponent = getReactFunctionDeclaration(blockParent);\n if (!reactComponent) {\n return undefined;\n }\n\n // Get component name\n let componentName: string | undefined;\n const variableDeclaration = reactComponent.getFirstAncestorByKind(SyntaxKind.VariableDeclaration);\n if (variableDeclaration) {\n componentName = variableDeclaration.getName();\n } else if (Node.isFunctionDeclaration(reactComponent)) {\n componentName = reactComponent.getName();\n }\n\n if (!componentName) {\n return undefined;\n }\n\n // Extract parameter info\n let spreadRestIdentifier: string | undefined;\n let paramIdentifier: string | undefined;\n\n reactComponent.getParameters().forEach((parameter) => {\n const objectBindingPattern = parameter.getChildrenOfKind(SyntaxKind.ObjectBindingPattern)[0];\n const identifier = parameter.getChildrenOfKind(SyntaxKind.Identifier)[0];\n\n if (objectBindingPattern) {\n const dotDotToken = objectBindingPattern.getFirstDescendantByKind(SyntaxKind.DotDotDotToken);\n if (dotDotToken) {\n spreadRestIdentifier = dotDotToken\n .getParent()\n ?.getFirstChildByKindOrThrow(SyntaxKind.Identifier)\n .getText();\n }\n } else if (identifier) {\n paramIdentifier = identifier.getText();\n }\n });\n\n return { componentName, spreadRestIdentifier, paramIdentifier };\n};\n"],"mappings":";;;;;;;AAiHA,MAAa,qBAAqB,eAAuD;AACvF,KAAI;AACF,SAAO,WACJ,uBAAuB,CACvB,KAAK,cACJ,UAAU,kBACP,MAAM,KAAK,oBAAoB,EAAE,IAAI,KAAK,wBAAwB,EAAE,CACtE,CACF,CACA,QACE,SACC,QAAQ,KAAK,KAAK,KAAK,oBAAoB,KAAK,IAAI,KAAK,wBAAwB,KAAK,EACzF;SACG;AACN,SAAO,EAAE"}
|
|
@@ -1,16 +1,15 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
2
|
-
const require_runtime = require('
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
|
+
const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
|
|
3
3
|
const require_purgeFromCode = require('./purgeFromCode.cjs');
|
|
4
4
|
const require_entryPoints = require('../../utils/entryPoints.cjs');
|
|
5
5
|
const require_safelist = require('./utils/safelist.cjs');
|
|
6
6
|
const require_files = require('./utils/files.cjs');
|
|
7
|
-
let node_path = require("node:path");
|
|
8
|
-
node_path = require_runtime.__toESM(node_path);
|
|
9
7
|
let node_fs = require("node:fs");
|
|
10
8
|
node_fs = require_runtime.__toESM(node_fs);
|
|
9
|
+
let node_path = require("node:path");
|
|
10
|
+
node_path = require_runtime.__toESM(node_path);
|
|
11
11
|
|
|
12
|
-
//#region
|
|
13
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
12
|
+
//#region src/purger/optimized/purge.ts
|
|
14
13
|
const warnedLocations = /* @__PURE__ */ new Set();
|
|
15
14
|
/**
|
|
16
15
|
* Clear warned locations (call at start of new purge run)
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
2
|
import { purgeFromCodeOptimized } from "./purgeFromCode.js";
|
|
3
3
|
import { DEFAULT_ENTRY } from "../../utils/entryPoints.js";
|
|
4
4
|
import { deduplicateSafelist, getThemeAndScaleClasses, saveSafelistToFile } from "./utils/safelist.js";
|
|
5
5
|
import { scanForFiles } from "./utils/files.js";
|
|
6
|
-
import path from "node:path";
|
|
7
6
|
import fs from "node:fs";
|
|
7
|
+
import path from "node:path";
|
|
8
8
|
|
|
9
|
-
//#region
|
|
10
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
9
|
+
//#region src/purger/optimized/purge.ts
|
|
11
10
|
const warnedLocations = /* @__PURE__ */ new Set();
|
|
12
11
|
/**
|
|
13
12
|
* Clear warned locations (call at start of new purge run)
|
|
@@ -65,4 +64,5 @@ const purgeOptimized = async (options) => {
|
|
|
65
64
|
};
|
|
66
65
|
|
|
67
66
|
//#endregion
|
|
68
|
-
export { purgeOptimized };
|
|
67
|
+
export { purgeOptimized };
|
|
68
|
+
//# sourceMappingURL=purge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purge.js","names":[],"sources":["../../../src/purger/optimized/purge.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { DEFAULT_ENTRY } from '../../utils/entryPoints';\nimport { purgeFromCodeOptimized } from './purgeFromCode';\nimport type { PurgeOptions, PurgeResult, PurgeStats } from './types';\nimport { scanForFiles } from './utils/files';\nimport { deduplicateSafelist, getThemeAndScaleClasses, saveSafelistToFile } from './utils/safelist';\n\n// Track warned locations to avoid duplicates\nconst warnedLocations = new Set<string>();\n\n/**\n * Clear warned locations (call at start of new purge run)\n */\nexport const clearWarnings = (): void => {\n warnedLocations.clear();\n};\n\n/**\n * Main purge function - optimized version\n *\n * Uses purgeFromCodeOptimized internally to ensure consistent behavior\n * between CLI and playground.\n */\nexport const purgeOptimized = async (options: PurgeOptions): Promise<PurgeResult> => {\n const {\n entry = DEFAULT_ENTRY,\n output = 'dist/safelist.ts',\n colorModes = ['dark'], // Light mode is already in :root\n variants,\n autoVariants,\n componentData,\n } = options;\n\n const startTime = performance.now();\n clearWarnings();\n\n const workspaceDir = process.env.PWD ?? process.cwd();\n\n const files = await scanForFiles(entry);\n\n // Aggregate results from all files\n const allClasses: string[] = [];\n const allImports = new Set<string>();\n const allComponents = new Set<string>();\n\n const stats: PurgeStats = {\n filesScanned: files.length,\n timeMs: 0,\n classesGenerated: 0,\n spreadsTraced: 0,\n expressionsResolved: 0,\n };\n\n // Process each file using purgeFromCodeOptimized\n const results = await Promise.all(\n files.map(async (filePath) => {\n const code = fs.readFileSync(filePath, 'utf-8');\n return purgeFromCodeOptimized(code, {\n colorModes,\n variants,\n autoVariants,\n componentData,\n });\n }),\n );\n\n results.forEach((result) => {\n allClasses.push(...result.safelist);\n result.imports.forEach((imp) => allImports.add(imp));\n result.components.forEach((comp) => allComponents.add(comp));\n stats.spreadsTraced += result.stats.spreadsTraced;\n stats.expressionsResolved += result.stats.expressionsResolved;\n });\n\n // Add color mode classes\n allClasses.push(...getThemeAndScaleClasses(colorModes));\n\n const finalSafelist = deduplicateSafelist(allClasses).sort();\n\n await saveSafelistToFile(finalSafelist, path.join(workspaceDir, output));\n\n stats.timeMs = Math.round(performance.now() - startTime);\n stats.classesGenerated = finalSafelist.length;\n\n return {\n safelist: finalSafelist,\n imports: [...allImports],\n components: [...allComponents],\n stats,\n };\n};\n"],"mappings":";;;;;;;;;AAUA,MAAM,kCAAkB,IAAI,KAAa;;;;AAKzC,MAAa,sBAA4B;AACvC,iBAAgB,OAAO;;;;;;;;AASzB,MAAa,iBAAiB,OAAO,YAAgD;CACnF,MAAM,EACJ,QAAQ,eACR,SAAS,oBACT,aAAa,CAAC,OAAO,EACrB,UACA,cACA,kBACE;CAEJ,MAAM,YAAY,YAAY,KAAK;AACnC,gBAAe;CAEf,MAAM,eAAe,QAAQ,IAAI,OAAO,QAAQ,KAAK;CAErD,MAAM,QAAQ,MAAM,aAAa,MAAM;CAGvC,MAAM,aAAuB,EAAE;CAC/B,MAAM,6BAAa,IAAI,KAAa;CACpC,MAAM,gCAAgB,IAAI,KAAa;CAEvC,MAAM,QAAoB;EACxB,cAAc,MAAM;EACpB,QAAQ;EACR,kBAAkB;EAClB,eAAe;EACf,qBAAqB;EACtB;AAeD,EAZgB,MAAM,QAAQ,IAC5B,MAAM,IAAI,OAAO,aAAa;AAE5B,SAAO,uBADM,GAAG,aAAa,UAAU,QAAQ,EACX;GAClC;GACA;GACA;GACA;GACD,CAAC;GACF,CACH,EAEO,SAAS,WAAW;AAC1B,aAAW,KAAK,GAAG,OAAO,SAAS;AACnC,SAAO,QAAQ,SAAS,QAAQ,WAAW,IAAI,IAAI,CAAC;AACpD,SAAO,WAAW,SAAS,SAAS,cAAc,IAAI,KAAK,CAAC;AAC5D,QAAM,iBAAiB,OAAO,MAAM;AACpC,QAAM,uBAAuB,OAAO,MAAM;GAC1C;AAGF,YAAW,KAAK,GAAG,wBAAwB,WAAW,CAAC;CAEvD,MAAM,gBAAgB,oBAAoB,WAAW,CAAC,MAAM;AAE5D,OAAM,mBAAmB,eAAe,KAAK,KAAK,cAAc,OAAO,CAAC;AAExE,OAAM,SAAS,KAAK,MAAM,YAAY,KAAK,GAAG,UAAU;AACxD,OAAM,mBAAmB,cAAc;AAEvC,QAAO;EACL,UAAU;EACV,SAAS,CAAC,GAAG,WAAW;EACxB,YAAY,CAAC,GAAG,cAAc;EAC9B;EACD"}
|
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
2
|
-
const require_runtime = require('
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
|
+
const require_runtime = require('../../_virtual/_rolldown/runtime.cjs');
|
|
3
3
|
const require_expressions = require('./ast/expressions.cjs');
|
|
4
4
|
const require_jsx = require('./ast/jsx.cjs');
|
|
5
5
|
let ts_morph = require("ts-morph");
|
|
6
6
|
|
|
7
|
-
//#region
|
|
8
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
7
|
+
//#region src/purger/optimized/purgeFromCode.ts
|
|
9
8
|
/**
|
|
10
9
|
* Get component info with all its dependencies (using pre-generated data)
|
|
11
10
|
*/
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
|
|
2
|
+
import { PurgeStats } from "./types.cjs";
|
|
3
|
+
|
|
4
|
+
//#region src/purger/optimized/purgeFromCode.d.ts
|
|
5
|
+
interface PurgeFromCodeResult {
|
|
6
|
+
safelist: string[];
|
|
7
|
+
imports: string[];
|
|
8
|
+
components: string[];
|
|
9
|
+
stats: PurgeStats;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Serialized component info from pre-generated data
|
|
13
|
+
*/
|
|
14
|
+
interface SerializedComponentInfo {
|
|
15
|
+
name: string;
|
|
16
|
+
defaultProps: Record<string, string>;
|
|
17
|
+
getStylesLiterals: Record<string, string>;
|
|
18
|
+
cxLiterals?: string[];
|
|
19
|
+
internalComponents: string[];
|
|
20
|
+
internalComponentProps: Record<string, Record<string, string[]>>;
|
|
21
|
+
propToVariantKeys: Record<string, string[]>;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Optimized purge from code string.
|
|
25
|
+
*
|
|
26
|
+
* This is a standalone implementation that:
|
|
27
|
+
* - Analyzes UDS component source files to get accurate default props
|
|
28
|
+
* - Includes defaults from internally used components
|
|
29
|
+
* - Only depends on variants from src/styles/variants.ts (source of truth)
|
|
30
|
+
* - Uses ts-morph for AST analysis
|
|
31
|
+
*
|
|
32
|
+
* Key behaviors:
|
|
33
|
+
* - Includes classes for component default props (analyzed from source)
|
|
34
|
+
* - Includes defaults for internal component dependencies
|
|
35
|
+
* - Includes classes for explicitly used prop values
|
|
36
|
+
* - Resolves ternary/logical expressions to extract all possible values
|
|
37
|
+
* - Traces spreads to const objects in the same file
|
|
38
|
+
* - Does NOT fall back to type properties for unresolved spreads
|
|
39
|
+
*/
|
|
40
|
+
/**
|
|
41
|
+
* Variant defaults per component from consumer's config
|
|
42
|
+
* e.g., { Button: { size: 'md', variant: 'primary' }, Avatar: { size: 'md' } }
|
|
43
|
+
*/
|
|
44
|
+
type VariantDefaults = Record<string, Record<string, string>>;
|
|
45
|
+
interface PurgeFromCodeOptions {
|
|
46
|
+
colorModes?: ('dark' | 'light')[];
|
|
47
|
+
/** Variant defaults from consumer's config - used to include default CSS when prop not specified */
|
|
48
|
+
variantDefaults?: VariantDefaults;
|
|
49
|
+
variants: Record<string, Record<string, string>>;
|
|
50
|
+
autoVariants: Record<string, Record<string, string>>;
|
|
51
|
+
componentData: Record<string, SerializedComponentInfo>;
|
|
52
|
+
includeAllClassNamePrimitives?: boolean;
|
|
53
|
+
filePath?: string;
|
|
54
|
+
}
|
|
55
|
+
declare const purgeFromCodeOptimized: (code: string, options: PurgeFromCodeOptions) => Promise<PurgeFromCodeResult>;
|
|
56
|
+
//#endregion
|
|
57
|
+
export { purgeFromCodeOptimized };
|
|
58
|
+
//# sourceMappingURL=purgeFromCode.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purgeFromCode.d.cts","names":[],"sources":["../../../src/purger/optimized/purgeFromCode.ts"],"mappings":";;;;UAMU,mBAAA;EACR,QAAA;EACA,OAAA;EACA,UAAA;EACA,KAAA,EAAO,UAAA;AAAA;;;;UAMC,uBAAA;EACR,IAAA;EACA,YAAA,EAAc,MAAA;EACd,iBAAA,EAAmB,MAAA;EACnB,UAAA;EACA,kBAAA;EACA,sBAAA,EAAwB,MAAA,SAAe,MAAA;EACvC,iBAAA,EAAmB,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;AAAM;;KAoDtB,eAAA,GAAkB,MAAA,SAAe,MAAA;AAAA,UAE5B,oBAAA;EACR,UAAA;EADQ;EAGR,eAAA,GAAkB,eAAA;EAClB,QAAA,EAAU,MAAA,SAAe,MAAA;EACzB,YAAA,EAAc,MAAA,SAAe,MAAA;EAC7B,aAAA,EAAe,MAAA,SAAe,uBAAA;EAC9B,6BAAA;EACA,QAAA;AAAA;AAAA,cAmLI,sBAAA,GACJ,IAAA,UACA,OAAA,EAAS,oBAAA,KACR,OAAA,CAAQ,mBAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
|
|
2
|
+
import { PurgeStats } from "./types.js";
|
|
3
|
+
|
|
4
|
+
//#region src/purger/optimized/purgeFromCode.d.ts
|
|
5
|
+
interface PurgeFromCodeResult {
|
|
6
|
+
safelist: string[];
|
|
7
|
+
imports: string[];
|
|
8
|
+
components: string[];
|
|
9
|
+
stats: PurgeStats;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Serialized component info from pre-generated data
|
|
13
|
+
*/
|
|
14
|
+
interface SerializedComponentInfo {
|
|
15
|
+
name: string;
|
|
16
|
+
defaultProps: Record<string, string>;
|
|
17
|
+
getStylesLiterals: Record<string, string>;
|
|
18
|
+
cxLiterals?: string[];
|
|
19
|
+
internalComponents: string[];
|
|
20
|
+
internalComponentProps: Record<string, Record<string, string[]>>;
|
|
21
|
+
propToVariantKeys: Record<string, string[]>;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Optimized purge from code string.
|
|
25
|
+
*
|
|
26
|
+
* This is a standalone implementation that:
|
|
27
|
+
* - Analyzes UDS component source files to get accurate default props
|
|
28
|
+
* - Includes defaults from internally used components
|
|
29
|
+
* - Only depends on variants from src/styles/variants.ts (source of truth)
|
|
30
|
+
* - Uses ts-morph for AST analysis
|
|
31
|
+
*
|
|
32
|
+
* Key behaviors:
|
|
33
|
+
* - Includes classes for component default props (analyzed from source)
|
|
34
|
+
* - Includes defaults for internal component dependencies
|
|
35
|
+
* - Includes classes for explicitly used prop values
|
|
36
|
+
* - Resolves ternary/logical expressions to extract all possible values
|
|
37
|
+
* - Traces spreads to const objects in the same file
|
|
38
|
+
* - Does NOT fall back to type properties for unresolved spreads
|
|
39
|
+
*/
|
|
40
|
+
/**
|
|
41
|
+
* Variant defaults per component from consumer's config
|
|
42
|
+
* e.g., { Button: { size: 'md', variant: 'primary' }, Avatar: { size: 'md' } }
|
|
43
|
+
*/
|
|
44
|
+
type VariantDefaults = Record<string, Record<string, string>>;
|
|
45
|
+
interface PurgeFromCodeOptions {
|
|
46
|
+
colorModes?: ('dark' | 'light')[];
|
|
47
|
+
/** Variant defaults from consumer's config - used to include default CSS when prop not specified */
|
|
48
|
+
variantDefaults?: VariantDefaults;
|
|
49
|
+
variants: Record<string, Record<string, string>>;
|
|
50
|
+
autoVariants: Record<string, Record<string, string>>;
|
|
51
|
+
componentData: Record<string, SerializedComponentInfo>;
|
|
52
|
+
includeAllClassNamePrimitives?: boolean;
|
|
53
|
+
filePath?: string;
|
|
54
|
+
}
|
|
55
|
+
declare const purgeFromCodeOptimized: (code: string, options: PurgeFromCodeOptions) => Promise<PurgeFromCodeResult>;
|
|
56
|
+
//#endregion
|
|
57
|
+
export { type PurgeFromCodeResult, purgeFromCodeOptimized };
|
|
58
|
+
//# sourceMappingURL=purgeFromCode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purgeFromCode.d.ts","names":[],"sources":["../../../src/purger/optimized/purgeFromCode.ts"],"mappings":";;;;UAMU,mBAAA;EACR,QAAA;EACA,OAAA;EACA,UAAA;EACA,KAAA,EAAO,UAAA;AAAA;;;;UAMC,uBAAA;EACR,IAAA;EACA,YAAA,EAAc,MAAA;EACd,iBAAA,EAAmB,MAAA;EACnB,UAAA;EACA,kBAAA;EACA,sBAAA,EAAwB,MAAA,SAAe,MAAA;EACvC,iBAAA,EAAmB,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;AAAM;;KAoDtB,eAAA,GAAkB,MAAA,SAAe,MAAA;AAAA,UAE5B,oBAAA;EACR,UAAA;EADQ;EAGR,eAAA,GAAkB,eAAA;EAClB,QAAA,EAAU,MAAA,SAAe,MAAA;EACzB,YAAA,EAAc,MAAA,SAAe,MAAA;EAC7B,aAAA,EAAe,MAAA,SAAe,uBAAA;EAC9B,6BAAA;EACA,QAAA;AAAA;AAAA,cAmLI,sBAAA,GACJ,IAAA,UACA,OAAA,EAAS,oBAAA,KACR,OAAA,CAAQ,mBAAA"}
|
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
/*! © 2026 Yahoo, Inc. UDS v0.0.0-development */
|
|
1
|
+
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
2
2
|
import { extractStringLiterals } from "./ast/expressions.js";
|
|
3
3
|
import { findJsxReferences } from "./ast/jsx.js";
|
|
4
4
|
import { Node, Project, SyntaxKind, ts } from "ts-morph";
|
|
5
5
|
|
|
6
|
-
//#region
|
|
7
|
-
/*! © 2026 Yahoo, Inc. UDS Tailwind and Purger v0.0.0-development */
|
|
6
|
+
//#region src/purger/optimized/purgeFromCode.ts
|
|
8
7
|
/**
|
|
9
8
|
* Get component info with all its dependencies (using pre-generated data)
|
|
10
9
|
*/
|
|
@@ -405,4 +404,5 @@ const extractGetStylesCalls = (sourceFile, stats, variants) => {
|
|
|
405
404
|
};
|
|
406
405
|
|
|
407
406
|
//#endregion
|
|
408
|
-
export { purgeFromCodeOptimized };
|
|
407
|
+
export { purgeFromCodeOptimized };
|
|
408
|
+
//# sourceMappingURL=purgeFromCode.js.map
|