@warp-drive-mirror/utilities 5.8.0-beta.0 → 5.8.0-beta.2

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 (74) hide show
  1. package/README.md +16 -25
  2. package/declarations/-private/active-record/find-record.d.ts +5 -6
  3. package/declarations/-private/active-record/query.d.ts +2 -2
  4. package/declarations/-private/active-record/save-record.d.ts +2 -2
  5. package/declarations/-private/handlers/meta-doc.d.ts +1 -1
  6. package/declarations/-private/json-api/find-record.d.ts +37 -18
  7. package/declarations/-private/json-api/query.d.ts +3 -6
  8. package/declarations/-private/json-api/save-record.d.ts +45 -10
  9. package/declarations/-private/json-api/serialize.d.ts +15 -1
  10. package/declarations/-private/rest/find-record.d.ts +5 -8
  11. package/declarations/-private/rest/query.d.ts +2 -2
  12. package/declarations/-private/rest/save-record.d.ts +2 -2
  13. package/dist/active-record.js +2 -0
  14. package/dist/handlers.js +3 -3
  15. package/dist/json-api.js +94 -26
  16. package/dist/rest.js +2 -2
  17. package/dist/string.js +428 -1
  18. package/dist/unpkg/dev/-private.js +7 -0
  19. package/dist/unpkg/dev/active-record.js +394 -0
  20. package/dist/unpkg/dev/builder-utils-Donkk-BZ.js +22 -0
  21. package/dist/unpkg/dev/derivations.js +30 -0
  22. package/dist/unpkg/dev/handlers.js +316 -0
  23. package/dist/unpkg/dev/index.js +362 -0
  24. package/dist/unpkg/dev/inflect-BEv8WqY1.js +343 -0
  25. package/dist/unpkg/dev/json-api.js +740 -0
  26. package/dist/unpkg/dev/rest.js +392 -0
  27. package/dist/unpkg/dev/string.js +1 -0
  28. package/dist/unpkg/dev-deprecated/-private.js +7 -0
  29. package/dist/unpkg/dev-deprecated/active-record.js +394 -0
  30. package/dist/unpkg/dev-deprecated/builder-utils-Donkk-BZ.js +22 -0
  31. package/dist/unpkg/dev-deprecated/derivations.js +30 -0
  32. package/dist/unpkg/dev-deprecated/handlers.js +316 -0
  33. package/dist/unpkg/dev-deprecated/index.js +362 -0
  34. package/dist/unpkg/dev-deprecated/inflect-BEv8WqY1.js +343 -0
  35. package/dist/unpkg/dev-deprecated/json-api.js +740 -0
  36. package/dist/unpkg/dev-deprecated/rest.js +392 -0
  37. package/dist/unpkg/dev-deprecated/string.js +1 -0
  38. package/dist/unpkg/prod/-private.js +7 -0
  39. package/dist/unpkg/prod/active-record.js +366 -0
  40. package/dist/unpkg/prod/builder-utils-Donkk-BZ.js +22 -0
  41. package/dist/unpkg/prod/derivations.js +30 -0
  42. package/dist/unpkg/prod/handlers.js +305 -0
  43. package/dist/unpkg/prod/index.js +239 -0
  44. package/dist/unpkg/prod/inflect-Dh9dyEYx.js +333 -0
  45. package/dist/unpkg/prod/json-api.js +702 -0
  46. package/dist/unpkg/prod/rest.js +364 -0
  47. package/dist/unpkg/prod/string.js +1 -0
  48. package/dist/unpkg/prod-deprecated/-private.js +7 -0
  49. package/dist/unpkg/prod-deprecated/active-record.js +366 -0
  50. package/dist/unpkg/prod-deprecated/builder-utils-Donkk-BZ.js +22 -0
  51. package/dist/unpkg/prod-deprecated/derivations.js +30 -0
  52. package/dist/unpkg/prod-deprecated/handlers.js +305 -0
  53. package/dist/unpkg/prod-deprecated/index.js +239 -0
  54. package/dist/unpkg/prod-deprecated/inflect-Dh9dyEYx.js +333 -0
  55. package/dist/unpkg/prod-deprecated/json-api.js +702 -0
  56. package/dist/unpkg/prod-deprecated/rest.js +364 -0
  57. package/dist/unpkg/prod-deprecated/string.js +1 -0
  58. package/logos/README.md +2 -2
  59. package/logos/logo-yellow-slab.svg +1 -0
  60. package/logos/word-mark-black.svg +1 -0
  61. package/logos/word-mark-white.svg +1 -0
  62. package/package.json +13 -5
  63. package/logos/NCC-1701-a-blue.svg +0 -4
  64. package/logos/NCC-1701-a-gold.svg +0 -4
  65. package/logos/NCC-1701-a-gold_100.svg +0 -1
  66. package/logos/NCC-1701-a-gold_base-64.txt +0 -1
  67. package/logos/NCC-1701-a.svg +0 -4
  68. package/logos/docs-badge.svg +0 -2
  69. package/logos/ember-data-logo-dark.svg +0 -12
  70. package/logos/ember-data-logo-light.svg +0 -12
  71. package/logos/social1.png +0 -0
  72. package/logos/social2.png +0 -0
  73. package/logos/warp-drive-logo-dark.svg +0 -4
  74. package/logos/warp-drive-logo-gold.svg +0 -4
@@ -0,0 +1,364 @@
1
+ import { buildBaseURL, buildQueryParams } from './index.js';
2
+ import { p as pluralize, g as camelize } from "./inflect-Dh9dyEYx.js";
3
+ import { e as extractCacheOptions, c as copyForwardUrlOptions } from "./builder-utils-Donkk-BZ.js";
4
+ import { recordIdentifierFor } from '@warp-drive-mirror/core';
5
+
6
+ /**
7
+ * Builds request options to fetch a single resource by a known id or identifier
8
+ * configured for the url and header expectations of most REST APIs.
9
+ *
10
+ * **Basic Usage**
11
+ *
12
+ * ```ts
13
+ * import { findRecord } from '@warp-drive-mirror/utilities/rest';
14
+ *
15
+ * const data = await store.request(findRecord('person', '1'));
16
+ * ```
17
+ *
18
+ * **With Options**
19
+ *
20
+ * ```ts
21
+ * import { findRecord } from '@warp-drive-mirror/utilities/rest';
22
+ *
23
+ * const options = findRecord('person', '1', { include: ['pets', 'friends'] });
24
+ * const data = await store.request(options);
25
+ * ```
26
+ *
27
+ * **With an Identifier**
28
+ *
29
+ * ```ts
30
+ * import { findRecord } from '@warp-drive-mirror/utilities/rest';
31
+ *
32
+ * const options = findRecord({ type: 'person', id: '1' }, { include: ['pets', 'friends'] });
33
+ * const data = await store.request(options);
34
+ * ```
35
+ *
36
+ * **Supplying Options to Modify the Request Behavior**
37
+ *
38
+ * The following options are supported:
39
+ *
40
+ * - `host` - The host to use for the request, defaults to the `host` configured with `setBuildURLConfig`.
41
+ * - `namespace` - The namespace to use for the request, defaults to the `namespace` configured with `setBuildURLConfig`.
42
+ * - `resourcePath` - The resource path to use for the request, defaults to pluralizing and camelCasing the supplied type
43
+ * - `reload` - Whether to forcibly reload the request if it is already in the store, not supplying this
44
+ * option will delegate to the store's CachePolicy, defaulting to `false` if none is configured.
45
+ * - `backgroundReload` - Whether to reload the request if it is already in the store, but to also resolve the
46
+ * promise with the cached value, not supplying this option will delegate to the store's CachePolicy,
47
+ * defaulting to `false` if none is configured.
48
+ * - `urlParamsSetting` - an object containing options for how to serialize the query params (see `buildQueryParams`)
49
+ *
50
+ * ```ts
51
+ * import { findRecord } from '@warp-drive-mirror/utilities/rest';
52
+ *
53
+ * const options = findRecord('person', '1', { include: ['pets', 'friends'] }, { namespace: 'api/v2' });
54
+ * const data = await store.request(options);
55
+ * ```
56
+ *
57
+ * @public
58
+ */
59
+
60
+ function findRecord(arg1, arg2, arg3) {
61
+ const identifier = typeof arg1 === 'string' ? {
62
+ type: arg1,
63
+ id: arg2
64
+ } : arg1;
65
+ const options = (typeof arg1 === 'string' ? arg3 : arg2) || {};
66
+ const cacheOptions = extractCacheOptions(options);
67
+ const urlOptions = {
68
+ identifier,
69
+ op: 'findRecord',
70
+ resourcePath: pluralize(camelize(identifier.type))
71
+ };
72
+ copyForwardUrlOptions(urlOptions, options);
73
+ const url = buildBaseURL(urlOptions);
74
+ const headers = new Headers();
75
+ headers.append('Accept', 'application/json;charset=utf-8');
76
+ return {
77
+ url: options.include?.length ? `${url}?${buildQueryParams({
78
+ include: options.include
79
+ }, options.urlParamsSettings)}` : url,
80
+ method: 'GET',
81
+ headers,
82
+ cacheOptions,
83
+ op: 'findRecord',
84
+ records: [identifier]
85
+ };
86
+ }
87
+
88
+ /** @deprecated use {@link ReactiveDataDocument} instead */
89
+
90
+ /**
91
+ * Builds request options to query for resources, usually by a primary
92
+ * type, configured for the url and header expectations of most REST APIs.
93
+ *
94
+ * **Basic Usage**
95
+ *
96
+ * ```ts
97
+ * import { query } from '@warp-drive-mirror/utilities/rest';
98
+ *
99
+ * const data = await store.request(query('person'));
100
+ * ```
101
+ *
102
+ * **With Query Params**
103
+ *
104
+ * ```ts
105
+ * import { query } from '@warp-drive-mirror/utilities/rest';
106
+ *
107
+ * const options = query('person', { include: ['pets', 'friends'] });
108
+ * const data = await store.request(options);
109
+ * ```
110
+ *
111
+ * **Supplying Options to Modify the Request Behavior**
112
+ *
113
+ * The following options are supported:
114
+ *
115
+ * - `host` - The host to use for the request, defaults to the `host` configured with `setBuildURLConfig`.
116
+ * - `namespace` - The namespace to use for the request, defaults to the `namespace` configured with `setBuildURLConfig`.
117
+ * - `resourcePath` - The resource path to use for the request, defaults to pluralizing and camelCasing the supplied type
118
+ * - `reload` - Whether to forcibly reload the request if it is already in the store, not supplying this
119
+ * option will delegate to the store's CachePolicy, defaulting to `false` if none is configured.
120
+ * - `backgroundReload` - Whether to reload the request if it is already in the store, but to also resolve the
121
+ * promise with the cached value, not supplying this option will delegate to the store's CachePolicy,
122
+ * defaulting to `false` if none is configured.
123
+ * - `urlParamsSettings` - an object containing options for how to serialize the query params (see `buildQueryParams`)
124
+ *
125
+ * ```ts
126
+ * import { query } from '@warp-drive-mirror/utilities/rest';
127
+ *
128
+ * const options = query('person', { include: ['pets', 'friends'] }, { reload: true });
129
+ * const data = await store.request(options);
130
+ * ```
131
+ *
132
+ * @public
133
+ * @param identifier
134
+ * @param query
135
+ * @param options
136
+ */
137
+
138
+ function query(type,
139
+ // eslint-disable-next-line @typescript-eslint/no-shadow
140
+ query = {}, options = {}) {
141
+ const cacheOptions = extractCacheOptions(options);
142
+ const urlOptions = {
143
+ identifier: {
144
+ type
145
+ },
146
+ op: 'query',
147
+ resourcePath: pluralize(camelize(type))
148
+ };
149
+ copyForwardUrlOptions(urlOptions, options);
150
+ const url = buildBaseURL(urlOptions);
151
+ const headers = new Headers();
152
+ headers.append('Accept', 'application/json;charset=utf-8');
153
+ const queryString = buildQueryParams(query, options.urlParamsSettings);
154
+ return {
155
+ url: queryString ? `${url}?${queryString}` : url,
156
+ method: 'GET',
157
+ headers,
158
+ cacheOptions,
159
+ op: 'query'
160
+ };
161
+ }
162
+
163
+ /**
164
+ * Builds request options to delete record for resources,
165
+ * configured for the url, method and header expectations of REST APIs.
166
+ *
167
+ * **Basic Usage**
168
+ *
169
+ * ```ts
170
+ * import { deleteRecord } from '@warp-drive-mirror/utilities/rest';
171
+ *
172
+ * const person = store.peekRecord('person', '1');
173
+ *
174
+ * // mark record as deleted
175
+ * store.deleteRecord(person);
176
+ *
177
+ * // persist deletion
178
+ * const data = await store.request(deleteRecord(person));
179
+ * ```
180
+ *
181
+ * **Supplying Options to Modify the Request Behavior**
182
+ *
183
+ * The following options are supported:
184
+ *
185
+ * - `host` - The host to use for the request, defaults to the `host` configured with `setBuildURLConfig`.
186
+ * - `namespace` - The namespace to use for the request, defaults to the `namespace` configured with `setBuildURLConfig`.
187
+ * - `resourcePath` - The resource path to use for the request, defaults to pluralizing the supplied type
188
+ * - `reload` - Whether to forcibly reload the request if it is already in the store, not supplying this
189
+ * option will delegate to the store's CachePolicy, defaulting to `false` if none is configured.
190
+ * - `backgroundReload` - Whether to reload the request if it is already in the store, but to also resolve the
191
+ * promise with the cached value, not supplying this option will delegate to the store's CachePolicy,
192
+ * defaulting to `false` if none is configured.
193
+ * - `urlParamsSetting` - an object containing options for how to serialize the query params (see `buildQueryParams`)
194
+ *
195
+ * ```ts
196
+ * import { deleteRecord } from '@warp-drive-mirror/utilities/rest';
197
+ *
198
+ * const person = store.peekRecord('person', '1');
199
+ *
200
+ * // mark record as deleted
201
+ * store.deleteRecord(person);
202
+ *
203
+ * // persist deletion
204
+ * const options = deleteRecord(person, { namespace: 'api/v1' });
205
+ * const data = await store.request(options);
206
+ * ```
207
+ *
208
+ * @public
209
+ * @param record
210
+ * @param options
211
+ */
212
+
213
+ function deleteRecord(record, options = {}) {
214
+ const identifier = recordIdentifierFor(record);
215
+ const urlOptions = {
216
+ identifier: identifier,
217
+ op: 'deleteRecord',
218
+ resourcePath: pluralize(camelize(identifier.type))
219
+ };
220
+ copyForwardUrlOptions(urlOptions, options);
221
+ const url = buildBaseURL(urlOptions);
222
+ const headers = new Headers();
223
+ headers.append('Accept', 'application/json;charset=utf-8');
224
+ return {
225
+ url,
226
+ method: 'DELETE',
227
+ headers,
228
+ op: 'deleteRecord',
229
+ data: {
230
+ record: identifier
231
+ },
232
+ records: [identifier]
233
+ };
234
+ }
235
+
236
+ /**
237
+ * Builds request options to create new record for resources,
238
+ * configured for the url, method and header expectations of most REST APIs.
239
+ *
240
+ * **Basic Usage**
241
+ *
242
+ * ```ts
243
+ * import { createRecord } from '@warp-drive-mirror/utilities/rest';
244
+ *
245
+ * const person = store.createRecord('person', { name: 'Ted' });
246
+ * const data = await store.request(createRecord(person));
247
+ * ```
248
+ *
249
+ * **Supplying Options to Modify the Request Behavior**
250
+ *
251
+ * The following options are supported:
252
+ *
253
+ * - `host` - The host to use for the request, defaults to the `host` configured with `setBuildURLConfig`.
254
+ * - `namespace` - The namespace to use for the request, defaults to the `namespace` configured with `setBuildURLConfig`.
255
+ * - `resourcePath` - The resource path to use for the request, defaults to pluralizing the supplied type
256
+ * - `reload` - Whether to forcibly reload the request if it is already in the store, not supplying this
257
+ * option will delegate to the store's CachePolicy, defaulting to `false` if none is configured.
258
+ * - `backgroundReload` - Whether to reload the request if it is already in the store, but to also resolve the
259
+ * promise with the cached value, not supplying this option will delegate to the store's CachePolicy,
260
+ * defaulting to `false` if none is configured.
261
+ * - `urlParamsSetting` - an object containing options for how to serialize the query params (see `buildQueryParams`)
262
+ *
263
+ * ```ts
264
+ * import { createRecord } from '@warp-drive-mirror/utilities/rest';
265
+ *
266
+ * const person = store.createRecord('person', { name: 'Ted' });
267
+ * const options = createRecord(person, { namespace: 'api/v1' });
268
+ * const data = await store.request(options);
269
+ * ```
270
+ *
271
+ * @public
272
+ * @param record
273
+ * @param options
274
+ */
275
+
276
+ function createRecord(record, options = {}) {
277
+ const identifier = recordIdentifierFor(record);
278
+ const urlOptions = {
279
+ identifier: identifier,
280
+ op: 'createRecord',
281
+ resourcePath: pluralize(camelize(identifier.type))
282
+ };
283
+ copyForwardUrlOptions(urlOptions, options);
284
+ const url = buildBaseURL(urlOptions);
285
+ const headers = new Headers();
286
+ headers.append('Accept', 'application/json;charset=utf-8');
287
+ return {
288
+ url,
289
+ method: 'POST',
290
+ headers,
291
+ op: 'createRecord',
292
+ data: {
293
+ record: identifier
294
+ },
295
+ records: [identifier]
296
+ };
297
+ }
298
+
299
+ /**
300
+ * Builds request options to update existing record for resources,
301
+ * configured for the url, method and header expectations of most REST APIs.
302
+ *
303
+ * **Basic Usage**
304
+ *
305
+ * ```ts
306
+ * import { updateRecord } from '@warp-drive-mirror/utilities/rest';
307
+ *
308
+ * const person = store.peekRecord('person', '1');
309
+ * person.name = 'Chris';
310
+ * const data = await store.request(updateRecord(person));
311
+ * ```
312
+ *
313
+ * **Supplying Options to Modify the Request Behavior**
314
+ *
315
+ * The following options are supported:
316
+ *
317
+ * - `patch` - Allows caller to specify whether to use a PATCH request instead of a PUT request, defaults to `false`.
318
+ * - `host` - The host to use for the request, defaults to the `host` configured with `setBuildURLConfig`.
319
+ * - `namespace` - The namespace to use for the request, defaults to the `namespace` configured with `setBuildURLConfig`.
320
+ * - `resourcePath` - The resource path to use for the request, defaults to pluralizing the supplied type
321
+ * - `reload` - Whether to forcibly reload the request if it is already in the store, not supplying this
322
+ * option will delegate to the store's CachePolicy, defaulting to `false` if none is configured.
323
+ * - `backgroundReload` - Whether to reload the request if it is already in the store, but to also resolve the
324
+ * promise with the cached value, not supplying this option will delegate to the store's CachePolicy,
325
+ * defaulting to `false` if none is configured.
326
+ * - `urlParamsSetting` - an object containing options for how to serialize the query params (see `buildQueryParams`)
327
+ *
328
+ * ```ts
329
+ * import { updateRecord } from '@warp-drive-mirror/utilities/rest';
330
+ *
331
+ * const person = store.peekRecord('person', '1');
332
+ * person.name = 'Chris';
333
+ * const options = updateRecord(person, { patch: true });
334
+ * const data = await store.request(options);
335
+ * ```
336
+ *
337
+ * @public
338
+ * @param record
339
+ * @param options
340
+ */
341
+
342
+ function updateRecord(record, options = {}) {
343
+ const identifier = recordIdentifierFor(record);
344
+ const urlOptions = {
345
+ identifier: identifier,
346
+ op: 'updateRecord',
347
+ resourcePath: pluralize(camelize(identifier.type))
348
+ };
349
+ copyForwardUrlOptions(urlOptions, options);
350
+ const url = buildBaseURL(urlOptions);
351
+ const headers = new Headers();
352
+ headers.append('Accept', 'application/json;charset=utf-8');
353
+ return {
354
+ url,
355
+ method: options.patch ? 'PATCH' : 'PUT',
356
+ headers,
357
+ op: 'updateRecord',
358
+ data: {
359
+ record: identifier
360
+ },
361
+ records: [identifier]
362
+ };
363
+ }
364
+ export { createRecord, deleteRecord, findRecord, query, updateRecord };
@@ -0,0 +1 @@
1
+ export { g as camelize, h as capitalize, d as clear, e as clearRules, f as dasherize, i as irregular, l as loadIrregular, c as loadUncountable, b as plural, p as pluralize, r as resetToDefaults, k as setMaxLRUCacheSize, a as singular, s as singularize, u as uncountable, j as underscore } from "./inflect-Dh9dyEYx.js";
@@ -0,0 +1,7 @@
1
+ const defaultRules = {
2
+ plurals: [[/$/, 's'], [/s$/i, 's'], [/^(ax|test)is$/i, '$1es'], [/(octop|vir)us$/i, '$1i'], [/(octop|vir)i$/i, '$1i'], [/(alias|status|bonus)$/i, '$1es'], [/(bu)s$/i, '$1ses'], [/(buffal|tomat)o$/i, '$1oes'], [/([ti])um$/i, '$1a'], [/([ti])a$/i, '$1a'], [/sis$/i, 'ses'], [/(?:([^f])fe|([lr])f)$/i, '$1$2ves'], [/(hive)$/i, '$1s'], [/([^aeiouy]|qu)y$/i, '$1ies'], [/(x|ch|ss|sh)$/i, '$1es'], [/(matr|vert|ind)(?:ix|ex)$/i, '$1ices'], [/^(m|l)ouse$/i, '$1ice'], [/^(m|l)ice$/i, '$1ice'], [/^(ox)$/i, '$1en'], [/^(oxen)$/i, '$1'], [/(quiz)$/i, '$1zes']],
3
+ singular: [[/s$/i, ''], [/(ss)$/i, '$1'], [/(n)ews$/i, '$1ews'], [/([ti])a$/i, '$1um'], [/((a)naly|(b)a|(d)iagno|(p)arenthe|(p)rogno|(s)ynop|(t)he)(sis|ses)$/i, '$1sis'], [/(^analy)(sis|ses)$/i, '$1sis'], [/([^f])ves$/i, '$1fe'], [/(hive)s$/i, '$1'], [/(tive)s$/i, '$1'], [/([lr])ves$/i, '$1f'], [/([^aeiouy]|qu)ies$/i, '$1y'], [/(s)eries$/i, '$1eries'], [/(m)ovies$/i, '$1ovie'], [/(x|ch|ss|sh)es$/i, '$1'], [/^(m|l)ice$/i, '$1ouse'], [/(bus)(es)?$/i, '$1'], [/(o)es$/i, '$1'], [/(shoe)s$/i, '$1'], [/(cris|test)(is|es)$/i, '$1is'], [/^(a)x[ie]s$/i, '$1xis'], [/(octop|vir)(us|i)$/i, '$1us'], [/(alias|status|bonus)(es)?$/i, '$1'], [/^(ox)en/i, '$1'], [/(vert|ind)ices$/i, '$1ex'], [/(matr)ices$/i, '$1ix'], [/(quiz)zes$/i, '$1'], [/(database)s$/i, '$1']],
4
+ irregularPairs: [['person', 'people'], ['man', 'men'], ['child', 'children'], ['sex', 'sexes'], ['move', 'moves'], ['cow', 'kine'], ['zombie', 'zombies']],
5
+ uncountable: ['equipment', 'information', 'rice', 'money', 'species', 'series', 'fish', 'sheep', 'jeans', 'police']
6
+ };
7
+ export { defaultRules as InflectionRuleDefaults };