@warp-drive/legacy 5.8.0-alpha.9 → 5.8.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 (200) hide show
  1. package/README.md +14 -27
  2. package/declarations/adapter/error.d.ts +7 -7
  3. package/declarations/adapter/json-api.d.ts +2 -2
  4. package/declarations/adapter/rest.d.ts +21 -104
  5. package/declarations/adapter.d.ts +2 -2
  6. package/declarations/compat/builders/find-all.d.ts +6 -6
  7. package/declarations/compat/builders/find-record.d.ts +8 -8
  8. package/declarations/compat/builders/query.d.ts +12 -12
  9. package/declarations/compat/legacy-network-handler/minimum-serializer-interface.d.ts +16 -24
  10. package/declarations/compat/utils.d.ts +13 -13
  11. package/declarations/compat.d.ts +31 -5
  12. package/declarations/index.d.ts +25 -8
  13. package/declarations/model/-private/legacy-relationships-support.d.ts +2 -2
  14. package/declarations/model/-private/model.d.ts +10 -51
  15. package/declarations/model/-private/promise-many-array.d.ts +0 -18
  16. package/declarations/model/-private/references/belongs-to.d.ts +18 -28
  17. package/declarations/model/-private/references/has-many.d.ts +13 -15
  18. package/declarations/model/migration-support.d.ts +42 -19
  19. package/declarations/model-fragments/extensions/fragment-array.d.ts +16 -0
  20. package/declarations/model-fragments/extensions/fragment.d.ts +15 -0
  21. package/declarations/model-fragments/hooks/model-for.d.ts +20 -0
  22. package/declarations/model-fragments/index.d.ts +5 -0
  23. package/declarations/model-fragments/instance-initializers/fragment-extensions.d.ts +9 -0
  24. package/declarations/model-fragments/utilities/with-array-defaults.d.ts +15 -0
  25. package/declarations/model-fragments/utilities/with-fragment-array-defaults.d.ts +20 -0
  26. package/declarations/model-fragments/utilities/with-fragment-defaults.d.ts +19 -0
  27. package/declarations/model-fragments/utilities/with-legacy.d.ts +3 -0
  28. package/declarations/model-fragments.d.ts +9 -0
  29. package/declarations/model.d.ts +2 -2
  30. package/declarations/serializer/-private/embedded-records-mixin.d.ts +1 -1
  31. package/declarations/serializer/json-api.d.ts +7 -6
  32. package/declarations/serializer/json.d.ts +3 -3
  33. package/declarations/serializer.d.ts +5 -6
  34. package/dist/{-private-B1pSSN52.js → -private-BG3bMiKp.js} +2 -1
  35. package/dist/adapter/-private.js +1 -1
  36. package/dist/adapter/error.js +9 -9
  37. package/dist/adapter/json-api.js +1 -1
  38. package/dist/adapter/rest.js +33 -117
  39. package/dist/adapter.js +2 -2
  40. package/dist/compat/-private.js +1 -1
  41. package/dist/compat/builders.js +26 -26
  42. package/dist/compat/utils.js +13 -14
  43. package/dist/compat.js +28 -8
  44. package/dist/{errors-COviC59J.js → errors-Cz5KrzBk.js} +113 -120
  45. package/dist/{hooks-Bp8SIQBU.js → hooks-D6diaM34.js} +1 -1
  46. package/dist/index.js +25 -8
  47. package/dist/{json-ksWOHRfq.js → json-ChdEfB0X.js} +12 -27
  48. package/dist/model/-private.js +1 -1
  49. package/dist/model/migration-support.js +55 -25
  50. package/dist/model-for-CqXsIKws.js +221 -0
  51. package/dist/model-fragments.js +76 -0
  52. package/dist/model.js +3 -3
  53. package/dist/{schema-provider-JlCneqZH.js → schema-provider-DJCV_6AF.js} +44 -87
  54. package/dist/{serialize-into-hash-BnYvPex3.js → serialize-into-hash-DPZYoF-i.js} +1 -1
  55. package/dist/serializer/json-api.js +18 -45
  56. package/dist/serializer/json.js +1 -1
  57. package/dist/serializer/rest.js +10 -10
  58. package/dist/serializer.js +5 -6
  59. package/dist/store.js +2 -1
  60. package/dist/unpkg/dev/-private-DtjBbEgy.js +1206 -0
  61. package/dist/unpkg/dev/adapter/-private.js +1 -0
  62. package/dist/unpkg/dev/adapter/error.js +335 -0
  63. package/dist/unpkg/dev/adapter/json-api.js +271 -0
  64. package/dist/unpkg/dev/adapter/rest.js +1171 -0
  65. package/dist/unpkg/dev/adapter.js +1252 -0
  66. package/dist/unpkg/dev/compat/-private.js +1 -0
  67. package/dist/unpkg/dev/compat/builders.js +275 -0
  68. package/dist/unpkg/dev/compat/extensions.js +242 -0
  69. package/dist/unpkg/dev/compat/utils.js +223 -0
  70. package/dist/unpkg/dev/compat.js +1147 -0
  71. package/dist/unpkg/dev/errors-DmGGJr3T.js +2562 -0
  72. package/dist/unpkg/dev/hooks-CkYiE6Ud.js +73 -0
  73. package/dist/unpkg/dev/index.js +197 -0
  74. package/dist/unpkg/dev/json-Cu1LNgmQ.js +1256 -0
  75. package/dist/unpkg/dev/model/-private.js +1 -0
  76. package/dist/unpkg/dev/model/migration-support.js +553 -0
  77. package/dist/unpkg/dev/model-for-CqXsIKws.js +221 -0
  78. package/dist/unpkg/dev/model-fragments.js +76 -0
  79. package/dist/unpkg/dev/model.js +678 -0
  80. package/dist/unpkg/dev/runtime-BPCpkOf1-BKOwiRJp.js +65 -0
  81. package/dist/unpkg/dev/schema-provider-DDVYxmUV.js +2186 -0
  82. package/dist/unpkg/dev/serialize-into-hash-B2xDbuo5.js +259 -0
  83. package/dist/unpkg/dev/serializer/json-api.js +649 -0
  84. package/dist/unpkg/dev/serializer/json.js +4 -0
  85. package/dist/unpkg/dev/serializer/rest.js +1242 -0
  86. package/dist/unpkg/dev/serializer/transform.js +278 -0
  87. package/dist/unpkg/dev/serializer.js +248 -0
  88. package/dist/unpkg/dev/store.js +637 -0
  89. package/dist/unpkg/dev/util-DvanW33H.js +20 -0
  90. package/dist/unpkg/dev/utils-BhvS1iTS.js +8 -0
  91. package/dist/unpkg/dev-deprecated/-private-DtjBbEgy.js +1206 -0
  92. package/dist/unpkg/dev-deprecated/adapter/-private.js +1 -0
  93. package/dist/unpkg/dev-deprecated/adapter/error.js +335 -0
  94. package/dist/unpkg/dev-deprecated/adapter/json-api.js +271 -0
  95. package/dist/unpkg/dev-deprecated/adapter/rest.js +1171 -0
  96. package/dist/unpkg/dev-deprecated/adapter.js +1252 -0
  97. package/dist/unpkg/dev-deprecated/compat/-private.js +1 -0
  98. package/dist/unpkg/dev-deprecated/compat/builders.js +275 -0
  99. package/dist/unpkg/dev-deprecated/compat/extensions.js +242 -0
  100. package/dist/unpkg/dev-deprecated/compat/utils.js +223 -0
  101. package/dist/unpkg/dev-deprecated/compat.js +1147 -0
  102. package/dist/unpkg/dev-deprecated/errors-Spt6ubMd.js +2565 -0
  103. package/dist/unpkg/dev-deprecated/hooks-DOXegvhL.js +73 -0
  104. package/dist/unpkg/dev-deprecated/index.js +196 -0
  105. package/dist/unpkg/dev-deprecated/json-Cu1LNgmQ.js +1256 -0
  106. package/dist/unpkg/dev-deprecated/model/-private.js +1 -0
  107. package/dist/unpkg/dev-deprecated/model/migration-support.js +570 -0
  108. package/dist/unpkg/dev-deprecated/model-for-CqXsIKws.js +221 -0
  109. package/dist/unpkg/dev-deprecated/model-fragments.js +76 -0
  110. package/dist/unpkg/dev-deprecated/model.js +682 -0
  111. package/dist/unpkg/dev-deprecated/runtime-BPCpkOf1-BKOwiRJp.js +65 -0
  112. package/dist/unpkg/dev-deprecated/schema-provider-BP6_8N-V.js +2211 -0
  113. package/dist/unpkg/dev-deprecated/serialize-into-hash-B2xDbuo5.js +259 -0
  114. package/dist/unpkg/dev-deprecated/serializer/json-api.js +649 -0
  115. package/dist/unpkg/dev-deprecated/serializer/json.js +4 -0
  116. package/dist/unpkg/dev-deprecated/serializer/rest.js +1242 -0
  117. package/dist/unpkg/dev-deprecated/serializer/transform.js +278 -0
  118. package/dist/unpkg/dev-deprecated/serializer.js +248 -0
  119. package/dist/unpkg/dev-deprecated/store.js +637 -0
  120. package/dist/unpkg/dev-deprecated/util-CWr5WQOT.js +24 -0
  121. package/dist/unpkg/dev-deprecated/utils-C9PJehtL.js +12 -0
  122. package/dist/unpkg/prod/-private-BdyZaGEh.js +971 -0
  123. package/dist/unpkg/prod/adapter/-private.js +1 -0
  124. package/dist/unpkg/prod/adapter/error.js +330 -0
  125. package/dist/unpkg/prod/adapter/json-api.js +266 -0
  126. package/dist/unpkg/prod/adapter/rest.js +1134 -0
  127. package/dist/unpkg/prod/adapter.js +1219 -0
  128. package/dist/unpkg/prod/compat/-private.js +1 -0
  129. package/dist/unpkg/prod/compat/builders.js +210 -0
  130. package/dist/unpkg/prod/compat/extensions.js +232 -0
  131. package/dist/unpkg/prod/compat/utils.js +218 -0
  132. package/dist/unpkg/prod/compat.js +727 -0
  133. package/dist/unpkg/prod/errors-BGVFCBmi.js +2314 -0
  134. package/dist/unpkg/prod/hooks-BztVA_x0.js +41 -0
  135. package/dist/unpkg/prod/index.js +151 -0
  136. package/dist/unpkg/prod/json-BWrZ5546.js +1243 -0
  137. package/dist/unpkg/prod/model/-private.js +1 -0
  138. package/dist/unpkg/prod/model/migration-support.js +546 -0
  139. package/dist/unpkg/prod/model-for-CqXsIKws.js +221 -0
  140. package/dist/unpkg/prod/model-fragments.js +76 -0
  141. package/dist/unpkg/prod/model.js +593 -0
  142. package/dist/unpkg/prod/runtime-BPCpkOf1-BKOwiRJp.js +65 -0
  143. package/dist/unpkg/prod/schema-provider-DJtD_8jZ.js +1861 -0
  144. package/dist/unpkg/prod/serialize-into-hash-DGlzQteF.js +215 -0
  145. package/dist/unpkg/prod/serializer/json-api.js +592 -0
  146. package/dist/unpkg/prod/serializer/json.js +4 -0
  147. package/dist/unpkg/prod/serializer/rest.js +1210 -0
  148. package/dist/unpkg/prod/serializer/transform.js +278 -0
  149. package/dist/unpkg/prod/serializer.js +248 -0
  150. package/dist/unpkg/prod/store.js +505 -0
  151. package/dist/unpkg/prod/util-DvanW33H.js +20 -0
  152. package/dist/unpkg/prod/utils-BhvS1iTS.js +8 -0
  153. package/dist/unpkg/prod-deprecated/-private-BdyZaGEh.js +971 -0
  154. package/dist/unpkg/prod-deprecated/adapter/-private.js +1 -0
  155. package/dist/unpkg/prod-deprecated/adapter/error.js +330 -0
  156. package/dist/unpkg/prod-deprecated/adapter/json-api.js +266 -0
  157. package/dist/unpkg/prod-deprecated/adapter/rest.js +1134 -0
  158. package/dist/unpkg/prod-deprecated/adapter.js +1219 -0
  159. package/dist/unpkg/prod-deprecated/compat/-private.js +1 -0
  160. package/dist/unpkg/prod-deprecated/compat/builders.js +210 -0
  161. package/dist/unpkg/prod-deprecated/compat/extensions.js +232 -0
  162. package/dist/unpkg/prod-deprecated/compat/utils.js +218 -0
  163. package/dist/unpkg/prod-deprecated/compat.js +727 -0
  164. package/dist/unpkg/prod-deprecated/errors-CdDaK81x.js +2317 -0
  165. package/dist/unpkg/prod-deprecated/hooks-yId87yyG.js +41 -0
  166. package/dist/unpkg/prod-deprecated/index.js +150 -0
  167. package/dist/unpkg/prod-deprecated/json-BWrZ5546.js +1243 -0
  168. package/dist/unpkg/prod-deprecated/model/-private.js +1 -0
  169. package/dist/unpkg/prod-deprecated/model/migration-support.js +563 -0
  170. package/dist/unpkg/prod-deprecated/model-for-CqXsIKws.js +221 -0
  171. package/dist/unpkg/prod-deprecated/model-fragments.js +76 -0
  172. package/dist/unpkg/prod-deprecated/model.js +596 -0
  173. package/dist/unpkg/prod-deprecated/runtime-BPCpkOf1-BKOwiRJp.js +65 -0
  174. package/dist/unpkg/prod-deprecated/schema-provider-CjX55uSY.js +1904 -0
  175. package/dist/unpkg/prod-deprecated/serialize-into-hash-DGlzQteF.js +215 -0
  176. package/dist/unpkg/prod-deprecated/serializer/json-api.js +592 -0
  177. package/dist/unpkg/prod-deprecated/serializer/json.js +4 -0
  178. package/dist/unpkg/prod-deprecated/serializer/rest.js +1210 -0
  179. package/dist/unpkg/prod-deprecated/serializer/transform.js +278 -0
  180. package/dist/unpkg/prod-deprecated/serializer.js +248 -0
  181. package/dist/unpkg/prod-deprecated/store.js +505 -0
  182. package/dist/unpkg/prod-deprecated/util-B6cn-i93.js +23 -0
  183. package/dist/unpkg/prod-deprecated/utils-BUWwQwCh.js +11 -0
  184. package/logos/README.md +2 -2
  185. package/logos/logo-yellow-slab.svg +1 -0
  186. package/logos/word-mark-black.svg +1 -0
  187. package/logos/word-mark-white.svg +1 -0
  188. package/package.json +14 -6
  189. package/logos/NCC-1701-a-blue.svg +0 -4
  190. package/logos/NCC-1701-a-gold.svg +0 -4
  191. package/logos/NCC-1701-a-gold_100.svg +0 -1
  192. package/logos/NCC-1701-a-gold_base-64.txt +0 -1
  193. package/logos/NCC-1701-a.svg +0 -4
  194. package/logos/docs-badge.svg +0 -2
  195. package/logos/ember-data-logo-dark.svg +0 -12
  196. package/logos/ember-data-logo-light.svg +0 -12
  197. package/logos/social1.png +0 -0
  198. package/logos/social2.png +0 -0
  199. package/logos/warp-drive-logo-dark.svg +0 -4
  200. package/logos/warp-drive-logo-gold.svg +0 -4
@@ -0,0 +1 @@
1
+ export { E as Errors, L as LEGACY_SUPPORT, P as PromiseBelongsTo, a as PromiseManyArray, l as lookupLegacySupport } from "../errors-Spt6ubMd.js";
@@ -0,0 +1,570 @@
1
+ import { recordIdentifierFor } from '@warp-drive/core';
2
+ import { Context } from '@warp-drive/core/reactive/-private';
3
+ import { notifyInternalSignal } from '@warp-drive/core/signals/-leaked';
4
+ import { assertPrivateStore } from '@warp-drive/core/store/-private';
5
+ import { getOrSetGlobal } from '@warp-drive/core/types/-private';
6
+ import { Type } from '@warp-drive/core/types/symbols';
7
+ import { l as lookupLegacySupport, E as Errors } from "../errors-Spt6ubMd.js";
8
+ import { b as buildSchema, u as unloadRecord, s as serialize, _ as _save, a as save, r as rollbackAttributes, c as _reload, d as reload, h as hasMany, e as _destroyRecord, f as destroyRecord, i as deleteRecord, R as RecordState, j as changedAttributes, k as belongsTo, l as createSnapshot } from "../schema-provider-BP6_8N-V.js";
9
+
10
+ /**
11
+ * This module provides support for migrating away from @warp-drive/legacy/model
12
+ * to ReactiveResource from @warp-drive/core/reactive.
13
+ *
14
+ * It includes:
15
+ *
16
+ * - A `withDefaults` function to assist in creating a schema in LegacyMode
17
+ * - A `registerDerivations` function to register the derivations necessary to support LegacyMode
18
+ * - A `DelegatingSchemaService` that can be used to provide a schema service that works with both
19
+ * @warp-drive/legacy/model and @warp-drive/core/reactive simultaneously for migration purposes.
20
+ * - A `WithLegacy` type util that can be used to create a type that includes the legacy
21
+ * properties and methods of a record.
22
+ *
23
+ * Using LegacyMode features on a ReactiveResource *requires* the use of these derivations and schema
24
+ * additions. LegacyMode is not intended to be a long-term solution, but rather a stepping stone
25
+ * to assist in more rapidly adopting modern WarpDrive features.
26
+ *
27
+ * @module
28
+ */
29
+
30
+ // 'isDestroying', 'isDestroyed'
31
+ const LegacyFields = ['_createSnapshot', 'adapterError', 'belongsTo', 'changedAttributes', 'constructor', 'currentState', 'deleteRecord', 'destroyRecord', 'dirtyType', 'errors', 'hasDirtyAttributes', 'hasMany', 'isDeleted', 'isEmpty', 'isError', 'isLoaded', 'isLoading', 'isNew', 'isSaving', 'isValid', 'reload', 'rollbackAttributes', 'save', 'serialize', 'unloadRecord'];
32
+
33
+ /**
34
+ * A Type utility that enables quickly adding type information for the fields
35
+ * defined by `import { withDefaults } from '@warp-drive/legacy/model/migration-support'`.
36
+ *
37
+ * Example:
38
+ *
39
+ * ```ts
40
+ * import { withDefaults, WithLegacy } from '@warp-drive/legacy/model/migration-support';
41
+ * import { Type } from '@warp-drive/core/types/symbols';
42
+ * import type { HasMany } from '@@warp-drive/legacy/model';
43
+ *
44
+ * export const UserSchema = withDefaults({
45
+ * type: 'user',
46
+ * fields: [
47
+ * { name: 'firstName', kind: 'attribute' },
48
+ * { name: 'lastName', kind: 'attribute' },
49
+ * { name: 'age', kind: 'attribute' },
50
+ * { name: 'friends',
51
+ * kind: 'hasMany',
52
+ * type: 'user',
53
+ * options: { inverse: 'friends', async: false }
54
+ * },
55
+ * { name: 'bestFriend',
56
+ * kind: 'belongsTo',
57
+ * type: 'user',
58
+ * options: { inverse: null, async: false }
59
+ * },
60
+ * ],
61
+ * });
62
+ *
63
+ * export type User = WithLegacy<{
64
+ * firstName: string;
65
+ * lastName: string;
66
+ * age: number;
67
+ * friends: HasMany<User>;
68
+ * bestFriend: User | null;
69
+ * [Type]: 'user';
70
+ * }>
71
+ * ```
72
+ *
73
+ */
74
+
75
+ const LegacySupport = getOrSetGlobal('LegacySupport', new WeakMap());
76
+ function legacySupport(record, options, prop) {
77
+ let state = LegacySupport.get(record);
78
+ if (!state) {
79
+ state = {};
80
+ LegacySupport.set(record, state);
81
+ }
82
+ const suppressDeprecation = Boolean(options && options.suppressDeprecation);
83
+ switch (prop) {
84
+ case '_createSnapshot':
85
+ // FIXME should be deprecated too?
86
+ return createSnapshot;
87
+ case 'adapterError':
88
+ // FIXME should be deprecated too?
89
+ return record.currentState.adapterError;
90
+ case 'belongsTo':
91
+ return belongsTo;
92
+ case 'changedAttributes':
93
+ return changedAttributes;
94
+ case 'constructor':
95
+ return state._constructor = state._constructor || {
96
+ isModel: true,
97
+ name: `Record<${recordIdentifierFor(record).type}>`,
98
+ modelName: recordIdentifierFor(record).type
99
+ };
100
+ case 'currentState':
101
+ return state.recordState = state.recordState || new RecordState(record);
102
+ case 'deleteRecord':
103
+ return deleteRecord;
104
+ case 'destroyRecord':
105
+ return suppressDeprecation ? _destroyRecord : destroyRecord;
106
+ case 'dirtyType':
107
+ return record.currentState.dirtyType;
108
+ case 'errors':
109
+ // FIXME should be deprecated too?
110
+ // @ts-expect-error
111
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call
112
+ return state.errors = state.errors || Errors.create({
113
+ __record: record
114
+ });
115
+ case 'hasDirtyAttributes':
116
+ return record.currentState.isDirty;
117
+ case 'hasMany':
118
+ return hasMany;
119
+ case 'isDeleted':
120
+ return record.currentState.isDeleted;
121
+ case 'isEmpty':
122
+ return record.currentState.isEmpty;
123
+ case 'isError':
124
+ return record.currentState.isError;
125
+ case 'isLoaded':
126
+ return record.currentState.isLoaded;
127
+ case 'isLoading':
128
+ return record.currentState.isLoading;
129
+ case 'isNew':
130
+ return record.currentState.isNew;
131
+ case 'isSaving':
132
+ return record.currentState.isSaving;
133
+ case 'isValid':
134
+ return record.currentState.isValid;
135
+ case 'reload':
136
+ return suppressDeprecation ? _reload : reload;
137
+ case 'rollbackAttributes':
138
+ return rollbackAttributes;
139
+ case 'save':
140
+ return suppressDeprecation ? _save : save;
141
+ case 'serialize':
142
+ // FIXME should be deprecated too? (is somewhat deprecated via store.serializeRecord)
143
+ return serialize;
144
+ case 'unloadRecord':
145
+ return unloadRecord;
146
+ default:
147
+ (test => {
148
+ {
149
+ throw new Error(`${prop} is not a supported legacy field`);
150
+ }
151
+ })();
152
+ }
153
+ }
154
+ legacySupport[Type] = '@legacy';
155
+
156
+ /**
157
+ * A function which adds the necessary fields to a schema and marks it as
158
+ * being in LegacyMode. This is used to support the legacy features of
159
+ * @warp-drive/legacy/model while migrating to WarpDrive.
160
+ *
161
+ * Example:
162
+ *
163
+ * ```ts
164
+ * import { withDefaults, WithLegacy } from '@warp-drive/legacy/model/migration-support';
165
+ * import { Type } from '@warp-drive/core/types/symbols';
166
+ * import type { HasMany } from '@warp-drive/legacy/model';
167
+ *
168
+ * export const UserSchema = withDefaults({
169
+ * type: 'user',
170
+ * fields: [
171
+ * { name: 'firstName', kind: 'attribute' },
172
+ * { name: 'lastName', kind: 'attribute' },
173
+ * { name: 'age', kind: 'attribute' },
174
+ * { name: 'friends',
175
+ * kind: 'hasMany',
176
+ * type: 'user',
177
+ * options: { inverse: 'friends', async: false }
178
+ * },
179
+ * { name: 'bestFriend',
180
+ * kind: 'belongsTo',
181
+ * type: 'user',
182
+ * options: { inverse: null, async: false }
183
+ * },
184
+ * ],
185
+ * });
186
+ *
187
+ * export type User = WithLegacy<{
188
+ * firstName: string;
189
+ * lastName: string;
190
+ * age: number;
191
+ * friends: HasMany<User>;
192
+ * bestFriend: User | null;
193
+ * [Type]: 'user';
194
+ * }>
195
+ * ```
196
+ *
197
+ * Using this function require registering the derivations
198
+ * it requires with the schema service.
199
+ *
200
+ * ```ts
201
+ * import { registerDerivations } from '@warp-drive/legacy/model/migration-support';
202
+ *
203
+ * registerDerivations(schema);
204
+ * ```
205
+ *
206
+ * @param schema The schema to add legacy support to.
207
+ * @return The schema with legacy support added.
208
+ * @public
209
+ */
210
+ function withDefaults(schema) {
211
+ schema.legacy = true;
212
+ schema.identity = {
213
+ kind: '@id',
214
+ name: 'id'
215
+ };
216
+ LegacyFields.forEach(field => {
217
+ schema.fields.push({
218
+ type: '@legacy',
219
+ name: field,
220
+ kind: 'derived'
221
+ });
222
+ });
223
+ schema.fields.push({
224
+ name: '_isReloading',
225
+ kind: '@local',
226
+ type: 'boolean',
227
+ options: {
228
+ defaultValue: false
229
+ }
230
+ });
231
+ schema.fields.push({
232
+ name: 'isDestroying',
233
+ kind: '@local',
234
+ type: 'boolean',
235
+ options: {
236
+ defaultValue: false
237
+ }
238
+ });
239
+ schema.fields.push({
240
+ name: 'isDestroyed',
241
+ kind: '@local',
242
+ type: 'boolean',
243
+ options: {
244
+ defaultValue: false
245
+ }
246
+ });
247
+ schema.objectExtensions = schema.objectExtensions || [];
248
+ schema.objectExtensions.push('deprecated-model-behaviors');
249
+ return schema;
250
+ }
251
+
252
+ /**
253
+ * Adds the necessasary fields to the schema for supporting
254
+ * the deprecated request methods on LegacyMode schemas.
255
+ *
256
+ * Use this instead of `withDefaults` to add the fields
257
+ * and behaviors necessary to support Model-Like capabilities.
258
+ *
259
+ * ```ts
260
+ * import { withRestoredDeprecatedModelRequestBehaviors } from '@warp-drive/legacy/model/migration-support';
261
+ *
262
+ * export const UserSchema = withRestoredDeprecatedModelRequestBehaviors({
263
+ * type: 'user',
264
+ * fields: [
265
+ * { name: 'firstName', kind: 'attribute' },
266
+ * { name: 'lastName', kind: 'attribute' },
267
+ * ]
268
+ * });
269
+ * ```
270
+ */
271
+ function withRestoredDeprecatedModelRequestBehaviors(schema) {
272
+ schema.legacy = true;
273
+ schema.identity = {
274
+ kind: '@id',
275
+ name: 'id'
276
+ };
277
+ LegacyFields.forEach(field => {
278
+ schema.fields.push({
279
+ type: '@legacy',
280
+ name: field,
281
+ kind: 'derived',
282
+ options: {
283
+ suppressDeprecation: true
284
+ }
285
+ });
286
+ });
287
+ schema.fields.push({
288
+ name: 'isReloading',
289
+ kind: '@local',
290
+ type: 'boolean',
291
+ options: {
292
+ defaultValue: false
293
+ }
294
+ });
295
+ schema.fields.push({
296
+ name: 'isDestroying',
297
+ kind: '@local',
298
+ type: 'boolean',
299
+ options: {
300
+ defaultValue: false
301
+ }
302
+ });
303
+ schema.fields.push({
304
+ name: 'isDestroyed',
305
+ kind: '@local',
306
+ type: 'boolean',
307
+ options: {
308
+ defaultValue: false
309
+ }
310
+ });
311
+ return schema;
312
+ }
313
+
314
+ /**
315
+ * A function which registers the necessary derivations to support
316
+ * the LegacyMode features of @warp-drive/legacy/model while migrating to WarpDrive.
317
+ *
318
+ * This must be called in order to use the fields added by {@link withDefaults} or
319
+ * {@link withRestoredDeprecatedModelRequestBehaviors}.
320
+ *
321
+ * @param schema The schema service to register the derivations with.
322
+ * @public
323
+ */
324
+ function registerDerivations(schema) {
325
+ schema.registerDerivation(legacySupport);
326
+ // @ts-expect-error
327
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call
328
+ schema._registerMode('@legacy', {
329
+ belongsTo: {
330
+ get(store, record, cacheKey, field) {
331
+ // FIXME field.name here should likely be field.sourceKey || field.name
332
+ return lookupLegacySupport(record).getBelongsTo(field.name);
333
+ },
334
+ set(store, record, cacheKey, field, value) {
335
+ assertPrivateStore(store);
336
+ store._join(() => {
337
+ // FIXME field.name here should likely be field.sourceKey || field.name
338
+ lookupLegacySupport(record).setDirtyBelongsTo(field.name, value);
339
+ });
340
+ }
341
+ },
342
+ hasMany: {
343
+ get(store, record, cacheKey, field) {
344
+ // FIXME field.name here should likely be field.sourceKey || field.name
345
+ return lookupLegacySupport(record).getHasMany(field.name);
346
+ },
347
+ set(store, record, cacheKey, field, value) {
348
+ assertPrivateStore(store);
349
+ store._join(() => {
350
+ const support = lookupLegacySupport(record);
351
+ // FIXME field.name here should likely be field.sourceKey || field.name
352
+ const manyArray = support.getManyArray(field.name);
353
+ manyArray.splice(0, manyArray.length, ...value);
354
+ });
355
+ },
356
+ notify(store, record, cacheKey, field) {
357
+ const support = lookupLegacySupport(record);
358
+ // FIXME field.name here should likely be field.sourceKey || field.name
359
+ const manyArray = support && support._manyArrayCache[field.name];
360
+ const hasPromise = support && support._relationshipPromisesCache[field.name];
361
+ if (manyArray && hasPromise) {
362
+ // do nothing, we will notify the ManyArray directly
363
+ // once the fetch has completed.
364
+ return false;
365
+ }
366
+ if (manyArray) {
367
+ notifyInternalSignal(manyArray[Context].signal);
368
+ return true;
369
+ }
370
+ return false;
371
+ }
372
+ }
373
+ });
374
+ schema.CAUTION_MEGA_DANGER_ZONE_registerExtension({
375
+ name: 'deprecated-model-behaviors',
376
+ kind: 'object',
377
+ features: {
378
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
379
+ get isReloading() {
380
+ console.warn(`record.isReloading is deprecated, please use store.request and either <Request> or getRequuestState to keep track of the request state instead.`); // @ts-expect-error
381
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-return
382
+ return this._isReloading;
383
+ },
384
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
385
+ set isReloading(v) {
386
+ // @ts-expect-error
387
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
388
+ this._isReloading = v;
389
+ }
390
+ }
391
+ });
392
+ }
393
+
394
+ /**
395
+ * A class which provides a schema service that delegates between
396
+ * a primary schema service and one that supports legacy model
397
+ * classes as its schema source.
398
+ *
399
+ * When the primary schema service has a schema for the given
400
+ * resource, it will be used. Otherwise, the fallback schema
401
+ * service will be used.
402
+ *
403
+ * This can be used when incrementally migrating from Models to
404
+ * ReactiveResources by enabling unmigrated Models to continue to
405
+ * provide their own schema information to the application.
406
+ *
407
+ * ```ts
408
+ * import { DelegatingSchemaService } from '@warp-drive/legacy/model/migration-support';
409
+ * import { SchemaService } from '@warp-drive/core/reactive';
410
+ *
411
+ * class AppStore extends Store {
412
+ * createSchemaService() {
413
+ * const schema = new SchemaService();
414
+ * return new DelegatingSchemaService(this, schema);
415
+ * }
416
+ * }
417
+ * ```
418
+ *
419
+ * All calls to register resources, derivations, transformations, hash functions
420
+ * etc. will be delegated to the primary schema service.
421
+ *
422
+ * @class DelegatingSchemaService
423
+ * @public
424
+ */
425
+
426
+ class DelegatingSchemaService {
427
+ /** @internal */
428
+ _preferred;
429
+ /** @internal */
430
+ _secondary;
431
+ constructor(store, schema) {
432
+ this._preferred = schema;
433
+ this._secondary = buildSchema(store);
434
+ }
435
+ isDelegated(resource) {
436
+ return !this._preferred.hasResource(resource) && this._secondary.hasResource(resource);
437
+ }
438
+ resourceTypes() {
439
+ return Array.from(new Set(this._preferred.resourceTypes().concat(this._secondary.resourceTypes())));
440
+ }
441
+ hasResource(resource) {
442
+ return this._preferred.hasResource(resource) || this._secondary.hasResource(resource);
443
+ }
444
+ hasTrait(type) {
445
+ if (this._preferred.hasResource({
446
+ type
447
+ })) {
448
+ return this._preferred.hasTrait(type);
449
+ }
450
+ return this._secondary.hasTrait(type);
451
+ }
452
+ resourceHasTrait(resource, trait) {
453
+ if (this._preferred.hasResource(resource)) {
454
+ return this._preferred.resourceHasTrait(resource, trait);
455
+ }
456
+ return this._secondary.resourceHasTrait(resource, trait);
457
+ }
458
+ fields(resource) {
459
+ if (this._preferred.hasResource(resource)) {
460
+ return this._preferred.fields(resource);
461
+ }
462
+ return this._secondary.fields(resource);
463
+ }
464
+ cacheFields(resource) {
465
+ if (this._preferred.hasResource?.(resource)) {
466
+ // @ts-expect-error
467
+ return this._preferred.cacheFields?.(resource);
468
+ }
469
+
470
+ // @ts-expect-error
471
+ return this._secondary.cacheFields?.(resource);
472
+ }
473
+ transformation(field) {
474
+ return this._preferred.transformation(field);
475
+ }
476
+ hashFn(field) {
477
+ return this._preferred.hashFn(field);
478
+ }
479
+ derivation(field) {
480
+ return this._preferred.derivation(field);
481
+ }
482
+ resource(resource) {
483
+ if (this._preferred.hasResource(resource)) {
484
+ return this._preferred.resource(resource);
485
+ }
486
+ return this._secondary.resource(resource);
487
+ }
488
+ registerResources(schemas) {
489
+ this._preferred.registerResources(schemas);
490
+ }
491
+ registerResource(schema) {
492
+ this._preferred.registerResource(schema);
493
+ }
494
+ registerTransformation(transform) {
495
+ this._preferred.registerTransformation(transform);
496
+ }
497
+ registerDerivation(derivation) {
498
+ this._preferred.registerDerivation(derivation);
499
+ }
500
+ registerHashFn(hashFn) {
501
+ this._preferred.registerHashFn(hashFn);
502
+ }
503
+ CAUTION_MEGA_DANGER_ZONE_hasExtension(ext) {
504
+ return this._preferred.CAUTION_MEGA_DANGER_ZONE_hasExtension(ext);
505
+ }
506
+ CAUTION_MEGA_DANGER_ZONE_registerExtension(extension) {
507
+ this._preferred.CAUTION_MEGA_DANGER_ZONE_registerExtension(extension);
508
+ }
509
+ CAUTION_MEGA_DANGER_ZONE_resourceExtensions(resource) {
510
+ return this._preferred.CAUTION_MEGA_DANGER_ZONE_resourceExtensions(resource);
511
+ }
512
+ CAUTION_MEGA_DANGER_ZONE_objectExtensions(field, resolvedType) {
513
+ return this._preferred.CAUTION_MEGA_DANGER_ZONE_objectExtensions(field, resolvedType);
514
+ }
515
+ CAUTION_MEGA_DANGER_ZONE_arrayExtensions(field) {
516
+ return this._preferred.CAUTION_MEGA_DANGER_ZONE_arrayExtensions(field);
517
+ }
518
+
519
+ /**
520
+ * This is an internal method used to register behaviors for legacy mode.
521
+ * It is not intended for public use.
522
+ *
523
+ * We do think a generalized `kind` registration system would be useful,
524
+ * but we have not yet designed it.
525
+ *
526
+ * See https://github.com/warp-drive-data/warp-drive/issues/9534
527
+ *
528
+ * @internal
529
+ */
530
+ _registerMode(mode, kinds) {
531
+ // @ts-expect-error
532
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call
533
+ this._preferred._registerMode(mode, kinds);
534
+ }
535
+
536
+ /**
537
+ * This is an internal method used to enable legacy behaviors for legacy mode.
538
+ * It is not intended for public use.
539
+ *
540
+ * We do think a generalized `kind` registration system would be useful,
541
+ * but we have not yet designed it.
542
+ *
543
+ * See https://github.com/warp-drive-data/warp-drive/issues/9534
544
+ *
545
+ * @internal
546
+ */
547
+ _kind(mode, kind) {
548
+ // @ts-expect-error
549
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-call
550
+ return this._preferred._kind(mode, kind);
551
+ }
552
+ }
553
+ {
554
+ DelegatingSchemaService.prototype.attributesDefinitionFor = function (resource) {
555
+ if (this._preferred.hasResource(resource)) {
556
+ return this._preferred.attributesDefinitionFor(resource);
557
+ }
558
+ return this._secondary.attributesDefinitionFor(resource);
559
+ };
560
+ DelegatingSchemaService.prototype.relationshipsDefinitionFor = function (resource) {
561
+ if (this._preferred.hasResource(resource)) {
562
+ return this._preferred.relationshipsDefinitionFor(resource);
563
+ }
564
+ return this._secondary.relationshipsDefinitionFor(resource);
565
+ };
566
+ DelegatingSchemaService.prototype.doesTypeExist = function (type) {
567
+ return this._preferred.doesTypeExist?.(type) || this._secondary.doesTypeExist?.(type) || false;
568
+ };
569
+ }
570
+ export { DelegatingSchemaService, registerDerivations, withDefaults, withRestoredDeprecatedModelRequestBehaviors };