signalium 1.2.1 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +34 -0
- package/{build/transform.js → config.js} +1 -5
- package/{build/react.js → debug.js} +1 -5
- package/dist/cjs/config.d.ts +1 -21
- package/dist/cjs/config.d.ts.map +1 -1
- package/dist/cjs/config.js +3 -36
- package/dist/cjs/config.js.map +1 -1
- package/dist/cjs/debug.d.ts +1 -1
- package/dist/cjs/debug.d.ts.map +1 -1
- package/dist/cjs/debug.js +1 -1
- package/dist/cjs/debug.js.map +1 -1
- package/dist/cjs/index.d.ts +5 -6
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +17 -22
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/internals/async.d.ts +24 -19
- package/dist/cjs/internals/async.d.ts.map +1 -1
- package/dist/cjs/internals/async.js +264 -137
- package/dist/cjs/internals/async.js.map +1 -1
- package/dist/cjs/internals/callback.d.ts +13 -0
- package/dist/cjs/internals/callback.d.ts.map +1 -0
- package/dist/cjs/internals/callback.js +73 -0
- package/dist/cjs/internals/callback.js.map +1 -0
- package/dist/cjs/internals/config.d.ts +7 -0
- package/dist/cjs/internals/config.d.ts.map +1 -0
- package/dist/cjs/internals/config.js +17 -0
- package/dist/cjs/internals/config.js.map +1 -0
- package/dist/cjs/internals/consumer.d.ts +3 -3
- package/dist/cjs/internals/consumer.d.ts.map +1 -1
- package/dist/cjs/internals/consumer.js.map +1 -1
- package/dist/cjs/internals/contexts.d.ts +16 -15
- package/dist/cjs/internals/contexts.d.ts.map +1 -1
- package/dist/cjs/internals/contexts.js +58 -56
- package/dist/cjs/internals/contexts.js.map +1 -1
- package/dist/cjs/internals/core-api.d.ts +15 -0
- package/dist/cjs/internals/core-api.d.ts.map +1 -0
- package/dist/cjs/internals/core-api.js +83 -0
- package/dist/cjs/internals/core-api.js.map +1 -0
- package/dist/cjs/internals/dirty.d.ts +3 -3
- package/dist/cjs/internals/dirty.d.ts.map +1 -1
- package/dist/cjs/internals/dirty.js +13 -13
- package/dist/cjs/internals/dirty.js.map +1 -1
- package/dist/cjs/internals/edge.d.ts +5 -5
- package/dist/cjs/internals/edge.d.ts.map +1 -1
- package/dist/cjs/internals/edge.js.map +1 -1
- package/dist/cjs/internals/generators.d.ts +5 -0
- package/dist/cjs/internals/generators.d.ts.map +1 -0
- package/dist/cjs/internals/generators.js +83 -0
- package/dist/cjs/internals/generators.js.map +1 -0
- package/dist/cjs/internals/get.d.ts +5 -8
- package/dist/cjs/internals/get.d.ts.map +1 -1
- package/dist/cjs/internals/get.js +48 -107
- package/dist/cjs/internals/get.js.map +1 -1
- package/dist/cjs/internals/reactive.d.ts +77 -0
- package/dist/cjs/internals/reactive.d.ts.map +1 -0
- package/dist/cjs/internals/{derived.js → reactive.js} +45 -33
- package/dist/cjs/internals/reactive.js.map +1 -0
- package/dist/cjs/internals/scheduling.d.ts +7 -7
- package/dist/cjs/internals/scheduling.d.ts.map +1 -1
- package/dist/cjs/internals/scheduling.js +9 -9
- package/dist/cjs/internals/scheduling.js.map +1 -1
- package/dist/cjs/internals/signal.d.ts +20 -0
- package/dist/cjs/internals/signal.d.ts.map +1 -0
- package/dist/cjs/internals/{state.js → signal.js} +31 -27
- package/dist/cjs/internals/signal.js.map +1 -0
- package/dist/{esm → cjs/internals}/trace.d.ts +1 -1
- package/dist/cjs/internals/trace.d.ts.map +1 -0
- package/dist/cjs/{trace.js → internals/trace.js} +1 -1
- package/dist/cjs/internals/trace.js.map +1 -0
- package/dist/cjs/internals/utils/equals.d.ts +4 -4
- package/dist/cjs/internals/utils/equals.d.ts.map +1 -1
- package/dist/cjs/internals/utils/equals.js.map +1 -1
- package/dist/cjs/internals/utils/type-utils.d.ts +0 -2
- package/dist/cjs/internals/utils/type-utils.d.ts.map +1 -1
- package/dist/cjs/internals/utils/type-utils.js +0 -5
- package/dist/cjs/internals/utils/type-utils.js.map +1 -1
- package/dist/cjs/internals/watch.d.ts +4 -0
- package/dist/cjs/internals/watch.d.ts.map +1 -0
- package/dist/cjs/internals/{connect.js → watch.js} +7 -7
- package/dist/cjs/internals/watch.js.map +1 -0
- package/dist/cjs/internals/weakref.d.ts.map +1 -0
- package/dist/cjs/internals/weakref.js.map +1 -0
- package/dist/cjs/react/component.d.ts +2 -0
- package/dist/cjs/react/component.d.ts.map +1 -0
- package/dist/cjs/react/component.js +40 -0
- package/dist/cjs/react/component.js.map +1 -0
- package/dist/cjs/react/context.d.ts +2 -1
- package/dist/cjs/react/context.d.ts.map +1 -1
- package/dist/cjs/react/context.js +10 -5
- package/dist/cjs/react/context.js.map +1 -1
- package/dist/cjs/react/index.d.ts +4 -4
- package/dist/cjs/react/index.d.ts.map +1 -1
- package/dist/cjs/react/index.js +11 -8
- package/dist/cjs/react/index.js.map +1 -1
- package/dist/cjs/react/provider.d.ts.map +1 -1
- package/dist/cjs/react/provider.js +1 -1
- package/dist/cjs/react/provider.js.map +1 -1
- package/dist/cjs/react/rendering.d.ts +0 -6
- package/dist/cjs/react/rendering.d.ts.map +1 -1
- package/dist/cjs/react/rendering.js +1 -19
- package/dist/cjs/react/rendering.js.map +1 -1
- package/dist/cjs/react/use-reactive.d.ts +7 -0
- package/dist/cjs/react/use-reactive.d.ts.map +1 -0
- package/dist/cjs/react/use-reactive.js +67 -0
- package/dist/cjs/react/use-reactive.js.map +1 -0
- package/dist/cjs/react/use-signal.d.ts +3 -0
- package/dist/cjs/react/use-signal.d.ts.map +1 -0
- package/dist/cjs/react/{state.js → use-signal.js} +5 -5
- package/dist/cjs/react/use-signal.js.map +1 -0
- package/dist/cjs/{transform.d.ts → transform/async.d.ts} +1 -1
- package/dist/cjs/transform/async.d.ts.map +1 -0
- package/dist/cjs/{transform.js → transform/async.js} +22 -9
- package/dist/cjs/transform/async.js.map +1 -0
- package/dist/cjs/transform/callback.d.ts +6 -0
- package/dist/cjs/transform/callback.d.ts.map +1 -0
- package/dist/cjs/transform/callback.js +259 -0
- package/dist/cjs/transform/callback.js.map +1 -0
- package/dist/cjs/transform/index.d.ts +5 -0
- package/dist/cjs/transform/index.d.ts.map +1 -0
- package/dist/cjs/transform/index.js +12 -0
- package/dist/cjs/transform/index.js.map +1 -0
- package/dist/cjs/transform/preset.d.ts +7 -0
- package/dist/cjs/transform/preset.d.ts.map +1 -0
- package/dist/cjs/transform/preset.js +20 -0
- package/dist/cjs/transform/preset.js.map +1 -0
- package/dist/cjs/transform/promise.d.ts +6 -0
- package/dist/cjs/transform/promise.d.ts.map +1 -0
- package/dist/cjs/transform/promise.js +129 -0
- package/dist/cjs/transform/promise.js.map +1 -0
- package/dist/cjs/types.d.ts +44 -63
- package/dist/cjs/types.d.ts.map +1 -1
- package/dist/cjs/utils.d.ts +2 -0
- package/dist/cjs/utils.d.ts.map +1 -0
- package/dist/cjs/utils.js +7 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/esm/config.d.ts +1 -21
- package/dist/esm/config.d.ts.map +1 -1
- package/dist/esm/config.js +1 -29
- package/dist/esm/config.js.map +1 -1
- package/dist/esm/debug.d.ts +1 -1
- package/dist/esm/debug.d.ts.map +1 -1
- package/dist/esm/debug.js +1 -1
- package/dist/esm/debug.js.map +1 -1
- package/dist/esm/index.d.ts +5 -6
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +5 -6
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/internals/async.d.ts +24 -19
- package/dist/esm/internals/async.d.ts.map +1 -1
- package/dist/esm/internals/async.js +253 -128
- package/dist/esm/internals/async.js.map +1 -1
- package/dist/esm/internals/callback.d.ts +13 -0
- package/dist/esm/internals/callback.d.ts.map +1 -0
- package/dist/esm/internals/callback.js +67 -0
- package/dist/esm/internals/callback.js.map +1 -0
- package/dist/esm/internals/config.d.ts +7 -0
- package/dist/esm/internals/config.d.ts.map +1 -0
- package/dist/esm/internals/config.js +11 -0
- package/dist/esm/internals/config.js.map +1 -0
- package/dist/esm/internals/consumer.d.ts +3 -3
- package/dist/esm/internals/consumer.d.ts.map +1 -1
- package/dist/esm/internals/consumer.js.map +1 -1
- package/dist/esm/internals/contexts.d.ts +16 -15
- package/dist/esm/internals/contexts.d.ts.map +1 -1
- package/dist/esm/internals/contexts.js +52 -50
- package/dist/esm/internals/contexts.js.map +1 -1
- package/dist/esm/internals/core-api.d.ts +15 -0
- package/dist/esm/internals/core-api.d.ts.map +1 -0
- package/dist/esm/internals/core-api.js +74 -0
- package/dist/esm/internals/core-api.js.map +1 -0
- package/dist/esm/internals/dirty.d.ts +3 -3
- package/dist/esm/internals/dirty.d.ts.map +1 -1
- package/dist/esm/internals/dirty.js +12 -12
- package/dist/esm/internals/dirty.js.map +1 -1
- package/dist/esm/internals/edge.d.ts +5 -5
- package/dist/esm/internals/edge.d.ts.map +1 -1
- package/dist/esm/internals/edge.js.map +1 -1
- package/dist/esm/internals/generators.d.ts +5 -0
- package/dist/esm/internals/generators.d.ts.map +1 -0
- package/dist/esm/internals/generators.js +79 -0
- package/dist/esm/internals/generators.js.map +1 -0
- package/dist/esm/internals/get.d.ts +5 -8
- package/dist/esm/internals/get.d.ts.map +1 -1
- package/dist/esm/internals/get.js +43 -100
- package/dist/esm/internals/get.js.map +1 -1
- package/dist/esm/internals/reactive.d.ts +77 -0
- package/dist/esm/internals/reactive.d.ts.map +1 -0
- package/dist/esm/internals/{derived.js → reactive.js} +41 -29
- package/dist/esm/internals/reactive.js.map +1 -0
- package/dist/esm/internals/scheduling.d.ts +7 -7
- package/dist/esm/internals/scheduling.d.ts.map +1 -1
- package/dist/esm/internals/scheduling.js +6 -6
- package/dist/esm/internals/scheduling.js.map +1 -1
- package/dist/esm/internals/signal.d.ts +20 -0
- package/dist/esm/internals/signal.d.ts.map +1 -0
- package/dist/esm/internals/{state.js → signal.js} +25 -22
- package/dist/esm/internals/signal.js.map +1 -0
- package/dist/{cjs → esm/internals}/trace.d.ts +1 -1
- package/dist/esm/internals/trace.d.ts.map +1 -0
- package/dist/esm/{trace.js → internals/trace.js} +1 -1
- package/dist/esm/internals/trace.js.map +1 -0
- package/dist/esm/internals/utils/equals.d.ts +4 -4
- package/dist/esm/internals/utils/equals.d.ts.map +1 -1
- package/dist/esm/internals/utils/equals.js.map +1 -1
- package/dist/esm/internals/utils/type-utils.d.ts +0 -2
- package/dist/esm/internals/utils/type-utils.d.ts.map +1 -1
- package/dist/esm/internals/utils/type-utils.js +0 -4
- package/dist/esm/internals/utils/type-utils.js.map +1 -1
- package/dist/esm/internals/watch.d.ts +4 -0
- package/dist/esm/internals/watch.d.ts.map +1 -0
- package/dist/esm/internals/{connect.js → watch.js} +7 -7
- package/dist/esm/internals/watch.js.map +1 -0
- package/dist/esm/internals/weakref.d.ts.map +1 -0
- package/dist/esm/internals/weakref.js.map +1 -0
- package/dist/esm/react/component.d.ts +2 -0
- package/dist/esm/react/component.d.ts.map +1 -0
- package/dist/esm/react/component.js +37 -0
- package/dist/esm/react/component.js.map +1 -0
- package/dist/esm/react/context.d.ts +2 -1
- package/dist/esm/react/context.d.ts.map +1 -1
- package/dist/esm/react/context.js +10 -6
- package/dist/esm/react/context.js.map +1 -1
- package/dist/esm/react/index.d.ts +4 -4
- package/dist/esm/react/index.d.ts.map +1 -1
- package/dist/esm/react/index.js +4 -4
- package/dist/esm/react/index.js.map +1 -1
- package/dist/esm/react/provider.d.ts.map +1 -1
- package/dist/esm/react/provider.js +2 -2
- package/dist/esm/react/provider.js.map +1 -1
- package/dist/esm/react/rendering.d.ts +0 -6
- package/dist/esm/react/rendering.d.ts.map +1 -1
- package/dist/esm/react/rendering.js +1 -17
- package/dist/esm/react/rendering.js.map +1 -1
- package/dist/esm/react/use-reactive.d.ts +7 -0
- package/dist/esm/react/use-reactive.d.ts.map +1 -0
- package/dist/esm/react/use-reactive.js +64 -0
- package/dist/esm/react/use-reactive.js.map +1 -0
- package/dist/esm/react/use-signal.d.ts +3 -0
- package/dist/esm/react/use-signal.d.ts.map +1 -0
- package/dist/esm/react/use-signal.js +10 -0
- package/dist/esm/react/use-signal.js.map +1 -0
- package/dist/esm/{transform.d.ts → transform/async.d.ts} +1 -1
- package/dist/esm/transform/async.d.ts.map +1 -0
- package/dist/esm/{transform.js → transform/async.js} +22 -9
- package/dist/esm/transform/async.js.map +1 -0
- package/dist/esm/transform/callback.d.ts +6 -0
- package/dist/esm/transform/callback.d.ts.map +1 -0
- package/dist/esm/transform/callback.js +256 -0
- package/dist/esm/transform/callback.js.map +1 -0
- package/dist/esm/transform/index.d.ts +5 -0
- package/dist/esm/transform/index.d.ts.map +1 -0
- package/dist/esm/transform/index.js +5 -0
- package/dist/esm/transform/index.js.map +1 -0
- package/dist/esm/transform/preset.d.ts +7 -0
- package/dist/esm/transform/preset.d.ts.map +1 -0
- package/dist/esm/transform/preset.js +17 -0
- package/dist/esm/transform/preset.js.map +1 -0
- package/dist/esm/transform/promise.d.ts +6 -0
- package/dist/esm/transform/promise.d.ts.map +1 -0
- package/dist/esm/transform/promise.js +126 -0
- package/dist/esm/transform/promise.js.map +1 -0
- package/dist/esm/types.d.ts +44 -63
- package/dist/esm/types.d.ts.map +1 -1
- package/dist/esm/utils.d.ts +2 -0
- package/dist/esm/utils.d.ts.map +1 -0
- package/dist/esm/utils.js +2 -0
- package/dist/esm/utils.js.map +1 -0
- package/package.json +56 -58
- package/react.js +0 -4
- package/transform.js +1 -5
- package/utils.js +15 -0
- package/.turbo/turbo-build.log +0 -12
- package/dist/cjs/hooks.d.ts +0 -16
- package/dist/cjs/hooks.d.ts.map +0 -1
- package/dist/cjs/hooks.js +0 -44
- package/dist/cjs/hooks.js.map +0 -1
- package/dist/cjs/internals/connect.d.ts +0 -4
- package/dist/cjs/internals/connect.d.ts.map +0 -1
- package/dist/cjs/internals/connect.js.map +0 -1
- package/dist/cjs/internals/derived.d.ts +0 -76
- package/dist/cjs/internals/derived.d.ts.map +0 -1
- package/dist/cjs/internals/derived.js.map +0 -1
- package/dist/cjs/internals/state.d.ts +0 -18
- package/dist/cjs/internals/state.d.ts.map +0 -1
- package/dist/cjs/internals/state.js.map +0 -1
- package/dist/cjs/react/setup.d.ts +0 -2
- package/dist/cjs/react/setup.d.ts.map +0 -1
- package/dist/cjs/react/setup.js +0 -14
- package/dist/cjs/react/setup.js.map +0 -1
- package/dist/cjs/react/signal-value.d.ts +0 -6
- package/dist/cjs/react/signal-value.d.ts.map +0 -1
- package/dist/cjs/react/signal-value.js +0 -37
- package/dist/cjs/react/signal-value.js.map +0 -1
- package/dist/cjs/react/state.d.ts +0 -3
- package/dist/cjs/react/state.d.ts.map +0 -1
- package/dist/cjs/react/state.js.map +0 -1
- package/dist/cjs/trace.d.ts.map +0 -1
- package/dist/cjs/trace.js.map +0 -1
- package/dist/cjs/transform.d.ts.map +0 -1
- package/dist/cjs/transform.js.map +0 -1
- package/dist/cjs/weakref.d.ts.map +0 -1
- package/dist/cjs/weakref.js.map +0 -1
- package/dist/esm/hooks.d.ts +0 -16
- package/dist/esm/hooks.d.ts.map +0 -1
- package/dist/esm/hooks.js +0 -37
- package/dist/esm/hooks.js.map +0 -1
- package/dist/esm/internals/connect.d.ts +0 -4
- package/dist/esm/internals/connect.d.ts.map +0 -1
- package/dist/esm/internals/connect.js.map +0 -1
- package/dist/esm/internals/derived.d.ts +0 -76
- package/dist/esm/internals/derived.d.ts.map +0 -1
- package/dist/esm/internals/derived.js.map +0 -1
- package/dist/esm/internals/state.d.ts +0 -18
- package/dist/esm/internals/state.d.ts.map +0 -1
- package/dist/esm/internals/state.js.map +0 -1
- package/dist/esm/react/setup.d.ts +0 -2
- package/dist/esm/react/setup.d.ts.map +0 -1
- package/dist/esm/react/setup.js +0 -11
- package/dist/esm/react/setup.js.map +0 -1
- package/dist/esm/react/signal-value.d.ts +0 -6
- package/dist/esm/react/signal-value.d.ts.map +0 -1
- package/dist/esm/react/signal-value.js +0 -33
- package/dist/esm/react/signal-value.js.map +0 -1
- package/dist/esm/react/state.d.ts +0 -3
- package/dist/esm/react/state.d.ts.map +0 -1
- package/dist/esm/react/state.js +0 -10
- package/dist/esm/react/state.js.map +0 -1
- package/dist/esm/trace.d.ts.map +0 -1
- package/dist/esm/trace.js.map +0 -1
- package/dist/esm/transform.d.ts.map +0 -1
- package/dist/esm/transform.js.map +0 -1
- package/dist/esm/weakref.d.ts.map +0 -1
- package/dist/esm/weakref.js.map +0 -1
- package/src/__tests__/__snapshots__/context.test.ts.snap +0 -2101
- package/src/__tests__/__snapshots__/nesting.test.ts.snap +0 -16201
- package/src/__tests__/__snapshots__/params-and-state.test.ts.snap +0 -1879
- package/src/__tests__/async-task.test.ts +0 -327
- package/src/__tests__/context.test.ts +0 -619
- package/src/__tests__/gc.test.ts +0 -256
- package/src/__tests__/nesting.test.ts +0 -298
- package/src/__tests__/params-and-state.test.ts +0 -230
- package/src/__tests__/reactive-async.test.ts +0 -548
- package/src/__tests__/reactive-sync.test.ts +0 -130
- package/src/__tests__/subscription.test.ts +0 -510
- package/src/__tests__/utils/async.ts +0 -6
- package/src/__tests__/utils/instrumented-hooks.ts +0 -410
- package/src/__tests__/utils/permute.ts +0 -85
- package/src/config.ts +0 -54
- package/src/debug.ts +0 -14
- package/src/hooks.ts +0 -82
- package/src/index.ts +0 -20
- package/src/internals/async.ts +0 -563
- package/src/internals/connect.ts +0 -49
- package/src/internals/consumer.ts +0 -13
- package/src/internals/contexts.ts +0 -173
- package/src/internals/derived.ts +0 -217
- package/src/internals/dirty.ts +0 -91
- package/src/internals/edge.ts +0 -109
- package/src/internals/get.ts +0 -298
- package/src/internals/scheduling.ts +0 -160
- package/src/internals/state.ts +0 -111
- package/src/internals/utils/debug-name.ts +0 -14
- package/src/internals/utils/equals.ts +0 -12
- package/src/internals/utils/hash.ts +0 -221
- package/src/internals/utils/stringify.ts +0 -57
- package/src/internals/utils/type-utils.ts +0 -19
- package/src/react/__tests__/async.test.tsx +0 -704
- package/src/react/__tests__/basic.test.tsx +0 -95
- package/src/react/__tests__/contexts.test.tsx +0 -181
- package/src/react/__tests__/subscriptions.test.tsx +0 -49
- package/src/react/__tests__/utils.tsx +0 -40
- package/src/react/context.ts +0 -14
- package/src/react/index.ts +0 -6
- package/src/react/provider.tsx +0 -18
- package/src/react/rendering.ts +0 -43
- package/src/react/setup.ts +0 -11
- package/src/react/signal-value.ts +0 -50
- package/src/react/state.ts +0 -13
- package/src/trace.ts +0 -454
- package/src/transform.ts +0 -113
- package/src/types.ts +0 -115
- package/src/weakref.ts +0 -9
- package/tsconfig.json +0 -13
- package/vitest.workspace.ts +0 -61
- /package/dist/cjs/{weakref.d.ts → internals/weakref.d.ts} +0 -0
- /package/dist/cjs/{weakref.js → internals/weakref.js} +0 -0
- /package/dist/esm/{weakref.d.ts → internals/weakref.d.ts} +0 -0
- /package/dist/esm/{weakref.js → internals/weakref.js} +0 -0
@@ -1,4 +1,5 @@
|
|
1
|
-
import { SignalScope } from '../internals/contexts.js';
|
1
|
+
import { Context, SignalScope } from '../internals/contexts.js';
|
2
2
|
export declare const ScopeContext: import("react").Context<SignalScope | undefined>;
|
3
3
|
export declare function useScope(): SignalScope | undefined;
|
4
|
+
export declare function useContext<T>(context: Context<T>): T;
|
4
5
|
//# sourceMappingURL=context.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/react/context.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/react/context.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAe,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAG7E,eAAO,MAAM,YAAY,kDAAoD,CAAC;AAE9E,wBAAgB,QAAQ,4BAEvB;AAED,wBAAgB,UAAU,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CASpD"}
|
@@ -2,14 +2,19 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.ScopeContext = void 0;
|
4
4
|
exports.useScope = useScope;
|
5
|
+
exports.useContext = useContext;
|
5
6
|
const react_1 = require("react");
|
6
|
-
const
|
7
|
+
const consumer_js_1 = require("../internals/consumer.js");
|
7
8
|
exports.ScopeContext = (0, react_1.createContext)(undefined);
|
8
9
|
function useScope() {
|
9
|
-
if (!(0, rendering_js_1.isRendering)()) {
|
10
|
-
return undefined;
|
11
|
-
}
|
12
|
-
// eslint-disable-next-line react-hooks/rules-of-hooks
|
13
10
|
return (0, react_1.useContext)(exports.ScopeContext);
|
14
11
|
}
|
12
|
+
function useContext(context) {
|
13
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
14
|
+
const scope = consumer_js_1.CURRENT_CONSUMER?.scope ?? useScope();
|
15
|
+
if (!scope) {
|
16
|
+
throw new Error('useContext must be used within a signal hook, a withContext, or a component');
|
17
|
+
}
|
18
|
+
return scope.getContext(context) ?? context.defaultValue;
|
19
|
+
}
|
15
20
|
//# sourceMappingURL=context.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/react/context.ts"],"names":[],"mappings":";;;AAMA,
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/react/context.ts"],"names":[],"mappings":";;;AAMA,4BAEC;AAED,gCASC;AAnBD,iCAAqE;AAErE,0DAA4D;AAE/C,QAAA,YAAY,GAAG,IAAA,qBAAa,EAA0B,SAAS,CAAC,CAAC;AAE9E,SAAgB,QAAQ;IACtB,OAAO,IAAA,kBAAe,EAAC,oBAAY,CAAC,CAAC;AACvC,CAAC;AAED,SAAgB,UAAU,CAAI,OAAmB;IAC/C,sDAAsD;IACtD,MAAM,KAAK,GAAG,8BAAgB,EAAE,KAAK,IAAI,QAAQ,EAAE,CAAC;IAEpD,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;IACjG,CAAC;IAED,OAAO,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,IAAK,OAAqC,CAAC,YAAY,CAAC;AAC1F,CAAC"}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
export { ContextProvider } from './provider.js';
|
2
|
-
export {
|
3
|
-
export {
|
4
|
-
export {
|
5
|
-
export {
|
2
|
+
export { default as component } from './component.js';
|
3
|
+
export { useContext } from './context.js';
|
4
|
+
export { useSignal } from './use-signal.js';
|
5
|
+
export { useReactive } from './use-reactive.js';
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC"}
|
package/dist/cjs/react/index.js
CHANGED
@@ -1,14 +1,17 @@
|
|
1
1
|
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.
|
6
|
+
exports.useReactive = exports.useSignal = exports.useContext = exports.component = exports.ContextProvider = void 0;
|
4
7
|
var provider_js_1 = require("./provider.js");
|
5
8
|
Object.defineProperty(exports, "ContextProvider", { enumerable: true, get: function () { return provider_js_1.ContextProvider; } });
|
9
|
+
var component_js_1 = require("./component.js");
|
10
|
+
Object.defineProperty(exports, "component", { enumerable: true, get: function () { return __importDefault(component_js_1).default; } });
|
6
11
|
var context_js_1 = require("./context.js");
|
7
|
-
Object.defineProperty(exports, "
|
8
|
-
var
|
9
|
-
Object.defineProperty(exports, "
|
10
|
-
var
|
11
|
-
Object.defineProperty(exports, "
|
12
|
-
var rendering_js_1 = require("./rendering.js");
|
13
|
-
Object.defineProperty(exports, "runReactiveSafe", { enumerable: true, get: function () { return rendering_js_1.runReactiveSafe; } });
|
12
|
+
Object.defineProperty(exports, "useContext", { enumerable: true, get: function () { return context_js_1.useContext; } });
|
13
|
+
var use_signal_js_1 = require("./use-signal.js");
|
14
|
+
Object.defineProperty(exports, "useSignal", { enumerable: true, get: function () { return use_signal_js_1.useSignal; } });
|
15
|
+
var use_reactive_js_1 = require("./use-reactive.js");
|
16
|
+
Object.defineProperty(exports, "useReactive", { enumerable: true, get: function () { return use_reactive_js_1.useReactive; } });
|
14
17
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/react/index.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAgD;AAAvC,8GAAA,eAAe,OAAA;AACxB,+CAAsD;AAA7C,0HAAA,OAAO,OAAa;AAC7B,2CAA0C;AAAjC,wGAAA,UAAU,OAAA;AACnB,iDAA4C;AAAnC,0GAAA,SAAS,OAAA;AAClB,qDAAgD;AAAvC,8GAAA,WAAW,OAAA"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../../src/react/provider.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAe,WAAW,
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../../src/react/provider.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAe,WAAW,EAA6B,MAAM,0BAA0B,CAAC;AAE/F,wBAAgB,eAAe,CAAC,CAAC,SAAS,OAAO,EAAE,EAAE,EACnD,QAAQ,EACR,QAAa,EACb,OAAc,GACf,EAAE;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;IACpC,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,2CAKA"}
|
@@ -6,7 +6,7 @@ const react_1 = require("react");
|
|
6
6
|
const context_js_1 = require("./context.js");
|
7
7
|
const contexts_js_1 = require("../internals/contexts.js");
|
8
8
|
function ContextProvider({ children, contexts = [], inherit = true, }) {
|
9
|
-
const parentScope = (0, react_1.useContext)(context_js_1.ScopeContext) ?? contexts_js_1.
|
9
|
+
const parentScope = (0, react_1.useContext)(context_js_1.ScopeContext) ?? contexts_js_1.GLOBAL_SCOPE;
|
10
10
|
const scope = new contexts_js_1.SignalScope(contexts, inherit ? parentScope : undefined);
|
11
11
|
return (0, jsx_runtime_1.jsx)(context_js_1.ScopeContext.Provider, { value: scope, children: children });
|
12
12
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../src/react/provider.tsx"],"names":[],"mappings":";;AAIA,0CAaC;;AAjBD,iCAAmC;AACnC,6CAA4C;AAC5C,
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../src/react/provider.tsx"],"names":[],"mappings":";;AAIA,0CAaC;;AAjBD,iCAAmC;AACnC,6CAA4C;AAC5C,0DAA+F;AAE/F,SAAgB,eAAe,CAAsB,EACnD,QAAQ,EACR,QAAQ,GAAG,EAAE,EACb,OAAO,GAAG,IAAI,GAKf;IACC,MAAM,WAAW,GAAG,IAAA,kBAAU,EAAC,yBAAY,CAAC,IAAI,0BAAY,CAAC;IAC7D,MAAM,KAAK,GAAG,IAAI,yBAAW,CAAC,QAA6C,EAAE,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAEhH,OAAO,uBAAC,yBAAY,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YAAG,QAAQ,GAAyB,CAAC;AACjF,CAAC"}
|
@@ -1,8 +1,2 @@
|
|
1
|
-
/**
|
2
|
-
* Reactive functions can be called anywhere, but React Hooks cannot. When calling reactive functions
|
3
|
-
* in code that _may or may not_ be used while rendering, we need to use this function to wrap the
|
4
|
-
* call. This will ensure that we will not be in a rendering context when the reactive function is called.
|
5
|
-
*/
|
6
|
-
export declare const runReactiveSafe: <T>(fn: () => T) => T;
|
7
1
|
export declare function isRendering(): boolean;
|
8
2
|
//# sourceMappingURL=rendering.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"rendering.d.ts","sourceRoot":"","sources":["../../../src/react/rendering.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"rendering.d.ts","sourceRoot":"","sources":["../../../src/react/rendering.ts"],"names":[],"mappings":"AAcA,wBAAgB,WAAW,YAU1B"}
|
@@ -3,7 +3,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
4
|
};
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.runReactiveSafe = void 0;
|
7
6
|
exports.isRendering = isRendering;
|
8
7
|
const react_1 = __importDefault(require("react"));
|
9
8
|
// This is a private React internal that we need to access to check if we are rendering.
|
@@ -15,26 +14,9 @@ const REACT_INTERNALS = react_1.default.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WIL
|
|
15
14
|
react_1.default.__SERVER_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;
|
16
15
|
const IS_REACT_18 = !!REACT_INTERNALS.ReactCurrentDispatcher;
|
17
16
|
const ReactCurrentDispatcher = REACT_INTERNALS.ReactCurrentDispatcher || REACT_INTERNALS;
|
18
|
-
let RENDERING_SAFE_MODE_COUNT = 0;
|
19
|
-
/**
|
20
|
-
* Reactive functions can be called anywhere, but React Hooks cannot. When calling reactive functions
|
21
|
-
* in code that _may or may not_ be used while rendering, we need to use this function to wrap the
|
22
|
-
* call. This will ensure that we will not be in a rendering context when the reactive function is called.
|
23
|
-
*/
|
24
|
-
const runReactiveSafe = (fn) => {
|
25
|
-
RENDERING_SAFE_MODE_COUNT++;
|
26
|
-
try {
|
27
|
-
return fn();
|
28
|
-
}
|
29
|
-
finally {
|
30
|
-
RENDERING_SAFE_MODE_COUNT--;
|
31
|
-
}
|
32
|
-
};
|
33
|
-
exports.runReactiveSafe = runReactiveSafe;
|
34
17
|
function isRendering() {
|
35
18
|
const dispatcher = IS_REACT_18 ? ReactCurrentDispatcher.current : ReactCurrentDispatcher.H;
|
36
|
-
return (
|
37
|
-
!!dispatcher &&
|
19
|
+
return (!!dispatcher &&
|
38
20
|
// dispatcher can be in a state where it's defined, but all hooks are invalid to call.
|
39
21
|
// Only way we can tell is that if they are invalid, they will all be equal to each other
|
40
22
|
// (e.g. because it's the function that throws an error)
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"rendering.js","sourceRoot":"","sources":["../../../src/react/rendering.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"rendering.js","sourceRoot":"","sources":["../../../src/react/rendering.ts"],"names":[],"mappings":";;;;;AAcA,kCAUC;AAxBD,kDAA0B;AAE1B,wFAAwF;AACxF,oFAAoF;AACpF,mFAAmF;AACnF,0DAA0D;AAC1D,MAAM,eAAe,GAClB,eAAa,CAAC,kDAAkD;IAChE,eAAa,CAAC,+DAA+D;IAC7E,eAAa,CAAC,+DAA+D,CAAC;AAEjF,MAAM,WAAW,GAAG,CAAC,CAAC,eAAe,CAAC,sBAAsB,CAAC;AAC7D,MAAM,sBAAsB,GAAG,eAAe,CAAC,sBAAsB,IAAI,eAAe,CAAC;AAEzF,SAAgB,WAAW;IACzB,MAAM,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC;IAE3F,OAAO,CACL,CAAC,CAAC,UAAU;QACZ,sFAAsF;QACtF,yFAAyF;QACzF,wDAAwD;QACxD,UAAU,CAAC,QAAQ,KAAK,UAAU,CAAC,SAAS,CAC7C,CAAC;AACJ,CAAC"}
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import { Signal, ReactivePromise } from '../types.js';
|
2
|
+
type Narrowable = string | number | boolean | null | undefined | bigint | symbol | {};
|
3
|
+
export declare function useReactive<R>(signal: Signal<R>): R;
|
4
|
+
export declare function useReactive<R>(signal: ReactivePromise<R>): ReactivePromise<R>;
|
5
|
+
export declare function useReactive<R, Args extends readonly Narrowable[]>(fn: (...args: Args) => R, ...args: Args): R;
|
6
|
+
export {};
|
7
|
+
//# sourceMappingURL=use-reactive.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"use-reactive.d.ts","sourceRoot":"","sources":["../../../src/react/use-reactive.ts"],"names":[],"mappings":"AAEA,OAAO,EAAiB,MAAM,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AA+DrE,KAAK,UAAU,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,EAAE,CAAC;AAEtF,wBAAgB,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;AACrD,wBAAgB,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC;AAC/E,wBAAgB,WAAW,CAAC,CAAC,EAAE,IAAI,SAAS,SAAS,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,GAAG,CAAC,CAAC"}
|
@@ -0,0 +1,67 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.useReactive = useReactive;
|
4
|
+
/* eslint-disable react-hooks/rules-of-hooks */
|
5
|
+
const react_1 = require("react");
|
6
|
+
const core_api_js_1 = require("../internals/core-api.js");
|
7
|
+
const consumer_js_1 = require("../internals/consumer.js");
|
8
|
+
const async_js_1 = require("../internals/async.js");
|
9
|
+
const context_js_1 = require("./context.js");
|
10
|
+
const contexts_js_1 = require("../internals/contexts.js");
|
11
|
+
const useStateSignal = (signal) => {
|
12
|
+
return (0, react_1.useSyncExternalStore)((0, react_1.useCallback)(onStoreChange => signal.addListener(onStoreChange), [signal]), () => signal.value, () => signal.value);
|
13
|
+
};
|
14
|
+
const useReactiveFnSignal = (signal) => {
|
15
|
+
return (0, react_1.useSyncExternalStore)(signal.addListenerLazy(), () => signal.value, () => signal.value);
|
16
|
+
};
|
17
|
+
const useReactivePromise = (promise) => {
|
18
|
+
if ((0, async_js_1.isRelay)(promise)) {
|
19
|
+
useReactiveFnSignal(promise['_signal']);
|
20
|
+
}
|
21
|
+
useStateSignal(promise['_version']);
|
22
|
+
return promise;
|
23
|
+
};
|
24
|
+
const useReactiveFn = (fn, ...args) => {
|
25
|
+
const [, def] = (0, core_api_js_1.getReactiveFnAndDefinition)(fn);
|
26
|
+
const scope = (0, context_js_1.useScope)() ?? contexts_js_1.GLOBAL_SCOPE;
|
27
|
+
const signal = scope.get(def, args);
|
28
|
+
const value = useReactiveFnSignal(signal);
|
29
|
+
// Reactive promises can update their value independently of the signal, since
|
30
|
+
// we reuse the same promise object for each result. We need to entangle the
|
31
|
+
// version of the promise here so that we can trigger a re-render when the
|
32
|
+
// promise value updates.
|
33
|
+
//
|
34
|
+
// If hooks could be called in dynamic order this would not be necessary, we
|
35
|
+
// could entangle the promise when it is used. But, because that is not the
|
36
|
+
// case, we need to eagerly entangle.
|
37
|
+
if (typeof value === 'object' && value !== null && (0, async_js_1.isReactivePromise)(value)) {
|
38
|
+
return useReactivePromise(value);
|
39
|
+
}
|
40
|
+
return value;
|
41
|
+
};
|
42
|
+
const isNonNullishAsyncSignal = (value) => {
|
43
|
+
return typeof value === 'object' && value !== null && (0, async_js_1.isReactivePromise)(value);
|
44
|
+
};
|
45
|
+
function useReactive(signal, ...args) {
|
46
|
+
if (consumer_js_1.CURRENT_CONSUMER) {
|
47
|
+
if (typeof signal === 'function') {
|
48
|
+
return signal(...args);
|
49
|
+
}
|
50
|
+
else if (isNonNullishAsyncSignal(signal)) {
|
51
|
+
return signal;
|
52
|
+
}
|
53
|
+
else {
|
54
|
+
return signal.value;
|
55
|
+
}
|
56
|
+
}
|
57
|
+
if (typeof signal === 'function') {
|
58
|
+
return useReactiveFn(signal, ...args);
|
59
|
+
}
|
60
|
+
else if (typeof signal === 'object' && signal !== null && (0, async_js_1.isReactivePromise)(signal)) {
|
61
|
+
return useReactivePromise(signal);
|
62
|
+
}
|
63
|
+
else {
|
64
|
+
return useStateSignal(signal);
|
65
|
+
}
|
66
|
+
}
|
67
|
+
//# sourceMappingURL=use-reactive.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"use-reactive.js","sourceRoot":"","sources":["../../../src/react/use-reactive.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"use-signal.d.ts","sourceRoot":"","sources":["../../../src/react/use-signal.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAGpD,wBAAgB,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAQzE"}
|
@@ -1,13 +1,13 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.
|
3
|
+
exports.useSignal = useSignal;
|
4
4
|
const react_1 = require("react");
|
5
|
-
const
|
6
|
-
function
|
5
|
+
const index_js_1 = require("../index.js");
|
6
|
+
function useSignal(value, opts) {
|
7
7
|
const ref = (0, react_1.useRef)(undefined);
|
8
8
|
if (!ref.current) {
|
9
|
-
ref.current = (0,
|
9
|
+
ref.current = (0, index_js_1.signal)(value, opts);
|
10
10
|
}
|
11
11
|
return ref.current;
|
12
12
|
}
|
13
|
-
//# sourceMappingURL=
|
13
|
+
//# sourceMappingURL=use-signal.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"use-signal.js","sourceRoot":"","sources":["../../../src/react/use-signal.ts"],"names":[],"mappings":";;AAIA,8BAQC;AAZD,iCAA+B;AAE/B,0CAAqC;AAErC,SAAgB,SAAS,CAAI,KAAQ,EAAE,IAAuB;IAC5D,MAAM,GAAG,GAAG,IAAA,cAAM,EAAwB,SAAS,CAAC,CAAC;IAErD,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACjB,GAAG,CAAC,OAAO,GAAG,IAAA,iBAAM,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,OAAO,GAAG,CAAC,OAAO,CAAC;AACrB,CAAC"}
|
@@ -3,4 +3,4 @@ export interface SignaliumAsyncTransformOptions {
|
|
3
3
|
transformedImports: [string, string | RegExp][];
|
4
4
|
}
|
5
5
|
export declare function signaliumAsyncTransform(opts?: SignaliumAsyncTransformOptions): (api: any) => PluginObj;
|
6
|
-
//# sourceMappingURL=
|
6
|
+
//# sourceMappingURL=async.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"async.d.ts","sourceRoot":"","sources":["../../../src/transform/async.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAY,SAAS,EAAc,MAAM,aAAa,CAAC;AAEnE,MAAM,WAAW,8BAA8B;IAC7C,kBAAkB,EAAE,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;CACjD;AAED,wBAAgB,uBAAuB,CAAC,IAAI,CAAC,EAAE,8BAA8B,GAAG,CAAC,GAAG,EAAE,GAAG,KAAK,SAAS,CAqHtG"}
|
@@ -5,7 +5,8 @@ function signaliumAsyncTransform(opts) {
|
|
5
5
|
const transformedImports = {
|
6
6
|
callback: ['signalium'],
|
7
7
|
reactive: ['signalium'],
|
8
|
-
|
8
|
+
reactiveMethod: ['signalium'],
|
9
|
+
relay: ['signalium'],
|
9
10
|
task: ['signalium'],
|
10
11
|
};
|
11
12
|
for (const [name, path] of opts?.transformedImports ?? []) {
|
@@ -23,22 +24,34 @@ function signaliumAsyncTransform(opts) {
|
|
23
24
|
if (!t.isCallExpression(path.node))
|
24
25
|
return false;
|
25
26
|
const callee = path.node.callee;
|
26
|
-
|
27
|
-
if (!importPath)
|
27
|
+
if (!t.isIdentifier(callee))
|
28
28
|
return false;
|
29
|
-
//
|
29
|
+
// Resolve binding for the local identifier (may be aliased)
|
30
30
|
const binding = path.scope.getBinding(callee.name);
|
31
31
|
if (!binding || !t.isImportSpecifier(binding.path.node))
|
32
32
|
return false;
|
33
|
+
const importSpec = binding.path.node;
|
34
|
+
const imported = importSpec.imported.name;
|
33
35
|
const importDecl = binding.path.parent;
|
34
36
|
if (!t.isImportDeclaration(importDecl))
|
35
37
|
return false;
|
36
|
-
|
38
|
+
const importPaths = transformedImports[imported];
|
39
|
+
if (!importPaths)
|
40
|
+
return false;
|
41
|
+
return importPaths.some(p => typeof p === 'string' ? importDecl.source.value === p : p.test(importDecl.source.value));
|
42
|
+
};
|
43
|
+
const isWithinTrackedCall = (path) => {
|
44
|
+
let current = path.parentPath;
|
45
|
+
while (current) {
|
46
|
+
if (current.isCallExpression() && isReactiveCall(current))
|
47
|
+
return true;
|
48
|
+
current = current.parentPath;
|
49
|
+
}
|
50
|
+
return false;
|
37
51
|
};
|
38
52
|
function convertReactiveToGenerator(path) {
|
39
|
-
// Only transform if
|
40
|
-
|
41
|
-
if (!isReactiveCall(parentPath))
|
53
|
+
// Only transform if within a tracked call (reactive/task/relay/callback)
|
54
|
+
if (!isWithinTrackedCall(path))
|
42
55
|
return;
|
43
56
|
if (!path.node.async)
|
44
57
|
return;
|
@@ -89,4 +102,4 @@ function signaliumAsyncTransform(opts) {
|
|
89
102
|
};
|
90
103
|
};
|
91
104
|
}
|
92
|
-
//# sourceMappingURL=
|
105
|
+
//# sourceMappingURL=async.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"async.js","sourceRoot":"","sources":["../../../src/transform/async.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import type { PluginObj } from '@babel/core';
|
2
|
+
export interface SignaliumCallbackTransformOptions {
|
3
|
+
transformedImports: [string, string | RegExp][];
|
4
|
+
}
|
5
|
+
export declare function signaliumCallbackTransform(opts?: SignaliumCallbackTransformOptions): (api: any) => PluginObj;
|
6
|
+
//# sourceMappingURL=callback.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"callback.d.ts","sourceRoot":"","sources":["../../../src/transform/callback.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAY,SAAS,EAAc,MAAM,aAAa,CAAC;AAEnE,MAAM,WAAW,iCAAiC;IAChD,kBAAkB,EAAE,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;CACjD;AAED,wBAAgB,0BAA0B,CAAC,IAAI,CAAC,EAAE,iCAAiC,GAAG,CAAC,GAAG,EAAE,GAAG,KAAK,SAAS,CAqR5G"}
|