@warp-drive/core 5.8.0-alpha.4 → 5.8.0-alpha.40
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 +22 -38
- package/declarations/build-config.d.ts +18 -1
- package/declarations/graph/-private/-edge-definition.d.ts +12 -2
- package/declarations/index.d.ts +90 -8
- package/declarations/reactive/-private/document.d.ts +58 -46
- package/declarations/reactive/-private/record.d.ts +10 -1
- package/declarations/reactive/-private/schema.d.ts +77 -4
- package/declarations/reactive/-private.d.ts +1 -0
- package/declarations/reactive.d.ts +13 -7
- package/declarations/request/-private/types.d.ts +1 -1
- package/declarations/request.d.ts +47 -0
- package/declarations/store/-private/caches/instance-cache.d.ts +5 -6
- package/declarations/store/-private/default-cache-policy.d.ts +147 -129
- package/declarations/store/-private/managers/cache-capabilities-manager.d.ts +1 -1
- package/declarations/store/-private/managers/cache-key-manager.d.ts +26 -8
- package/declarations/store/-private/managers/cache-manager.d.ts +6 -4
- package/declarations/store/-private/managers/notification-manager.d.ts +1 -1
- package/declarations/store/-private/new-core-tmp/promise-state.d.ts +1 -0
- package/declarations/store/-private/new-core-tmp/request-state.d.ts +1 -1
- package/declarations/store/-private/store-service.d.ts +43 -64
- package/declarations/store/-private.d.ts +0 -1
- package/declarations/store/-types/q/cache-capabilities-manager.d.ts +1 -1
- package/declarations/store/deprecated/-private.d.ts +1 -1
- package/declarations/store/deprecated/store.d.ts +33 -32
- package/declarations/store.d.ts +1 -0
- package/declarations/types/cache.d.ts +8 -6
- package/declarations/types/record.d.ts +132 -0
- package/declarations/types/request.d.ts +26 -14
- package/declarations/types/schema/fields.d.ts +33 -9
- package/declarations/{store/-types/q → types/schema}/schema-service.d.ts +15 -13
- package/declarations/types/spec/document.d.ts +34 -0
- package/declarations/types/symbols.d.ts +2 -2
- package/declarations/types.d.ts +1 -1
- package/dist/build-config.js +1 -1
- package/dist/default-cache-policy-D7_u4YRH.js +572 -0
- package/dist/graph/-private.js +13 -4
- package/dist/{request-state-CUuZzgvE.js → index-BKcD4JZK.js} +10018 -8847
- package/dist/index.js +6 -382
- package/dist/reactive.js +4 -778
- package/dist/{context-C_7OLieY.js → request-oqoLC9rz.js} +219 -172
- package/dist/request.js +1 -1
- package/dist/store/-private.js +1 -1
- package/dist/store.js +1 -533
- package/dist/types/-private.js +1 -1
- package/dist/types/record.js +127 -0
- package/dist/types/request.js +14 -12
- package/dist/types/schema/fields.js +14 -0
- package/dist/types/schema/schema-service.js +0 -0
- package/dist/types/symbols.js +2 -2
- package/dist/unpkg/dev/-private-3C1OkYtZ.js +39 -0
- package/dist/unpkg/dev/build-config/babel-macros.js +1 -0
- package/dist/unpkg/dev/build-config/canary-features.js +1 -0
- package/dist/unpkg/dev/build-config/debugging.js +1 -0
- package/dist/unpkg/dev/build-config/deprecations.js +1 -0
- package/dist/unpkg/dev/build-config/env.js +1 -0
- package/dist/unpkg/dev/build-config/macros.js +1 -0
- package/dist/unpkg/dev/build-config.js +1 -0
- package/dist/unpkg/dev/configure-BC66sfNO.js +183 -0
- package/dist/unpkg/dev/configure.js +1 -0
- package/dist/unpkg/dev/graph/-private.js +3131 -0
- package/dist/unpkg/dev/index-DqhXrNZ_.js +11160 -0
- package/dist/unpkg/dev/index.js +6 -0
- package/dist/unpkg/dev/reactive/-private.js +1 -0
- package/dist/unpkg/dev/reactive.js +127 -0
- package/dist/unpkg/dev/request-CA9K0gXq.js +719 -0
- package/dist/unpkg/dev/request.js +1 -0
- package/dist/unpkg/dev/runtime-DGG4CvlW.js +135 -0
- package/dist/unpkg/dev/store/-private.js +56 -0
- package/dist/unpkg/dev/store.js +558 -0
- package/dist/unpkg/dev/types/-private.js +69 -0
- package/dist/unpkg/dev/types/cache/aliases.js +0 -0
- package/dist/unpkg/dev/types/cache/change.js +0 -0
- package/dist/unpkg/dev/types/cache/mutations.js +0 -0
- package/dist/unpkg/dev/types/cache/operations.js +0 -0
- package/dist/unpkg/dev/types/cache/relationship.js +0 -0
- package/dist/unpkg/dev/types/cache.js +0 -0
- package/dist/unpkg/dev/types/graph.js +0 -0
- package/dist/unpkg/dev/types/identifier.js +61 -0
- package/dist/unpkg/dev/types/json/raw.js +0 -0
- package/dist/unpkg/dev/types/params.js +0 -0
- package/dist/unpkg/dev/types/record.js +191 -0
- package/dist/unpkg/dev/types/request.js +77 -0
- package/dist/unpkg/dev/types/runtime.js +34 -0
- package/dist/unpkg/dev/types/schema/concepts.js +0 -0
- package/dist/unpkg/dev/types/schema/fields.js +505 -0
- package/dist/unpkg/dev/types/schema/fields.type-test.js +0 -0
- package/dist/unpkg/dev/types/schema/schema-service.js +0 -0
- package/dist/unpkg/dev/types/spec/document.js +0 -0
- package/dist/unpkg/dev/types/spec/error.js +0 -0
- package/dist/unpkg/dev/types/spec/json-api-raw.js +0 -0
- package/dist/unpkg/dev/types/symbols.js +84 -0
- package/dist/unpkg/dev/types/utils.js +0 -0
- package/dist/unpkg/dev/types.js +0 -0
- package/dist/unpkg/dev/utils/string.js +91 -0
- package/dist/unpkg/dev-deprecated/-private-3C1OkYtZ.js +39 -0
- package/dist/unpkg/dev-deprecated/build-config/babel-macros.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config/canary-features.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config/debugging.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config/deprecations.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config/env.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config/macros.js +1 -0
- package/dist/unpkg/dev-deprecated/build-config.js +1 -0
- package/dist/unpkg/dev-deprecated/configure-BC66sfNO.js +183 -0
- package/dist/unpkg/dev-deprecated/configure.js +1 -0
- package/dist/unpkg/dev-deprecated/graph/-private.js +3326 -0
- package/dist/unpkg/dev-deprecated/index-BBlq5is_.js +11775 -0
- package/dist/unpkg/dev-deprecated/index.js +5 -0
- package/dist/unpkg/dev-deprecated/reactive/-private.js +1 -0
- package/dist/unpkg/dev-deprecated/reactive.js +127 -0
- package/dist/unpkg/dev-deprecated/request-CA9K0gXq.js +719 -0
- package/dist/unpkg/dev-deprecated/request.js +1 -0
- package/dist/unpkg/dev-deprecated/runtime-DfhJzpZH.js +135 -0
- package/dist/unpkg/dev-deprecated/store/-private.js +2 -0
- package/dist/unpkg/dev-deprecated/store.js +558 -0
- package/dist/unpkg/dev-deprecated/types/-private.js +69 -0
- package/dist/unpkg/dev-deprecated/types/cache/aliases.js +0 -0
- package/dist/unpkg/dev-deprecated/types/cache/change.js +0 -0
- package/dist/unpkg/dev-deprecated/types/cache/mutations.js +0 -0
- package/dist/unpkg/dev-deprecated/types/cache/operations.js +0 -0
- package/dist/unpkg/dev-deprecated/types/cache/relationship.js +0 -0
- package/dist/unpkg/dev-deprecated/types/cache.js +0 -0
- package/dist/unpkg/dev-deprecated/types/graph.js +0 -0
- package/dist/unpkg/dev-deprecated/types/identifier.js +61 -0
- package/dist/unpkg/dev-deprecated/types/json/raw.js +0 -0
- package/dist/unpkg/dev-deprecated/types/params.js +0 -0
- package/dist/unpkg/dev-deprecated/types/record.js +191 -0
- package/dist/unpkg/dev-deprecated/types/request.js +77 -0
- package/dist/unpkg/dev-deprecated/types/runtime.js +34 -0
- package/dist/unpkg/dev-deprecated/types/schema/concepts.js +0 -0
- package/dist/unpkg/dev-deprecated/types/schema/fields.js +505 -0
- package/dist/unpkg/dev-deprecated/types/schema/fields.type-test.js +0 -0
- package/dist/unpkg/dev-deprecated/types/schema/schema-service.js +0 -0
- package/dist/unpkg/dev-deprecated/types/spec/document.js +0 -0
- package/dist/unpkg/dev-deprecated/types/spec/error.js +0 -0
- package/dist/unpkg/dev-deprecated/types/spec/json-api-raw.js +0 -0
- package/dist/unpkg/dev-deprecated/types/symbols.js +84 -0
- package/dist/unpkg/dev-deprecated/types/utils.js +0 -0
- package/dist/unpkg/dev-deprecated/types.js +0 -0
- package/dist/unpkg/dev-deprecated/utils/string.js +91 -0
- package/dist/unpkg/prod/-private-3C1OkYtZ.js +39 -0
- package/dist/unpkg/prod/build-config/babel-macros.js +1 -0
- package/dist/unpkg/prod/build-config/canary-features.js +1 -0
- package/dist/unpkg/prod/build-config/debugging.js +1 -0
- package/dist/unpkg/prod/build-config/deprecations.js +1 -0
- package/dist/unpkg/prod/build-config/env.js +1 -0
- package/dist/unpkg/prod/build-config/macros.js +1 -0
- package/dist/unpkg/prod/build-config.js +1 -0
- package/dist/unpkg/prod/configure-C0C1LpG6.js +158 -0
- package/dist/unpkg/prod/configure.js +1 -0
- package/dist/unpkg/prod/graph/-private.js +2234 -0
- package/dist/unpkg/prod/handler-LAyD1Y5l.js +1619 -0
- package/dist/unpkg/prod/hooks-BfiqDg3O.js +26 -0
- package/dist/unpkg/prod/index.js +481 -0
- package/dist/unpkg/prod/promise-state-ipG60SdD.js +6738 -0
- package/dist/unpkg/prod/reactive/-private.js +1 -0
- package/dist/unpkg/prod/reactive.js +127 -0
- package/dist/unpkg/prod/request-CN2LxbYX.js +437 -0
- package/dist/unpkg/prod/request.js +1 -0
- package/dist/unpkg/prod/store/-private.js +127 -0
- package/dist/unpkg/prod/store.js +437 -0
- package/dist/unpkg/prod/types/-private.js +49 -0
- package/dist/unpkg/prod/types/cache/aliases.js +0 -0
- package/dist/unpkg/prod/types/cache/change.js +0 -0
- package/dist/unpkg/prod/types/cache/mutations.js +0 -0
- package/dist/unpkg/prod/types/cache/operations.js +0 -0
- package/dist/unpkg/prod/types/cache/relationship.js +0 -0
- package/dist/unpkg/prod/types/cache.js +0 -0
- package/dist/unpkg/prod/types/graph.js +0 -0
- package/dist/unpkg/prod/types/identifier.js +61 -0
- package/dist/unpkg/prod/types/json/raw.js +0 -0
- package/dist/unpkg/prod/types/params.js +0 -0
- package/dist/unpkg/prod/types/record.js +191 -0
- package/dist/unpkg/prod/types/request.js +77 -0
- package/dist/unpkg/prod/types/runtime.js +34 -0
- package/dist/unpkg/prod/types/schema/concepts.js +0 -0
- package/dist/unpkg/prod/types/schema/fields.js +505 -0
- package/dist/unpkg/prod/types/schema/fields.type-test.js +0 -0
- package/dist/unpkg/prod/types/schema/schema-service.js +0 -0
- package/dist/unpkg/prod/types/spec/document.js +0 -0
- package/dist/unpkg/prod/types/spec/error.js +0 -0
- package/dist/unpkg/prod/types/spec/json-api-raw.js +0 -0
- package/dist/unpkg/prod/types/symbols.js +84 -0
- package/dist/unpkg/prod/types/utils.js +0 -0
- package/dist/unpkg/prod/types.js +0 -0
- package/dist/unpkg/prod/utils/string.js +72 -0
- package/dist/unpkg/prod-deprecated/-private-3C1OkYtZ.js +39 -0
- package/dist/unpkg/prod-deprecated/build-config/babel-macros.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config/canary-features.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config/debugging.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config/deprecations.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config/env.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config/macros.js +1 -0
- package/dist/unpkg/prod-deprecated/build-config.js +1 -0
- package/dist/unpkg/prod-deprecated/configure-BQ8CpIcW.js +158 -0
- package/dist/unpkg/prod-deprecated/configure.js +1 -0
- package/dist/unpkg/prod-deprecated/graph/-private.js +2407 -0
- package/dist/unpkg/prod-deprecated/handler-D639oFvl.js +334 -0
- package/dist/unpkg/prod-deprecated/hooks-DGvi9teJ.js +26 -0
- package/dist/unpkg/prod-deprecated/index.js +481 -0
- package/dist/unpkg/prod-deprecated/promise-state-CYvoIPna.js +8458 -0
- package/dist/unpkg/prod-deprecated/reactive/-private.js +1 -0
- package/dist/unpkg/prod-deprecated/reactive.js +126 -0
- package/dist/unpkg/prod-deprecated/request-CN2LxbYX.js +437 -0
- package/dist/unpkg/prod-deprecated/request.js +1 -0
- package/dist/unpkg/prod-deprecated/store/-private.js +89 -0
- package/dist/unpkg/prod-deprecated/store.js +437 -0
- package/dist/unpkg/prod-deprecated/types/-private.js +49 -0
- package/dist/unpkg/prod-deprecated/types/cache/aliases.js +0 -0
- package/dist/unpkg/prod-deprecated/types/cache/change.js +0 -0
- package/dist/unpkg/prod-deprecated/types/cache/mutations.js +0 -0
- package/dist/unpkg/prod-deprecated/types/cache/operations.js +0 -0
- package/dist/unpkg/prod-deprecated/types/cache/relationship.js +0 -0
- package/dist/unpkg/prod-deprecated/types/cache.js +0 -0
- package/dist/unpkg/prod-deprecated/types/graph.js +0 -0
- package/dist/unpkg/prod-deprecated/types/identifier.js +61 -0
- package/dist/unpkg/prod-deprecated/types/json/raw.js +0 -0
- package/dist/unpkg/prod-deprecated/types/params.js +0 -0
- package/dist/unpkg/prod-deprecated/types/record.js +191 -0
- package/dist/unpkg/prod-deprecated/types/request.js +77 -0
- package/dist/unpkg/prod-deprecated/types/runtime.js +34 -0
- package/dist/unpkg/prod-deprecated/types/schema/concepts.js +0 -0
- package/dist/unpkg/prod-deprecated/types/schema/fields.js +505 -0
- package/dist/unpkg/prod-deprecated/types/schema/fields.type-test.js +0 -0
- package/dist/unpkg/prod-deprecated/types/schema/schema-service.js +0 -0
- package/dist/unpkg/prod-deprecated/types/spec/document.js +0 -0
- package/dist/unpkg/prod-deprecated/types/spec/error.js +0 -0
- package/dist/unpkg/prod-deprecated/types/spec/json-api-raw.js +0 -0
- package/dist/unpkg/prod-deprecated/types/symbols.js +84 -0
- package/dist/unpkg/prod-deprecated/types/utils.js +0 -0
- package/dist/unpkg/prod-deprecated/types.js +0 -0
- package/dist/unpkg/prod-deprecated/utils/string.js +72 -0
- package/logos/README.md +2 -2
- package/logos/logo-yellow-slab.svg +1 -0
- package/logos/word-mark-black.svg +1 -0
- package/logos/word-mark-white.svg +1 -0
- package/package.json +11 -3
- package/logos/NCC-1701-a-blue.svg +0 -4
- package/logos/NCC-1701-a-gold.svg +0 -4
- package/logos/NCC-1701-a-gold_100.svg +0 -1
- package/logos/NCC-1701-a-gold_base-64.txt +0 -1
- package/logos/NCC-1701-a.svg +0 -4
- package/logos/docs-badge.svg +0 -2
- package/logos/ember-data-logo-dark.svg +0 -12
- package/logos/ember-data-logo-light.svg +0 -12
- package/logos/social1.png +0 -0
- package/logos/social2.png +0 -0
- package/logos/warp-drive-logo-dark.svg +0 -4
- package/logos/warp-drive-logo-gold.svg +0 -4
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { getOrSetGlobal } from './types/-private.js';
|
|
2
|
+
|
|
3
|
+
///////////////////
|
|
4
|
+
///// WARNING /////
|
|
5
|
+
///////////////////
|
|
6
|
+
|
|
7
|
+
// Great, got your attention with that warning didn't we?
|
|
8
|
+
// Good. Here's the deal: typescript treats symbols as unique types.
|
|
9
|
+
// If by accident a module creating a symbol is processed more than
|
|
10
|
+
// once, the symbol will be different in each processing. This will
|
|
11
|
+
// cause a type error.
|
|
12
|
+
// It could also cause a runtime error if the symbol is used innapropriately.
|
|
13
|
+
// However, this case is extremely hard to hit and would require other things
|
|
14
|
+
// to go wrong first.
|
|
15
|
+
//
|
|
16
|
+
// So, why do the warning? And why do we lie about the types of the symbols?
|
|
17
|
+
//
|
|
18
|
+
// Because we intentionally create multiple copies of them within the types
|
|
19
|
+
// at build time. This is because we rollup our d.ts files in order to give
|
|
20
|
+
// our consumers a better experience.
|
|
21
|
+
//
|
|
22
|
+
// However, no tool today supports rolling up d.ts files with multiple entry
|
|
23
|
+
// points correctly. The tool we use currently (vite-plugin-dts) uses @microsoft/api-extractor
|
|
24
|
+
// which creates a fully unique stand-alone types file per-entry-point. Thus
|
|
25
|
+
// every entry point that uses one of these symbols somewhere will have accidentally
|
|
26
|
+
// created a new symbol type.
|
|
27
|
+
//
|
|
28
|
+
// This cast allows us to rollup these types using this tool while not encountering
|
|
29
|
+
// the unique symbol type issue.
|
|
30
|
+
//
|
|
31
|
+
// Note that none of these symbols are part of the public API, these are used for
|
|
32
|
+
// debugging DX and as a safe way to provide an intimate contract on public objects.
|
|
33
|
+
|
|
34
|
+
const SOURCE = getOrSetGlobal('SOURCE', Symbol('#source'));
|
|
35
|
+
const Destroy = getOrSetGlobal('Destroy', Symbol.dispose || Symbol.for('Dispose'));
|
|
36
|
+
const Checkout = getOrSetGlobal('Checkout', Symbol('Checkout'));
|
|
37
|
+
const Commit = getOrSetGlobal('Commit', Symbol('Commit'));
|
|
38
|
+
const Context = getOrSetGlobal('Context', Symbol('Context'));
|
|
39
|
+
export { Checkout as C, Destroy as D, SOURCE as S, Context as a, Commit as b };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { macros } from '@warp-drive/build-config/babel-macros';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '@warp-drive/build-config/canary-features';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '@warp-drive/build-config/debugging';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '@warp-drive/build-config/deprecations';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { DEBUG, IS_CI, IS_RECORDING, PRODUCTION, SHOULD_RECORD, TESTING } from '@warp-drive/build-config/env';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { assert } from '@warp-drive/build-config/macros';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { babelPlugin, setConfig } from '@warp-drive/build-config';
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { getOrSetGlobal, peekTransient, setTransient } from './types/-private.js';
|
|
2
|
+
|
|
3
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
4
|
+
|
|
5
|
+
const ARRAY_SIGNAL = getOrSetGlobal('#[]', Symbol('#[]'));
|
|
6
|
+
const OBJECT_SIGNAL = getOrSetGlobal('#{}', Symbol('#{}'));
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Requirements:
|
|
10
|
+
*
|
|
11
|
+
* Signal:
|
|
12
|
+
*
|
|
13
|
+
* - signal: a way of creating a reference that we can dirty when we desire to notify
|
|
14
|
+
* - @signal: a way of creating an accessor on an object that subscribes to a signal on access
|
|
15
|
+
* and notifies the signal on set, or of upgrading a descriptor to be such an accessor
|
|
16
|
+
* - defineSignal: a way of creating a signal on an object
|
|
17
|
+
* - notifySignal: a way of notifying the underlying signal that it has been dirtied
|
|
18
|
+
* - peekSignal: a way of inspecting the signal without notifying it
|
|
19
|
+
*
|
|
20
|
+
* - gate: a memoized getter function that re-runs when on access if its signal is dirty
|
|
21
|
+
* conceptually, a gate is a tightly coupled signal and memo
|
|
22
|
+
* - @gate: a way of creating a gate on an object or upgrading a descriptor with a getter
|
|
23
|
+
* to be a gate
|
|
24
|
+
* - defineGate: a way of creating a gate on an object
|
|
25
|
+
* - notifySignal: a way of notifying the signal for a gate that it has been dirtied
|
|
26
|
+
*
|
|
27
|
+
* - memo:
|
|
28
|
+
* - @memo: a way of creating a memoized getter on an object or upgrading a descriptor with a getter
|
|
29
|
+
* to be a memo
|
|
30
|
+
* - defineMemo: a way of creating a memo on an object
|
|
31
|
+
*
|
|
32
|
+
* - signalStore: storage bucket for signals associated to an object
|
|
33
|
+
* - withSignalStore: a way of pre-creating a signal store on an object
|
|
34
|
+
*
|
|
35
|
+
*
|
|
36
|
+
* @internal
|
|
37
|
+
*/
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* An Opaque type that represents a framework specific or TC39 signal.
|
|
41
|
+
*
|
|
42
|
+
* It may be an array of signals or a single signal.
|
|
43
|
+
*
|
|
44
|
+
* @private
|
|
45
|
+
*/
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* The hooks which MUST be configured in order to use reactive arrays,
|
|
49
|
+
* resources and documents with framework specfic signals or TC39 signals.
|
|
50
|
+
*
|
|
51
|
+
* Support for multiple frameworks simultaneously can be done via
|
|
52
|
+
* this abstraction by returning multiple signals from the `createSignal`
|
|
53
|
+
* method, and consuming the correct one via the correct framework via
|
|
54
|
+
* the `consumeSignal` and `notifySignal` methods.
|
|
55
|
+
*
|
|
56
|
+
* Unlike many signals implementations, WarpDrive does not wrap values as
|
|
57
|
+
* signals directly, but instead uses signals to alert the reactive layer
|
|
58
|
+
* to changes in the underlying cache. E.g. a signal is associated to a value,
|
|
59
|
+
* but does not serve as the cache for that value directly. We refer to this as
|
|
60
|
+
* a "gate", the pattern has also been called "side-signals".
|
|
61
|
+
*
|
|
62
|
+
* A no-op implementation is allowed, though it may lead to performance issues
|
|
63
|
+
* in locations that use createMemo as no memoization would be done. This is
|
|
64
|
+
* typically desirable only when integrating with a framework that does its own
|
|
65
|
+
* memoization and does not integrate with any signals-like primitive. For these
|
|
66
|
+
* scenarios you may also be interested in integrating with the {@link NotificationManager}
|
|
67
|
+
* more directly.
|
|
68
|
+
*
|
|
69
|
+
* @public
|
|
70
|
+
*/
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Contains information a {@link SignalHooks} implementation may want
|
|
74
|
+
* to use, such as the specialized key used for the signal
|
|
75
|
+
* representing an array's contents / length.
|
|
76
|
+
*
|
|
77
|
+
* ```ts
|
|
78
|
+
* interface HooksOptions {
|
|
79
|
+
* wellknown: {
|
|
80
|
+
* Array: symbol | string;
|
|
81
|
+
* }
|
|
82
|
+
* }
|
|
83
|
+
* ```
|
|
84
|
+
*
|
|
85
|
+
* @public
|
|
86
|
+
*/
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Configures the signals implementation to use. Supports multiple
|
|
90
|
+
* implementations simultaneously.
|
|
91
|
+
*
|
|
92
|
+
* See {@link HooksOptions} for the options passed to the provided function
|
|
93
|
+
* when called.
|
|
94
|
+
*
|
|
95
|
+
* See {@link SignalHooks} for the implementation the callback function should
|
|
96
|
+
* return.
|
|
97
|
+
*
|
|
98
|
+
* @public
|
|
99
|
+
* @param buildConfig - a function that takes options and returns a configuration object
|
|
100
|
+
*/
|
|
101
|
+
function setupSignals(buildConfig) {
|
|
102
|
+
// We want to assert this but can't because too many package manager
|
|
103
|
+
// and bundler bugs exist that cause this to be called multiple times
|
|
104
|
+
// for what should be a single call.
|
|
105
|
+
// assert(`Cannot override configured signal hooks`, peekTransient('signalHooks') === null);
|
|
106
|
+
const hooks = buildConfig({
|
|
107
|
+
wellknown: {
|
|
108
|
+
Array: ARRAY_SIGNAL
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
setTransient('signalHooks', hooks);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Internal method for consuming the configured `createSignal` hook
|
|
116
|
+
*
|
|
117
|
+
* @private
|
|
118
|
+
*/
|
|
119
|
+
function createSignal(obj, key) {
|
|
120
|
+
const signalHooks = peekTransient('signalHooks');
|
|
121
|
+
(test => {
|
|
122
|
+
if (!test) {
|
|
123
|
+
throw new Error(`Signal hooks not configured`);
|
|
124
|
+
}
|
|
125
|
+
})(signalHooks);
|
|
126
|
+
return signalHooks.createSignal(obj, key);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* Internal method for consuming the configured `consumeSignal` hook
|
|
131
|
+
*
|
|
132
|
+
* @private
|
|
133
|
+
*/
|
|
134
|
+
function consumeSignal(signal) {
|
|
135
|
+
const signalHooks = peekTransient('signalHooks');
|
|
136
|
+
(test => {
|
|
137
|
+
if (!test) {
|
|
138
|
+
throw new Error(`Signal hooks not configured`);
|
|
139
|
+
}
|
|
140
|
+
})(signalHooks);
|
|
141
|
+
return signalHooks.consumeSignal(signal);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Internal method for consuming the configured `notifySignal` hook
|
|
146
|
+
*
|
|
147
|
+
* @private
|
|
148
|
+
*/
|
|
149
|
+
function notifySignal(signal) {
|
|
150
|
+
const signalHooks = peekTransient('signalHooks');
|
|
151
|
+
(test => {
|
|
152
|
+
if (!test) {
|
|
153
|
+
throw new Error(`Signal hooks not configured`);
|
|
154
|
+
}
|
|
155
|
+
})(signalHooks);
|
|
156
|
+
return signalHooks.notifySignal(signal);
|
|
157
|
+
}
|
|
158
|
+
function createMemo(object, key, fn) {
|
|
159
|
+
const signalHooks = peekTransient('signalHooks');
|
|
160
|
+
(test => {
|
|
161
|
+
if (!test) {
|
|
162
|
+
throw new Error(`Signal hooks not configured`);
|
|
163
|
+
}
|
|
164
|
+
})(signalHooks);
|
|
165
|
+
return signalHooks.createMemo(object, key, fn);
|
|
166
|
+
}
|
|
167
|
+
function willSyncFlushWatchers() {
|
|
168
|
+
const signalHooks = peekTransient('signalHooks');
|
|
169
|
+
(test => {
|
|
170
|
+
if (!test) {
|
|
171
|
+
throw new Error(`Signal hooks not configured`);
|
|
172
|
+
}
|
|
173
|
+
})(signalHooks);
|
|
174
|
+
return signalHooks.willSyncFlushWatchers();
|
|
175
|
+
}
|
|
176
|
+
function waitFor(promise) {
|
|
177
|
+
const signalHooks = peekTransient('signalHooks');
|
|
178
|
+
if (signalHooks?.waitFor) {
|
|
179
|
+
return signalHooks.waitFor(promise);
|
|
180
|
+
}
|
|
181
|
+
return promise;
|
|
182
|
+
}
|
|
183
|
+
export { ARRAY_SIGNAL as A, OBJECT_SIGNAL as O, consumeSignal as a, createMemo as b, createSignal as c, willSyncFlushWatchers as d, notifySignal as n, setupSignals as s, waitFor as w };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { s as setupSignals } from "./configure-BC66sfNO.js";
|