@ember-data-types/store 5.6.0-beta.0 → 5.6.0-beta.1

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.
Files changed (90) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/unstable-preview-types/-private.d.ts +3 -32
  4. package/unstable-preview-types/configure.d.ts +14 -18
  5. package/unstable-preview-types/index.d.ts +4 -226
  6. package/unstable-preview-types/types.d.ts +3 -6
  7. package/unstable-preview-types/-private/cache-handler/handler.d.ts +0 -62
  8. package/unstable-preview-types/-private/cache-handler/handler.d.ts.map +0 -1
  9. package/unstable-preview-types/-private/cache-handler/types.d.ts +0 -107
  10. package/unstable-preview-types/-private/cache-handler/types.d.ts.map +0 -1
  11. package/unstable-preview-types/-private/cache-handler/utils.d.ts +0 -34
  12. package/unstable-preview-types/-private/cache-handler/utils.d.ts.map +0 -1
  13. package/unstable-preview-types/-private/caches/cache-utils.d.ts +0 -11
  14. package/unstable-preview-types/-private/caches/cache-utils.d.ts.map +0 -1
  15. package/unstable-preview-types/-private/caches/identifier-cache.d.ts +0 -180
  16. package/unstable-preview-types/-private/caches/identifier-cache.d.ts.map +0 -1
  17. package/unstable-preview-types/-private/caches/instance-cache.d.ts +0 -64
  18. package/unstable-preview-types/-private/caches/instance-cache.d.ts.map +0 -1
  19. package/unstable-preview-types/-private/caches/resource-utils.d.ts +0 -12
  20. package/unstable-preview-types/-private/caches/resource-utils.d.ts.map +0 -1
  21. package/unstable-preview-types/-private/debug/utils.d.ts +0 -9
  22. package/unstable-preview-types/-private/debug/utils.d.ts.map +0 -1
  23. package/unstable-preview-types/-private/document.d.ts +0 -155
  24. package/unstable-preview-types/-private/document.d.ts.map +0 -1
  25. package/unstable-preview-types/-private/legacy-model-support/record-reference.d.ts +0 -179
  26. package/unstable-preview-types/-private/legacy-model-support/record-reference.d.ts.map +0 -1
  27. package/unstable-preview-types/-private/legacy-model-support/shim-model-class.d.ts +0 -19
  28. package/unstable-preview-types/-private/legacy-model-support/shim-model-class.d.ts.map +0 -1
  29. package/unstable-preview-types/-private/managers/cache-capabilities-manager.d.ts +0 -31
  30. package/unstable-preview-types/-private/managers/cache-capabilities-manager.d.ts.map +0 -1
  31. package/unstable-preview-types/-private/managers/cache-manager.d.ts +0 -463
  32. package/unstable-preview-types/-private/managers/cache-manager.d.ts.map +0 -1
  33. package/unstable-preview-types/-private/managers/notification-manager.d.ts +0 -101
  34. package/unstable-preview-types/-private/managers/notification-manager.d.ts.map +0 -1
  35. package/unstable-preview-types/-private/managers/record-array-manager.d.ts +0 -101
  36. package/unstable-preview-types/-private/managers/record-array-manager.d.ts.map +0 -1
  37. package/unstable-preview-types/-private/network/request-cache.d.ts +0 -109
  38. package/unstable-preview-types/-private/network/request-cache.d.ts.map +0 -1
  39. package/unstable-preview-types/-private/new-core-tmp/promise-state.d.ts +0 -289
  40. package/unstable-preview-types/-private/new-core-tmp/promise-state.d.ts.map +0 -1
  41. package/unstable-preview-types/-private/new-core-tmp/reactivity/configure.d.ts +0 -92
  42. package/unstable-preview-types/-private/new-core-tmp/reactivity/configure.d.ts.map +0 -1
  43. package/unstable-preview-types/-private/new-core-tmp/reactivity/internal.d.ts +0 -172
  44. package/unstable-preview-types/-private/new-core-tmp/reactivity/internal.d.ts.map +0 -1
  45. package/unstable-preview-types/-private/new-core-tmp/reactivity/signal.d.ts +0 -32
  46. package/unstable-preview-types/-private/new-core-tmp/reactivity/signal.d.ts.map +0 -1
  47. package/unstable-preview-types/-private/new-core-tmp/request-state.d.ts +0 -276
  48. package/unstable-preview-types/-private/new-core-tmp/request-state.d.ts.map +0 -1
  49. package/unstable-preview-types/-private/record-arrays/identifier-array.d.ts +0 -145
  50. package/unstable-preview-types/-private/record-arrays/identifier-array.d.ts.map +0 -1
  51. package/unstable-preview-types/-private/record-arrays/many-array.d.ts +0 -203
  52. package/unstable-preview-types/-private/record-arrays/many-array.d.ts.map +0 -1
  53. package/unstable-preview-types/-private/record-arrays/native-proxy-type-fix.d.ts +0 -118
  54. package/unstable-preview-types/-private/record-arrays/native-proxy-type-fix.d.ts.map +0 -1
  55. package/unstable-preview-types/-private/store-service.d.ts +0 -1601
  56. package/unstable-preview-types/-private/store-service.d.ts.map +0 -1
  57. package/unstable-preview-types/-private/store-service.type-test.d.ts +0 -4
  58. package/unstable-preview-types/-private/store-service.type-test.d.ts.map +0 -1
  59. package/unstable-preview-types/-private/utils/coerce-id.d.ts +0 -10
  60. package/unstable-preview-types/-private/utils/coerce-id.d.ts.map +0 -1
  61. package/unstable-preview-types/-private/utils/construct-resource.d.ts +0 -9
  62. package/unstable-preview-types/-private/utils/construct-resource.d.ts.map +0 -1
  63. package/unstable-preview-types/-private/utils/is-non-empty-string.d.ts +0 -4
  64. package/unstable-preview-types/-private/utils/is-non-empty-string.d.ts.map +0 -1
  65. package/unstable-preview-types/-private/utils/normalize-model-name.d.ts +0 -4
  66. package/unstable-preview-types/-private/utils/normalize-model-name.d.ts.map +0 -1
  67. package/unstable-preview-types/-private/utils/uuid-polyfill.d.ts +0 -4
  68. package/unstable-preview-types/-private/utils/uuid-polyfill.d.ts.map +0 -1
  69. package/unstable-preview-types/-private.d.ts.map +0 -1
  70. package/unstable-preview-types/-types/overview.d.ts +0 -21
  71. package/unstable-preview-types/-types/overview.d.ts.map +0 -1
  72. package/unstable-preview-types/-types/q/cache-capabilities-manager.d.ts +0 -110
  73. package/unstable-preview-types/-types/q/cache-capabilities-manager.d.ts.map +0 -1
  74. package/unstable-preview-types/-types/q/ds-model.d.ts +0 -25
  75. package/unstable-preview-types/-types/q/ds-model.d.ts.map +0 -1
  76. package/unstable-preview-types/-types/q/identifier.d.ts +0 -193
  77. package/unstable-preview-types/-types/q/identifier.d.ts.map +0 -1
  78. package/unstable-preview-types/-types/q/promise-proxies.d.ts +0 -4
  79. package/unstable-preview-types/-types/q/promise-proxies.d.ts.map +0 -1
  80. package/unstable-preview-types/-types/q/record-data-json-api.d.ts +0 -36
  81. package/unstable-preview-types/-types/q/record-data-json-api.d.ts.map +0 -1
  82. package/unstable-preview-types/-types/q/record-instance.d.ts +0 -29
  83. package/unstable-preview-types/-types/q/record-instance.d.ts.map +0 -1
  84. package/unstable-preview-types/-types/q/schema-service.d.ts +0 -354
  85. package/unstable-preview-types/-types/q/schema-service.d.ts.map +0 -1
  86. package/unstable-preview-types/-types/q/store.d.ts +0 -38
  87. package/unstable-preview-types/-types/q/store.d.ts.map +0 -1
  88. package/unstable-preview-types/configure.d.ts.map +0 -1
  89. package/unstable-preview-types/index.d.ts.map +0 -1
  90. package/unstable-preview-types/types.d.ts.map +0 -1
@@ -1,180 +0,0 @@
1
- declare module '@ember-data/store/-private/caches/identifier-cache' {
2
- import { type Identifier, type RecordIdentifier, type StableDocumentIdentifier, type StableExistingRecordIdentifier, type StableRecordIdentifier } from '@warp-drive/core-types/identifier';
3
- import type { ImmutableRequestInfo } from '@warp-drive/core-types/request';
4
- import type { ExistingResourceIdentifierObject, ResourceIdentifierObject } from '@warp-drive/core-types/spec/json-api-raw';
5
- import type { ForgetMethod, GenerationMethod, KeyInfo, KeyInfoMethod, ResetMethod, UpdateMethod } from '@ember-data/store/-types/q/identifier';
6
- type TypeFromIdentifier<T> = T extends {
7
- type: infer U;
8
- } ? U : string;
9
- type NarrowIdentifierIfPossible<T> = T extends ExistingResourceIdentifierObject ? StableExistingRecordIdentifier<TypeFromIdentifier<T>> : StableRecordIdentifier;
10
- export function isStableIdentifier(identifier: unknown): identifier is StableRecordIdentifier;
11
- export function isDocumentIdentifier(identifier: unknown): identifier is StableDocumentIdentifier;
12
- interface KeyOptions {
13
- lid: IdentifierMap;
14
- id: IdentifierMap;
15
- }
16
- type TypeMap = {
17
- [key: string]: KeyOptions;
18
- };
19
- type IdentifierMap = Map<string, StableRecordIdentifier>;
20
- type StableCache = {
21
- resources: IdentifierMap;
22
- documents: Map<string, StableDocumentIdentifier>;
23
- resourcesByType: TypeMap;
24
- polymorphicLidBackMap: Map<string, string[]>;
25
- };
26
- export type MergeMethod = (targetIdentifier: StableRecordIdentifier, matchedIdentifier: StableRecordIdentifier, resourceData: unknown) => StableRecordIdentifier;
27
- export function setIdentifierGenerationMethod(method: GenerationMethod | null): void;
28
- export function setIdentifierUpdateMethod(method: UpdateMethod | null): void;
29
- export function setIdentifierForgetMethod(method: ForgetMethod | null): void;
30
- export function setIdentifierResetMethod(method: ResetMethod | null): void;
31
- export function setKeyInfoForResource(method: KeyInfoMethod | null): void;
32
- /**
33
- * Each instance of {Store} receives a unique instance of a IdentifierCache.
34
- *
35
- * This cache is responsible for assigning or retrieving the unique identify
36
- * for arbitrary resource data encountered by the store. Data representing
37
- * a unique resource or record should always be represented by the same
38
- * identifier.
39
- *
40
- * It can be configured by consuming applications.
41
- *
42
- * @class IdentifierCache
43
- @public
44
- */
45
- export class IdentifierCache {
46
- _cache: StableCache;
47
- _generate: GenerationMethod;
48
- _update: UpdateMethod;
49
- _forget: ForgetMethod;
50
- _reset: ResetMethod;
51
- _merge: MergeMethod;
52
- _keyInfoForResource: KeyInfoMethod;
53
- _id: number;
54
- constructor();
55
- /**
56
- * Internal hook to allow management of merge conflicts with identifiers.
57
- *
58
- * we allow late binding of this private internal merge so that
59
- * the cache can insert itself here to handle elimination of duplicates
60
- *
61
- * @method __configureMerge
62
- * @private
63
- */
64
- __configureMerge(method: MergeMethod | null): void;
65
- upgradeIdentifier(resource: {
66
- type: string;
67
- id: string | null;
68
- lid?: string;
69
- }): StableRecordIdentifier;
70
- /**
71
- * @method _getRecordIdentifier
72
- * @private
73
- */
74
- _getRecordIdentifier(resource: {
75
- type: string;
76
- id: string | null;
77
- lid?: string;
78
- }, shouldGenerate: 2): StableRecordIdentifier;
79
- _getRecordIdentifier(resource: unknown, shouldGenerate: 1): StableRecordIdentifier;
80
- _getRecordIdentifier(resource: unknown, shouldGenerate: 0): StableRecordIdentifier | undefined;
81
- /**
82
- * allows us to peek without generating when needed
83
- * useful for the "create" case when we need to see if
84
- * we are accidentally overwritting something
85
- *
86
- * @method peekRecordIdentifier
87
- * @param resource
88
- * @return {StableRecordIdentifier | undefined}
89
- * @private
90
- */
91
- peekRecordIdentifier(resource: ResourceIdentifierObject | Identifier): StableRecordIdentifier | undefined;
92
- /**
93
- Returns the DocumentIdentifier for the given Request, creates one if it does not yet exist.
94
- Returns `null` if the request does not have a `cacheKey` or `url`.
95
-
96
- @method getOrCreateDocumentIdentifier
97
- @param request
98
- @return {StableDocumentIdentifier | null}
99
- @public
100
- */
101
- getOrCreateDocumentIdentifier(request: ImmutableRequestInfo): StableDocumentIdentifier | null;
102
- /**
103
- Returns the Identifier for the given Resource, creates one if it does not yet exist.
104
-
105
- Specifically this means that we:
106
-
107
- - validate the `id` `type` and `lid` combo against known identifiers
108
- - return an object with an `lid` that is stable (repeated calls with the same
109
- `id` + `type` or `lid` will return the same `lid` value)
110
- - this referential stability of the object itself is guaranteed
111
-
112
- @method getOrCreateRecordIdentifier
113
- @param resource
114
- @return {StableRecordIdentifier}
115
- @public
116
- */
117
- getOrCreateRecordIdentifier<T>(resource: T): NarrowIdentifierIfPossible<T>;
118
- /**
119
- Returns a new Identifier for the supplied data. Call this method to generate
120
- an identifier when a new resource is being created local to the client and
121
- potentially does not have an `id`.
122
-
123
- Delegates generation to the user supplied `GenerateMethod` if one has been provided
124
- with the signature `generateMethod({ type }, 'record')`.
125
-
126
- @method createIdentifierForNewRecord
127
- @param data
128
- @return {StableRecordIdentifier}
129
- @public
130
- */
131
- createIdentifierForNewRecord(data: {
132
- type: string;
133
- id?: string | null;
134
- }): StableRecordIdentifier;
135
- /**
136
- Provides the opportunity to update secondary lookup tables for existing identifiers
137
- Called after an identifier created with `createIdentifierForNewRecord` has been
138
- committed.
139
-
140
- Assigned `id` to an `Identifier` if `id` has not previously existed; however,
141
- attempting to change the `id` or calling update without providing an `id` when
142
- one is missing will throw an error.
143
-
144
- - sets `id` (if `id` was previously `null`)
145
- - `lid` and `type` MUST NOT be altered post creation
146
-
147
- If a merge occurs, it is possible the returned identifier does not match the originally
148
- provided identifier. In this case the abandoned identifier will go through the usual
149
- `forgetRecordIdentifier` codepaths.
150
-
151
- @method updateRecordIdentifier
152
- @param identifierObject
153
- @param data
154
- @return {StableRecordIdentifier}
155
- @public
156
- */
157
- updateRecordIdentifier(identifierObject: RecordIdentifier, data: unknown): StableRecordIdentifier;
158
- /**
159
- * @method _mergeRecordIdentifiers
160
- * @private
161
- */
162
- _mergeRecordIdentifiers(keyInfo: KeyInfo, identifier: StableRecordIdentifier, existingIdentifier: StableRecordIdentifier, data: unknown): StableRecordIdentifier;
163
- /**
164
- Provides the opportunity to eliminate an identifier from secondary lookup tables
165
- as well as eliminates it from ember-data's own lookup tables and book keeping.
166
-
167
- Useful when a record has been deleted and the deletion has been persisted and
168
- we do not care about the record anymore. Especially useful when an `id` of a
169
- deleted record might be reused later for a new record.
170
-
171
- @method forgetRecordIdentifier
172
- @param identifierObject
173
- @public
174
- */
175
- forgetRecordIdentifier(identifierObject: RecordIdentifier): void;
176
- destroy(): void;
177
- }
178
- export {};
179
- }
180
- //# sourceMappingURL=identifier-cache.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"identifier-cache.d.ts","sourceRoot":"","sources":["../../../src/-private/caches/identifier-cache.ts"],"names":[],"mappings":"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"}
@@ -1,64 +0,0 @@
1
- declare module '@ember-data/store/-private/caches/instance-cache' {
2
- import type { Cache } from '@warp-drive/core-types/cache';
3
- import type { StableDocumentIdentifier, StableRecordIdentifier } from '@warp-drive/core-types/identifier';
4
- import type { Value } from '@warp-drive/core-types/json/raw';
5
- import type { TypedRecordInstance, TypeFromInstance } from '@warp-drive/core-types/record';
6
- import type { OpaqueRecordInstance } from '@ember-data/store/-types/q/record-instance';
7
- import { ReactiveDocument } from '@ember-data/store/-private/document';
8
- import RecordReference from '@ember-data/store/-private/legacy-model-support/record-reference';
9
- import { CacheCapabilitiesManager } from '@ember-data/store/-private/managers/cache-capabilities-manager';
10
- import type { CacheManager } from '@ember-data/store/-private/managers/cache-manager';
11
- import type { CreateRecordProperties, Store } from '@ember-data/store/-private/store-service';
12
- export function peekRecordIdentifier(record: OpaqueRecordInstance): StableRecordIdentifier | undefined;
13
- /**
14
- Retrieves the unique referentially-stable [RecordIdentifier](/ember-data/release/classes/StableRecordIdentifier)
15
- assigned to the given record instance.
16
- ```js
17
- import { recordIdentifierFor } from "@ember-data/store";
18
- // ... gain access to a record, for instance with peekRecord or findRecord
19
- const record = store.peekRecord("user", "1");
20
- // get the identifier for the record (see docs for StableRecordIdentifier)
21
- const identifier = recordIdentifierFor(record);
22
- // access the identifier's properties.
23
- const { id, type, lid } = identifier;
24
- ```
25
- @method recordIdentifierFor
26
- @public
27
- @static
28
- @for @ember-data/store
29
- @param {Object} record a record instance previously obstained from the store.
30
- @return {StableRecordIdentifier}
31
- */
32
- export function recordIdentifierFor<T extends TypedRecordInstance>(record: T): StableRecordIdentifier<TypeFromInstance<T>>;
33
- export function recordIdentifierFor(record: OpaqueRecordInstance): StableRecordIdentifier;
34
- export function setRecordIdentifier(record: OpaqueRecordInstance, identifier: StableRecordIdentifier): void;
35
- export const StoreMap: Map<unknown, Store>;
36
- export function storeFor(record: OpaqueRecordInstance): Store | undefined;
37
- type Caches = {
38
- record: Map<StableRecordIdentifier, OpaqueRecordInstance>;
39
- reference: WeakMap<StableRecordIdentifier, RecordReference>;
40
- document: Map<StableDocumentIdentifier, ReactiveDocument<OpaqueRecordInstance | OpaqueRecordInstance[] | null | undefined>>;
41
- };
42
- export class InstanceCache {
43
- store: Store;
44
- cache: Cache;
45
- _storeWrapper: CacheCapabilitiesManager;
46
- __cacheManager: CacheManager;
47
- __instances: Caches;
48
- constructor(store: Store);
49
- peek(identifier: StableRecordIdentifier): Cache | OpaqueRecordInstance | undefined;
50
- getDocument<T>(identifier: StableDocumentIdentifier): ReactiveDocument<T>;
51
- getRecord(identifier: StableRecordIdentifier, properties?: CreateRecordProperties): OpaqueRecordInstance;
52
- getReference(identifier: StableRecordIdentifier): RecordReference;
53
- recordIsLoaded(identifier: StableRecordIdentifier, filterDeleted?: boolean): boolean;
54
- disconnect(identifier: StableRecordIdentifier): void;
55
- unloadRecord(identifier: StableRecordIdentifier): void;
56
- clear(type?: string): void;
57
- setRecordId(identifier: StableRecordIdentifier, id: string): void;
58
- }
59
- export function resourceIsFullyDeleted(instanceCache: InstanceCache, identifier: StableRecordIdentifier): boolean;
60
- export function preloadData(store: Store, identifier: StableRecordIdentifier, preload: Record<string, Value>): void;
61
- export function _clearCaches(): void;
62
- export {};
63
- }
64
- //# sourceMappingURL=instance-cache.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"instance-cache.d.ts","sourceRoot":"","sources":["../../../src/-private/caches/instance-cache.ts"],"names":[],"mappings":"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"}
@@ -1,12 +0,0 @@
1
- declare module '@ember-data/store/-private/caches/resource-utils' {
2
- export function hasLid(resource: unknown): resource is {
3
- lid: string;
4
- };
5
- export function hasId(resource: unknown): resource is {
6
- id: string;
7
- };
8
- export function hasType(resource: unknown): resource is {
9
- type: string;
10
- };
11
- }
12
- //# sourceMappingURL=resource-utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"resource-utils.d.ts","sourceRoot":"","sources":["../../../src/-private/caches/resource-utils.ts"],"names":[],"mappings":"AAUA,wBAAgB,MAAM,CAAC,QAAQ,EAAE,OAAO,GAAG,QAAQ,IAAI;IAAE,GAAG,EAAE,MAAM,CAAA;CAAE,CAErE;AAED,wBAAgB,KAAK,CAAC,QAAQ,EAAE,OAAO,GAAG,QAAQ,IAAI;IAAE,EAAE,EAAE,MAAM,CAAA;CAAE,CAInE;AAED,wBAAgB,OAAO,CAAC,QAAQ,EAAE,OAAO,GAAG,QAAQ,IAAI;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,CAEvE"}
@@ -1,9 +0,0 @@
1
- declare module '@ember-data/store/-private/debug/utils' {
2
- export function logGroup(scope: 'cache', prefix: string, type: string, lid: string, bucket: string, key: string): void;
3
- export function logGroup(scope: 'reactive-ui', prefix: string, type: string, lid: string, bucket: string, key: ''): void;
4
- export function logGroup(scope: 'notify', prefix: string, type: string, lid: string, bucket: string, key: string): void;
5
- export function log(scope: 'cache', prefix: string, type: string, lid: string, bucket: string, key: string): void;
6
- export function log(scope: 'reactive-ui', prefix: string, type: string, lid: string, bucket: string, key: ''): void;
7
- export function log(scope: 'notify', prefix: string, type: string, lid: string, bucket: string, key: string): void;
8
- }
9
- //# sourceMappingURL=utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/-private/debug/utils.ts"],"names":[],"mappings":"AAiEA,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;AACvH,wBAAgB,QAAQ,CACtB,KAAK,EAAE,aAAa,EACpB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,EAAE,GACN,IAAI,CAAC;AACR,wBAAgB,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;AAaxH,wBAAgB,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;AAClH,wBAAgB,GAAG,CAAC,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC;AACpH,wBAAgB,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC"}
@@ -1,155 +0,0 @@
1
- declare module '@ember-data/store/-private/document' {
2
- import type { StableDocumentIdentifier } from '@warp-drive/core-types/identifier';
3
- import type { ImmutableRequestInfo, RequestInfo } from '@warp-drive/core-types/request';
4
- import type { ResourceDocument } from '@warp-drive/core-types/spec/document';
5
- import type { Meta, PaginationLinks } from '@warp-drive/core-types/spec/json-api-raw';
6
- import type { Store } from '@ember-data/store/-private/store-service';
7
- /**
8
- * A Document is a class that wraps the response content from a request to the API
9
- * returned by `Cache.put` or `Cache.peek`, converting resource-identifiers into
10
- * record instances.
11
- *
12
- * It is not directly instantiated by the user, and its properties should not
13
- * be directly modified. Whether individual properties are mutable or not is
14
- * determined by the record instance itself.
15
- *
16
- * @public
17
- * @class ReactiveDocument
18
- */
19
- export class ReactiveDocument<T> {
20
- #private;
21
- /**
22
- * The links object for this document, if any
23
- *
24
- * e.g.
25
- *
26
- * ```
27
- * {
28
- * self: '/articles?page[number]=3',
29
- * }
30
- * ```
31
- *
32
- * @property links
33
- * @type {Object|undefined} - a links object
34
- * @public
35
- */
36
- readonly links?: PaginationLinks;
37
- /**
38
- * The primary data for this document, if any.
39
- *
40
- * If this document has no primary data (e.g. because it is an error document)
41
- * this property will be `undefined`.
42
- *
43
- * For collections this will be an array of record instances,
44
- * for single resource requests it will be a single record instance or null.
45
- *
46
- * @property data
47
- * @public
48
- * @type {Object|Array<object>|null|undefined} - a data object
49
- */
50
- readonly data?: T;
51
- /**
52
- * The errors returned by the API for this request, if any
53
- *
54
- * @property errors
55
- * @public
56
- * @type {Object|undefined} - an errors object
57
- */
58
- readonly errors?: object[];
59
- /**
60
- * The meta object for this document, if any
61
- *
62
- * @property meta
63
- * @public
64
- * @type {Object|undefined} - a meta object
65
- */
66
- readonly meta?: Meta;
67
- /**
68
- * The identifier associated with this document, if any
69
- *
70
- * @property identifier
71
- * @public
72
- * @type {StableDocumentIdentifier|null}
73
- */
74
- readonly identifier: StableDocumentIdentifier | null;
75
- protected readonly _store: Store;
76
- protected readonly _localCache: {
77
- document: ResourceDocument;
78
- request: ImmutableRequestInfo;
79
- } | null;
80
- constructor(store: Store, identifier: StableDocumentIdentifier | null, localCache: {
81
- document: ResourceDocument;
82
- request: ImmutableRequestInfo;
83
- } | null);
84
- /**
85
- * Fetches the related link for this document, returning a promise that resolves
86
- * with the document when the request completes. If no related link is present,
87
- * will fallback to the self link if present
88
- *
89
- * @method fetch
90
- * @public
91
- * @param {Object} options
92
- * @return Promise<Document>
93
- */
94
- fetch(options?: Partial<RequestInfo<T, ReactiveDocument<T>>>): Promise<ReactiveDocument<T>>;
95
- /**
96
- * Fetches the next link for this document, returning a promise that resolves
97
- * with the new document when the request completes, or null if there is no
98
- * next link.
99
- *
100
- * @method next
101
- * @public
102
- * @param {Object} options
103
- * @return Promise<Document | null>
104
- */
105
- next(options?: Partial<RequestInfo<T, ReactiveDocument<T>>>): Promise<ReactiveDocument<T> | null>;
106
- /**
107
- * Fetches the prev link for this document, returning a promise that resolves
108
- * with the new document when the request completes, or null if there is no
109
- * prev link.
110
- *
111
- * @method prev
112
- * @public
113
- * @param {Object} options
114
- * @return Promise<Document | null>
115
- */
116
- prev(options?: Partial<RequestInfo<T, ReactiveDocument<T>>>): Promise<ReactiveDocument<T> | null>;
117
- /**
118
- * Fetches the first link for this document, returning a promise that resolves
119
- * with the new document when the request completes, or null if there is no
120
- * first link.
121
- *
122
- * @method first
123
- * @public
124
- * @param {Object} options
125
- * @return Promise<Document | null>
126
- */
127
- first(options?: Partial<RequestInfo<T, ReactiveDocument<T>>>): Promise<ReactiveDocument<T> | null>;
128
- /**
129
- * Fetches the last link for this document, returning a promise that resolves
130
- * with the new document when the request completes, or null if there is no
131
- * last link.
132
- *
133
- * @method last
134
- * @public
135
- * @param {Object} options
136
- * @return Promise<Document | null>
137
- */
138
- last(options?: Partial<RequestInfo<T, ReactiveDocument<T>>>): Promise<ReactiveDocument<T> | null>;
139
- /**
140
- * Implemented for `JSON.stringify` support.
141
- *
142
- * Returns the JSON representation of the document wrapper.
143
- *
144
- * This is a shallow serialization, it does not deeply serialize
145
- * the document's contents, leaving that to the individual record
146
- * instances to determine how to do, if at all.
147
- *
148
- * @method toJSON
149
- * @public
150
- * @return
151
- */
152
- toJSON(): object;
153
- }
154
- }
155
- //# sourceMappingURL=document.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"document.d.ts","sourceRoot":"","sources":["../../src/-private/document.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAClF,OAAO,KAAK,EAAE,oBAAoB,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AACxF,OAAO,KAAK,EAAkC,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AAC7G,OAAO,KAAK,EAAQ,IAAI,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAM5F,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAO7C;;;;;;;;;;;GAWG;AACH,qBAAa,gBAAgB,CAAC,CAAC;;IAC7B;;;;;;;;;;;;;;OAcG;IACH,SAAiB,KAAK,CAAC,EAAE,eAAe,CAAC;IACzC;;;;;;;;;;;;OAYG;IACH,SAAiB,IAAI,CAAC,EAAE,CAAC,CAAC;IAE1B;;;;;;OAMG;IACH,SAAiB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAEnC;;;;;;OAMG;IACH,SAAiB,IAAI,CAAC,EAAE,IAAI,CAAC;IAE7B;;;;;;OAMG;IACH,SAAiB,UAAU,EAAE,wBAAwB,GAAG,IAAI,CAAC;IAE7D,mBAA2B,MAAM,EAAE,KAAK,CAAC;IACzC,mBAA2B,WAAW,EAAE;QAAE,QAAQ,EAAE,gBAAgB,CAAC;QAAC,OAAO,EAAE,oBAAoB,CAAA;KAAE,GAAG,IAAI,CAAC;gBAG3G,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,wBAAwB,GAAG,IAAI,EAC3C,UAAU,EAAE;QAAE,QAAQ,EAAE,gBAAgB,CAAC;QAAC,OAAO,EAAE,oBAAoB,CAAA;KAAE,GAAG,IAAI;IAiDlF;;;;;;;;;OASG;IACH,KAAK,CAAC,OAAO,GAAE,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;IAO/F;;;;;;;;;OASG;IACH,IAAI,CAAC,OAAO,GAAE,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAIrG;;;;;;;;;OASG;IACH,IAAI,CAAC,OAAO,GAAE,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAIrG;;;;;;;;;OASG;IACH,KAAK,CAAC,OAAO,GAAE,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAItG;;;;;;;;;OASG;IACH,IAAI,CAAC,OAAO,GAAE,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAIrG;;;;;;;;;;;;OAYG;IACH,MAAM,IAAI,MAAM;CAiBjB"}
@@ -1,179 +0,0 @@
1
- declare module '@ember-data/store/-private/legacy-model-support/record-reference' {
2
- import type { StableRecordIdentifier } from '@warp-drive/core-types/identifier';
3
- /**
4
- @module @ember-data/store
5
- */
6
- import type { SingleResourceDocument } from '@warp-drive/core-types/spec/json-api-raw';
7
- import type { OpaqueRecordInstance } from '@ember-data/store/-types/q/record-instance';
8
- import type { Store } from '@ember-data/store/-private/store-service';
9
- /**
10
- @module @ember-data/store
11
- */
12
- /**
13
- A `RecordReference` is a low-level API that allows users and
14
- addon authors to perform meta-operations on a record.
15
-
16
- @class RecordReference
17
- @public
18
- */
19
- export default class RecordReference {
20
- store: Store;
21
- ___token: object;
22
- ___identifier: StableRecordIdentifier;
23
- _ref: number;
24
- constructor(store: Store, identifier: StableRecordIdentifier);
25
- destroy(): void;
26
- get type(): string;
27
- /**
28
- The `id` of the record that this reference refers to.
29
-
30
- Together, the `type` and `id` properties form a composite key for
31
- the identity map.
32
-
33
- Example
34
-
35
- ```javascript
36
- let userRef = store.getReference('user', 1);
37
-
38
- userRef.id(); // '1'
39
- ```
40
-
41
- @method id
42
- @public
43
- @return {String} The id of the record.
44
- */
45
- id(): string | null;
46
- /**
47
- The `identifier` of the record that this reference refers to.
48
-
49
- Together, the `type` and `id` properties form a composite key for
50
- the identity map.
51
-
52
- Example
53
-
54
- ```javascript
55
- let userRef = store.getReference('user', 1);
56
-
57
- userRef.identifier(); // '1'
58
- ```
59
-
60
- @method identifier
61
- @public
62
- @return {String} The identifier of the record.
63
- */
64
- identifier(): StableRecordIdentifier;
65
- /**
66
- How the reference will be looked up when it is loaded. Currently
67
- this always returns `identity` to signify that a record will be
68
- loaded by its `type` and `id`.
69
-
70
- Example
71
-
72
- ```javascript
73
- const userRef = store.getReference('user', 1);
74
-
75
- userRef.remoteType(); // 'identity'
76
- ```
77
-
78
- @method remoteType
79
- @public
80
- @return {String} 'identity'
81
- */
82
- remoteType(): 'identity';
83
- /**
84
- This API allows you to provide a reference with new data. The
85
- simplest usage of this API is similar to `store.push`: you provide a
86
- normalized hash of data and the object represented by the reference
87
- will update.
88
-
89
- If you pass a promise to `push`, Ember Data will not ask the adapter
90
- for the data if another attempt to fetch it is made in the
91
- interim. When the promise resolves, the underlying object is updated
92
- with the new data, and the promise returned by *this function* is resolved
93
- with that object.
94
-
95
- For example, `recordReference.push(promise)` will be resolved with a
96
- record.
97
-
98
- Example
99
-
100
- ```javascript
101
- let userRef = store.getReference('user', 1);
102
-
103
- // provide data for reference
104
- userRef.push({
105
- data: {
106
- id: "1",
107
- type: "user",
108
- attributes: {
109
- username: "@user"
110
- }
111
- }
112
- }).then(function(user) {
113
- userRef.value() === user;
114
- });
115
- ```
116
-
117
- @method push
118
- @public
119
- @param objectOrPromise a JSON:API ResourceDocument or a promise resolving to one
120
- @return a promise for the value (record or relationship)
121
- */
122
- push(objectOrPromise: SingleResourceDocument | Promise<SingleResourceDocument>): Promise<OpaqueRecordInstance>;
123
- /**
124
- If the entity referred to by the reference is already loaded, it is
125
- present as `reference.value`. Otherwise the value returned by this function
126
- is `null`.
127
-
128
- Example
129
-
130
- ```javascript
131
- let userRef = store.getReference('user', 1);
132
-
133
- userRef.value(); // user
134
- ```
135
-
136
- @method value
137
- @public
138
- @return {Model} the record for this RecordReference
139
- */
140
- value(): OpaqueRecordInstance | null;
141
- /**
142
- Triggers a fetch for the backing entity based on its `remoteType`
143
- (see `remoteType` definitions per reference type).
144
-
145
- Example
146
-
147
- ```javascript
148
- let userRef = store.getReference('user', 1);
149
-
150
- // load user (via store.find)
151
- userRef.load().then(...)
152
- ```
153
-
154
- @method load
155
- @public
156
- @return {Promise<record>} the record for this RecordReference
157
- */
158
- load(): Promise<unknown>;
159
- /**
160
- Reloads the record if it is already loaded. If the record is not
161
- loaded it will load the record via `store.findRecord`
162
-
163
- Example
164
-
165
- ```javascript
166
- let userRef = store.getReference('user', 1);
167
-
168
- // or trigger a reload
169
- userRef.reload().then(...)
170
- ```
171
-
172
- @method reload
173
- @public
174
- @return {Promise<record>} the record for this RecordReference
175
- */
176
- reload(): Promise<unknown>;
177
- }
178
- }
179
- //# sourceMappingURL=record-reference.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"record-reference.d.ts","sourceRoot":"","sources":["../../../src/-private/legacy-model-support/record-reference.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AAChF;;EAEE;AACF,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAEvF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAG3E,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAE9C;;EAEE;AAEF;;;;;;EAME;AACF,MAAM,CAAC,OAAO,OAAO,eAAe;IAC1B,KAAK,EAAE,KAAK,CAAC;IAErB,QAAQ,EAAG,MAAM,CAAC;IAClB,aAAa,EAAE,sBAAsB,CAAC;IAE9B,IAAI,EAAE,MAAM,CAAC;gBAET,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,sBAAsB;IAa5D,OAAO;IAIP,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED;;;;;;;;;;;;;;;;;MAiBE;IACF,EAAE;IAMF;;;;;;;;;;;;;;;;;MAiBE;IACF,UAAU,IAAI,sBAAsB;IAIpC;;;;;;;;;;;;;;;;MAgBE;IACF,UAAU,IAAI,UAAU;IAIxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAsCE;IACF,IAAI,CAAC,eAAe,EAAE,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAO9G;;;;;;;;;;;;;;;;MAgBE;IACF,KAAK,IAAI,oBAAoB,GAAG,IAAI;IAIpC;;;;;;;;;;;;;;;;MAgBE;IACF,IAAI;IAQJ;;;;;;;;;;;;;;;;MAgBE;IACF,MAAM;CAOP"}
@@ -1,19 +0,0 @@
1
- declare module '@ember-data/store/-private/legacy-model-support/shim-model-class' {
2
- import type { TypedRecordInstance, TypeFromInstance } from '@warp-drive/core-types/record';
3
- import type { LegacyAttributeField, LegacyRelationshipField } from '@warp-drive/core-types/schema/fields';
4
- import type { KeyOrString, ModelSchema } from '@ember-data/store/-types/q/ds-model';
5
- import type { Store } from '@ember-data/store/-private/store-service';
6
- export function getShimClass<T>(store: Store, modelName: T extends TypedRecordInstance ? TypeFromInstance<T> : string): ShimModelClass<T>;
7
- export default class ShimModelClass<T = unknown> implements ModelSchema<T> {
8
- __store: Store;
9
- modelName: T extends TypedRecordInstance ? TypeFromInstance<T> : string;
10
- constructor(store: Store, modelName: T extends TypedRecordInstance ? TypeFromInstance<T> : string);
11
- get fields(): Map<KeyOrString<T>, 'attribute' | 'belongsTo' | 'hasMany'>;
12
- get attributes(): Map<KeyOrString<T>, LegacyAttributeField>;
13
- get relationshipsByName(): Map<KeyOrString<T>, LegacyRelationshipField>;
14
- eachAttribute<K extends KeyOrString<T>>(callback: (key: K, attribute: LegacyAttributeField) => void, binding?: T): void;
15
- eachRelationship<K extends KeyOrString<T>>(callback: (key: K, relationship: LegacyRelationshipField) => void, binding?: T): void;
16
- eachTransformedAttribute<K extends KeyOrString<T>>(callback: (key: K, type: string | null) => void, binding?: T): void;
17
- }
18
- }
19
- //# sourceMappingURL=shim-model-class.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"shim-model-class.d.ts","sourceRoot":"","sources":["../../../src/-private/legacy-model-support/shim-model-class.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAC3F,OAAO,KAAK,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AAE1G,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAM9C,wBAAgB,YAAY,CAAC,CAAC,EAC5B,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,SAAS,mBAAmB,GAAG,gBAAgB,CAAC,CAAC,CAAC,GAAG,MAAM,GACtE,cAAc,CAAC,CAAC,CAAC,CAcnB;AAGD,MAAM,CAAC,OAAO,OAAO,cAAc,CAAC,CAAC,GAAG,OAAO,CAAE,YAAW,WAAW,CAAC,CAAC,CAAC;IAChE,OAAO,EAAE,KAAK,CAAC;IACf,SAAS,EAAE,CAAC,SAAS,mBAAmB,GAAG,gBAAgB,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;gBACpE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,SAAS,mBAAmB,GAAG,gBAAgB,CAAC,CAAC,CAAC,GAAG,MAAM;IAKjG,IAAI,MAAM,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,GAAG,WAAW,GAAG,SAAS,CAAC,CAWvE;IAED,IAAI,UAAU,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,oBAAoB,CAAC,CAW1D;IAED,IAAI,mBAAmB,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,uBAAuB,CAAC,CAWtE;IAED,aAAa,CAAC,CAAC,SAAS,WAAW,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,oBAAoB,KAAK,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC;IAQhH,gBAAgB,CAAC,CAAC,SAAS,WAAW,CAAC,CAAC,CAAC,EACvC,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,YAAY,EAAE,uBAAuB,KAAK,IAAI,EACjE,OAAO,CAAC,EAAE,CAAC;IASb,wBAAwB,CAAC,CAAC,SAAS,WAAW,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC;CAQhH"}