signalium 2.0.8 → 2.1.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 +17 -0
- package/dist/cjs/internals/async.d.ts +1 -0
- package/dist/cjs/internals/async.d.ts.map +1 -1
- package/dist/cjs/internals/async.js +48 -15
- package/dist/cjs/internals/async.js.map +1 -1
- package/dist/cjs/internals/contexts.d.ts.map +1 -1
- package/dist/cjs/internals/contexts.js +7 -1
- package/dist/cjs/internals/contexts.js.map +1 -1
- package/dist/cjs/internals/edge.d.ts.map +1 -1
- package/dist/cjs/internals/edge.js +3 -0
- package/dist/cjs/internals/edge.js.map +1 -1
- package/dist/cjs/internals/get.d.ts.map +1 -1
- package/dist/cjs/internals/get.js +5 -0
- package/dist/cjs/internals/get.js.map +1 -1
- package/dist/cjs/internals/reactive.d.ts +1 -0
- package/dist/cjs/internals/reactive.d.ts.map +1 -1
- package/dist/cjs/internals/reactive.js +2 -0
- package/dist/cjs/internals/reactive.js.map +1 -1
- package/dist/cjs/internals/scheduling.d.ts +1 -0
- package/dist/cjs/internals/scheduling.d.ts.map +1 -1
- package/dist/cjs/internals/scheduling.js +9 -5
- package/dist/cjs/internals/scheduling.js.map +1 -1
- package/dist/cjs/internals/watch.js +1 -1
- package/dist/cjs/internals/watch.js.map +1 -1
- package/dist/cjs/react/component.d.ts.map +1 -1
- package/dist/cjs/react/component.js +4 -1
- package/dist/cjs/react/component.js.map +1 -1
- package/dist/cjs/react/index.d.ts +1 -0
- package/dist/cjs/react/index.d.ts.map +1 -1
- package/dist/cjs/react/index.js +3 -1
- package/dist/cjs/react/index.js.map +1 -1
- package/dist/cjs/react/suspend-signals-context.d.ts +3 -0
- package/dist/cjs/react/suspend-signals-context.d.ts.map +1 -0
- package/dist/cjs/react/suspend-signals-context.js +11 -0
- package/dist/cjs/react/suspend-signals-context.js.map +1 -0
- package/dist/cjs/react/use-reactive.d.ts.map +1 -1
- package/dist/cjs/react/use-reactive.js +10 -2
- package/dist/cjs/react/use-reactive.js.map +1 -1
- package/dist/esm/internals/async.d.ts +1 -0
- package/dist/esm/internals/async.d.ts.map +1 -1
- package/dist/esm/internals/async.js +48 -15
- package/dist/esm/internals/async.js.map +1 -1
- package/dist/esm/internals/contexts.d.ts.map +1 -1
- package/dist/esm/internals/contexts.js +7 -1
- package/dist/esm/internals/contexts.js.map +1 -1
- package/dist/esm/internals/edge.d.ts.map +1 -1
- package/dist/esm/internals/edge.js +3 -0
- package/dist/esm/internals/edge.js.map +1 -1
- package/dist/esm/internals/get.d.ts.map +1 -1
- package/dist/esm/internals/get.js +5 -0
- package/dist/esm/internals/get.js.map +1 -1
- package/dist/esm/internals/reactive.d.ts +1 -0
- package/dist/esm/internals/reactive.d.ts.map +1 -1
- package/dist/esm/internals/reactive.js +3 -1
- package/dist/esm/internals/reactive.js.map +1 -1
- package/dist/esm/internals/scheduling.d.ts +1 -0
- package/dist/esm/internals/scheduling.d.ts.map +1 -1
- package/dist/esm/internals/scheduling.js +7 -4
- package/dist/esm/internals/scheduling.js.map +1 -1
- package/dist/esm/internals/watch.js +1 -1
- package/dist/esm/internals/watch.js.map +1 -1
- package/dist/esm/react/component.d.ts.map +1 -1
- package/dist/esm/react/component.js +4 -1
- package/dist/esm/react/component.js.map +1 -1
- package/dist/esm/react/index.d.ts +1 -0
- package/dist/esm/react/index.d.ts.map +1 -1
- package/dist/esm/react/index.js +1 -0
- package/dist/esm/react/index.js.map +1 -1
- package/dist/esm/react/suspend-signals-context.d.ts +3 -0
- package/dist/esm/react/suspend-signals-context.d.ts.map +1 -0
- package/dist/esm/react/suspend-signals-context.js +7 -0
- package/dist/esm/react/suspend-signals-context.js.map +1 -0
- package/dist/esm/react/use-reactive.d.ts.map +1 -1
- package/dist/esm/react/use-reactive.js +10 -2
- package/dist/esm/react/use-reactive.js.map +1 -1
- package/package.json +1 -1
|
@@ -7,7 +7,7 @@ import { unwatchSignal } from './watch.js';
|
|
|
7
7
|
// Determine once at startup which scheduling function to use for GC
|
|
8
8
|
const scheduleIdleCallback = typeof requestIdleCallback === 'function' ? requestIdleCallback : (cb) => _scheduleFlush(cb);
|
|
9
9
|
let PROMISE_WAS_RESOLVED = false;
|
|
10
|
-
let PENDING_PULLS =
|
|
10
|
+
let PENDING_PULLS = new Set();
|
|
11
11
|
let PENDING_ASYNC_PULLS = [];
|
|
12
12
|
let PENDING_UNWATCH = new Map();
|
|
13
13
|
let PENDING_LISTENERS = [];
|
|
@@ -27,9 +27,12 @@ export const setResolved = () => {
|
|
|
27
27
|
PROMISE_WAS_RESOLVED = true;
|
|
28
28
|
};
|
|
29
29
|
export const schedulePull = (signal) => {
|
|
30
|
-
PENDING_PULLS.
|
|
30
|
+
PENDING_PULLS.add(signal);
|
|
31
31
|
scheduleFlush(flushWatchers);
|
|
32
32
|
};
|
|
33
|
+
export const cancelPull = (signal) => {
|
|
34
|
+
PENDING_PULLS.delete(signal);
|
|
35
|
+
};
|
|
33
36
|
export const scheduleAsyncPull = (signal) => {
|
|
34
37
|
PENDING_ASYNC_PULLS.push(signal);
|
|
35
38
|
scheduleFlush(flushWatchers);
|
|
@@ -62,7 +65,7 @@ const flushWatchers = async () => {
|
|
|
62
65
|
const flush = currentFlush;
|
|
63
66
|
// Flush all auto-pulled signals recursively, clearing
|
|
64
67
|
// the microtask queue until they are all settled
|
|
65
|
-
while (PROMISE_WAS_RESOLVED || PENDING_ASYNC_PULLS.length > 0 || PENDING_PULLS.
|
|
68
|
+
while (PROMISE_WAS_RESOLVED || PENDING_ASYNC_PULLS.length > 0 || PENDING_PULLS.size > 0) {
|
|
66
69
|
PROMISE_WAS_RESOLVED = false;
|
|
67
70
|
const asyncPulls = PENDING_ASYNC_PULLS;
|
|
68
71
|
PENDING_ASYNC_PULLS = [];
|
|
@@ -70,7 +73,7 @@ const flushWatchers = async () => {
|
|
|
70
73
|
checkSignal(pull);
|
|
71
74
|
}
|
|
72
75
|
const pulls = PENDING_PULLS;
|
|
73
|
-
PENDING_PULLS =
|
|
76
|
+
PENDING_PULLS = new Set();
|
|
74
77
|
for (const pull of pulls) {
|
|
75
78
|
checkAndRunListeners(pull);
|
|
76
79
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduling.js","sourceRoot":"","sources":["../../../src/internals/scheduling.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,IAAI,cAAc,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC7D,OAAO,EAAE,YAAY,IAAI,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,YAAY,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAI3C,oEAAoE;AACpE,MAAM,oBAAoB,GACxB,OAAO,mBAAmB,KAAK,UAAU,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,EAAc,EAAE,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;AAE3G,IAAI,oBAAoB,GAAG,KAAK,CAAC;AAEjC,IAAI,aAAa,
|
|
1
|
+
{"version":3,"file":"scheduling.js","sourceRoot":"","sources":["../../../src/internals/scheduling.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,IAAI,cAAc,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC7D,OAAO,EAAE,YAAY,IAAI,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,YAAY,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAI3C,oEAAoE;AACpE,MAAM,oBAAoB,GACxB,OAAO,mBAAmB,KAAK,UAAU,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,EAAc,EAAE,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;AAE3G,IAAI,oBAAoB,GAAG,KAAK,CAAC;AAEjC,IAAI,aAAa,GAAoC,IAAI,GAAG,EAAE,CAAC;AAC/D,IAAI,mBAAmB,GAAiC,EAAE,CAAC;AAC3D,IAAI,eAAe,GAAG,IAAI,GAAG,EAAsC,CAAC;AACpE,IAAI,iBAAiB,GAAsD,EAAE,CAAC;AAC9E,IAAI,eAAe,GAAa,EAAE,CAAC;AACnC,IAAI,UAAU,GAAG,IAAI,GAAG,EAAe,CAAC;AAExC,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;AAE1C,IAAI,YAAY,GAA2D,IAAI,CAAC;AAEhF,MAAM,aAAa,GAAG,CAAC,EAAc,EAAE,EAAE;IACvC,IAAI,YAAY;QAAE,OAAO;IAEzB,IAAI,OAAmB,CAAC;IACxB,MAAM,OAAO,GAAG,IAAI,OAAO,CAAO,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;IAEtD,YAAY,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,OAAQ,EAAE,CAAC;IAE9C,cAAc,CAAC,aAAa,CAAC,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,GAAG,EAAE;IAC9B,oBAAoB,GAAG,IAAI,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,MAAkC,EAAE,EAAE;IACjE,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC1B,aAAa,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,MAAkC,EAAE,EAAE;IAC/D,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,MAAkC,EAAE,EAAE;IACtE,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjC,aAAa,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAmC,EAAE,EAAE;IACrE,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAElD,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,GAAG,CAAC,CAAC,CAAC;IAE1C,aAAa,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,MAAqD,EAAE,EAAE;IACzF,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC/B,aAAa,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,MAAc,EAAE,EAAE;IAC/C,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,aAAa,CAAC,aAAa,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,KAAkB,EAAE,EAAE;IACpD,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAEtB,IAAI,UAAU,CAAC,IAAI,GAAG,CAAC;QAAE,OAAO;IAEhC,oBAAoB,CAAC,GAAG,EAAE;QACxB,KAAK,MAAM,KAAK,IAAI,UAAU,EAAE,CAAC;YAC/B,KAAK,CAAC,OAAO,EAAE,CAAC;QAClB,CAAC;QAED,UAAU,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,KAAK,IAAI,EAAE;IAC/B,MAAM,KAAK,GAAG,YAAa,CAAC;IAE5B,sDAAsD;IACtD,iDAAiD;IACjD,OAAO,oBAAoB,IAAI,mBAAmB,CAAC,MAAM,GAAG,CAAC,IAAI,aAAa,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;QACxF,oBAAoB,GAAG,KAAK,CAAC;QAC7B,MAAM,UAAU,GAAG,mBAAmB,CAAC;QAEvC,mBAAmB,GAAG,EAAE,CAAC;QAEzB,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;YAC9B,WAAW,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QAED,MAAM,KAAK,GAAG,aAAa,CAAC;QAE5B,aAAa,GAAG,IAAI,GAAG,EAAE,CAAC;QAE1B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,oBAAoB,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;QAED,oFAAoF;QACpF,mFAAmF;QACnF,6EAA6E;QAE7E,MAAM,SAAS,EAAE,CAAC;IACpB,CAAC;IAED,8DAA8D;IAC9D,wCAAwC;IACxC,YAAY,GAAG,IAAI,CAAC;IAEpB,QAAQ,CAAC,GAAG,EAAE;QACZ,KAAK,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,eAAe,EAAE,CAAC;YAC9C,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC/B,CAAC;QAED,KAAK,MAAM,MAAM,IAAI,iBAAiB,EAAE,CAAC;YACvC,IAAI,MAAM,YAAY,gBAAgB,EAAE,CAAC;gBACvC,mBAAmB,CAAC,MAAa,CAAC,CAAC;YACrC,CAAC;iBAAM,CAAC;gBACN,iBAAiB,CAAC,MAAa,CAAC,CAAC;YACnC,CAAC;QACH,CAAC;QAED,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE,CAAC;YACrC,MAAM,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;QAED,eAAe,CAAC,KAAK,EAAE,CAAC;QACxB,iBAAiB,GAAG,EAAE,CAAC;QACvB,eAAe,GAAG,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,4BAA4B;IAC5B,KAAK,CAAC,OAAO,EAAE,CAAC;AAClB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAAI,EAAE;IAChC,OAAO,YAAY,EAAE,CAAC;QACpB,MAAM,YAAY,CAAC,OAAO,CAAC;IAC7B,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,CAAC,EAAc,EAAE,EAAE;IACtC,IAAI,OAAmB,CAAC;IACxB,MAAM,OAAO,GAAG,IAAI,OAAO,CAAO,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;IAEtD,YAAY,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,OAAQ,EAAE,CAAC;IAE9C,EAAE,EAAE,CAAC;IACL,aAAa,EAAE,CAAC;AAClB,CAAC,CAAC"}
|
|
@@ -7,7 +7,7 @@ export function watchSignal(signal) {
|
|
|
7
7
|
// If > 0, already watching, return
|
|
8
8
|
if (watchCount > 0)
|
|
9
9
|
return;
|
|
10
|
-
// If signal is being watched again, remove from GC candidates
|
|
10
|
+
// If signal is being watched again, remove from GC candidates and add back to scope
|
|
11
11
|
signal.scope?.removeFromGc(signal);
|
|
12
12
|
for (const dep of signal.deps.keys()) {
|
|
13
13
|
watchSignal(dep);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"watch.js","sourceRoot":"","sources":["../../../src/internals/watch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,OAAO,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,MAAM,UAAU,WAAW,CAAC,MAAkC;IAC5D,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;IAC9B,MAAM,aAAa,GAAG,UAAU,GAAG,CAAC,CAAC;IAErC,MAAM,CAAC,UAAU,GAAG,aAAa,CAAC;IAElC,mCAAmC;IACnC,IAAI,UAAU,GAAG,CAAC;QAAE,OAAO;IAE3B,
|
|
1
|
+
{"version":3,"file":"watch.js","sourceRoot":"","sources":["../../../src/internals/watch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,OAAO,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,MAAM,UAAU,WAAW,CAAC,MAAkC;IAC5D,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;IAC9B,MAAM,aAAa,GAAG,UAAU,GAAG,CAAC,CAAC;IAErC,MAAM,CAAC,UAAU,GAAG,aAAa,CAAC;IAElC,mCAAmC;IACnC,IAAI,UAAU,GAAG,CAAC;QAAE,OAAO;IAE3B,oFAAoF;IACpF,MAAM,CAAC,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC;IAEnC,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;QACrC,WAAW,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QACpB,sBAAsB;QACtB,WAAW,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,MAAkC,EAAE,KAAK,GAAG,CAAC;IACzE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;IAC9B,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC;IAEtD,MAAM,CAAC,UAAU,GAAG,aAAa,CAAC;IAElC,IAAI,aAAa,GAAG,CAAC,EAAE,CAAC;QACtB,OAAO;IACT,CAAC;IAED,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;QACrC,aAAa,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QACpB,qBAAqB;QACrB,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;IACpB,CAAC;IAED,oDAAoD;IACpD,IAAI,aAAa,KAAK,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;QACxC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component.d.ts","sourceRoot":"","sources":["../../../src/react/component.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"component.d.ts","sourceRoot":"","sources":["../../../src/react/component.tsx"],"names":[],"mappings":"AASA,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,KAAK,SAAS,MAAM,EACpD,EAAE,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,EAAE,GAAG,IAAI,WA2CjD,KAAK,6CAMrB"}
|
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { useMemo, useRef, useSyncExternalStore } from 'react';
|
|
3
3
|
import { useScope } from './context.js';
|
|
4
|
+
import { useSignalsSuspended } from './suspend-signals-context.js';
|
|
4
5
|
import { createReactiveFnSignal } from '../internals/reactive.js';
|
|
5
6
|
import { runSignal } from '../internals/get.js';
|
|
6
7
|
import { hashValue } from '../internals/utils/hash.js';
|
|
8
|
+
const noopStore = () => () => { };
|
|
7
9
|
export default function component(fn) {
|
|
8
10
|
const Component = (props) => {
|
|
9
11
|
const scope = useScope();
|
|
12
|
+
const suspended = useSignalsSuspended();
|
|
10
13
|
const fnSignalRef = useRef(undefined);
|
|
11
14
|
const propsRef = useRef(props);
|
|
12
15
|
propsRef.current = props;
|
|
@@ -23,7 +26,7 @@ export default function component(fn) {
|
|
|
23
26
|
// We always want to re-render when the signal is updated, regardless of
|
|
24
27
|
// whether or not the result changed. This is because the signal is lazy,
|
|
25
28
|
// so it will not be updated until the next render.
|
|
26
|
-
useSyncExternalStore(signal.addListenerLazy(), () => signal.updatedCount, () => signal.updatedCount);
|
|
29
|
+
useSyncExternalStore(suspended ? noopStore : signal.addListenerLazy(), () => signal.updatedCount, () => signal.updatedCount);
|
|
27
30
|
runSignal(signal);
|
|
28
31
|
return signal.value;
|
|
29
32
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/react/component.tsx"],"names":[],"mappings":";AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/react/component.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAa,OAAO,EAAE,MAAM,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,sBAAsB,EAAoB,MAAM,0BAA0B,CAAC;AACpF,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAEvD,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC;AAEjC,MAAM,CAAC,OAAO,UAAU,SAAS,CAC/B,EAAgE;IAEhE,MAAM,SAAS,GAAG,CAAC,KAAY,EAAE,EAAE;QACjC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;QACzB,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;QAExC,MAAM,WAAW,GAAG,MAAM,CAA+E,SAAS,CAAC,CAAC;QACpH,MAAM,QAAQ,GAAG,MAAM,CAAQ,KAAK,CAAC,CAAC;QAEtC,QAAQ,CAAC,OAAO,GAAG,KAAK,CAAC;QAEzB,IAAI,MAAM,GAAG,WAAW,CAAC,OAAO,CAAC;QAEjC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,WAAW,CAAC,OAAO,GAAG,MAAM,GAAG,sBAAsB,CACnD;gBACE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACnC,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK;gBACnB,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,SAAS;aAClB,EACD,EAAE,EACF,SAAS,EACT,KAAK,CACN,CAAC;YAEF,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;QAED,wEAAwE;QACxE,yEAAyE;QACzE,mDAAmD;QACnD,oBAAoB,CAClB,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,eAAe,EAAE,EAChD,GAAG,EAAE,CAAC,MAAM,CAAC,YAAY,EACzB,GAAG,EAAE,CAAC,MAAM,CAAC,YAAY,CAC1B,CAAC;QAEF,SAAS,CAAC,MAAsC,CAAC,CAAC;QAElD,OAAO,MAAM,CAAC,KAAK,CAAC;IACtB,CAAC,CAAC;IAEF,OAAO,CAAC,KAAY,EAAE,EAAE;QACtB,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;QAC9B,sCAAsC;QACtC,uDAAuD;QACvD,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,KAAC,SAAS,OAAK,KAAK,GAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -3,4 +3,5 @@ export { default as component } from './component.js';
|
|
|
3
3
|
export { useContext } from './context.js';
|
|
4
4
|
export { useSignal } from './use-signal.js';
|
|
5
5
|
export { useReactive } from './use-reactive.js';
|
|
6
|
+
export { SuspendSignalsProvider } from './suspend-signals-context.js';
|
|
6
7
|
//# 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,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"}
|
|
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;AAChD,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC"}
|
package/dist/esm/react/index.js
CHANGED
|
@@ -3,4 +3,5 @@ export { default as component } from './component.js';
|
|
|
3
3
|
export { useContext } from './context.js';
|
|
4
4
|
export { useSignal } from './use-signal.js';
|
|
5
5
|
export { useReactive } from './use-reactive.js';
|
|
6
|
+
export { SuspendSignalsProvider } from './suspend-signals-context.js';
|
|
6
7
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","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"}
|
|
1
|
+
{"version":3,"file":"index.js","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;AAChD,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suspend-signals-context.d.ts","sourceRoot":"","sources":["../../../src/react/suspend-signals-context.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,sBAAsB,mCAAiC,CAAC;AAErE,wBAAgB,mBAAmB,IAAI,OAAO,CAE7C"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
|
+
const SuspendSignalsContext = createContext(false);
|
|
3
|
+
export const SuspendSignalsProvider = SuspendSignalsContext.Provider;
|
|
4
|
+
export function useSignalsSuspended() {
|
|
5
|
+
return useContext(SuspendSignalsContext);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=suspend-signals-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suspend-signals-context.js","sourceRoot":"","sources":["../../../src/react/suspend-signals-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAElD,MAAM,qBAAqB,GAAG,aAAa,CAAU,KAAK,CAAC,CAAC;AAE5D,MAAM,CAAC,MAAM,sBAAsB,GAAG,qBAAqB,CAAC,QAAQ,CAAC;AAErE,MAAM,UAAU,mBAAmB;IACjC,OAAO,UAAU,CAAC,qBAAqB,CAAC,CAAC;AAC3C,CAAC"}
|
|
@@ -1 +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;
|
|
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;AAsErE,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"}
|
|
@@ -4,12 +4,20 @@ import { getReactiveFnAndDefinition } from '../internals/core-api.js';
|
|
|
4
4
|
import { getCurrentConsumer } from '../internals/consumer.js';
|
|
5
5
|
import { isReactivePromise, isRelay } from '../internals/async.js';
|
|
6
6
|
import { useScope } from './context.js';
|
|
7
|
+
import { useSignalsSuspended } from './suspend-signals-context.js';
|
|
7
8
|
import { getGlobalScope } from '../internals/contexts.js';
|
|
8
9
|
const useStateSignal = (signal) => {
|
|
9
|
-
|
|
10
|
+
const suspended = useSignalsSuspended();
|
|
11
|
+
return useSyncExternalStore(
|
|
12
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
13
|
+
useCallback(suspended ? () => () => { } : onStoreChange => signal.addListener(onStoreChange), [
|
|
14
|
+
signal,
|
|
15
|
+
suspended,
|
|
16
|
+
]), () => signal.value, () => signal.value);
|
|
10
17
|
};
|
|
11
18
|
const useReactiveFnSignal = (signal) => {
|
|
12
|
-
|
|
19
|
+
const suspended = useSignalsSuspended();
|
|
20
|
+
return useSyncExternalStore(suspended ? () => () => { } : signal.addListenerLazy(), () => signal.value, () => signal.value);
|
|
13
21
|
};
|
|
14
22
|
const useReactivePromise = (promise) => {
|
|
15
23
|
if (isRelay(promise)) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-reactive.js","sourceRoot":"","sources":["../../../src/react/use-reactive.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAC/C,OAAO,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAE1D,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAE9D,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAuB,MAAM,uBAAuB,CAAC;AAExF,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAE1D,MAAM,cAAc,GAAG,CAAI,MAAiB,EAAK,EAAE;IACjD,OAAO,oBAAoB,
|
|
1
|
+
{"version":3,"file":"use-reactive.js","sourceRoot":"","sources":["../../../src/react/use-reactive.ts"],"names":[],"mappings":"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"}
|