@tachui/core 0.7.0-alpha1
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/LICENSE +363 -0
- package/dist/assets/Asset.cjs +2 -0
- package/dist/assets/Asset.cjs.map +1 -0
- package/dist/assets/Asset.d.ts +11 -0
- package/dist/assets/Asset.d.ts.map +1 -0
- package/dist/assets/Asset.js +9 -0
- package/dist/assets/Asset.js.map +1 -0
- package/dist/assets/AssetCollection.cjs +2 -0
- package/dist/assets/AssetCollection.cjs.map +1 -0
- package/dist/assets/AssetCollection.d.ts +14 -0
- package/dist/assets/AssetCollection.d.ts.map +1 -0
- package/dist/assets/AssetCollection.js +44 -0
- package/dist/assets/AssetCollection.js.map +1 -0
- package/dist/assets/ColorAsset.cjs +2 -0
- package/dist/assets/ColorAsset.cjs.map +1 -0
- package/dist/assets/ColorAsset.d.ts +31 -0
- package/dist/assets/ColorAsset.d.ts.map +1 -0
- package/dist/assets/ColorAsset.js +114 -0
- package/dist/assets/ColorAsset.js.map +1 -0
- package/dist/assets/FontAsset.cjs +9 -0
- package/dist/assets/FontAsset.cjs.map +1 -0
- package/dist/assets/FontAsset.d.ts +114 -0
- package/dist/assets/FontAsset.d.ts.map +1 -0
- package/dist/assets/FontAsset.js +173 -0
- package/dist/assets/FontAsset.js.map +1 -0
- package/dist/assets/ImageAsset.cjs +2 -0
- package/dist/assets/ImageAsset.cjs.map +1 -0
- package/dist/assets/ImageAsset.d.ts +35 -0
- package/dist/assets/ImageAsset.d.ts.map +1 -0
- package/dist/assets/ImageAsset.js +39 -0
- package/dist/assets/ImageAsset.js.map +1 -0
- package/dist/assets/index.cjs +2 -0
- package/dist/assets/index.cjs.map +1 -0
- package/dist/assets/index.d.ts +26 -0
- package/dist/assets/index.d.ts.map +1 -0
- package/dist/assets/index.js +119 -0
- package/dist/assets/index.js.map +1 -0
- package/dist/assets/types.d.ts +70 -0
- package/dist/assets/types.d.ts.map +1 -0
- package/dist/bundles/common.d.ts +24 -0
- package/dist/bundles/common.d.ts.map +1 -0
- package/dist/bundles/complete.d.ts +27 -0
- package/dist/bundles/complete.d.ts.map +1 -0
- package/dist/bundles/essential.d.ts +24 -0
- package/dist/bundles/essential.d.ts.map +1 -0
- package/dist/bundles/minimal.d.ts +24 -0
- package/dist/bundles/minimal.d.ts.map +1 -0
- package/dist/bundles/production-minimal.d.ts +35 -0
- package/dist/bundles/production-minimal.d.ts.map +1 -0
- package/dist/common.cjs +2 -0
- package/dist/common.cjs.map +1 -0
- package/dist/common.js +985 -0
- package/dist/common.js.map +1 -0
- package/dist/compiler/advanced-parser.cjs +5 -0
- package/dist/compiler/advanced-parser.cjs.map +1 -0
- package/dist/compiler/advanced-parser.d.ts +113 -0
- package/dist/compiler/advanced-parser.d.ts.map +1 -0
- package/dist/compiler/advanced-parser.js +440 -0
- package/dist/compiler/advanced-parser.js.map +1 -0
- package/dist/compiler/codegen.cjs +6 -0
- package/dist/compiler/codegen.cjs.map +1 -0
- package/dist/compiler/codegen.d.ts +20 -0
- package/dist/compiler/codegen.d.ts.map +1 -0
- package/dist/compiler/codegen.js +241 -0
- package/dist/compiler/codegen.js.map +1 -0
- package/dist/compiler/enhanced-codegen.cjs +6 -0
- package/dist/compiler/enhanced-codegen.cjs.map +1 -0
- package/dist/compiler/enhanced-codegen.d.ts +121 -0
- package/dist/compiler/enhanced-codegen.d.ts.map +1 -0
- package/dist/compiler/enhanced-codegen.js +347 -0
- package/dist/compiler/enhanced-codegen.js.map +1 -0
- package/dist/compiler/index.cjs +2 -0
- package/dist/compiler/index.cjs.map +1 -0
- package/dist/compiler/index.d.ts +14 -0
- package/dist/compiler/index.d.ts.map +1 -0
- package/dist/compiler/index.js +13 -0
- package/dist/compiler/index.js.map +1 -0
- package/dist/compiler/parser.cjs +5 -0
- package/dist/compiler/parser.cjs.map +1 -0
- package/dist/compiler/parser.d.ts +12 -0
- package/dist/compiler/parser.d.ts.map +1 -0
- package/dist/compiler/parser.js +275 -0
- package/dist/compiler/parser.js.map +1 -0
- package/dist/compiler/plugin.cjs +33 -0
- package/dist/compiler/plugin.cjs.map +1 -0
- package/dist/compiler/plugin.d.ts +13 -0
- package/dist/compiler/plugin.d.ts.map +1 -0
- package/dist/compiler/plugin.js +103 -0
- package/dist/compiler/plugin.js.map +1 -0
- package/dist/compiler/types.d.ts +149 -0
- package/dist/compiler/types.d.ts.map +1 -0
- package/dist/components/BasicInput.cjs +2 -0
- package/dist/components/BasicInput.cjs.map +1 -0
- package/dist/components/BasicInput.d.ts +116 -0
- package/dist/components/BasicInput.d.ts.map +1 -0
- package/dist/components/BasicInput.js +182 -0
- package/dist/components/BasicInput.js.map +1 -0
- package/dist/components/Button.cjs +7 -0
- package/dist/components/Button.cjs.map +1 -0
- package/dist/components/Button.d.ts +252 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +408 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/Divider.cjs +2 -0
- package/dist/components/Divider.cjs.map +1 -0
- package/dist/components/Divider.d.ts +141 -0
- package/dist/components/Divider.d.ts.map +1 -0
- package/dist/components/Divider.js +187 -0
- package/dist/components/Divider.js.map +1 -0
- package/dist/components/EnhancedLink.cjs +2 -0
- package/dist/components/EnhancedLink.cjs.map +1 -0
- package/dist/components/EnhancedLink.d.ts +365 -0
- package/dist/components/EnhancedLink.d.ts.map +1 -0
- package/dist/components/EnhancedLink.js +345 -0
- package/dist/components/EnhancedLink.js.map +1 -0
- package/dist/components/Form.cjs +2 -0
- package/dist/components/Form.cjs.map +1 -0
- package/dist/components/Form.d.ts +141 -0
- package/dist/components/Form.d.ts.map +1 -0
- package/dist/components/Form.js +244 -0
- package/dist/components/Form.js.map +1 -0
- package/dist/components/Grid.cjs +2 -0
- package/dist/components/Grid.cjs.map +1 -0
- package/dist/components/Grid.d.ts +698 -0
- package/dist/components/Grid.d.ts.map +1 -0
- package/dist/components/Grid.js +1045 -0
- package/dist/components/Grid.js.map +1 -0
- package/dist/components/GridResponsive.cjs +2 -0
- package/dist/components/GridResponsive.cjs.map +1 -0
- package/dist/components/GridResponsive.d.ts +214 -0
- package/dist/components/GridResponsive.d.ts.map +1 -0
- package/dist/components/GridResponsive.js +382 -0
- package/dist/components/GridResponsive.js.map +1 -0
- package/dist/components/Image.cjs +2 -0
- package/dist/components/Image.cjs.map +1 -0
- package/dist/components/Image.d.ts +162 -0
- package/dist/components/Image.d.ts.map +1 -0
- package/dist/components/Image.js +212 -0
- package/dist/components/Image.js.map +1 -0
- package/dist/components/List.cjs +2 -0
- package/dist/components/List.cjs.map +1 -0
- package/dist/components/List.d.ts +287 -0
- package/dist/components/List.d.ts.map +1 -0
- package/dist/components/List.js +561 -0
- package/dist/components/List.js.map +1 -0
- package/dist/components/Menu.cjs +2 -0
- package/dist/components/Menu.cjs.map +1 -0
- package/dist/components/Menu.d.ts +159 -0
- package/dist/components/Menu.d.ts.map +1 -0
- package/dist/components/Menu.js +443 -0
- package/dist/components/Menu.js.map +1 -0
- package/dist/components/Picker.cjs +2 -0
- package/dist/components/Picker.cjs.map +1 -0
- package/dist/components/Picker.d.ts +153 -0
- package/dist/components/Picker.d.ts.map +1 -0
- package/dist/components/Picker.js +478 -0
- package/dist/components/Picker.js.map +1 -0
- package/dist/components/ScrollView.cjs +6 -0
- package/dist/components/ScrollView.cjs.map +1 -0
- package/dist/components/ScrollView.d.ts +222 -0
- package/dist/components/ScrollView.d.ts.map +1 -0
- package/dist/components/ScrollView.js +363 -0
- package/dist/components/ScrollView.js.map +1 -0
- package/dist/components/Section.cjs +2 -0
- package/dist/components/Section.cjs.map +1 -0
- package/dist/components/Section.d.ts +153 -0
- package/dist/components/Section.d.ts.map +1 -0
- package/dist/components/Section.js +323 -0
- package/dist/components/Section.js.map +1 -0
- package/dist/components/Show.cjs +2 -0
- package/dist/components/Show.cjs.map +1 -0
- package/dist/components/Show.d.ts +64 -0
- package/dist/components/Show.d.ts.map +1 -0
- package/dist/components/Show.js +112 -0
- package/dist/components/Show.js.map +1 -0
- package/dist/components/Spacer.cjs +2 -0
- package/dist/components/Spacer.cjs.map +1 -0
- package/dist/components/Spacer.d.ts +35 -0
- package/dist/components/Spacer.d.ts.map +1 -0
- package/dist/components/Spacer.js +53 -0
- package/dist/components/Spacer.js.map +1 -0
- package/dist/components/Text.cjs +2 -0
- package/dist/components/Text.cjs.map +1 -0
- package/dist/components/Text.d.ts +242 -0
- package/dist/components/Text.d.ts.map +1 -0
- package/dist/components/Text.js +193 -0
- package/dist/components/Text.js.map +1 -0
- package/dist/components/Toggle.cjs +2 -0
- package/dist/components/Toggle.cjs.map +1 -0
- package/dist/components/Toggle.d.ts +207 -0
- package/dist/components/Toggle.d.ts.map +1 -0
- package/dist/components/Toggle.js +477 -0
- package/dist/components/Toggle.js.map +1 -0
- package/dist/components/index.cjs +2 -0
- package/dist/components/index.cjs.map +1 -0
- package/dist/components/index.d.ts +45 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +104 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/wrapper.cjs +2 -0
- package/dist/components/wrapper.cjs.map +1 -0
- package/dist/components/wrapper.d.ts +249 -0
- package/dist/components/wrapper.d.ts.map +1 -0
- package/dist/components/wrapper.js +484 -0
- package/dist/components/wrapper.js.map +1 -0
- package/dist/concatenation/concatenatable.cjs +2 -0
- package/dist/concatenation/concatenatable.cjs.map +1 -0
- package/dist/concatenation/concatenatable.d.ts +63 -0
- package/dist/concatenation/concatenatable.d.ts.map +1 -0
- package/dist/concatenation/concatenatable.js +118 -0
- package/dist/concatenation/concatenatable.js.map +1 -0
- package/dist/concatenation/concatenated-component.cjs +2 -0
- package/dist/concatenation/concatenated-component.cjs.map +1 -0
- package/dist/concatenation/concatenated-component.d.ts +110 -0
- package/dist/concatenation/concatenated-component.d.ts.map +1 -0
- package/dist/concatenation/concatenated-component.js +276 -0
- package/dist/concatenation/concatenated-component.js.map +1 -0
- package/dist/concatenation/index.d.ts +13 -0
- package/dist/concatenation/index.d.ts.map +1 -0
- package/dist/concatenation/text-optimizer.cjs +2 -0
- package/dist/concatenation/text-optimizer.cjs.map +1 -0
- package/dist/concatenation/text-optimizer.d.ts +104 -0
- package/dist/concatenation/text-optimizer.d.ts.map +1 -0
- package/dist/concatenation/text-optimizer.js +236 -0
- package/dist/concatenation/text-optimizer.js.map +1 -0
- package/dist/concatenation/types.cjs +2 -0
- package/dist/concatenation/types.cjs.map +1 -0
- package/dist/concatenation/types.d.ts +88 -0
- package/dist/concatenation/types.d.ts.map +1 -0
- package/dist/concatenation/types.js +13 -0
- package/dist/concatenation/types.js.map +1 -0
- package/dist/constants/frame-utils.cjs +2 -0
- package/dist/constants/frame-utils.cjs.map +1 -0
- package/dist/constants/frame-utils.d.ts +68 -0
- package/dist/constants/frame-utils.d.ts.map +1 -0
- package/dist/constants/frame-utils.js +116 -0
- package/dist/constants/frame-utils.js.map +1 -0
- package/dist/constants/index.d.ts +8 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/layout.cjs +2 -0
- package/dist/constants/layout.cjs.map +1 -0
- package/dist/constants/layout.d.ts +60 -0
- package/dist/constants/layout.d.ts.map +1 -0
- package/dist/constants/layout.js +46 -0
- package/dist/constants/layout.js.map +1 -0
- package/dist/css-classes/component-base.cjs +2 -0
- package/dist/css-classes/component-base.cjs.map +1 -0
- package/dist/css-classes/component-base.d.ts +40 -0
- package/dist/css-classes/component-base.d.ts.map +1 -0
- package/dist/css-classes/component-base.js +62 -0
- package/dist/css-classes/component-base.js.map +1 -0
- package/dist/css-classes/css-class-manager.cjs +2 -0
- package/dist/css-classes/css-class-manager.cjs.map +1 -0
- package/dist/css-classes/css-class-manager.d.ts +89 -0
- package/dist/css-classes/css-class-manager.d.ts.map +1 -0
- package/dist/css-classes/css-class-manager.js +209 -0
- package/dist/css-classes/css-class-manager.js.map +1 -0
- package/dist/css-classes/dom-integration.cjs +2 -0
- package/dist/css-classes/dom-integration.cjs.map +1 -0
- package/dist/css-classes/dom-integration.d.ts +76 -0
- package/dist/css-classes/dom-integration.d.ts.map +1 -0
- package/dist/css-classes/dom-integration.js +67 -0
- package/dist/css-classes/dom-integration.js.map +1 -0
- package/dist/css-classes/enhanced-renderer.cjs +2 -0
- package/dist/css-classes/enhanced-renderer.cjs.map +1 -0
- package/dist/css-classes/enhanced-renderer.d.ts +42 -0
- package/dist/css-classes/enhanced-renderer.d.ts.map +1 -0
- package/dist/css-classes/enhanced-renderer.js +73 -0
- package/dist/css-classes/enhanced-renderer.js.map +1 -0
- package/dist/css-classes/index.d.ts +14 -0
- package/dist/css-classes/index.d.ts.map +1 -0
- package/dist/css-classes/types.d.ts +59 -0
- package/dist/css-classes/types.d.ts.map +1 -0
- package/dist/css-classes/utilities.cjs +2 -0
- package/dist/css-classes/utilities.cjs.map +1 -0
- package/dist/css-classes/utilities.d.ts +104 -0
- package/dist/css-classes/utilities.d.ts.map +1 -0
- package/dist/css-classes/utilities.js +41 -0
- package/dist/css-classes/utilities.js.map +1 -0
- package/dist/debug/index.d.ts +61 -0
- package/dist/debug/index.d.ts.map +1 -0
- package/dist/debug.cjs +52 -0
- package/dist/debug.cjs.map +1 -0
- package/dist/debug.js +179 -0
- package/dist/debug.js.map +1 -0
- package/dist/developer-experience/enhanced-errors.d.ts +128 -0
- package/dist/developer-experience/enhanced-errors.d.ts.map +1 -0
- package/dist/developer-experience/enhanced-types.d.ts +281 -0
- package/dist/developer-experience/enhanced-types.d.ts.map +1 -0
- package/dist/developer-experience/index.d.ts +44 -0
- package/dist/developer-experience/index.d.ts.map +1 -0
- package/dist/essential.cjs +2 -0
- package/dist/essential.cjs.map +1 -0
- package/dist/essential.js +968 -0
- package/dist/essential.js.map +1 -0
- package/dist/gradients/css-generator.cjs +2 -0
- package/dist/gradients/css-generator.cjs.map +1 -0
- package/dist/gradients/css-generator.d.ts +10 -0
- package/dist/gradients/css-generator.d.ts.map +1 -0
- package/dist/gradients/css-generator.js +100 -0
- package/dist/gradients/css-generator.js.map +1 -0
- package/dist/gradients/examples.cjs +2 -0
- package/dist/gradients/examples.cjs.map +1 -0
- package/dist/gradients/examples.d.ts +432 -0
- package/dist/gradients/examples.d.ts.map +1 -0
- package/dist/gradients/examples.js +555 -0
- package/dist/gradients/examples.js.map +1 -0
- package/dist/gradients/gradient-asset.cjs +2 -0
- package/dist/gradients/gradient-asset.cjs.map +1 -0
- package/dist/gradients/gradient-asset.d.ts +10 -0
- package/dist/gradients/gradient-asset.d.ts.map +1 -0
- package/dist/gradients/gradient-asset.js +22 -0
- package/dist/gradients/gradient-asset.js.map +1 -0
- package/dist/gradients/index.cjs +2 -0
- package/dist/gradients/index.cjs.map +1 -0
- package/dist/gradients/index.d.ts +19 -0
- package/dist/gradients/index.d.ts.map +1 -0
- package/dist/gradients/index.js +78 -0
- package/dist/gradients/index.js.map +1 -0
- package/dist/gradients/performance.cjs +2 -0
- package/dist/gradients/performance.cjs.map +1 -0
- package/dist/gradients/performance.d.ts +146 -0
- package/dist/gradients/performance.d.ts.map +1 -0
- package/dist/gradients/performance.js +237 -0
- package/dist/gradients/performance.js.map +1 -0
- package/dist/gradients/presets.cjs +2 -0
- package/dist/gradients/presets.cjs.map +1 -0
- package/dist/gradients/presets.d.ts +165 -0
- package/dist/gradients/presets.d.ts.map +1 -0
- package/dist/gradients/presets.js +254 -0
- package/dist/gradients/presets.js.map +1 -0
- package/dist/gradients/reactive.cjs +2 -0
- package/dist/gradients/reactive.cjs.map +1 -0
- package/dist/gradients/reactive.d.ts +167 -0
- package/dist/gradients/reactive.d.ts.map +1 -0
- package/dist/gradients/reactive.js +239 -0
- package/dist/gradients/reactive.js.map +1 -0
- package/dist/gradients/state-gradient-asset.cjs +2 -0
- package/dist/gradients/state-gradient-asset.cjs.map +1 -0
- package/dist/gradients/state-gradient-asset.d.ts +67 -0
- package/dist/gradients/state-gradient-asset.d.ts.map +1 -0
- package/dist/gradients/state-gradient-asset.js +111 -0
- package/dist/gradients/state-gradient-asset.js.map +1 -0
- package/dist/gradients/types.d.ts +94 -0
- package/dist/gradients/types.d.ts.map +1 -0
- package/dist/gradients/utils.cjs +2 -0
- package/dist/gradients/utils.cjs.map +1 -0
- package/dist/gradients/utils.d.ts +313 -0
- package/dist/gradients/utils.d.ts.map +1 -0
- package/dist/gradients/utils.js +385 -0
- package/dist/gradients/utils.js.map +1 -0
- package/dist/gradients/validation.cjs +2 -0
- package/dist/gradients/validation.cjs.map +1 -0
- package/dist/gradients/validation.d.ts +156 -0
- package/dist/gradients/validation.d.ts.map +1 -0
- package/dist/gradients/validation.js +209 -0
- package/dist/gradients/validation.js.map +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +965 -0
- package/dist/index.js.map +1 -0
- package/dist/index2.cjs +2 -0
- package/dist/index2.cjs.map +1 -0
- package/dist/index2.js +293 -0
- package/dist/index2.js.map +1 -0
- package/dist/lifecycle/hooks.cjs +2 -0
- package/dist/lifecycle/hooks.cjs.map +1 -0
- package/dist/lifecycle/hooks.d.ts +101 -0
- package/dist/lifecycle/hooks.d.ts.map +1 -0
- package/dist/lifecycle/hooks.js +159 -0
- package/dist/lifecycle/hooks.js.map +1 -0
- package/dist/minimal-prod.cjs +2 -0
- package/dist/minimal-prod.cjs.map +1 -0
- package/dist/minimal-prod.js +193 -0
- package/dist/minimal-prod.js.map +1 -0
- package/dist/minimal.cjs +2 -0
- package/dist/minimal.cjs.map +1 -0
- package/dist/minimal.js +968 -0
- package/dist/minimal.js.map +1 -0
- package/dist/modifiers/as-html-validator.cjs +2 -0
- package/dist/modifiers/as-html-validator.cjs.map +1 -0
- package/dist/modifiers/as-html-validator.d.ts +20 -0
- package/dist/modifiers/as-html-validator.d.ts.map +1 -0
- package/dist/modifiers/as-html-validator.js +47 -0
- package/dist/modifiers/as-html-validator.js.map +1 -0
- package/dist/modifiers/as-html.cjs +2 -0
- package/dist/modifiers/as-html.cjs.map +1 -0
- package/dist/modifiers/as-html.d.ts +65 -0
- package/dist/modifiers/as-html.d.ts.map +1 -0
- package/dist/modifiers/as-html.js +71 -0
- package/dist/modifiers/as-html.js.map +1 -0
- package/dist/modifiers/attributes.cjs +2 -0
- package/dist/modifiers/attributes.cjs.map +1 -0
- package/dist/modifiers/attributes.d.ts +203 -0
- package/dist/modifiers/attributes.d.ts.map +1 -0
- package/dist/modifiers/attributes.js +272 -0
- package/dist/modifiers/attributes.js.map +1 -0
- package/dist/modifiers/backdrop.cjs +2 -0
- package/dist/modifiers/backdrop.cjs.map +1 -0
- package/dist/modifiers/backdrop.d.ts +59 -0
- package/dist/modifiers/backdrop.d.ts.map +1 -0
- package/dist/modifiers/backdrop.js +109 -0
- package/dist/modifiers/backdrop.js.map +1 -0
- package/dist/modifiers/background.cjs +2 -0
- package/dist/modifiers/background.cjs.map +1 -0
- package/dist/modifiers/background.d.ts +21 -0
- package/dist/modifiers/background.d.ts.map +1 -0
- package/dist/modifiers/background.js +67 -0
- package/dist/modifiers/background.js.map +1 -0
- package/dist/modifiers/base.cjs +25 -0
- package/dist/modifiers/base.cjs.map +1 -0
- package/dist/modifiers/base.d.ts +156 -0
- package/dist/modifiers/base.d.ts.map +1 -0
- package/dist/modifiers/base.js +745 -0
- package/dist/modifiers/base.js.map +1 -0
- package/dist/modifiers/basic-sanitizer.cjs +2 -0
- package/dist/modifiers/basic-sanitizer.cjs.map +1 -0
- package/dist/modifiers/basic-sanitizer.d.ts +54 -0
- package/dist/modifiers/basic-sanitizer.d.ts.map +1 -0
- package/dist/modifiers/basic-sanitizer.js +162 -0
- package/dist/modifiers/basic-sanitizer.js.map +1 -0
- package/dist/modifiers/border.cjs +2 -0
- package/dist/modifiers/border.cjs.map +1 -0
- package/dist/modifiers/border.d.ts +217 -0
- package/dist/modifiers/border.d.ts.map +1 -0
- package/dist/modifiers/border.js +160 -0
- package/dist/modifiers/border.js.map +1 -0
- package/dist/modifiers/builder.cjs +2 -0
- package/dist/modifiers/builder.cjs.map +1 -0
- package/dist/modifiers/builder.d.ts +377 -0
- package/dist/modifiers/builder.d.ts.map +1 -0
- package/dist/modifiers/builder.js +930 -0
- package/dist/modifiers/builder.js.map +1 -0
- package/dist/modifiers/core.cjs +2 -0
- package/dist/modifiers/core.cjs.map +1 -0
- package/dist/modifiers/core.d.ts +407 -0
- package/dist/modifiers/core.d.ts.map +1 -0
- package/dist/modifiers/core.js +398 -0
- package/dist/modifiers/core.js.map +1 -0
- package/dist/modifiers/css.cjs +2 -0
- package/dist/modifiers/css.cjs.map +1 -0
- package/dist/modifiers/css.d.ts +86 -0
- package/dist/modifiers/css.d.ts.map +1 -0
- package/dist/modifiers/css.js +50 -0
- package/dist/modifiers/css.js.map +1 -0
- package/dist/modifiers/effects.cjs +2 -0
- package/dist/modifiers/effects.cjs.map +1 -0
- package/dist/modifiers/effects.d.ts +159 -0
- package/dist/modifiers/effects.d.ts.map +1 -0
- package/dist/modifiers/effects.js +178 -0
- package/dist/modifiers/effects.js.map +1 -0
- package/dist/modifiers/elements.cjs +2 -0
- package/dist/modifiers/elements.cjs.map +1 -0
- package/dist/modifiers/elements.d.ts +240 -0
- package/dist/modifiers/elements.d.ts.map +1 -0
- package/dist/modifiers/elements.js +216 -0
- package/dist/modifiers/elements.js.map +1 -0
- package/dist/modifiers/filters.cjs +2 -0
- package/dist/modifiers/filters.cjs.map +1 -0
- package/dist/modifiers/filters.d.ts +275 -0
- package/dist/modifiers/filters.d.ts.map +1 -0
- package/dist/modifiers/filters.js +223 -0
- package/dist/modifiers/filters.js.map +1 -0
- package/dist/modifiers/flexbox.cjs +2 -0
- package/dist/modifiers/flexbox.cjs.map +1 -0
- package/dist/modifiers/flexbox.d.ts +82 -0
- package/dist/modifiers/flexbox.d.ts.map +1 -0
- package/dist/modifiers/flexbox.js +56 -0
- package/dist/modifiers/flexbox.js.map +1 -0
- package/dist/modifiers/font.cjs +2 -0
- package/dist/modifiers/font.cjs.map +1 -0
- package/dist/modifiers/font.d.ts +71 -0
- package/dist/modifiers/font.d.ts.map +1 -0
- package/dist/modifiers/font.js +60 -0
- package/dist/modifiers/font.js.map +1 -0
- package/dist/modifiers/grid.cjs +2 -0
- package/dist/modifiers/grid.cjs.map +1 -0
- package/dist/modifiers/grid.d.ts +92 -0
- package/dist/modifiers/grid.d.ts.map +1 -0
- package/dist/modifiers/grid.js +92 -0
- package/dist/modifiers/grid.js.map +1 -0
- package/dist/modifiers/index.d.ts +58 -0
- package/dist/modifiers/index.d.ts.map +1 -0
- package/dist/modifiers/margin.cjs +2 -0
- package/dist/modifiers/margin.cjs.map +1 -0
- package/dist/modifiers/margin.d.ts +128 -0
- package/dist/modifiers/margin.d.ts.map +1 -0
- package/dist/modifiers/margin.js +65 -0
- package/dist/modifiers/margin.js.map +1 -0
- package/dist/modifiers/padding.cjs +2 -0
- package/dist/modifiers/padding.cjs.map +1 -0
- package/dist/modifiers/padding.d.ts +204 -0
- package/dist/modifiers/padding.d.ts.map +1 -0
- package/dist/modifiers/padding.js +109 -0
- package/dist/modifiers/padding.js.map +1 -0
- package/dist/modifiers/registry.cjs +2 -0
- package/dist/modifiers/registry.cjs.map +1 -0
- package/dist/modifiers/registry.d.ts +69 -0
- package/dist/modifiers/registry.d.ts.map +1 -0
- package/dist/modifiers/registry.js +163 -0
- package/dist/modifiers/registry.js.map +1 -0
- package/dist/modifiers/responsive/advanced-utilities.cjs +2 -0
- package/dist/modifiers/responsive/advanced-utilities.cjs.map +1 -0
- package/dist/modifiers/responsive/advanced-utilities.d.ts +118 -0
- package/dist/modifiers/responsive/advanced-utilities.d.ts.map +1 -0
- package/dist/modifiers/responsive/advanced-utilities.js +291 -0
- package/dist/modifiers/responsive/advanced-utilities.js.map +1 -0
- package/dist/modifiers/responsive/breakpoints.cjs +2 -0
- package/dist/modifiers/responsive/breakpoints.cjs.map +1 -0
- package/dist/modifiers/responsive/breakpoints.d.ts +81 -0
- package/dist/modifiers/responsive/breakpoints.d.ts.map +1 -0
- package/dist/modifiers/responsive/breakpoints.js +168 -0
- package/dist/modifiers/responsive/breakpoints.js.map +1 -0
- package/dist/modifiers/responsive/css-generator.cjs +5 -0
- package/dist/modifiers/responsive/css-generator.cjs.map +1 -0
- package/dist/modifiers/responsive/css-generator.d.ts +100 -0
- package/dist/modifiers/responsive/css-generator.d.ts.map +1 -0
- package/dist/modifiers/responsive/css-generator.js +261 -0
- package/dist/modifiers/responsive/css-generator.js.map +1 -0
- package/dist/modifiers/responsive/dev-tools.cjs +77 -0
- package/dist/modifiers/responsive/dev-tools.cjs.map +1 -0
- package/dist/modifiers/responsive/dev-tools.d.ts +107 -0
- package/dist/modifiers/responsive/dev-tools.d.ts.map +1 -0
- package/dist/modifiers/responsive/dev-tools.js +380 -0
- package/dist/modifiers/responsive/dev-tools.js.map +1 -0
- package/dist/modifiers/responsive/index.d.ts +28 -0
- package/dist/modifiers/responsive/index.d.ts.map +1 -0
- package/dist/modifiers/responsive/layout-patterns.cjs +2 -0
- package/dist/modifiers/responsive/layout-patterns.cjs.map +1 -0
- package/dist/modifiers/responsive/layout-patterns.d.ts +230 -0
- package/dist/modifiers/responsive/layout-patterns.d.ts.map +1 -0
- package/dist/modifiers/responsive/layout-patterns.js +254 -0
- package/dist/modifiers/responsive/layout-patterns.js.map +1 -0
- package/dist/modifiers/responsive/performance.cjs +3 -0
- package/dist/modifiers/responsive/performance.cjs.map +1 -0
- package/dist/modifiers/responsive/performance.d.ts +130 -0
- package/dist/modifiers/responsive/performance.d.ts.map +1 -0
- package/dist/modifiers/responsive/performance.js +212 -0
- package/dist/modifiers/responsive/performance.js.map +1 -0
- package/dist/modifiers/responsive/responsive-builder.cjs +2 -0
- package/dist/modifiers/responsive/responsive-builder.cjs.map +1 -0
- package/dist/modifiers/responsive/responsive-builder.d.ts +133 -0
- package/dist/modifiers/responsive/responsive-builder.d.ts.map +1 -0
- package/dist/modifiers/responsive/responsive-builder.js +272 -0
- package/dist/modifiers/responsive/responsive-builder.js.map +1 -0
- package/dist/modifiers/responsive/responsive-modifier.cjs +3 -0
- package/dist/modifiers/responsive/responsive-modifier.cjs.map +1 -0
- package/dist/modifiers/responsive/responsive-modifier.d.ts +123 -0
- package/dist/modifiers/responsive/responsive-modifier.d.ts.map +1 -0
- package/dist/modifiers/responsive/responsive-modifier.js +204 -0
- package/dist/modifiers/responsive/responsive-modifier.js.map +1 -0
- package/dist/modifiers/responsive/types.cjs +2 -0
- package/dist/modifiers/responsive/types.cjs.map +1 -0
- package/dist/modifiers/responsive/types.d.ts +183 -0
- package/dist/modifiers/responsive/types.d.ts.map +1 -0
- package/dist/modifiers/responsive/types.js +26 -0
- package/dist/modifiers/responsive/types.js.map +1 -0
- package/dist/modifiers/responsive/utilities.cjs +16 -0
- package/dist/modifiers/responsive/utilities.cjs.map +1 -0
- package/dist/modifiers/responsive/utilities.d.ts +149 -0
- package/dist/modifiers/responsive/utilities.d.ts.map +1 -0
- package/dist/modifiers/responsive/utilities.js +273 -0
- package/dist/modifiers/responsive/utilities.js.map +1 -0
- package/dist/modifiers/scroll.cjs +2 -0
- package/dist/modifiers/scroll.cjs.map +1 -0
- package/dist/modifiers/scroll.d.ts +143 -0
- package/dist/modifiers/scroll.d.ts.map +1 -0
- package/dist/modifiers/scroll.js +82 -0
- package/dist/modifiers/scroll.js.map +1 -0
- package/dist/modifiers/shadows.cjs +2 -0
- package/dist/modifiers/shadows.cjs.map +1 -0
- package/dist/modifiers/shadows.d.ts +114 -0
- package/dist/modifiers/shadows.d.ts.map +1 -0
- package/dist/modifiers/shadows.js +147 -0
- package/dist/modifiers/shadows.js.map +1 -0
- package/dist/modifiers/size.cjs +2 -0
- package/dist/modifiers/size.cjs.map +1 -0
- package/dist/modifiers/size.d.ts +113 -0
- package/dist/modifiers/size.d.ts.map +1 -0
- package/dist/modifiers/size.js +74 -0
- package/dist/modifiers/size.js.map +1 -0
- package/dist/modifiers/text.cjs +2 -0
- package/dist/modifiers/text.cjs.map +1 -0
- package/dist/modifiers/text.d.ts +147 -0
- package/dist/modifiers/text.d.ts.map +1 -0
- package/dist/modifiers/text.js +166 -0
- package/dist/modifiers/text.js.map +1 -0
- package/dist/modifiers/transformations.cjs +2 -0
- package/dist/modifiers/transformations.cjs.map +1 -0
- package/dist/modifiers/transformations.d.ts +329 -0
- package/dist/modifiers/transformations.d.ts.map +1 -0
- package/dist/modifiers/transformations.js +216 -0
- package/dist/modifiers/transformations.js.map +1 -0
- package/dist/modifiers/transitions.cjs +2 -0
- package/dist/modifiers/transitions.cjs.map +1 -0
- package/dist/modifiers/transitions.d.ts +98 -0
- package/dist/modifiers/transitions.d.ts.map +1 -0
- package/dist/modifiers/transitions.js +102 -0
- package/dist/modifiers/transitions.js.map +1 -0
- package/dist/modifiers/types.cjs +2 -0
- package/dist/modifiers/types.cjs.map +1 -0
- package/dist/modifiers/types.d.ts +655 -0
- package/dist/modifiers/types.d.ts.map +1 -0
- package/dist/modifiers/types.js +5 -0
- package/dist/modifiers/types.js.map +1 -0
- package/dist/modifiers/typography.cjs +2 -0
- package/dist/modifiers/typography.cjs.map +1 -0
- package/dist/modifiers/typography.d.ts +192 -0
- package/dist/modifiers/typography.d.ts.map +1 -0
- package/dist/modifiers/typography.js +76 -0
- package/dist/modifiers/typography.js.map +1 -0
- package/dist/modifiers/utility.cjs +2 -0
- package/dist/modifiers/utility.cjs.map +1 -0
- package/dist/modifiers/utility.d.ts +69 -0
- package/dist/modifiers/utility.d.ts.map +1 -0
- package/dist/modifiers/utility.js +71 -0
- package/dist/modifiers/utility.js.map +1 -0
- package/dist/modifiers/utils.cjs +2 -0
- package/dist/modifiers/utils.cjs.map +1 -0
- package/dist/modifiers/utils.d.ts +75 -0
- package/dist/modifiers/utils.d.ts.map +1 -0
- package/dist/modifiers/utils.js +250 -0
- package/dist/modifiers/utils.js.map +1 -0
- package/dist/plugins/component-loader-registry.d.ts +143 -0
- package/dist/plugins/component-loader-registry.d.ts.map +1 -0
- package/dist/plugins/index.cjs +2 -0
- package/dist/plugins/index.cjs.map +1 -0
- package/dist/plugins/index.d.ts +17 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +34 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/legacy-adapter.cjs +2 -0
- package/dist/plugins/legacy-adapter.cjs.map +1 -0
- package/dist/plugins/legacy-adapter.d.ts +35 -0
- package/dist/plugins/legacy-adapter.d.ts.map +1 -0
- package/dist/plugins/legacy-adapter.js +30 -0
- package/dist/plugins/legacy-adapter.js.map +1 -0
- package/dist/plugins/simplified-component-registry.cjs +2 -0
- package/dist/plugins/simplified-component-registry.cjs.map +1 -0
- package/dist/plugins/simplified-component-registry.d.ts +40 -0
- package/dist/plugins/simplified-component-registry.d.ts.map +1 -0
- package/dist/plugins/simplified-component-registry.js +71 -0
- package/dist/plugins/simplified-component-registry.js.map +1 -0
- package/dist/plugins/simplified-error-handler.cjs +2 -0
- package/dist/plugins/simplified-error-handler.cjs.map +1 -0
- package/dist/plugins/simplified-error-handler.d.ts +83 -0
- package/dist/plugins/simplified-error-handler.d.ts.map +1 -0
- package/dist/plugins/simplified-error-handler.js +154 -0
- package/dist/plugins/simplified-error-handler.js.map +1 -0
- package/dist/plugins/simplified-index.d.ts +17 -0
- package/dist/plugins/simplified-index.d.ts.map +1 -0
- package/dist/plugins/simplified-lazy-loader.cjs +2 -0
- package/dist/plugins/simplified-lazy-loader.cjs.map +1 -0
- package/dist/plugins/simplified-lazy-loader.d.ts +65 -0
- package/dist/plugins/simplified-lazy-loader.d.ts.map +1 -0
- package/dist/plugins/simplified-lazy-loader.js +129 -0
- package/dist/plugins/simplified-lazy-loader.js.map +1 -0
- package/dist/plugins/simplified-plugin-manager.cjs +2 -0
- package/dist/plugins/simplified-plugin-manager.cjs.map +1 -0
- package/dist/plugins/simplified-plugin-manager.d.ts +24 -0
- package/dist/plugins/simplified-plugin-manager.d.ts.map +1 -0
- package/dist/plugins/simplified-plugin-manager.js +51 -0
- package/dist/plugins/simplified-plugin-manager.js.map +1 -0
- package/dist/plugins/simplified-tachui-instance.cjs +2 -0
- package/dist/plugins/simplified-tachui-instance.cjs.map +1 -0
- package/dist/plugins/simplified-tachui-instance.d.ts +54 -0
- package/dist/plugins/simplified-tachui-instance.d.ts.map +1 -0
- package/dist/plugins/simplified-tachui-instance.js +88 -0
- package/dist/plugins/simplified-tachui-instance.js.map +1 -0
- package/dist/plugins/simplified-types.cjs +2 -0
- package/dist/plugins/simplified-types.cjs.map +1 -0
- package/dist/plugins/simplified-types.d.ts +63 -0
- package/dist/plugins/simplified-types.d.ts.map +1 -0
- package/dist/plugins/simplified-types.js +9 -0
- package/dist/plugins/simplified-types.js.map +1 -0
- package/dist/plugins/simplified-utils.cjs +2 -0
- package/dist/plugins/simplified-utils.cjs.map +1 -0
- package/dist/plugins/simplified-utils.d.ts +39 -0
- package/dist/plugins/simplified-utils.d.ts.map +1 -0
- package/dist/plugins/simplified-utils.js +40 -0
- package/dist/plugins/simplified-utils.js.map +1 -0
- package/dist/reactive/cleanup.cjs +2 -0
- package/dist/reactive/cleanup.cjs.map +1 -0
- package/dist/reactive/cleanup.d.ts +115 -0
- package/dist/reactive/cleanup.d.ts.map +1 -0
- package/dist/reactive/cleanup.js +62 -0
- package/dist/reactive/cleanup.js.map +1 -0
- package/dist/reactive/computed.cjs +2 -0
- package/dist/reactive/computed.cjs.map +1 -0
- package/dist/reactive/computed.d.ts +115 -0
- package/dist/reactive/computed.d.ts.map +1 -0
- package/dist/reactive/computed.js +121 -0
- package/dist/reactive/computed.js.map +1 -0
- package/dist/reactive/context.cjs +2 -0
- package/dist/reactive/context.cjs.map +1 -0
- package/dist/reactive/context.d.ts +82 -0
- package/dist/reactive/context.d.ts.map +1 -0
- package/dist/reactive/context.js +143 -0
- package/dist/reactive/context.js.map +1 -0
- package/dist/reactive/effect.cjs +2 -0
- package/dist/reactive/effect.cjs.map +1 -0
- package/dist/reactive/effect.d.ts +79 -0
- package/dist/reactive/effect.d.ts.map +1 -0
- package/dist/reactive/effect.js +67 -0
- package/dist/reactive/effect.js.map +1 -0
- package/dist/reactive/enhanced-effect.cjs +2 -0
- package/dist/reactive/enhanced-effect.cjs.map +1 -0
- package/dist/reactive/enhanced-effect.d.ts +108 -0
- package/dist/reactive/enhanced-effect.d.ts.map +1 -0
- package/dist/reactive/enhanced-effect.js +153 -0
- package/dist/reactive/enhanced-effect.js.map +1 -0
- package/dist/reactive/enhanced-signal.cjs +2 -0
- package/dist/reactive/enhanced-signal.cjs.map +1 -0
- package/dist/reactive/enhanced-signal.d.ts +91 -0
- package/dist/reactive/enhanced-signal.d.ts.map +1 -0
- package/dist/reactive/enhanced-signal.js +117 -0
- package/dist/reactive/enhanced-signal.js.map +1 -0
- package/dist/reactive/equality.cjs +2 -0
- package/dist/reactive/equality.cjs.map +1 -0
- package/dist/reactive/equality.d.ts +51 -0
- package/dist/reactive/equality.d.ts.map +1 -0
- package/dist/reactive/equality.js +66 -0
- package/dist/reactive/equality.js.map +1 -0
- package/dist/reactive/index.cjs +2 -0
- package/dist/reactive/index.cjs.map +1 -0
- package/dist/reactive/index.d.ts +21 -0
- package/dist/reactive/index.d.ts.map +1 -0
- package/dist/reactive/index.js +95 -0
- package/dist/reactive/index.js.map +1 -0
- package/dist/reactive/migration.cjs +18 -0
- package/dist/reactive/migration.cjs.map +1 -0
- package/dist/reactive/migration.d.ts +104 -0
- package/dist/reactive/migration.d.ts.map +1 -0
- package/dist/reactive/migration.js +164 -0
- package/dist/reactive/migration.js.map +1 -0
- package/dist/reactive/ownership.cjs +2 -0
- package/dist/reactive/ownership.cjs.map +1 -0
- package/dist/reactive/ownership.d.ts +75 -0
- package/dist/reactive/ownership.d.ts.map +1 -0
- package/dist/reactive/ownership.js +34 -0
- package/dist/reactive/ownership.js.map +1 -0
- package/dist/reactive/scheduler.cjs +2 -0
- package/dist/reactive/scheduler.cjs.map +1 -0
- package/dist/reactive/scheduler.d.ts +56 -0
- package/dist/reactive/scheduler.d.ts.map +1 -0
- package/dist/reactive/scheduler.js +111 -0
- package/dist/reactive/scheduler.js.map +1 -0
- package/dist/reactive/signal.cjs +2 -0
- package/dist/reactive/signal.cjs.map +1 -0
- package/dist/reactive/signal.d.ts +82 -0
- package/dist/reactive/signal.d.ts.map +1 -0
- package/dist/reactive/signal.js +96 -0
- package/dist/reactive/signal.js.map +1 -0
- package/dist/reactive/theme.cjs +2 -0
- package/dist/reactive/theme.cjs.map +1 -0
- package/dist/reactive/theme.d.ts +12 -0
- package/dist/reactive/theme.d.ts.map +1 -0
- package/dist/reactive/theme.js +27 -0
- package/dist/reactive/theme.js.map +1 -0
- package/dist/reactive/types.cjs +2 -0
- package/dist/reactive/types.cjs.map +1 -0
- package/dist/reactive/types.d.ts +93 -0
- package/dist/reactive/types.d.ts.map +1 -0
- package/dist/reactive/types.js +5 -0
- package/dist/reactive/types.js.map +1 -0
- package/dist/reactive/unified-scheduler.cjs +2 -0
- package/dist/reactive/unified-scheduler.cjs.map +1 -0
- package/dist/reactive/unified-scheduler.d.ts +112 -0
- package/dist/reactive/unified-scheduler.d.ts.map +1 -0
- package/dist/reactive/unified-scheduler.js +219 -0
- package/dist/reactive/unified-scheduler.js.map +1 -0
- package/dist/runtime/component-context.cjs +2 -0
- package/dist/runtime/component-context.cjs.map +1 -0
- package/dist/runtime/component-context.d.ts +73 -0
- package/dist/runtime/component-context.d.ts.map +1 -0
- package/dist/runtime/component-context.js +177 -0
- package/dist/runtime/component-context.js.map +1 -0
- package/dist/runtime/component.cjs +2 -0
- package/dist/runtime/component.cjs.map +1 -0
- package/dist/runtime/component.d.ts +112 -0
- package/dist/runtime/component.d.ts.map +1 -0
- package/dist/runtime/component.js +238 -0
- package/dist/runtime/component.js.map +1 -0
- package/dist/runtime/context.cjs +2 -0
- package/dist/runtime/context.cjs.map +1 -0
- package/dist/runtime/context.d.ts +138 -0
- package/dist/runtime/context.d.ts.map +1 -0
- package/dist/runtime/context.js +289 -0
- package/dist/runtime/context.js.map +1 -0
- package/dist/runtime/dev-tools.cjs +2 -0
- package/dist/runtime/dev-tools.cjs.map +1 -0
- package/dist/runtime/dev-tools.d.ts +240 -0
- package/dist/runtime/dev-tools.d.ts.map +1 -0
- package/dist/runtime/dev-tools.js +391 -0
- package/dist/runtime/dev-tools.js.map +1 -0
- package/dist/runtime/development-warnings.cjs +2 -0
- package/dist/runtime/development-warnings.cjs.map +1 -0
- package/dist/runtime/development-warnings.d.ts +42 -0
- package/dist/runtime/development-warnings.d.ts.map +1 -0
- package/dist/runtime/development-warnings.js +69 -0
- package/dist/runtime/development-warnings.js.map +1 -0
- package/dist/runtime/dom-bridge.cjs +2 -0
- package/dist/runtime/dom-bridge.cjs.map +1 -0
- package/dist/runtime/dom-bridge.d.ts +70 -0
- package/dist/runtime/dom-bridge.d.ts.map +1 -0
- package/dist/runtime/dom-bridge.js +241 -0
- package/dist/runtime/dom-bridge.js.map +1 -0
- package/dist/runtime/element-override.cjs +2 -0
- package/dist/runtime/element-override.cjs.map +1 -0
- package/dist/runtime/element-override.d.ts +82 -0
- package/dist/runtime/element-override.d.ts.map +1 -0
- package/dist/runtime/element-override.js +214 -0
- package/dist/runtime/element-override.js.map +1 -0
- package/dist/runtime/error-boundary.cjs +2 -0
- package/dist/runtime/error-boundary.cjs.map +1 -0
- package/dist/runtime/error-boundary.d.ts +302 -0
- package/dist/runtime/error-boundary.d.ts.map +1 -0
- package/dist/runtime/error-boundary.js +559 -0
- package/dist/runtime/error-boundary.js.map +1 -0
- package/dist/runtime/error-recovery.cjs +2 -0
- package/dist/runtime/error-recovery.cjs.map +1 -0
- package/dist/runtime/error-recovery.d.ts +267 -0
- package/dist/runtime/error-recovery.d.ts.map +1 -0
- package/dist/runtime/error-recovery.js +385 -0
- package/dist/runtime/error-recovery.js.map +1 -0
- package/dist/runtime/error-reporting.cjs +3 -0
- package/dist/runtime/error-reporting.cjs.map +1 -0
- package/dist/runtime/error-reporting.d.ts +287 -0
- package/dist/runtime/error-reporting.d.ts.map +1 -0
- package/dist/runtime/error-reporting.js +479 -0
- package/dist/runtime/error-reporting.js.map +1 -0
- package/dist/runtime/error-utils.cjs +3 -0
- package/dist/runtime/error-utils.cjs.map +1 -0
- package/dist/runtime/error-utils.d.ts +204 -0
- package/dist/runtime/error-utils.d.ts.map +1 -0
- package/dist/runtime/error-utils.js +352 -0
- package/dist/runtime/error-utils.js.map +1 -0
- package/dist/runtime/index.d.ts +29 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/lazy-component.cjs +2 -0
- package/dist/runtime/lazy-component.cjs.map +1 -0
- package/dist/runtime/lazy-component.d.ts +58 -0
- package/dist/runtime/lazy-component.d.ts.map +1 -0
- package/dist/runtime/lazy-component.js +129 -0
- package/dist/runtime/lazy-component.js.map +1 -0
- package/dist/runtime/lifecycle.cjs +2 -0
- package/dist/runtime/lifecycle.cjs.map +1 -0
- package/dist/runtime/lifecycle.d.ts +8 -0
- package/dist/runtime/lifecycle.d.ts.map +1 -0
- package/dist/runtime/lifecycle.js +7 -0
- package/dist/runtime/lifecycle.js.map +1 -0
- package/dist/runtime/mounting.cjs +2 -0
- package/dist/runtime/mounting.cjs.map +1 -0
- package/dist/runtime/mounting.d.ts +9 -0
- package/dist/runtime/mounting.d.ts.map +1 -0
- package/dist/runtime/mounting.js +12 -0
- package/dist/runtime/mounting.js.map +1 -0
- package/dist/runtime/optimization.cjs +2 -0
- package/dist/runtime/optimization.cjs.map +1 -0
- package/dist/runtime/optimization.d.ts +8 -0
- package/dist/runtime/optimization.d.ts.map +1 -0
- package/dist/runtime/optimization.js +6 -0
- package/dist/runtime/optimization.js.map +1 -0
- package/dist/runtime/performance.cjs +2 -0
- package/dist/runtime/performance.cjs.map +1 -0
- package/dist/runtime/performance.d.ts +217 -0
- package/dist/runtime/performance.d.ts.map +1 -0
- package/dist/runtime/performance.js +399 -0
- package/dist/runtime/performance.js.map +1 -0
- package/dist/runtime/props.cjs +2 -0
- package/dist/runtime/props.cjs.map +1 -0
- package/dist/runtime/props.d.ts +154 -0
- package/dist/runtime/props.d.ts.map +1 -0
- package/dist/runtime/props.js +265 -0
- package/dist/runtime/props.js.map +1 -0
- package/dist/runtime/refs.d.ts +8 -0
- package/dist/runtime/refs.d.ts.map +1 -0
- package/dist/runtime/renderer.cjs +2 -0
- package/dist/runtime/renderer.cjs.map +1 -0
- package/dist/runtime/renderer.d.ts +116 -0
- package/dist/runtime/renderer.d.ts.map +1 -0
- package/dist/runtime/renderer.js +390 -0
- package/dist/runtime/renderer.js.map +1 -0
- package/dist/runtime/semantic-role-manager.cjs +2 -0
- package/dist/runtime/semantic-role-manager.cjs.map +1 -0
- package/dist/runtime/semantic-role-manager.d.ts +37 -0
- package/dist/runtime/semantic-role-manager.d.ts.map +1 -0
- package/dist/runtime/semantic-role-manager.js +82 -0
- package/dist/runtime/semantic-role-manager.js.map +1 -0
- package/dist/runtime/types.d.ts +230 -0
- package/dist/runtime/types.d.ts.map +1 -0
- package/dist/state/binding.cjs +2 -0
- package/dist/state/binding.cjs.map +1 -0
- package/dist/state/binding.d.ts +96 -0
- package/dist/state/binding.d.ts.map +1 -0
- package/dist/state/binding.js +155 -0
- package/dist/state/binding.js.map +1 -0
- package/dist/state/environment-object.d.ts +130 -0
- package/dist/state/environment-object.d.ts.map +1 -0
- package/dist/state/environment.cjs +2 -0
- package/dist/state/environment.cjs.map +1 -0
- package/dist/state/environment.d.ts +178 -0
- package/dist/state/environment.d.ts.map +1 -0
- package/dist/state/environment.js +115 -0
- package/dist/state/environment.js.map +1 -0
- package/dist/state/index.cjs +2 -0
- package/dist/state/index.cjs.map +1 -0
- package/dist/state/index.d.ts +108 -0
- package/dist/state/index.d.ts.map +1 -0
- package/dist/state/index.js +63 -0
- package/dist/state/index.js.map +1 -0
- package/dist/state/observed-object.cjs +2 -0
- package/dist/state/observed-object.cjs.map +1 -0
- package/dist/state/observed-object.d.ts +126 -0
- package/dist/state/observed-object.d.ts.map +1 -0
- package/dist/state/observed-object.js +163 -0
- package/dist/state/observed-object.js.map +1 -0
- package/dist/state/state-manager.cjs +2 -0
- package/dist/state/state-manager.cjs.map +1 -0
- package/dist/state/state-manager.d.ts +97 -0
- package/dist/state/state-manager.d.ts.map +1 -0
- package/dist/state/state-manager.js +233 -0
- package/dist/state/state-manager.js.map +1 -0
- package/dist/state/state.cjs +2 -0
- package/dist/state/state.cjs.map +1 -0
- package/dist/state/state.d.ts +78 -0
- package/dist/state/state.d.ts.map +1 -0
- package/dist/state/state.js +159 -0
- package/dist/state/state.js.map +1 -0
- package/dist/state/types.d.ts +159 -0
- package/dist/state/types.d.ts.map +1 -0
- package/dist/sui-compat.cjs +2 -0
- package/dist/sui-compat.cjs.map +1 -0
- package/dist/sui-compat.d.ts +110 -0
- package/dist/sui-compat.d.ts.map +1 -0
- package/dist/sui-compat.js +88 -0
- package/dist/sui-compat.js.map +1 -0
- package/dist/validation/advanced-debugging.cjs +44 -0
- package/dist/validation/advanced-debugging.cjs.map +1 -0
- package/dist/validation/advanced-debugging.d.ts +319 -0
- package/dist/validation/advanced-debugging.d.ts.map +1 -0
- package/dist/validation/advanced-debugging.js +455 -0
- package/dist/validation/advanced-debugging.js.map +1 -0
- package/dist/validation/build-time/detection.cjs +2 -0
- package/dist/validation/build-time/detection.cjs.map +1 -0
- package/dist/validation/build-time/detection.d.ts +32 -0
- package/dist/validation/build-time/detection.d.ts.map +1 -0
- package/dist/validation/build-time/detection.js +199 -0
- package/dist/validation/build-time/detection.js.map +1 -0
- package/dist/validation/build-time/index.cjs +2 -0
- package/dist/validation/build-time/index.cjs.map +1 -0
- package/dist/validation/build-time/index.d.ts +84 -0
- package/dist/validation/build-time/index.d.ts.map +1 -0
- package/dist/validation/build-time/index.js +122 -0
- package/dist/validation/build-time/index.js.map +1 -0
- package/dist/validation/build-time/plugins.cjs +3 -0
- package/dist/validation/build-time/plugins.cjs.map +1 -0
- package/dist/validation/build-time/plugins.d.ts +75 -0
- package/dist/validation/build-time/plugins.d.ts.map +1 -0
- package/dist/validation/build-time/plugins.js +282 -0
- package/dist/validation/build-time/plugins.js.map +1 -0
- package/dist/validation/build-time/rules.cjs +2 -0
- package/dist/validation/build-time/rules.cjs.map +1 -0
- package/dist/validation/build-time/rules.d.ts +73 -0
- package/dist/validation/build-time/rules.d.ts.map +1 -0
- package/dist/validation/build-time/rules.js +576 -0
- package/dist/validation/build-time/rules.js.map +1 -0
- package/dist/validation/build-time/transformer.cjs +3 -0
- package/dist/validation/build-time/transformer.cjs.map +1 -0
- package/dist/validation/build-time/transformer.d.ts +23 -0
- package/dist/validation/build-time/transformer.d.ts.map +1 -0
- package/dist/validation/build-time/transformer.js +177 -0
- package/dist/validation/build-time/transformer.js.map +1 -0
- package/dist/validation/build-time/types.d.ts +212 -0
- package/dist/validation/build-time/types.d.ts.map +1 -0
- package/dist/validation/comprehensive.cjs +9 -0
- package/dist/validation/comprehensive.cjs.map +1 -0
- package/dist/validation/comprehensive.d.ts +160 -0
- package/dist/validation/comprehensive.d.ts.map +1 -0
- package/dist/validation/comprehensive.js +916 -0
- package/dist/validation/comprehensive.js.map +1 -0
- package/dist/validation/debug-tools.cjs +16 -0
- package/dist/validation/debug-tools.cjs.map +1 -0
- package/dist/validation/debug-tools.d.ts +251 -0
- package/dist/validation/debug-tools.d.ts.map +1 -0
- package/dist/validation/debug-tools.js +405 -0
- package/dist/validation/debug-tools.js.map +1 -0
- package/dist/validation/developer-experience.cjs +17 -0
- package/dist/validation/developer-experience.cjs.map +1 -0
- package/dist/validation/developer-experience.d.ts +243 -0
- package/dist/validation/developer-experience.d.ts.map +1 -0
- package/dist/validation/developer-experience.js +433 -0
- package/dist/validation/developer-experience.js.map +1 -0
- package/dist/validation/documentation-integration.cjs +7 -0
- package/dist/validation/documentation-integration.cjs.map +1 -0
- package/dist/validation/documentation-integration.d.ts +269 -0
- package/dist/validation/documentation-integration.d.ts.map +1 -0
- package/dist/validation/documentation-integration.js +440 -0
- package/dist/validation/documentation-integration.js.map +1 -0
- package/dist/validation/enhanced-runtime.cjs +6 -0
- package/dist/validation/enhanced-runtime.cjs.map +1 -0
- package/dist/validation/enhanced-runtime.d.ts +279 -0
- package/dist/validation/enhanced-runtime.d.ts.map +1 -0
- package/dist/validation/enhanced-runtime.js +465 -0
- package/dist/validation/enhanced-runtime.js.map +1 -0
- package/dist/validation/error-reporting.cjs +32 -0
- package/dist/validation/error-reporting.cjs.map +1 -0
- package/dist/validation/error-reporting.d.ts +186 -0
- package/dist/validation/error-reporting.d.ts.map +1 -0
- package/dist/validation/error-reporting.js +370 -0
- package/dist/validation/error-reporting.js.map +1 -0
- package/dist/validation/ide-integration.cjs +85 -0
- package/dist/validation/ide-integration.cjs.map +1 -0
- package/dist/validation/ide-integration.d.ts +328 -0
- package/dist/validation/ide-integration.d.ts.map +1 -0
- package/dist/validation/ide-integration.js +557 -0
- package/dist/validation/ide-integration.js.map +1 -0
- package/dist/validation/index.cjs +6 -0
- package/dist/validation/index.cjs.map +1 -0
- package/dist/validation/index.d.ts +171 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +309 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/lifecycle-validation.cjs +2 -0
- package/dist/validation/lifecycle-validation.cjs.map +1 -0
- package/dist/validation/lifecycle-validation.d.ts +165 -0
- package/dist/validation/lifecycle-validation.d.ts.map +1 -0
- package/dist/validation/lifecycle-validation.js +314 -0
- package/dist/validation/lifecycle-validation.js.map +1 -0
- package/dist/validation/performance-optimizer.cjs +2 -0
- package/dist/validation/performance-optimizer.cjs.map +1 -0
- package/dist/validation/performance-optimizer.d.ts +218 -0
- package/dist/validation/performance-optimizer.d.ts.map +1 -0
- package/dist/validation/performance-optimizer.js +338 -0
- package/dist/validation/performance-optimizer.js.map +1 -0
- package/dist/validation/plugin-registration.cjs +2 -0
- package/dist/validation/plugin-registration.cjs.map +1 -0
- package/dist/validation/plugin-registration.d.ts +88 -0
- package/dist/validation/plugin-registration.d.ts.map +1 -0
- package/dist/validation/plugin-registration.js +126 -0
- package/dist/validation/plugin-registration.js.map +1 -0
- package/dist/validation/production-bypass.cjs +2 -0
- package/dist/validation/production-bypass.cjs.map +1 -0
- package/dist/validation/production-bypass.d.ts +175 -0
- package/dist/validation/production-bypass.d.ts.map +1 -0
- package/dist/validation/production-bypass.js +218 -0
- package/dist/validation/production-bypass.js.map +1 -0
- package/dist/validation/simple.cjs +9 -0
- package/dist/validation/simple.cjs.map +1 -0
- package/dist/validation/simple.d.ts +111 -0
- package/dist/validation/simple.d.ts.map +1 -0
- package/dist/validation/simple.js +146 -0
- package/dist/validation/simple.js.map +1 -0
- package/dist/viewport/adapters/web-adapter.cjs +70 -0
- package/dist/viewport/adapters/web-adapter.cjs.map +1 -0
- package/dist/viewport/adapters/web-adapter.d.ts +227 -0
- package/dist/viewport/adapters/web-adapter.d.ts.map +1 -0
- package/dist/viewport/adapters/web-adapter.js +823 -0
- package/dist/viewport/adapters/web-adapter.js.map +1 -0
- package/dist/viewport/components.cjs +2 -0
- package/dist/viewport/components.cjs.map +1 -0
- package/dist/viewport/components.d.ts +131 -0
- package/dist/viewport/components.d.ts.map +1 -0
- package/dist/viewport/components.js +298 -0
- package/dist/viewport/components.js.map +1 -0
- package/dist/viewport/environment.cjs +2 -0
- package/dist/viewport/environment.cjs.map +1 -0
- package/dist/viewport/environment.d.ts +75 -0
- package/dist/viewport/environment.d.ts.map +1 -0
- package/dist/viewport/environment.js +86 -0
- package/dist/viewport/environment.js.map +1 -0
- package/dist/viewport/index.cjs +2 -0
- package/dist/viewport/index.cjs.map +1 -0
- package/dist/viewport/index.d.ts +138 -0
- package/dist/viewport/index.d.ts.map +1 -0
- package/dist/viewport/index.js +166 -0
- package/dist/viewport/index.js.map +1 -0
- package/dist/viewport/platform-detection.cjs +2 -0
- package/dist/viewport/platform-detection.cjs.map +1 -0
- package/dist/viewport/platform-detection.d.ts +59 -0
- package/dist/viewport/platform-detection.d.ts.map +1 -0
- package/dist/viewport/platform-detection.js +205 -0
- package/dist/viewport/platform-detection.js.map +1 -0
- package/dist/viewport/types.cjs +2 -0
- package/dist/viewport/types.cjs.map +1 -0
- package/dist/viewport/types.d.ts +301 -0
- package/dist/viewport/types.d.ts.map +1 -0
- package/dist/viewport/types.js +13 -0
- package/dist/viewport/types.js.map +1 -0
- package/dist/viewport/viewport-manager.cjs +2 -0
- package/dist/viewport/viewport-manager.cjs.map +1 -0
- package/dist/viewport/viewport-manager.d.ts +118 -0
- package/dist/viewport/viewport-manager.d.ts.map +1 -0
- package/dist/viewport/viewport-manager.js +524 -0
- package/dist/viewport/viewport-manager.js.map +1 -0
- package/package.json +128 -0
- package/src/assets/Asset.ts +11 -0
- package/src/assets/AssetCollection.ts +99 -0
- package/src/assets/ColorAsset.ts +210 -0
- package/src/assets/FontAsset.ts +380 -0
- package/src/assets/ImageAsset.ts +91 -0
- package/src/assets/README.md +190 -0
- package/src/assets/index.ts +175 -0
- package/src/assets/test-assets.ts +69 -0
- package/src/assets/test-integration.ts +46 -0
- package/src/assets/test-simple.ts +28 -0
- package/src/assets/types.ts +79 -0
- package/src/bundles/common.ts +30 -0
- package/src/bundles/complete.ts +29 -0
- package/src/bundles/essential.ts +26 -0
- package/src/bundles/minimal.ts +26 -0
- package/src/bundles/production-minimal.ts +67 -0
- package/src/compiler/advanced-parser.ts +871 -0
- package/src/compiler/codegen.ts +450 -0
- package/src/compiler/enhanced-codegen.ts +729 -0
- package/src/compiler/index.ts +25 -0
- package/src/compiler/parser.ts +461 -0
- package/src/compiler/plugin.ts +181 -0
- package/src/compiler/types.ts +177 -0
- package/src/components/BasicInput.ts +352 -0
- package/src/components/Button.ts +963 -0
- package/src/components/Divider.ts +341 -0
- package/src/components/EnhancedLink.ts +676 -0
- package/src/components/Form.ts +414 -0
- package/src/components/Grid.ts +2507 -0
- package/src/components/GridResponsive.ts +637 -0
- package/src/components/Image.ts +426 -0
- package/src/components/List.ts +1084 -0
- package/src/components/Menu.ts +807 -0
- package/src/components/Picker.ts +678 -0
- package/src/components/ScrollView.ts +725 -0
- package/src/components/Section.ts +472 -0
- package/src/components/Show.ts +205 -0
- package/src/components/Spacer.ts +93 -0
- package/src/components/Text.ts +447 -0
- package/src/components/Toggle.ts +700 -0
- package/src/components/index.ts +231 -0
- package/src/components/wrapper.ts +828 -0
- package/src/concatenation/concatenatable.ts +211 -0
- package/src/concatenation/concatenated-component.ts +471 -0
- package/src/concatenation/index.ts +41 -0
- package/src/concatenation/styles.css +120 -0
- package/src/concatenation/text-optimizer.ts +440 -0
- package/src/concatenation/types.ts +116 -0
- package/src/constants/README.md +339 -0
- package/src/constants/__tests__/frame-utils.test.ts +276 -0
- package/src/constants/__tests__/layout.test.ts +215 -0
- package/src/constants/frame-utils.ts +174 -0
- package/src/constants/index.ts +8 -0
- package/src/constants/layout.ts +120 -0
- package/src/css-classes/component-base.ts +117 -0
- package/src/css-classes/css-class-manager.ts +372 -0
- package/src/css-classes/dom-integration.ts +162 -0
- package/src/css-classes/enhanced-renderer.ts +166 -0
- package/src/css-classes/index.ts +45 -0
- package/src/css-classes/types.ts +73 -0
- package/src/css-classes/utilities.ts +175 -0
- package/src/debug/index.ts +267 -0
- package/src/developer-experience/enhanced-errors.ts +556 -0
- package/src/developer-experience/enhanced-types.ts +427 -0
- package/src/developer-experience/index.ts +220 -0
- package/src/globals.d.ts +43 -0
- package/src/gradients/__tests__/angular-gradient.test.ts +111 -0
- package/src/gradients/__tests__/background-modifier.test.ts +81 -0
- package/src/gradients/__tests__/comprehensive-gradients.test.ts +296 -0
- package/src/gradients/__tests__/gradient-asset.test.ts +144 -0
- package/src/gradients/__tests__/linear-gradient.test.ts +92 -0
- package/src/gradients/__tests__/phase4-features.test.ts +386 -0
- package/src/gradients/__tests__/radial-gradient.test.ts +110 -0
- package/src/gradients/__tests__/repeating-gradients.test.ts +125 -0
- package/src/gradients/__tests__/state-background-modifier.test.ts +340 -0
- package/src/gradients/__tests__/state-gradient-asset.test.ts +262 -0
- package/src/gradients/__tests__/state-gradient-integration.test.ts +277 -0
- package/src/gradients/css-generator.ts +158 -0
- package/src/gradients/examples.ts +632 -0
- package/src/gradients/gradient-asset.ts +30 -0
- package/src/gradients/index.ts +85 -0
- package/src/gradients/performance.ts +521 -0
- package/src/gradients/presets.ts +422 -0
- package/src/gradients/reactive.ts +470 -0
- package/src/gradients/state-gradient-asset.ts +179 -0
- package/src/gradients/types.ts +148 -0
- package/src/gradients/utils.ts +579 -0
- package/src/gradients/validation.ts +489 -0
- package/src/index.ts +168 -0
- package/src/lifecycle/hooks.ts +332 -0
- package/src/modifiers/__tests__/as-html-integration.test.ts +204 -0
- package/src/modifiers/__tests__/as-html.test.ts +437 -0
- package/src/modifiers/__tests__/basic-sanitizer-security.test.ts +294 -0
- package/src/modifiers/__tests__/border.test.ts +371 -0
- package/src/modifiers/__tests__/margin-string-support.test.ts +41 -0
- package/src/modifiers/__tests__/padding-string-support.test.ts +41 -0
- package/src/modifiers/as-html-validator.ts +68 -0
- package/src/modifiers/as-html.ts +216 -0
- package/src/modifiers/attributes.ts +574 -0
- package/src/modifiers/backdrop.ts +290 -0
- package/src/modifiers/background.ts +165 -0
- package/src/modifiers/base.ts +1815 -0
- package/src/modifiers/basic-sanitizer.ts +227 -0
- package/src/modifiers/border.ts +574 -0
- package/src/modifiers/builder.ts +1747 -0
- package/src/modifiers/core.ts +521 -0
- package/src/modifiers/css.ts +148 -0
- package/src/modifiers/effects.ts +412 -0
- package/src/modifiers/elements.ts +541 -0
- package/src/modifiers/filters.ts +501 -0
- package/src/modifiers/flexbox.ts +180 -0
- package/src/modifiers/font.ts +149 -0
- package/src/modifiers/grid.ts +238 -0
- package/src/modifiers/index.ts +481 -0
- package/src/modifiers/margin.ts +218 -0
- package/src/modifiers/padding.ts +318 -0
- package/src/modifiers/registry.ts +444 -0
- package/src/modifiers/responsive/__tests__/advanced-media-queries.test.ts +392 -0
- package/src/modifiers/responsive/__tests__/advanced-utilities.test.ts +368 -0
- package/src/modifiers/responsive/__tests__/comprehensive-browser-tests.test.ts +556 -0
- package/src/modifiers/responsive/__tests__/layout-patterns.test.ts +558 -0
- package/src/modifiers/responsive/advanced-utilities.ts +562 -0
- package/src/modifiers/responsive/breakpoints.ts +330 -0
- package/src/modifiers/responsive/css-generator.ts +432 -0
- package/src/modifiers/responsive/dev-tools.ts +650 -0
- package/src/modifiers/responsive/index.ts +119 -0
- package/src/modifiers/responsive/layout-patterns.ts +592 -0
- package/src/modifiers/responsive/performance.ts +385 -0
- package/src/modifiers/responsive/responsive-builder.ts +620 -0
- package/src/modifiers/responsive/responsive-modifier.ts +410 -0
- package/src/modifiers/responsive/types.ts +226 -0
- package/src/modifiers/responsive/utilities.ts +478 -0
- package/src/modifiers/scroll.ts +297 -0
- package/src/modifiers/shadows.ts +321 -0
- package/src/modifiers/size.ts +208 -0
- package/src/modifiers/text.ts +416 -0
- package/src/modifiers/transformations.ts +640 -0
- package/src/modifiers/transitions.ts +218 -0
- package/src/modifiers/types.ts +889 -0
- package/src/modifiers/typography.ts +341 -0
- package/src/modifiers/utility.ts +209 -0
- package/src/modifiers/utils.ts +413 -0
- package/src/plugins/__tests__/simplified-plugin-system.test.ts +190 -0
- package/src/plugins/component-loader-registry.ts +371 -0
- package/src/plugins/index.ts +61 -0
- package/src/plugins/legacy-adapter.ts +84 -0
- package/src/plugins/simplified-component-registry.ts +130 -0
- package/src/plugins/simplified-error-handler.ts +372 -0
- package/src/plugins/simplified-index.ts +61 -0
- package/src/plugins/simplified-lazy-loader.ts +242 -0
- package/src/plugins/simplified-plugin-manager.ts +93 -0
- package/src/plugins/simplified-tachui-instance.ts +142 -0
- package/src/plugins/simplified-types.ts +79 -0
- package/src/plugins/simplified-utils.ts +118 -0
- package/src/reactive/cleanup.ts +241 -0
- package/src/reactive/computed.ts +281 -0
- package/src/reactive/context.ts +287 -0
- package/src/reactive/effect.ts +194 -0
- package/src/reactive/enhanced-effect.ts +318 -0
- package/src/reactive/enhanced-signal.ts +227 -0
- package/src/reactive/equality.ts +188 -0
- package/src/reactive/globals.d.ts +5 -0
- package/src/reactive/index.ts +150 -0
- package/src/reactive/migration.ts +335 -0
- package/src/reactive/ownership.ts +182 -0
- package/src/reactive/scheduler.ts +300 -0
- package/src/reactive/signal.ts +201 -0
- package/src/reactive/theme.ts +49 -0
- package/src/reactive/types.ts +103 -0
- package/src/reactive/unified-scheduler.ts +357 -0
- package/src/runtime/component-context.ts +343 -0
- package/src/runtime/component.ts +499 -0
- package/src/runtime/context.ts +527 -0
- package/src/runtime/dev-tools.ts +752 -0
- package/src/runtime/development-warnings.ts +114 -0
- package/src/runtime/dom-bridge.ts +570 -0
- package/src/runtime/element-override.ts +282 -0
- package/src/runtime/error-boundary.ts +955 -0
- package/src/runtime/error-recovery.ts +638 -0
- package/src/runtime/error-reporting.ts +808 -0
- package/src/runtime/error-utils.ts +698 -0
- package/src/runtime/index.ts +202 -0
- package/src/runtime/lazy-component.ts +268 -0
- package/src/runtime/lifecycle.ts +10 -0
- package/src/runtime/mounting.ts +17 -0
- package/src/runtime/optimization.ts +13 -0
- package/src/runtime/performance.ts +693 -0
- package/src/runtime/props.ts +434 -0
- package/src/runtime/refs.ts +13 -0
- package/src/runtime/renderer.ts +674 -0
- package/src/runtime/semantic-role-manager.ts +140 -0
- package/src/runtime/types.ts +282 -0
- package/src/state/binding.ts +381 -0
- package/src/state/environment-object.ts +444 -0
- package/src/state/environment.ts +351 -0
- package/src/state/index.ts +179 -0
- package/src/state/observed-object.ts +405 -0
- package/src/state/state-manager.ts +366 -0
- package/src/state/state.ts +339 -0
- package/src/state/types.ts +192 -0
- package/src/sui-compat.ts +163 -0
- package/src/validation/__tests__/phase-1d-integration.test.ts +558 -0
- package/src/validation/advanced-debugging.ts +860 -0
- package/src/validation/build-time/detection.ts +373 -0
- package/src/validation/build-time/index.ts +222 -0
- package/src/validation/build-time/plugins.ts +515 -0
- package/src/validation/build-time/rules.ts +624 -0
- package/src/validation/build-time/transformer.ts +372 -0
- package/src/validation/build-time/types.ts +232 -0
- package/src/validation/comprehensive.ts +1272 -0
- package/src/validation/debug-tools.ts +724 -0
- package/src/validation/developer-experience.ts +712 -0
- package/src/validation/documentation-integration.ts +835 -0
- package/src/validation/enhanced-runtime.ts +765 -0
- package/src/validation/error-reporting.ts +587 -0
- package/src/validation/ide-integration.ts +845 -0
- package/src/validation/index.ts +353 -0
- package/src/validation/lifecycle-validation.ts +636 -0
- package/src/validation/performance-optimizer.ts +599 -0
- package/src/validation/plugin-registration.ts +249 -0
- package/src/validation/production-bypass.ts +466 -0
- package/src/validation/simple.ts +465 -0
- package/src/viewport/adapters/web-adapter.ts +1385 -0
- package/src/viewport/components.ts +505 -0
- package/src/viewport/environment.ts +173 -0
- package/src/viewport/index.ts +290 -0
- package/src/viewport/platform-detection.ts +431 -0
- package/src/viewport/types.ts +371 -0
- package/src/viewport/viewport-manager.ts +979 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css-class-manager.js","sources":["../../src/css-classes/css-class-manager.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Class Manager\n *\n * Core CSS class processing system that handles sanitization,\n * deduplication, and integration with tachUI components.\n */\n\nimport { isSignal, isComputed } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type {\n CSSClassProcessor,\n CSSClassConfig,\n ClassProcessingResult\n} from './types'\n\n/**\n * Default configuration for CSS class processing\n */\nconst DEFAULT_CONFIG: CSSClassConfig = {\n sanitizeClassNames: true,\n sanitizationRules: {\n allowNumbers: true,\n allowUnderscores: true,\n customReplacements: {}\n },\n enableCaching: true,\n maxCacheSize: 1000,\n warnDuplicateClasses: process.env.NODE_ENV === 'development',\n warnInvalidClasses: process.env.NODE_ENV === 'development'\n}\n\n/**\n * CSS Class Manager - Core processing system\n */\nexport class CSSClassManager implements CSSClassProcessor {\n private config: CSSClassConfig\n private classCache: Map<string, string[]> | { [key: string]: string[] }\n private processingCache: Map<string, ClassProcessingResult> | { [key: string]: ClassProcessingResult }\n\n constructor(config: Partial<CSSClassConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config }\n\n // Initialize caches with Map if available, otherwise use plain objects\n // Use safe check for Map availability to handle all edge cases\n const mapAvailable = (() => {\n try {\n return typeof Map !== 'undefined' && typeof Map === 'function'\n } catch (_e) {\n return false\n }\n })()\n\n this.classCache = mapAvailable ? new Map() : {}\n this.processingCache = mapAvailable ? new Map() : {}\n }\n\n /**\n * Cache helper methods to work with both Map and plain object fallbacks\n */\n private cacheHas(cache: Map<string, any> | { [key: string]: any }, key: string): boolean {\n try {\n return cache instanceof Map ? cache.has(key) : key in cache\n } catch (_e) {\n // Fallback if Map check fails\n return key in cache\n }\n }\n\n private cacheGet<T>(cache: Map<string, T> | { [key: string]: T }, key: string): T | undefined {\n try {\n return cache instanceof Map ? cache.get(key) : cache[key]\n } catch (_e) {\n return (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheSet<T>(cache: Map<string, T> | { [key: string]: T }, key: string, value: T): void {\n try {\n if (cache instanceof Map) {\n cache.set(key, value)\n } else {\n cache[key] = value\n }\n } catch (_e) {\n ;(cache as { [key: string]: T })[key] = value\n }\n }\n\n private cacheDelete<T>(cache: Map<string, T> | { [key: string]: T }, key: string): void {\n try {\n if (cache instanceof Map) {\n cache.delete(key)\n } else {\n delete cache[key]\n }\n } catch (_e) {\n delete (cache as { [key: string]: T })[key]\n }\n }\n\n private cacheClear<T>(cache: Map<string, T> | { [key: string]: T }): void {\n try {\n if (cache instanceof Map) {\n cache.clear()\n } else {\n Object.keys(cache).forEach(key => delete cache[key])\n }\n } catch (_e) {\n Object.keys(cache as { [key: string]: T }).forEach(key => delete (cache as { [key: string]: T })[key])\n }\n }\n\n private cacheSize<T>(cache: Map<string, T> | { [key: string]: T }): number {\n try {\n return cache instanceof Map ? cache.size : Object.keys(cache).length\n } catch (_e) {\n return Object.keys(cache).length\n }\n }\n\n private cacheKeys<T>(cache: Map<string, T> | { [key: string]: T }): IterableIterator<string> | string[] {\n try {\n return cache instanceof Map ? cache.keys() : Object.keys(cache)\n } catch (_e) {\n return Object.keys(cache)\n }\n }\n\n /**\n * Process CSS classes from various input formats\n */\n processClasses(input: string | string[] | Signal<string | string[]>): string[] {\n if (!input) return []\n\n // Handle reactive signals and computed values - no caching for dynamic values\n if (isSignal(input) || isComputed(input)) {\n const resolved = input()\n return this.processClasses(resolved)\n }\n\n // Check cache for static inputs\n const cacheKey = this.getCacheKey(input)\n if (this.config.enableCaching && this.cacheHas(this.classCache, cacheKey)) {\n return this.cacheGet(this.classCache, cacheKey)!\n }\n\n let classes: string[] = []\n\n // Handle string input - split on whitespace\n if (typeof input === 'string') {\n classes = input.trim().split(/\\s+/).filter(Boolean)\n }\n // Handle array input - flatten and filter, convert non-strings to strings\n else if (Array.isArray(input)) {\n classes = input\n .flatMap(cls => {\n if (cls === null || cls === undefined || cls === '') {\n return [] // Skip null, undefined, and empty strings\n }\n // Convert non-strings to strings\n const stringified = typeof cls === 'string' ? cls : String(cls)\n const trimmed = stringified.trim()\n\n // For non-string values that have been stringified, treat as single class name\n // to preserve object representations like \"[object Object]\"\n if (typeof cls !== 'string' && trimmed) {\n return [trimmed]\n }\n\n // For strings, split on whitespace as normal\n return trimmed.split(/\\s+/)\n })\n .filter(Boolean)\n }\n // Handle other types by converting to string (for edge case testing)\n // Treat the entire stringified value as a single class name to preserve object representations\n else {\n const stringified = String(input).trim()\n classes = stringified ? [stringified] : []\n }\n\n // Process classes through sanitization and deduplication\n const processed = this.processClassArray(classes)\n\n // Cache the result if caching is enabled\n if (this.config.enableCaching) {\n this.setCachedClasses(cacheKey, processed)\n }\n\n return processed\n }\n\n /**\n * Process an array of class names\n */\n private processClassArray(classes: string[]): string[] {\n let processed = classes\n\n // Sanitize class names if enabled\n if (this.config.sanitizeClassNames) {\n processed = processed.map(cls => this.sanitizeClassName(cls))\n }\n\n // Remove duplicates while preserving order\n processed = this.deduplicateClasses(processed)\n\n // Development warnings\n if (this.config.warnDuplicateClasses && classes.length !== processed.length) {\n console.warn('[tachUI] Duplicate CSS classes detected and removed:',\n classes.filter((cls, i) => classes.indexOf(cls) !== i))\n }\n\n return processed\n }\n\n /**\n * Sanitize class name to be valid CSS identifier\n */\n sanitizeClassName(className: string): string {\n if (!className || typeof className !== 'string') return ''\n\n const rules = this.config.sanitizationRules!\n let sanitized = className.trim()\n\n // Handle spaces in class names\n // CSS class names cannot contain spaces - convert them to hyphens to create valid single class names\n if (sanitized.includes(' ')) {\n sanitized = sanitized.replace(/\\s+/g, '-')\n if (this.config.warnInvalidClasses) {\n console.warn(`[tachUI] CSS class names cannot contain spaces. Converted \"${className}\" to \"${sanitized}\"`)\n }\n }\n\n // Apply custom replacements first\n Object.entries(rules.customReplacements || {}).forEach(([from, to]) => {\n sanitized = sanitized.replace(new RegExp(from, 'g'), to)\n })\n\n // Build character allowlist - be more permissive for modern CSS frameworks\n let allowedChars = 'a-zA-Z\\\\-\\\\.' // Basic CSS characters\n if (rules.allowNumbers) allowedChars += '0-9'\n if (rules.allowUnderscores) allowedChars += '_'\n\n // Allow modern CSS framework characters (Tailwind, CSS modules, etc.)\n // : for pseudo-classes (hover:bg-blue-500)\n // [ ] for arbitrary values ([10px])\n // / for opacity modifiers (bg-black/50)\n // % for percentages\n allowedChars += ':\\\\[\\\\]/%'\n\n // Only replace characters that are truly invalid in CSS class names\n // Keep most characters as-is since modern CSS frameworks use many special chars\n sanitized = sanitized.replace(new RegExp(`[^${allowedChars}]`, 'g'), '-')\n\n // Ensure doesn't start with number (invalid CSS)\n if (/^[0-9]/.test(sanitized)) {\n sanitized = 'cls-' + sanitized\n }\n\n // Collapse excessive hyphens (3 or more) but preserve CSS custom property prefixes (--)\n sanitized = sanitized.replace(/---+/g, '--')\n\n // Keep leading/trailing hyphens - they are valid in CSS class names\n // Only remove if they result from excessive collapsing (e.g., \"---\" became \"--\" then \"-\" at edges)\n\n // Keep original case - many frameworks use camelCase and mixed case\n // Do not convert to lowercase to preserve modern CSS framework conventions\n\n // Warn about invalid classes in development\n if (this.config.warnInvalidClasses && sanitized !== className.trim()) {\n console.warn(`[tachUI] CSS class \"${className}\" sanitized to \"${sanitized}\"`)\n }\n\n return sanitized\n }\n\n /**\n * Deduplicate classes while preserving first occurrence order\n */\n deduplicateClasses(classes: string[]): string[] {\n return [...new Set(classes.filter(Boolean))]\n }\n\n /**\n * Combine tachUI classes with user-provided CSS classes\n * User classes come AFTER tachUI classes for proper CSS cascade\n */\n combineClasses(tachuiClasses: string[], userClasses: string[]): string[] {\n const processedUserClasses = this.processClasses(userClasses)\n const combined = [...tachuiClasses, ...processedUserClasses]\n return this.deduplicateClasses(combined)\n }\n\n /**\n * Update configuration\n */\n updateConfig(config: Partial<CSSClassConfig>): void {\n this.config = { ...this.config, ...config }\n\n // Clear caches when config changes\n this.clearCaches()\n }\n\n /**\n * Get current configuration\n */\n getConfig(): CSSClassConfig {\n return { ...this.config }\n }\n\n /**\n * Clear all caches\n */\n clearCaches(): void {\n this.cacheClear(this.classCache)\n this.cacheClear(this.processingCache)\n }\n\n /**\n * Get cache statistics for debugging\n */\n getCacheStats(): { size: number; maxSize: number; hitRate: number } {\n return {\n size: this.cacheSize(this.classCache),\n maxSize: this.config.maxCacheSize,\n hitRate: 0 // TODO: Implement hit rate tracking if needed\n }\n }\n\n /**\n * Generate cache key for input\n */\n private getCacheKey(input: string | string[]): string {\n return Array.isArray(input) ? input.join('|') : input\n }\n\n /**\n * Set cached classes with LRU eviction\n */\n private setCachedClasses(key: string, classes: string[]): void {\n // Implement LRU cache eviction\n if (this.cacheSize(this.classCache) >= this.config.maxCacheSize) {\n const keys = this.cacheKeys(this.classCache)\n // const firstKey = keys instanceof Array ? keys[0] : keys.next().value\n const firstKey = Array.isArray(keys) ? keys[0] : keys.next().value\n if (firstKey !== undefined) {\n this.cacheDelete(this.classCache, firstKey)\n }\n }\n\n this.cacheSet(this.classCache, key, classes)\n }\n}\n\n/**\n * Global CSS class manager instance\n */\nexport const cssClassManager = new CSSClassManager()\n\n/**\n * Configure global CSS class processing\n */\nexport function configureCSSClasses(config: Partial<CSSClassConfig>): void {\n cssClassManager.updateConfig(config)\n}\n\n/**\n * Get current CSS class configuration\n */\nexport function getCSSClassConfig(): CSSClassConfig {\n return cssClassManager.getConfig()\n}\n"],"names":["DEFAULT_CONFIG","CSSClassManager","config","__publicField","mapAvailable","cache","key","value","input","isSignal","isComputed","resolved","cacheKey","classes","cls","trimmed","stringified","processed","className","rules","sanitized","from","to","allowedChars","tachuiClasses","userClasses","processedUserClasses","combined","keys","firstKey","cssClassManager","configureCSSClasses","getCSSClassConfig"],"mappings":";;;;;;;AAkBA,MAAMA,IAAiC;AAAA,EACrC,oBAAoB;AAAA,EACpB,mBAAmB;AAAA,IACjB,cAAc;AAAA,IACd,kBAAkB;AAAA,IAClB,oBAAoB,CAAA;AAAA,EAAC;AAAA,EAEvB,eAAe;AAAA,EACf,cAAc;AAAA,EACd,sBAAsB,QAAQ,IAAI,aAAa;AAAA,EAC/C,oBAAoB,QAAQ,IAAI,aAAa;AAC/C;AAKO,MAAMC,EAA6C;AAAA,EAKxD,YAAYC,IAAkC,IAAI;AAJlD,IAAAC,EAAA,MAAQ,QAAA,GACRA,EAAA,MAAQ,YAAA,GACRA,EAAA,MAAQ,iBAAA,GAGN,KAAK,SAAS,EAAE,GAAGH,GAAgB,GAAGE,EAAA;AAItC,UAAME,KAAgB,MAAM;AAC1B,UAAI;AACF,eAAO,OAAO,MAAQ,OAAe,OAAO,OAAQ;AAAA,MACtD,QAAa;AACX,eAAO;AAAA,MACT;AAAA,IACF,GAAA;AAEA,SAAK,aAAaA,IAAe,oBAAI,IAAA,IAAQ,CAAA,GAC7C,KAAK,kBAAkBA,IAAe,oBAAI,IAAA,IAAQ,CAAA;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKQ,SAASC,GAAkDC,GAAsB;AACvF,QAAI;AACF,aAAOD,aAAiB,MAAMA,EAAM,IAAIC,CAAG,IAAIA,KAAOD;AAAA,IACxD,QAAa;AAEX,aAAOC,KAAOD;AAAA,IAChB;AAAA,EACF;AAAA,EAEQ,SAAYA,GAA8CC,GAA4B;AAC5F,QAAI;AACF,aAAOD,aAAiB,MAAMA,EAAM,IAAIC,CAAG,IAAID,EAAMC,CAAG;AAAA,IAC1D,QAAa;AACX,aAAQD,EAA+BC,CAAG;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,SAAYD,GAA8CC,GAAaC,GAAgB;AAC7F,QAAI;AACF,MAAIF,aAAiB,MACnBA,EAAM,IAAIC,GAAKC,CAAK,IAEpBF,EAAMC,CAAG,IAAIC;AAAA,IAEjB,QAAa;AACT,MAAAF,EAA+BC,CAAG,IAAIC;AAAA,IAC1C;AAAA,EACF;AAAA,EAEQ,YAAeF,GAA8CC,GAAmB;AACtF,QAAI;AACF,MAAID,aAAiB,MACnBA,EAAM,OAAOC,CAAG,IAEhB,OAAOD,EAAMC,CAAG;AAAA,IAEpB,QAAa;AACX,aAAQD,EAA+BC,CAAG;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,WAAcD,GAAoD;AACxE,QAAI;AACF,MAAIA,aAAiB,MACnBA,EAAM,MAAA,IAEN,OAAO,KAAKA,CAAK,EAAE,QAAQ,OAAO,OAAOA,EAAMC,CAAG,CAAC;AAAA,IAEvD,QAAa;AACX,aAAO,KAAKD,CAA6B,EAAE,QAAQ,OAAO,OAAQA,EAA+BC,CAAG,CAAC;AAAA,IACvG;AAAA,EACF;AAAA,EAEQ,UAAaD,GAAsD;AACzE,QAAI;AACF,aAAOA,aAAiB,MAAMA,EAAM,OAAO,OAAO,KAAKA,CAAK,EAAE;AAAA,IAChE,QAAa;AACX,aAAO,OAAO,KAAKA,CAAK,EAAE;AAAA,IAC5B;AAAA,EACF;AAAA,EAEQ,UAAaA,GAAmF;AACtG,QAAI;AACF,aAAOA,aAAiB,MAAMA,EAAM,SAAS,OAAO,KAAKA,CAAK;AAAA,IAChE,QAAa;AACX,aAAO,OAAO,KAAKA,CAAK;AAAA,IAC1B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,eAAeG,GAAgE;AAC7E,QAAI,CAACA,EAAO,QAAO,CAAA;AAGnB,QAAIC,EAASD,CAAK,KAAKE,EAAWF,CAAK,GAAG;AACxC,YAAMG,IAAWH,EAAA;AACjB,aAAO,KAAK,eAAeG,CAAQ;AAAA,IACrC;AAGA,UAAMC,IAAW,KAAK,YAAYJ,CAAK;AACvC,QAAI,KAAK,OAAO,iBAAiB,KAAK,SAAS,KAAK,YAAYI,CAAQ;AACtE,aAAO,KAAK,SAAS,KAAK,YAAYA,CAAQ;AAGhD,QAAIC,IAAoB,CAAA;AAGxB,QAAI,OAAOL,KAAU;AACnB,MAAAK,IAAUL,EAAM,KAAA,EAAO,MAAM,KAAK,EAAE,OAAO,OAAO;AAAA,aAG3C,MAAM,QAAQA,CAAK;AAC1B,MAAAK,IAAUL,EACP,QAAQ,CAAAM,MAAO;AACd,YAAIA,KAAQ,QAA6BA,MAAQ;AAC/C,iBAAO,CAAA;AAIT,cAAMC,KADc,OAAOD,KAAQ,WAAWA,IAAM,OAAOA,CAAG,GAClC,KAAA;AAI5B,eAAI,OAAOA,KAAQ,YAAYC,IACtB,CAACA,CAAO,IAIVA,EAAQ,MAAM,KAAK;AAAA,MAC5B,CAAC,EACA,OAAO,OAAO;AAAA,SAId;AACH,YAAMC,IAAc,OAAOR,CAAK,EAAE,KAAA;AAClC,MAAAK,IAAUG,IAAc,CAACA,CAAW,IAAI,CAAA;AAAA,IAC1C;AAGA,UAAMC,IAAY,KAAK,kBAAkBJ,CAAO;AAGhD,WAAI,KAAK,OAAO,iBACd,KAAK,iBAAiBD,GAAUK,CAAS,GAGpCA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,kBAAkBJ,GAA6B;AACrD,QAAII,IAAYJ;AAGhB,WAAI,KAAK,OAAO,uBACdI,IAAYA,EAAU,IAAI,CAAAH,MAAO,KAAK,kBAAkBA,CAAG,CAAC,IAI9DG,IAAY,KAAK,mBAAmBA,CAAS,GAGzC,KAAK,OAAO,wBAAwBJ,EAAQ,WAAWI,EAAU,UACnE,QAAQ;AAAA,MAAK;AAAA,MACXJ,EAAQ,OAAO,CAACC,GAAK,MAAMD,EAAQ,QAAQC,CAAG,MAAM,CAAC;AAAA,IAAA,GAGlDG;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAkBC,GAA2B;AAC3C,QAAI,CAACA,KAAa,OAAOA,KAAc,SAAU,QAAO;AAExD,UAAMC,IAAQ,KAAK,OAAO;AAC1B,QAAIC,IAAYF,EAAU,KAAA;AAI1B,IAAIE,EAAU,SAAS,GAAG,MACxBA,IAAYA,EAAU,QAAQ,QAAQ,GAAG,GACrC,KAAK,OAAO,sBACd,QAAQ,KAAK,8DAA8DF,CAAS,SAASE,CAAS,GAAG,IAK7G,OAAO,QAAQD,EAAM,sBAAsB,CAAA,CAAE,EAAE,QAAQ,CAAC,CAACE,GAAMC,CAAE,MAAM;AACrE,MAAAF,IAAYA,EAAU,QAAQ,IAAI,OAAOC,GAAM,GAAG,GAAGC,CAAE;AAAA,IACzD,CAAC;AAGD,QAAIC,IAAe;AACnB,WAAIJ,EAAM,iBAAcI,KAAgB,QACpCJ,EAAM,qBAAkBI,KAAgB,MAO5CA,KAAgB,aAIhBH,IAAYA,EAAU,QAAQ,IAAI,OAAO,KAAKG,CAAY,KAAK,GAAG,GAAG,GAAG,GAGpE,SAAS,KAAKH,CAAS,MACzBA,IAAY,SAASA,IAIvBA,IAAYA,EAAU,QAAQ,SAAS,IAAI,GASvC,KAAK,OAAO,sBAAsBA,MAAcF,EAAU,UAC5D,QAAQ,KAAK,uBAAuBA,CAAS,mBAAmBE,CAAS,GAAG,GAGvEA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,mBAAmBP,GAA6B;AAC9C,WAAO,CAAC,GAAG,IAAI,IAAIA,EAAQ,OAAO,OAAO,CAAC,CAAC;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,eAAeW,GAAyBC,GAAiC;AACvE,UAAMC,IAAuB,KAAK,eAAeD,CAAW,GACtDE,IAAW,CAAC,GAAGH,GAAe,GAAGE,CAAoB;AAC3D,WAAO,KAAK,mBAAmBC,CAAQ;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA,EAKA,aAAazB,GAAuC;AAClD,SAAK,SAAS,EAAE,GAAG,KAAK,QAAQ,GAAGA,EAAA,GAGnC,KAAK,YAAA;AAAA,EACP;AAAA;AAAA;AAAA;AAAA,EAKA,YAA4B;AAC1B,WAAO,EAAE,GAAG,KAAK,OAAA;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA,EAKA,cAAoB;AAClB,SAAK,WAAW,KAAK,UAAU,GAC/B,KAAK,WAAW,KAAK,eAAe;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAoE;AAClE,WAAO;AAAA,MACL,MAAM,KAAK,UAAU,KAAK,UAAU;AAAA,MACpC,SAAS,KAAK,OAAO;AAAA,MACrB,SAAS;AAAA;AAAA,IAAA;AAAA,EAEb;AAAA;AAAA;AAAA;AAAA,EAKQ,YAAYM,GAAkC;AACpD,WAAO,MAAM,QAAQA,CAAK,IAAIA,EAAM,KAAK,GAAG,IAAIA;AAAA,EAClD;AAAA;AAAA;AAAA;AAAA,EAKQ,iBAAiBF,GAAaO,GAAyB;AAE7D,QAAI,KAAK,UAAU,KAAK,UAAU,KAAK,KAAK,OAAO,cAAc;AAC/D,YAAMe,IAAO,KAAK,UAAU,KAAK,UAAU,GAErCC,IAAW,MAAM,QAAQD,CAAI,IAAIA,EAAK,CAAC,IAAIA,EAAK,KAAA,EAAO;AAC7D,MAAIC,MAAa,UACf,KAAK,YAAY,KAAK,YAAYA,CAAQ;AAAA,IAE9C;AAEA,SAAK,SAAS,KAAK,YAAYvB,GAAKO,CAAO;AAAA,EAC7C;AACF;AAKO,MAAMiB,IAAkB,IAAI7B,EAAA;AAK5B,SAAS8B,EAAoB7B,GAAuC;AACzE,EAAA4B,EAAgB,aAAa5B,CAAM;AACrC;AAKO,SAAS8B,IAAoC;AAClD,SAAOF,EAAgB,UAAA;AACzB;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});class i{applyCSSClasses(e,s){if(!s)return;const t=(Array.isArray(s)?s:[s]).filter(Boolean);t.length>0&&(e.className=t.join(" "))}applyReactiveCSSClasses(e,s){const a=require("../reactive").createEffect;return a(()=>{const r=s();e.className=r})}updateCSSClasses(e,s){this.applyCSSClasses(e,s)}removeCSSClasses(e,s){if(!s)return;const a=Array.isArray(s)?s:[s],r=e.className.split(" ").filter(l=>!a.includes(l));e.className=r.join(" ")}mergeCSSClasses(e,s){if(!s)return;const a=Array.isArray(s)?s:[s],r=[...e.className?e.className.split(" "):[],...a.filter(Boolean)],l=[...new Set(r)];e.className=l.join(" ")}}const o=new i;function n(c,e={},s=[],a){const r={...{type:"element",tag:c,props:e,children:s}};return a&&(Array.isArray(a)?r.cssClasses=a:r.reactiveClasses=a),r}function C(c){return{static:c.cssClasses||[],reactive:c.reactiveClasses}}exports.DOMCSSClassApplicator=i;exports.createDOMNodeWithClasses=n;exports.domCSSClassApplicator=o;exports.extractCSSClasses=C;
|
|
2
|
+
//# sourceMappingURL=dom-integration.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom-integration.cjs","sources":["../../src/css-classes/dom-integration.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - DOM Integration\n * \n * Enhanced DOM node types and utilities for CSS class integration\n */\n\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\n\n/**\n * Enhanced DOM node with CSS class support\n */\nexport interface DOMNodeWithClasses extends DOMNode {\n cssClasses?: string[]\n reactiveClasses?: Signal<string>\n}\n\n/**\n * CSS class application utilities for DOM elements\n */\nexport interface CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void\n \n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void)\n \n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void\n \n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void\n}\n\n/**\n * DOM CSS class applicator implementation\n */\nexport class DOMCSSClassApplicator implements CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const validClasses = classArray.filter(Boolean)\n \n if (validClasses.length > 0) {\n element.className = validClasses.join(' ')\n }\n }\n\n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void) {\n // Import createEffect dynamically to avoid circular dependencies\n const createEffect = require('../reactive').createEffect\n \n // Create effect to update classes when signal changes\n const dispose = createEffect(() => {\n const classString = classSignal()\n element.className = classString\n })\n \n return dispose\n }\n\n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void {\n this.applyCSSClasses(element, newClasses)\n }\n\n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const currentClasses = element.className.split(' ')\n const filteredClasses = currentClasses.filter(cls => !classArray.includes(cls))\n \n element.className = filteredClasses.join(' ')\n }\n\n /**\n * Merge CSS classes with existing classes on an element\n */\n mergeCSSClasses(element: Element, newClasses: string[] | string): void {\n if (!newClasses) return\n \n const classArray = Array.isArray(newClasses) ? newClasses : [newClasses]\n const currentClasses = element.className ? element.className.split(' ') : []\n const mergedClasses = [...currentClasses, ...classArray.filter(Boolean)]\n \n // Deduplicate classes\n const uniqueClasses = [...new Set(mergedClasses)]\n element.className = uniqueClasses.join(' ')\n }\n}\n\n/**\n * Global DOM CSS class applicator instance\n */\nexport const domCSSClassApplicator = new DOMCSSClassApplicator()\n\n/**\n * Helper function to create DOM nodes with CSS classes\n */\nexport function createDOMNodeWithClasses(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const baseNode: DOMNode = {\n type: 'element',\n tag,\n props,\n children\n }\n\n const enhancedNode: DOMNodeWithClasses = {\n ...baseNode\n }\n\n // Add CSS class support\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n enhancedNode.cssClasses = cssClasses\n } else {\n // Assume it's a signal\n enhancedNode.reactiveClasses = cssClasses as Signal<string>\n }\n }\n\n return enhancedNode\n}\n\n/**\n * Utility to extract CSS classes from a DOMNodeWithClasses\n */\nexport function extractCSSClasses(node: DOMNodeWithClasses): {\n static: string[]\n reactive: Signal<string> | undefined\n} {\n return {\n static: node.cssClasses || [],\n reactive: node.reactiveClasses\n }\n}"],"names":["DOMCSSClassApplicator","element","classes","validClasses","classSignal","createEffect","classString","newClasses","classArray","filteredClasses","cls","mergedClasses","uniqueClasses","domCSSClassApplicator","createDOMNodeWithClasses","tag","props","children","cssClasses","enhancedNode","extractCSSClasses","node"],"mappings":"gFA6CO,MAAMA,CAAuD,CAIlE,gBAAgBC,EAAkBC,EAAkC,CAClE,GAAI,CAACA,EAAS,OAGd,MAAMC,GADa,MAAM,QAAQD,CAAO,EAAIA,EAAU,CAACA,CAAO,GAC9B,OAAO,OAAO,EAE1CC,EAAa,OAAS,IACxBF,EAAQ,UAAYE,EAAa,KAAK,GAAG,EAE7C,CAKA,wBAAwBF,EAAkBG,EAA2C,CAEnF,MAAMC,EAAe,QAAQ,aAAa,EAAE,aAQ5C,OALgBA,EAAa,IAAM,CACjC,MAAMC,EAAcF,EAAA,EACpBH,EAAQ,UAAYK,CACtB,CAAC,CAGH,CAKA,iBAAiBL,EAAkBM,EAAqC,CACtE,KAAK,gBAAgBN,EAASM,CAAU,CAC1C,CAKA,iBAAiBN,EAAkBC,EAAkC,CACnE,GAAI,CAACA,EAAS,OAEd,MAAMM,EAAa,MAAM,QAAQN,CAAO,EAAIA,EAAU,CAACA,CAAO,EAExDO,EADiBR,EAAQ,UAAU,MAAM,GAAG,EACX,OAAOS,GAAO,CAACF,EAAW,SAASE,CAAG,CAAC,EAE9ET,EAAQ,UAAYQ,EAAgB,KAAK,GAAG,CAC9C,CAKA,gBAAgBR,EAAkBM,EAAqC,CACrE,GAAI,CAACA,EAAY,OAEjB,MAAMC,EAAa,MAAM,QAAQD,CAAU,EAAIA,EAAa,CAACA,CAAU,EAEjEI,EAAgB,CAAC,GADAV,EAAQ,UAAYA,EAAQ,UAAU,MAAM,GAAG,EAAI,CAAA,EAChC,GAAGO,EAAW,OAAO,OAAO,CAAC,EAGjEI,EAAgB,CAAC,GAAG,IAAI,IAAID,CAAa,CAAC,EAChDV,EAAQ,UAAYW,EAAc,KAAK,GAAG,CAC5C,CACF,CAKO,MAAMC,EAAwB,IAAIb,EAKlC,SAASc,EACdC,EACAC,EAA6B,CAAA,EAC7BC,EAAsB,CAAA,EACtBC,EACoB,CAQpB,MAAMC,EAAmC,CACvC,GARwB,CACxB,KAAM,UACN,IAAAJ,EACA,MAAAC,EACA,SAAAC,CAAA,CAIG,EAIL,OAAIC,IACE,MAAM,QAAQA,CAAU,EAC1BC,EAAa,WAAaD,EAG1BC,EAAa,gBAAkBD,GAI5BC,CACT,CAKO,SAASC,EAAkBC,EAGhC,CACA,MAAO,CACL,OAAQA,EAAK,YAAc,CAAA,EAC3B,SAAUA,EAAK,eAAA,CAEnB"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Classes Enhancement - DOM Integration
|
|
3
|
+
*
|
|
4
|
+
* Enhanced DOM node types and utilities for CSS class integration
|
|
5
|
+
*/
|
|
6
|
+
import type { Signal } from '../reactive/types';
|
|
7
|
+
import type { DOMNode } from '../runtime/types';
|
|
8
|
+
/**
|
|
9
|
+
* Enhanced DOM node with CSS class support
|
|
10
|
+
*/
|
|
11
|
+
export interface DOMNodeWithClasses extends DOMNode {
|
|
12
|
+
cssClasses?: string[];
|
|
13
|
+
reactiveClasses?: Signal<string>;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* CSS class application utilities for DOM elements
|
|
17
|
+
*/
|
|
18
|
+
export interface CSSClassDOMApplicator {
|
|
19
|
+
/**
|
|
20
|
+
* Apply CSS classes to a DOM element
|
|
21
|
+
*/
|
|
22
|
+
applyCSSClasses(element: Element, classes: string[] | string): void;
|
|
23
|
+
/**
|
|
24
|
+
* Apply reactive CSS classes to a DOM element
|
|
25
|
+
*/
|
|
26
|
+
applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void);
|
|
27
|
+
/**
|
|
28
|
+
* Update CSS classes on an existing element
|
|
29
|
+
*/
|
|
30
|
+
updateCSSClasses(element: Element, newClasses: string[] | string): void;
|
|
31
|
+
/**
|
|
32
|
+
* Remove CSS classes from an element
|
|
33
|
+
*/
|
|
34
|
+
removeCSSClasses(element: Element, classes: string[] | string): void;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* DOM CSS class applicator implementation
|
|
38
|
+
*/
|
|
39
|
+
export declare class DOMCSSClassApplicator implements CSSClassDOMApplicator {
|
|
40
|
+
/**
|
|
41
|
+
* Apply CSS classes to a DOM element
|
|
42
|
+
*/
|
|
43
|
+
applyCSSClasses(element: Element, classes: string[] | string): void;
|
|
44
|
+
/**
|
|
45
|
+
* Apply reactive CSS classes to a DOM element
|
|
46
|
+
*/
|
|
47
|
+
applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void);
|
|
48
|
+
/**
|
|
49
|
+
* Update CSS classes on an existing element
|
|
50
|
+
*/
|
|
51
|
+
updateCSSClasses(element: Element, newClasses: string[] | string): void;
|
|
52
|
+
/**
|
|
53
|
+
* Remove CSS classes from an element
|
|
54
|
+
*/
|
|
55
|
+
removeCSSClasses(element: Element, classes: string[] | string): void;
|
|
56
|
+
/**
|
|
57
|
+
* Merge CSS classes with existing classes on an element
|
|
58
|
+
*/
|
|
59
|
+
mergeCSSClasses(element: Element, newClasses: string[] | string): void;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Global DOM CSS class applicator instance
|
|
63
|
+
*/
|
|
64
|
+
export declare const domCSSClassApplicator: DOMCSSClassApplicator;
|
|
65
|
+
/**
|
|
66
|
+
* Helper function to create DOM nodes with CSS classes
|
|
67
|
+
*/
|
|
68
|
+
export declare function createDOMNodeWithClasses(tag: string, props?: Record<string, any>, children?: DOMNode[], cssClasses?: string[] | Signal<string>): DOMNodeWithClasses;
|
|
69
|
+
/**
|
|
70
|
+
* Utility to extract CSS classes from a DOMNodeWithClasses
|
|
71
|
+
*/
|
|
72
|
+
export declare function extractCSSClasses(node: DOMNodeWithClasses): {
|
|
73
|
+
static: string[];
|
|
74
|
+
reactive: Signal<string> | undefined;
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=dom-integration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom-integration.d.ts","sourceRoot":"","sources":["../../src/css-classes/dom-integration.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAE/C;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,OAAO;IACjD,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;CACjC;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI,CAAA;IAEnE;;OAEG;IACH,uBAAuB,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,CAAA;IAEpF;;OAEG;IACH,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI,CAAA;IAEvE;;OAEG;IACH,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI,CAAA;CACrE;AAED;;GAEG;AACH,qBAAa,qBAAsB,YAAW,qBAAqB;IACjE;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI;IAWnE;;OAEG;IACH,uBAAuB,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC;IAapF;;OAEG;IACH,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI;IAIvE;;OAEG;IACH,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI;IAUpE;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI;CAWvE;AAED;;GAEG;AACH,eAAO,MAAM,qBAAqB,uBAA8B,CAAA;AAEhE;;GAEG;AACH,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,MAAM,EACX,KAAK,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,EAC/B,QAAQ,GAAE,OAAO,EAAO,EACxB,UAAU,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,GACrC,kBAAkB,CAuBpB;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,kBAAkB,GAAG;IAC3D,MAAM,EAAE,MAAM,EAAE,CAAA;IAChB,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,SAAS,CAAA;CACrC,CAKA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
class i {
|
|
2
|
+
/**
|
|
3
|
+
* Apply CSS classes to a DOM element
|
|
4
|
+
*/
|
|
5
|
+
applyCSSClasses(e, s) {
|
|
6
|
+
if (!s) return;
|
|
7
|
+
const t = (Array.isArray(s) ? s : [s]).filter(Boolean);
|
|
8
|
+
t.length > 0 && (e.className = t.join(" "));
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Apply reactive CSS classes to a DOM element
|
|
12
|
+
*/
|
|
13
|
+
applyReactiveCSSClasses(e, s) {
|
|
14
|
+
const r = require("../reactive").createEffect;
|
|
15
|
+
return r(() => {
|
|
16
|
+
const a = s();
|
|
17
|
+
e.className = a;
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Update CSS classes on an existing element
|
|
22
|
+
*/
|
|
23
|
+
updateCSSClasses(e, s) {
|
|
24
|
+
this.applyCSSClasses(e, s);
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Remove CSS classes from an element
|
|
28
|
+
*/
|
|
29
|
+
removeCSSClasses(e, s) {
|
|
30
|
+
if (!s) return;
|
|
31
|
+
const r = Array.isArray(s) ? s : [s], a = e.className.split(" ").filter((l) => !r.includes(l));
|
|
32
|
+
e.className = a.join(" ");
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Merge CSS classes with existing classes on an element
|
|
36
|
+
*/
|
|
37
|
+
mergeCSSClasses(e, s) {
|
|
38
|
+
if (!s) return;
|
|
39
|
+
const r = Array.isArray(s) ? s : [s], a = [...e.className ? e.className.split(" ") : [], ...r.filter(Boolean)], l = [...new Set(a)];
|
|
40
|
+
e.className = l.join(" ");
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
const n = new i();
|
|
44
|
+
function o(c, e = {}, s = [], r) {
|
|
45
|
+
const a = {
|
|
46
|
+
...{
|
|
47
|
+
type: "element",
|
|
48
|
+
tag: c,
|
|
49
|
+
props: e,
|
|
50
|
+
children: s
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
return r && (Array.isArray(r) ? a.cssClasses = r : a.reactiveClasses = r), a;
|
|
54
|
+
}
|
|
55
|
+
function C(c) {
|
|
56
|
+
return {
|
|
57
|
+
static: c.cssClasses || [],
|
|
58
|
+
reactive: c.reactiveClasses
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
export {
|
|
62
|
+
i as DOMCSSClassApplicator,
|
|
63
|
+
o as createDOMNodeWithClasses,
|
|
64
|
+
n as domCSSClassApplicator,
|
|
65
|
+
C as extractCSSClasses
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=dom-integration.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dom-integration.js","sources":["../../src/css-classes/dom-integration.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - DOM Integration\n * \n * Enhanced DOM node types and utilities for CSS class integration\n */\n\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\n\n/**\n * Enhanced DOM node with CSS class support\n */\nexport interface DOMNodeWithClasses extends DOMNode {\n cssClasses?: string[]\n reactiveClasses?: Signal<string>\n}\n\n/**\n * CSS class application utilities for DOM elements\n */\nexport interface CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void\n \n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void)\n \n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void\n \n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void\n}\n\n/**\n * DOM CSS class applicator implementation\n */\nexport class DOMCSSClassApplicator implements CSSClassDOMApplicator {\n /**\n * Apply CSS classes to a DOM element\n */\n applyCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const validClasses = classArray.filter(Boolean)\n \n if (validClasses.length > 0) {\n element.className = validClasses.join(' ')\n }\n }\n\n /**\n * Apply reactive CSS classes to a DOM element\n */\n applyReactiveCSSClasses(element: Element, classSignal: Signal<string>): (() => void) {\n // Import createEffect dynamically to avoid circular dependencies\n const createEffect = require('../reactive').createEffect\n \n // Create effect to update classes when signal changes\n const dispose = createEffect(() => {\n const classString = classSignal()\n element.className = classString\n })\n \n return dispose\n }\n\n /**\n * Update CSS classes on an existing element\n */\n updateCSSClasses(element: Element, newClasses: string[] | string): void {\n this.applyCSSClasses(element, newClasses)\n }\n\n /**\n * Remove CSS classes from an element\n */\n removeCSSClasses(element: Element, classes: string[] | string): void {\n if (!classes) return\n \n const classArray = Array.isArray(classes) ? classes : [classes]\n const currentClasses = element.className.split(' ')\n const filteredClasses = currentClasses.filter(cls => !classArray.includes(cls))\n \n element.className = filteredClasses.join(' ')\n }\n\n /**\n * Merge CSS classes with existing classes on an element\n */\n mergeCSSClasses(element: Element, newClasses: string[] | string): void {\n if (!newClasses) return\n \n const classArray = Array.isArray(newClasses) ? newClasses : [newClasses]\n const currentClasses = element.className ? element.className.split(' ') : []\n const mergedClasses = [...currentClasses, ...classArray.filter(Boolean)]\n \n // Deduplicate classes\n const uniqueClasses = [...new Set(mergedClasses)]\n element.className = uniqueClasses.join(' ')\n }\n}\n\n/**\n * Global DOM CSS class applicator instance\n */\nexport const domCSSClassApplicator = new DOMCSSClassApplicator()\n\n/**\n * Helper function to create DOM nodes with CSS classes\n */\nexport function createDOMNodeWithClasses(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const baseNode: DOMNode = {\n type: 'element',\n tag,\n props,\n children\n }\n\n const enhancedNode: DOMNodeWithClasses = {\n ...baseNode\n }\n\n // Add CSS class support\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n enhancedNode.cssClasses = cssClasses\n } else {\n // Assume it's a signal\n enhancedNode.reactiveClasses = cssClasses as Signal<string>\n }\n }\n\n return enhancedNode\n}\n\n/**\n * Utility to extract CSS classes from a DOMNodeWithClasses\n */\nexport function extractCSSClasses(node: DOMNodeWithClasses): {\n static: string[]\n reactive: Signal<string> | undefined\n} {\n return {\n static: node.cssClasses || [],\n reactive: node.reactiveClasses\n }\n}"],"names":["DOMCSSClassApplicator","element","classes","validClasses","classSignal","createEffect","classString","newClasses","classArray","filteredClasses","cls","mergedClasses","uniqueClasses","domCSSClassApplicator","createDOMNodeWithClasses","tag","props","children","cssClasses","enhancedNode","extractCSSClasses","node"],"mappings":"AA6CO,MAAMA,EAAuD;AAAA;AAAA;AAAA;AAAA,EAIlE,gBAAgBC,GAAkBC,GAAkC;AAClE,QAAI,CAACA,EAAS;AAGd,UAAMC,KADa,MAAM,QAAQD,CAAO,IAAIA,IAAU,CAACA,CAAO,GAC9B,OAAO,OAAO;AAE9C,IAAIC,EAAa,SAAS,MACxBF,EAAQ,YAAYE,EAAa,KAAK,GAAG;AAAA,EAE7C;AAAA;AAAA;AAAA;AAAA,EAKA,wBAAwBF,GAAkBG,GAA2C;AAEnF,UAAMC,IAAe,QAAQ,aAAa,EAAE;AAQ5C,WALgBA,EAAa,MAAM;AACjC,YAAMC,IAAcF,EAAA;AACpB,MAAAH,EAAQ,YAAYK;AAAA,IACtB,CAAC;AAAA,EAGH;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiBL,GAAkBM,GAAqC;AACtE,SAAK,gBAAgBN,GAASM,CAAU;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAiBN,GAAkBC,GAAkC;AACnE,QAAI,CAACA,EAAS;AAEd,UAAMM,IAAa,MAAM,QAAQN,CAAO,IAAIA,IAAU,CAACA,CAAO,GAExDO,IADiBR,EAAQ,UAAU,MAAM,GAAG,EACX,OAAO,CAAAS,MAAO,CAACF,EAAW,SAASE,CAAG,CAAC;AAE9E,IAAAT,EAAQ,YAAYQ,EAAgB,KAAK,GAAG;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgBR,GAAkBM,GAAqC;AACrE,QAAI,CAACA,EAAY;AAEjB,UAAMC,IAAa,MAAM,QAAQD,CAAU,IAAIA,IAAa,CAACA,CAAU,GAEjEI,IAAgB,CAAC,GADAV,EAAQ,YAAYA,EAAQ,UAAU,MAAM,GAAG,IAAI,CAAA,GAChC,GAAGO,EAAW,OAAO,OAAO,CAAC,GAGjEI,IAAgB,CAAC,GAAG,IAAI,IAAID,CAAa,CAAC;AAChD,IAAAV,EAAQ,YAAYW,EAAc,KAAK,GAAG;AAAA,EAC5C;AACF;AAKO,MAAMC,IAAwB,IAAIb,EAAA;AAKlC,SAASc,EACdC,GACAC,IAA6B,CAAA,GAC7BC,IAAsB,CAAA,GACtBC,GACoB;AAQpB,QAAMC,IAAmC;AAAA,IACvC,GARwB;AAAA,MACxB,MAAM;AAAA,MACN,KAAAJ;AAAA,MACA,OAAAC;AAAA,MACA,UAAAC;AAAA,IAAA;AAAA,EAIG;AAIL,SAAIC,MACE,MAAM,QAAQA,CAAU,IAC1BC,EAAa,aAAaD,IAG1BC,EAAa,kBAAkBD,IAI5BC;AACT;AAKO,SAASC,EAAkBC,GAGhC;AACA,SAAO;AAAA,IACL,QAAQA,EAAK,cAAc,CAAA;AAAA,IAC3B,UAAUA,EAAK;AAAA,EAAA;AAEnB;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../reactive/cleanup.cjs");require("../reactive/unified-scheduler.cjs");const r=require("../reactive/effect.cjs"),n=require("../reactive/signal.cjs");require("../reactive/scheduler.cjs");require("../reactive/theme.cjs");const l={applyCSSClasses(e,s){if(s.cssClasses&&s.cssClasses.length>0){const t=s.cssClasses.join(" ");e.className=t}if(s.reactiveClasses&&n.isSignal(s.reactiveClasses)){const t=s.reactiveClasses();e.className=t,r.createEffect(()=>{const a=s.reactiveClasses();e.className=a})}},processElementClasses(e,s){let t=[];if(s.props?.className){const a=typeof s.props.className=="string"?s.props.className.split(" ").filter(Boolean):[];t.push(...a)}if(s.cssClasses&&t.push(...s.cssClasses),t.length>0){const a=[...new Set(t)];e.className=a.join(" ")}s.reactiveClasses&&n.isSignal(s.reactiveClasses)&&r.createEffect(()=>{const a=s.reactiveClasses();if(t.length>0){const i=t.join(" ");e.className=`${i} ${a}`.trim()}else e.className=a})}};function C(e){const s=e.createElement.bind(e),t=a=>{const i=s(a),c=a;return(c.cssClasses||c.reactiveClasses)&&l.processElementClasses(i,c),i};return e.createElement=t,Object.assign(e,l)}function o(e,s={},t=[],a){const i={type:"element",tag:e,props:s,children:t};return a&&(Array.isArray(a)?i.cssClasses=a:i.reactiveClasses=a),i}function S(e){const s=e;return!!(s.cssClasses||s.reactiveClasses)}exports.createCSSClassDOMNode=o;exports.cssClassRendererMixin=l;exports.enhanceRendererWithCSSClasses=C;exports.hasCSSClassSupport=S;
|
|
2
|
+
//# sourceMappingURL=enhanced-renderer.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enhanced-renderer.cjs","sources":["../../src/css-classes/enhanced-renderer.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Enhanced Renderer\n * \n * Enhanced DOM renderer that supports CSS class integration\n * while maintaining compatibility with existing functionality.\n */\n\nimport { createEffect, isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\nimport type { DOMNodeWithClasses } from './dom-integration'\n\n/**\n * Enhanced renderer mixin for CSS class support\n * This can be mixed into the existing DirectDOMRenderer\n */\nexport interface CSSClassRendererMixin {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void\n}\n\n/**\n * CSS class renderer mixin implementation\n */\nexport const cssClassRendererMixin: CSSClassRendererMixin = {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void {\n // Handle static CSS classes\n if (node.cssClasses && node.cssClasses.length > 0) {\n const classString = node.cssClasses.join(' ')\n element.className = classString\n }\n\n // Handle reactive CSS classes\n if (node.reactiveClasses) {\n if (isSignal(node.reactiveClasses)) {\n // Set initial value\n const initialClasses = node.reactiveClasses()\n element.className = initialClasses\n\n // Create reactive effect for updates\n createEffect(() => {\n const classString = node.reactiveClasses!()\n element.className = classString\n })\n }\n }\n },\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void {\n let finalClasses: string[] = []\n\n // Start with existing className prop if it exists\n if (node.props?.className) {\n const existingClasses = typeof node.props.className === 'string' \n ? node.props.className.split(' ').filter(Boolean)\n : []\n finalClasses.push(...existingClasses)\n }\n\n // Add CSS classes from cssClasses property\n if (node.cssClasses) {\n finalClasses.push(...node.cssClasses)\n }\n\n // Deduplicate and apply classes\n if (finalClasses.length > 0) {\n const uniqueClasses = [...new Set(finalClasses)]\n element.className = uniqueClasses.join(' ')\n }\n\n // Handle reactive classes separately (they override static classes)\n if (node.reactiveClasses && isSignal(node.reactiveClasses)) {\n createEffect(() => {\n const reactiveClassString = node.reactiveClasses!()\n \n // Combine with static classes if needed\n if (finalClasses.length > 0) {\n const staticClassString = finalClasses.join(' ')\n element.className = `${staticClassString} ${reactiveClassString}`.trim()\n } else {\n element.className = reactiveClassString\n }\n })\n }\n }\n}\n\n/**\n * Function to enhance any renderer with CSS class support\n */\nexport function enhanceRendererWithCSSClasses<T extends { createElement: (node: DOMNode) => Element }>(\n renderer: T\n): T & CSSClassRendererMixin {\n // Store original createElement method\n const originalCreateElement = renderer.createElement.bind(renderer)\n\n // Enhanced createElement that supports CSS classes\n const enhancedCreateElement = (node: DOMNode): Element => {\n // Call original createElement to create the element\n const element = originalCreateElement(node)\n\n // Check if this is a CSS-enhanced node\n const cssNode = node as DOMNodeWithClasses\n \n // Apply CSS classes if present\n if (cssNode.cssClasses || cssNode.reactiveClasses) {\n cssClassRendererMixin.processElementClasses(element, cssNode)\n }\n\n return element\n }\n\n // Replace createElement with enhanced version\n ;(renderer as any).createElement = enhancedCreateElement\n\n // Mix in CSS class methods\n return Object.assign(renderer, cssClassRendererMixin)\n}\n\n/**\n * Utility function to create a CSS class-aware DOM node\n */\nexport function createCSSClassDOMNode(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const node: DOMNodeWithClasses = {\n type: 'element',\n tag,\n props,\n children\n }\n\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n node.cssClasses = cssClasses\n } else {\n node.reactiveClasses = cssClasses\n }\n }\n\n return node\n}\n\n/**\n * Helper to check if a DOMNode has CSS class support\n */\nexport function hasCSSClassSupport(node: DOMNode): node is DOMNodeWithClasses {\n const cssNode = node as DOMNodeWithClasses\n return !!(cssNode.cssClasses || cssNode.reactiveClasses)\n}"],"names":["cssClassRendererMixin","element","node","classString","isSignal","initialClasses","createEffect","finalClasses","existingClasses","uniqueClasses","reactiveClassString","staticClassString","enhanceRendererWithCSSClasses","renderer","originalCreateElement","enhancedCreateElement","cssNode","createCSSClassDOMNode","tag","props","children","cssClasses","hasCSSClassSupport"],"mappings":"oTA+BO,MAAMA,EAA+C,CAI1D,gBAAgBC,EAAkBC,EAAgC,CAEhE,GAAIA,EAAK,YAAcA,EAAK,WAAW,OAAS,EAAG,CACjD,MAAMC,EAAcD,EAAK,WAAW,KAAK,GAAG,EAC5CD,EAAQ,UAAYE,CACtB,CAGA,GAAID,EAAK,iBACHE,EAAAA,SAASF,EAAK,eAAe,EAAG,CAElC,MAAMG,EAAiBH,EAAK,gBAAA,EAC5BD,EAAQ,UAAYI,EAGpBC,EAAAA,aAAa,IAAM,CACjB,MAAMH,EAAcD,EAAK,gBAAA,EACzBD,EAAQ,UAAYE,CACtB,CAAC,CACH,CAEJ,EAKA,sBAAsBF,EAAkBC,EAAgC,CACtE,IAAIK,EAAyB,CAAA,EAG7B,GAAIL,EAAK,OAAO,UAAW,CACzB,MAAMM,EAAkB,OAAON,EAAK,MAAM,WAAc,SACpDA,EAAK,MAAM,UAAU,MAAM,GAAG,EAAE,OAAO,OAAO,EAC9C,CAAA,EACJK,EAAa,KAAK,GAAGC,CAAe,CACtC,CAQA,GALIN,EAAK,YACPK,EAAa,KAAK,GAAGL,EAAK,UAAU,EAIlCK,EAAa,OAAS,EAAG,CAC3B,MAAME,EAAgB,CAAC,GAAG,IAAI,IAAIF,CAAY,CAAC,EAC/CN,EAAQ,UAAYQ,EAAc,KAAK,GAAG,CAC5C,CAGIP,EAAK,iBAAmBE,EAAAA,SAASF,EAAK,eAAe,GACvDI,EAAAA,aAAa,IAAM,CACjB,MAAMI,EAAsBR,EAAK,gBAAA,EAGjC,GAAIK,EAAa,OAAS,EAAG,CAC3B,MAAMI,EAAoBJ,EAAa,KAAK,GAAG,EAC/CN,EAAQ,UAAY,GAAGU,CAAiB,IAAID,CAAmB,GAAG,KAAA,CACpE,MACET,EAAQ,UAAYS,CAExB,CAAC,CAEL,CACF,EAKO,SAASE,EACdC,EAC2B,CAE3B,MAAMC,EAAwBD,EAAS,cAAc,KAAKA,CAAQ,EAG5DE,EAAyBb,GAA2B,CAExD,MAAMD,EAAUa,EAAsBZ,CAAI,EAGpCc,EAAUd,EAGhB,OAAIc,EAAQ,YAAcA,EAAQ,kBAChChB,EAAsB,sBAAsBC,EAASe,CAAO,EAGvDf,CACT,EAGE,OAAAY,EAAiB,cAAgBE,EAG5B,OAAO,OAAOF,EAAUb,CAAqB,CACtD,CAKO,SAASiB,EACdC,EACAC,EAA6B,CAAA,EAC7BC,EAAsB,CAAA,EACtBC,EACoB,CACpB,MAAMnB,EAA2B,CAC/B,KAAM,UACN,IAAAgB,EACA,MAAAC,EACA,SAAAC,CAAA,EAGF,OAAIC,IACE,MAAM,QAAQA,CAAU,EAC1BnB,EAAK,WAAamB,EAElBnB,EAAK,gBAAkBmB,GAIpBnB,CACT,CAKO,SAASoB,EAAmBpB,EAA2C,CAC5E,MAAMc,EAAUd,EAChB,MAAO,CAAC,EAAEc,EAAQ,YAAcA,EAAQ,gBAC1C"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Classes Enhancement - Enhanced Renderer
|
|
3
|
+
*
|
|
4
|
+
* Enhanced DOM renderer that supports CSS class integration
|
|
5
|
+
* while maintaining compatibility with existing functionality.
|
|
6
|
+
*/
|
|
7
|
+
import type { Signal } from '../reactive/types';
|
|
8
|
+
import type { DOMNode } from '../runtime/types';
|
|
9
|
+
import type { DOMNodeWithClasses } from './dom-integration';
|
|
10
|
+
/**
|
|
11
|
+
* Enhanced renderer mixin for CSS class support
|
|
12
|
+
* This can be mixed into the existing DirectDOMRenderer
|
|
13
|
+
*/
|
|
14
|
+
export interface CSSClassRendererMixin {
|
|
15
|
+
/**
|
|
16
|
+
* Apply CSS classes to an element during creation
|
|
17
|
+
*/
|
|
18
|
+
applyCSSClasses(element: Element, node: DOMNodeWithClasses): void;
|
|
19
|
+
/**
|
|
20
|
+
* Process className prop and CSS classes together
|
|
21
|
+
*/
|
|
22
|
+
processElementClasses(element: Element, node: DOMNodeWithClasses): void;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* CSS class renderer mixin implementation
|
|
26
|
+
*/
|
|
27
|
+
export declare const cssClassRendererMixin: CSSClassRendererMixin;
|
|
28
|
+
/**
|
|
29
|
+
* Function to enhance any renderer with CSS class support
|
|
30
|
+
*/
|
|
31
|
+
export declare function enhanceRendererWithCSSClasses<T extends {
|
|
32
|
+
createElement: (node: DOMNode) => Element;
|
|
33
|
+
}>(renderer: T): T & CSSClassRendererMixin;
|
|
34
|
+
/**
|
|
35
|
+
* Utility function to create a CSS class-aware DOM node
|
|
36
|
+
*/
|
|
37
|
+
export declare function createCSSClassDOMNode(tag: string, props?: Record<string, any>, children?: DOMNode[], cssClasses?: string[] | Signal<string>): DOMNodeWithClasses;
|
|
38
|
+
/**
|
|
39
|
+
* Helper to check if a DOMNode has CSS class support
|
|
40
|
+
*/
|
|
41
|
+
export declare function hasCSSClassSupport(node: DOMNode): node is DOMNodeWithClasses;
|
|
42
|
+
//# sourceMappingURL=enhanced-renderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enhanced-renderer.d.ts","sourceRoot":"","sources":["../../src/css-classes/enhanced-renderer.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC/C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAE3D;;;GAGG;AACH,MAAM,WAAW,qBAAqB;IACpC;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,kBAAkB,GAAG,IAAI,CAAA;IAEjE;;OAEG;IACH,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,kBAAkB,GAAG,IAAI,CAAA;CACxE;AAED;;GAEG;AACH,eAAO,MAAM,qBAAqB,EAAE,qBAmEnC,CAAA;AAED;;GAEG;AACH,wBAAgB,6BAA6B,CAAC,CAAC,SAAS;IAAE,aAAa,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,OAAO,CAAA;CAAE,EACnG,QAAQ,EAAE,CAAC,GACV,CAAC,GAAG,qBAAqB,CAyB3B;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,GAAG,EAAE,MAAM,EACX,KAAK,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,EAC/B,QAAQ,GAAE,OAAO,EAAO,EACxB,UAAU,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,GACrC,kBAAkB,CAiBpB;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,IAAI,kBAAkB,CAG5E"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import "../reactive/cleanup.js";
|
|
2
|
+
import "../reactive/unified-scheduler.js";
|
|
3
|
+
import { createEffect as l } from "../reactive/effect.js";
|
|
4
|
+
import { isSignal as r } from "../reactive/signal.js";
|
|
5
|
+
import "../reactive/scheduler.js";
|
|
6
|
+
import "../reactive/theme.js";
|
|
7
|
+
const n = {
|
|
8
|
+
/**
|
|
9
|
+
* Apply CSS classes to an element during creation
|
|
10
|
+
*/
|
|
11
|
+
applyCSSClasses(e, s) {
|
|
12
|
+
if (s.cssClasses && s.cssClasses.length > 0) {
|
|
13
|
+
const t = s.cssClasses.join(" ");
|
|
14
|
+
e.className = t;
|
|
15
|
+
}
|
|
16
|
+
if (s.reactiveClasses && r(s.reactiveClasses)) {
|
|
17
|
+
const t = s.reactiveClasses();
|
|
18
|
+
e.className = t, l(() => {
|
|
19
|
+
const a = s.reactiveClasses();
|
|
20
|
+
e.className = a;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
/**
|
|
25
|
+
* Process className prop and CSS classes together
|
|
26
|
+
*/
|
|
27
|
+
processElementClasses(e, s) {
|
|
28
|
+
let t = [];
|
|
29
|
+
if (s.props?.className) {
|
|
30
|
+
const a = typeof s.props.className == "string" ? s.props.className.split(" ").filter(Boolean) : [];
|
|
31
|
+
t.push(...a);
|
|
32
|
+
}
|
|
33
|
+
if (s.cssClasses && t.push(...s.cssClasses), t.length > 0) {
|
|
34
|
+
const a = [...new Set(t)];
|
|
35
|
+
e.className = a.join(" ");
|
|
36
|
+
}
|
|
37
|
+
s.reactiveClasses && r(s.reactiveClasses) && l(() => {
|
|
38
|
+
const a = s.reactiveClasses();
|
|
39
|
+
if (t.length > 0) {
|
|
40
|
+
const i = t.join(" ");
|
|
41
|
+
e.className = `${i} ${a}`.trim();
|
|
42
|
+
} else
|
|
43
|
+
e.className = a;
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
function g(e) {
|
|
48
|
+
const s = e.createElement.bind(e), t = (a) => {
|
|
49
|
+
const i = s(a), c = a;
|
|
50
|
+
return (c.cssClasses || c.reactiveClasses) && n.processElementClasses(i, c), i;
|
|
51
|
+
};
|
|
52
|
+
return e.createElement = t, Object.assign(e, n);
|
|
53
|
+
}
|
|
54
|
+
function u(e, s = {}, t = [], a) {
|
|
55
|
+
const i = {
|
|
56
|
+
type: "element",
|
|
57
|
+
tag: e,
|
|
58
|
+
props: s,
|
|
59
|
+
children: t
|
|
60
|
+
};
|
|
61
|
+
return a && (Array.isArray(a) ? i.cssClasses = a : i.reactiveClasses = a), i;
|
|
62
|
+
}
|
|
63
|
+
function N(e) {
|
|
64
|
+
const s = e;
|
|
65
|
+
return !!(s.cssClasses || s.reactiveClasses);
|
|
66
|
+
}
|
|
67
|
+
export {
|
|
68
|
+
u as createCSSClassDOMNode,
|
|
69
|
+
n as cssClassRendererMixin,
|
|
70
|
+
g as enhanceRendererWithCSSClasses,
|
|
71
|
+
N as hasCSSClassSupport
|
|
72
|
+
};
|
|
73
|
+
//# sourceMappingURL=enhanced-renderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enhanced-renderer.js","sources":["../../src/css-classes/enhanced-renderer.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Enhanced Renderer\n * \n * Enhanced DOM renderer that supports CSS class integration\n * while maintaining compatibility with existing functionality.\n */\n\nimport { createEffect, isSignal } from '../reactive'\nimport type { Signal } from '../reactive/types'\nimport type { DOMNode } from '../runtime/types'\nimport type { DOMNodeWithClasses } from './dom-integration'\n\n/**\n * Enhanced renderer mixin for CSS class support\n * This can be mixed into the existing DirectDOMRenderer\n */\nexport interface CSSClassRendererMixin {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void\n}\n\n/**\n * CSS class renderer mixin implementation\n */\nexport const cssClassRendererMixin: CSSClassRendererMixin = {\n /**\n * Apply CSS classes to an element during creation\n */\n applyCSSClasses(element: Element, node: DOMNodeWithClasses): void {\n // Handle static CSS classes\n if (node.cssClasses && node.cssClasses.length > 0) {\n const classString = node.cssClasses.join(' ')\n element.className = classString\n }\n\n // Handle reactive CSS classes\n if (node.reactiveClasses) {\n if (isSignal(node.reactiveClasses)) {\n // Set initial value\n const initialClasses = node.reactiveClasses()\n element.className = initialClasses\n\n // Create reactive effect for updates\n createEffect(() => {\n const classString = node.reactiveClasses!()\n element.className = classString\n })\n }\n }\n },\n\n /**\n * Process className prop and CSS classes together\n */\n processElementClasses(element: Element, node: DOMNodeWithClasses): void {\n let finalClasses: string[] = []\n\n // Start with existing className prop if it exists\n if (node.props?.className) {\n const existingClasses = typeof node.props.className === 'string' \n ? node.props.className.split(' ').filter(Boolean)\n : []\n finalClasses.push(...existingClasses)\n }\n\n // Add CSS classes from cssClasses property\n if (node.cssClasses) {\n finalClasses.push(...node.cssClasses)\n }\n\n // Deduplicate and apply classes\n if (finalClasses.length > 0) {\n const uniqueClasses = [...new Set(finalClasses)]\n element.className = uniqueClasses.join(' ')\n }\n\n // Handle reactive classes separately (they override static classes)\n if (node.reactiveClasses && isSignal(node.reactiveClasses)) {\n createEffect(() => {\n const reactiveClassString = node.reactiveClasses!()\n \n // Combine with static classes if needed\n if (finalClasses.length > 0) {\n const staticClassString = finalClasses.join(' ')\n element.className = `${staticClassString} ${reactiveClassString}`.trim()\n } else {\n element.className = reactiveClassString\n }\n })\n }\n }\n}\n\n/**\n * Function to enhance any renderer with CSS class support\n */\nexport function enhanceRendererWithCSSClasses<T extends { createElement: (node: DOMNode) => Element }>(\n renderer: T\n): T & CSSClassRendererMixin {\n // Store original createElement method\n const originalCreateElement = renderer.createElement.bind(renderer)\n\n // Enhanced createElement that supports CSS classes\n const enhancedCreateElement = (node: DOMNode): Element => {\n // Call original createElement to create the element\n const element = originalCreateElement(node)\n\n // Check if this is a CSS-enhanced node\n const cssNode = node as DOMNodeWithClasses\n \n // Apply CSS classes if present\n if (cssNode.cssClasses || cssNode.reactiveClasses) {\n cssClassRendererMixin.processElementClasses(element, cssNode)\n }\n\n return element\n }\n\n // Replace createElement with enhanced version\n ;(renderer as any).createElement = enhancedCreateElement\n\n // Mix in CSS class methods\n return Object.assign(renderer, cssClassRendererMixin)\n}\n\n/**\n * Utility function to create a CSS class-aware DOM node\n */\nexport function createCSSClassDOMNode(\n tag: string,\n props: Record<string, any> = {},\n children: DOMNode[] = [],\n cssClasses?: string[] | Signal<string>\n): DOMNodeWithClasses {\n const node: DOMNodeWithClasses = {\n type: 'element',\n tag,\n props,\n children\n }\n\n if (cssClasses) {\n if (Array.isArray(cssClasses)) {\n node.cssClasses = cssClasses\n } else {\n node.reactiveClasses = cssClasses\n }\n }\n\n return node\n}\n\n/**\n * Helper to check if a DOMNode has CSS class support\n */\nexport function hasCSSClassSupport(node: DOMNode): node is DOMNodeWithClasses {\n const cssNode = node as DOMNodeWithClasses\n return !!(cssNode.cssClasses || cssNode.reactiveClasses)\n}"],"names":["cssClassRendererMixin","element","node","classString","isSignal","initialClasses","createEffect","finalClasses","existingClasses","uniqueClasses","reactiveClassString","staticClassString","enhanceRendererWithCSSClasses","renderer","originalCreateElement","enhancedCreateElement","cssNode","createCSSClassDOMNode","tag","props","children","cssClasses","hasCSSClassSupport"],"mappings":";;;;;;AA+BO,MAAMA,IAA+C;AAAA;AAAA;AAAA;AAAA,EAI1D,gBAAgBC,GAAkBC,GAAgC;AAEhE,QAAIA,EAAK,cAAcA,EAAK,WAAW,SAAS,GAAG;AACjD,YAAMC,IAAcD,EAAK,WAAW,KAAK,GAAG;AAC5C,MAAAD,EAAQ,YAAYE;AAAA,IACtB;AAGA,QAAID,EAAK,mBACHE,EAASF,EAAK,eAAe,GAAG;AAElC,YAAMG,IAAiBH,EAAK,gBAAA;AAC5B,MAAAD,EAAQ,YAAYI,GAGpBC,EAAa,MAAM;AACjB,cAAMH,IAAcD,EAAK,gBAAA;AACzB,QAAAD,EAAQ,YAAYE;AAAA,MACtB,CAAC;AAAA,IACH;AAAA,EAEJ;AAAA;AAAA;AAAA;AAAA,EAKA,sBAAsBF,GAAkBC,GAAgC;AACtE,QAAIK,IAAyB,CAAA;AAG7B,QAAIL,EAAK,OAAO,WAAW;AACzB,YAAMM,IAAkB,OAAON,EAAK,MAAM,aAAc,WACpDA,EAAK,MAAM,UAAU,MAAM,GAAG,EAAE,OAAO,OAAO,IAC9C,CAAA;AACJ,MAAAK,EAAa,KAAK,GAAGC,CAAe;AAAA,IACtC;AAQA,QALIN,EAAK,cACPK,EAAa,KAAK,GAAGL,EAAK,UAAU,GAIlCK,EAAa,SAAS,GAAG;AAC3B,YAAME,IAAgB,CAAC,GAAG,IAAI,IAAIF,CAAY,CAAC;AAC/C,MAAAN,EAAQ,YAAYQ,EAAc,KAAK,GAAG;AAAA,IAC5C;AAGA,IAAIP,EAAK,mBAAmBE,EAASF,EAAK,eAAe,KACvDI,EAAa,MAAM;AACjB,YAAMI,IAAsBR,EAAK,gBAAA;AAGjC,UAAIK,EAAa,SAAS,GAAG;AAC3B,cAAMI,IAAoBJ,EAAa,KAAK,GAAG;AAC/C,QAAAN,EAAQ,YAAY,GAAGU,CAAiB,IAAID,CAAmB,GAAG,KAAA;AAAA,MACpE;AACE,QAAAT,EAAQ,YAAYS;AAAA,IAExB,CAAC;AAAA,EAEL;AACF;AAKO,SAASE,EACdC,GAC2B;AAE3B,QAAMC,IAAwBD,EAAS,cAAc,KAAKA,CAAQ,GAG5DE,IAAwB,CAACb,MAA2B;AAExD,UAAMD,IAAUa,EAAsBZ,CAAI,GAGpCc,IAAUd;AAGhB,YAAIc,EAAQ,cAAcA,EAAQ,oBAChChB,EAAsB,sBAAsBC,GAASe,CAAO,GAGvDf;AAAA,EACT;AAGE,SAAAY,EAAiB,gBAAgBE,GAG5B,OAAO,OAAOF,GAAUb,CAAqB;AACtD;AAKO,SAASiB,EACdC,GACAC,IAA6B,CAAA,GAC7BC,IAAsB,CAAA,GACtBC,GACoB;AACpB,QAAMnB,IAA2B;AAAA,IAC/B,MAAM;AAAA,IACN,KAAAgB;AAAA,IACA,OAAAC;AAAA,IACA,UAAAC;AAAA,EAAA;AAGF,SAAIC,MACE,MAAM,QAAQA,CAAU,IAC1BnB,EAAK,aAAamB,IAElBnB,EAAK,kBAAkBmB,IAIpBnB;AACT;AAKO,SAASoB,EAAmBpB,GAA2C;AAC5E,QAAMc,IAAUd;AAChB,SAAO,CAAC,EAAEc,EAAQ,cAAcA,EAAQ;AAC1C;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Classes Enhancement - Public API
|
|
3
|
+
*
|
|
4
|
+
* Exports the public API for CSS class integration system.
|
|
5
|
+
*/
|
|
6
|
+
export type { CSSClassesProps, CSSClassProcessor, CSSClassConfig, ClassProcessingResult } from './types';
|
|
7
|
+
export { CSSClassManager, cssClassManager, configureCSSClasses, getCSSClassConfig } from './css-class-manager';
|
|
8
|
+
export { ComponentWithCSSClasses } from './component-base';
|
|
9
|
+
export { createCSSClassUtilities } from './utilities';
|
|
10
|
+
export type { DOMNodeWithClasses, CSSClassDOMApplicator } from './dom-integration';
|
|
11
|
+
export { DOMCSSClassApplicator, domCSSClassApplicator, createDOMNodeWithClasses, extractCSSClasses } from './dom-integration';
|
|
12
|
+
export type { CSSClassRendererMixin } from './enhanced-renderer';
|
|
13
|
+
export { cssClassRendererMixin, enhanceRendererWithCSSClasses, createCSSClassDOMNode, hasCSSClassSupport } from './enhanced-renderer';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/css-classes/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,YAAY,EACV,eAAe,EACf,iBAAiB,EACjB,cAAc,EACd,qBAAqB,EACtB,MAAM,SAAS,CAAA;AAGhB,OAAO,EACL,eAAe,EACf,eAAe,EACf,mBAAmB,EACnB,iBAAiB,EAClB,MAAM,qBAAqB,CAAA;AAG5B,OAAO,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAA;AAG1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAA;AAGrD,YAAY,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAClF,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,wBAAwB,EACxB,iBAAiB,EAClB,MAAM,mBAAmB,CAAA;AAG1B,YAAY,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA;AAChE,OAAO,EACL,qBAAqB,EACrB,6BAA6B,EAC7B,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,qBAAqB,CAAA"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Classes Enhancement - Type Definitions
|
|
3
|
+
*
|
|
4
|
+
* Core types for CSS class integration system that enables components
|
|
5
|
+
* to accept CSS classes from external frameworks (Tailwind, Bootstrap, etc.)
|
|
6
|
+
*/
|
|
7
|
+
import type { Signal } from '../reactive/types';
|
|
8
|
+
/**
|
|
9
|
+
* CSS Classes property interface - extended by all component props
|
|
10
|
+
*/
|
|
11
|
+
export interface CSSClassesProps {
|
|
12
|
+
css?: string | string[] | Signal<string | string[]>;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* CSS Class processor interface
|
|
16
|
+
*/
|
|
17
|
+
export interface CSSClassProcessor {
|
|
18
|
+
/**
|
|
19
|
+
* Process and normalize CSS classes from various input formats
|
|
20
|
+
*/
|
|
21
|
+
processClasses(input: string | string[] | Signal<string | string[]>): string[];
|
|
22
|
+
/**
|
|
23
|
+
* Sanitize class names to be valid CSS identifiers
|
|
24
|
+
*/
|
|
25
|
+
sanitizeClassName(className: string): string;
|
|
26
|
+
/**
|
|
27
|
+
* Deduplicate class arrays while preserving order
|
|
28
|
+
*/
|
|
29
|
+
deduplicateClasses(classes: string[]): string[];
|
|
30
|
+
/**
|
|
31
|
+
* Combine tachUI classes with user-provided CSS classes
|
|
32
|
+
*/
|
|
33
|
+
combineClasses(tachuiClasses: string[], userClasses: string[]): string[];
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Configuration for CSS class processing
|
|
37
|
+
*/
|
|
38
|
+
export interface CSSClassConfig {
|
|
39
|
+
sanitizeClassNames: boolean;
|
|
40
|
+
sanitizationRules?: {
|
|
41
|
+
allowNumbers: boolean;
|
|
42
|
+
allowUnderscores: boolean;
|
|
43
|
+
customReplacements: Record<string, string>;
|
|
44
|
+
};
|
|
45
|
+
enableCaching: boolean;
|
|
46
|
+
maxCacheSize: number;
|
|
47
|
+
warnDuplicateClasses: boolean;
|
|
48
|
+
warnInvalidClasses: boolean;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Processing result metadata
|
|
52
|
+
*/
|
|
53
|
+
export interface ClassProcessingResult {
|
|
54
|
+
classes: string[];
|
|
55
|
+
sanitized: string[];
|
|
56
|
+
duplicatesRemoved: number;
|
|
57
|
+
invalidClasses: string[];
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/css-classes/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE/C;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,CAAA;CACpD;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,CAAA;IAE9E;;OAEG;IACH,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAA;IAE5C;;OAEG;IACH,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAAA;IAE/C;;OAEG;IACH,cAAc,CAAC,aAAa,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAAA;CACzE;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAE7B,kBAAkB,EAAE,OAAO,CAAA;IAG3B,iBAAiB,CAAC,EAAE;QAClB,YAAY,EAAE,OAAO,CAAA;QACrB,gBAAgB,EAAE,OAAO,CAAA;QACzB,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAC3C,CAAA;IAGD,aAAa,EAAE,OAAO,CAAA;IACtB,YAAY,EAAE,MAAM,CAAA;IAGpB,oBAAoB,EAAE,OAAO,CAAA;IAC7B,kBAAkB,EAAE,OAAO,CAAA;CAC5B;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,OAAO,EAAE,MAAM,EAAE,CAAA;IACjB,SAAS,EAAE,MAAM,EAAE,CAAA;IACnB,iBAAiB,EAAE,MAAM,CAAA;IACzB,cAAc,EAAE,MAAM,EAAE,CAAA;CACzB"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./css-class-manager.cjs");function l(){return{combineClasses(...a){const s=[];return a.forEach(e=>{if(e){const t=r.cssClassManager.processClasses(e);s.push(...t)}}),r.cssClassManager.deduplicateClasses(s).join(" ")},conditionalClasses(a){return Object.entries(a).filter(([s,e])=>e).map(([s,e])=>s)},mergeClassProps(...a){const s=[];return a.forEach(e=>{if(e?.css){const t=r.cssClassManager.processClasses(e.css);s.push(...t)}}),s.length===0?{}:{css:r.cssClassManager.deduplicateClasses(s)}},extractClasses(a){return r.cssClassManager.processClasses(a)},validateClassNames(a){const s=[],e=[];return a.forEach(t=>{r.cssClassManager.sanitizeClassName(t)===t.toLowerCase()?s.push(t):e.push(t)}),{valid:s,invalid:e}}}}exports.createCSSClassUtilities=l;
|
|
2
|
+
//# sourceMappingURL=utilities.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utilities.cjs","sources":["../../src/css-classes/utilities.ts"],"sourcesContent":["/**\n * CSS Classes Enhancement - Utilities\n * \n * Utility functions for CSS class processing and common patterns.\n */\n\nimport { cssClassManager } from './css-class-manager'\nimport type { CSSClassesProps } from './types'\n\n/**\n * Utility functions for CSS class operations\n */\nexport interface CSSClassUtilities {\n /**\n * Combine multiple class sources into a single class string\n */\n combineClasses(...sources: (string | string[] | undefined)[]): string\n\n /**\n * Create conditional classes based on boolean conditions\n */\n conditionalClasses(conditions: Record<string, boolean>): string[]\n\n /**\n * Merge CSS class props from multiple sources\n */\n mergeClassProps(...props: (CSSClassesProps | undefined)[]): CSSClassesProps\n\n /**\n * Extract unique classes from a class string\n */\n extractClasses(classString: string): string[]\n\n /**\n * Validate CSS class names\n */\n validateClassNames(classes: string[]): { valid: string[], invalid: string[] }\n}\n\n/**\n * Create CSS class utilities instance\n */\nexport function createCSSClassUtilities(): CSSClassUtilities {\n return {\n combineClasses(...sources: (string | string[] | undefined)[]): string {\n const allClasses: string[] = []\n \n sources.forEach(source => {\n if (source) {\n const processed = cssClassManager.processClasses(source)\n allClasses.push(...processed)\n }\n })\n \n return cssClassManager.deduplicateClasses(allClasses).join(' ')\n },\n\n conditionalClasses(conditions: Record<string, boolean>): string[] {\n return Object.entries(conditions)\n .filter(([_, condition]) => condition)\n .map(([className, _]) => className)\n },\n\n mergeClassProps(...props: (CSSClassesProps | undefined)[]): CSSClassesProps {\n const allClasses: string[] = []\n \n props.forEach(prop => {\n if (prop?.css) {\n const processed = cssClassManager.processClasses(prop.css)\n allClasses.push(...processed)\n }\n })\n \n if (allClasses.length === 0) {\n return {}\n }\n \n return {\n css: cssClassManager.deduplicateClasses(allClasses)\n }\n },\n\n extractClasses(classString: string): string[] {\n return cssClassManager.processClasses(classString)\n },\n\n validateClassNames(classes: string[]): { valid: string[], invalid: string[] } {\n const valid: string[] = []\n const invalid: string[] = []\n \n classes.forEach(className => {\n const sanitized = cssClassManager.sanitizeClassName(className)\n if (sanitized === className.toLowerCase()) {\n valid.push(className)\n } else {\n invalid.push(className)\n }\n })\n \n return { valid, invalid }\n }\n }\n}\n\n/**\n * Default CSS class utilities instance\n */\nexport const cssClassUtils = createCSSClassUtilities()\n\n/**\n * Common CSS class patterns for popular frameworks\n */\nexport const CSSPatterns = {\n /**\n * Tailwind CSS utility patterns\n */\n tailwind: {\n flexCenter: 'flex items-center justify-center',\n flexBetween: 'flex items-center justify-between',\n absoluteCenter: 'absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2',\n srOnly: 'sr-only',\n card: 'bg-white rounded-lg shadow-md p-6',\n btn: {\n primary: 'bg-blue-500 hover:bg-blue-600 text-white px-4 py-2 rounded transition-colors',\n secondary: 'bg-gray-500 hover:bg-gray-600 text-white px-4 py-2 rounded transition-colors',\n outline: 'border border-blue-500 text-blue-500 hover:bg-blue-50 px-4 py-2 rounded transition-colors'\n }\n },\n\n /**\n * Bootstrap component patterns\n */\n bootstrap: {\n flexCenter: 'd-flex align-items-center justify-content-center',\n flexBetween: 'd-flex align-items-center justify-content-between',\n srOnly: 'visually-hidden',\n card: 'card',\n btn: {\n primary: 'btn btn-primary',\n secondary: 'btn btn-secondary',\n outline: 'btn btn-outline-primary'\n }\n }\n}\n\n/**\n * Framework-specific class builders\n */\nexport const FrameworkBuilders = {\n /**\n * Tailwind CSS class builder\n */\n tailwind: {\n spacing: (value: number) => `p-${value}`,\n margin: (value: number) => `m-${value}`,\n textSize: (size: 'xs' | 'sm' | 'base' | 'lg' | 'xl' | '2xl' | '3xl' | '4xl' | '5xl' | '6xl') => `text-${size}`,\n backgroundColor: (color: string) => `bg-${color}`,\n textColor: (color: string) => `text-${color}`,\n rounded: (size: 'none' | 'sm' | 'base' | 'md' | 'lg' | 'xl' | 'full' = 'base') => \n size === 'base' ? 'rounded' : `rounded-${size}`\n },\n\n /**\n * Bootstrap class builder\n */\n bootstrap: {\n spacing: (value: 1 | 2 | 3 | 4 | 5) => `p-${value}`,\n margin: (value: 1 | 2 | 3 | 4 | 5) => `m-${value}`,\n textSize: (size: 1 | 2 | 3 | 4 | 5 | 6) => `h${size}`,\n backgroundColor: (color: string) => `bg-${color}`,\n textColor: (color: string) => `text-${color}`,\n rounded: (size: 0 | 1 | 2 | 3 | 'circle' | 'pill' = 1) => \n typeof size === 'number' ? `rounded-${size}` : `rounded-${size}`\n }\n}"],"names":["createCSSClassUtilities","sources","allClasses","source","processed","cssClassManager","conditions","_","condition","className","props","prop","classString","classes","valid","invalid"],"mappings":"2HA0CO,SAASA,GAA6C,CAC3D,MAAO,CACL,kBAAkBC,EAAoD,CACpE,MAAMC,EAAuB,CAAA,EAE7B,OAAAD,EAAQ,QAAQE,GAAU,CACxB,GAAIA,EAAQ,CACV,MAAMC,EAAYC,EAAAA,gBAAgB,eAAeF,CAAM,EACvDD,EAAW,KAAK,GAAGE,CAAS,CAC9B,CACF,CAAC,EAEMC,EAAAA,gBAAgB,mBAAmBH,CAAU,EAAE,KAAK,GAAG,CAChE,EAEA,mBAAmBI,EAA+C,CAChE,OAAO,OAAO,QAAQA,CAAU,EAC7B,OAAO,CAAC,CAACC,EAAGC,CAAS,IAAMA,CAAS,EACpC,IAAI,CAAC,CAACC,EAAWF,CAAC,IAAME,CAAS,CACtC,EAEA,mBAAmBC,EAAyD,CAC1E,MAAMR,EAAuB,CAAA,EAS7B,OAPAQ,EAAM,QAAQC,GAAQ,CACpB,GAAIA,GAAM,IAAK,CACb,MAAMP,EAAYC,EAAAA,gBAAgB,eAAeM,EAAK,GAAG,EACzDT,EAAW,KAAK,GAAGE,CAAS,CAC9B,CACF,CAAC,EAEGF,EAAW,SAAW,EACjB,CAAA,EAGF,CACL,IAAKG,EAAAA,gBAAgB,mBAAmBH,CAAU,CAAA,CAEtD,EAEA,eAAeU,EAA+B,CAC5C,OAAOP,EAAAA,gBAAgB,eAAeO,CAAW,CACnD,EAEA,mBAAmBC,EAA2D,CAC5E,MAAMC,EAAkB,CAAA,EAClBC,EAAoB,CAAA,EAE1B,OAAAF,EAAQ,QAAQJ,GAAa,CACTJ,EAAAA,gBAAgB,kBAAkBI,CAAS,IAC3CA,EAAU,cAC1BK,EAAM,KAAKL,CAAS,EAEpBM,EAAQ,KAAKN,CAAS,CAE1B,CAAC,EAEM,CAAE,MAAAK,EAAO,QAAAC,CAAA,CAClB,CAAA,CAEJ"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Classes Enhancement - Utilities
|
|
3
|
+
*
|
|
4
|
+
* Utility functions for CSS class processing and common patterns.
|
|
5
|
+
*/
|
|
6
|
+
import type { CSSClassesProps } from './types';
|
|
7
|
+
/**
|
|
8
|
+
* Utility functions for CSS class operations
|
|
9
|
+
*/
|
|
10
|
+
export interface CSSClassUtilities {
|
|
11
|
+
/**
|
|
12
|
+
* Combine multiple class sources into a single class string
|
|
13
|
+
*/
|
|
14
|
+
combineClasses(...sources: (string | string[] | undefined)[]): string;
|
|
15
|
+
/**
|
|
16
|
+
* Create conditional classes based on boolean conditions
|
|
17
|
+
*/
|
|
18
|
+
conditionalClasses(conditions: Record<string, boolean>): string[];
|
|
19
|
+
/**
|
|
20
|
+
* Merge CSS class props from multiple sources
|
|
21
|
+
*/
|
|
22
|
+
mergeClassProps(...props: (CSSClassesProps | undefined)[]): CSSClassesProps;
|
|
23
|
+
/**
|
|
24
|
+
* Extract unique classes from a class string
|
|
25
|
+
*/
|
|
26
|
+
extractClasses(classString: string): string[];
|
|
27
|
+
/**
|
|
28
|
+
* Validate CSS class names
|
|
29
|
+
*/
|
|
30
|
+
validateClassNames(classes: string[]): {
|
|
31
|
+
valid: string[];
|
|
32
|
+
invalid: string[];
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Create CSS class utilities instance
|
|
37
|
+
*/
|
|
38
|
+
export declare function createCSSClassUtilities(): CSSClassUtilities;
|
|
39
|
+
/**
|
|
40
|
+
* Default CSS class utilities instance
|
|
41
|
+
*/
|
|
42
|
+
export declare const cssClassUtils: CSSClassUtilities;
|
|
43
|
+
/**
|
|
44
|
+
* Common CSS class patterns for popular frameworks
|
|
45
|
+
*/
|
|
46
|
+
export declare const CSSPatterns: {
|
|
47
|
+
/**
|
|
48
|
+
* Tailwind CSS utility patterns
|
|
49
|
+
*/
|
|
50
|
+
tailwind: {
|
|
51
|
+
flexCenter: string;
|
|
52
|
+
flexBetween: string;
|
|
53
|
+
absoluteCenter: string;
|
|
54
|
+
srOnly: string;
|
|
55
|
+
card: string;
|
|
56
|
+
btn: {
|
|
57
|
+
primary: string;
|
|
58
|
+
secondary: string;
|
|
59
|
+
outline: string;
|
|
60
|
+
};
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Bootstrap component patterns
|
|
64
|
+
*/
|
|
65
|
+
bootstrap: {
|
|
66
|
+
flexCenter: string;
|
|
67
|
+
flexBetween: string;
|
|
68
|
+
srOnly: string;
|
|
69
|
+
card: string;
|
|
70
|
+
btn: {
|
|
71
|
+
primary: string;
|
|
72
|
+
secondary: string;
|
|
73
|
+
outline: string;
|
|
74
|
+
};
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Framework-specific class builders
|
|
79
|
+
*/
|
|
80
|
+
export declare const FrameworkBuilders: {
|
|
81
|
+
/**
|
|
82
|
+
* Tailwind CSS class builder
|
|
83
|
+
*/
|
|
84
|
+
tailwind: {
|
|
85
|
+
spacing: (value: number) => string;
|
|
86
|
+
margin: (value: number) => string;
|
|
87
|
+
textSize: (size: "xs" | "sm" | "base" | "lg" | "xl" | "2xl" | "3xl" | "4xl" | "5xl" | "6xl") => string;
|
|
88
|
+
backgroundColor: (color: string) => string;
|
|
89
|
+
textColor: (color: string) => string;
|
|
90
|
+
rounded: (size?: "none" | "sm" | "base" | "md" | "lg" | "xl" | "full") => string;
|
|
91
|
+
};
|
|
92
|
+
/**
|
|
93
|
+
* Bootstrap class builder
|
|
94
|
+
*/
|
|
95
|
+
bootstrap: {
|
|
96
|
+
spacing: (value: 1 | 2 | 3 | 4 | 5) => string;
|
|
97
|
+
margin: (value: 1 | 2 | 3 | 4 | 5) => string;
|
|
98
|
+
textSize: (size: 1 | 2 | 3 | 4 | 5 | 6) => string;
|
|
99
|
+
backgroundColor: (color: string) => string;
|
|
100
|
+
textColor: (color: string) => string;
|
|
101
|
+
rounded: (size?: 0 | 1 | 2 | 3 | "circle" | "pill") => string;
|
|
102
|
+
};
|
|
103
|
+
};
|
|
104
|
+
//# sourceMappingURL=utilities.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utilities.d.ts","sourceRoot":"","sources":["../../src/css-classes/utilities.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAE9C;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,cAAc,CAAC,GAAG,OAAO,EAAE,CAAC,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,EAAE,GAAG,MAAM,CAAA;IAErE;;OAEG;IACH,kBAAkB,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,EAAE,CAAA;IAEjE;;OAEG;IACH,eAAe,CAAC,GAAG,KAAK,EAAE,CAAC,eAAe,GAAG,SAAS,CAAC,EAAE,GAAG,eAAe,CAAA;IAE3E;;OAEG;IACH,cAAc,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IAE7C;;OAEG;IACH,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG;QAAE,KAAK,EAAE,MAAM,EAAE,CAAC;QAAC,OAAO,EAAE,MAAM,EAAE,CAAA;KAAE,CAAA;CAC9E;AAED;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,iBAAiB,CA4D3D;AAED;;GAEG;AACH,eAAO,MAAM,aAAa,mBAA4B,CAAA;AAEtD;;GAEG;AACH,eAAO,MAAM,WAAW;IACtB;;OAEG;;;;;;;;;;;;;IAcH;;OAEG;;;;;;;;;;;;CAYJ,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,iBAAiB;IAC5B;;OAEG;;yBAEgB,MAAM;wBACP,MAAM;yBACL,IAAI,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK;iCAClE,MAAM;2BACZ,MAAM;yBACT,MAAM,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM;;IAItE;;OAEG;;yBAEgB,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC;wBAClB,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC;yBAChB,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC;iCACb,MAAM;2BACZ,MAAM;yBACT,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,QAAQ,GAAG,MAAM;;CAGpD,CAAA"}
|