@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":"breakpoints.js","sources":["../../../src/modifiers/responsive/breakpoints.ts"],"sourcesContent":["/**\n * Breakpoint Configuration System\n * \n * Manages responsive breakpoint configuration, validation, and utilities.\n * Supports both default Tailwind-inspired breakpoints and custom configurations.\n */\n\nimport { \n BreakpointKey, \n BreakpointConfig, \n DEFAULT_BREAKPOINTS,\n BreakpointContext,\n isValidBreakpointKey\n} from './types'\nimport { createSignal, Signal } from '../../reactive'\n\n/**\n * Global breakpoint configuration state\n */\nlet currentBreakpointConfig: Required<BreakpointConfig> = { ...DEFAULT_BREAKPOINTS }\n\n/**\n * Current active breakpoint signal\n */\nconst [currentBreakpoint, setCurrentBreakpoint] = createSignal<BreakpointKey>('base')\n\n/**\n * Current viewport dimensions signal\n */\nconst [viewportDimensions, setViewportDimensions] = createSignal({ width: 0, height: 0 })\n\n/**\n * Configure global breakpoints for the application\n */\nexport function configureBreakpoints(config: Partial<BreakpointConfig>): void {\n // Validate breakpoint configuration\n validateBreakpointConfig(config)\n \n // Update global configuration\n currentBreakpointConfig = {\n ...DEFAULT_BREAKPOINTS,\n ...config\n }\n \n // Re-evaluate current breakpoint\n updateCurrentBreakpoint()\n \n if (typeof window !== 'undefined') {\n // Update breakpoint on window resize\n window.addEventListener('resize', updateCurrentBreakpoint)\n }\n}\n\n/**\n * Get the current breakpoint configuration\n */\nexport function getCurrentBreakpointConfig(): Required<BreakpointConfig> {\n return { ...currentBreakpointConfig }\n}\n\n/**\n * Get the current active breakpoint\n */\nexport function getCurrentBreakpoint(): Signal<BreakpointKey> {\n return currentBreakpoint as Signal<BreakpointKey>\n}\n\n/**\n * Get current viewport dimensions\n */\nexport function getViewportDimensions(): Signal<{ width: number; height: number }> {\n return viewportDimensions as Signal<{ width: number; height: number }>\n}\n\n/**\n * Initialize the responsive system (should be called once on app startup)\n */\nexport function initializeResponsiveSystem(): void {\n if (typeof window === 'undefined') {\n return // Skip on server-side\n }\n \n // Set initial viewport dimensions\n updateViewportDimensions()\n updateCurrentBreakpoint()\n \n // Listen for window resize events\n window.addEventListener('resize', () => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n })\n \n // Listen for orientation changes\n window.addEventListener('orientationchange', () => {\n // Delay to ensure accurate dimensions after orientation change\n setTimeout(() => {\n updateViewportDimensions()\n updateCurrentBreakpoint()\n }, 100)\n })\n}\n\n/**\n * Create a breakpoint context for utilities\n */\nexport function createBreakpointContext(): BreakpointContext {\n const current = currentBreakpoint()\n const dimensions = viewportDimensions()\n \n return {\n current,\n width: dimensions.width,\n height: dimensions.height,\n isAbove: (breakpoint: BreakpointKey) => isBreakpointAbove(current, breakpoint),\n isBelow: (breakpoint: BreakpointKey) => isBreakpointBelow(current, breakpoint),\n isBetween: (min: BreakpointKey, max: BreakpointKey) => \n isBreakpointAbove(current, min) && isBreakpointBelow(current, max),\n matches: (query: string) => window.matchMedia(query).matches\n }\n}\n\n/**\n * Convert breakpoint value to numeric pixels for comparison\n */\nexport function breakpointToPixels(breakpoint: BreakpointKey): number {\n const value = currentBreakpointConfig[breakpoint]\n \n // Handle different CSS units\n if (value.endsWith('px')) {\n return parseInt(value, 10)\n } else if (value.endsWith('em')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n } else if (value.endsWith('rem')) {\n return parseInt(value, 10) * 16 // Assume 16px base font size\n }\n \n // Fallback to direct number conversion\n return parseInt(value, 10) || 0\n}\n\n/**\n * Get breakpoint index for comparison (base = 0, sm = 1, etc.)\n */\nexport function getBreakpointIndex(breakpoint: BreakpointKey): number {\n const order: BreakpointKey[] = ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n return order.indexOf(breakpoint)\n}\n\n/**\n * Check if breakpoint A is above breakpoint B\n */\nexport function isBreakpointAbove(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) > getBreakpointIndex(b)\n}\n\n/**\n * Check if breakpoint A is below breakpoint B\n */\nexport function isBreakpointBelow(a: BreakpointKey, b: BreakpointKey): boolean {\n return getBreakpointIndex(a) < getBreakpointIndex(b)\n}\n\n/**\n * Generate CSS media query string for a breakpoint\n */\nexport function generateMediaQuery(breakpoint: BreakpointKey): string {\n if (breakpoint === 'base') {\n return '' // No media query for base (mobile-first)\n }\n \n const minWidth = currentBreakpointConfig[breakpoint]\n return `(min-width: ${minWidth})`\n}\n\n/**\n * Generate CSS media query for a range of breakpoints\n */\nexport function generateRangeMediaQuery(min: BreakpointKey, max?: BreakpointKey): string {\n const queries: string[] = []\n \n if (min !== 'base') {\n queries.push(`(min-width: ${currentBreakpointConfig[min]})`)\n }\n \n if (max && max !== '2xl') {\n const maxBreakpoints: BreakpointKey[] = ['sm', 'md', 'lg', 'xl', '2xl']\n const maxIndex = maxBreakpoints.indexOf(max)\n if (maxIndex >= 0 && maxIndex < maxBreakpoints.length - 1) {\n const nextBreakpoint = maxBreakpoints[maxIndex + 1]\n const maxWidth = `${breakpointToPixels(nextBreakpoint) - 1}px`\n queries.push(`(max-width: ${maxWidth})`)\n }\n }\n \n return queries.length > 0 ? queries.join(' and ') : ''\n}\n\n/**\n * Get all breakpoints sorted by size\n */\nexport function getSortedBreakpoints(): BreakpointKey[] {\n return ['base', 'sm', 'md', 'lg', 'xl', '2xl']\n}\n\n/**\n * Get breakpoints above a given breakpoint\n */\nexport function getBreakpointsAbove(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index >= 0 ? sorted.slice(index + 1) : []\n}\n\n/**\n * Get breakpoints below a given breakpoint\n */\nexport function getBreakpointsBelow(breakpoint: BreakpointKey): BreakpointKey[] {\n const sorted = getSortedBreakpoints()\n const index = sorted.indexOf(breakpoint)\n return index > 0 ? sorted.slice(0, index) : []\n}\n\n/**\n * Resolve current breakpoint based on viewport width\n */\nfunction updateCurrentBreakpoint(): void {\n if (typeof window === 'undefined') {\n return\n }\n \n const width = window.innerWidth\n const breakpoints = getSortedBreakpoints().reverse() // Start from largest\n \n for (const breakpoint of breakpoints) {\n if (breakpoint === 'base' || width >= breakpointToPixels(breakpoint)) {\n setCurrentBreakpoint(breakpoint)\n return\n }\n }\n \n setCurrentBreakpoint('base')\n}\n\n/**\n * Update viewport dimensions\n */\nfunction updateViewportDimensions(): void {\n if (typeof window !== 'undefined') {\n setViewportDimensions({\n width: window.innerWidth,\n height: window.innerHeight\n })\n }\n}\n\n/**\n * Validate breakpoint configuration\n */\nfunction validateBreakpointConfig(config: Partial<BreakpointConfig>): void {\n for (const [key, value] of Object.entries(config)) {\n if (!isValidBreakpointKey(key)) {\n throw new Error(`Invalid breakpoint key: \"${key}\". Valid keys are: base, sm, md, lg, xl, 2xl`)\n }\n \n if (typeof value !== 'string') {\n throw new Error(`Breakpoint value for \"${key}\" must be a string (e.g., \"768px\")`)\n }\n \n if (!value.match(/^\\d+(\\.\\d+)?(px|em|rem|%)$/)) {\n throw new Error(`Invalid breakpoint value for \"${key}\": \"${value}\". Must be a valid CSS length (e.g., \"768px\", \"48em\")`)\n }\n }\n \n // Validate that breakpoints are in ascending order\n const sortedKeys = Object.keys(config).filter(isValidBreakpointKey).sort((a, b) => {\n return getBreakpointIndex(a as BreakpointKey) - getBreakpointIndex(b as BreakpointKey)\n })\n \n for (let i = 1; i < sortedKeys.length; i++) {\n const prev = sortedKeys[i - 1] as BreakpointKey\n const current = sortedKeys[i] as BreakpointKey\n const prevValue = config[prev]!\n const currentValue = config[current]!\n \n if (breakpointToPixels(prev) >= parseInt(currentValue, 10)) {\n throw new Error(`Breakpoint \"${current}\" (${currentValue}) must be larger than \"${prev}\" (${prevValue})`)\n }\n }\n}\n\n/**\n * Create common breakpoint configurations\n */\nexport const BreakpointPresets = {\n // Tailwind CSS (default)\n tailwind: {\n sm: '640px',\n md: '768px',\n lg: '1024px',\n xl: '1280px',\n '2xl': '1536px'\n } as BreakpointConfig,\n \n // Bootstrap\n bootstrap: {\n sm: '576px',\n md: '768px',\n lg: '992px',\n xl: '1200px',\n '2xl': '1400px'\n } as BreakpointConfig,\n \n // Material Design\n material: {\n sm: '600px',\n md: '960px',\n lg: '1280px',\n xl: '1920px',\n '2xl': '2560px'\n } as BreakpointConfig,\n \n // Custom mobile-first\n mobileFocus: {\n sm: '480px',\n md: '768px',\n lg: '1024px',\n xl: '1200px',\n '2xl': '1440px'\n } as BreakpointConfig\n} as const"],"names":["currentBreakpointConfig","DEFAULT_BREAKPOINTS","currentBreakpoint","setCurrentBreakpoint","createSignal","viewportDimensions","setViewportDimensions","configureBreakpoints","config","validateBreakpointConfig","updateCurrentBreakpoint","getCurrentBreakpointConfig","getCurrentBreakpoint","getViewportDimensions","initializeResponsiveSystem","updateViewportDimensions","createBreakpointContext","current","dimensions","breakpoint","isBreakpointAbove","isBreakpointBelow","min","max","query","breakpointToPixels","value","getBreakpointIndex","a","b","generateMediaQuery","generateRangeMediaQuery","queries","maxBreakpoints","maxIndex","nextBreakpoint","maxWidth","getSortedBreakpoints","getBreakpointsAbove","sorted","index","getBreakpointsBelow","width","breakpoints","key","isValidBreakpointKey","sortedKeys","i","prev","prevValue","currentValue","BreakpointPresets"],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("./types.cjs"),h=require("./breakpoints.cjs");var m=Object.defineProperty,$=(l,e,t)=>e in l?m(l,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):l[e]=t,f=(l,e,t)=>$(l,typeof e!="symbol"?e+"":e,t);class g{constructor(e){f(this,"options"),this.options={generateMinified:!1,includeComments:!0,optimizeOutput:!0,mobileFirst:!0,...e}}generateResponsiveCSS(e){const t=[],s=[],r={};let o=!1;for(const[n,c]of Object.entries(e))if(y.isResponsiveValue(c)){o=!0;const i=this.generatePropertyMediaQueries(n,c);t.push(...i.mediaQueries),i.baseStyles&&Object.assign(r,i.baseStyles)}else r[this.toCSSPropertyName(n)]=this.formatCSSValue(n,c);return s.push(...this.generateCSSRules(t,r)),{cssRules:s,mediaQueries:t,fallbackStyles:r,hasResponsiveStyles:o}}generatePropertyMediaQueries(e,t){const s=[],r={},o=h.getSortedBreakpoints();for(const n of o){const c=t[n];if(c===void 0)continue;const i=this.toCSSPropertyName(e),u=this.formatCSSValue(e,c);if(n==="base")r[i]=u;else{const a=h.generateMediaQuery(n),d={[i]:u};s.push({breakpoint:n,query:a,styles:d,selector:this.options.selector})}}return{mediaQueries:s,baseStyles:Object.keys(r).length>0?r:void 0}}generateCSSRules(e,t){const s=[];if(Object.keys(t).length>0){const o=this.generateCSSRule(this.options.selector,t);s.push(o)}const r=this.groupQueriesByMediaQuery(e);for(const[o,n]of Object.entries(r)){if(o==="")continue;const c={};for(const u of n)Object.assign(c,u.styles);const i=this.generateMediaQueryRule(o,this.options.selector,c);s.push(i)}return s}groupQueriesByMediaQuery(e){const t={};for(const s of e)t[s.query]||(t[s.query]=[]),t[s.query].push(s);return t}generateCSSRule(e,t){const{generateMinified:s,includeComments:r}=this.options,o=s?"":" ",n=s?"":`
|
|
2
|
+
`,c=s?"":" ";let i=`${e}${c}{${n}`;for(const[u,a]of Object.entries(t))i+=`${o}${u}:${c}${a};${n}`;return i+=`}${n}`,r&&!s&&(i=`/* Base styles (mobile-first) */${n}${i}`),i}generateMediaQueryRule(e,t,s){const{generateMinified:r,includeComments:o}=this.options,n=r?"":" ",c=r?"":" ",i=r?"":`
|
|
3
|
+
`,u=r?"":" ";let a=`@media ${e}${u}{${i}`;a+=`${n}${t}${u}{${i}`;for(const[d,p]of Object.entries(s))a+=`${c}${d}:${u}${p};${i}`;return a+=`${n}}${i}`,a+=`}${i}`,o&&!r&&(a=`/* ${this.getBreakpointFromQuery(e)} styles */${i}${a}`),a}toCSSProperty(e){return e.replace(/[A-Z]/g,t=>`-${t.toLowerCase()}`)}formatCSSValue(e,t){if(t==null)return"inherit";if(typeof t=="number"){const s=["opacity","z-index","font-weight","line-height","flex-grow","flex-shrink","order","grid-column-start","grid-column-end","grid-row-start","grid-row-end"],r=this.toCSSProperty(e);if(s.includes(r))return this.addImportantIfNeeded(e,t.toString());if(["width","height","min-width","max-width","min-height","max-height","padding","margin","border-width","border-radius","top","right","bottom","left","font-size","letter-spacing","text-indent"].some(n=>r.includes(n)))return this.addImportantIfNeeded(e,`${t}px`)}return this.addImportantIfNeeded(e,t.toString())}addImportantIfNeeded(e,t){const s=["flexDirection","flex-direction","justifyContent","justify-content","alignItems","align-items","display"],r=this.toCSSProperty(e);return s.includes(e)||s.includes(r)?`${t} !important`:t}toCSSPropertyName(e){return this.toCSSProperty(e)}getBreakpointFromQuery(e){const t=h.getCurrentBreakpointConfig();for(const[s,r]of Object.entries(t))if(e.includes(r))return s;return"custom"}}function b(l,e,t,s){if(!y.isResponsiveValue(t)){const c=e.replace(/[A-Z]/g,u=>`-${u.toLowerCase()}`),i=typeof t=="number"?`${t}px`:t.toString();return[`${l} { ${c}: ${i}; }`]}const r=new g({selector:l,...s}),o={[e]:t};return r.generateResponsiveCSS(o).cssRules}function C(l,e,t){const{generateMinified:s=!1}=t||{},r=s?"":" ",o=s?"":`
|
|
4
|
+
`,n=s?"":" ";let c=`@media ${e.query}${n}{${o}`;c+=`${r}${l}${n}{${o}`;for(const[i,u]of Object.entries(e.styles)){const a=i.replace(/[A-Z]/g,p=>`-${p.toLowerCase()}`),d=typeof u=="number"?`${u}px`:u.toString();c+=`${r}${r}${a}:${n}${d};${o}`}return c+=`${r}}${o}`,c+=`}${o}`,c}class S{static getStyleSheet(){if(this.styleSheet)return this.styleSheet;const e=document.createElement("style");return e.setAttribute("data-tachui-responsive","true"),document.head.appendChild(e),this.styleSheet=e.sheet,this.styleSheet}static injectCSS(e){if(typeof document>"u")return;const t=this.getStyleSheet();for(const s of e)if(!this.injectedRules.has(s))try{t.insertRule(s,t.cssRules.length),this.injectedRules.add(s)}catch(r){console.warn("Failed to inject CSS rule:",s,r)}}static clearCSS(){if(this.styleSheet){for(;this.styleSheet.cssRules.length>0;)this.styleSheet.deleteRule(0);this.injectedRules.clear()}}static hasRule(e){return this.injectedRules.has(e)}}f(S,"styleSheet",null);f(S,"injectedRules",new Set);exports.CSSInjector=S;exports.ResponsiveCSSGenerator=g;exports.generateCustomMediaQuery=C;exports.generateResponsiveProperty=b;
|
|
5
|
+
//# sourceMappingURL=css-generator.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css-generator.cjs","sources":["../../../src/modifiers/responsive/css-generator.ts"],"sourcesContent":["/**\n * Responsive CSS Generation Engine\n * \n * Generates optimized CSS media queries from responsive modifier configurations.\n * Supports mobile-first design patterns and advanced media query features.\n */\n\nimport {\n BreakpointKey,\n ResponsiveValue,\n ResponsiveStyleConfig,\n MediaQueryConfig,\n GeneratedMediaQuery,\n ResponsiveModifierResult,\n isResponsiveValue\n} from './types'\nimport {\n generateMediaQuery,\n getCurrentBreakpointConfig,\n getSortedBreakpoints\n} from './breakpoints'\n\n/**\n * CSS generation options\n */\nexport interface CSSGenerationOptions {\n selector: string // CSS selector for the element\n generateMinified?: boolean // Generate minified CSS\n includeComments?: boolean // Include helpful comments\n optimizeOutput?: boolean // Optimize and deduplicate CSS\n mobileFirst?: boolean // Use mobile-first approach (default: true)\n}\n\n/**\n * Main CSS generation class\n */\nexport class ResponsiveCSSGenerator {\n private options: Required<CSSGenerationOptions>\n \n constructor(options: CSSGenerationOptions) {\n this.options = {\n generateMinified: false,\n includeComments: true,\n optimizeOutput: true,\n mobileFirst: true,\n ...options\n }\n }\n \n /**\n * Generate complete responsive CSS from a style configuration\n */\n generateResponsiveCSS(config: ResponsiveStyleConfig): ResponsiveModifierResult {\n const mediaQueries: GeneratedMediaQuery[] = []\n const cssRules: string[] = []\n const fallbackStyles: Record<string, string | number> = {}\n let hasResponsiveStyles = false\n \n // Process each property in the configuration\n for (const [property, value] of Object.entries(config)) {\n if (isResponsiveValue(value)) {\n hasResponsiveStyles = true\n const result = this.generatePropertyMediaQueries(property, value)\n mediaQueries.push(...result.mediaQueries)\n \n // Add base styles to fallback\n if (result.baseStyles) {\n Object.assign(fallbackStyles, result.baseStyles)\n }\n } else {\n // Non-responsive property - add to fallback styles\n fallbackStyles[this.toCSSPropertyName(property)] = this.formatCSSValue(property, value)\n }\n }\n \n // Generate CSS rules from media queries\n cssRules.push(...this.generateCSSRules(mediaQueries, fallbackStyles))\n \n return {\n cssRules,\n mediaQueries,\n fallbackStyles,\n hasResponsiveStyles\n }\n }\n \n /**\n * Generate media queries for a single property\n */\n private generatePropertyMediaQueries(\n property: string, \n value: Partial<Record<BreakpointKey, any>>\n ): { mediaQueries: GeneratedMediaQuery[]; baseStyles?: Record<string, string | number> } {\n const mediaQueries: GeneratedMediaQuery[] = []\n const baseStyles: Record<string, string | number> = {}\n const sortedBreakpoints = getSortedBreakpoints()\n \n for (const breakpoint of sortedBreakpoints) {\n const breakpointValue = value[breakpoint]\n if (breakpointValue === undefined) continue\n \n const cssProperty = this.toCSSPropertyName(property)\n const cssValue = this.formatCSSValue(property, breakpointValue)\n \n if (breakpoint === 'base') {\n // Base styles (no media query needed for mobile-first)\n baseStyles[cssProperty] = cssValue\n } else {\n // Generate media query for this breakpoint\n const query = generateMediaQuery(breakpoint)\n const styles = { [cssProperty]: cssValue }\n \n mediaQueries.push({\n breakpoint,\n query,\n styles,\n selector: this.options.selector\n })\n }\n }\n \n return { mediaQueries, baseStyles: Object.keys(baseStyles).length > 0 ? baseStyles : undefined }\n }\n \n /**\n * Generate CSS rules from media queries and base styles\n */\n private generateCSSRules(\n mediaQueries: GeneratedMediaQuery[], \n baseStyles: Record<string, string | number>\n ): string[] {\n const rules: string[] = []\n \n // Generate base styles rule (mobile-first)\n if (Object.keys(baseStyles).length > 0) {\n const baseRule = this.generateCSSRule(this.options.selector, baseStyles)\n rules.push(baseRule)\n }\n \n // Generate media query rules\n const groupedQueries = this.groupQueriesByMediaQuery(mediaQueries)\n \n for (const [query, queryMediaQueries] of Object.entries(groupedQueries)) {\n if (query === '') continue // Skip empty queries (base styles)\n \n // Combine all styles for this media query\n const combinedStyles: Record<string, string | number> = {}\n for (const mq of queryMediaQueries) {\n Object.assign(combinedStyles, mq.styles)\n }\n \n const mediaRule = this.generateMediaQueryRule(query, this.options.selector, combinedStyles)\n rules.push(mediaRule)\n }\n \n return rules\n }\n \n /**\n * Group media queries by their query string for optimization\n */\n private groupQueriesByMediaQuery(mediaQueries: GeneratedMediaQuery[]): Record<string, GeneratedMediaQuery[]> {\n const grouped: Record<string, GeneratedMediaQuery[]> = {}\n \n for (const mq of mediaQueries) {\n if (!grouped[mq.query]) {\n grouped[mq.query] = []\n }\n grouped[mq.query].push(mq)\n }\n \n return grouped\n }\n \n /**\n * Generate a single CSS rule\n */\n private generateCSSRule(selector: string, styles: Record<string, string | number>): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${indent}${property}:${space}${value};${newline}`\n }\n \n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n rule = `/* Base styles (mobile-first) */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Generate a CSS media query rule\n */\n private generateMediaQueryRule(\n query: string, \n selector: string, \n styles: Record<string, string | number>\n ): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const doubleIndent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${doubleIndent}${property}:${space}${value};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n const breakpoint = this.getBreakpointFromQuery(query)\n rule = `/* ${breakpoint} styles */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Convert camelCase property to CSS kebab-case\n */\n private toCSSProperty(property: string): string {\n return property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n }\n \n /**\n * Format CSS value with appropriate units and validation\n */\n private formatCSSValue(property: string, value: any): string {\n if (value === null || value === undefined) {\n return 'inherit'\n }\n \n // Handle numeric values that need units\n if (typeof value === 'number') {\n const unitlessProperties = [\n 'opacity', 'z-index', 'font-weight', 'line-height', \n 'flex-grow', 'flex-shrink', 'order', 'grid-column-start',\n 'grid-column-end', 'grid-row-start', 'grid-row-end'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (unitlessProperties.includes(cssProperty)) {\n return this.addImportantIfNeeded(property, value.toString())\n }\n \n // Add px unit for dimension properties\n const dimensionProperties = [\n 'width', 'height', 'min-width', 'max-width', 'min-height', 'max-height',\n 'padding', 'margin', 'border-width', 'border-radius', 'top', 'right', \n 'bottom', 'left', 'font-size', 'letter-spacing', 'text-indent'\n ]\n \n if (dimensionProperties.some(prop => cssProperty.includes(prop))) {\n return this.addImportantIfNeeded(property, `${value}px`)\n }\n }\n \n return this.addImportantIfNeeded(property, value.toString())\n }\n\n /**\n * Add !important for properties that need to override base component styles\n */\n private addImportantIfNeeded(property: string, value: string): string {\n const conflictingProperties = [\n 'flexDirection', 'flex-direction',\n 'justifyContent', 'justify-content', \n 'alignItems', 'align-items',\n 'display'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (conflictingProperties.includes(property) || conflictingProperties.includes(cssProperty)) {\n return `${value} !important`\n }\n \n return value\n }\n\n /**\n * Convert property name to appropriate CSS property (including custom properties)\n */\n private toCSSPropertyName(property: string): string {\n return this.toCSSProperty(property)\n }\n \n /**\n * Extract breakpoint name from media query for comments\n */\n private getBreakpointFromQuery(query: string): string {\n const breakpointConfig = getCurrentBreakpointConfig()\n \n for (const [breakpoint, value] of Object.entries(breakpointConfig)) {\n if (query.includes(value)) {\n return breakpoint\n }\n }\n \n return 'custom'\n }\n}\n\n/**\n * Utility function to generate responsive CSS for a single property\n */\nexport function generateResponsiveProperty(\n selector: string,\n property: string,\n value: ResponsiveValue<any>,\n options?: Partial<CSSGenerationOptions>\n): string[] {\n if (!isResponsiveValue(value)) {\n // Non-responsive value - return simple CSS rule\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n return [`${selector} { ${cssProperty}: ${cssValue}; }`]\n }\n \n const generator = new ResponsiveCSSGenerator({ selector, ...options })\n const config = { [property]: value }\n const result = generator.generateResponsiveCSS(config)\n \n return result.cssRules\n}\n\n/**\n * Utility function to generate media query for custom conditions\n */\nexport function generateCustomMediaQuery(\n selector: string,\n mediaQueryConfig: MediaQueryConfig,\n options?: Partial<CSSGenerationOptions>\n): string {\n const { generateMinified = false } = options || {}\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${mediaQueryConfig.query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(mediaQueryConfig.styles)) {\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n rule += `${indent}${indent}${cssProperty}:${space}${cssValue};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n return rule\n}\n\n/**\n * CSS injection utilities for runtime application\n */\nexport class CSSInjector {\n private static styleSheet: CSSStyleSheet | null = null\n private static injectedRules = new Set<string>()\n \n /**\n * Get or create the tachUI responsive stylesheet\n */\n private static getStyleSheet(): CSSStyleSheet {\n if (this.styleSheet) {\n return this.styleSheet\n }\n \n const style = document.createElement('style')\n style.setAttribute('data-tachui-responsive', 'true')\n document.head.appendChild(style)\n \n this.styleSheet = style.sheet as CSSStyleSheet\n return this.styleSheet\n }\n\n /**\n * Inject CSS rules into the document\n */\n static injectCSS(rules: string[]): void {\n if (typeof document === 'undefined') {\n return // Skip on server-side\n }\n \n const styleSheet = this.getStyleSheet()\n \n for (const rule of rules) {\n if (this.injectedRules.has(rule)) {\n continue // Skip duplicate rules\n }\n \n try {\n styleSheet.insertRule(rule, styleSheet.cssRules.length)\n this.injectedRules.add(rule)\n } catch (error) {\n console.warn('Failed to inject CSS rule:', rule, error)\n }\n }\n }\n \n /**\n * Clear all injected responsive CSS\n */\n static clearCSS(): void {\n if (this.styleSheet) {\n while (this.styleSheet.cssRules.length > 0) {\n this.styleSheet.deleteRule(0)\n }\n this.injectedRules.clear()\n }\n }\n \n /**\n * Check if a rule has been injected\n */\n static hasRule(rule: string): boolean {\n return this.injectedRules.has(rule)\n }\n}"],"names":["ResponsiveCSSGenerator","options","__publicField","config","mediaQueries","cssRules","fallbackStyles","hasResponsiveStyles","property","value","isResponsiveValue","result","baseStyles","sortedBreakpoints","getSortedBreakpoints","breakpoint","breakpointValue","cssProperty","cssValue","query","generateMediaQuery","styles","rules","baseRule","groupedQueries","queryMediaQueries","combinedStyles","mq","mediaRule","grouped","selector","generateMinified","includeComments","indent","newline","space","rule","doubleIndent","match","unitlessProperties","prop","conflictingProperties","breakpointConfig","getCurrentBreakpointConfig","generateResponsiveProperty","generator","generateCustomMediaQuery","mediaQueryConfig","CSSInjector","style","styleSheet","error"],"mappings":"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"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Responsive CSS Generation Engine
|
|
3
|
+
*
|
|
4
|
+
* Generates optimized CSS media queries from responsive modifier configurations.
|
|
5
|
+
* Supports mobile-first design patterns and advanced media query features.
|
|
6
|
+
*/
|
|
7
|
+
import { ResponsiveValue, ResponsiveStyleConfig, MediaQueryConfig, ResponsiveModifierResult } from './types';
|
|
8
|
+
/**
|
|
9
|
+
* CSS generation options
|
|
10
|
+
*/
|
|
11
|
+
export interface CSSGenerationOptions {
|
|
12
|
+
selector: string;
|
|
13
|
+
generateMinified?: boolean;
|
|
14
|
+
includeComments?: boolean;
|
|
15
|
+
optimizeOutput?: boolean;
|
|
16
|
+
mobileFirst?: boolean;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Main CSS generation class
|
|
20
|
+
*/
|
|
21
|
+
export declare class ResponsiveCSSGenerator {
|
|
22
|
+
private options;
|
|
23
|
+
constructor(options: CSSGenerationOptions);
|
|
24
|
+
/**
|
|
25
|
+
* Generate complete responsive CSS from a style configuration
|
|
26
|
+
*/
|
|
27
|
+
generateResponsiveCSS(config: ResponsiveStyleConfig): ResponsiveModifierResult;
|
|
28
|
+
/**
|
|
29
|
+
* Generate media queries for a single property
|
|
30
|
+
*/
|
|
31
|
+
private generatePropertyMediaQueries;
|
|
32
|
+
/**
|
|
33
|
+
* Generate CSS rules from media queries and base styles
|
|
34
|
+
*/
|
|
35
|
+
private generateCSSRules;
|
|
36
|
+
/**
|
|
37
|
+
* Group media queries by their query string for optimization
|
|
38
|
+
*/
|
|
39
|
+
private groupQueriesByMediaQuery;
|
|
40
|
+
/**
|
|
41
|
+
* Generate a single CSS rule
|
|
42
|
+
*/
|
|
43
|
+
private generateCSSRule;
|
|
44
|
+
/**
|
|
45
|
+
* Generate a CSS media query rule
|
|
46
|
+
*/
|
|
47
|
+
private generateMediaQueryRule;
|
|
48
|
+
/**
|
|
49
|
+
* Convert camelCase property to CSS kebab-case
|
|
50
|
+
*/
|
|
51
|
+
private toCSSProperty;
|
|
52
|
+
/**
|
|
53
|
+
* Format CSS value with appropriate units and validation
|
|
54
|
+
*/
|
|
55
|
+
private formatCSSValue;
|
|
56
|
+
/**
|
|
57
|
+
* Add !important for properties that need to override base component styles
|
|
58
|
+
*/
|
|
59
|
+
private addImportantIfNeeded;
|
|
60
|
+
/**
|
|
61
|
+
* Convert property name to appropriate CSS property (including custom properties)
|
|
62
|
+
*/
|
|
63
|
+
private toCSSPropertyName;
|
|
64
|
+
/**
|
|
65
|
+
* Extract breakpoint name from media query for comments
|
|
66
|
+
*/
|
|
67
|
+
private getBreakpointFromQuery;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Utility function to generate responsive CSS for a single property
|
|
71
|
+
*/
|
|
72
|
+
export declare function generateResponsiveProperty(selector: string, property: string, value: ResponsiveValue<any>, options?: Partial<CSSGenerationOptions>): string[];
|
|
73
|
+
/**
|
|
74
|
+
* Utility function to generate media query for custom conditions
|
|
75
|
+
*/
|
|
76
|
+
export declare function generateCustomMediaQuery(selector: string, mediaQueryConfig: MediaQueryConfig, options?: Partial<CSSGenerationOptions>): string;
|
|
77
|
+
/**
|
|
78
|
+
* CSS injection utilities for runtime application
|
|
79
|
+
*/
|
|
80
|
+
export declare class CSSInjector {
|
|
81
|
+
private static styleSheet;
|
|
82
|
+
private static injectedRules;
|
|
83
|
+
/**
|
|
84
|
+
* Get or create the tachUI responsive stylesheet
|
|
85
|
+
*/
|
|
86
|
+
private static getStyleSheet;
|
|
87
|
+
/**
|
|
88
|
+
* Inject CSS rules into the document
|
|
89
|
+
*/
|
|
90
|
+
static injectCSS(rules: string[]): void;
|
|
91
|
+
/**
|
|
92
|
+
* Clear all injected responsive CSS
|
|
93
|
+
*/
|
|
94
|
+
static clearCSS(): void;
|
|
95
|
+
/**
|
|
96
|
+
* Check if a rule has been injected
|
|
97
|
+
*/
|
|
98
|
+
static hasRule(rule: string): boolean;
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=css-generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css-generator.d.ts","sourceRoot":"","sources":["../../../src/modifiers/responsive/css-generator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAEL,eAAe,EACf,qBAAqB,EACrB,gBAAgB,EAEhB,wBAAwB,EAEzB,MAAM,SAAS,CAAA;AAOhB;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,MAAM,CAAA;IAChB,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED;;GAEG;AACH,qBAAa,sBAAsB;IACjC,OAAO,CAAC,OAAO,CAAgC;gBAEnC,OAAO,EAAE,oBAAoB;IAUzC;;OAEG;IACH,qBAAqB,CAAC,MAAM,EAAE,qBAAqB,GAAG,wBAAwB;IAkC9E;;OAEG;IACH,OAAO,CAAC,4BAA4B;IAmCpC;;OAEG;IACH,OAAO,CAAC,gBAAgB;IA+BxB;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAahC;;OAEG;IACH,OAAO,CAAC,eAAe;IAqBvB;;OAEG;IACH,OAAO,CAAC,sBAAsB;IA6B9B;;OAEG;IACH,OAAO,CAAC,aAAa;IAIrB;;OAEG;IACH,OAAO,CAAC,cAAc;IAiCtB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAgB5B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;OAEG;IACH,OAAO,CAAC,sBAAsB;CAW/B;AAED;;GAEG;AACH,wBAAgB,0BAA0B,CACxC,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,eAAe,CAAC,GAAG,CAAC,EAC3B,OAAO,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,GACtC,MAAM,EAAE,CAaV;AAED;;GAEG;AACH,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,MAAM,EAChB,gBAAgB,EAAE,gBAAgB,EAClC,OAAO,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,GACtC,MAAM,CAmBR;AAED;;GAEG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAC,UAAU,CAA6B;IACtD,OAAO,CAAC,MAAM,CAAC,aAAa,CAAoB;IAEhD;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IAa5B;;OAEG;IACH,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI;IAqBvC;;OAEG;IACH,MAAM,CAAC,QAAQ,IAAI,IAAI;IASvB;;OAEG;IACH,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;CAGtC"}
|
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { isResponsiveValue as h } from "./types.js";
|
|
2
|
+
import { getSortedBreakpoints as y, generateMediaQuery as g, getCurrentBreakpointConfig as m } from "./breakpoints.js";
|
|
3
|
+
var $ = Object.defineProperty, b = (a, e, t) => e in a ? $(a, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[e] = t, f = (a, e, t) => b(a, typeof e != "symbol" ? e + "" : e, t);
|
|
4
|
+
class C {
|
|
5
|
+
constructor(e) {
|
|
6
|
+
f(this, "options"), this.options = {
|
|
7
|
+
generateMinified: !1,
|
|
8
|
+
includeComments: !0,
|
|
9
|
+
optimizeOutput: !0,
|
|
10
|
+
mobileFirst: !0,
|
|
11
|
+
...e
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Generate complete responsive CSS from a style configuration
|
|
16
|
+
*/
|
|
17
|
+
generateResponsiveCSS(e) {
|
|
18
|
+
const t = [], s = [], r = {};
|
|
19
|
+
let o = !1;
|
|
20
|
+
for (const [n, c] of Object.entries(e))
|
|
21
|
+
if (h(c)) {
|
|
22
|
+
o = !0;
|
|
23
|
+
const i = this.generatePropertyMediaQueries(n, c);
|
|
24
|
+
t.push(...i.mediaQueries), i.baseStyles && Object.assign(r, i.baseStyles);
|
|
25
|
+
} else
|
|
26
|
+
r[this.toCSSPropertyName(n)] = this.formatCSSValue(n, c);
|
|
27
|
+
return s.push(...this.generateCSSRules(t, r)), {
|
|
28
|
+
cssRules: s,
|
|
29
|
+
mediaQueries: t,
|
|
30
|
+
fallbackStyles: r,
|
|
31
|
+
hasResponsiveStyles: o
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Generate media queries for a single property
|
|
36
|
+
*/
|
|
37
|
+
generatePropertyMediaQueries(e, t) {
|
|
38
|
+
const s = [], r = {}, o = y();
|
|
39
|
+
for (const n of o) {
|
|
40
|
+
const c = t[n];
|
|
41
|
+
if (c === void 0) continue;
|
|
42
|
+
const i = this.toCSSPropertyName(e), u = this.formatCSSValue(e, c);
|
|
43
|
+
if (n === "base")
|
|
44
|
+
r[i] = u;
|
|
45
|
+
else {
|
|
46
|
+
const l = g(n), d = { [i]: u };
|
|
47
|
+
s.push({
|
|
48
|
+
breakpoint: n,
|
|
49
|
+
query: l,
|
|
50
|
+
styles: d,
|
|
51
|
+
selector: this.options.selector
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return { mediaQueries: s, baseStyles: Object.keys(r).length > 0 ? r : void 0 };
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Generate CSS rules from media queries and base styles
|
|
59
|
+
*/
|
|
60
|
+
generateCSSRules(e, t) {
|
|
61
|
+
const s = [];
|
|
62
|
+
if (Object.keys(t).length > 0) {
|
|
63
|
+
const o = this.generateCSSRule(this.options.selector, t);
|
|
64
|
+
s.push(o);
|
|
65
|
+
}
|
|
66
|
+
const r = this.groupQueriesByMediaQuery(e);
|
|
67
|
+
for (const [o, n] of Object.entries(r)) {
|
|
68
|
+
if (o === "") continue;
|
|
69
|
+
const c = {};
|
|
70
|
+
for (const u of n)
|
|
71
|
+
Object.assign(c, u.styles);
|
|
72
|
+
const i = this.generateMediaQueryRule(o, this.options.selector, c);
|
|
73
|
+
s.push(i);
|
|
74
|
+
}
|
|
75
|
+
return s;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Group media queries by their query string for optimization
|
|
79
|
+
*/
|
|
80
|
+
groupQueriesByMediaQuery(e) {
|
|
81
|
+
const t = {};
|
|
82
|
+
for (const s of e)
|
|
83
|
+
t[s.query] || (t[s.query] = []), t[s.query].push(s);
|
|
84
|
+
return t;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Generate a single CSS rule
|
|
88
|
+
*/
|
|
89
|
+
generateCSSRule(e, t) {
|
|
90
|
+
const { generateMinified: s, includeComments: r } = this.options, o = s ? "" : " ", n = s ? "" : `
|
|
91
|
+
`, c = s ? "" : " ";
|
|
92
|
+
let i = `${e}${c}{${n}`;
|
|
93
|
+
for (const [u, l] of Object.entries(t))
|
|
94
|
+
i += `${o}${u}:${c}${l};${n}`;
|
|
95
|
+
return i += `}${n}`, r && !s && (i = `/* Base styles (mobile-first) */${n}${i}`), i;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Generate a CSS media query rule
|
|
99
|
+
*/
|
|
100
|
+
generateMediaQueryRule(e, t, s) {
|
|
101
|
+
const { generateMinified: r, includeComments: o } = this.options, n = r ? "" : " ", c = r ? "" : " ", i = r ? "" : `
|
|
102
|
+
`, u = r ? "" : " ";
|
|
103
|
+
let l = `@media ${e}${u}{${i}`;
|
|
104
|
+
l += `${n}${t}${u}{${i}`;
|
|
105
|
+
for (const [d, p] of Object.entries(s))
|
|
106
|
+
l += `${c}${d}:${u}${p};${i}`;
|
|
107
|
+
return l += `${n}}${i}`, l += `}${i}`, o && !r && (l = `/* ${this.getBreakpointFromQuery(e)} styles */${i}${l}`), l;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Convert camelCase property to CSS kebab-case
|
|
111
|
+
*/
|
|
112
|
+
toCSSProperty(e) {
|
|
113
|
+
return e.replace(/[A-Z]/g, (t) => `-${t.toLowerCase()}`);
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Format CSS value with appropriate units and validation
|
|
117
|
+
*/
|
|
118
|
+
formatCSSValue(e, t) {
|
|
119
|
+
if (t == null)
|
|
120
|
+
return "inherit";
|
|
121
|
+
if (typeof t == "number") {
|
|
122
|
+
const s = [
|
|
123
|
+
"opacity",
|
|
124
|
+
"z-index",
|
|
125
|
+
"font-weight",
|
|
126
|
+
"line-height",
|
|
127
|
+
"flex-grow",
|
|
128
|
+
"flex-shrink",
|
|
129
|
+
"order",
|
|
130
|
+
"grid-column-start",
|
|
131
|
+
"grid-column-end",
|
|
132
|
+
"grid-row-start",
|
|
133
|
+
"grid-row-end"
|
|
134
|
+
], r = this.toCSSProperty(e);
|
|
135
|
+
if (s.includes(r))
|
|
136
|
+
return this.addImportantIfNeeded(e, t.toString());
|
|
137
|
+
if ([
|
|
138
|
+
"width",
|
|
139
|
+
"height",
|
|
140
|
+
"min-width",
|
|
141
|
+
"max-width",
|
|
142
|
+
"min-height",
|
|
143
|
+
"max-height",
|
|
144
|
+
"padding",
|
|
145
|
+
"margin",
|
|
146
|
+
"border-width",
|
|
147
|
+
"border-radius",
|
|
148
|
+
"top",
|
|
149
|
+
"right",
|
|
150
|
+
"bottom",
|
|
151
|
+
"left",
|
|
152
|
+
"font-size",
|
|
153
|
+
"letter-spacing",
|
|
154
|
+
"text-indent"
|
|
155
|
+
].some((n) => r.includes(n)))
|
|
156
|
+
return this.addImportantIfNeeded(e, `${t}px`);
|
|
157
|
+
}
|
|
158
|
+
return this.addImportantIfNeeded(e, t.toString());
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Add !important for properties that need to override base component styles
|
|
162
|
+
*/
|
|
163
|
+
addImportantIfNeeded(e, t) {
|
|
164
|
+
const s = [
|
|
165
|
+
"flexDirection",
|
|
166
|
+
"flex-direction",
|
|
167
|
+
"justifyContent",
|
|
168
|
+
"justify-content",
|
|
169
|
+
"alignItems",
|
|
170
|
+
"align-items",
|
|
171
|
+
"display"
|
|
172
|
+
], r = this.toCSSProperty(e);
|
|
173
|
+
return s.includes(e) || s.includes(r) ? `${t} !important` : t;
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Convert property name to appropriate CSS property (including custom properties)
|
|
177
|
+
*/
|
|
178
|
+
toCSSPropertyName(e) {
|
|
179
|
+
return this.toCSSProperty(e);
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Extract breakpoint name from media query for comments
|
|
183
|
+
*/
|
|
184
|
+
getBreakpointFromQuery(e) {
|
|
185
|
+
const t = m();
|
|
186
|
+
for (const [s, r] of Object.entries(t))
|
|
187
|
+
if (e.includes(r))
|
|
188
|
+
return s;
|
|
189
|
+
return "custom";
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
function j(a, e, t, s) {
|
|
193
|
+
if (!h(t)) {
|
|
194
|
+
const c = e.replace(/[A-Z]/g, (u) => `-${u.toLowerCase()}`), i = typeof t == "number" ? `${t}px` : t.toString();
|
|
195
|
+
return [`${a} { ${c}: ${i}; }`];
|
|
196
|
+
}
|
|
197
|
+
const r = new C({ selector: a, ...s }), o = { [e]: t };
|
|
198
|
+
return r.generateResponsiveCSS(o).cssRules;
|
|
199
|
+
}
|
|
200
|
+
function w(a, e, t) {
|
|
201
|
+
const { generateMinified: s = !1 } = t || {}, r = s ? "" : " ", o = s ? "" : `
|
|
202
|
+
`, n = s ? "" : " ";
|
|
203
|
+
let c = `@media ${e.query}${n}{${o}`;
|
|
204
|
+
c += `${r}${a}${n}{${o}`;
|
|
205
|
+
for (const [i, u] of Object.entries(e.styles)) {
|
|
206
|
+
const l = i.replace(/[A-Z]/g, (p) => `-${p.toLowerCase()}`), d = typeof u == "number" ? `${u}px` : u.toString();
|
|
207
|
+
c += `${r}${r}${l}:${n}${d};${o}`;
|
|
208
|
+
}
|
|
209
|
+
return c += `${r}}${o}`, c += `}${o}`, c;
|
|
210
|
+
}
|
|
211
|
+
class S {
|
|
212
|
+
/**
|
|
213
|
+
* Get or create the tachUI responsive stylesheet
|
|
214
|
+
*/
|
|
215
|
+
static getStyleSheet() {
|
|
216
|
+
if (this.styleSheet)
|
|
217
|
+
return this.styleSheet;
|
|
218
|
+
const e = document.createElement("style");
|
|
219
|
+
return e.setAttribute("data-tachui-responsive", "true"), document.head.appendChild(e), this.styleSheet = e.sheet, this.styleSheet;
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Inject CSS rules into the document
|
|
223
|
+
*/
|
|
224
|
+
static injectCSS(e) {
|
|
225
|
+
if (typeof document > "u")
|
|
226
|
+
return;
|
|
227
|
+
const t = this.getStyleSheet();
|
|
228
|
+
for (const s of e)
|
|
229
|
+
if (!this.injectedRules.has(s))
|
|
230
|
+
try {
|
|
231
|
+
t.insertRule(s, t.cssRules.length), this.injectedRules.add(s);
|
|
232
|
+
} catch (r) {
|
|
233
|
+
console.warn("Failed to inject CSS rule:", s, r);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Clear all injected responsive CSS
|
|
238
|
+
*/
|
|
239
|
+
static clearCSS() {
|
|
240
|
+
if (this.styleSheet) {
|
|
241
|
+
for (; this.styleSheet.cssRules.length > 0; )
|
|
242
|
+
this.styleSheet.deleteRule(0);
|
|
243
|
+
this.injectedRules.clear();
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Check if a rule has been injected
|
|
248
|
+
*/
|
|
249
|
+
static hasRule(e) {
|
|
250
|
+
return this.injectedRules.has(e);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
f(S, "styleSheet", null);
|
|
254
|
+
f(S, "injectedRules", /* @__PURE__ */ new Set());
|
|
255
|
+
export {
|
|
256
|
+
S as CSSInjector,
|
|
257
|
+
C as ResponsiveCSSGenerator,
|
|
258
|
+
w as generateCustomMediaQuery,
|
|
259
|
+
j as generateResponsiveProperty
|
|
260
|
+
};
|
|
261
|
+
//# sourceMappingURL=css-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css-generator.js","sources":["../../../src/modifiers/responsive/css-generator.ts"],"sourcesContent":["/**\n * Responsive CSS Generation Engine\n * \n * Generates optimized CSS media queries from responsive modifier configurations.\n * Supports mobile-first design patterns and advanced media query features.\n */\n\nimport {\n BreakpointKey,\n ResponsiveValue,\n ResponsiveStyleConfig,\n MediaQueryConfig,\n GeneratedMediaQuery,\n ResponsiveModifierResult,\n isResponsiveValue\n} from './types'\nimport {\n generateMediaQuery,\n getCurrentBreakpointConfig,\n getSortedBreakpoints\n} from './breakpoints'\n\n/**\n * CSS generation options\n */\nexport interface CSSGenerationOptions {\n selector: string // CSS selector for the element\n generateMinified?: boolean // Generate minified CSS\n includeComments?: boolean // Include helpful comments\n optimizeOutput?: boolean // Optimize and deduplicate CSS\n mobileFirst?: boolean // Use mobile-first approach (default: true)\n}\n\n/**\n * Main CSS generation class\n */\nexport class ResponsiveCSSGenerator {\n private options: Required<CSSGenerationOptions>\n \n constructor(options: CSSGenerationOptions) {\n this.options = {\n generateMinified: false,\n includeComments: true,\n optimizeOutput: true,\n mobileFirst: true,\n ...options\n }\n }\n \n /**\n * Generate complete responsive CSS from a style configuration\n */\n generateResponsiveCSS(config: ResponsiveStyleConfig): ResponsiveModifierResult {\n const mediaQueries: GeneratedMediaQuery[] = []\n const cssRules: string[] = []\n const fallbackStyles: Record<string, string | number> = {}\n let hasResponsiveStyles = false\n \n // Process each property in the configuration\n for (const [property, value] of Object.entries(config)) {\n if (isResponsiveValue(value)) {\n hasResponsiveStyles = true\n const result = this.generatePropertyMediaQueries(property, value)\n mediaQueries.push(...result.mediaQueries)\n \n // Add base styles to fallback\n if (result.baseStyles) {\n Object.assign(fallbackStyles, result.baseStyles)\n }\n } else {\n // Non-responsive property - add to fallback styles\n fallbackStyles[this.toCSSPropertyName(property)] = this.formatCSSValue(property, value)\n }\n }\n \n // Generate CSS rules from media queries\n cssRules.push(...this.generateCSSRules(mediaQueries, fallbackStyles))\n \n return {\n cssRules,\n mediaQueries,\n fallbackStyles,\n hasResponsiveStyles\n }\n }\n \n /**\n * Generate media queries for a single property\n */\n private generatePropertyMediaQueries(\n property: string, \n value: Partial<Record<BreakpointKey, any>>\n ): { mediaQueries: GeneratedMediaQuery[]; baseStyles?: Record<string, string | number> } {\n const mediaQueries: GeneratedMediaQuery[] = []\n const baseStyles: Record<string, string | number> = {}\n const sortedBreakpoints = getSortedBreakpoints()\n \n for (const breakpoint of sortedBreakpoints) {\n const breakpointValue = value[breakpoint]\n if (breakpointValue === undefined) continue\n \n const cssProperty = this.toCSSPropertyName(property)\n const cssValue = this.formatCSSValue(property, breakpointValue)\n \n if (breakpoint === 'base') {\n // Base styles (no media query needed for mobile-first)\n baseStyles[cssProperty] = cssValue\n } else {\n // Generate media query for this breakpoint\n const query = generateMediaQuery(breakpoint)\n const styles = { [cssProperty]: cssValue }\n \n mediaQueries.push({\n breakpoint,\n query,\n styles,\n selector: this.options.selector\n })\n }\n }\n \n return { mediaQueries, baseStyles: Object.keys(baseStyles).length > 0 ? baseStyles : undefined }\n }\n \n /**\n * Generate CSS rules from media queries and base styles\n */\n private generateCSSRules(\n mediaQueries: GeneratedMediaQuery[], \n baseStyles: Record<string, string | number>\n ): string[] {\n const rules: string[] = []\n \n // Generate base styles rule (mobile-first)\n if (Object.keys(baseStyles).length > 0) {\n const baseRule = this.generateCSSRule(this.options.selector, baseStyles)\n rules.push(baseRule)\n }\n \n // Generate media query rules\n const groupedQueries = this.groupQueriesByMediaQuery(mediaQueries)\n \n for (const [query, queryMediaQueries] of Object.entries(groupedQueries)) {\n if (query === '') continue // Skip empty queries (base styles)\n \n // Combine all styles for this media query\n const combinedStyles: Record<string, string | number> = {}\n for (const mq of queryMediaQueries) {\n Object.assign(combinedStyles, mq.styles)\n }\n \n const mediaRule = this.generateMediaQueryRule(query, this.options.selector, combinedStyles)\n rules.push(mediaRule)\n }\n \n return rules\n }\n \n /**\n * Group media queries by their query string for optimization\n */\n private groupQueriesByMediaQuery(mediaQueries: GeneratedMediaQuery[]): Record<string, GeneratedMediaQuery[]> {\n const grouped: Record<string, GeneratedMediaQuery[]> = {}\n \n for (const mq of mediaQueries) {\n if (!grouped[mq.query]) {\n grouped[mq.query] = []\n }\n grouped[mq.query].push(mq)\n }\n \n return grouped\n }\n \n /**\n * Generate a single CSS rule\n */\n private generateCSSRule(selector: string, styles: Record<string, string | number>): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${indent}${property}:${space}${value};${newline}`\n }\n \n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n rule = `/* Base styles (mobile-first) */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Generate a CSS media query rule\n */\n private generateMediaQueryRule(\n query: string, \n selector: string, \n styles: Record<string, string | number>\n ): string {\n const { generateMinified, includeComments } = this.options\n const indent = generateMinified ? '' : ' '\n const doubleIndent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(styles)) {\n rule += `${doubleIndent}${property}:${space}${value};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n if (includeComments && !generateMinified) {\n const breakpoint = this.getBreakpointFromQuery(query)\n rule = `/* ${breakpoint} styles */${newline}${rule}`\n }\n \n return rule\n }\n \n /**\n * Convert camelCase property to CSS kebab-case\n */\n private toCSSProperty(property: string): string {\n return property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n }\n \n /**\n * Format CSS value with appropriate units and validation\n */\n private formatCSSValue(property: string, value: any): string {\n if (value === null || value === undefined) {\n return 'inherit'\n }\n \n // Handle numeric values that need units\n if (typeof value === 'number') {\n const unitlessProperties = [\n 'opacity', 'z-index', 'font-weight', 'line-height', \n 'flex-grow', 'flex-shrink', 'order', 'grid-column-start',\n 'grid-column-end', 'grid-row-start', 'grid-row-end'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (unitlessProperties.includes(cssProperty)) {\n return this.addImportantIfNeeded(property, value.toString())\n }\n \n // Add px unit for dimension properties\n const dimensionProperties = [\n 'width', 'height', 'min-width', 'max-width', 'min-height', 'max-height',\n 'padding', 'margin', 'border-width', 'border-radius', 'top', 'right', \n 'bottom', 'left', 'font-size', 'letter-spacing', 'text-indent'\n ]\n \n if (dimensionProperties.some(prop => cssProperty.includes(prop))) {\n return this.addImportantIfNeeded(property, `${value}px`)\n }\n }\n \n return this.addImportantIfNeeded(property, value.toString())\n }\n\n /**\n * Add !important for properties that need to override base component styles\n */\n private addImportantIfNeeded(property: string, value: string): string {\n const conflictingProperties = [\n 'flexDirection', 'flex-direction',\n 'justifyContent', 'justify-content', \n 'alignItems', 'align-items',\n 'display'\n ]\n \n const cssProperty = this.toCSSProperty(property)\n if (conflictingProperties.includes(property) || conflictingProperties.includes(cssProperty)) {\n return `${value} !important`\n }\n \n return value\n }\n\n /**\n * Convert property name to appropriate CSS property (including custom properties)\n */\n private toCSSPropertyName(property: string): string {\n return this.toCSSProperty(property)\n }\n \n /**\n * Extract breakpoint name from media query for comments\n */\n private getBreakpointFromQuery(query: string): string {\n const breakpointConfig = getCurrentBreakpointConfig()\n \n for (const [breakpoint, value] of Object.entries(breakpointConfig)) {\n if (query.includes(value)) {\n return breakpoint\n }\n }\n \n return 'custom'\n }\n}\n\n/**\n * Utility function to generate responsive CSS for a single property\n */\nexport function generateResponsiveProperty(\n selector: string,\n property: string,\n value: ResponsiveValue<any>,\n options?: Partial<CSSGenerationOptions>\n): string[] {\n if (!isResponsiveValue(value)) {\n // Non-responsive value - return simple CSS rule\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n return [`${selector} { ${cssProperty}: ${cssValue}; }`]\n }\n \n const generator = new ResponsiveCSSGenerator({ selector, ...options })\n const config = { [property]: value }\n const result = generator.generateResponsiveCSS(config)\n \n return result.cssRules\n}\n\n/**\n * Utility function to generate media query for custom conditions\n */\nexport function generateCustomMediaQuery(\n selector: string,\n mediaQueryConfig: MediaQueryConfig,\n options?: Partial<CSSGenerationOptions>\n): string {\n const { generateMinified = false } = options || {}\n const indent = generateMinified ? '' : ' '\n const newline = generateMinified ? '' : '\\n'\n const space = generateMinified ? '' : ' '\n \n let rule = `@media ${mediaQueryConfig.query}${space}{${newline}`\n rule += `${indent}${selector}${space}{${newline}`\n \n for (const [property, value] of Object.entries(mediaQueryConfig.styles)) {\n const cssProperty = property.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)\n const cssValue = typeof value === 'number' ? `${value}px` : value.toString()\n rule += `${indent}${indent}${cssProperty}:${space}${cssValue};${newline}`\n }\n \n rule += `${indent}}${newline}`\n rule += `}${newline}`\n \n return rule\n}\n\n/**\n * CSS injection utilities for runtime application\n */\nexport class CSSInjector {\n private static styleSheet: CSSStyleSheet | null = null\n private static injectedRules = new Set<string>()\n \n /**\n * Get or create the tachUI responsive stylesheet\n */\n private static getStyleSheet(): CSSStyleSheet {\n if (this.styleSheet) {\n return this.styleSheet\n }\n \n const style = document.createElement('style')\n style.setAttribute('data-tachui-responsive', 'true')\n document.head.appendChild(style)\n \n this.styleSheet = style.sheet as CSSStyleSheet\n return this.styleSheet\n }\n\n /**\n * Inject CSS rules into the document\n */\n static injectCSS(rules: string[]): void {\n if (typeof document === 'undefined') {\n return // Skip on server-side\n }\n \n const styleSheet = this.getStyleSheet()\n \n for (const rule of rules) {\n if (this.injectedRules.has(rule)) {\n continue // Skip duplicate rules\n }\n \n try {\n styleSheet.insertRule(rule, styleSheet.cssRules.length)\n this.injectedRules.add(rule)\n } catch (error) {\n console.warn('Failed to inject CSS rule:', rule, error)\n }\n }\n }\n \n /**\n * Clear all injected responsive CSS\n */\n static clearCSS(): void {\n if (this.styleSheet) {\n while (this.styleSheet.cssRules.length > 0) {\n this.styleSheet.deleteRule(0)\n }\n this.injectedRules.clear()\n }\n }\n \n /**\n * Check if a rule has been injected\n */\n static hasRule(rule: string): boolean {\n return this.injectedRules.has(rule)\n }\n}"],"names":["ResponsiveCSSGenerator","options","__publicField","config","mediaQueries","cssRules","fallbackStyles","hasResponsiveStyles","property","value","isResponsiveValue","result","baseStyles","sortedBreakpoints","getSortedBreakpoints","breakpoint","breakpointValue","cssProperty","cssValue","query","generateMediaQuery","styles","rules","baseRule","groupedQueries","queryMediaQueries","combinedStyles","mq","mediaRule","grouped","selector","generateMinified","includeComments","indent","newline","space","rule","doubleIndent","match","unitlessProperties","prop","conflictingProperties","breakpointConfig","getCurrentBreakpointConfig","generateResponsiveProperty","generator","generateCustomMediaQuery","mediaQueryConfig","CSSInjector","style","styleSheet","error"],"mappings":"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"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../../reactive/cleanup.cjs");const x=require("../../reactive/computed.cjs");require("../../reactive/unified-scheduler.cjs");require("../../reactive/signal.cjs");require("../../reactive/scheduler.cjs");require("../../reactive/theme.cjs");const v=require("./types.cjs"),p=require("./breakpoints.cjs"),h=require("./performance.cjs"),d=require("./utilities.cjs");var w=Object.defineProperty,S=(c,e,t)=>e in c?w(c,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):c[e]=t,f=(c,e,t)=>S(c,typeof e!="symbol"?e+"":e,t);class u{static enable(e={}){if(process.env.NODE_ENV==="production"){console.warn("ResponsiveDevTools: Not enabling in production mode");return}this.isEnabled=!0,this.logLevel=e.logLevel||"info",this.log("info","ResponsiveDevTools: Enabled"),e.showOverlay&&this.createDebugOverlay(e),e.highlightResponsiveElements&&this.enableElementHighlighting(),e.showPerformance&&this.enablePerformanceMonitoring(),this.logResponsiveState()}static disable(){this.isEnabled=!1,this.debugOverlay&&(this.debugOverlay.remove(),this.debugOverlay=null),this.disableElementHighlighting(),this.log("info","ResponsiveDevTools: Disabled")}static get enabled(){return this.isEnabled&&process.env.NODE_ENV!=="production"}static log(e,...t){if(!this.enabled)return;const i=["error","warn","info","debug"],o=i.indexOf(this.logLevel);i.indexOf(e)<=o&&console[e]("[ResponsiveDevTools]",...t)}static createDebugOverlay(e){if(typeof document>"u")return;const t=e.position||"top-right";this.debugOverlay=document.createElement("div"),this.debugOverlay.id="tachui-responsive-debug",this.debugOverlay.style.cssText=`
|
|
2
|
+
position: fixed;
|
|
3
|
+
${t.includes("top")?"top: 10px":"bottom: 10px"};
|
|
4
|
+
${t.includes("right")?"right: 10px":"left: 10px"};
|
|
5
|
+
background: rgba(0, 0, 0, 0.9);
|
|
6
|
+
color: white;
|
|
7
|
+
padding: 12px;
|
|
8
|
+
border-radius: 8px;
|
|
9
|
+
font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
|
|
10
|
+
font-size: 12px;
|
|
11
|
+
z-index: 10000;
|
|
12
|
+
pointer-events: auto;
|
|
13
|
+
cursor: pointer;
|
|
14
|
+
max-width: 300px;
|
|
15
|
+
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
|
|
16
|
+
border: 1px solid rgba(255, 255, 255, 0.1);
|
|
17
|
+
`;const i=document.createElement("div");i.textContent="×",i.style.cssText=`
|
|
18
|
+
position: absolute;
|
|
19
|
+
top: 4px;
|
|
20
|
+
right: 8px;
|
|
21
|
+
cursor: pointer;
|
|
22
|
+
font-size: 16px;
|
|
23
|
+
color: #ff6b6b;
|
|
24
|
+
`,i.onclick=()=>this.disable(),this.debugOverlay.appendChild(i),document.body.appendChild(this.debugOverlay),this.updateDebugOverlay(e);let o;window.addEventListener("resize",()=>{clearTimeout(o),o=window.setTimeout(()=>{this.updateDebugOverlay(e)},100)})}static updateDebugOverlay(e){if(!this.debugOverlay)return;const t=p.createBreakpointContext(),i=p.getCurrentBreakpointConfig();let o=`
|
|
25
|
+
<div style="margin-bottom: 8px; font-weight: bold; color: #4fc3f7;">
|
|
26
|
+
📱 Responsive Debug
|
|
27
|
+
</div>
|
|
28
|
+
`;if(o+=`
|
|
29
|
+
<div style="margin-bottom: 6px;">
|
|
30
|
+
<strong>Current:</strong> <span style="color: #66bb6a;">${t.current}</span>
|
|
31
|
+
</div>
|
|
32
|
+
<div style="margin-bottom: 6px;">
|
|
33
|
+
<strong>Size:</strong> ${t.width}×${t.height}
|
|
34
|
+
</div>
|
|
35
|
+
`,e.showBreakpoints){o+='<div style="margin: 8px 0; font-weight: bold; color: #ffb74d;">Breakpoints:</div>';for(const[s,a]of Object.entries(i)){const n=s===t.current;o+=`
|
|
36
|
+
<div style="color: ${n?"#66bb6a":"#999"}; margin-bottom: 2px;">
|
|
37
|
+
${n?"▶":"▷"} ${s}: ${a}
|
|
38
|
+
</div>
|
|
39
|
+
`}}if(e.showPerformance){const s=h.ResponsivePerformanceMonitor.getStats(),a=h.cssRuleCache.getStats();if(o+='<div style="margin: 8px 0; font-weight: bold; color: #f06292;">Performance:</div>',o+=`
|
|
40
|
+
<div style="margin-bottom: 2px;">
|
|
41
|
+
Cache: ${a.size} rules (${(a.hitRate*100).toFixed(1)}% hit rate)
|
|
42
|
+
</div>
|
|
43
|
+
`,Object.keys(s).length>0)for(const[n,l]of Object.entries(s))o+=`
|
|
44
|
+
<div style="margin-bottom: 2px;">
|
|
45
|
+
${n}: ${l.average.toFixed(2)}ms avg
|
|
46
|
+
</div>
|
|
47
|
+
`}o+='<div style="margin: 8px 0; font-weight: bold; color: #ba68c8;">Media Queries:</div>';const r={Touch:d.MediaQueries.touchDevice,Dark:d.MediaQueries.darkMode,"Reduced Motion":d.MediaQueries.reducedMotion,"High Contrast":d.MediaQueries.highContrast};for(const[s,a]of Object.entries(r)){const n=window.matchMedia(a).matches;o+=`
|
|
48
|
+
<div style="color: ${n?"#66bb6a":"#666"}; margin-bottom: 2px;">
|
|
49
|
+
${n?"✓":"✗"} ${s}
|
|
50
|
+
</div>
|
|
51
|
+
`}this.debugOverlay.innerHTML=o+this.debugOverlay.querySelector("div:last-child")?.outerHTML||""}static enableElementHighlighting(){if(typeof document>"u")return;const e=document.createElement("style");e.id="tachui-responsive-highlight",e.textContent=`
|
|
52
|
+
.tachui-responsive-element {
|
|
53
|
+
outline: 2px dashed #4fc3f7 !important;
|
|
54
|
+
outline-offset: 2px !important;
|
|
55
|
+
position: relative !important;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.tachui-responsive-element::before {
|
|
59
|
+
content: 'R';
|
|
60
|
+
position: absolute !important;
|
|
61
|
+
top: -8px !important;
|
|
62
|
+
right: -8px !important;
|
|
63
|
+
background: #4fc3f7 !important;
|
|
64
|
+
color: white !important;
|
|
65
|
+
width: 16px !important;
|
|
66
|
+
height: 16px !important;
|
|
67
|
+
border-radius: 50% !important;
|
|
68
|
+
font-size: 10px !important;
|
|
69
|
+
font-weight: bold !important;
|
|
70
|
+
display: flex !important;
|
|
71
|
+
align-items: center !important;
|
|
72
|
+
justify-content: center !important;
|
|
73
|
+
z-index: 10001 !important;
|
|
74
|
+
font-family: monospace !important;
|
|
75
|
+
}
|
|
76
|
+
`,document.head.appendChild(e),new MutationObserver(()=>{this.highlightResponsiveElements()}).observe(document.body,{childList:!0,subtree:!0,attributes:!0,attributeFilter:["class"]}),this.highlightResponsiveElements()}static disableElementHighlighting(){if(typeof document>"u")return;const e=document.getElementById("tachui-responsive-highlight");e&&e.remove(),document.querySelectorAll(".tachui-responsive-element").forEach(t=>{t.classList.remove("tachui-responsive-element")})}static highlightResponsiveElements(){if(typeof document>"u")return;['[class*="tachui-responsive-"]','[class*="tachui-mq-"]'].forEach(t=>{document.querySelectorAll(t).forEach(i=>{i.classList.contains("tachui-responsive-element")||i.classList.add("tachui-responsive-element")})})}static enablePerformanceMonitoring(){setInterval(()=>{if(!this.enabled)return;const e=h.ResponsivePerformanceMonitor.getStats(),t=h.cssRuleCache.getStats();this.log("debug","Performance Stats:",{cache:t,performance:e})},5e3)}static logResponsiveState(){if(!this.enabled)return;const e=p.createBreakpointContext(),t=p.getCurrentBreakpointConfig();if(console.group("🔍 TachUI Responsive State"),console.log("Current breakpoint:",e.current),console.log("Viewport:",`${e.width}×${e.height}`),console.log("Configuration:",t),typeof window<"u"&&window.matchMedia){const i={Mobile:d.MediaQueries.mobile,Tablet:d.MediaQueries.tablet,Desktop:d.MediaQueries.desktop,"Touch Device":d.MediaQueries.touchDevice,"Dark Mode":d.MediaQueries.darkMode,"Reduced Motion":d.MediaQueries.reducedMotion};console.log("Media Query Results:");for(const[o,r]of Object.entries(i))try{console.log(` ${o}: ${window.matchMedia(r).matches}`)}catch{console.log(` ${o}: Error testing query`)}}console.groupEnd()}static inspectResponsiveValue(e,t){if(!this.enabled)return;const i=p.getCurrentBreakpoint();if(console.group(`🔍 Responsive Value${t?` - ${t}`:""}`),v.isResponsiveValue(e)){const o=e;console.log("Responsive object:",o);const r=["base","sm","md","lg","xl","2xl"],s=r.indexOf(i());let a;for(let n=s;n>=0;n--){const l=r[n];if(o[l]!==void 0){a=o[l],console.log(`Resolved value (${l}):`,a);break}}console.log("Defined breakpoints:");for(const[n,l]of Object.entries(o))if(l!==void 0){const g=n===i();console.log(` ${g?"→":" "} ${n}:`,l)}}else console.log("Static value:",e);console.groupEnd()}static testResponsiveBehavior(e,t=["base","sm","md","lg","xl","2xl"]){if(!this.enabled)return{};const i={};return t.forEach(o=>{this.log("debug",`Testing breakpoint ${o}:`,e)}),i}static exportConfiguration(){const e=p.createBreakpointContext(),t=p.getCurrentBreakpointConfig(),i=h.ResponsivePerformanceMonitor.getStats(),o=h.cssRuleCache.getStats(),r={};if(typeof window<"u"&&window.matchMedia){for(const[s,a]of Object.entries(d.MediaQueries))if(typeof a=="string")try{r[s]=window.matchMedia(a).matches}catch{r[s]=!1}}return{breakpoints:t,currentContext:e,performance:{cache:o,timings:i},mediaQueries:r}}}f(u,"isEnabled",!1);f(u,"debugOverlay",null);f(u,"logLevel","info");function b(c,e){const t=p.getCurrentBreakpoint();return x.createComputed(()=>{const i=t(),o=v.isResponsiveValue(c);let r,s={};if(o){const a=c;s=a;const n=["base","sm","md","lg","xl","2xl"],l=n.indexOf(i);for(let g=l;g>=0;g--){const m=n[g];if(a[m]!==void 0){r=a[m];break}}}else r=c,s={[i]:r};return u.enabled&&e&&u.inspectResponsiveValue(c,e),{resolvedValue:r,activeBreakpoint:i,allValues:s,isResponsive:o}})}class y{static testCSSFeatures(){if(typeof window>"u"||typeof CSS>"u"||!CSS.supports)return{};const e={};try{e.cssGrid=CSS.supports("display","grid"),e.flexbox=CSS.supports("display","flex"),e.customProperties=CSS.supports("--test","value"),e.viewportUnits=CSS.supports("width","100vw"),e.mediaQueries=typeof window.matchMedia=="function",e.containerQueries=CSS.supports("container-type","inline-size"),e.logicalProperties=CSS.supports("margin-inline-start","1rem")}catch{}return e}static testViewportSizes(e){if(typeof window>"u")return;const t=[{width:320,height:568,name:"iPhone SE"},{width:375,height:667,name:"iPhone 8"},{width:768,height:1024,name:"iPad Portrait"},{width:1024,height:768,name:"iPad Landscape"},{width:1280,height:720,name:"Desktop Small"},{width:1920,height:1080,name:"Desktop Large"}];u.enabled&&u.log("info","Testing viewport sizes:",t),t.forEach(i=>{e(i.width,i.height)})}}typeof window<"u"&&process.env.NODE_ENV!=="production"&&(window.tachUIResponsive={devTools:u,inspector:b,compatibility:y,logState:()=>u.logResponsiveState(),export:()=>u.exportConfiguration()});exports.BrowserCompatibility=y;exports.ResponsiveDevTools=u;exports.useResponsiveInspector=b;
|
|
77
|
+
//# sourceMappingURL=dev-tools.cjs.map
|