@warp-drive/core 5.6.0-alpha.14 → 5.6.0-alpha.17

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 (287) hide show
  1. package/declarations/build-config/babel-macros.d.ts +1 -2
  2. package/declarations/build-config/canary-features.d.ts +1 -2
  3. package/declarations/build-config/debugging.d.ts +1 -2
  4. package/declarations/build-config/deprecations.d.ts +1 -2
  5. package/declarations/build-config/env.d.ts +1 -2
  6. package/declarations/build-config/macros.d.ts +1 -2
  7. package/declarations/build-config.d.ts +1 -2
  8. package/declarations/configure.d.ts +6 -7
  9. package/declarations/graph/-private/-diff.d.ts +21 -22
  10. package/declarations/graph/-private/-edge-definition.d.ts +134 -135
  11. package/declarations/graph/-private/-state.d.ts +93 -7
  12. package/declarations/graph/-private/-utils.d.ts +18 -13
  13. package/declarations/graph/-private/coerce-id.d.ts +6 -1
  14. package/declarations/graph/-private/debug/assert-polymorphic-type.d.ts +15 -4
  15. package/declarations/graph/-private/edges/collection.d.ts +35 -36
  16. package/declarations/graph/-private/edges/implicit.d.ts +28 -29
  17. package/declarations/graph/-private/edges/resource.d.ts +19 -20
  18. package/declarations/graph/-private/graph.d.ts +83 -48
  19. package/declarations/graph/-private/normalize-link.d.ts +7 -2
  20. package/declarations/graph/-private/operations/add-to-related-records.d.ts +3 -4
  21. package/declarations/graph/-private/operations/merge-identifier.d.ts +2 -3
  22. package/declarations/graph/-private/operations/remove-from-related-records.d.ts +3 -4
  23. package/declarations/graph/-private/operations/replace-related-record.d.ts +2 -3
  24. package/declarations/graph/-private/operations/replace-related-records.d.ts +58 -4
  25. package/declarations/graph/-private/operations/update-relationship.d.ts +11 -9
  26. package/declarations/graph/-private.d.ts +9 -10
  27. package/declarations/index.d.ts +11 -12
  28. package/declarations/reactive/-private/document.d.ts +143 -144
  29. package/declarations/reactive/-private/fields/compute.d.ts +31 -28
  30. package/declarations/reactive/-private/fields/extension.d.ts +8 -0
  31. package/declarations/reactive/-private/fields/managed-array.d.ts +19 -20
  32. package/declarations/reactive/-private/fields/managed-object.d.ts +16 -16
  33. package/declarations/reactive/-private/fields/many-array-manager.d.ts +15 -16
  34. package/declarations/reactive/-private/hooks.d.ts +3 -4
  35. package/declarations/reactive/-private/record.d.ts +61 -58
  36. package/declarations/reactive/-private/schema.d.ts +256 -165
  37. package/declarations/reactive/-private/symbols.d.ts +27 -2
  38. package/declarations/reactive/-private.d.ts +1 -2
  39. package/declarations/reactive.d.ts +4 -5
  40. package/declarations/request/-private/context.d.ts +34 -35
  41. package/declarations/request/-private/debug.d.ts +2 -3
  42. package/declarations/request/-private/fetch.d.ts +23 -24
  43. package/declarations/request/-private/future.d.ts +3 -4
  44. package/declarations/request/-private/manager.d.ts +159 -157
  45. package/declarations/request/-private/promise-cache.d.ts +21 -13
  46. package/declarations/request/-private/types.d.ts +124 -124
  47. package/declarations/request/-private/utils.d.ts +8 -9
  48. package/declarations/request.d.ts +5 -6
  49. package/declarations/store/-private/cache-handler/handler.d.ts +57 -52
  50. package/declarations/store/-private/cache-handler/types.d.ts +95 -96
  51. package/declarations/store/-private/cache-handler/utils.d.ts +16 -16
  52. package/declarations/store/-private/caches/cache-utils.d.ts +7 -4
  53. package/declarations/store/-private/caches/identifier-cache.d.ts +234 -246
  54. package/declarations/store/-private/caches/instance-cache.d.ts +47 -47
  55. package/declarations/store/-private/caches/resource-utils.d.ts +3 -4
  56. package/declarations/store/-private/debug/utils.d.ts +6 -7
  57. package/declarations/store/-private/default-cache-policy.d.ts +362 -361
  58. package/declarations/store/-private/legacy-model-support/record-reference.d.ts +154 -159
  59. package/declarations/store/-private/legacy-model-support/shim-model-class.d.ts +14 -14
  60. package/declarations/store/-private/managers/cache-capabilities-manager.d.ts +21 -22
  61. package/declarations/store/-private/managers/cache-manager.d.ts +440 -425
  62. package/declarations/store/-private/managers/notification-manager.d.ts +88 -83
  63. package/declarations/store/-private/managers/record-array-manager.d.ts +89 -90
  64. package/declarations/store/-private/network/request-cache.d.ts +86 -83
  65. package/declarations/store/-private/new-core-tmp/promise-state.d.ts +252 -244
  66. package/declarations/store/-private/new-core-tmp/reactivity/configure.d.ts +155 -72
  67. package/declarations/store/-private/new-core-tmp/reactivity/internal.d.ts +148 -149
  68. package/declarations/store/-private/new-core-tmp/reactivity/signal.d.ts +28 -23
  69. package/declarations/store/-private/new-core-tmp/request-state.d.ts +263 -241
  70. package/declarations/store/-private/new-core-tmp/request-subscription.d.ts +261 -0
  71. package/declarations/store/-private/record-arrays/identifier-array.d.ts +125 -119
  72. package/declarations/store/-private/record-arrays/many-array.d.ts +180 -182
  73. package/declarations/store/-private/record-arrays/native-proxy-type-fix.d.ts +120 -110
  74. package/declarations/store/-private/store-service.d.ts +1594 -1586
  75. package/declarations/store/-private/utils/coerce-id.d.ts +6 -1
  76. package/declarations/store/-private/utils/construct-resource.d.ts +1 -2
  77. package/declarations/store/-private/utils/is-non-empty-string.d.ts +0 -1
  78. package/declarations/store/-private/utils/normalize-model-name.d.ts +0 -1
  79. package/declarations/store/-private/utils/uuid-polyfill.d.ts +0 -1
  80. package/declarations/store/-private.d.ts +31 -27
  81. package/declarations/store/-types/q/cache-capabilities-manager.d.ts +96 -97
  82. package/declarations/store/-types/q/ds-model.d.ts +17 -18
  83. package/declarations/store/-types/q/identifier.d.ts +11 -12
  84. package/declarations/store/-types/q/record-instance.d.ts +16 -17
  85. package/declarations/store/-types/q/schema-service.d.ts +346 -323
  86. package/declarations/store/-types/q/store.d.ts +25 -28
  87. package/declarations/store.d.ts +1 -2
  88. package/declarations/types/-private.d.ts +16 -8
  89. package/declarations/types/cache/aliases.d.ts +11 -1
  90. package/declarations/types/cache/change.d.ts +4 -5
  91. package/declarations/types/cache/mutations.d.ts +51 -28
  92. package/declarations/types/cache/operations.d.ts +60 -47
  93. package/declarations/types/cache/relationship.d.ts +11 -9
  94. package/declarations/types/cache.d.ts +495 -484
  95. package/declarations/types/graph.d.ts +31 -32
  96. package/declarations/types/identifier.d.ts +83 -82
  97. package/declarations/types/json/raw.d.ts +1 -2
  98. package/declarations/types/params.d.ts +4 -5
  99. package/declarations/types/record.d.ts +117 -76
  100. package/declarations/types/request.d.ts +289 -266
  101. package/declarations/types/runtime.d.ts +8 -9
  102. package/declarations/types/schema/concepts.d.ts +19 -13
  103. package/declarations/types/schema/fields.d.ts +1712 -1587
  104. package/declarations/types/schema/fields.type-test.d.ts +0 -1
  105. package/declarations/types/spec/document.d.ts +28 -22
  106. package/declarations/types/spec/error.d.ts +16 -17
  107. package/declarations/types/spec/json-api-raw.d.ts +102 -102
  108. package/declarations/types/symbols.d.ts +74 -75
  109. package/declarations/types/utils.d.ts +5 -5
  110. package/declarations/types.d.ts +10 -11
  111. package/declarations/utils/string.d.ts +43 -40
  112. package/dist/{configure-BgaZESRo.js → configure-B48bFHOl.js} +38 -2
  113. package/dist/configure.js +1 -1
  114. package/dist/graph/-private.js +2 -2
  115. package/dist/{handler-cHghx9Y9.js → handler-C2T-IyJK.js} +1 -1
  116. package/dist/index.js +3 -3
  117. package/dist/reactive/-private.js +1 -1
  118. package/dist/reactive.js +287 -101
  119. package/dist/{request-state-DgwTEXLU.js → request-state-CjLph1LP.js} +1030 -249
  120. package/dist/store/-private.js +3 -3
  121. package/dist/{symbols-BmDcn6hS.js → symbols-SIstXMLI.js} +3 -3
  122. package/dist/types/-private.js +1 -1
  123. package/dist/types/schema/fields.js +4 -4
  124. package/package.json +4 -4
  125. package/declarations/build-config/babel-macros.d.ts.map +0 -1
  126. package/declarations/build-config/canary-features.d.ts.map +0 -1
  127. package/declarations/build-config/debugging.d.ts.map +0 -1
  128. package/declarations/build-config/deprecations.d.ts.map +0 -1
  129. package/declarations/build-config/env.d.ts.map +0 -1
  130. package/declarations/build-config/macros.d.ts.map +0 -1
  131. package/declarations/build-config.d.ts.map +0 -1
  132. package/declarations/configure.d.ts.map +0 -1
  133. package/declarations/graph/-private/-diff.d.ts.map +0 -1
  134. package/declarations/graph/-private/-edge-definition.d.ts.map +0 -1
  135. package/declarations/graph/-private/-state.d.ts.map +0 -1
  136. package/declarations/graph/-private/-utils.d.ts.map +0 -1
  137. package/declarations/graph/-private/coerce-id.d.ts.map +0 -1
  138. package/declarations/graph/-private/debug/assert-polymorphic-type.d.ts.map +0 -1
  139. package/declarations/graph/-private/edges/collection.d.ts.map +0 -1
  140. package/declarations/graph/-private/edges/implicit.d.ts.map +0 -1
  141. package/declarations/graph/-private/edges/resource.d.ts.map +0 -1
  142. package/declarations/graph/-private/graph.d.ts.map +0 -1
  143. package/declarations/graph/-private/normalize-link.d.ts.map +0 -1
  144. package/declarations/graph/-private/operations/add-to-related-records.d.ts.map +0 -1
  145. package/declarations/graph/-private/operations/merge-identifier.d.ts.map +0 -1
  146. package/declarations/graph/-private/operations/remove-from-related-records.d.ts.map +0 -1
  147. package/declarations/graph/-private/operations/replace-related-record.d.ts.map +0 -1
  148. package/declarations/graph/-private/operations/replace-related-records.d.ts.map +0 -1
  149. package/declarations/graph/-private/operations/update-relationship.d.ts.map +0 -1
  150. package/declarations/graph/-private.d.ts.map +0 -1
  151. package/declarations/index.d.ts.map +0 -1
  152. package/declarations/reactive/-private/document.d.ts.map +0 -1
  153. package/declarations/reactive/-private/fields/compute.d.ts.map +0 -1
  154. package/declarations/reactive/-private/fields/managed-array.d.ts.map +0 -1
  155. package/declarations/reactive/-private/fields/managed-object.d.ts.map +0 -1
  156. package/declarations/reactive/-private/fields/many-array-manager.d.ts.map +0 -1
  157. package/declarations/reactive/-private/hooks.d.ts.map +0 -1
  158. package/declarations/reactive/-private/record.d.ts.map +0 -1
  159. package/declarations/reactive/-private/schema.d.ts.map +0 -1
  160. package/declarations/reactive/-private/symbols.d.ts.map +0 -1
  161. package/declarations/reactive/-private.d.ts.map +0 -1
  162. package/declarations/reactive.d.ts.map +0 -1
  163. package/declarations/request/-private/context.d.ts.map +0 -1
  164. package/declarations/request/-private/debug.d.ts.map +0 -1
  165. package/declarations/request/-private/fetch.d.ts.map +0 -1
  166. package/declarations/request/-private/future.d.ts.map +0 -1
  167. package/declarations/request/-private/manager.d.ts.map +0 -1
  168. package/declarations/request/-private/promise-cache.d.ts.map +0 -1
  169. package/declarations/request/-private/types.d.ts.map +0 -1
  170. package/declarations/request/-private/utils.d.ts.map +0 -1
  171. package/declarations/request.d.ts.map +0 -1
  172. package/declarations/store/-private/cache-handler/handler.d.ts.map +0 -1
  173. package/declarations/store/-private/cache-handler/types.d.ts.map +0 -1
  174. package/declarations/store/-private/cache-handler/utils.d.ts.map +0 -1
  175. package/declarations/store/-private/caches/cache-utils.d.ts.map +0 -1
  176. package/declarations/store/-private/caches/identifier-cache.d.ts.map +0 -1
  177. package/declarations/store/-private/caches/instance-cache.d.ts.map +0 -1
  178. package/declarations/store/-private/caches/resource-utils.d.ts.map +0 -1
  179. package/declarations/store/-private/debug/utils.d.ts.map +0 -1
  180. package/declarations/store/-private/default-cache-policy.d.ts.map +0 -1
  181. package/declarations/store/-private/legacy-model-support/record-reference.d.ts.map +0 -1
  182. package/declarations/store/-private/legacy-model-support/shim-model-class.d.ts.map +0 -1
  183. package/declarations/store/-private/managers/cache-capabilities-manager.d.ts.map +0 -1
  184. package/declarations/store/-private/managers/cache-manager.d.ts.map +0 -1
  185. package/declarations/store/-private/managers/notification-manager.d.ts.map +0 -1
  186. package/declarations/store/-private/managers/record-array-manager.d.ts.map +0 -1
  187. package/declarations/store/-private/network/request-cache.d.ts.map +0 -1
  188. package/declarations/store/-private/new-core-tmp/promise-state.d.ts.map +0 -1
  189. package/declarations/store/-private/new-core-tmp/reactivity/configure.d.ts.map +0 -1
  190. package/declarations/store/-private/new-core-tmp/reactivity/internal.d.ts.map +0 -1
  191. package/declarations/store/-private/new-core-tmp/reactivity/signal.d.ts.map +0 -1
  192. package/declarations/store/-private/new-core-tmp/request-state.d.ts.map +0 -1
  193. package/declarations/store/-private/record-arrays/identifier-array.d.ts.map +0 -1
  194. package/declarations/store/-private/record-arrays/many-array.d.ts.map +0 -1
  195. package/declarations/store/-private/record-arrays/native-proxy-type-fix.d.ts.map +0 -1
  196. package/declarations/store/-private/store-service.d.ts.map +0 -1
  197. package/declarations/store/-private/store-service.type-test.d.ts +0 -2
  198. package/declarations/store/-private/store-service.type-test.d.ts.map +0 -1
  199. package/declarations/store/-private/utils/coerce-id.d.ts.map +0 -1
  200. package/declarations/store/-private/utils/construct-resource.d.ts.map +0 -1
  201. package/declarations/store/-private/utils/is-non-empty-string.d.ts.map +0 -1
  202. package/declarations/store/-private/utils/normalize-model-name.d.ts.map +0 -1
  203. package/declarations/store/-private/utils/uuid-polyfill.d.ts.map +0 -1
  204. package/declarations/store/-private.d.ts.map +0 -1
  205. package/declarations/store/-types/q/cache-capabilities-manager.d.ts.map +0 -1
  206. package/declarations/store/-types/q/ds-model.d.ts.map +0 -1
  207. package/declarations/store/-types/q/identifier.d.ts.map +0 -1
  208. package/declarations/store/-types/q/promise-proxies.d.ts +0 -2
  209. package/declarations/store/-types/q/promise-proxies.d.ts.map +0 -1
  210. package/declarations/store/-types/q/record-data-json-api.d.ts +0 -31
  211. package/declarations/store/-types/q/record-data-json-api.d.ts.map +0 -1
  212. package/declarations/store/-types/q/record-instance.d.ts.map +0 -1
  213. package/declarations/store/-types/q/schema-service.d.ts.map +0 -1
  214. package/declarations/store/-types/q/store.d.ts.map +0 -1
  215. package/declarations/store.d.ts.map +0 -1
  216. package/declarations/types/-private.d.ts.map +0 -1
  217. package/declarations/types/cache/aliases.d.ts.map +0 -1
  218. package/declarations/types/cache/change.d.ts.map +0 -1
  219. package/declarations/types/cache/mutations.d.ts.map +0 -1
  220. package/declarations/types/cache/operations.d.ts.map +0 -1
  221. package/declarations/types/cache/relationship.d.ts.map +0 -1
  222. package/declarations/types/cache.d.ts.map +0 -1
  223. package/declarations/types/graph.d.ts.map +0 -1
  224. package/declarations/types/identifier.d.ts.map +0 -1
  225. package/declarations/types/json/raw.d.ts.map +0 -1
  226. package/declarations/types/params.d.ts.map +0 -1
  227. package/declarations/types/record.d.ts.map +0 -1
  228. package/declarations/types/record.type-test.d.ts +0 -2
  229. package/declarations/types/record.type-test.d.ts.map +0 -1
  230. package/declarations/types/request.d.ts.map +0 -1
  231. package/declarations/types/request.type-test.d.ts +0 -2
  232. package/declarations/types/request.type-test.d.ts.map +0 -1
  233. package/declarations/types/runtime.d.ts.map +0 -1
  234. package/declarations/types/schema/concepts.d.ts.map +0 -1
  235. package/declarations/types/schema/fields.d.ts.map +0 -1
  236. package/declarations/types/schema/fields.type-test.d.ts.map +0 -1
  237. package/declarations/types/spec/document.d.ts.map +0 -1
  238. package/declarations/types/spec/error.d.ts.map +0 -1
  239. package/declarations/types/spec/json-api-raw.d.ts.map +0 -1
  240. package/declarations/types/symbols.d.ts.map +0 -1
  241. package/declarations/types/utils.d.ts.map +0 -1
  242. package/declarations/types.d.ts.map +0 -1
  243. package/declarations/utils/string.d.ts.map +0 -1
  244. package/dist/build-config/babel-macros.js.map +0 -1
  245. package/dist/build-config/canary-features.js.map +0 -1
  246. package/dist/build-config/debugging.js.map +0 -1
  247. package/dist/build-config/deprecations.js.map +0 -1
  248. package/dist/build-config/env.js.map +0 -1
  249. package/dist/build-config/macros.js.map +0 -1
  250. package/dist/build-config.js.map +0 -1
  251. package/dist/configure-BgaZESRo.js.map +0 -1
  252. package/dist/configure.js.map +0 -1
  253. package/dist/context-COmAnXUQ.js.map +0 -1
  254. package/dist/graph/-private.js.map +0 -1
  255. package/dist/handler-cHghx9Y9.js.map +0 -1
  256. package/dist/index.js.map +0 -1
  257. package/dist/reactive/-private.js.map +0 -1
  258. package/dist/reactive.js.map +0 -1
  259. package/dist/request-state-DgwTEXLU.js.map +0 -1
  260. package/dist/request.js.map +0 -1
  261. package/dist/store/-private.js.map +0 -1
  262. package/dist/store.js.map +0 -1
  263. package/dist/symbols-BmDcn6hS.js.map +0 -1
  264. package/dist/types/-private.js.map +0 -1
  265. package/dist/types/cache/aliases.js.map +0 -1
  266. package/dist/types/cache/change.js.map +0 -1
  267. package/dist/types/cache/mutations.js.map +0 -1
  268. package/dist/types/cache/operations.js.map +0 -1
  269. package/dist/types/cache/relationship.js.map +0 -1
  270. package/dist/types/cache.js.map +0 -1
  271. package/dist/types/graph.js.map +0 -1
  272. package/dist/types/identifier.js.map +0 -1
  273. package/dist/types/json/raw.js.map +0 -1
  274. package/dist/types/params.js.map +0 -1
  275. package/dist/types/record.js.map +0 -1
  276. package/dist/types/request.js.map +0 -1
  277. package/dist/types/runtime.js.map +0 -1
  278. package/dist/types/schema/concepts.js.map +0 -1
  279. package/dist/types/schema/fields.js.map +0 -1
  280. package/dist/types/schema/fields.type-test.js.map +0 -1
  281. package/dist/types/spec/document.js.map +0 -1
  282. package/dist/types/spec/error.js.map +0 -1
  283. package/dist/types/spec/json-api-raw.js.map +0 -1
  284. package/dist/types/symbols.js.map +0 -1
  285. package/dist/types/utils.js.map +0 -1
  286. package/dist/types.js.map +0 -1
  287. package/dist/utils/string.js.map +0 -1
@@ -1,199 +1,197 @@
1
- import type { BaseFinderOptions, ModelSchema, StableRecordIdentifier } from '../../../types.ts';
2
- import type { Cache } from '../../../types/cache.ts';
3
- import type { TypedRecordInstance, TypeFromInstance, TypeFromInstanceOrString } from '../../../types/record.ts';
4
- import type { Links, PaginationLinks } from '../../../types/spec/json-api-raw.ts';
5
- import { type WarpDriveSignal } from '../new-core-tmp/reactivity/internal.ts';
6
- import type { CreateRecordProperties, Store } from '../store-service.ts';
7
- import type { MinimumManager } from './identifier-array.ts';
8
- import { IdentifierArray, MUTATE } from './identifier-array.ts';
9
- import type { NativeProxy } from './native-proxy-type-fix.ts';
1
+ import type { BaseFinderOptions, ModelSchema, StableRecordIdentifier } from "../../../types.js";
2
+ import type { Cache } from "../../../types/cache.js";
3
+ import type { TypedRecordInstance, TypeFromInstance, TypeFromInstanceOrString } from "../../../types/record.js";
4
+ import type { LegacyHasManyField, LinksModeHasManyField } from "../../../types/schema/fields.js";
5
+ import type { Links, PaginationLinks } from "../../../types/spec/json-api-raw.js";
6
+ import type { CreateRecordProperties, Store } from "../store-service.js";
7
+ import type { MinimumManager } from "./identifier-array.js";
8
+ import { IdentifierArray } from "./identifier-array.js";
10
9
  export interface ManyArrayCreateArgs<T> {
11
- identifiers: StableRecordIdentifier<TypeFromInstanceOrString<T>>[];
12
- type: TypeFromInstanceOrString<T>;
13
- store: Store;
14
- allowMutation: boolean;
15
- manager: MinimumManager;
16
- identifier: StableRecordIdentifier;
17
- cache: Cache;
18
- meta: Record<string, unknown> | null;
19
- links: Links | PaginationLinks | null;
20
- key: string;
21
- isPolymorphic: boolean;
22
- isAsync: boolean;
23
- _inverseIsAsync: boolean;
24
- isLoaded: boolean;
10
+ identifiers: StableRecordIdentifier<TypeFromInstanceOrString<T>>[];
11
+ type: TypeFromInstanceOrString<T>;
12
+ store: Store;
13
+ allowMutation: boolean;
14
+ manager: MinimumManager;
15
+ field?: LegacyHasManyField | LinksModeHasManyField;
16
+ identifier: StableRecordIdentifier;
17
+ cache: Cache;
18
+ meta: Record<string, unknown> | null;
19
+ links: Links | PaginationLinks | null;
20
+ key: string;
21
+ isPolymorphic: boolean;
22
+ isAsync: boolean;
23
+ _inverseIsAsync: boolean;
24
+ isLoaded: boolean;
25
25
  }
26
26
  /**
27
- A `ManyArray` is a `MutableArray` that represents the contents of a has-many
28
- relationship.
27
+ A `ManyArray` is a `MutableArray` that represents the contents of a has-many
28
+ relationship.
29
29
 
30
- The `ManyArray` is instantiated lazily the first time the relationship is
31
- requested.
30
+ The `ManyArray` is instantiated lazily the first time the relationship is
31
+ requested.
32
32
 
33
- This class is not intended to be directly instantiated by consuming applications.
33
+ This class is not intended to be directly instantiated by consuming applications.
34
34
 
35
- ### Inverses
35
+ ### Inverses
36
36
 
37
- Often, the relationships in Ember Data applications will have
38
- an inverse. For example, imagine the following models are
39
- defined:
37
+ Often, the relationships in Ember Data applications will have
38
+ an inverse. For example, imagine the following models are
39
+ defined:
40
40
 
41
- ```js [app/models/post.js]
42
- import Model, { hasMany } from '@ember-data/model';
41
+ ```js [app/models/post.js]
42
+ import Model, { hasMany } from '@ember-data/model';
43
43
 
44
- export default class PostModel extends Model {
45
- @hasMany('comment') comments;
46
- }
47
- ```
44
+ export default class PostModel extends Model {
45
+ @hasMany('comment') comments;
46
+ }
47
+ ```
48
48
 
49
- ```js [app/models/comment.js]
50
- import { Model, belongsTo } from '@warp-drive/legacy/model';
49
+ ```js [app/models/comment.js]
50
+ import { Model, belongsTo } from '@warp-drive/legacy/model';
51
51
 
52
- export default class CommentModel extends Model {
53
- @belongsTo('post') post;
54
- }
55
- ```
52
+ export default class CommentModel extends Model {
53
+ @belongsTo('post') post;
54
+ }
55
+ ```
56
56
 
57
- If you created a new instance of `Post` and added
58
- a `Comment` record to its `comments` has-many
59
- relationship, you would expect the comment's `post`
60
- property to be set to the post that contained
61
- the has-many.
57
+ If you created a new instance of `Post` and added
58
+ a `Comment` record to its `comments` has-many
59
+ relationship, you would expect the comment's `post`
60
+ property to be set to the post that contained
61
+ the has-many.
62
62
 
63
- We call the record to which a relationship belongs-to the
64
- relationship's _owner_.
63
+ We call the record to which a relationship belongs-to the
64
+ relationship's _owner_.
65
65
 
66
- @class ManyArray
67
- @public
66
+ @class ManyArray
67
+ @public
68
68
  */
69
69
  export declare class RelatedCollection<T = unknown> extends IdentifierArray<T> {
70
- isAsync: boolean;
71
- /**
72
- The loading state of this array
73
-
74
- @property isLoaded
75
- @type {Boolean}
76
- @public
77
- */
78
- isLoaded: boolean;
79
- /**
80
- `true` if the relationship is polymorphic, `false` otherwise.
81
-
82
- @property isPolymorphic
83
- @type {Boolean}
84
- @private
85
- */
86
- isPolymorphic: boolean;
87
- _inverseIsAsync: boolean;
88
- /**
89
- Metadata associated with the request for async hasMany relationships.
90
-
91
- Example
92
-
93
- Given that the server returns the following JSON payload when fetching a
94
- hasMany relationship:
95
-
96
- ```js
97
- {
98
- "comments": [{
99
- "id": 1,
100
- "comment": "This is the first comment",
101
- }, {
102
- // ...
103
- }],
104
-
105
- "meta": {
106
- "page": 1,
107
- "total": 5
108
- }
109
- }
110
- ```
111
-
112
- You can then access the meta data via the `meta` property:
113
-
114
- ```js
115
- let comments = await post.comments;
116
- let meta = comments.meta;
117
-
118
- // meta.page => 1
119
- // meta.total => 5
120
- ```
121
-
122
- @property meta
123
- @type {Object | null}
124
- @public
125
- */
126
- meta: Record<string, unknown> | null;
127
- /**
128
- * Retrieve the links for this relationship
129
- *
130
- @property links
131
- @type {Object | null}
132
- @public
133
- */
134
- links: Links | PaginationLinks | null;
135
- identifier: StableRecordIdentifier;
136
- cache: Cache;
137
- _manager: MinimumManager;
138
- store: Store;
139
- key: string;
140
- type: ModelSchema;
141
- modelName: T extends TypedRecordInstance ? TypeFromInstance<T> : string;
142
- constructor(options: ManyArrayCreateArgs<T>);
143
- [MUTATE](target: StableRecordIdentifier[], receiver: typeof NativeProxy<StableRecordIdentifier[], T[]>, prop: string, args: unknown[], _SIGNAL: WarpDriveSignal): unknown;
144
- notify(): void;
145
- /**
146
- Reloads all of the records in the manyArray. If the manyArray
147
- holds a relationship that was originally fetched using a links url
148
- WarpDrive will revisit the original links url to repopulate the
149
- relationship.
150
-
151
- If the ManyArray holds the result of a `store.query()` reload will
152
- re-run the original query.
153
-
154
- Example
155
-
156
- ```javascript
157
- let user = store.peekRecord('user', '1')
158
- await login(user);
159
-
160
- let permissions = await user.permissions;
161
- await permissions.reload();
162
- ```
163
-
164
- @public
165
- */
166
- reload(options?: BaseFinderOptions): Promise<this>;
167
- /**
168
- Create a child record within the owner
169
-
170
- @public
171
- @param {Object} hash
172
- @return {Model} record
173
- */
174
- createRecord(hash: CreateRecordProperties<T>): T;
175
- /**
176
- Saves all of the records in the `ManyArray`.
177
-
178
- Note: this API can only be used in legacy mode with a configured Adapter.
179
-
180
- Example
181
-
182
- ```javascript
183
- const { content: { data: inbox } } = await store.request(findRecord({ type: 'inbox', id: '1' }));
184
-
185
- let messages = await inbox.messages;
186
- messages.forEach((message) => {
187
- message.isRead = true;
188
- });
189
- messages.save();
190
- ```
191
-
192
- @public
193
- @return {PromiseArray} promise
194
- */
195
- save: () => Promise<IdentifierArray<T>>;
196
- /** @internal */
197
- destroy(): void;
70
+ isAsync: boolean;
71
+ /**
72
+ The loading state of this array
73
+
74
+ @property isLoaded
75
+ @type {Boolean}
76
+ @public
77
+ */
78
+ isLoaded: boolean;
79
+ /**
80
+ `true` if the relationship is polymorphic, `false` otherwise.
81
+
82
+ @property isPolymorphic
83
+ @type {Boolean}
84
+ @private
85
+ */
86
+ isPolymorphic: boolean;
87
+ _inverseIsAsync: boolean;
88
+ /**
89
+ Metadata associated with the request for async hasMany relationships.
90
+
91
+ Example
92
+
93
+ Given that the server returns the following JSON payload when fetching a
94
+ hasMany relationship:
95
+
96
+ ```js
97
+ {
98
+ "comments": [{
99
+ "id": 1,
100
+ "comment": "This is the first comment",
101
+ }, {
102
+ // ...
103
+ }],
104
+
105
+ "meta": {
106
+ "page": 1,
107
+ "total": 5
108
+ }
109
+ }
110
+ ```
111
+
112
+ You can then access the meta data via the `meta` property:
113
+
114
+ ```js
115
+ let comments = await post.comments;
116
+ let meta = comments.meta;
117
+
118
+ // meta.page => 1
119
+ // meta.total => 5
120
+ ```
121
+
122
+ @property meta
123
+ @type {Object | null}
124
+ @public
125
+ */
126
+ meta: Record<string, unknown> | null;
127
+ /**
128
+ * Retrieve the links for this relationship
129
+ *
130
+ @property links
131
+ @type {Object | null}
132
+ @public
133
+ */
134
+ links: Links | PaginationLinks | null;
135
+ identifier: StableRecordIdentifier;
136
+ cache: Cache;
137
+ _manager: MinimumManager;
138
+ store: Store;
139
+ key: string;
140
+ type: ModelSchema;
141
+ modelName: T extends TypedRecordInstance ? TypeFromInstance<T> : string;
142
+ constructor(options: ManyArrayCreateArgs<T>);
143
+ notify(): void;
144
+ /**
145
+ Reloads all of the records in the manyArray. If the manyArray
146
+ holds a relationship that was originally fetched using a links url
147
+ WarpDrive will revisit the original links url to repopulate the
148
+ relationship.
149
+
150
+ If the ManyArray holds the result of a `store.query()` reload will
151
+ re-run the original query.
152
+
153
+ Example
154
+
155
+ ```javascript
156
+ let user = store.peekRecord('user', '1')
157
+ await login(user);
158
+
159
+ let permissions = await user.permissions;
160
+ await permissions.reload();
161
+ ```
162
+
163
+ @public
164
+ */
165
+ reload(options?: BaseFinderOptions): Promise<this>;
166
+ /**
167
+ Create a child record within the owner
168
+
169
+ @public
170
+ @param {Object} hash
171
+ @return {Model} record
172
+ */
173
+ createRecord(hash: CreateRecordProperties<T>): T;
174
+ /**
175
+ Saves all of the records in the `ManyArray`.
176
+
177
+ Note: this API can only be used in legacy mode with a configured Adapter.
178
+
179
+ Example
180
+
181
+ ```javascript
182
+ const { content: { data: inbox } } = await store.request(findRecord({ type: 'inbox', id: '1' }));
183
+
184
+ let messages = await inbox.messages;
185
+ messages.forEach((message) => {
186
+ message.isRead = true;
187
+ });
188
+ messages.save();
189
+ ```
190
+
191
+ @public
192
+ @return {PromiseArray} promise
193
+ */
194
+ save: () => Promise<IdentifierArray<T>>;
195
+ /** @internal */
196
+ destroy(): void;
198
197
  }
199
- //# sourceMappingURL=many-array.d.ts.map
@@ -1,116 +1,126 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ /*
3
+ We redefine Proxy because the native Proxy type treats the `target` and
4
+ `receiver` as the same type incorrectly.
5
+
6
+ We ported this from Typescript's own Proxy types on 3/10/2024.
7
+ */
1
8
  interface ProxyHandler<T extends object> {
2
- /**
3
- * A trap method for a function call.
4
- * @param target The original callable object which is being proxied.
5
- * @internal
6
- */
7
- apply?(target: T, thisArg: any, argArray: any[]): any;
8
- /**
9
- * A trap for the `new` operator.
10
- * @param target The original object which is being proxied.
11
- * @param newTarget The constructor that was originally called.
12
- * @internal
13
- */
14
- construct?(target: T, argArray: any[], newTarget: Function): object;
15
- /**
16
- * A trap for `Object.defineProperty()`.
17
- * @param target The original object which is being proxied.
18
- * @return A `Boolean` indicating whether or not the property has been defined.
19
- * @internal
20
- */
21
- defineProperty?(target: T, property: string | symbol, attributes: PropertyDescriptor): boolean;
22
- /**
23
- * A trap for the `delete` operator.
24
- * @param target The original object which is being proxied.
25
- * @param p The name or `Symbol` of the property to delete.
26
- * @return A `Boolean` indicating whether or not the property was deleted.
27
- * @internal
28
- */
29
- deleteProperty?(target: T, p: string | symbol): boolean;
30
- /**
31
- * A trap for getting a property value.
32
- * @param target The original object which is being proxied.
33
- * @param p The name or `Symbol` of the property to get.
34
- * @param receiver The proxy or an object that inherits from the proxy.
35
- * @internal
36
- */
37
- get?(target: T, p: string | symbol, receiver: any): any;
38
- /**
39
- * A trap for `Object.getOwnPropertyDescriptor()`.
40
- * @param target The original object which is being proxied.
41
- * @param p The name of the property whose description should be retrieved.
42
- * @internal
43
- */
44
- getOwnPropertyDescriptor?(target: T, p: string | symbol): PropertyDescriptor | undefined;
45
- /**
46
- * A trap for the `[[GetPrototypeOf]]` internal method.
47
- * @param target The original object which is being proxied.
48
- * @internal
49
- */
50
- getPrototypeOf?(target: T): object | null;
51
- /**
52
- * A trap for the `in` operator.
53
- * @param target The original object which is being proxied.
54
- * @param p The name or `Symbol` of the property to check for existence.
55
- * @internal
56
- */
57
- has?(target: T, p: string | symbol): boolean;
58
- /**
59
- * A trap for `Object.isExtensible()`.
60
- * @param target The original object which is being proxied.
61
- * @internal
62
- */
63
- isExtensible?(target: T): boolean;
64
- /**
65
- * A trap for `Reflect.ownKeys()`.
66
- * @param target The original object which is being proxied.
67
- * @internal
68
- */
69
- ownKeys?(target: T): ArrayLike<string | symbol>;
70
- /**
71
- * A trap for `Object.preventExtensions()`.
72
- * @param target The original object which is being proxied.
73
- * @internal
74
- */
75
- preventExtensions?(target: T): boolean;
76
- /**
77
- * A trap for setting a property value.
78
- * @param target The original object which is being proxied.
79
- * @param p The name or `Symbol` of the property to set.
80
- * @param receiver The object to which the assignment was originally directed.
81
- * @return A `Boolean` indicating whether or not the property was set.
82
- * @internal
83
- */
84
- set?(target: T, p: string | symbol, newValue: any, receiver: any): boolean;
85
- /**
86
- * A trap for `Object.setPrototypeOf()`.
87
- * @param target The original object which is being proxied.
88
- * @param newPrototype The object's new prototype or `null`.
89
- * @internal
90
- */
91
- setPrototypeOf?(target: T, v: object | null): boolean;
9
+ /**
10
+ * A trap method for a function call.
11
+ * @param target The original callable object which is being proxied.
12
+ * @internal
13
+ */
14
+ apply?(target: T, thisArg: any, argArray: any[]): any;
15
+ /**
16
+ * A trap for the `new` operator.
17
+ * @param target The original object which is being proxied.
18
+ * @param newTarget The constructor that was originally called.
19
+ * @internal
20
+ */
21
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type
22
+ construct?(target: T, argArray: any[], newTarget: Function): object;
23
+ /**
24
+ * A trap for `Object.defineProperty()`.
25
+ * @param target The original object which is being proxied.
26
+ * @return A `Boolean` indicating whether or not the property has been defined.
27
+ * @internal
28
+ */
29
+ defineProperty?(target: T, property: string | symbol, attributes: PropertyDescriptor): boolean;
30
+ /**
31
+ * A trap for the `delete` operator.
32
+ * @param target The original object which is being proxied.
33
+ * @param p The name or `Symbol` of the property to delete.
34
+ * @return A `Boolean` indicating whether or not the property was deleted.
35
+ * @internal
36
+ */
37
+ deleteProperty?(target: T, p: string | symbol): boolean;
38
+ /**
39
+ * A trap for getting a property value.
40
+ * @param target The original object which is being proxied.
41
+ * @param p The name or `Symbol` of the property to get.
42
+ * @param receiver The proxy or an object that inherits from the proxy.
43
+ * @internal
44
+ */
45
+ get?(target: T, p: string | symbol, receiver: any): any;
46
+ /**
47
+ * A trap for `Object.getOwnPropertyDescriptor()`.
48
+ * @param target The original object which is being proxied.
49
+ * @param p The name of the property whose description should be retrieved.
50
+ * @internal
51
+ */
52
+ getOwnPropertyDescriptor?(target: T, p: string | symbol): PropertyDescriptor | undefined;
53
+ /**
54
+ * A trap for the `[[GetPrototypeOf]]` internal method.
55
+ * @param target The original object which is being proxied.
56
+ * @internal
57
+ */
58
+ getPrototypeOf?(target: T): object | null;
59
+ /**
60
+ * A trap for the `in` operator.
61
+ * @param target The original object which is being proxied.
62
+ * @param p The name or `Symbol` of the property to check for existence.
63
+ * @internal
64
+ */
65
+ has?(target: T, p: string | symbol): boolean;
66
+ /**
67
+ * A trap for `Object.isExtensible()`.
68
+ * @param target The original object which is being proxied.
69
+ * @internal
70
+ */
71
+ isExtensible?(target: T): boolean;
72
+ /**
73
+ * A trap for `Reflect.ownKeys()`.
74
+ * @param target The original object which is being proxied.
75
+ * @internal
76
+ */
77
+ ownKeys?(target: T): ArrayLike<string | symbol>;
78
+ /**
79
+ * A trap for `Object.preventExtensions()`.
80
+ * @param target The original object which is being proxied.
81
+ * @internal
82
+ */
83
+ preventExtensions?(target: T): boolean;
84
+ /**
85
+ * A trap for setting a property value.
86
+ * @param target The original object which is being proxied.
87
+ * @param p The name or `Symbol` of the property to set.
88
+ * @param receiver The object to which the assignment was originally directed.
89
+ * @return A `Boolean` indicating whether or not the property was set.
90
+ * @internal
91
+ */
92
+ set?(target: T, p: string | symbol, newValue: any, receiver: any): boolean;
93
+ /**
94
+ * A trap for `Object.setPrototypeOf()`.
95
+ * @param target The original object which is being proxied.
96
+ * @param newPrototype The object's new prototype or `null`.
97
+ * @internal
98
+ */
99
+ setPrototypeOf?(target: T, v: object | null): boolean;
92
100
  }
93
101
  interface ProxyConstructor {
94
- /**
95
- * Creates a revocable Proxy object.
96
- * @param target A target object to wrap with Proxy.
97
- * @param handler An object whose properties define the behavior of Proxy when an operation is attempted on it.
98
- * @internal
99
- */
100
- revocable<T extends object>(target: T, handler: ProxyHandler<T>): {
101
- proxy: T;
102
- revoke: () => void;
103
- };
104
- /**
105
- * Creates a Proxy object. The Proxy object allows you to create an object that can be used in place of the
106
- * original object, but which may redefine fundamental Object operations like getting, setting, and defining
107
- * properties. Proxy objects are commonly used to log property accesses, validate, format, or sanitize inputs.
108
- * @param target A target object to wrap with Proxy.
109
- * @param handler An object whose properties define the behavior of Proxy when an operation is attempted on it.
110
- * @internal
111
- */
112
- new <TSource extends object, TTarget extends object>(target: TSource, handler: ProxyHandler<TSource>): TTarget;
102
+ /**
103
+ * Creates a revocable Proxy object.
104
+ * @param target A target object to wrap with Proxy.
105
+ * @param handler An object whose properties define the behavior of Proxy when an operation is attempted on it.
106
+ * @internal
107
+ */
108
+ revocable<T extends object>(target: T, handler: ProxyHandler<T>): {
109
+ proxy: T;
110
+ revoke: () => void;
111
+ };
112
+ /**
113
+ * Creates a Proxy object. The Proxy object allows you to create an object that can be used in place of the
114
+ * original object, but which may redefine fundamental Object operations like getting, setting, and defining
115
+ * properties. Proxy objects are commonly used to log property accesses, validate, format, or sanitize inputs.
116
+ * @param target A target object to wrap with Proxy.
117
+ * @param handler An object whose properties define the behavior of Proxy when an operation is attempted on it.
118
+ * @internal
119
+ */
120
+ new <
121
+ TSource extends object,
122
+ TTarget extends object
123
+ >(target: TSource, handler: ProxyHandler<TSource>): TTarget;
113
124
  }
114
125
  export declare const NativeProxy: ProxyConstructor;
115
126
  export {};
116
- //# sourceMappingURL=native-proxy-type-fix.d.ts.map