@tachui/core 0.7.0-alpha1 → 0.8.0-alpha
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/README.md +195 -0
- package/dist/bundles/common.d.ts +1 -1
- package/dist/bundles/common.d.ts.map +1 -1
- package/dist/bundles/minimal.d.ts +17 -5
- package/dist/bundles/minimal.d.ts.map +1 -1
- package/dist/bundles/production-minimal.d.ts +2 -16
- package/dist/bundles/production-minimal.d.ts.map +1 -1
- package/dist/common.js +402 -955
- package/dist/compiler/advanced-parser.d.ts.map +1 -1
- package/dist/compiler/index.js +1392 -10
- package/dist/component-XAzF1xqs.js +487 -0
- package/dist/component-base-x2XmHFjy.js +255 -0
- package/dist/components/index.d.ts +4 -38
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +7 -102
- package/dist/components/wrapper.d.ts +5 -152
- package/dist/components/wrapper.d.ts.map +1 -1
- package/dist/concatenated-component-ByPl3_FF.js +2933 -0
- package/dist/constants/index.d.ts +1 -1
- package/dist/constants/layout.d.ts +47 -4
- package/dist/constants/layout.d.ts.map +1 -1
- package/dist/constants/layout.js +52 -14
- package/dist/css-classes/index.js +176 -0
- package/dist/dom-bridge-CAa1N2zX.js +406 -0
- package/dist/effect-B9Knft0b.js +66 -0
- package/dist/essential.js +394 -953
- package/dist/index-DCPJFUm9.js +1407 -0
- package/dist/index-DIvMCJQO.js +268 -0
- package/dist/index-vdsiw6gQ.js +777 -0
- package/dist/index.d.ts +9 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +394 -953
- package/dist/minimal-prod.js +107 -190
- package/dist/minimal.js +115 -955
- package/dist/modifiers/background.d.ts +41 -11
- package/dist/modifiers/background.d.ts.map +1 -1
- package/dist/modifiers/base.d.ts +6 -33
- package/dist/modifiers/base.d.ts.map +1 -1
- package/dist/modifiers/base.js +275 -533
- package/dist/modifiers/builder.d.ts +103 -195
- package/dist/modifiers/builder.d.ts.map +1 -1
- package/dist/modifiers/builder.js +7 -928
- package/dist/modifiers/core.d.ts +9 -401
- package/dist/modifiers/core.d.ts.map +1 -1
- package/dist/modifiers/{utils.d.ts → factories.d.ts} +18 -5
- package/dist/modifiers/factories.d.ts.map +1 -0
- package/dist/modifiers/index.d.ts +8 -52
- package/dist/modifiers/index.d.ts.map +1 -1
- package/dist/modifiers/index.js +38 -0
- package/dist/modifiers/presets.d.ts +368 -0
- package/dist/modifiers/presets.d.ts.map +1 -0
- package/dist/modifiers/registry.js +8 -161
- package/dist/modifiers/types.d.ts +39 -211
- package/dist/modifiers/types.d.ts.map +1 -1
- package/dist/modifiers/types.js +0 -1
- package/dist/performance-optimizer-stub-CtfXUwl4.js +38 -0
- package/dist/plugins/index.d.ts +5 -6
- package/dist/plugins/index.d.ts.map +1 -1
- package/dist/plugins/index.js +393 -32
- package/dist/plugins/simplified-index.d.ts +5 -6
- package/dist/plugins/simplified-index.d.ts.map +1 -1
- package/dist/production-minimal-BY_gMc-l.js +2532 -0
- package/dist/reactive/index.js +489 -91
- package/dist/reactive/types.js +0 -1
- package/dist/runtime/dom-bridge.js +12 -239
- package/dist/runtime/element-override.d.ts.map +1 -1
- package/dist/runtime/index.d.ts +0 -7
- package/dist/runtime/index.d.ts.map +1 -1
- package/dist/runtime/renderer.d.ts.map +1 -1
- package/dist/runtime/renderer.js +7 -388
- package/dist/runtime/semantic-role-manager.d.ts.map +1 -1
- package/dist/runtime/types.js +1 -0
- package/dist/scheduler-BKeqwrYE.js +814 -0
- package/dist/validation/build-time-stub.d.ts +33 -0
- package/dist/validation/build-time-stub.d.ts.map +1 -0
- package/dist/validation/debug-tools-stub.d.ts +67 -0
- package/dist/validation/debug-tools-stub.d.ts.map +1 -0
- package/dist/validation/index.d.ts +23 -78
- package/dist/validation/index.d.ts.map +1 -1
- package/dist/validation/index.js +788 -233
- package/dist/validation/lifecycle-validation.d.ts.map +1 -1
- package/dist/validation/performance-optimizer-stub.d.ts +50 -0
- package/dist/validation/performance-optimizer-stub.d.ts.map +1 -0
- package/dist/validation/plugin-registration.d.ts +5 -1
- package/dist/validation/plugin-registration.d.ts.map +1 -1
- package/dist/validation/production-bypass-core.d.ts +69 -0
- package/dist/validation/production-bypass-core.d.ts.map +1 -0
- package/package.json +43 -8
- package/dist/assets/Asset.cjs +0 -2
- package/dist/assets/Asset.cjs.map +0 -1
- package/dist/assets/Asset.js +0 -9
- package/dist/assets/Asset.js.map +0 -1
- package/dist/assets/AssetCollection.cjs +0 -2
- package/dist/assets/AssetCollection.cjs.map +0 -1
- package/dist/assets/AssetCollection.js +0 -44
- package/dist/assets/AssetCollection.js.map +0 -1
- package/dist/assets/ColorAsset.cjs +0 -2
- package/dist/assets/ColorAsset.cjs.map +0 -1
- package/dist/assets/ColorAsset.js +0 -114
- package/dist/assets/ColorAsset.js.map +0 -1
- package/dist/assets/FontAsset.cjs +0 -9
- package/dist/assets/FontAsset.cjs.map +0 -1
- package/dist/assets/FontAsset.js +0 -173
- package/dist/assets/FontAsset.js.map +0 -1
- package/dist/assets/ImageAsset.cjs +0 -2
- package/dist/assets/ImageAsset.cjs.map +0 -1
- package/dist/assets/ImageAsset.js +0 -39
- package/dist/assets/ImageAsset.js.map +0 -1
- package/dist/assets/index.cjs +0 -2
- package/dist/assets/index.cjs.map +0 -1
- package/dist/assets/index.js +0 -119
- package/dist/assets/index.js.map +0 -1
- package/dist/common.cjs +0 -2
- package/dist/common.cjs.map +0 -1
- package/dist/common.js.map +0 -1
- package/dist/compiler/advanced-parser.cjs +0 -5
- package/dist/compiler/advanced-parser.cjs.map +0 -1
- package/dist/compiler/advanced-parser.js +0 -440
- package/dist/compiler/advanced-parser.js.map +0 -1
- package/dist/compiler/codegen.cjs +0 -6
- package/dist/compiler/codegen.cjs.map +0 -1
- package/dist/compiler/codegen.js +0 -241
- package/dist/compiler/codegen.js.map +0 -1
- package/dist/compiler/enhanced-codegen.cjs +0 -6
- package/dist/compiler/enhanced-codegen.cjs.map +0 -1
- package/dist/compiler/enhanced-codegen.js +0 -347
- package/dist/compiler/enhanced-codegen.js.map +0 -1
- package/dist/compiler/index.cjs +0 -2
- package/dist/compiler/index.cjs.map +0 -1
- package/dist/compiler/index.js.map +0 -1
- package/dist/compiler/parser.cjs +0 -5
- package/dist/compiler/parser.cjs.map +0 -1
- package/dist/compiler/parser.js +0 -275
- package/dist/compiler/parser.js.map +0 -1
- package/dist/compiler/plugin.cjs +0 -33
- package/dist/compiler/plugin.cjs.map +0 -1
- package/dist/compiler/plugin.js +0 -103
- package/dist/compiler/plugin.js.map +0 -1
- package/dist/components/BasicInput.cjs +0 -2
- package/dist/components/BasicInput.cjs.map +0 -1
- package/dist/components/BasicInput.d.ts +0 -116
- package/dist/components/BasicInput.d.ts.map +0 -1
- package/dist/components/BasicInput.js +0 -182
- package/dist/components/BasicInput.js.map +0 -1
- package/dist/components/Button.cjs +0 -7
- package/dist/components/Button.cjs.map +0 -1
- package/dist/components/Button.d.ts +0 -252
- package/dist/components/Button.d.ts.map +0 -1
- package/dist/components/Button.js +0 -408
- package/dist/components/Button.js.map +0 -1
- package/dist/components/Divider.cjs +0 -2
- package/dist/components/Divider.cjs.map +0 -1
- package/dist/components/Divider.d.ts +0 -141
- package/dist/components/Divider.d.ts.map +0 -1
- package/dist/components/Divider.js +0 -187
- package/dist/components/Divider.js.map +0 -1
- package/dist/components/EnhancedLink.cjs +0 -2
- package/dist/components/EnhancedLink.cjs.map +0 -1
- package/dist/components/EnhancedLink.d.ts +0 -365
- package/dist/components/EnhancedLink.d.ts.map +0 -1
- package/dist/components/EnhancedLink.js +0 -345
- package/dist/components/EnhancedLink.js.map +0 -1
- package/dist/components/Form.cjs +0 -2
- package/dist/components/Form.cjs.map +0 -1
- package/dist/components/Form.d.ts +0 -141
- package/dist/components/Form.d.ts.map +0 -1
- package/dist/components/Form.js +0 -244
- package/dist/components/Form.js.map +0 -1
- package/dist/components/Grid.cjs +0 -2
- package/dist/components/Grid.cjs.map +0 -1
- package/dist/components/Grid.d.ts +0 -698
- package/dist/components/Grid.d.ts.map +0 -1
- package/dist/components/Grid.js +0 -1045
- package/dist/components/Grid.js.map +0 -1
- package/dist/components/GridResponsive.cjs +0 -2
- package/dist/components/GridResponsive.cjs.map +0 -1
- package/dist/components/GridResponsive.d.ts +0 -214
- package/dist/components/GridResponsive.d.ts.map +0 -1
- package/dist/components/GridResponsive.js +0 -382
- package/dist/components/GridResponsive.js.map +0 -1
- package/dist/components/Image.cjs +0 -2
- package/dist/components/Image.cjs.map +0 -1
- package/dist/components/Image.d.ts +0 -162
- package/dist/components/Image.d.ts.map +0 -1
- package/dist/components/Image.js +0 -212
- package/dist/components/Image.js.map +0 -1
- package/dist/components/List.cjs +0 -2
- package/dist/components/List.cjs.map +0 -1
- package/dist/components/List.d.ts +0 -287
- package/dist/components/List.d.ts.map +0 -1
- package/dist/components/List.js +0 -561
- package/dist/components/List.js.map +0 -1
- package/dist/components/Menu.cjs +0 -2
- package/dist/components/Menu.cjs.map +0 -1
- package/dist/components/Menu.d.ts +0 -159
- package/dist/components/Menu.d.ts.map +0 -1
- package/dist/components/Menu.js +0 -443
- package/dist/components/Menu.js.map +0 -1
- package/dist/components/Picker.cjs +0 -2
- package/dist/components/Picker.cjs.map +0 -1
- package/dist/components/Picker.d.ts +0 -153
- package/dist/components/Picker.d.ts.map +0 -1
- package/dist/components/Picker.js +0 -478
- package/dist/components/Picker.js.map +0 -1
- package/dist/components/ScrollView.cjs +0 -6
- package/dist/components/ScrollView.cjs.map +0 -1
- package/dist/components/ScrollView.d.ts +0 -222
- package/dist/components/ScrollView.d.ts.map +0 -1
- package/dist/components/ScrollView.js +0 -363
- package/dist/components/ScrollView.js.map +0 -1
- package/dist/components/Section.cjs +0 -2
- package/dist/components/Section.cjs.map +0 -1
- package/dist/components/Section.d.ts +0 -153
- package/dist/components/Section.d.ts.map +0 -1
- package/dist/components/Section.js +0 -323
- package/dist/components/Section.js.map +0 -1
- package/dist/components/Show.cjs +0 -2
- package/dist/components/Show.cjs.map +0 -1
- package/dist/components/Show.d.ts +0 -64
- package/dist/components/Show.d.ts.map +0 -1
- package/dist/components/Show.js +0 -112
- package/dist/components/Show.js.map +0 -1
- package/dist/components/Spacer.cjs +0 -2
- package/dist/components/Spacer.cjs.map +0 -1
- package/dist/components/Spacer.d.ts +0 -35
- package/dist/components/Spacer.d.ts.map +0 -1
- package/dist/components/Spacer.js +0 -53
- package/dist/components/Spacer.js.map +0 -1
- package/dist/components/Text.cjs +0 -2
- package/dist/components/Text.cjs.map +0 -1
- package/dist/components/Text.d.ts +0 -242
- package/dist/components/Text.d.ts.map +0 -1
- package/dist/components/Text.js +0 -193
- package/dist/components/Text.js.map +0 -1
- package/dist/components/Toggle.cjs +0 -2
- package/dist/components/Toggle.cjs.map +0 -1
- package/dist/components/Toggle.d.ts +0 -207
- package/dist/components/Toggle.d.ts.map +0 -1
- package/dist/components/Toggle.js +0 -477
- package/dist/components/Toggle.js.map +0 -1
- package/dist/components/index.cjs +0 -2
- package/dist/components/index.cjs.map +0 -1
- package/dist/components/index.js.map +0 -1
- package/dist/components/wrapper.cjs +0 -2
- package/dist/components/wrapper.cjs.map +0 -1
- package/dist/components/wrapper.js +0 -484
- package/dist/components/wrapper.js.map +0 -1
- package/dist/concatenation/concatenatable.cjs +0 -2
- package/dist/concatenation/concatenatable.cjs.map +0 -1
- package/dist/concatenation/concatenatable.js +0 -118
- package/dist/concatenation/concatenatable.js.map +0 -1
- package/dist/concatenation/concatenated-component.cjs +0 -2
- package/dist/concatenation/concatenated-component.cjs.map +0 -1
- package/dist/concatenation/concatenated-component.js +0 -276
- package/dist/concatenation/concatenated-component.js.map +0 -1
- package/dist/concatenation/text-optimizer.cjs +0 -2
- package/dist/concatenation/text-optimizer.cjs.map +0 -1
- package/dist/concatenation/text-optimizer.js +0 -236
- package/dist/concatenation/text-optimizer.js.map +0 -1
- package/dist/concatenation/types.cjs +0 -2
- package/dist/concatenation/types.cjs.map +0 -1
- package/dist/concatenation/types.js +0 -13
- package/dist/concatenation/types.js.map +0 -1
- package/dist/constants/frame-utils.cjs +0 -2
- package/dist/constants/frame-utils.cjs.map +0 -1
- package/dist/constants/frame-utils.js +0 -116
- package/dist/constants/frame-utils.js.map +0 -1
- package/dist/constants/layout.cjs +0 -2
- package/dist/constants/layout.cjs.map +0 -1
- package/dist/constants/layout.js.map +0 -1
- package/dist/css-classes/component-base.cjs +0 -2
- package/dist/css-classes/component-base.cjs.map +0 -1
- package/dist/css-classes/component-base.js +0 -62
- package/dist/css-classes/component-base.js.map +0 -1
- package/dist/css-classes/css-class-manager.cjs +0 -2
- package/dist/css-classes/css-class-manager.cjs.map +0 -1
- package/dist/css-classes/css-class-manager.js +0 -209
- package/dist/css-classes/css-class-manager.js.map +0 -1
- package/dist/css-classes/dom-integration.cjs +0 -2
- package/dist/css-classes/dom-integration.cjs.map +0 -1
- package/dist/css-classes/dom-integration.js +0 -67
- package/dist/css-classes/dom-integration.js.map +0 -1
- package/dist/css-classes/enhanced-renderer.cjs +0 -2
- package/dist/css-classes/enhanced-renderer.cjs.map +0 -1
- package/dist/css-classes/enhanced-renderer.js +0 -73
- package/dist/css-classes/enhanced-renderer.js.map +0 -1
- package/dist/css-classes/utilities.cjs +0 -2
- package/dist/css-classes/utilities.cjs.map +0 -1
- package/dist/css-classes/utilities.js +0 -41
- package/dist/css-classes/utilities.js.map +0 -1
- package/dist/debug/index.d.ts +0 -61
- package/dist/debug/index.d.ts.map +0 -1
- package/dist/debug.cjs +0 -52
- package/dist/debug.cjs.map +0 -1
- package/dist/debug.js +0 -179
- package/dist/debug.js.map +0 -1
- package/dist/developer-experience/enhanced-errors.d.ts +0 -128
- package/dist/developer-experience/enhanced-errors.d.ts.map +0 -1
- package/dist/developer-experience/enhanced-types.d.ts +0 -281
- package/dist/developer-experience/enhanced-types.d.ts.map +0 -1
- package/dist/developer-experience/index.d.ts +0 -44
- package/dist/developer-experience/index.d.ts.map +0 -1
- package/dist/essential.cjs +0 -2
- package/dist/essential.cjs.map +0 -1
- package/dist/essential.js.map +0 -1
- package/dist/gradients/css-generator.cjs +0 -2
- package/dist/gradients/css-generator.cjs.map +0 -1
- package/dist/gradients/css-generator.js +0 -100
- package/dist/gradients/css-generator.js.map +0 -1
- package/dist/gradients/examples.cjs +0 -2
- package/dist/gradients/examples.cjs.map +0 -1
- package/dist/gradients/examples.js +0 -555
- package/dist/gradients/examples.js.map +0 -1
- package/dist/gradients/gradient-asset.cjs +0 -2
- package/dist/gradients/gradient-asset.cjs.map +0 -1
- package/dist/gradients/gradient-asset.js +0 -22
- package/dist/gradients/gradient-asset.js.map +0 -1
- package/dist/gradients/index.cjs +0 -2
- package/dist/gradients/index.cjs.map +0 -1
- package/dist/gradients/index.js +0 -78
- package/dist/gradients/index.js.map +0 -1
- package/dist/gradients/performance.cjs +0 -2
- package/dist/gradients/performance.cjs.map +0 -1
- package/dist/gradients/performance.js +0 -237
- package/dist/gradients/performance.js.map +0 -1
- package/dist/gradients/presets.cjs +0 -2
- package/dist/gradients/presets.cjs.map +0 -1
- package/dist/gradients/presets.js +0 -254
- package/dist/gradients/presets.js.map +0 -1
- package/dist/gradients/reactive.cjs +0 -2
- package/dist/gradients/reactive.cjs.map +0 -1
- package/dist/gradients/reactive.js +0 -239
- package/dist/gradients/reactive.js.map +0 -1
- package/dist/gradients/state-gradient-asset.cjs +0 -2
- package/dist/gradients/state-gradient-asset.cjs.map +0 -1
- package/dist/gradients/state-gradient-asset.js +0 -111
- package/dist/gradients/state-gradient-asset.js.map +0 -1
- package/dist/gradients/utils.cjs +0 -2
- package/dist/gradients/utils.cjs.map +0 -1
- package/dist/gradients/utils.js +0 -385
- package/dist/gradients/utils.js.map +0 -1
- package/dist/gradients/validation.cjs +0 -2
- package/dist/gradients/validation.cjs.map +0 -1
- package/dist/gradients/validation.js +0 -209
- package/dist/gradients/validation.js.map +0 -1
- package/dist/index.cjs +0 -2
- package/dist/index.cjs.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index2.cjs +0 -2
- package/dist/index2.cjs.map +0 -1
- package/dist/index2.js +0 -293
- package/dist/index2.js.map +0 -1
- package/dist/lifecycle/hooks.cjs +0 -2
- package/dist/lifecycle/hooks.cjs.map +0 -1
- package/dist/lifecycle/hooks.js +0 -159
- package/dist/lifecycle/hooks.js.map +0 -1
- package/dist/minimal-prod.cjs +0 -2
- package/dist/minimal-prod.cjs.map +0 -1
- package/dist/minimal-prod.js.map +0 -1
- package/dist/minimal.cjs +0 -2
- package/dist/minimal.cjs.map +0 -1
- package/dist/minimal.js.map +0 -1
- package/dist/modifiers/as-html-validator.cjs +0 -2
- package/dist/modifiers/as-html-validator.cjs.map +0 -1
- package/dist/modifiers/as-html-validator.js +0 -47
- package/dist/modifiers/as-html-validator.js.map +0 -1
- package/dist/modifiers/as-html.cjs +0 -2
- package/dist/modifiers/as-html.cjs.map +0 -1
- package/dist/modifiers/as-html.js +0 -71
- package/dist/modifiers/as-html.js.map +0 -1
- package/dist/modifiers/attributes.cjs +0 -2
- package/dist/modifiers/attributes.cjs.map +0 -1
- package/dist/modifiers/attributes.d.ts +0 -203
- package/dist/modifiers/attributes.d.ts.map +0 -1
- package/dist/modifiers/attributes.js +0 -272
- package/dist/modifiers/attributes.js.map +0 -1
- package/dist/modifiers/backdrop.cjs +0 -2
- package/dist/modifiers/backdrop.cjs.map +0 -1
- package/dist/modifiers/backdrop.d.ts +0 -59
- package/dist/modifiers/backdrop.d.ts.map +0 -1
- package/dist/modifiers/backdrop.js +0 -109
- package/dist/modifiers/backdrop.js.map +0 -1
- package/dist/modifiers/background.cjs +0 -2
- package/dist/modifiers/background.cjs.map +0 -1
- package/dist/modifiers/background.js +0 -67
- package/dist/modifiers/background.js.map +0 -1
- package/dist/modifiers/base.cjs +0 -25
- package/dist/modifiers/base.cjs.map +0 -1
- package/dist/modifiers/base.js.map +0 -1
- package/dist/modifiers/basic-sanitizer.cjs +0 -2
- package/dist/modifiers/basic-sanitizer.cjs.map +0 -1
- package/dist/modifiers/basic-sanitizer.js +0 -162
- package/dist/modifiers/basic-sanitizer.js.map +0 -1
- package/dist/modifiers/border.cjs +0 -2
- package/dist/modifiers/border.cjs.map +0 -1
- package/dist/modifiers/border.d.ts +0 -217
- package/dist/modifiers/border.d.ts.map +0 -1
- package/dist/modifiers/border.js +0 -160
- package/dist/modifiers/border.js.map +0 -1
- package/dist/modifiers/builder.cjs +0 -2
- package/dist/modifiers/builder.cjs.map +0 -1
- package/dist/modifiers/builder.js.map +0 -1
- package/dist/modifiers/core.cjs +0 -2
- package/dist/modifiers/core.cjs.map +0 -1
- package/dist/modifiers/core.js +0 -398
- package/dist/modifiers/core.js.map +0 -1
- package/dist/modifiers/css.cjs +0 -2
- package/dist/modifiers/css.cjs.map +0 -1
- package/dist/modifiers/css.js +0 -50
- package/dist/modifiers/css.js.map +0 -1
- package/dist/modifiers/effects.cjs +0 -2
- package/dist/modifiers/effects.cjs.map +0 -1
- package/dist/modifiers/effects.d.ts +0 -159
- package/dist/modifiers/effects.d.ts.map +0 -1
- package/dist/modifiers/effects.js +0 -178
- package/dist/modifiers/effects.js.map +0 -1
- package/dist/modifiers/elements.cjs +0 -2
- package/dist/modifiers/elements.cjs.map +0 -1
- package/dist/modifiers/elements.d.ts +0 -240
- package/dist/modifiers/elements.d.ts.map +0 -1
- package/dist/modifiers/elements.js +0 -216
- package/dist/modifiers/elements.js.map +0 -1
- package/dist/modifiers/filters.cjs +0 -2
- package/dist/modifiers/filters.cjs.map +0 -1
- package/dist/modifiers/filters.d.ts +0 -275
- package/dist/modifiers/filters.d.ts.map +0 -1
- package/dist/modifiers/filters.js +0 -223
- package/dist/modifiers/filters.js.map +0 -1
- package/dist/modifiers/flexbox.cjs +0 -2
- package/dist/modifiers/flexbox.cjs.map +0 -1
- package/dist/modifiers/flexbox.d.ts +0 -82
- package/dist/modifiers/flexbox.d.ts.map +0 -1
- package/dist/modifiers/flexbox.js +0 -56
- package/dist/modifiers/flexbox.js.map +0 -1
- package/dist/modifiers/font.cjs +0 -2
- package/dist/modifiers/font.cjs.map +0 -1
- package/dist/modifiers/font.d.ts +0 -71
- package/dist/modifiers/font.d.ts.map +0 -1
- package/dist/modifiers/font.js +0 -60
- package/dist/modifiers/font.js.map +0 -1
- package/dist/modifiers/grid.cjs +0 -2
- package/dist/modifiers/grid.cjs.map +0 -1
- package/dist/modifiers/grid.d.ts +0 -92
- package/dist/modifiers/grid.d.ts.map +0 -1
- package/dist/modifiers/grid.js +0 -92
- package/dist/modifiers/grid.js.map +0 -1
- package/dist/modifiers/margin.cjs +0 -2
- package/dist/modifiers/margin.cjs.map +0 -1
- package/dist/modifiers/margin.d.ts +0 -128
- package/dist/modifiers/margin.d.ts.map +0 -1
- package/dist/modifiers/margin.js +0 -65
- package/dist/modifiers/margin.js.map +0 -1
- package/dist/modifiers/padding.cjs +0 -2
- package/dist/modifiers/padding.cjs.map +0 -1
- package/dist/modifiers/padding.d.ts +0 -204
- package/dist/modifiers/padding.d.ts.map +0 -1
- package/dist/modifiers/padding.js +0 -109
- package/dist/modifiers/padding.js.map +0 -1
- package/dist/modifiers/registry.cjs +0 -2
- package/dist/modifiers/registry.cjs.map +0 -1
- package/dist/modifiers/registry.js.map +0 -1
- package/dist/modifiers/responsive/advanced-utilities.cjs +0 -2
- package/dist/modifiers/responsive/advanced-utilities.cjs.map +0 -1
- package/dist/modifiers/responsive/advanced-utilities.d.ts +0 -118
- package/dist/modifiers/responsive/advanced-utilities.d.ts.map +0 -1
- package/dist/modifiers/responsive/advanced-utilities.js +0 -291
- package/dist/modifiers/responsive/advanced-utilities.js.map +0 -1
- package/dist/modifiers/responsive/breakpoints.cjs +0 -2
- package/dist/modifiers/responsive/breakpoints.cjs.map +0 -1
- package/dist/modifiers/responsive/breakpoints.d.ts +0 -81
- package/dist/modifiers/responsive/breakpoints.d.ts.map +0 -1
- package/dist/modifiers/responsive/breakpoints.js +0 -168
- package/dist/modifiers/responsive/breakpoints.js.map +0 -1
- package/dist/modifiers/responsive/css-generator.cjs +0 -5
- package/dist/modifiers/responsive/css-generator.cjs.map +0 -1
- package/dist/modifiers/responsive/css-generator.d.ts +0 -100
- package/dist/modifiers/responsive/css-generator.d.ts.map +0 -1
- package/dist/modifiers/responsive/css-generator.js +0 -261
- package/dist/modifiers/responsive/css-generator.js.map +0 -1
- package/dist/modifiers/responsive/dev-tools.cjs +0 -77
- package/dist/modifiers/responsive/dev-tools.cjs.map +0 -1
- package/dist/modifiers/responsive/dev-tools.d.ts +0 -107
- package/dist/modifiers/responsive/dev-tools.d.ts.map +0 -1
- package/dist/modifiers/responsive/dev-tools.js +0 -380
- package/dist/modifiers/responsive/dev-tools.js.map +0 -1
- package/dist/modifiers/responsive/index.d.ts +0 -28
- package/dist/modifiers/responsive/index.d.ts.map +0 -1
- package/dist/modifiers/responsive/layout-patterns.cjs +0 -2
- package/dist/modifiers/responsive/layout-patterns.cjs.map +0 -1
- package/dist/modifiers/responsive/layout-patterns.d.ts +0 -230
- package/dist/modifiers/responsive/layout-patterns.d.ts.map +0 -1
- package/dist/modifiers/responsive/layout-patterns.js +0 -254
- package/dist/modifiers/responsive/layout-patterns.js.map +0 -1
- package/dist/modifiers/responsive/performance.cjs +0 -3
- package/dist/modifiers/responsive/performance.cjs.map +0 -1
- package/dist/modifiers/responsive/performance.d.ts +0 -130
- package/dist/modifiers/responsive/performance.d.ts.map +0 -1
- package/dist/modifiers/responsive/performance.js +0 -212
- package/dist/modifiers/responsive/performance.js.map +0 -1
- package/dist/modifiers/responsive/responsive-builder.cjs +0 -2
- package/dist/modifiers/responsive/responsive-builder.cjs.map +0 -1
- package/dist/modifiers/responsive/responsive-builder.d.ts +0 -133
- package/dist/modifiers/responsive/responsive-builder.d.ts.map +0 -1
- package/dist/modifiers/responsive/responsive-builder.js +0 -272
- package/dist/modifiers/responsive/responsive-builder.js.map +0 -1
- package/dist/modifiers/responsive/responsive-modifier.cjs +0 -3
- package/dist/modifiers/responsive/responsive-modifier.cjs.map +0 -1
- package/dist/modifiers/responsive/responsive-modifier.d.ts +0 -123
- package/dist/modifiers/responsive/responsive-modifier.d.ts.map +0 -1
- package/dist/modifiers/responsive/responsive-modifier.js +0 -204
- package/dist/modifiers/responsive/responsive-modifier.js.map +0 -1
- package/dist/modifiers/responsive/types.cjs +0 -2
- package/dist/modifiers/responsive/types.cjs.map +0 -1
- package/dist/modifiers/responsive/types.d.ts +0 -183
- package/dist/modifiers/responsive/types.d.ts.map +0 -1
- package/dist/modifiers/responsive/types.js +0 -26
- package/dist/modifiers/responsive/types.js.map +0 -1
- package/dist/modifiers/responsive/utilities.cjs +0 -16
- package/dist/modifiers/responsive/utilities.cjs.map +0 -1
- package/dist/modifiers/responsive/utilities.d.ts +0 -149
- package/dist/modifiers/responsive/utilities.d.ts.map +0 -1
- package/dist/modifiers/responsive/utilities.js +0 -273
- package/dist/modifiers/responsive/utilities.js.map +0 -1
- package/dist/modifiers/scroll.cjs +0 -2
- package/dist/modifiers/scroll.cjs.map +0 -1
- package/dist/modifiers/scroll.d.ts +0 -143
- package/dist/modifiers/scroll.d.ts.map +0 -1
- package/dist/modifiers/scroll.js +0 -82
- package/dist/modifiers/scroll.js.map +0 -1
- package/dist/modifiers/shadows.cjs +0 -2
- package/dist/modifiers/shadows.cjs.map +0 -1
- package/dist/modifiers/shadows.d.ts +0 -114
- package/dist/modifiers/shadows.d.ts.map +0 -1
- package/dist/modifiers/shadows.js +0 -147
- package/dist/modifiers/shadows.js.map +0 -1
- package/dist/modifiers/size.cjs +0 -2
- package/dist/modifiers/size.cjs.map +0 -1
- package/dist/modifiers/size.d.ts +0 -113
- package/dist/modifiers/size.d.ts.map +0 -1
- package/dist/modifiers/size.js +0 -74
- package/dist/modifiers/size.js.map +0 -1
- package/dist/modifiers/text.cjs +0 -2
- package/dist/modifiers/text.cjs.map +0 -1
- package/dist/modifiers/text.d.ts +0 -147
- package/dist/modifiers/text.d.ts.map +0 -1
- package/dist/modifiers/text.js +0 -166
- package/dist/modifiers/text.js.map +0 -1
- package/dist/modifiers/transformations.cjs +0 -2
- package/dist/modifiers/transformations.cjs.map +0 -1
- package/dist/modifiers/transformations.d.ts +0 -329
- package/dist/modifiers/transformations.d.ts.map +0 -1
- package/dist/modifiers/transformations.js +0 -216
- package/dist/modifiers/transformations.js.map +0 -1
- package/dist/modifiers/transitions.cjs +0 -2
- package/dist/modifiers/transitions.cjs.map +0 -1
- package/dist/modifiers/transitions.d.ts +0 -98
- package/dist/modifiers/transitions.d.ts.map +0 -1
- package/dist/modifiers/transitions.js +0 -102
- package/dist/modifiers/transitions.js.map +0 -1
- package/dist/modifiers/types.cjs +0 -2
- package/dist/modifiers/types.cjs.map +0 -1
- package/dist/modifiers/types.js.map +0 -1
- package/dist/modifiers/typography.cjs +0 -2
- package/dist/modifiers/typography.cjs.map +0 -1
- package/dist/modifiers/typography.d.ts +0 -192
- package/dist/modifiers/typography.d.ts.map +0 -1
- package/dist/modifiers/typography.js +0 -76
- package/dist/modifiers/typography.js.map +0 -1
- package/dist/modifiers/utility.cjs +0 -2
- package/dist/modifiers/utility.cjs.map +0 -1
- package/dist/modifiers/utility.d.ts +0 -69
- package/dist/modifiers/utility.d.ts.map +0 -1
- package/dist/modifiers/utility.js +0 -71
- package/dist/modifiers/utility.js.map +0 -1
- package/dist/modifiers/utils.cjs +0 -2
- package/dist/modifiers/utils.cjs.map +0 -1
- package/dist/modifiers/utils.d.ts.map +0 -1
- package/dist/modifiers/utils.js +0 -250
- package/dist/modifiers/utils.js.map +0 -1
- package/dist/plugins/index.cjs +0 -2
- package/dist/plugins/index.cjs.map +0 -1
- package/dist/plugins/index.js.map +0 -1
- package/dist/plugins/legacy-adapter.cjs +0 -2
- package/dist/plugins/legacy-adapter.cjs.map +0 -1
- package/dist/plugins/legacy-adapter.js +0 -30
- package/dist/plugins/legacy-adapter.js.map +0 -1
- package/dist/plugins/simplified-component-registry.cjs +0 -2
- package/dist/plugins/simplified-component-registry.cjs.map +0 -1
- package/dist/plugins/simplified-component-registry.js +0 -71
- package/dist/plugins/simplified-component-registry.js.map +0 -1
- package/dist/plugins/simplified-error-handler.cjs +0 -2
- package/dist/plugins/simplified-error-handler.cjs.map +0 -1
- package/dist/plugins/simplified-error-handler.d.ts +0 -83
- package/dist/plugins/simplified-error-handler.d.ts.map +0 -1
- package/dist/plugins/simplified-error-handler.js +0 -154
- package/dist/plugins/simplified-error-handler.js.map +0 -1
- package/dist/plugins/simplified-lazy-loader.cjs +0 -2
- package/dist/plugins/simplified-lazy-loader.cjs.map +0 -1
- package/dist/plugins/simplified-lazy-loader.js +0 -129
- package/dist/plugins/simplified-lazy-loader.js.map +0 -1
- package/dist/plugins/simplified-plugin-manager.cjs +0 -2
- package/dist/plugins/simplified-plugin-manager.cjs.map +0 -1
- package/dist/plugins/simplified-plugin-manager.js +0 -51
- package/dist/plugins/simplified-plugin-manager.js.map +0 -1
- package/dist/plugins/simplified-tachui-instance.cjs +0 -2
- package/dist/plugins/simplified-tachui-instance.cjs.map +0 -1
- package/dist/plugins/simplified-tachui-instance.js +0 -88
- package/dist/plugins/simplified-tachui-instance.js.map +0 -1
- package/dist/plugins/simplified-types.cjs +0 -2
- package/dist/plugins/simplified-types.cjs.map +0 -1
- package/dist/plugins/simplified-types.js +0 -9
- package/dist/plugins/simplified-types.js.map +0 -1
- package/dist/plugins/simplified-utils.cjs +0 -2
- package/dist/plugins/simplified-utils.cjs.map +0 -1
- package/dist/plugins/simplified-utils.js +0 -40
- package/dist/plugins/simplified-utils.js.map +0 -1
- package/dist/reactive/cleanup.cjs +0 -2
- package/dist/reactive/cleanup.cjs.map +0 -1
- package/dist/reactive/cleanup.js +0 -62
- package/dist/reactive/cleanup.js.map +0 -1
- package/dist/reactive/computed.cjs +0 -2
- package/dist/reactive/computed.cjs.map +0 -1
- package/dist/reactive/computed.js +0 -121
- package/dist/reactive/computed.js.map +0 -1
- package/dist/reactive/context.cjs +0 -2
- package/dist/reactive/context.cjs.map +0 -1
- package/dist/reactive/context.js +0 -143
- package/dist/reactive/context.js.map +0 -1
- package/dist/reactive/effect.cjs +0 -2
- package/dist/reactive/effect.cjs.map +0 -1
- package/dist/reactive/effect.js +0 -67
- package/dist/reactive/effect.js.map +0 -1
- package/dist/reactive/enhanced-effect.cjs +0 -2
- package/dist/reactive/enhanced-effect.cjs.map +0 -1
- package/dist/reactive/enhanced-effect.js +0 -153
- package/dist/reactive/enhanced-effect.js.map +0 -1
- package/dist/reactive/enhanced-signal.cjs +0 -2
- package/dist/reactive/enhanced-signal.cjs.map +0 -1
- package/dist/reactive/enhanced-signal.js +0 -117
- package/dist/reactive/enhanced-signal.js.map +0 -1
- package/dist/reactive/equality.cjs +0 -2
- package/dist/reactive/equality.cjs.map +0 -1
- package/dist/reactive/equality.js +0 -66
- package/dist/reactive/equality.js.map +0 -1
- package/dist/reactive/index.cjs +0 -2
- package/dist/reactive/index.cjs.map +0 -1
- package/dist/reactive/index.js.map +0 -1
- package/dist/reactive/migration.cjs +0 -18
- package/dist/reactive/migration.cjs.map +0 -1
- package/dist/reactive/migration.js +0 -164
- package/dist/reactive/migration.js.map +0 -1
- package/dist/reactive/ownership.cjs +0 -2
- package/dist/reactive/ownership.cjs.map +0 -1
- package/dist/reactive/ownership.js +0 -34
- package/dist/reactive/ownership.js.map +0 -1
- package/dist/reactive/scheduler.cjs +0 -2
- package/dist/reactive/scheduler.cjs.map +0 -1
- package/dist/reactive/scheduler.js +0 -111
- package/dist/reactive/scheduler.js.map +0 -1
- package/dist/reactive/signal.cjs +0 -2
- package/dist/reactive/signal.cjs.map +0 -1
- package/dist/reactive/signal.js +0 -96
- package/dist/reactive/signal.js.map +0 -1
- package/dist/reactive/theme.cjs +0 -2
- package/dist/reactive/theme.cjs.map +0 -1
- package/dist/reactive/theme.js +0 -27
- package/dist/reactive/theme.js.map +0 -1
- package/dist/reactive/types.cjs +0 -2
- package/dist/reactive/types.cjs.map +0 -1
- package/dist/reactive/types.js.map +0 -1
- package/dist/reactive/unified-scheduler.cjs +0 -2
- package/dist/reactive/unified-scheduler.cjs.map +0 -1
- package/dist/reactive/unified-scheduler.js +0 -219
- package/dist/reactive/unified-scheduler.js.map +0 -1
- package/dist/runtime/component-context.cjs +0 -2
- package/dist/runtime/component-context.cjs.map +0 -1
- package/dist/runtime/component-context.js +0 -177
- package/dist/runtime/component-context.js.map +0 -1
- package/dist/runtime/component.cjs +0 -2
- package/dist/runtime/component.cjs.map +0 -1
- package/dist/runtime/component.js +0 -238
- package/dist/runtime/component.js.map +0 -1
- package/dist/runtime/context.cjs +0 -2
- package/dist/runtime/context.cjs.map +0 -1
- package/dist/runtime/context.js +0 -289
- package/dist/runtime/context.js.map +0 -1
- package/dist/runtime/dev-tools.cjs +0 -2
- package/dist/runtime/dev-tools.cjs.map +0 -1
- package/dist/runtime/dev-tools.d.ts +0 -240
- package/dist/runtime/dev-tools.d.ts.map +0 -1
- package/dist/runtime/dev-tools.js +0 -391
- package/dist/runtime/dev-tools.js.map +0 -1
- package/dist/runtime/development-warnings.cjs +0 -2
- package/dist/runtime/development-warnings.cjs.map +0 -1
- package/dist/runtime/development-warnings.d.ts +0 -42
- package/dist/runtime/development-warnings.d.ts.map +0 -1
- package/dist/runtime/development-warnings.js +0 -69
- package/dist/runtime/development-warnings.js.map +0 -1
- package/dist/runtime/dom-bridge.cjs +0 -2
- package/dist/runtime/dom-bridge.cjs.map +0 -1
- package/dist/runtime/dom-bridge.js.map +0 -1
- package/dist/runtime/element-override.cjs +0 -2
- package/dist/runtime/element-override.cjs.map +0 -1
- package/dist/runtime/element-override.js +0 -214
- package/dist/runtime/element-override.js.map +0 -1
- package/dist/runtime/error-boundary.cjs +0 -2
- package/dist/runtime/error-boundary.cjs.map +0 -1
- package/dist/runtime/error-boundary.d.ts +0 -302
- package/dist/runtime/error-boundary.d.ts.map +0 -1
- package/dist/runtime/error-boundary.js +0 -559
- package/dist/runtime/error-boundary.js.map +0 -1
- package/dist/runtime/error-recovery.cjs +0 -2
- package/dist/runtime/error-recovery.cjs.map +0 -1
- package/dist/runtime/error-recovery.d.ts +0 -267
- package/dist/runtime/error-recovery.d.ts.map +0 -1
- package/dist/runtime/error-recovery.js +0 -385
- package/dist/runtime/error-recovery.js.map +0 -1
- package/dist/runtime/error-reporting.cjs +0 -3
- package/dist/runtime/error-reporting.cjs.map +0 -1
- package/dist/runtime/error-reporting.d.ts +0 -287
- package/dist/runtime/error-reporting.d.ts.map +0 -1
- package/dist/runtime/error-reporting.js +0 -479
- package/dist/runtime/error-reporting.js.map +0 -1
- package/dist/runtime/error-utils.cjs +0 -3
- package/dist/runtime/error-utils.cjs.map +0 -1
- package/dist/runtime/error-utils.d.ts +0 -204
- package/dist/runtime/error-utils.d.ts.map +0 -1
- package/dist/runtime/error-utils.js +0 -352
- package/dist/runtime/error-utils.js.map +0 -1
- package/dist/runtime/lazy-component.cjs +0 -2
- package/dist/runtime/lazy-component.cjs.map +0 -1
- package/dist/runtime/lazy-component.js +0 -129
- package/dist/runtime/lazy-component.js.map +0 -1
- package/dist/runtime/lifecycle.cjs +0 -2
- package/dist/runtime/lifecycle.cjs.map +0 -1
- package/dist/runtime/lifecycle.js +0 -7
- package/dist/runtime/lifecycle.js.map +0 -1
- package/dist/runtime/mounting.cjs +0 -2
- package/dist/runtime/mounting.cjs.map +0 -1
- package/dist/runtime/mounting.js +0 -12
- package/dist/runtime/mounting.js.map +0 -1
- package/dist/runtime/optimization.cjs +0 -2
- package/dist/runtime/optimization.cjs.map +0 -1
- package/dist/runtime/optimization.js +0 -6
- package/dist/runtime/optimization.js.map +0 -1
- package/dist/runtime/performance.cjs +0 -2
- package/dist/runtime/performance.cjs.map +0 -1
- package/dist/runtime/performance.d.ts +0 -217
- package/dist/runtime/performance.d.ts.map +0 -1
- package/dist/runtime/performance.js +0 -399
- package/dist/runtime/performance.js.map +0 -1
- package/dist/runtime/props.cjs +0 -2
- package/dist/runtime/props.cjs.map +0 -1
- package/dist/runtime/props.js +0 -265
- package/dist/runtime/props.js.map +0 -1
- package/dist/runtime/renderer.cjs +0 -2
- package/dist/runtime/renderer.cjs.map +0 -1
- package/dist/runtime/renderer.js.map +0 -1
- package/dist/runtime/semantic-role-manager.cjs +0 -2
- package/dist/runtime/semantic-role-manager.cjs.map +0 -1
- package/dist/runtime/semantic-role-manager.js +0 -82
- package/dist/runtime/semantic-role-manager.js.map +0 -1
- package/dist/state/binding.cjs +0 -2
- package/dist/state/binding.cjs.map +0 -1
- package/dist/state/binding.js +0 -155
- package/dist/state/binding.js.map +0 -1
- package/dist/state/environment.cjs +0 -2
- package/dist/state/environment.cjs.map +0 -1
- package/dist/state/environment.js +0 -115
- package/dist/state/environment.js.map +0 -1
- package/dist/state/index.cjs +0 -2
- package/dist/state/index.cjs.map +0 -1
- package/dist/state/index.js +0 -63
- package/dist/state/index.js.map +0 -1
- package/dist/state/observed-object.cjs +0 -2
- package/dist/state/observed-object.cjs.map +0 -1
- package/dist/state/observed-object.js +0 -163
- package/dist/state/observed-object.js.map +0 -1
- package/dist/state/state-manager.cjs +0 -2
- package/dist/state/state-manager.cjs.map +0 -1
- package/dist/state/state-manager.js +0 -233
- package/dist/state/state-manager.js.map +0 -1
- package/dist/state/state.cjs +0 -2
- package/dist/state/state.cjs.map +0 -1
- package/dist/state/state.js +0 -159
- package/dist/state/state.js.map +0 -1
- package/dist/sui-compat.cjs +0 -2
- package/dist/sui-compat.cjs.map +0 -1
- package/dist/sui-compat.d.ts +0 -110
- package/dist/sui-compat.d.ts.map +0 -1
- package/dist/sui-compat.js +0 -88
- package/dist/sui-compat.js.map +0 -1
- package/dist/validation/advanced-debugging.cjs +0 -44
- package/dist/validation/advanced-debugging.cjs.map +0 -1
- package/dist/validation/advanced-debugging.d.ts +0 -319
- package/dist/validation/advanced-debugging.d.ts.map +0 -1
- package/dist/validation/advanced-debugging.js +0 -455
- package/dist/validation/advanced-debugging.js.map +0 -1
- package/dist/validation/build-time/detection.cjs +0 -2
- package/dist/validation/build-time/detection.cjs.map +0 -1
- package/dist/validation/build-time/detection.d.ts +0 -32
- package/dist/validation/build-time/detection.d.ts.map +0 -1
- package/dist/validation/build-time/detection.js +0 -199
- package/dist/validation/build-time/detection.js.map +0 -1
- package/dist/validation/build-time/index.cjs +0 -2
- package/dist/validation/build-time/index.cjs.map +0 -1
- package/dist/validation/build-time/index.d.ts +0 -84
- package/dist/validation/build-time/index.d.ts.map +0 -1
- package/dist/validation/build-time/index.js +0 -122
- package/dist/validation/build-time/index.js.map +0 -1
- package/dist/validation/build-time/plugins.cjs +0 -3
- package/dist/validation/build-time/plugins.cjs.map +0 -1
- package/dist/validation/build-time/plugins.d.ts +0 -75
- package/dist/validation/build-time/plugins.d.ts.map +0 -1
- package/dist/validation/build-time/plugins.js +0 -282
- package/dist/validation/build-time/plugins.js.map +0 -1
- package/dist/validation/build-time/rules.cjs +0 -2
- package/dist/validation/build-time/rules.cjs.map +0 -1
- package/dist/validation/build-time/rules.d.ts +0 -73
- package/dist/validation/build-time/rules.d.ts.map +0 -1
- package/dist/validation/build-time/rules.js +0 -576
- package/dist/validation/build-time/rules.js.map +0 -1
- package/dist/validation/build-time/transformer.cjs +0 -3
- package/dist/validation/build-time/transformer.cjs.map +0 -1
- package/dist/validation/build-time/transformer.d.ts +0 -23
- package/dist/validation/build-time/transformer.d.ts.map +0 -1
- package/dist/validation/build-time/transformer.js +0 -177
- package/dist/validation/build-time/transformer.js.map +0 -1
- package/dist/validation/build-time/types.d.ts +0 -212
- package/dist/validation/build-time/types.d.ts.map +0 -1
- package/dist/validation/comprehensive.cjs +0 -9
- package/dist/validation/comprehensive.cjs.map +0 -1
- package/dist/validation/comprehensive.d.ts +0 -160
- package/dist/validation/comprehensive.d.ts.map +0 -1
- package/dist/validation/comprehensive.js +0 -916
- package/dist/validation/comprehensive.js.map +0 -1
- package/dist/validation/debug-tools.cjs +0 -16
- package/dist/validation/debug-tools.cjs.map +0 -1
- package/dist/validation/debug-tools.d.ts +0 -251
- package/dist/validation/debug-tools.d.ts.map +0 -1
- package/dist/validation/debug-tools.js +0 -405
- package/dist/validation/debug-tools.js.map +0 -1
- package/dist/validation/developer-experience.cjs +0 -17
- package/dist/validation/developer-experience.cjs.map +0 -1
- package/dist/validation/developer-experience.d.ts +0 -243
- package/dist/validation/developer-experience.d.ts.map +0 -1
- package/dist/validation/developer-experience.js +0 -433
- package/dist/validation/developer-experience.js.map +0 -1
- package/dist/validation/documentation-integration.cjs +0 -7
- package/dist/validation/documentation-integration.cjs.map +0 -1
- package/dist/validation/documentation-integration.d.ts +0 -269
- package/dist/validation/documentation-integration.d.ts.map +0 -1
- package/dist/validation/documentation-integration.js +0 -440
- package/dist/validation/documentation-integration.js.map +0 -1
- package/dist/validation/enhanced-runtime.cjs +0 -6
- package/dist/validation/enhanced-runtime.cjs.map +0 -1
- package/dist/validation/enhanced-runtime.d.ts +0 -279
- package/dist/validation/enhanced-runtime.d.ts.map +0 -1
- package/dist/validation/enhanced-runtime.js +0 -465
- package/dist/validation/enhanced-runtime.js.map +0 -1
- package/dist/validation/error-reporting.cjs +0 -32
- package/dist/validation/error-reporting.cjs.map +0 -1
- package/dist/validation/error-reporting.d.ts +0 -186
- package/dist/validation/error-reporting.d.ts.map +0 -1
- package/dist/validation/error-reporting.js +0 -370
- package/dist/validation/error-reporting.js.map +0 -1
- package/dist/validation/ide-integration.cjs +0 -85
- package/dist/validation/ide-integration.cjs.map +0 -1
- package/dist/validation/ide-integration.d.ts +0 -328
- package/dist/validation/ide-integration.d.ts.map +0 -1
- package/dist/validation/ide-integration.js +0 -557
- package/dist/validation/ide-integration.js.map +0 -1
- package/dist/validation/index.cjs +0 -6
- package/dist/validation/index.cjs.map +0 -1
- package/dist/validation/index.js.map +0 -1
- package/dist/validation/lifecycle-validation.cjs +0 -2
- package/dist/validation/lifecycle-validation.cjs.map +0 -1
- package/dist/validation/lifecycle-validation.js +0 -314
- package/dist/validation/lifecycle-validation.js.map +0 -1
- package/dist/validation/performance-optimizer.cjs +0 -2
- package/dist/validation/performance-optimizer.cjs.map +0 -1
- package/dist/validation/performance-optimizer.d.ts +0 -218
- package/dist/validation/performance-optimizer.d.ts.map +0 -1
- package/dist/validation/performance-optimizer.js +0 -338
- package/dist/validation/performance-optimizer.js.map +0 -1
- package/dist/validation/plugin-registration.cjs +0 -2
- package/dist/validation/plugin-registration.cjs.map +0 -1
- package/dist/validation/plugin-registration.js +0 -126
- package/dist/validation/plugin-registration.js.map +0 -1
- package/dist/validation/production-bypass.cjs +0 -2
- package/dist/validation/production-bypass.cjs.map +0 -1
- package/dist/validation/production-bypass.d.ts +0 -175
- package/dist/validation/production-bypass.d.ts.map +0 -1
- package/dist/validation/production-bypass.js +0 -218
- package/dist/validation/production-bypass.js.map +0 -1
- package/dist/validation/simple.cjs +0 -9
- package/dist/validation/simple.cjs.map +0 -1
- package/dist/validation/simple.d.ts +0 -111
- package/dist/validation/simple.d.ts.map +0 -1
- package/dist/validation/simple.js +0 -146
- package/dist/validation/simple.js.map +0 -1
- package/dist/viewport/adapters/web-adapter.cjs +0 -70
- package/dist/viewport/adapters/web-adapter.cjs.map +0 -1
- package/dist/viewport/adapters/web-adapter.d.ts +0 -227
- package/dist/viewport/adapters/web-adapter.d.ts.map +0 -1
- package/dist/viewport/adapters/web-adapter.js +0 -823
- package/dist/viewport/adapters/web-adapter.js.map +0 -1
- package/dist/viewport/components.cjs +0 -2
- package/dist/viewport/components.cjs.map +0 -1
- package/dist/viewport/components.d.ts +0 -131
- package/dist/viewport/components.d.ts.map +0 -1
- package/dist/viewport/components.js +0 -298
- package/dist/viewport/components.js.map +0 -1
- package/dist/viewport/environment.cjs +0 -2
- package/dist/viewport/environment.cjs.map +0 -1
- package/dist/viewport/environment.d.ts +0 -75
- package/dist/viewport/environment.d.ts.map +0 -1
- package/dist/viewport/environment.js +0 -86
- package/dist/viewport/environment.js.map +0 -1
- package/dist/viewport/index.cjs +0 -2
- package/dist/viewport/index.cjs.map +0 -1
- package/dist/viewport/index.d.ts +0 -138
- package/dist/viewport/index.d.ts.map +0 -1
- package/dist/viewport/index.js +0 -166
- package/dist/viewport/index.js.map +0 -1
- package/dist/viewport/platform-detection.cjs +0 -2
- package/dist/viewport/platform-detection.cjs.map +0 -1
- package/dist/viewport/platform-detection.d.ts +0 -59
- package/dist/viewport/platform-detection.d.ts.map +0 -1
- package/dist/viewport/platform-detection.js +0 -205
- package/dist/viewport/platform-detection.js.map +0 -1
- package/dist/viewport/types.cjs +0 -2
- package/dist/viewport/types.cjs.map +0 -1
- package/dist/viewport/types.d.ts +0 -301
- package/dist/viewport/types.d.ts.map +0 -1
- package/dist/viewport/types.js +0 -13
- package/dist/viewport/types.js.map +0 -1
- package/dist/viewport/viewport-manager.cjs +0 -2
- package/dist/viewport/viewport-manager.cjs.map +0 -1
- package/dist/viewport/viewport-manager.d.ts +0 -118
- package/dist/viewport/viewport-manager.d.ts.map +0 -1
- package/dist/viewport/viewport-manager.js +0 -524
- package/dist/viewport/viewport-manager.js.map +0 -1
- package/src/assets/Asset.ts +0 -11
- package/src/assets/AssetCollection.ts +0 -99
- package/src/assets/ColorAsset.ts +0 -210
- package/src/assets/FontAsset.ts +0 -380
- package/src/assets/ImageAsset.ts +0 -91
- package/src/assets/README.md +0 -190
- package/src/assets/index.ts +0 -175
- package/src/assets/test-assets.ts +0 -69
- package/src/assets/test-integration.ts +0 -46
- package/src/assets/test-simple.ts +0 -28
- package/src/assets/types.ts +0 -79
- package/src/bundles/common.ts +0 -30
- package/src/bundles/complete.ts +0 -29
- package/src/bundles/essential.ts +0 -26
- package/src/bundles/minimal.ts +0 -26
- package/src/bundles/production-minimal.ts +0 -67
- package/src/compiler/advanced-parser.ts +0 -871
- package/src/compiler/codegen.ts +0 -450
- package/src/compiler/enhanced-codegen.ts +0 -729
- package/src/compiler/index.ts +0 -25
- package/src/compiler/parser.ts +0 -461
- package/src/compiler/plugin.ts +0 -181
- package/src/compiler/types.ts +0 -177
- package/src/components/BasicInput.ts +0 -352
- package/src/components/Button.ts +0 -963
- package/src/components/Divider.ts +0 -341
- package/src/components/EnhancedLink.ts +0 -676
- package/src/components/Form.ts +0 -414
- package/src/components/Grid.ts +0 -2507
- package/src/components/GridResponsive.ts +0 -637
- package/src/components/Image.ts +0 -426
- package/src/components/List.ts +0 -1084
- package/src/components/Menu.ts +0 -807
- package/src/components/Picker.ts +0 -678
- package/src/components/ScrollView.ts +0 -725
- package/src/components/Section.ts +0 -472
- package/src/components/Show.ts +0 -205
- package/src/components/Spacer.ts +0 -93
- package/src/components/Text.ts +0 -447
- package/src/components/Toggle.ts +0 -700
- package/src/components/index.ts +0 -231
- package/src/components/wrapper.ts +0 -828
- package/src/concatenation/concatenatable.ts +0 -211
- package/src/concatenation/concatenated-component.ts +0 -471
- package/src/concatenation/index.ts +0 -41
- package/src/concatenation/styles.css +0 -120
- package/src/concatenation/text-optimizer.ts +0 -440
- package/src/concatenation/types.ts +0 -116
- package/src/constants/README.md +0 -339
- package/src/constants/__tests__/frame-utils.test.ts +0 -276
- package/src/constants/__tests__/layout.test.ts +0 -215
- package/src/constants/frame-utils.ts +0 -174
- package/src/constants/index.ts +0 -8
- package/src/constants/layout.ts +0 -120
- package/src/css-classes/component-base.ts +0 -117
- package/src/css-classes/css-class-manager.ts +0 -372
- package/src/css-classes/dom-integration.ts +0 -162
- package/src/css-classes/enhanced-renderer.ts +0 -166
- package/src/css-classes/index.ts +0 -45
- package/src/css-classes/types.ts +0 -73
- package/src/css-classes/utilities.ts +0 -175
- package/src/debug/index.ts +0 -267
- package/src/developer-experience/enhanced-errors.ts +0 -556
- package/src/developer-experience/enhanced-types.ts +0 -427
- package/src/developer-experience/index.ts +0 -220
- package/src/globals.d.ts +0 -43
- package/src/gradients/__tests__/angular-gradient.test.ts +0 -111
- package/src/gradients/__tests__/background-modifier.test.ts +0 -81
- package/src/gradients/__tests__/comprehensive-gradients.test.ts +0 -296
- package/src/gradients/__tests__/gradient-asset.test.ts +0 -144
- package/src/gradients/__tests__/linear-gradient.test.ts +0 -92
- package/src/gradients/__tests__/phase4-features.test.ts +0 -386
- package/src/gradients/__tests__/radial-gradient.test.ts +0 -110
- package/src/gradients/__tests__/repeating-gradients.test.ts +0 -125
- package/src/gradients/__tests__/state-background-modifier.test.ts +0 -340
- package/src/gradients/__tests__/state-gradient-asset.test.ts +0 -262
- package/src/gradients/__tests__/state-gradient-integration.test.ts +0 -277
- package/src/gradients/css-generator.ts +0 -158
- package/src/gradients/examples.ts +0 -632
- package/src/gradients/gradient-asset.ts +0 -30
- package/src/gradients/index.ts +0 -85
- package/src/gradients/performance.ts +0 -521
- package/src/gradients/presets.ts +0 -422
- package/src/gradients/reactive.ts +0 -470
- package/src/gradients/state-gradient-asset.ts +0 -179
- package/src/gradients/types.ts +0 -148
- package/src/gradients/utils.ts +0 -579
- package/src/gradients/validation.ts +0 -489
- package/src/index.ts +0 -168
- package/src/lifecycle/hooks.ts +0 -332
- package/src/modifiers/__tests__/as-html-integration.test.ts +0 -204
- package/src/modifiers/__tests__/as-html.test.ts +0 -437
- package/src/modifiers/__tests__/basic-sanitizer-security.test.ts +0 -294
- package/src/modifiers/__tests__/border.test.ts +0 -371
- package/src/modifiers/__tests__/margin-string-support.test.ts +0 -41
- package/src/modifiers/__tests__/padding-string-support.test.ts +0 -41
- package/src/modifiers/as-html-validator.ts +0 -68
- package/src/modifiers/as-html.ts +0 -216
- package/src/modifiers/attributes.ts +0 -574
- package/src/modifiers/backdrop.ts +0 -290
- package/src/modifiers/background.ts +0 -165
- package/src/modifiers/base.ts +0 -1815
- package/src/modifiers/basic-sanitizer.ts +0 -227
- package/src/modifiers/border.ts +0 -574
- package/src/modifiers/builder.ts +0 -1747
- package/src/modifiers/core.ts +0 -521
- package/src/modifiers/css.ts +0 -148
- package/src/modifiers/effects.ts +0 -412
- package/src/modifiers/elements.ts +0 -541
- package/src/modifiers/filters.ts +0 -501
- package/src/modifiers/flexbox.ts +0 -180
- package/src/modifiers/font.ts +0 -149
- package/src/modifiers/grid.ts +0 -238
- package/src/modifiers/index.ts +0 -481
- package/src/modifiers/margin.ts +0 -218
- package/src/modifiers/padding.ts +0 -318
- package/src/modifiers/registry.ts +0 -444
- package/src/modifiers/responsive/__tests__/advanced-media-queries.test.ts +0 -392
- package/src/modifiers/responsive/__tests__/advanced-utilities.test.ts +0 -368
- package/src/modifiers/responsive/__tests__/comprehensive-browser-tests.test.ts +0 -556
- package/src/modifiers/responsive/__tests__/layout-patterns.test.ts +0 -558
- package/src/modifiers/responsive/advanced-utilities.ts +0 -562
- package/src/modifiers/responsive/breakpoints.ts +0 -330
- package/src/modifiers/responsive/css-generator.ts +0 -432
- package/src/modifiers/responsive/dev-tools.ts +0 -650
- package/src/modifiers/responsive/index.ts +0 -119
- package/src/modifiers/responsive/layout-patterns.ts +0 -592
- package/src/modifiers/responsive/performance.ts +0 -385
- package/src/modifiers/responsive/responsive-builder.ts +0 -620
- package/src/modifiers/responsive/responsive-modifier.ts +0 -410
- package/src/modifiers/responsive/types.ts +0 -226
- package/src/modifiers/responsive/utilities.ts +0 -478
- package/src/modifiers/scroll.ts +0 -297
- package/src/modifiers/shadows.ts +0 -321
- package/src/modifiers/size.ts +0 -208
- package/src/modifiers/text.ts +0 -416
- package/src/modifiers/transformations.ts +0 -640
- package/src/modifiers/transitions.ts +0 -218
- package/src/modifiers/types.ts +0 -889
- package/src/modifiers/typography.ts +0 -341
- package/src/modifiers/utility.ts +0 -209
- package/src/modifiers/utils.ts +0 -413
- package/src/plugins/__tests__/simplified-plugin-system.test.ts +0 -190
- package/src/plugins/component-loader-registry.ts +0 -371
- package/src/plugins/index.ts +0 -61
- package/src/plugins/legacy-adapter.ts +0 -84
- package/src/plugins/simplified-component-registry.ts +0 -130
- package/src/plugins/simplified-error-handler.ts +0 -372
- package/src/plugins/simplified-index.ts +0 -61
- package/src/plugins/simplified-lazy-loader.ts +0 -242
- package/src/plugins/simplified-plugin-manager.ts +0 -93
- package/src/plugins/simplified-tachui-instance.ts +0 -142
- package/src/plugins/simplified-types.ts +0 -79
- package/src/plugins/simplified-utils.ts +0 -118
- package/src/reactive/cleanup.ts +0 -241
- package/src/reactive/computed.ts +0 -281
- package/src/reactive/context.ts +0 -287
- package/src/reactive/effect.ts +0 -194
- package/src/reactive/enhanced-effect.ts +0 -318
- package/src/reactive/enhanced-signal.ts +0 -227
- package/src/reactive/equality.ts +0 -188
- package/src/reactive/globals.d.ts +0 -5
- package/src/reactive/index.ts +0 -150
- package/src/reactive/migration.ts +0 -335
- package/src/reactive/ownership.ts +0 -182
- package/src/reactive/scheduler.ts +0 -300
- package/src/reactive/signal.ts +0 -201
- package/src/reactive/theme.ts +0 -49
- package/src/reactive/types.ts +0 -103
- package/src/reactive/unified-scheduler.ts +0 -357
- package/src/runtime/component-context.ts +0 -343
- package/src/runtime/component.ts +0 -499
- package/src/runtime/context.ts +0 -527
- package/src/runtime/dev-tools.ts +0 -752
- package/src/runtime/development-warnings.ts +0 -114
- package/src/runtime/dom-bridge.ts +0 -570
- package/src/runtime/element-override.ts +0 -282
- package/src/runtime/error-boundary.ts +0 -955
- package/src/runtime/error-recovery.ts +0 -638
- package/src/runtime/error-reporting.ts +0 -808
- package/src/runtime/error-utils.ts +0 -698
- package/src/runtime/index.ts +0 -202
- package/src/runtime/lazy-component.ts +0 -268
- package/src/runtime/lifecycle.ts +0 -10
- package/src/runtime/mounting.ts +0 -17
- package/src/runtime/optimization.ts +0 -13
- package/src/runtime/performance.ts +0 -693
- package/src/runtime/props.ts +0 -434
- package/src/runtime/refs.ts +0 -13
- package/src/runtime/renderer.ts +0 -674
- package/src/runtime/semantic-role-manager.ts +0 -140
- package/src/runtime/types.ts +0 -282
- package/src/state/binding.ts +0 -381
- package/src/state/environment-object.ts +0 -444
- package/src/state/environment.ts +0 -351
- package/src/state/index.ts +0 -179
- package/src/state/observed-object.ts +0 -405
- package/src/state/state-manager.ts +0 -366
- package/src/state/state.ts +0 -339
- package/src/state/types.ts +0 -192
- package/src/sui-compat.ts +0 -163
- package/src/validation/__tests__/phase-1d-integration.test.ts +0 -558
- package/src/validation/advanced-debugging.ts +0 -860
- package/src/validation/build-time/detection.ts +0 -373
- package/src/validation/build-time/index.ts +0 -222
- package/src/validation/build-time/plugins.ts +0 -515
- package/src/validation/build-time/rules.ts +0 -624
- package/src/validation/build-time/transformer.ts +0 -372
- package/src/validation/build-time/types.ts +0 -232
- package/src/validation/comprehensive.ts +0 -1272
- package/src/validation/debug-tools.ts +0 -724
- package/src/validation/developer-experience.ts +0 -712
- package/src/validation/documentation-integration.ts +0 -835
- package/src/validation/enhanced-runtime.ts +0 -765
- package/src/validation/error-reporting.ts +0 -587
- package/src/validation/ide-integration.ts +0 -845
- package/src/validation/index.ts +0 -353
- package/src/validation/lifecycle-validation.ts +0 -636
- package/src/validation/performance-optimizer.ts +0 -599
- package/src/validation/plugin-registration.ts +0 -249
- package/src/validation/production-bypass.ts +0 -466
- package/src/validation/simple.ts +0 -465
- package/src/viewport/adapters/web-adapter.ts +0 -1385
- package/src/viewport/components.ts +0 -505
- package/src/viewport/environment.ts +0 -173
- package/src/viewport/index.ts +0 -290
- package/src/viewport/platform-detection.ts +0 -431
- package/src/viewport/types.ts +0 -371
- package/src/viewport/viewport-manager.ts +0 -979
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"simplified-types.js","sources":["../../src/plugins/simplified-types.ts"],"sourcesContent":["/**\n * Simplified Plugin Types - Phase 1 Implementation\n * \n * Streamlined type definitions for the simplified plugin system.\n * Removes complex configuration schemas, security features, and performance monitoring.\n */\n\nimport type { Component } from '../runtime/types'\nimport type { SimplifiedComponentRegistry } from './simplified-component-registry'\n\n/**\n * Simplified plugin interface with essential properties only\n */\nexport interface TachUIPlugin {\n /** Unique plugin name */\n name: string\n \n /** Plugin version (semver recommended) */\n version: string\n \n /** Plugin description (optional) */\n description?: string\n \n /** Plugin installation function */\n install(instance: TachUIInstance): Promise<void>\n \n /** Plugin uninstallation function (optional) */\n uninstall?(): Promise<void>\n}\n\n/**\n * Simplified TachUI instance interface for plugins\n */\nexport interface TachUIInstance {\n /** Register a component with the framework */\n registerComponent(name: string, component: Component, options?: ComponentRegistrationOptions): void\n \n /** Register a service with the framework */\n registerService(name: string, service: any): void\n \n /** Access to component registry */\n components: SimplifiedComponentRegistry\n \n /** Access to services registry */\n services: Map<string, any>\n}\n\n/**\n * Component registration options (simplified)\n */\nexport interface ComponentRegistrationOptions {\n /** Component category for organization */\n category?: string\n \n /** Tags for component discovery */\n tags?: string[]\n \n /** Whether to overwrite existing component */\n overwrite?: boolean\n}\n\n/**\n * Plugin error class for handling plugin-related errors\n */\nexport class PluginError extends Error {\n constructor(message: string, public code?: string) {\n super(message)\n this.name = 'PluginError'\n }\n}\n\n/**\n * Service registration interface\n */\nexport interface ServiceRegistration {\n name: string\n service: any\n plugin?: string\n}"],"names":["PluginError","message","code"],"mappings":"AAgEO,MAAMA,UAAoB,MAAM;AAAA,EACrC,YAAYC,GAAwBC,GAAe;AACjD,UAAMD,CAAO,GADqB,KAAA,OAAAC,GAElC,KAAK,OAAO;AAAA,EACd;AACF;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function o(e){return!e||typeof e!="string"?!1:/^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/.test(e)}function u(e,a){if(!o(e)||!o(a))throw new Error("Invalid semantic version format");const t=i=>{const[s,l]=i.split("-"),[m,p,c]=s.split(".").map(Number);return{major:m,minor:p,patch:c,prerelease:l}},r=t(e),n=t(a);return r.major!==n.major?r.major<n.major?-1:1:r.minor!==n.minor?r.minor<n.minor?-1:1:r.patch!==n.patch?r.patch<n.patch?-1:1:r.prerelease&&n.prerelease?r.prerelease<n.prerelease?-1:r.prerelease>n.prerelease?1:0:r.prerelease&&!n.prerelease?-1:!r.prerelease&&n.prerelease?1:0}function f(e){return!e||typeof e!="string"?!1:/^(@[a-z0-9-~][a-z0-9-._~]*\/)?[a-z0-9-~][a-z0-9-._~]*$/.test(e)}function g(e){return e.replace(/^@[^/]+\//,"")}const v={log(e,a,t){process.env.NODE_ENV==="development"&&(console.group(`🔌 [${e}]`),console.log(a),t&&console.log("Data:",t),console.groupEnd())},warn(e,a){process.env.NODE_ENV==="development"&&console.warn(`⚠️ [${e}] ${a}`)}};exports.PluginDevUtils=v;exports.compareSemver=u;exports.normalizePluginName=g;exports.validatePluginName=f;exports.validateSemver=o;
|
|
2
|
-
//# sourceMappingURL=simplified-utils.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"simplified-utils.cjs","sources":["../../src/plugins/simplified-utils.ts"],"sourcesContent":["/**\n * Simplified Plugin Utilities - Phase 1 Implementation\n * \n * Essential utility functions only, removing complex debounce/throttle/deepClone\n * functionality that adds unnecessary complexity for simple plugin use cases.\n */\n\n/**\n * Validates a semantic version string\n */\nexport function validateSemver(version: string): boolean {\n if (!version || typeof version !== 'string') {\n return false\n }\n\n const semverRegex =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/\n return semverRegex.test(version)\n}\n\n/**\n * Compares two semantic version strings\n * @param a First version\n * @param b Second version\n * @returns -1 if a < b, 0 if a === b, 1 if a > b\n */\nexport function compareSemver(a: string, b: string): number {\n if (!validateSemver(a) || !validateSemver(b)) {\n throw new Error('Invalid semantic version format')\n }\n\n const parseVersion = (version: string) => {\n const [main, prerelease] = version.split('-')\n const [major, minor, patch] = main.split('.').map(Number)\n return { major, minor, patch, prerelease }\n }\n\n const versionA = parseVersion(a)\n const versionB = parseVersion(b)\n\n // Compare major version\n if (versionA.major !== versionB.major) {\n return versionA.major < versionB.major ? -1 : 1\n }\n\n // Compare minor version\n if (versionA.minor !== versionB.minor) {\n return versionA.minor < versionB.minor ? -1 : 1\n }\n\n // Compare patch version\n if (versionA.patch !== versionB.patch) {\n return versionA.patch < versionB.patch ? -1 : 1\n }\n\n // Compare prerelease versions\n if (versionA.prerelease && versionB.prerelease) {\n return versionA.prerelease < versionB.prerelease\n ? -1\n : versionA.prerelease > versionB.prerelease\n ? 1\n : 0\n }\n\n // Version with prerelease is less than version without\n if (versionA.prerelease && !versionB.prerelease) return -1\n if (!versionA.prerelease && versionB.prerelease) return 1\n\n return 0\n}\n\n/**\n * Validates plugin name format\n */\nexport function validatePluginName(name: string): boolean {\n if (!name || typeof name !== 'string') {\n return false\n }\n\n // Allow scoped packages (@scope/name) or simple names\n const nameRegex = /^(@[a-z0-9-~][a-z0-9-._~]*\\/)?[a-z0-9-~][a-z0-9-._~]*$/\n return nameRegex.test(name)\n}\n\n/**\n * Normalizes a plugin name (removes @scope/ prefix for ID generation)\n */\nexport function normalizePluginName(name: string): string {\n return name.replace(/^@[^/]+\\//, '')\n}\n\n/**\n * Simple plugin development utilities for debugging\n */\nexport const PluginDevUtils = {\n /**\n * Logs plugin debug information in development mode\n */\n log(pluginName: string, message: string, data?: any): void {\n if (process.env.NODE_ENV === 'development') {\n console.group(`🔌 [${pluginName}]`)\n console.log(message)\n if (data) {\n console.log('Data:', data)\n }\n console.groupEnd()\n }\n },\n\n /**\n * Creates a development-only warning\n */\n warn(pluginName: string, message: string): void {\n if (process.env.NODE_ENV === 'development') {\n console.warn(`⚠️ [${pluginName}] ${message}`)\n }\n },\n}"],"names":["validateSemver","version","compareSemver","a","b","parseVersion","main","prerelease","major","minor","patch","versionA","versionB","validatePluginName","name","normalizePluginName","PluginDevUtils","pluginName","message","data"],"mappings":"gFAUO,SAASA,EAAeC,EAA0B,CACvD,MAAI,CAACA,GAAW,OAAOA,GAAY,SAC1B,GAIP,sLACiB,KAAKA,CAAO,CACjC,CAQO,SAASC,EAAcC,EAAWC,EAAmB,CAC1D,GAAI,CAACJ,EAAeG,CAAC,GAAK,CAACH,EAAeI,CAAC,EACzC,MAAM,IAAI,MAAM,iCAAiC,EAGnD,MAAMC,EAAgBJ,GAAoB,CACxC,KAAM,CAACK,EAAMC,CAAU,EAAIN,EAAQ,MAAM,GAAG,EACtC,CAACO,EAAOC,EAAOC,CAAK,EAAIJ,EAAK,MAAM,GAAG,EAAE,IAAI,MAAM,EACxD,MAAO,CAAE,MAAAE,EAAO,MAAAC,EAAO,MAAAC,EAAO,WAAAH,CAAA,CAChC,EAEMI,EAAWN,EAAaF,CAAC,EACzBS,EAAWP,EAAaD,CAAC,EAG/B,OAAIO,EAAS,QAAUC,EAAS,MACvBD,EAAS,MAAQC,EAAS,MAAQ,GAAK,EAI5CD,EAAS,QAAUC,EAAS,MACvBD,EAAS,MAAQC,EAAS,MAAQ,GAAK,EAI5CD,EAAS,QAAUC,EAAS,MACvBD,EAAS,MAAQC,EAAS,MAAQ,GAAK,EAI5CD,EAAS,YAAcC,EAAS,WAC3BD,EAAS,WAAaC,EAAS,WAClC,GACAD,EAAS,WAAaC,EAAS,WAC7B,EACA,EAIJD,EAAS,YAAc,CAACC,EAAS,WAAmB,GACpD,CAACD,EAAS,YAAcC,EAAS,WAAmB,EAEjD,CACT,CAKO,SAASC,EAAmBC,EAAuB,CACxD,MAAI,CAACA,GAAQ,OAAOA,GAAS,SACpB,GAIS,yDACD,KAAKA,CAAI,CAC5B,CAKO,SAASC,EAAoBD,EAAsB,CACxD,OAAOA,EAAK,QAAQ,YAAa,EAAE,CACrC,CAKO,MAAME,EAAiB,CAI5B,IAAIC,EAAoBC,EAAiBC,EAAkB,CACrD,QAAQ,IAAI,WAAa,gBAC3B,QAAQ,MAAM,OAAOF,CAAU,GAAG,EAClC,QAAQ,IAAIC,CAAO,EACfC,GACF,QAAQ,IAAI,QAASA,CAAI,EAE3B,QAAQ,SAAA,EAEZ,EAKA,KAAKF,EAAoBC,EAAuB,CAC1C,QAAQ,IAAI,WAAa,eAC3B,QAAQ,KAAK,QAAQD,CAAU,KAAKC,CAAO,EAAE,CAEjD,CACF"}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
function t(e) {
|
|
2
|
-
return !e || typeof e != "string" ? !1 : /^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/.test(e);
|
|
3
|
-
}
|
|
4
|
-
function u(e, o) {
|
|
5
|
-
if (!t(e) || !t(o))
|
|
6
|
-
throw new Error("Invalid semantic version format");
|
|
7
|
-
const a = (s) => {
|
|
8
|
-
const [i, l] = s.split("-"), [p, c, m] = i.split(".").map(Number);
|
|
9
|
-
return { major: p, minor: c, patch: m, prerelease: l };
|
|
10
|
-
}, r = a(e), n = a(o);
|
|
11
|
-
return r.major !== n.major ? r.major < n.major ? -1 : 1 : r.minor !== n.minor ? r.minor < n.minor ? -1 : 1 : r.patch !== n.patch ? r.patch < n.patch ? -1 : 1 : r.prerelease && n.prerelease ? r.prerelease < n.prerelease ? -1 : r.prerelease > n.prerelease ? 1 : 0 : r.prerelease && !n.prerelease ? -1 : !r.prerelease && n.prerelease ? 1 : 0;
|
|
12
|
-
}
|
|
13
|
-
function f(e) {
|
|
14
|
-
return !e || typeof e != "string" ? !1 : /^(@[a-z0-9-~][a-z0-9-._~]*\/)?[a-z0-9-~][a-z0-9-._~]*$/.test(e);
|
|
15
|
-
}
|
|
16
|
-
function g(e) {
|
|
17
|
-
return e.replace(/^@[^/]+\//, "");
|
|
18
|
-
}
|
|
19
|
-
const v = {
|
|
20
|
-
/**
|
|
21
|
-
* Logs plugin debug information in development mode
|
|
22
|
-
*/
|
|
23
|
-
log(e, o, a) {
|
|
24
|
-
process.env.NODE_ENV === "development" && (console.group(`🔌 [${e}]`), console.log(o), a && console.log("Data:", a), console.groupEnd());
|
|
25
|
-
},
|
|
26
|
-
/**
|
|
27
|
-
* Creates a development-only warning
|
|
28
|
-
*/
|
|
29
|
-
warn(e, o) {
|
|
30
|
-
process.env.NODE_ENV === "development" && console.warn(`⚠️ [${e}] ${o}`);
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
export {
|
|
34
|
-
v as PluginDevUtils,
|
|
35
|
-
u as compareSemver,
|
|
36
|
-
g as normalizePluginName,
|
|
37
|
-
f as validatePluginName,
|
|
38
|
-
t as validateSemver
|
|
39
|
-
};
|
|
40
|
-
//# sourceMappingURL=simplified-utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"simplified-utils.js","sources":["../../src/plugins/simplified-utils.ts"],"sourcesContent":["/**\n * Simplified Plugin Utilities - Phase 1 Implementation\n * \n * Essential utility functions only, removing complex debounce/throttle/deepClone\n * functionality that adds unnecessary complexity for simple plugin use cases.\n */\n\n/**\n * Validates a semantic version string\n */\nexport function validateSemver(version: string): boolean {\n if (!version || typeof version !== 'string') {\n return false\n }\n\n const semverRegex =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/\n return semverRegex.test(version)\n}\n\n/**\n * Compares two semantic version strings\n * @param a First version\n * @param b Second version\n * @returns -1 if a < b, 0 if a === b, 1 if a > b\n */\nexport function compareSemver(a: string, b: string): number {\n if (!validateSemver(a) || !validateSemver(b)) {\n throw new Error('Invalid semantic version format')\n }\n\n const parseVersion = (version: string) => {\n const [main, prerelease] = version.split('-')\n const [major, minor, patch] = main.split('.').map(Number)\n return { major, minor, patch, prerelease }\n }\n\n const versionA = parseVersion(a)\n const versionB = parseVersion(b)\n\n // Compare major version\n if (versionA.major !== versionB.major) {\n return versionA.major < versionB.major ? -1 : 1\n }\n\n // Compare minor version\n if (versionA.minor !== versionB.minor) {\n return versionA.minor < versionB.minor ? -1 : 1\n }\n\n // Compare patch version\n if (versionA.patch !== versionB.patch) {\n return versionA.patch < versionB.patch ? -1 : 1\n }\n\n // Compare prerelease versions\n if (versionA.prerelease && versionB.prerelease) {\n return versionA.prerelease < versionB.prerelease\n ? -1\n : versionA.prerelease > versionB.prerelease\n ? 1\n : 0\n }\n\n // Version with prerelease is less than version without\n if (versionA.prerelease && !versionB.prerelease) return -1\n if (!versionA.prerelease && versionB.prerelease) return 1\n\n return 0\n}\n\n/**\n * Validates plugin name format\n */\nexport function validatePluginName(name: string): boolean {\n if (!name || typeof name !== 'string') {\n return false\n }\n\n // Allow scoped packages (@scope/name) or simple names\n const nameRegex = /^(@[a-z0-9-~][a-z0-9-._~]*\\/)?[a-z0-9-~][a-z0-9-._~]*$/\n return nameRegex.test(name)\n}\n\n/**\n * Normalizes a plugin name (removes @scope/ prefix for ID generation)\n */\nexport function normalizePluginName(name: string): string {\n return name.replace(/^@[^/]+\\//, '')\n}\n\n/**\n * Simple plugin development utilities for debugging\n */\nexport const PluginDevUtils = {\n /**\n * Logs plugin debug information in development mode\n */\n log(pluginName: string, message: string, data?: any): void {\n if (process.env.NODE_ENV === 'development') {\n console.group(`🔌 [${pluginName}]`)\n console.log(message)\n if (data) {\n console.log('Data:', data)\n }\n console.groupEnd()\n }\n },\n\n /**\n * Creates a development-only warning\n */\n warn(pluginName: string, message: string): void {\n if (process.env.NODE_ENV === 'development') {\n console.warn(`⚠️ [${pluginName}] ${message}`)\n }\n },\n}"],"names":["validateSemver","version","compareSemver","a","b","parseVersion","main","prerelease","major","minor","patch","versionA","versionB","validatePluginName","name","normalizePluginName","PluginDevUtils","pluginName","message","data"],"mappings":"AAUO,SAASA,EAAeC,GAA0B;AACvD,SAAI,CAACA,KAAW,OAAOA,KAAY,WAC1B,KAIP,sLACiB,KAAKA,CAAO;AACjC;AAQO,SAASC,EAAcC,GAAWC,GAAmB;AAC1D,MAAI,CAACJ,EAAeG,CAAC,KAAK,CAACH,EAAeI,CAAC;AACzC,UAAM,IAAI,MAAM,iCAAiC;AAGnD,QAAMC,IAAe,CAACJ,MAAoB;AACxC,UAAM,CAACK,GAAMC,CAAU,IAAIN,EAAQ,MAAM,GAAG,GACtC,CAACO,GAAOC,GAAOC,CAAK,IAAIJ,EAAK,MAAM,GAAG,EAAE,IAAI,MAAM;AACxD,WAAO,EAAE,OAAAE,GAAO,OAAAC,GAAO,OAAAC,GAAO,YAAAH,EAAA;AAAA,EAChC,GAEMI,IAAWN,EAAaF,CAAC,GACzBS,IAAWP,EAAaD,CAAC;AAG/B,SAAIO,EAAS,UAAUC,EAAS,QACvBD,EAAS,QAAQC,EAAS,QAAQ,KAAK,IAI5CD,EAAS,UAAUC,EAAS,QACvBD,EAAS,QAAQC,EAAS,QAAQ,KAAK,IAI5CD,EAAS,UAAUC,EAAS,QACvBD,EAAS,QAAQC,EAAS,QAAQ,KAAK,IAI5CD,EAAS,cAAcC,EAAS,aAC3BD,EAAS,aAAaC,EAAS,aAClC,KACAD,EAAS,aAAaC,EAAS,aAC7B,IACA,IAIJD,EAAS,cAAc,CAACC,EAAS,aAAmB,KACpD,CAACD,EAAS,cAAcC,EAAS,aAAmB,IAEjD;AACT;AAKO,SAASC,EAAmBC,GAAuB;AACxD,SAAI,CAACA,KAAQ,OAAOA,KAAS,WACpB,KAIS,yDACD,KAAKA,CAAI;AAC5B;AAKO,SAASC,EAAoBD,GAAsB;AACxD,SAAOA,EAAK,QAAQ,aAAa,EAAE;AACrC;AAKO,MAAME,IAAiB;AAAA;AAAA;AAAA;AAAA,EAI5B,IAAIC,GAAoBC,GAAiBC,GAAkB;AACzD,IAAI,QAAQ,IAAI,aAAa,kBAC3B,QAAQ,MAAM,OAAOF,CAAU,GAAG,GAClC,QAAQ,IAAIC,CAAO,GACfC,KACF,QAAQ,IAAI,SAASA,CAAI,GAE3B,QAAQ,SAAA;AAAA,EAEZ;AAAA;AAAA;AAAA;AAAA,EAKA,KAAKF,GAAoBC,GAAuB;AAC9C,IAAI,QAAQ,IAAI,aAAa,iBAC3B,QAAQ,KAAK,QAAQD,CAAU,KAAKC,CAAO,EAAE;AAAA,EAEjD;AACF;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./context.cjs");function r(e){const n=s.getCurrentOwner();n&&!n.disposed?n.cleanups.push(e):__DEV__&&console.warn("onCleanup called outside of reactive context")}function c(e){"dispose"in e&&typeof e.dispose=="function"&&e.dispose()}function i(e){const[n,t]=e();return r(t),n}function u(){const e=[];let n=!1;return{add(t){if(n){__DEV__&&console.warn("Adding cleanup to disposed group");return}e.push(t)},dispose(){if(!n){n=!0;for(const t of e)try{t()}catch(o){console.error("Error in cleanup function:",o)}e.length=0}},get disposed(){return n}}}function a(e,n){const t=setTimeout(e,n);return r(()=>clearTimeout(t)),t}function l(e,n){const t=setInterval(e,n);return r(()=>clearInterval(t)),t}function p(e,n,t,o){e.addEventListener(n,t,o),r(()=>e.removeEventListener(n,t,o))}typeof globalThis.__DEV__>"u"&&(globalThis.__DEV__=process.env.NODE_ENV!=="production");exports.createCleanupGroup=u;exports.createEventListener=p;exports.createInterval=l;exports.createResource=i;exports.createTimeout=a;exports.dispose=c;exports.onCleanup=r;
|
|
2
|
-
//# sourceMappingURL=cleanup.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup.cjs","sources":["../../src/reactive/cleanup.ts"],"sourcesContent":["/**\n * Cleanup and disposal utilities for reactive system\n *\n * Provides memory management, cleanup functions, and disposal\n * utilities to prevent memory leaks in reactive computations.\n */\n\nimport { getCurrentOwner } from './context'\nimport type { CleanupFunction, Owner } from './types'\n\n/**\n * Add a cleanup function to the current reactive context\n *\n * @param fn Cleanup function to run when the context is disposed\n *\n * @example\n * ```typescript\n * createEffect(() => {\n * const interval = setInterval(() => {\n * console.log('tick')\n * }, 1000)\n *\n * onCleanup(() => {\n * clearInterval(interval)\n * })\n * })\n * ```\n */\nexport function onCleanup(fn: CleanupFunction): void {\n const owner = getCurrentOwner()\n if (owner && !owner.disposed) {\n owner.cleanups.push(fn)\n } else if (__DEV__) {\n console.warn('onCleanup called outside of reactive context')\n }\n}\n\n/**\n * Dispose a reactive owner and all its children\n *\n * @param owner The owner to dispose\n */\nexport function dispose(owner: Owner): void {\n if ('dispose' in owner && typeof owner.dispose === 'function') {\n owner.dispose()\n }\n}\n\n/**\n * Create a disposable resource with automatic cleanup\n *\n * @param fn Function that creates and returns a resource and its cleanup\n * @returns The created resource\n *\n * @example\n * ```typescript\n * const timer = createResource(() => {\n * const id = setInterval(() => console.log('tick'), 1000)\n * return [id, () => clearInterval(id)]\n * })\n * ```\n */\nexport function createResource<T>(fn: () => [T, CleanupFunction]): T {\n const [resource, cleanup] = fn()\n onCleanup(cleanup)\n return resource\n}\n\n/**\n * Create a cleanup group that can be disposed manually\n *\n * @returns Cleanup group with dispose function\n *\n * @example\n * ```typescript\n * const group = createCleanupGroup()\n *\n * group.add(() => console.log('cleanup 1'))\n * group.add(() => console.log('cleanup 2'))\n *\n * // Later...\n * group.dispose() // Runs both cleanup functions\n * ```\n */\nexport function createCleanupGroup(): {\n add: (fn: CleanupFunction) => void\n dispose: () => void\n disposed: boolean\n} {\n const cleanups: CleanupFunction[] = []\n let disposed = false\n\n return {\n add(fn: CleanupFunction) {\n if (disposed) {\n if (__DEV__) {\n console.warn('Adding cleanup to disposed group')\n }\n return\n }\n cleanups.push(fn)\n },\n\n dispose() {\n if (disposed) return\n disposed = true\n\n for (const cleanup of cleanups) {\n try {\n cleanup()\n } catch (error) {\n console.error('Error in cleanup function:', error)\n }\n }\n cleanups.length = 0\n },\n\n get disposed() {\n return disposed\n },\n }\n}\n\n/**\n * Create a weak disposal tracker using WeakRef and FinalizationRegistry\n * for automatic cleanup of unreferenced objects\n */\nexport function createWeakDisposal<T extends object>(\n target: T,\n cleanup: CleanupFunction\n): WeakRef<T> {\n const weakRef = new WeakRef(target)\n\n if (typeof FinalizationRegistry !== 'undefined') {\n const registry = new FinalizationRegistry(cleanup)\n registry.register(target, cleanup)\n }\n\n return weakRef\n}\n\n/**\n * Defer a cleanup function to run after the current reactive cycle\n *\n * @param fn Cleanup function to defer\n */\nexport function deferCleanup(fn: CleanupFunction): void {\n queueMicrotask(() => {\n try {\n fn()\n } catch (error) {\n console.error('Error in deferred cleanup:', error)\n }\n })\n}\n\n/**\n * Create a cleanup function that only runs once\n *\n * @param fn Cleanup function\n * @returns Cleanup function that only runs once\n */\nexport function createOnceCleanup(fn: CleanupFunction): CleanupFunction {\n let hasRun = false\n\n return () => {\n if (hasRun) return\n hasRun = true\n fn()\n }\n}\n\n/**\n * Create a timeout with automatic cleanup\n *\n * @param fn Function to run after timeout\n * @param delay Delay in milliseconds\n * @returns Timeout ID\n */\nexport function createTimeout(fn: () => void, delay: number): NodeJS.Timeout {\n const id = setTimeout(fn, delay)\n onCleanup(() => clearTimeout(id))\n return id\n}\n\n/**\n * Create an interval with automatic cleanup\n *\n * @param fn Function to run on interval\n * @param delay Delay in milliseconds\n * @returns Interval ID\n */\nexport function createInterval(fn: () => void, delay: number): NodeJS.Timeout {\n const id = setInterval(fn, delay)\n onCleanup(() => clearInterval(id))\n return id\n}\n\n/**\n * Create an event listener with automatic cleanup\n *\n * @param target Event target\n * @param event Event name\n * @param handler Event handler\n * @param options Event listener options\n */\nexport function createEventListener<K extends keyof WindowEventMap>(\n target: Window,\n event: K,\n handler: (event: WindowEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener<K extends keyof DocumentEventMap>(\n target: Document,\n event: K,\n handler: (event: DocumentEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener<K extends keyof HTMLElementEventMap>(\n target: HTMLElement,\n event: K,\n handler: (event: HTMLElementEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener(\n target: EventTarget,\n event: string,\n handler: (event: Event) => void,\n options?: AddEventListenerOptions\n): void {\n target.addEventListener(event, handler, options)\n onCleanup(() => target.removeEventListener(event, handler, options))\n}\n\n// Development mode flag - simplified approach\nif (typeof (globalThis as any).__DEV__ === 'undefined') {\n ;(globalThis as any).__DEV__ = process.env.NODE_ENV !== 'production'\n}\n\n// Re-export types\nexport type { CleanupFunction }\n"],"names":["onCleanup","fn","owner","getCurrentOwner","dispose","createResource","resource","cleanup","createCleanupGroup","cleanups","disposed","error","createTimeout","delay","id","createInterval","createEventListener","target","event","handler","options"],"mappings":"iHA4BO,SAASA,EAAUC,EAA2B,CACnD,MAAMC,EAAQC,EAAAA,gBAAA,EACVD,GAAS,CAACA,EAAM,SAClBA,EAAM,SAAS,KAAKD,CAAE,EACb,SACT,QAAQ,KAAK,8CAA8C,CAE/D,CAOO,SAASG,EAAQF,EAAoB,CACtC,YAAaA,GAAS,OAAOA,EAAM,SAAY,YACjDA,EAAM,QAAA,CAEV,CAgBO,SAASG,EAAkBJ,EAAmC,CACnE,KAAM,CAACK,EAAUC,CAAO,EAAIN,EAAA,EAC5B,OAAAD,EAAUO,CAAO,EACVD,CACT,CAkBO,SAASE,GAId,CACA,MAAMC,EAA8B,CAAA,EACpC,IAAIC,EAAW,GAEf,MAAO,CACL,IAAIT,EAAqB,CACvB,GAAIS,EAAU,CACR,SACF,QAAQ,KAAK,kCAAkC,EAEjD,MACF,CACAD,EAAS,KAAKR,CAAE,CAClB,EAEA,SAAU,CACR,GAAI,CAAAS,EACJ,CAAAA,EAAW,GAEX,UAAWH,KAAWE,EACpB,GAAI,CACFF,EAAA,CACF,OAASI,EAAO,CACd,QAAQ,MAAM,6BAA8BA,CAAK,CACnD,CAEFF,EAAS,OAAS,EACpB,EAEA,IAAI,UAAW,CACb,OAAOC,CACT,CAAA,CAEJ,CA0DO,SAASE,EAAcX,EAAgBY,EAA+B,CAC3E,MAAMC,EAAK,WAAWb,EAAIY,CAAK,EAC/B,OAAAb,EAAU,IAAM,aAAac,CAAE,CAAC,EACzBA,CACT,CASO,SAASC,EAAed,EAAgBY,EAA+B,CAC5E,MAAMC,EAAK,YAAYb,EAAIY,CAAK,EAChC,OAAAb,EAAU,IAAM,cAAcc,CAAE,CAAC,EAC1BA,CACT,CA4BO,SAASE,EACdC,EACAC,EACAC,EACAC,EACM,CACNH,EAAO,iBAAiBC,EAAOC,EAASC,CAAO,EAC/CpB,EAAU,IAAMiB,EAAO,oBAAoBC,EAAOC,EAASC,CAAO,CAAC,CACrE,CAGI,OAAQ,WAAmB,QAAY,MACvC,WAAmB,QAAU,QAAQ,IAAI,WAAa"}
|
package/dist/reactive/cleanup.js
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { getCurrentOwner as s } from "./context.js";
|
|
2
|
-
function r(e) {
|
|
3
|
-
const n = s();
|
|
4
|
-
n && !n.disposed ? n.cleanups.push(e) : __DEV__ && console.warn("onCleanup called outside of reactive context");
|
|
5
|
-
}
|
|
6
|
-
function c(e) {
|
|
7
|
-
"dispose" in e && typeof e.dispose == "function" && e.dispose();
|
|
8
|
-
}
|
|
9
|
-
function u(e) {
|
|
10
|
-
const [n, o] = e();
|
|
11
|
-
return r(o), n;
|
|
12
|
-
}
|
|
13
|
-
function a() {
|
|
14
|
-
const e = [];
|
|
15
|
-
let n = !1;
|
|
16
|
-
return {
|
|
17
|
-
add(o) {
|
|
18
|
-
if (n) {
|
|
19
|
-
__DEV__ && console.warn("Adding cleanup to disposed group");
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
e.push(o);
|
|
23
|
-
},
|
|
24
|
-
dispose() {
|
|
25
|
-
if (!n) {
|
|
26
|
-
n = !0;
|
|
27
|
-
for (const o of e)
|
|
28
|
-
try {
|
|
29
|
-
o();
|
|
30
|
-
} catch (t) {
|
|
31
|
-
console.error("Error in cleanup function:", t);
|
|
32
|
-
}
|
|
33
|
-
e.length = 0;
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
get disposed() {
|
|
37
|
-
return n;
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
function p(e, n) {
|
|
42
|
-
const o = setTimeout(e, n);
|
|
43
|
-
return r(() => clearTimeout(o)), o;
|
|
44
|
-
}
|
|
45
|
-
function l(e, n) {
|
|
46
|
-
const o = setInterval(e, n);
|
|
47
|
-
return r(() => clearInterval(o)), o;
|
|
48
|
-
}
|
|
49
|
-
function d(e, n, o, t) {
|
|
50
|
-
e.addEventListener(n, o, t), r(() => e.removeEventListener(n, o, t));
|
|
51
|
-
}
|
|
52
|
-
typeof globalThis.__DEV__ > "u" && (globalThis.__DEV__ = process.env.NODE_ENV !== "production");
|
|
53
|
-
export {
|
|
54
|
-
a as createCleanupGroup,
|
|
55
|
-
d as createEventListener,
|
|
56
|
-
l as createInterval,
|
|
57
|
-
u as createResource,
|
|
58
|
-
p as createTimeout,
|
|
59
|
-
c as dispose,
|
|
60
|
-
r as onCleanup
|
|
61
|
-
};
|
|
62
|
-
//# sourceMappingURL=cleanup.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup.js","sources":["../../src/reactive/cleanup.ts"],"sourcesContent":["/**\n * Cleanup and disposal utilities for reactive system\n *\n * Provides memory management, cleanup functions, and disposal\n * utilities to prevent memory leaks in reactive computations.\n */\n\nimport { getCurrentOwner } from './context'\nimport type { CleanupFunction, Owner } from './types'\n\n/**\n * Add a cleanup function to the current reactive context\n *\n * @param fn Cleanup function to run when the context is disposed\n *\n * @example\n * ```typescript\n * createEffect(() => {\n * const interval = setInterval(() => {\n * console.log('tick')\n * }, 1000)\n *\n * onCleanup(() => {\n * clearInterval(interval)\n * })\n * })\n * ```\n */\nexport function onCleanup(fn: CleanupFunction): void {\n const owner = getCurrentOwner()\n if (owner && !owner.disposed) {\n owner.cleanups.push(fn)\n } else if (__DEV__) {\n console.warn('onCleanup called outside of reactive context')\n }\n}\n\n/**\n * Dispose a reactive owner and all its children\n *\n * @param owner The owner to dispose\n */\nexport function dispose(owner: Owner): void {\n if ('dispose' in owner && typeof owner.dispose === 'function') {\n owner.dispose()\n }\n}\n\n/**\n * Create a disposable resource with automatic cleanup\n *\n * @param fn Function that creates and returns a resource and its cleanup\n * @returns The created resource\n *\n * @example\n * ```typescript\n * const timer = createResource(() => {\n * const id = setInterval(() => console.log('tick'), 1000)\n * return [id, () => clearInterval(id)]\n * })\n * ```\n */\nexport function createResource<T>(fn: () => [T, CleanupFunction]): T {\n const [resource, cleanup] = fn()\n onCleanup(cleanup)\n return resource\n}\n\n/**\n * Create a cleanup group that can be disposed manually\n *\n * @returns Cleanup group with dispose function\n *\n * @example\n * ```typescript\n * const group = createCleanupGroup()\n *\n * group.add(() => console.log('cleanup 1'))\n * group.add(() => console.log('cleanup 2'))\n *\n * // Later...\n * group.dispose() // Runs both cleanup functions\n * ```\n */\nexport function createCleanupGroup(): {\n add: (fn: CleanupFunction) => void\n dispose: () => void\n disposed: boolean\n} {\n const cleanups: CleanupFunction[] = []\n let disposed = false\n\n return {\n add(fn: CleanupFunction) {\n if (disposed) {\n if (__DEV__) {\n console.warn('Adding cleanup to disposed group')\n }\n return\n }\n cleanups.push(fn)\n },\n\n dispose() {\n if (disposed) return\n disposed = true\n\n for (const cleanup of cleanups) {\n try {\n cleanup()\n } catch (error) {\n console.error('Error in cleanup function:', error)\n }\n }\n cleanups.length = 0\n },\n\n get disposed() {\n return disposed\n },\n }\n}\n\n/**\n * Create a weak disposal tracker using WeakRef and FinalizationRegistry\n * for automatic cleanup of unreferenced objects\n */\nexport function createWeakDisposal<T extends object>(\n target: T,\n cleanup: CleanupFunction\n): WeakRef<T> {\n const weakRef = new WeakRef(target)\n\n if (typeof FinalizationRegistry !== 'undefined') {\n const registry = new FinalizationRegistry(cleanup)\n registry.register(target, cleanup)\n }\n\n return weakRef\n}\n\n/**\n * Defer a cleanup function to run after the current reactive cycle\n *\n * @param fn Cleanup function to defer\n */\nexport function deferCleanup(fn: CleanupFunction): void {\n queueMicrotask(() => {\n try {\n fn()\n } catch (error) {\n console.error('Error in deferred cleanup:', error)\n }\n })\n}\n\n/**\n * Create a cleanup function that only runs once\n *\n * @param fn Cleanup function\n * @returns Cleanup function that only runs once\n */\nexport function createOnceCleanup(fn: CleanupFunction): CleanupFunction {\n let hasRun = false\n\n return () => {\n if (hasRun) return\n hasRun = true\n fn()\n }\n}\n\n/**\n * Create a timeout with automatic cleanup\n *\n * @param fn Function to run after timeout\n * @param delay Delay in milliseconds\n * @returns Timeout ID\n */\nexport function createTimeout(fn: () => void, delay: number): NodeJS.Timeout {\n const id = setTimeout(fn, delay)\n onCleanup(() => clearTimeout(id))\n return id\n}\n\n/**\n * Create an interval with automatic cleanup\n *\n * @param fn Function to run on interval\n * @param delay Delay in milliseconds\n * @returns Interval ID\n */\nexport function createInterval(fn: () => void, delay: number): NodeJS.Timeout {\n const id = setInterval(fn, delay)\n onCleanup(() => clearInterval(id))\n return id\n}\n\n/**\n * Create an event listener with automatic cleanup\n *\n * @param target Event target\n * @param event Event name\n * @param handler Event handler\n * @param options Event listener options\n */\nexport function createEventListener<K extends keyof WindowEventMap>(\n target: Window,\n event: K,\n handler: (event: WindowEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener<K extends keyof DocumentEventMap>(\n target: Document,\n event: K,\n handler: (event: DocumentEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener<K extends keyof HTMLElementEventMap>(\n target: HTMLElement,\n event: K,\n handler: (event: HTMLElementEventMap[K]) => void,\n options?: AddEventListenerOptions\n): void\nexport function createEventListener(\n target: EventTarget,\n event: string,\n handler: (event: Event) => void,\n options?: AddEventListenerOptions\n): void {\n target.addEventListener(event, handler, options)\n onCleanup(() => target.removeEventListener(event, handler, options))\n}\n\n// Development mode flag - simplified approach\nif (typeof (globalThis as any).__DEV__ === 'undefined') {\n ;(globalThis as any).__DEV__ = process.env.NODE_ENV !== 'production'\n}\n\n// Re-export types\nexport type { CleanupFunction }\n"],"names":["onCleanup","fn","owner","getCurrentOwner","dispose","createResource","resource","cleanup","createCleanupGroup","cleanups","disposed","error","createTimeout","delay","id","createInterval","createEventListener","target","event","handler","options"],"mappings":";AA4BO,SAASA,EAAUC,GAA2B;AACnD,QAAMC,IAAQC,EAAA;AACd,EAAID,KAAS,CAACA,EAAM,WAClBA,EAAM,SAAS,KAAKD,CAAE,IACb,WACT,QAAQ,KAAK,8CAA8C;AAE/D;AAOO,SAASG,EAAQF,GAAoB;AAC1C,EAAI,aAAaA,KAAS,OAAOA,EAAM,WAAY,cACjDA,EAAM,QAAA;AAEV;AAgBO,SAASG,EAAkBJ,GAAmC;AACnE,QAAM,CAACK,GAAUC,CAAO,IAAIN,EAAA;AAC5B,SAAAD,EAAUO,CAAO,GACVD;AACT;AAkBO,SAASE,IAId;AACA,QAAMC,IAA8B,CAAA;AACpC,MAAIC,IAAW;AAEf,SAAO;AAAA,IACL,IAAIT,GAAqB;AACvB,UAAIS,GAAU;AACZ,QAAI,WACF,QAAQ,KAAK,kCAAkC;AAEjD;AAAA,MACF;AACA,MAAAD,EAAS,KAAKR,CAAE;AAAA,IAClB;AAAA,IAEA,UAAU;AACR,UAAI,CAAAS,GACJ;AAAA,QAAAA,IAAW;AAEX,mBAAWH,KAAWE;AACpB,cAAI;AACF,YAAAF,EAAA;AAAA,UACF,SAASI,GAAO;AACd,oBAAQ,MAAM,8BAA8BA,CAAK;AAAA,UACnD;AAEF,QAAAF,EAAS,SAAS;AAAA;AAAA,IACpB;AAAA,IAEA,IAAI,WAAW;AACb,aAAOC;AAAA,IACT;AAAA,EAAA;AAEJ;AA0DO,SAASE,EAAcX,GAAgBY,GAA+B;AAC3E,QAAMC,IAAK,WAAWb,GAAIY,CAAK;AAC/B,SAAAb,EAAU,MAAM,aAAac,CAAE,CAAC,GACzBA;AACT;AASO,SAASC,EAAed,GAAgBY,GAA+B;AAC5E,QAAMC,IAAK,YAAYb,GAAIY,CAAK;AAChC,SAAAb,EAAU,MAAM,cAAcc,CAAE,CAAC,GAC1BA;AACT;AA4BO,SAASE,EACdC,GACAC,GACAC,GACAC,GACM;AACN,EAAAH,EAAO,iBAAiBC,GAAOC,GAASC,CAAO,GAC/CpB,EAAU,MAAMiB,EAAO,oBAAoBC,GAAOC,GAASC,CAAO,CAAC;AACrE;AAGI,OAAQ,WAAmB,UAAY,QACvC,WAAmB,UAAU,QAAQ,IAAI,aAAa;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("./context.cjs"),l=require("./equality.cjs"),i=require("./types.cjs"),n=require("./unified-scheduler.cjs");var c=Object.defineProperty,h=(s,e,t)=>e in s?c(s,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):s[e]=t,o=(s,e,t)=>h(s,typeof e!="symbol"?e+"":e,t);class p extends a.ComputationImpl{constructor(e,t={},r=a.getCurrentOwner()){super(e,r),o(this,"type","computed"),o(this,"priority"),o(this,"_hasValue",!1),o(this,"_error",null),o(this,"equalsFn"),o(this,"options"),this.priority=t.priority??n.UpdatePriority.Normal,this.equalsFn=t.equals??l.defaultEquals,this.options=t}getValue(){const e=a.getCurrentComputation();return e&&e.state!==i.ComputationState.Disposed&&(this.observers.add(e),e.sources.add(this)),(this.state===i.ComputationState.Dirty||!this._hasValue)&&(this.execute(),this._hasValue=!0),this.value}peek(){return(this.state===i.ComputationState.Dirty||!this._hasValue)&&(this.execute(),this._hasValue=!0),this.value}removeObserver(e){this.observers.delete(e)}execute(){const e=this._hasValue?this.value:void 0,t=super.execute();if(!this._hasValue||!this.equalsFn(e,t))for(const r of this.observers)r.state!==i.ComputationState.Disposed&&(r.state=i.ComputationState.Dirty,"execute"in r&&typeof r.execute=="function"&&queueMicrotask(()=>{r.state===i.ComputationState.Dirty&&r.execute()}));return t}notify(){this.execute()}cleanup(){for(const e of this.sources)"removeObserver"in e&&e.removeObserver(this);this.sources.clear();for(const e of this.observers)e.sources.delete(this);this.observers.clear(),this._hasValue=!1,this._error=null,this.state=i.ComputationState.Disposed}dispose(){this.cleanup(),super.dispose()}[Symbol.for("tachui.debug")](){return{id:this.id,type:this.type,value:this._hasValue?this.value:void 0,hasValue:this._hasValue,error:this._error?.message,state:this.state,sourceCount:this.sources.size,observerCount:this.observers.size,priority:n.UpdatePriority[this.priority],debugName:this.options.debugName,equalsFn:this.equalsFn.name||"anonymous"}}toString(){return`Computed(${this.options.debugName||this.id}): ${this._hasValue?this.value:"no value"}`}}function u(s,e){const t=new p(s,e),r=t.getValue.bind(t);return r.peek=t.peek.bind(t),Object.defineProperty(r,Symbol.for("tachui.computed"),{value:t,enumerable:!1}),r}function d(s,e){return u(s,e)}function m(s){return typeof s=="function"&&Symbol.for("tachui.computed")in s}function f(s){return s[Symbol.for("tachui.computed")]||null}function b(s,e){return u(e?()=>{for(const r of e)r();return s()}:s)}function v(s,e){let t,r=!1;return u(()=>(e()&&(t=s(),r=!0),r||(t=s(),r=!0),t))}exports.createComputed=u;exports.createConditionalComputed=v;exports.createDerivedSignal=b;exports.createMemo=d;exports.getComputedImpl=f;exports.isComputed=m;
|
|
2
|
-
//# sourceMappingURL=computed.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"computed.cjs","sources":["../../src/reactive/computed.ts"],"sourcesContent":["/**\n * Computed values implementation\n *\n * Computed values are derived reactive values that automatically\n * update when their dependencies change, with memoization.\n */\n\nimport { ComputationImpl, getCurrentComputation, getCurrentOwner } from './context'\nimport { defaultEquals, type EqualityFunction } from './equality'\nimport type { Computation, Signal } from './types'\nimport { ComputationState } from './types'\nimport { type ReactiveNode, UpdatePriority } from './unified-scheduler'\n\nexport interface ComputedOptions<T> {\n equals?: EqualityFunction<T>\n priority?: UpdatePriority\n debugName?: string\n onError?: (error: Error) => T // Error recovery function\n}\n\n/**\n * Robust computed value implementation with error recovery\n */\nclass ComputedImpl<T> extends ComputationImpl implements ReactiveNode {\n readonly type = 'computed' as const\n readonly priority: UpdatePriority\n\n private _hasValue = false\n private _error: Error | null = null\n private equalsFn: EqualityFunction<T>\n private options: ComputedOptions<T>\n\n constructor(fn: () => T, options: ComputedOptions<T> = {}, owner = getCurrentOwner()) {\n super(fn, owner)\n this.priority = options.priority ?? UpdatePriority.Normal\n this.equalsFn = options.equals ?? defaultEquals\n this.options = options\n }\n\n /**\n * Get the computed value, tracking dependency and lazily computing\n */\n getValue(): T {\n // Track this computed as a dependency if we're in a reactive context\n const computation = getCurrentComputation()\n if (computation && computation.state !== ComputationState.Disposed) {\n this.observers.add(computation)\n computation.sources.add(this)\n }\n\n // Compute value if needed\n if (this.state === ComputationState.Dirty || !this._hasValue) {\n this.execute()\n this._hasValue = true\n }\n\n return this.value\n }\n\n /**\n * Get the current value without tracking dependency\n */\n peek(): T {\n if (this.state === ComputationState.Dirty || !this._hasValue) {\n this.execute()\n this._hasValue = true\n }\n return this.value\n }\n\n /**\n * Remove an observer (cleanup)\n */\n removeObserver(computation: Computation): void {\n this.observers.delete(computation)\n }\n\n /**\n * Execute the computation and notify observers\n */\n execute(): T {\n const previousValue = this._hasValue ? this.value : undefined\n const result = super.execute()\n\n // Only notify observers if the value actually changed\n if (!this._hasValue || !this.equalsFn(previousValue, result)) {\n // Notify dependent computations\n for (const observer of this.observers) {\n if (observer.state !== ComputationState.Disposed) {\n observer.state = ComputationState.Dirty\n // Use the signal's scheduling mechanism for consistency\n if ('execute' in observer && typeof observer.execute === 'function') {\n queueMicrotask(() => {\n if (observer.state === ComputationState.Dirty) {\n observer.execute()\n }\n })\n }\n }\n }\n }\n\n return result\n }\n\n /**\n * Notify method for ReactiveNode compatibility\n */\n notify(): void {\n // For computations, notify means execute\n this.execute()\n }\n\n /**\n * Complete cleanup for memory management\n */\n cleanup(): void {\n // Complete bidirectional cleanup\n for (const source of this.sources) {\n if ('removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n for (const observer of this.observers) {\n observer.sources.delete(this)\n }\n this.observers.clear()\n\n this._hasValue = false\n this._error = null\n this.state = ComputationState.Disposed\n }\n\n /**\n * Dispose the computed value\n */\n dispose(): void {\n this.cleanup()\n super.dispose()\n }\n\n /**\n * Debug information\n */\n [Symbol.for('tachui.debug')](): object {\n return {\n id: this.id,\n type: this.type,\n value: this._hasValue ? this.value : undefined,\n hasValue: this._hasValue,\n error: this._error?.message,\n state: this.state,\n sourceCount: this.sources.size,\n observerCount: this.observers.size,\n priority: UpdatePriority[this.priority],\n debugName: this.options.debugName,\n equalsFn: this.equalsFn.name || 'anonymous',\n }\n }\n\n toString(): string {\n return `Computed(${this.options.debugName || this.id}): ${this._hasValue ? this.value : 'no value'}`\n }\n}\n\n/**\n * Create a computed value that automatically updates when dependencies change\n *\n * @param fn The computation function\n * @param options Configuration options for the computed value\n * @returns An accessor function for the computed value\n *\n * @example\n * ```typescript\n * const [count, setCount] = createSignal(0)\n * const doubleCount = createComputed(() => count() * 2, {\n * debugName: 'doubleCounter',\n * onError: (error) => {\n * console.error('Computation failed:', error)\n * return 0 // fallback value\n * }\n * })\n *\n * console.log(doubleCount()) // 0\n * setCount(5)\n * console.log(doubleCount()) // 10\n * ```\n */\nexport function createComputed<T>(fn: () => T, options?: ComputedOptions<T>): Signal<T> {\n const computed = new ComputedImpl(fn, options)\n\n // Create bound accessor with peek method - this is already a Signal<T>\n const accessor = computed.getValue.bind(computed) as Signal<T>\n accessor.peek = computed.peek.bind(computed)\n\n // Add debug information\n Object.defineProperty(accessor, Symbol.for('tachui.computed'), {\n value: computed,\n enumerable: false,\n })\n\n return accessor\n}\n\n/**\n * Create a memo (alias for createComputed for SolidJS compatibility)\n */\nexport function createMemo<T>(fn: () => T, options?: ComputedOptions<T>): Signal<T> {\n return createComputed(fn, options)\n}\n\n/**\n * Type guard to check if a value is a computed\n */\nexport function isComputed<T = any>(value: any): value is Signal<T> {\n return typeof value === 'function' && Symbol.for('tachui.computed') in value\n}\n\n/**\n * Get the underlying computed implementation for debugging\n */\nexport function getComputedImpl<T>(computed: Signal<T>): ComputedImpl<T> | null {\n return (computed as any)[Symbol.for('tachui.computed')] || null\n}\n\n/**\n * Create a computed value with explicit dependency tracking\n *\n * @param fn The computation function\n * @param deps Explicit dependencies (optional)\n * @returns An accessor function for the computed value\n */\nexport function createDerivedSignal<T>(fn: () => T, deps?: (() => any)[]): Signal<T> {\n if (!deps) {\n return createComputed(fn)\n }\n\n // Wrap function to explicitly track dependencies\n const wrappedFn = () => {\n // Read all dependencies to track them\n for (const dep of deps) {\n dep()\n }\n return fn()\n }\n\n return createComputed(wrappedFn)\n}\n\n/**\n * Create a computed value that only updates when a condition is met\n *\n * @param fn The computation function\n * @param when Condition function that must return true for updates\n * @returns An accessor function for the computed value\n */\nexport function createConditionalComputed<T>(fn: () => T, when: () => boolean): Signal<T> {\n let lastValue: T\n let hasValue = false\n\n return createComputed(() => {\n if (when()) {\n lastValue = fn()\n hasValue = true\n }\n\n if (!hasValue) {\n lastValue = fn()\n hasValue = true\n }\n\n return lastValue\n })\n}\n\n/**\n * Public Computed type export\n */\nexport type Computed<T> = Signal<T>\n"],"names":["ComputedImpl","ComputationImpl","fn","options","owner","getCurrentOwner","__publicField","UpdatePriority","defaultEquals","computation","getCurrentComputation","ComputationState","previousValue","result","observer","source","createComputed","computed","accessor","createMemo","isComputed","value","getComputedImpl","createDerivedSignal","deps","dep","createConditionalComputed","when","lastValue","hasValue"],"mappings":"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"}
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { ComputationImpl as n, getCurrentOwner as h, getCurrentComputation as l } from "./context.js";
|
|
2
|
-
import { defaultEquals as c } from "./equality.js";
|
|
3
|
-
import { ComputationState as i } from "./types.js";
|
|
4
|
-
import { UpdatePriority as a } from "./unified-scheduler.js";
|
|
5
|
-
var p = Object.defineProperty, f = (s, e, t) => e in s ? p(s, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : s[e] = t, o = (s, e, t) => f(s, typeof e != "symbol" ? e + "" : e, t);
|
|
6
|
-
class d extends n {
|
|
7
|
-
constructor(e, t = {}, r = h()) {
|
|
8
|
-
super(e, r), o(this, "type", "computed"), o(this, "priority"), o(this, "_hasValue", !1), o(this, "_error", null), o(this, "equalsFn"), o(this, "options"), this.priority = t.priority ?? a.Normal, this.equalsFn = t.equals ?? c, this.options = t;
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Get the computed value, tracking dependency and lazily computing
|
|
12
|
-
*/
|
|
13
|
-
getValue() {
|
|
14
|
-
const e = l();
|
|
15
|
-
return e && e.state !== i.Disposed && (this.observers.add(e), e.sources.add(this)), (this.state === i.Dirty || !this._hasValue) && (this.execute(), this._hasValue = !0), this.value;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Get the current value without tracking dependency
|
|
19
|
-
*/
|
|
20
|
-
peek() {
|
|
21
|
-
return (this.state === i.Dirty || !this._hasValue) && (this.execute(), this._hasValue = !0), this.value;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* Remove an observer (cleanup)
|
|
25
|
-
*/
|
|
26
|
-
removeObserver(e) {
|
|
27
|
-
this.observers.delete(e);
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Execute the computation and notify observers
|
|
31
|
-
*/
|
|
32
|
-
execute() {
|
|
33
|
-
const e = this._hasValue ? this.value : void 0, t = super.execute();
|
|
34
|
-
if (!this._hasValue || !this.equalsFn(e, t))
|
|
35
|
-
for (const r of this.observers)
|
|
36
|
-
r.state !== i.Disposed && (r.state = i.Dirty, "execute" in r && typeof r.execute == "function" && queueMicrotask(() => {
|
|
37
|
-
r.state === i.Dirty && r.execute();
|
|
38
|
-
}));
|
|
39
|
-
return t;
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Notify method for ReactiveNode compatibility
|
|
43
|
-
*/
|
|
44
|
-
notify() {
|
|
45
|
-
this.execute();
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Complete cleanup for memory management
|
|
49
|
-
*/
|
|
50
|
-
cleanup() {
|
|
51
|
-
for (const e of this.sources)
|
|
52
|
-
"removeObserver" in e && e.removeObserver(this);
|
|
53
|
-
this.sources.clear();
|
|
54
|
-
for (const e of this.observers)
|
|
55
|
-
e.sources.delete(this);
|
|
56
|
-
this.observers.clear(), this._hasValue = !1, this._error = null, this.state = i.Disposed;
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Dispose the computed value
|
|
60
|
-
*/
|
|
61
|
-
dispose() {
|
|
62
|
-
this.cleanup(), super.dispose();
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Debug information
|
|
66
|
-
*/
|
|
67
|
-
[Symbol.for("tachui.debug")]() {
|
|
68
|
-
return {
|
|
69
|
-
id: this.id,
|
|
70
|
-
type: this.type,
|
|
71
|
-
value: this._hasValue ? this.value : void 0,
|
|
72
|
-
hasValue: this._hasValue,
|
|
73
|
-
error: this._error?.message,
|
|
74
|
-
state: this.state,
|
|
75
|
-
sourceCount: this.sources.size,
|
|
76
|
-
observerCount: this.observers.size,
|
|
77
|
-
priority: a[this.priority],
|
|
78
|
-
debugName: this.options.debugName,
|
|
79
|
-
equalsFn: this.equalsFn.name || "anonymous"
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
toString() {
|
|
83
|
-
return `Computed(${this.options.debugName || this.id}): ${this._hasValue ? this.value : "no value"}`;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
function u(s, e) {
|
|
87
|
-
const t = new d(s, e), r = t.getValue.bind(t);
|
|
88
|
-
return r.peek = t.peek.bind(t), Object.defineProperty(r, Symbol.for("tachui.computed"), {
|
|
89
|
-
value: t,
|
|
90
|
-
enumerable: !1
|
|
91
|
-
}), r;
|
|
92
|
-
}
|
|
93
|
-
function _(s, e) {
|
|
94
|
-
return u(s, e);
|
|
95
|
-
}
|
|
96
|
-
function V(s) {
|
|
97
|
-
return typeof s == "function" && Symbol.for("tachui.computed") in s;
|
|
98
|
-
}
|
|
99
|
-
function C(s) {
|
|
100
|
-
return s[Symbol.for("tachui.computed")] || null;
|
|
101
|
-
}
|
|
102
|
-
function g(s, e) {
|
|
103
|
-
return u(e ? () => {
|
|
104
|
-
for (const r of e)
|
|
105
|
-
r();
|
|
106
|
-
return s();
|
|
107
|
-
} : s);
|
|
108
|
-
}
|
|
109
|
-
function x(s, e) {
|
|
110
|
-
let t, r = !1;
|
|
111
|
-
return u(() => (e() && (t = s(), r = !0), r || (t = s(), r = !0), t));
|
|
112
|
-
}
|
|
113
|
-
export {
|
|
114
|
-
u as createComputed,
|
|
115
|
-
x as createConditionalComputed,
|
|
116
|
-
g as createDerivedSignal,
|
|
117
|
-
_ as createMemo,
|
|
118
|
-
C as getComputedImpl,
|
|
119
|
-
V as isComputed
|
|
120
|
-
};
|
|
121
|
-
//# sourceMappingURL=computed.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"computed.js","sources":["../../src/reactive/computed.ts"],"sourcesContent":["/**\n * Computed values implementation\n *\n * Computed values are derived reactive values that automatically\n * update when their dependencies change, with memoization.\n */\n\nimport { ComputationImpl, getCurrentComputation, getCurrentOwner } from './context'\nimport { defaultEquals, type EqualityFunction } from './equality'\nimport type { Computation, Signal } from './types'\nimport { ComputationState } from './types'\nimport { type ReactiveNode, UpdatePriority } from './unified-scheduler'\n\nexport interface ComputedOptions<T> {\n equals?: EqualityFunction<T>\n priority?: UpdatePriority\n debugName?: string\n onError?: (error: Error) => T // Error recovery function\n}\n\n/**\n * Robust computed value implementation with error recovery\n */\nclass ComputedImpl<T> extends ComputationImpl implements ReactiveNode {\n readonly type = 'computed' as const\n readonly priority: UpdatePriority\n\n private _hasValue = false\n private _error: Error | null = null\n private equalsFn: EqualityFunction<T>\n private options: ComputedOptions<T>\n\n constructor(fn: () => T, options: ComputedOptions<T> = {}, owner = getCurrentOwner()) {\n super(fn, owner)\n this.priority = options.priority ?? UpdatePriority.Normal\n this.equalsFn = options.equals ?? defaultEquals\n this.options = options\n }\n\n /**\n * Get the computed value, tracking dependency and lazily computing\n */\n getValue(): T {\n // Track this computed as a dependency if we're in a reactive context\n const computation = getCurrentComputation()\n if (computation && computation.state !== ComputationState.Disposed) {\n this.observers.add(computation)\n computation.sources.add(this)\n }\n\n // Compute value if needed\n if (this.state === ComputationState.Dirty || !this._hasValue) {\n this.execute()\n this._hasValue = true\n }\n\n return this.value\n }\n\n /**\n * Get the current value without tracking dependency\n */\n peek(): T {\n if (this.state === ComputationState.Dirty || !this._hasValue) {\n this.execute()\n this._hasValue = true\n }\n return this.value\n }\n\n /**\n * Remove an observer (cleanup)\n */\n removeObserver(computation: Computation): void {\n this.observers.delete(computation)\n }\n\n /**\n * Execute the computation and notify observers\n */\n execute(): T {\n const previousValue = this._hasValue ? this.value : undefined\n const result = super.execute()\n\n // Only notify observers if the value actually changed\n if (!this._hasValue || !this.equalsFn(previousValue, result)) {\n // Notify dependent computations\n for (const observer of this.observers) {\n if (observer.state !== ComputationState.Disposed) {\n observer.state = ComputationState.Dirty\n // Use the signal's scheduling mechanism for consistency\n if ('execute' in observer && typeof observer.execute === 'function') {\n queueMicrotask(() => {\n if (observer.state === ComputationState.Dirty) {\n observer.execute()\n }\n })\n }\n }\n }\n }\n\n return result\n }\n\n /**\n * Notify method for ReactiveNode compatibility\n */\n notify(): void {\n // For computations, notify means execute\n this.execute()\n }\n\n /**\n * Complete cleanup for memory management\n */\n cleanup(): void {\n // Complete bidirectional cleanup\n for (const source of this.sources) {\n if ('removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n for (const observer of this.observers) {\n observer.sources.delete(this)\n }\n this.observers.clear()\n\n this._hasValue = false\n this._error = null\n this.state = ComputationState.Disposed\n }\n\n /**\n * Dispose the computed value\n */\n dispose(): void {\n this.cleanup()\n super.dispose()\n }\n\n /**\n * Debug information\n */\n [Symbol.for('tachui.debug')](): object {\n return {\n id: this.id,\n type: this.type,\n value: this._hasValue ? this.value : undefined,\n hasValue: this._hasValue,\n error: this._error?.message,\n state: this.state,\n sourceCount: this.sources.size,\n observerCount: this.observers.size,\n priority: UpdatePriority[this.priority],\n debugName: this.options.debugName,\n equalsFn: this.equalsFn.name || 'anonymous',\n }\n }\n\n toString(): string {\n return `Computed(${this.options.debugName || this.id}): ${this._hasValue ? this.value : 'no value'}`\n }\n}\n\n/**\n * Create a computed value that automatically updates when dependencies change\n *\n * @param fn The computation function\n * @param options Configuration options for the computed value\n * @returns An accessor function for the computed value\n *\n * @example\n * ```typescript\n * const [count, setCount] = createSignal(0)\n * const doubleCount = createComputed(() => count() * 2, {\n * debugName: 'doubleCounter',\n * onError: (error) => {\n * console.error('Computation failed:', error)\n * return 0 // fallback value\n * }\n * })\n *\n * console.log(doubleCount()) // 0\n * setCount(5)\n * console.log(doubleCount()) // 10\n * ```\n */\nexport function createComputed<T>(fn: () => T, options?: ComputedOptions<T>): Signal<T> {\n const computed = new ComputedImpl(fn, options)\n\n // Create bound accessor with peek method - this is already a Signal<T>\n const accessor = computed.getValue.bind(computed) as Signal<T>\n accessor.peek = computed.peek.bind(computed)\n\n // Add debug information\n Object.defineProperty(accessor, Symbol.for('tachui.computed'), {\n value: computed,\n enumerable: false,\n })\n\n return accessor\n}\n\n/**\n * Create a memo (alias for createComputed for SolidJS compatibility)\n */\nexport function createMemo<T>(fn: () => T, options?: ComputedOptions<T>): Signal<T> {\n return createComputed(fn, options)\n}\n\n/**\n * Type guard to check if a value is a computed\n */\nexport function isComputed<T = any>(value: any): value is Signal<T> {\n return typeof value === 'function' && Symbol.for('tachui.computed') in value\n}\n\n/**\n * Get the underlying computed implementation for debugging\n */\nexport function getComputedImpl<T>(computed: Signal<T>): ComputedImpl<T> | null {\n return (computed as any)[Symbol.for('tachui.computed')] || null\n}\n\n/**\n * Create a computed value with explicit dependency tracking\n *\n * @param fn The computation function\n * @param deps Explicit dependencies (optional)\n * @returns An accessor function for the computed value\n */\nexport function createDerivedSignal<T>(fn: () => T, deps?: (() => any)[]): Signal<T> {\n if (!deps) {\n return createComputed(fn)\n }\n\n // Wrap function to explicitly track dependencies\n const wrappedFn = () => {\n // Read all dependencies to track them\n for (const dep of deps) {\n dep()\n }\n return fn()\n }\n\n return createComputed(wrappedFn)\n}\n\n/**\n * Create a computed value that only updates when a condition is met\n *\n * @param fn The computation function\n * @param when Condition function that must return true for updates\n * @returns An accessor function for the computed value\n */\nexport function createConditionalComputed<T>(fn: () => T, when: () => boolean): Signal<T> {\n let lastValue: T\n let hasValue = false\n\n return createComputed(() => {\n if (when()) {\n lastValue = fn()\n hasValue = true\n }\n\n if (!hasValue) {\n lastValue = fn()\n hasValue = true\n }\n\n return lastValue\n })\n}\n\n/**\n * Public Computed type export\n */\nexport type Computed<T> = Signal<T>\n"],"names":["ComputedImpl","ComputationImpl","fn","options","owner","getCurrentOwner","__publicField","UpdatePriority","defaultEquals","computation","getCurrentComputation","ComputationState","previousValue","result","observer","source","createComputed","computed","accessor","createMemo","isComputed","value","getComputedImpl","createDerivedSignal","deps","dep","createConditionalComputed","when","lastValue","hasValue"],"mappings":";;;;;AAuBA,MAAMA,UAAwBC,EAAwC;AAAA,EASpE,YAAYC,GAAaC,IAA8B,CAAA,GAAIC,IAAQC,KAAmB;AACpF,UAAMH,GAAIE,CAAK,GATjBE,EAAA,MAAS,QAAO,UAAA,GAChBA,EAAA,MAAS,UAAA,GAETA,EAAA,MAAQ,aAAY,EAAA,GACpBA,EAAA,MAAQ,UAAuB,IAAA,GAC/BA,EAAA,MAAQ,UAAA,GACRA,EAAA,MAAQ,SAAA,GAIN,KAAK,WAAWH,EAAQ,YAAYI,EAAe,QACnD,KAAK,WAAWJ,EAAQ,UAAUK,GAClC,KAAK,UAAUL;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA,EAKA,WAAc;AAEZ,UAAMM,IAAcC,EAAA;AACpB,WAAID,KAAeA,EAAY,UAAUE,EAAiB,aACxD,KAAK,UAAU,IAAIF,CAAW,GAC9BA,EAAY,QAAQ,IAAI,IAAI,KAI1B,KAAK,UAAUE,EAAiB,SAAS,CAAC,KAAK,eACjD,KAAK,QAAA,GACL,KAAK,YAAY,KAGZ,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,OAAU;AACR,YAAI,KAAK,UAAUA,EAAiB,SAAS,CAAC,KAAK,eACjD,KAAK,QAAA,GACL,KAAK,YAAY,KAEZ,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,eAAeF,GAAgC;AAC7C,SAAK,UAAU,OAAOA,CAAW;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA,EAKA,UAAa;AACX,UAAMG,IAAgB,KAAK,YAAY,KAAK,QAAQ,QAC9CC,IAAS,MAAM,QAAA;AAGrB,QAAI,CAAC,KAAK,aAAa,CAAC,KAAK,SAASD,GAAeC,CAAM;AAEzD,iBAAWC,KAAY,KAAK;AAC1B,QAAIA,EAAS,UAAUH,EAAiB,aACtCG,EAAS,QAAQH,EAAiB,OAE9B,aAAaG,KAAY,OAAOA,EAAS,WAAY,cACvD,eAAe,MAAM;AACnB,UAAIA,EAAS,UAAUH,EAAiB,SACtCG,EAAS,QAAA;AAAA,QAEb,CAAC;AAMT,WAAOD;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,SAAe;AAEb,SAAK,QAAA;AAAA,EACP;AAAA;AAAA;AAAA;AAAA,EAKA,UAAgB;AAEd,eAAWE,KAAU,KAAK;AACxB,MAAI,oBAAoBA,KACpBA,EAAe,eAAe,IAAI;AAGxC,SAAK,QAAQ,MAAA;AAEb,eAAWD,KAAY,KAAK;AAC1B,MAAAA,EAAS,QAAQ,OAAO,IAAI;AAE9B,SAAK,UAAU,MAAA,GAEf,KAAK,YAAY,IACjB,KAAK,SAAS,MACd,KAAK,QAAQH,EAAiB;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA,EAKA,UAAgB;AACd,SAAK,QAAA,GACL,MAAM,QAAA;AAAA,EACR;AAAA;AAAA;AAAA;AAAA,EAKA,CAAC,OAAO,IAAI,cAAc,CAAC,IAAY;AACrC,WAAO;AAAA,MACL,IAAI,KAAK;AAAA,MACT,MAAM,KAAK;AAAA,MACX,OAAO,KAAK,YAAY,KAAK,QAAQ;AAAA,MACrC,UAAU,KAAK;AAAA,MACf,OAAO,KAAK,QAAQ;AAAA,MACpB,OAAO,KAAK;AAAA,MACZ,aAAa,KAAK,QAAQ;AAAA,MAC1B,eAAe,KAAK,UAAU;AAAA,MAC9B,UAAUJ,EAAe,KAAK,QAAQ;AAAA,MACtC,WAAW,KAAK,QAAQ;AAAA,MACxB,UAAU,KAAK,SAAS,QAAQ;AAAA,IAAA;AAAA,EAEpC;AAAA,EAEA,WAAmB;AACjB,WAAO,YAAY,KAAK,QAAQ,aAAa,KAAK,EAAE,MAAM,KAAK,YAAY,KAAK,QAAQ,UAAU;AAAA,EACpG;AACF;AAyBO,SAASS,EAAkBd,GAAaC,GAAyC;AACtF,QAAMc,IAAW,IAAIjB,EAAaE,GAAIC,CAAO,GAGvCe,IAAWD,EAAS,SAAS,KAAKA,CAAQ;AAChD,SAAAC,EAAS,OAAOD,EAAS,KAAK,KAAKA,CAAQ,GAG3C,OAAO,eAAeC,GAAU,OAAO,IAAI,iBAAiB,GAAG;AAAA,IAC7D,OAAOD;AAAA,IACP,YAAY;AAAA,EAAA,CACb,GAEMC;AACT;AAKO,SAASC,EAAcjB,GAAaC,GAAyC;AAClF,SAAOa,EAAed,GAAIC,CAAO;AACnC;AAKO,SAASiB,EAAoBC,GAAgC;AAClE,SAAO,OAAOA,KAAU,cAAc,OAAO,IAAI,iBAAiB,KAAKA;AACzE;AAKO,SAASC,EAAmBL,GAA6C;AAC9E,SAAQA,EAAiB,OAAO,IAAI,iBAAiB,CAAC,KAAK;AAC7D;AASO,SAASM,EAAuBrB,GAAasB,GAAiC;AACnF,SAaOR,EAbFQ,IAKa,MAAM;AAEtB,eAAWC,KAAOD;AAChB,MAAAC,EAAA;AAEF,WAAOvB,EAAA;AAAA,EACT,IAVwBA,CAYO;AACjC;AASO,SAASwB,EAA6BxB,GAAayB,GAAgC;AACxF,MAAIC,GACAC,IAAW;AAEf,SAAOb,EAAe,OAChBW,QACFC,IAAY1B,EAAA,GACZ2B,IAAW,KAGRA,MACHD,IAAY1B,EAAA,GACZ2B,IAAW,KAGND,EACR;AACH;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("./types.cjs");var p=Object.defineProperty,f=(r,t,e)=>t in r?p(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,s=(r,t,e)=>f(r,typeof t!="symbol"?t+"":t,e);let a=0,h=0,o=null,n=null,i=!1;function d(){return o}function m(){return n}function C(){return i}class v{constructor(t=null){s(this,"id"),s(this,"parent"),s(this,"context",new Map),s(this,"cleanups",[]),s(this,"sources",new Set),s(this,"disposed",!1),this.id=++h,this.parent=t}dispose(){if(!this.disposed){this.disposed=!0;for(const t of this.sources)t.dispose();this.sources.clear();for(const t of this.cleanups)try{t()}catch(e){console.error("Error in cleanup function:",e)}this.cleanups.length=0,this.parent&&!this.parent.disposed&&this.parent.sources.delete(this)}}}class l{constructor(t,e=null){s(this,"id"),s(this,"owner"),s(this,"fn"),s(this,"sources",new Set),s(this,"observers",new Set),s(this,"state",u.ComputationState.Dirty),s(this,"value"),this.id=++a,this.fn=t,this.owner=e,e&&!e.disposed&&e.sources.add(this)}execute(){if(this.state===u.ComputationState.Disposed)return this.value;for(const e of this.sources)e&&typeof e=="object"&&"removeObserver"in e&&e.removeObserver(this);this.sources.clear();const t=o;o=this;try{return this.state=u.ComputationState.Clean,this.value=this.fn(),this.value}catch(e){throw this.state=u.ComputationState.Disposed,(typeof process>"u"||process.env.NODE_ENV!=="test")&&console.error("Error in computation:",e),e}finally{o=t}}dispose(){if(this.state!==u.ComputationState.Disposed){this.state=u.ComputationState.Disposed;for(const t of this.sources)t&&typeof t=="object"&&"removeObserver"in t&&t.removeObserver(this);this.sources.clear();for(const t of this.observers)t.sources.delete(this);this.observers.clear(),this.owner&&!this.owner.disposed&&this.owner.sources.delete(this)}}}function w(r){const t=new v(n),e=n;n=t;try{return r(()=>t.dispose())}finally{n=e}}function g(r,t){const e=n;n=r;try{return t()}finally{n=e}}function b(){return n}let c=null;function O(r){c=r}function y(r){if(i)return r();const t=i;i=!0;try{const e=r();return!t&&c&&c(),e}finally{i=t}}function S(r){const t=o;o=null;try{return r()}finally{o=t}}function D(r,t){const e=new l(r,t||n);return e.execute(),e}function B(){return{computation:o,batch:i}}const _={getCurrentComputation:()=>o,getCurrentOwner:()=>n,getComputationCount:()=>a,getOwnerCount:()=>h,isBatching:()=>i};exports.ComputationImpl=l;exports.DEBUG=_;exports.batch=y;exports.createComputation=D;exports.createRoot=w;exports.getCurrentComputation=d;exports.getCurrentOwner=m;exports.getOwner=b;exports.getReactiveContext=B;exports.isBatchingUpdates=C;exports.runWithOwner=g;exports.setFlushFunction=O;exports.untrack=S;
|
|
2
|
-
//# sourceMappingURL=context.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"context.cjs","sources":["../../src/reactive/context.ts"],"sourcesContent":["/**\n * Reactive context and computation management\n *\n * Manages the reactive execution context, dependency tracking,\n * and computation lifecycle.\n */\n\nimport type { CleanupFunction, Computation, Owner, ReactiveContext } from './types'\nimport { ComputationState } from './types'\n\nlet computationIdCounter = 0\nlet ownerIdCounter = 0\n\n/**\n * Global reactive context\n */\nlet currentComputation: Computation | null = null\nlet currentOwner: Owner | null = null\nlet isBatching = false\n\n/**\n * Get the current computation context\n */\nexport function getCurrentComputation(): Computation | null {\n return currentComputation\n}\n\n/**\n * Get the current owner context\n */\nexport function getCurrentOwner(): Owner | null {\n return currentOwner\n}\n\n/**\n * Check if we're currently batching updates\n */\nexport function isBatchingUpdates(): boolean {\n return isBatching\n}\n\n/**\n * Owner implementation for managing cleanup and context\n */\nclass OwnerImpl implements Owner {\n readonly id: number\n readonly parent: Owner | null\n readonly context = new Map<symbol, any>()\n readonly cleanups: CleanupFunction[] = []\n readonly sources = new Set<Computation>()\n disposed = false\n\n constructor(parent: Owner | null = null) {\n this.id = ++ownerIdCounter\n this.parent = parent\n }\n\n dispose(): void {\n if (this.disposed) return\n\n this.disposed = true\n\n // Dispose all child computations\n for (const computation of this.sources) {\n computation.dispose()\n }\n this.sources.clear()\n\n // Run cleanup functions\n for (const cleanup of this.cleanups) {\n try {\n cleanup()\n } catch (error) {\n console.error('Error in cleanup function:', error)\n }\n }\n this.cleanups.length = 0\n\n // Remove from parent\n if (this.parent && !this.parent.disposed) {\n this.parent.sources.delete(this as any)\n }\n }\n}\n\n/**\n * Computation implementation\n */\nexport class ComputationImpl implements Computation {\n readonly id: number\n readonly owner: Owner | null\n readonly fn: () => any\n readonly sources = new Set<any>() // Signals this computation depends on\n readonly observers = new Set<Computation>() // Computations that depend on this\n state = ComputationState.Dirty\n value: any = undefined\n\n constructor(fn: () => any, owner: Owner | null = null) {\n this.id = ++computationIdCounter\n this.fn = fn\n this.owner = owner\n\n if (owner && !owner.disposed) {\n owner.sources.add(this)\n }\n }\n\n execute(): any {\n if (this.state === ComputationState.Disposed) {\n return this.value\n }\n\n // Clean up old dependencies\n for (const source of this.sources) {\n if (source && typeof source === 'object' && 'removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n const prevComputation = currentComputation\n currentComputation = this\n\n try {\n this.state = ComputationState.Clean\n this.value = this.fn()\n return this.value\n } catch (error) {\n this.state = ComputationState.Disposed\n // Don't suppress errors - let them propagate for proper error handling\n // Only log in non-test environments to avoid polluting test output\n if (typeof process === 'undefined' || process.env.NODE_ENV !== 'test') {\n console.error('Error in computation:', error)\n }\n throw error\n } finally {\n currentComputation = prevComputation\n }\n }\n\n dispose(): void {\n if (this.state === ComputationState.Disposed) return\n\n this.state = ComputationState.Disposed\n\n // Remove from all sources\n for (const source of this.sources) {\n if (source && typeof source === 'object' && 'removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n // Notify observers that this computation is disposed\n for (const observer of this.observers) {\n observer.sources.delete(this)\n }\n this.observers.clear()\n\n // Remove from owner\n if (this.owner && !this.owner.disposed) {\n this.owner.sources.delete(this)\n }\n }\n}\n\n/**\n * Create a new reactive computation root\n */\nexport function createRoot<T>(fn: (dispose: () => void) => T): T {\n const owner = new OwnerImpl(currentOwner)\n const prevOwner = currentOwner\n currentOwner = owner\n\n try {\n return fn(() => owner.dispose())\n } finally {\n currentOwner = prevOwner\n }\n}\n\n/**\n * Run a function with a specific owner context\n */\nexport function runWithOwner<T>(owner: Owner | null, fn: () => T): T {\n const prevOwner = currentOwner\n currentOwner = owner\n\n try {\n return fn()\n } finally {\n currentOwner = prevOwner\n }\n}\n\n/**\n * Get the current owner context\n */\nexport function getOwner(): Owner | null {\n return currentOwner\n}\n\n// Global flush function reference\nlet flushFunction: (() => void) | null = null\n\n/**\n * Set the flush function (called by signal module)\n */\nexport function setFlushFunction(fn: () => void): void {\n flushFunction = fn\n}\n\n/**\n * Batch multiple updates together\n */\nexport function batch<T>(fn: () => T): T {\n if (isBatching) {\n return fn()\n }\n\n const wasBatching = isBatching\n isBatching = true\n\n try {\n const result = fn()\n // Flush updates after batch completes\n if (!wasBatching && flushFunction) {\n flushFunction()\n }\n return result\n } finally {\n isBatching = wasBatching\n }\n}\n\n/**\n * Read a signal without tracking dependency\n */\nexport function untrack<T>(fn: () => T): T {\n const prevComputation = currentComputation\n currentComputation = null\n\n try {\n return fn()\n } finally {\n currentComputation = prevComputation\n }\n}\n\n/**\n * Add cleanup function to current owner\n */\nexport function onCleanup(fn: CleanupFunction): void {\n if (currentOwner && !currentOwner.disposed) {\n currentOwner.cleanups.push(fn)\n }\n}\n\n/**\n * Create a computation that runs immediately and tracks dependencies\n */\nexport function createComputation<T>(fn: () => T, owner?: Owner): ComputationImpl {\n const computation = new ComputationImpl(fn, owner || currentOwner)\n computation.execute()\n return computation\n}\n\n/**\n * Get reactive context information\n */\nexport function getReactiveContext(): ReactiveContext {\n return {\n computation: currentComputation,\n batch: isBatching,\n }\n}\n\n/**\n * Debug utilities\n */\nexport const DEBUG = {\n getCurrentComputation: () => currentComputation,\n getCurrentOwner: () => currentOwner,\n getComputationCount: () => computationIdCounter,\n getOwnerCount: () => ownerIdCounter,\n isBatching: () => isBatching,\n}\n"],"names":["computationIdCounter","ownerIdCounter","currentComputation","currentOwner","isBatching","getCurrentComputation","getCurrentOwner","isBatchingUpdates","OwnerImpl","parent","__publicField","computation","cleanup","error","ComputationImpl","fn","owner","ComputationState","source","prevComputation","observer","createRoot","prevOwner","runWithOwner","getOwner","flushFunction","setFlushFunction","batch","wasBatching","result","untrack","createComputation","getReactiveContext","DEBUG"],"mappings":"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"}
|
package/dist/reactive/context.js
DELETED
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
import { ComputationState as u } from "./types.js";
|
|
2
|
-
var l = Object.defineProperty, p = (r, t, e) => t in r ? l(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e, s = (r, t, e) => p(r, typeof t != "symbol" ? t + "" : t, e);
|
|
3
|
-
let a = 0, h = 0, o = null, n = null, i = !1;
|
|
4
|
-
function v() {
|
|
5
|
-
return o;
|
|
6
|
-
}
|
|
7
|
-
function w() {
|
|
8
|
-
return n;
|
|
9
|
-
}
|
|
10
|
-
function C() {
|
|
11
|
-
return i;
|
|
12
|
-
}
|
|
13
|
-
class f {
|
|
14
|
-
constructor(t = null) {
|
|
15
|
-
s(this, "id"), s(this, "parent"), s(this, "context", /* @__PURE__ */ new Map()), s(this, "cleanups", []), s(this, "sources", /* @__PURE__ */ new Set()), s(this, "disposed", !1), this.id = ++h, this.parent = t;
|
|
16
|
-
}
|
|
17
|
-
dispose() {
|
|
18
|
-
if (!this.disposed) {
|
|
19
|
-
this.disposed = !0;
|
|
20
|
-
for (const t of this.sources)
|
|
21
|
-
t.dispose();
|
|
22
|
-
this.sources.clear();
|
|
23
|
-
for (const t of this.cleanups)
|
|
24
|
-
try {
|
|
25
|
-
t();
|
|
26
|
-
} catch (e) {
|
|
27
|
-
console.error("Error in cleanup function:", e);
|
|
28
|
-
}
|
|
29
|
-
this.cleanups.length = 0, this.parent && !this.parent.disposed && this.parent.sources.delete(this);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
class d {
|
|
34
|
-
constructor(t, e = null) {
|
|
35
|
-
s(this, "id"), s(this, "owner"), s(this, "fn"), s(this, "sources", /* @__PURE__ */ new Set()), s(this, "observers", /* @__PURE__ */ new Set()), s(this, "state", u.Dirty), s(this, "value"), this.id = ++a, this.fn = t, this.owner = e, e && !e.disposed && e.sources.add(this);
|
|
36
|
-
}
|
|
37
|
-
execute() {
|
|
38
|
-
if (this.state === u.Disposed)
|
|
39
|
-
return this.value;
|
|
40
|
-
for (const e of this.sources)
|
|
41
|
-
e && typeof e == "object" && "removeObserver" in e && e.removeObserver(this);
|
|
42
|
-
this.sources.clear();
|
|
43
|
-
const t = o;
|
|
44
|
-
o = this;
|
|
45
|
-
try {
|
|
46
|
-
return this.state = u.Clean, this.value = this.fn(), this.value;
|
|
47
|
-
} catch (e) {
|
|
48
|
-
throw this.state = u.Disposed, (typeof process > "u" || process.env.NODE_ENV !== "test") && console.error("Error in computation:", e), e;
|
|
49
|
-
} finally {
|
|
50
|
-
o = t;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
dispose() {
|
|
54
|
-
if (this.state !== u.Disposed) {
|
|
55
|
-
this.state = u.Disposed;
|
|
56
|
-
for (const t of this.sources)
|
|
57
|
-
t && typeof t == "object" && "removeObserver" in t && t.removeObserver(this);
|
|
58
|
-
this.sources.clear();
|
|
59
|
-
for (const t of this.observers)
|
|
60
|
-
t.sources.delete(this);
|
|
61
|
-
this.observers.clear(), this.owner && !this.owner.disposed && this.owner.sources.delete(this);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
function b(r) {
|
|
66
|
-
const t = new f(n), e = n;
|
|
67
|
-
n = t;
|
|
68
|
-
try {
|
|
69
|
-
return r(() => t.dispose());
|
|
70
|
-
} finally {
|
|
71
|
-
n = e;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
function O(r, t) {
|
|
75
|
-
const e = n;
|
|
76
|
-
n = r;
|
|
77
|
-
try {
|
|
78
|
-
return t();
|
|
79
|
-
} finally {
|
|
80
|
-
n = e;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
function g() {
|
|
84
|
-
return n;
|
|
85
|
-
}
|
|
86
|
-
let c = null;
|
|
87
|
-
function y(r) {
|
|
88
|
-
c = r;
|
|
89
|
-
}
|
|
90
|
-
function D(r) {
|
|
91
|
-
if (i)
|
|
92
|
-
return r();
|
|
93
|
-
const t = i;
|
|
94
|
-
i = !0;
|
|
95
|
-
try {
|
|
96
|
-
const e = r();
|
|
97
|
-
return !t && c && c(), e;
|
|
98
|
-
} finally {
|
|
99
|
-
i = t;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
function _(r) {
|
|
103
|
-
const t = o;
|
|
104
|
-
o = null;
|
|
105
|
-
try {
|
|
106
|
-
return r();
|
|
107
|
-
} finally {
|
|
108
|
-
o = t;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
function x(r, t) {
|
|
112
|
-
const e = new d(r, t || n);
|
|
113
|
-
return e.execute(), e;
|
|
114
|
-
}
|
|
115
|
-
function B() {
|
|
116
|
-
return {
|
|
117
|
-
computation: o,
|
|
118
|
-
batch: i
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
const E = {
|
|
122
|
-
getCurrentComputation: () => o,
|
|
123
|
-
getCurrentOwner: () => n,
|
|
124
|
-
getComputationCount: () => a,
|
|
125
|
-
getOwnerCount: () => h,
|
|
126
|
-
isBatching: () => i
|
|
127
|
-
};
|
|
128
|
-
export {
|
|
129
|
-
d as ComputationImpl,
|
|
130
|
-
E as DEBUG,
|
|
131
|
-
D as batch,
|
|
132
|
-
x as createComputation,
|
|
133
|
-
b as createRoot,
|
|
134
|
-
v as getCurrentComputation,
|
|
135
|
-
w as getCurrentOwner,
|
|
136
|
-
g as getOwner,
|
|
137
|
-
B as getReactiveContext,
|
|
138
|
-
C as isBatchingUpdates,
|
|
139
|
-
O as runWithOwner,
|
|
140
|
-
y as setFlushFunction,
|
|
141
|
-
_ as untrack
|
|
142
|
-
};
|
|
143
|
-
//# sourceMappingURL=context.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sources":["../../src/reactive/context.ts"],"sourcesContent":["/**\n * Reactive context and computation management\n *\n * Manages the reactive execution context, dependency tracking,\n * and computation lifecycle.\n */\n\nimport type { CleanupFunction, Computation, Owner, ReactiveContext } from './types'\nimport { ComputationState } from './types'\n\nlet computationIdCounter = 0\nlet ownerIdCounter = 0\n\n/**\n * Global reactive context\n */\nlet currentComputation: Computation | null = null\nlet currentOwner: Owner | null = null\nlet isBatching = false\n\n/**\n * Get the current computation context\n */\nexport function getCurrentComputation(): Computation | null {\n return currentComputation\n}\n\n/**\n * Get the current owner context\n */\nexport function getCurrentOwner(): Owner | null {\n return currentOwner\n}\n\n/**\n * Check if we're currently batching updates\n */\nexport function isBatchingUpdates(): boolean {\n return isBatching\n}\n\n/**\n * Owner implementation for managing cleanup and context\n */\nclass OwnerImpl implements Owner {\n readonly id: number\n readonly parent: Owner | null\n readonly context = new Map<symbol, any>()\n readonly cleanups: CleanupFunction[] = []\n readonly sources = new Set<Computation>()\n disposed = false\n\n constructor(parent: Owner | null = null) {\n this.id = ++ownerIdCounter\n this.parent = parent\n }\n\n dispose(): void {\n if (this.disposed) return\n\n this.disposed = true\n\n // Dispose all child computations\n for (const computation of this.sources) {\n computation.dispose()\n }\n this.sources.clear()\n\n // Run cleanup functions\n for (const cleanup of this.cleanups) {\n try {\n cleanup()\n } catch (error) {\n console.error('Error in cleanup function:', error)\n }\n }\n this.cleanups.length = 0\n\n // Remove from parent\n if (this.parent && !this.parent.disposed) {\n this.parent.sources.delete(this as any)\n }\n }\n}\n\n/**\n * Computation implementation\n */\nexport class ComputationImpl implements Computation {\n readonly id: number\n readonly owner: Owner | null\n readonly fn: () => any\n readonly sources = new Set<any>() // Signals this computation depends on\n readonly observers = new Set<Computation>() // Computations that depend on this\n state = ComputationState.Dirty\n value: any = undefined\n\n constructor(fn: () => any, owner: Owner | null = null) {\n this.id = ++computationIdCounter\n this.fn = fn\n this.owner = owner\n\n if (owner && !owner.disposed) {\n owner.sources.add(this)\n }\n }\n\n execute(): any {\n if (this.state === ComputationState.Disposed) {\n return this.value\n }\n\n // Clean up old dependencies\n for (const source of this.sources) {\n if (source && typeof source === 'object' && 'removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n const prevComputation = currentComputation\n currentComputation = this\n\n try {\n this.state = ComputationState.Clean\n this.value = this.fn()\n return this.value\n } catch (error) {\n this.state = ComputationState.Disposed\n // Don't suppress errors - let them propagate for proper error handling\n // Only log in non-test environments to avoid polluting test output\n if (typeof process === 'undefined' || process.env.NODE_ENV !== 'test') {\n console.error('Error in computation:', error)\n }\n throw error\n } finally {\n currentComputation = prevComputation\n }\n }\n\n dispose(): void {\n if (this.state === ComputationState.Disposed) return\n\n this.state = ComputationState.Disposed\n\n // Remove from all sources\n for (const source of this.sources) {\n if (source && typeof source === 'object' && 'removeObserver' in source) {\n ;(source as any).removeObserver(this)\n }\n }\n this.sources.clear()\n\n // Notify observers that this computation is disposed\n for (const observer of this.observers) {\n observer.sources.delete(this)\n }\n this.observers.clear()\n\n // Remove from owner\n if (this.owner && !this.owner.disposed) {\n this.owner.sources.delete(this)\n }\n }\n}\n\n/**\n * Create a new reactive computation root\n */\nexport function createRoot<T>(fn: (dispose: () => void) => T): T {\n const owner = new OwnerImpl(currentOwner)\n const prevOwner = currentOwner\n currentOwner = owner\n\n try {\n return fn(() => owner.dispose())\n } finally {\n currentOwner = prevOwner\n }\n}\n\n/**\n * Run a function with a specific owner context\n */\nexport function runWithOwner<T>(owner: Owner | null, fn: () => T): T {\n const prevOwner = currentOwner\n currentOwner = owner\n\n try {\n return fn()\n } finally {\n currentOwner = prevOwner\n }\n}\n\n/**\n * Get the current owner context\n */\nexport function getOwner(): Owner | null {\n return currentOwner\n}\n\n// Global flush function reference\nlet flushFunction: (() => void) | null = null\n\n/**\n * Set the flush function (called by signal module)\n */\nexport function setFlushFunction(fn: () => void): void {\n flushFunction = fn\n}\n\n/**\n * Batch multiple updates together\n */\nexport function batch<T>(fn: () => T): T {\n if (isBatching) {\n return fn()\n }\n\n const wasBatching = isBatching\n isBatching = true\n\n try {\n const result = fn()\n // Flush updates after batch completes\n if (!wasBatching && flushFunction) {\n flushFunction()\n }\n return result\n } finally {\n isBatching = wasBatching\n }\n}\n\n/**\n * Read a signal without tracking dependency\n */\nexport function untrack<T>(fn: () => T): T {\n const prevComputation = currentComputation\n currentComputation = null\n\n try {\n return fn()\n } finally {\n currentComputation = prevComputation\n }\n}\n\n/**\n * Add cleanup function to current owner\n */\nexport function onCleanup(fn: CleanupFunction): void {\n if (currentOwner && !currentOwner.disposed) {\n currentOwner.cleanups.push(fn)\n }\n}\n\n/**\n * Create a computation that runs immediately and tracks dependencies\n */\nexport function createComputation<T>(fn: () => T, owner?: Owner): ComputationImpl {\n const computation = new ComputationImpl(fn, owner || currentOwner)\n computation.execute()\n return computation\n}\n\n/**\n * Get reactive context information\n */\nexport function getReactiveContext(): ReactiveContext {\n return {\n computation: currentComputation,\n batch: isBatching,\n }\n}\n\n/**\n * Debug utilities\n */\nexport const DEBUG = {\n getCurrentComputation: () => currentComputation,\n getCurrentOwner: () => currentOwner,\n getComputationCount: () => computationIdCounter,\n getOwnerCount: () => ownerIdCounter,\n isBatching: () => isBatching,\n}\n"],"names":["computationIdCounter","ownerIdCounter","currentComputation","currentOwner","isBatching","getCurrentComputation","getCurrentOwner","isBatchingUpdates","OwnerImpl","parent","__publicField","computation","cleanup","error","ComputationImpl","fn","owner","ComputationState","source","prevComputation","observer","createRoot","prevOwner","runWithOwner","getOwner","flushFunction","setFlushFunction","batch","wasBatching","result","untrack","createComputation","getReactiveContext","DEBUG"],"mappings":";;AAUA,IAAIA,IAAuB,GACvBC,IAAiB,GAKjBC,IAAyC,MACzCC,IAA6B,MAC7BC,IAAa;AAKV,SAASC,IAA4C;AAC1D,SAAOH;AACT;AAKO,SAASI,IAAgC;AAC9C,SAAOH;AACT;AAKO,SAASI,IAA6B;AAC3C,SAAOH;AACT;AAKA,MAAMI,EAA2B;AAAA,EAQ/B,YAAYC,IAAuB,MAAM;AAPzC,IAAAC,EAAA,MAAS,IAAA,GACTA,EAAA,MAAS,QAAA,GACTA,EAAA,MAAS,+BAAc,IAAA,CAAiB,GACxCA,EAAA,MAAS,YAA8B,EAAC,GACxCA,EAAA,MAAS,+BAAc,IAAA,CAAiB,GACxCA,EAAA,MAAA,YAAW,EAAA,GAGT,KAAK,KAAK,EAAET,GACZ,KAAK,SAASQ;AAAA,EAChB;AAAA,EAEA,UAAgB;AACd,QAAI,MAAK,UAET;AAAA,WAAK,WAAW;AAGhB,iBAAWE,KAAe,KAAK;AAC7B,QAAAA,EAAY,QAAA;AAEd,WAAK,QAAQ,MAAA;AAGb,iBAAWC,KAAW,KAAK;AACzB,YAAI;AACF,UAAAA,EAAA;AAAA,QACF,SAASC,GAAO;AACd,kBAAQ,MAAM,8BAA8BA,CAAK;AAAA,QACnD;AAEF,WAAK,SAAS,SAAS,GAGnB,KAAK,UAAU,CAAC,KAAK,OAAO,YAC9B,KAAK,OAAO,QAAQ,OAAO,IAAW;AAAA;AAAA,EAE1C;AACF;AAKO,MAAMC,EAAuC;AAAA,EASlD,YAAYC,GAAeC,IAAsB,MAAM;AARvD,IAAAN,EAAA,MAAS,IAAA,GACTA,EAAA,MAAS,OAAA,GACTA,EAAA,MAAS,IAAA,GACTA,EAAA,MAAS,+BAAc,IAAA,CAAS,GAChCA,EAAA,MAAS,iCAAgB,IAAA,CAAiB,GAC1CA,EAAA,MAAA,SAAQO,EAAiB,KAAA,GACzBP,EAAA,MAAA,OAAA,GAGE,KAAK,KAAK,EAAEV,GACZ,KAAK,KAAKe,GACV,KAAK,QAAQC,GAETA,KAAS,CAACA,EAAM,YAClBA,EAAM,QAAQ,IAAI,IAAI;AAAA,EAE1B;AAAA,EAEA,UAAe;AACb,QAAI,KAAK,UAAUC,EAAiB;AAClC,aAAO,KAAK;AAId,eAAWC,KAAU,KAAK;AACxB,MAAIA,KAAU,OAAOA,KAAW,YAAY,oBAAoBA,KAC5DA,EAAe,eAAe,IAAI;AAGxC,SAAK,QAAQ,MAAA;AAEb,UAAMC,IAAkBjB;AACxB,IAAAA,IAAqB;AAErB,QAAI;AACF,kBAAK,QAAQe,EAAiB,OAC9B,KAAK,QAAQ,KAAK,GAAA,GACX,KAAK;AAAA,IACd,SAASJ,GAAO;AACd,iBAAK,QAAQI,EAAiB,WAG1B,OAAO,UAAY,OAAe,QAAQ,IAAI,aAAa,WAC7D,QAAQ,MAAM,yBAAyBJ,CAAK,GAExCA;AAAA,IACR,UAAA;AACE,MAAAX,IAAqBiB;AAAA,IACvB;AAAA,EACF;AAAA,EAEA,UAAgB;AACd,QAAI,KAAK,UAAUF,EAAiB,UAEpC;AAAA,WAAK,QAAQA,EAAiB;AAG9B,iBAAWC,KAAU,KAAK;AACxB,QAAIA,KAAU,OAAOA,KAAW,YAAY,oBAAoBA,KAC5DA,EAAe,eAAe,IAAI;AAGxC,WAAK,QAAQ,MAAA;AAGb,iBAAWE,KAAY,KAAK;AAC1B,QAAAA,EAAS,QAAQ,OAAO,IAAI;AAE9B,WAAK,UAAU,MAAA,GAGX,KAAK,SAAS,CAAC,KAAK,MAAM,YAC5B,KAAK,MAAM,QAAQ,OAAO,IAAI;AAAA;AAAA,EAElC;AACF;AAKO,SAASC,EAAcN,GAAmC;AAC/D,QAAMC,IAAQ,IAAIR,EAAUL,CAAY,GAClCmB,IAAYnB;AAClB,EAAAA,IAAea;AAEf,MAAI;AACF,WAAOD,EAAG,MAAMC,EAAM,SAAS;AAAA,EACjC,UAAA;AACE,IAAAb,IAAemB;AAAA,EACjB;AACF;AAKO,SAASC,EAAgBP,GAAqBD,GAAgB;AACnE,QAAMO,IAAYnB;AAClB,EAAAA,IAAea;AAEf,MAAI;AACF,WAAOD,EAAA;AAAA,EACT,UAAA;AACE,IAAAZ,IAAemB;AAAA,EACjB;AACF;AAKO,SAASE,IAAyB;AACvC,SAAOrB;AACT;AAGA,IAAIsB,IAAqC;AAKlC,SAASC,EAAiBX,GAAsB;AACrD,EAAAU,IAAgBV;AAClB;AAKO,SAASY,EAASZ,GAAgB;AACvC,MAAIX;AACF,WAAOW,EAAA;AAGT,QAAMa,IAAcxB;AACpB,EAAAA,IAAa;AAEb,MAAI;AACF,UAAMyB,IAASd,EAAA;AAEf,WAAI,CAACa,KAAeH,KAClBA,EAAA,GAEKI;AAAA,EACT,UAAA;AACE,IAAAzB,IAAawB;AAAA,EACf;AACF;AAKO,SAASE,EAAWf,GAAgB;AACzC,QAAMI,IAAkBjB;AACxB,EAAAA,IAAqB;AAErB,MAAI;AACF,WAAOa,EAAA;AAAA,EACT,UAAA;AACE,IAAAb,IAAqBiB;AAAA,EACvB;AACF;AAcO,SAASY,EAAqBhB,GAAaC,GAAgC;AAChF,QAAML,IAAc,IAAIG,EAAgBC,GAAIC,KAASb,CAAY;AACjE,SAAAQ,EAAY,QAAA,GACLA;AACT;AAKO,SAASqB,IAAsC;AACpD,SAAO;AAAA,IACL,aAAa9B;AAAA,IACb,OAAOE;AAAA,EAAA;AAEX;AAKO,MAAM6B,IAAQ;AAAA,EACnB,uBAAuB,MAAM/B;AAAA,EAC7B,iBAAiB,MAAMC;AAAA,EACvB,qBAAqB,MAAMH;AAAA,EAC3B,eAAe,MAAMC;AAAA,EACrB,YAAY,MAAMG;AACpB;"}
|
package/dist/reactive/effect.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("./context.cjs");function a(e,t={}){const u=s.getCurrentOwner();let r,n=!0;const o=()=>{const f=e(r);return n&&(n=!1),r=f,f},c=new s.ComputationImpl(o,u);return t.name&&Object.defineProperty(c,"name",{value:t.name,enumerable:!1}),c.execute(),c}function l(e,t={}){const u=s.getCurrentOwner();let r,n=!1;const o=()=>{if(!n)return n=!0,e(r);const f=e(r);return r=f,f},c=new s.ComputationImpl(o,u);return t.name&&Object.defineProperty(c,"name",{value:t.name,enumerable:!1}),c.execute(),c}function m(e,t={}){const u=s.getCurrentOwner(),r=()=>{const o=e(void 0);return n.dispose(),o},n=new s.ComputationImpl(r,u);return t.name&&Object.defineProperty(n,"name",{value:`${t.name}(once)`,enumerable:!1}),n.execute(),n}function d(e,t={}){return a(e,{...t,name:`${t.name||"sync"}(sync)`})}function p(e){e.dispose()}function i(e){return e.state===3}function E(e){return{id:e.id,name:e.name||"anonymous",state:e.state,sourceCount:e.sources.size,observerCount:e.observers.size,disposed:i(e),type:"Effect"}}exports.createEffect=a;exports.createOnceEffect=m;exports.createRenderEffect=l;exports.createSyncEffect=d;exports.disposeEffect=p;exports.getEffectInfo=E;exports.isEffectDisposed=i;
|
|
2
|
-
//# sourceMappingURL=effect.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"effect.cjs","sources":["../../src/reactive/effect.ts"],"sourcesContent":["/**\n * Effect implementation for side effects in reactive system\n *\n * Effects run when their dependencies change, enabling reactive\n * side effects like DOM updates, logging, API calls, etc.\n */\n\nimport { ComputationImpl, getCurrentOwner } from './context'\nimport type { EffectFunction, EffectOptions } from './types'\n\n/**\n * Effect function type\n */\nexport type Effect = ComputationImpl\n\n/**\n * Create a reactive effect that runs when dependencies change\n *\n * @param fn The effect function to run\n * @param options Effect configuration options\n * @returns The effect computation\n *\n * @example\n * ```typescript\n * const [count, setCount] = createSignal(0)\n *\n * createEffect(() => {\n * console.log('Count changed:', count())\n * })\n *\n * setCount(5) // Logs: \"Count changed: 5\"\n * ```\n */\nexport function createEffect<T>(fn: EffectFunction<T>, options: EffectOptions = {}): Effect {\n const owner = getCurrentOwner()\n\n let previousValue: T | undefined\n let isFirst = true\n\n const effectFn = () => {\n const nextValue = fn(previousValue)\n\n if (!isFirst) {\n previousValue = nextValue\n } else {\n isFirst = false\n previousValue = nextValue\n }\n\n return nextValue\n }\n\n // Create the computation\n const effect = new ComputationImpl(effectFn, owner)\n\n // Add debug name if provided\n if (options.name) {\n Object.defineProperty(effect, 'name', {\n value: options.name,\n enumerable: false,\n })\n }\n\n // Execute immediately to establish dependencies\n effect.execute()\n\n return effect\n}\n\n/**\n * Create an effect that only runs after dependencies change (not on first run)\n *\n * @param fn The effect function to run\n * @param options Effect configuration options\n * @returns The effect computation\n *\n * @example\n * ```typescript\n * const [count, setCount] = createSignal(0)\n *\n * createRenderEffect(() => {\n * // This won't run immediately, only when count changes\n * document.title = `Count: ${count()}`\n * })\n * ```\n */\nexport function createRenderEffect<T>(fn: EffectFunction<T>, options: EffectOptions = {}): Effect {\n const owner = getCurrentOwner()\n\n let previousValue: T | undefined\n let hasRun = false\n\n const effectFn = () => {\n if (!hasRun) {\n hasRun = true\n // Track dependencies but don't run the effect\n return fn(previousValue)\n }\n\n const nextValue = fn(previousValue)\n previousValue = nextValue\n return nextValue\n }\n\n const effect = new ComputationImpl(effectFn, owner)\n\n if (options.name) {\n Object.defineProperty(effect, 'name', {\n value: options.name,\n enumerable: false,\n })\n }\n\n // Execute to establish dependencies but not run the actual effect\n effect.execute()\n\n return effect\n}\n\n/**\n * Create a one-time effect that disposes itself after first execution\n *\n * @param fn The effect function to run once\n * @param options Effect configuration options\n * @returns The effect computation\n */\nexport function createOnceEffect<T>(fn: EffectFunction<T>, options: EffectOptions = {}): Effect {\n const owner = getCurrentOwner()\n\n const effectFn = () => {\n const result = fn(undefined)\n // Dispose the effect after first run\n effect.dispose()\n return result\n }\n\n const effect = new ComputationImpl(effectFn, owner)\n\n if (options.name) {\n Object.defineProperty(effect, 'name', {\n value: `${options.name}(once)`,\n enumerable: false,\n })\n }\n\n effect.execute()\n\n return effect\n}\n\n/**\n * Create an effect that runs synchronously (not batched)\n *\n * @param fn The effect function to run\n * @param options Effect configuration options\n * @returns The effect computation\n */\nexport function createSyncEffect<T>(fn: EffectFunction<T>, options: EffectOptions = {}): Effect {\n // TODO: Implement synchronous execution\n // For now, use regular effect\n return createEffect(fn, { ...options, name: `${options.name || 'sync'}(sync)` })\n}\n\n/**\n * Dispose an effect\n */\nexport function disposeEffect(effect: Effect): void {\n effect.dispose()\n}\n\n/**\n * Check if an effect is disposed\n */\nexport function isEffectDisposed(effect: Effect): boolean {\n return effect.state === 3 // ComputationState.Disposed\n}\n\n/**\n * Get effect debug information\n */\nexport function getEffectInfo(effect: Effect): object {\n return {\n id: effect.id,\n name: (effect as any).name || 'anonymous',\n state: effect.state,\n sourceCount: effect.sources.size,\n observerCount: effect.observers.size,\n disposed: isEffectDisposed(effect),\n type: 'Effect',\n }\n}\n\n// Re-export types\nexport type { EffectFunction, EffectOptions }\n"],"names":["createEffect","fn","options","owner","getCurrentOwner","previousValue","isFirst","effectFn","nextValue","effect","ComputationImpl","createRenderEffect","hasRun","createOnceEffect","result","createSyncEffect","disposeEffect","isEffectDisposed","getEffectInfo"],"mappings":"iHAiCO,SAASA,EAAgBC,EAAuBC,EAAyB,GAAY,CAC1F,MAAMC,EAAQC,EAAAA,gBAAA,EAEd,IAAIC,EACAC,EAAU,GAEd,MAAMC,EAAW,IAAM,CACrB,MAAMC,EAAYP,EAAGI,CAAa,EAElC,OAAKC,IAGHA,EAAU,IACVD,EAAgBG,EAGXA,CACT,EAGMC,EAAS,IAAIC,kBAAgBH,EAAUJ,CAAK,EAGlD,OAAID,EAAQ,MACV,OAAO,eAAeO,EAAQ,OAAQ,CACpC,MAAOP,EAAQ,KACf,WAAY,EAAA,CACb,EAIHO,EAAO,QAAA,EAEAA,CACT,CAmBO,SAASE,EAAsBV,EAAuBC,EAAyB,GAAY,CAChG,MAAMC,EAAQC,EAAAA,gBAAA,EAEd,IAAIC,EACAO,EAAS,GAEb,MAAML,EAAW,IAAM,CACrB,GAAI,CAACK,EACH,OAAAA,EAAS,GAEFX,EAAGI,CAAa,EAGzB,MAAMG,EAAYP,EAAGI,CAAa,EAClC,OAAAA,EAAgBG,EACTA,CACT,EAEMC,EAAS,IAAIC,kBAAgBH,EAAUJ,CAAK,EAElD,OAAID,EAAQ,MACV,OAAO,eAAeO,EAAQ,OAAQ,CACpC,MAAOP,EAAQ,KACf,WAAY,EAAA,CACb,EAIHO,EAAO,QAAA,EAEAA,CACT,CASO,SAASI,EAAoBZ,EAAuBC,EAAyB,GAAY,CAC9F,MAAMC,EAAQC,EAAAA,gBAAA,EAERG,EAAW,IAAM,CACrB,MAAMO,EAASb,EAAG,MAAS,EAE3B,OAAAQ,EAAO,QAAA,EACAK,CACT,EAEML,EAAS,IAAIC,kBAAgBH,EAAUJ,CAAK,EAElD,OAAID,EAAQ,MACV,OAAO,eAAeO,EAAQ,OAAQ,CACpC,MAAO,GAAGP,EAAQ,IAAI,SACtB,WAAY,EAAA,CACb,EAGHO,EAAO,QAAA,EAEAA,CACT,CASO,SAASM,EAAoBd,EAAuBC,EAAyB,GAAY,CAG9F,OAAOF,EAAaC,EAAI,CAAE,GAAGC,EAAS,KAAM,GAAGA,EAAQ,MAAQ,MAAM,QAAA,CAAU,CACjF,CAKO,SAASc,EAAcP,EAAsB,CAClDA,EAAO,QAAA,CACT,CAKO,SAASQ,EAAiBR,EAAyB,CACxD,OAAOA,EAAO,QAAU,CAC1B,CAKO,SAASS,EAAcT,EAAwB,CACpD,MAAO,CACL,GAAIA,EAAO,GACX,KAAOA,EAAe,MAAQ,YAC9B,MAAOA,EAAO,MACd,YAAaA,EAAO,QAAQ,KAC5B,cAAeA,EAAO,UAAU,KAChC,SAAUQ,EAAiBR,CAAM,EACjC,KAAM,QAAA,CAEV"}
|