@wordpress/core-data 4.2.0-next.e230fbab09.0 → 4.3.0

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 (118) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/README.md +41 -8
  3. package/build/actions.js +61 -41
  4. package/build/actions.js.map +1 -1
  5. package/build/entities.js +36 -23
  6. package/build/entities.js.map +1 -1
  7. package/build/entity-provider.js +46 -44
  8. package/build/entity-provider.js.map +1 -1
  9. package/build/entity-types/{base-entity-types.js → base-entity-records.js} +9 -9
  10. package/build/entity-types/base-entity-records.js.map +1 -0
  11. package/build/fetch/__experimental-fetch-link-suggestions.js +1 -1
  12. package/build/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
  13. package/build/fetch/__experimental-fetch-url-data.js +1 -1
  14. package/build/fetch/__experimental-fetch-url-data.js.map +1 -1
  15. package/build/hooks/use-entity-record.js +15 -5
  16. package/build/hooks/use-entity-record.js.map +1 -1
  17. package/build/hooks/use-entity-records.js +17 -5
  18. package/build/hooks/use-entity-records.js.map +1 -1
  19. package/build/index.js +9 -21
  20. package/build/index.js.map +1 -1
  21. package/build/queried-data/actions.js +4 -4
  22. package/build/queried-data/actions.js.map +1 -1
  23. package/build/queried-data/get-query-parts.js +7 -3
  24. package/build/queried-data/get-query-parts.js.map +1 -1
  25. package/build/queried-data/reducer.js +8 -6
  26. package/build/queried-data/reducer.js.map +1 -1
  27. package/build/reducer.js +16 -16
  28. package/build/reducer.js.map +1 -1
  29. package/build/resolvers.js +17 -23
  30. package/build/resolvers.js.map +1 -1
  31. package/build/selectors.js +92 -51
  32. package/build/selectors.js.map +1 -1
  33. package/build/utils/conservative-map-item.js +1 -1
  34. package/build/utils/conservative-map-item.js.map +1 -1
  35. package/build/utils/is-raw-attribute.js +1 -1
  36. package/build/utils/is-raw-attribute.js.map +1 -1
  37. package/build-module/actions.js +62 -42
  38. package/build-module/actions.js.map +1 -1
  39. package/build-module/entities.js +32 -19
  40. package/build-module/entities.js.map +1 -1
  41. package/build-module/entity-provider.js +47 -45
  42. package/build-module/entity-provider.js.map +1 -1
  43. package/build-module/entity-types/{base-entity-types.js → base-entity-records.js} +7 -7
  44. package/build-module/entity-types/base-entity-records.js.map +1 -0
  45. package/build-module/fetch/__experimental-fetch-link-suggestions.js +1 -1
  46. package/build-module/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
  47. package/build-module/fetch/__experimental-fetch-url-data.js +1 -1
  48. package/build-module/fetch/__experimental-fetch-url-data.js.map +1 -1
  49. package/build-module/hooks/use-entity-record.js +15 -5
  50. package/build-module/hooks/use-entity-record.js.map +1 -1
  51. package/build-module/hooks/use-entity-records.js +17 -5
  52. package/build-module/hooks/use-entity-records.js.map +1 -1
  53. package/build-module/index.js +10 -22
  54. package/build-module/index.js.map +1 -1
  55. package/build-module/queried-data/actions.js +4 -4
  56. package/build-module/queried-data/actions.js.map +1 -1
  57. package/build-module/queried-data/get-query-parts.js +7 -3
  58. package/build-module/queried-data/get-query-parts.js.map +1 -1
  59. package/build-module/queried-data/reducer.js +8 -6
  60. package/build-module/queried-data/reducer.js.map +1 -1
  61. package/build-module/reducer.js +17 -17
  62. package/build-module/reducer.js.map +1 -1
  63. package/build-module/resolvers.js +18 -24
  64. package/build-module/resolvers.js.map +1 -1
  65. package/build-module/selectors.js +88 -51
  66. package/build-module/selectors.js.map +1 -1
  67. package/build-module/utils/conservative-map-item.js +1 -1
  68. package/build-module/utils/conservative-map-item.js.map +1 -1
  69. package/build-module/utils/is-raw-attribute.js +1 -1
  70. package/build-module/utils/is-raw-attribute.js.map +1 -1
  71. package/package.json +11 -11
  72. package/src/actions.js +62 -42
  73. package/src/entities.js +43 -17
  74. package/src/entity-provider.js +50 -44
  75. package/src/entity-types/attachment.ts +5 -5
  76. package/src/entity-types/{base-entity-types.ts → base-entity-records.ts} +5 -5
  77. package/src/entity-types/comment.ts +5 -5
  78. package/src/entity-types/helpers.ts +1 -1
  79. package/src/entity-types/index.ts +4 -4
  80. package/src/entity-types/menu-location.ts +5 -5
  81. package/src/entity-types/nav-menu-item.ts +10 -5
  82. package/src/entity-types/nav-menu.ts +5 -5
  83. package/src/entity-types/navigation-area.ts +5 -5
  84. package/src/entity-types/page.ts +5 -5
  85. package/src/entity-types/plugin.ts +10 -5
  86. package/src/entity-types/post.ts +5 -5
  87. package/src/entity-types/settings.ts +10 -5
  88. package/src/entity-types/sidebar.ts +6 -7
  89. package/src/entity-types/taxonomy.ts +5 -5
  90. package/src/entity-types/theme.ts +5 -5
  91. package/src/entity-types/type.ts +5 -5
  92. package/src/entity-types/user.ts +10 -5
  93. package/src/entity-types/widget-type.ts +5 -5
  94. package/src/entity-types/widget.ts +5 -5
  95. package/src/entity-types/wp-template-part.ts +5 -5
  96. package/src/entity-types/wp-template.ts +5 -5
  97. package/src/fetch/__experimental-fetch-link-suggestions.js +1 -1
  98. package/src/fetch/__experimental-fetch-url-data.js +1 -0
  99. package/src/hooks/use-entity-record.ts +19 -8
  100. package/src/hooks/use-entity-records.ts +26 -9
  101. package/src/index.js +10 -15
  102. package/src/locks/test/selectors.js +4 -4
  103. package/src/queried-data/actions.js +4 -4
  104. package/src/queried-data/get-query-parts.js +5 -5
  105. package/src/queried-data/reducer.js +6 -6
  106. package/src/reducer.js +17 -17
  107. package/src/resolvers.js +25 -30
  108. package/src/selectors.js +92 -53
  109. package/src/test/actions.js +138 -33
  110. package/src/test/entities.js +11 -11
  111. package/src/test/reducer.js +4 -4
  112. package/src/test/resolvers.js +5 -5
  113. package/src/test/selectors.js +22 -22
  114. package/src/utils/conservative-map-item.js +1 -1
  115. package/src/utils/is-raw-attribute.js +1 -1
  116. package/src/utils/test/is-raw-attribute.js +4 -4
  117. package/build/entity-types/base-entity-types.js.map +0 -1
  118. package/build-module/entity-types/base-entity-types.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/core-data/src/utils/is-raw-attribute.js"],"names":["isRawAttribute","entity","attribute","rawAttributes","includes"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACe,SAASA,cAAT,CAAyBC,MAAzB,EAAiCC,SAAjC,EAA6C;AAC3D,SAAO,CAAED,MAAM,CAACE,aAAP,IAAwB,EAA1B,EAA+BC,QAA/B,CAAyCF,SAAzC,CAAP;AACA","sourcesContent":["/**\n * Checks whether the attribute is a \"raw\" attribute or not.\n *\n * @param {Object} entity Entity data.\n * @param {string} attribute Attribute name.\n *\n * @return {boolean} Is the attribute raw\n */\nexport default function isRawAttribute( entity, attribute ) {\n\treturn ( entity.rawAttributes || [] ).includes( attribute );\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/core-data/src/utils/is-raw-attribute.js"],"names":["isRawAttribute","entity","attribute","rawAttributes","includes"],"mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACe,SAASA,cAAT,CAAyBC,MAAzB,EAAiCC,SAAjC,EAA6C;AAC3D,SAAO,CAAED,MAAM,CAACE,aAAP,IAAwB,EAA1B,EAA+BC,QAA/B,CAAyCF,SAAzC,CAAP;AACA","sourcesContent":["/**\n * Checks whether the attribute is a \"raw\" attribute or not.\n *\n * @param {Object} entity Entity record.\n * @param {string} attribute Attribute name.\n *\n * @return {boolean} Is the attribute raw\n */\nexport default function isRawAttribute( entity, attribute ) {\n\treturn ( entity.rawAttributes || [] ).includes( attribute );\n}\n"]}
@@ -15,7 +15,7 @@ import deprecated from '@wordpress/deprecated';
15
15
  */
16
16
 
17
17
  import { receiveItems, removeItems, receiveQueriedItems } from './queried-data';
18
- import { getKindEntities, DEFAULT_ENTITY_KEY } from './entities';
18
+ import { getOrLoadEntitiesConfig, DEFAULT_ENTITY_KEY } from './entities';
19
19
  import { createBatch } from './batch';
20
20
  import { STORE_NAME } from './name';
21
21
  /**
@@ -65,8 +65,8 @@ export function addEntities(entities) {
65
65
  /**
66
66
  * Returns an action object used in signalling that entity records have been received.
67
67
  *
68
- * @param {string} kind Kind of the received entity.
69
- * @param {string} name Name of the received entity.
68
+ * @param {string} kind Kind of the received entity record.
69
+ * @param {string} name Name of the received entity record.
70
70
  * @param {Array|Object} records Records received.
71
71
  * @param {?Object} query Query Object.
72
72
  * @param {?boolean} invalidateCache Should invalidate query caches.
@@ -196,38 +196,41 @@ export function receiveEmbedPreview(url, preview) {
196
196
  /**
197
197
  * Action triggered to delete an entity record.
198
198
  *
199
- * @param {string} kind Kind of the deleted entity.
200
- * @param {string} name Name of the deleted entity.
201
- * @param {string} recordId Record ID of the deleted entity.
202
- * @param {?Object} query Special query parameters for the
203
- * DELETE API call.
204
- * @param {Object} [options] Delete options.
205
- * @param {Function} [options.__unstableFetch] Internal use only. Function to
206
- * call instead of `apiFetch()`.
207
- * Must return a promise.
199
+ * @param {string} kind Kind of the deleted entity.
200
+ * @param {string} name Name of the deleted entity.
201
+ * @param {string} recordId Record ID of the deleted entity.
202
+ * @param {?Object} query Special query parameters for the
203
+ * DELETE API call.
204
+ * @param {Object} [options] Delete options.
205
+ * @param {Function} [options.__unstableFetch] Internal use only. Function to
206
+ * call instead of `apiFetch()`.
207
+ * Must return a promise.
208
+ * @param {boolean} [options.throwOnError=false] If false, this action suppresses all
209
+ * the exceptions. Defaults to false.
208
210
  */
209
211
 
210
212
  export const deleteEntityRecord = function (kind, name, recordId, query) {
211
213
  let {
212
- __unstableFetch = apiFetch
214
+ __unstableFetch = apiFetch,
215
+ throwOnError = false
213
216
  } = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
214
217
  return async _ref => {
215
218
  let {
216
219
  dispatch
217
220
  } = _ref;
218
- const entities = await dispatch(getKindEntities(kind));
219
- const entity = find(entities, {
221
+ const configs = await dispatch(getOrLoadEntitiesConfig(kind));
222
+ const entityConfig = find(configs, {
220
223
  kind,
221
224
  name
222
225
  });
223
226
  let error;
224
227
  let deletedRecord = false;
225
228
 
226
- if (!entity || entity !== null && entity !== void 0 && entity.__experimentalNoFetch) {
229
+ if (!entityConfig || entityConfig !== null && entityConfig !== void 0 && entityConfig.__experimentalNoFetch) {
227
230
  return;
228
231
  }
229
232
 
230
- const lock = await dispatch.__unstableAcquireStoreLock(STORE_NAME, ['entities', 'data', kind, name, recordId], {
233
+ const lock = await dispatch.__unstableAcquireStoreLock(STORE_NAME, ['entities', 'records', kind, name, recordId], {
231
234
  exclusive: true
232
235
  });
233
236
 
@@ -238,9 +241,10 @@ export const deleteEntityRecord = function (kind, name, recordId, query) {
238
241
  name,
239
242
  recordId
240
243
  });
244
+ let hasError = false;
241
245
 
242
246
  try {
243
- let path = `${entity.baseURL}/${recordId}`;
247
+ let path = `${entityConfig.baseURL}/${recordId}`;
244
248
 
245
249
  if (query) {
246
250
  path = addQueryArgs(path, query);
@@ -252,6 +256,7 @@ export const deleteEntityRecord = function (kind, name, recordId, query) {
252
256
  });
253
257
  await dispatch(removeItems(kind, name, recordId, true));
254
258
  } catch (_error) {
259
+ hasError = true;
255
260
  error = _error;
256
261
  }
257
262
 
@@ -262,6 +267,11 @@ export const deleteEntityRecord = function (kind, name, recordId, query) {
262
267
  recordId,
263
268
  error
264
269
  });
270
+
271
+ if (hasError && throwOnError) {
272
+ throw error;
273
+ }
274
+
265
275
  return deletedRecord;
266
276
  } finally {
267
277
  dispatch.__unstableReleaseStoreLock(lock);
@@ -289,16 +299,16 @@ export const editEntityRecord = function (kind, name, recordId, edits) {
289
299
  select,
290
300
  dispatch
291
301
  } = _ref2;
292
- const entity = select.getEntity(kind, name);
302
+ const entityConfig = select.getEntityConfig(kind, name);
293
303
 
294
- if (!entity) {
304
+ if (!entityConfig) {
295
305
  throw new Error(`The entity being edited (${kind}, ${name}) does not have a loaded config.`);
296
306
  }
297
307
 
298
308
  const {
299
309
  transientEdits = {},
300
310
  mergedEdits = {}
301
- } = entity;
311
+ } = entityConfig;
302
312
  const record = select.getRawEntityRecord(kind, name, recordId);
303
313
  const editedRecord = select.getEditedEntityRecord(kind, name, recordId);
304
314
  const edit = {
@@ -395,20 +405,23 @@ export function __unstableCreateUndoLevel() {
395
405
  /**
396
406
  * Action triggered to save an entity record.
397
407
  *
398
- * @param {string} kind Kind of the received entity.
399
- * @param {string} name Name of the received entity.
400
- * @param {Object} record Record to be saved.
401
- * @param {Object} options Saving options.
402
- * @param {boolean} [options.isAutosave=false] Whether this is an autosave.
403
- * @param {Function} [options.__unstableFetch] Internal use only. Function to
404
- * call instead of `apiFetch()`.
405
- * Must return a promise.
408
+ * @param {string} kind Kind of the received entity.
409
+ * @param {string} name Name of the received entity.
410
+ * @param {Object} record Record to be saved.
411
+ * @param {Object} options Saving options.
412
+ * @param {boolean} [options.isAutosave=false] Whether this is an autosave.
413
+ * @param {Function} [options.__unstableFetch] Internal use only. Function to
414
+ * call instead of `apiFetch()`.
415
+ * Must return a promise.
416
+ * @param {boolean} [options.throwOnError=false] If false, this action suppresses all
417
+ * the exceptions. Defaults to false.
406
418
  */
407
419
 
408
420
  export const saveEntityRecord = function (kind, name, record) {
409
421
  let {
410
422
  isAutosave = false,
411
- __unstableFetch = apiFetch
423
+ __unstableFetch = apiFetch,
424
+ throwOnError = false
412
425
  } = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
413
426
  return async _ref5 => {
414
427
  let {
@@ -416,19 +429,19 @@ export const saveEntityRecord = function (kind, name, record) {
416
429
  resolveSelect,
417
430
  dispatch
418
431
  } = _ref5;
419
- const entities = await dispatch(getKindEntities(kind));
420
- const entity = find(entities, {
432
+ const configs = await dispatch(getOrLoadEntitiesConfig(kind));
433
+ const entityConfig = find(configs, {
421
434
  kind,
422
435
  name
423
436
  });
424
437
 
425
- if (!entity || entity !== null && entity !== void 0 && entity.__experimentalNoFetch) {
438
+ if (!entityConfig || entityConfig !== null && entityConfig !== void 0 && entityConfig.__experimentalNoFetch) {
426
439
  return;
427
440
  }
428
441
 
429
- const entityIdKey = entity.key || DEFAULT_ENTITY_KEY;
442
+ const entityIdKey = entityConfig.key || DEFAULT_ENTITY_KEY;
430
443
  const recordId = record[entityIdKey];
431
- const lock = await dispatch.__unstableAcquireStoreLock(STORE_NAME, ['entities', 'data', kind, name, recordId || uuid()], {
444
+ const lock = await dispatch.__unstableAcquireStoreLock(STORE_NAME, ['entities', 'records', kind, name, recordId || uuid()], {
432
445
  exclusive: true
433
446
  });
434
447
 
@@ -456,9 +469,10 @@ export const saveEntityRecord = function (kind, name, record) {
456
469
  });
457
470
  let updatedRecord;
458
471
  let error;
472
+ let hasError = false;
459
473
 
460
474
  try {
461
- const path = `${entity.baseURL}${recordId ? '/' + recordId : ''}`;
475
+ const path = `${entityConfig.baseURL}${recordId ? '/' + recordId : ''}`;
462
476
  const persistedRecord = select.getRawEntityRecord(kind, name, recordId);
463
477
 
464
478
  if (isAutosave) {
@@ -521,9 +535,9 @@ export const saveEntityRecord = function (kind, name, record) {
521
535
  } else {
522
536
  let edits = record;
523
537
 
524
- if (entity.__unstablePrePersist) {
538
+ if (entityConfig.__unstablePrePersist) {
525
539
  edits = { ...edits,
526
- ...entity.__unstablePrePersist(persistedRecord, edits)
540
+ ...entityConfig.__unstablePrePersist(persistedRecord, edits)
527
541
  };
528
542
  }
529
543
 
@@ -535,6 +549,7 @@ export const saveEntityRecord = function (kind, name, record) {
535
549
  dispatch.receiveEntityRecords(kind, name, updatedRecord, undefined, true, edits);
536
550
  }
537
551
  } catch (_error) {
552
+ hasError = true;
538
553
  error = _error;
539
554
  }
540
555
 
@@ -546,6 +561,11 @@ export const saveEntityRecord = function (kind, name, record) {
546
561
  error,
547
562
  isAutosave
548
563
  });
564
+
565
+ if (hasError && throwOnError) {
566
+ throw error;
567
+ }
568
+
549
569
  return updatedRecord;
550
570
  } finally {
551
571
  dispatch.__unstableReleaseStoreLock(lock);
@@ -623,17 +643,17 @@ export const saveEditedEntityRecord = (kind, name, recordId, options) => async _
623
643
  return;
624
644
  }
625
645
 
626
- const entities = await dispatch(getKindEntities(kind));
627
- const entity = find(entities, {
646
+ const configs = await dispatch(getOrLoadEntitiesConfig(kind));
647
+ const entityConfig = find(configs, {
628
648
  kind,
629
649
  name
630
650
  });
631
651
 
632
- if (!entity) {
652
+ if (!entityConfig) {
633
653
  return;
634
654
  }
635
655
 
636
- const entityIdKey = entity.key || DEFAULT_ENTITY_KEY;
656
+ const entityIdKey = entityConfig.key || DEFAULT_ENTITY_KEY;
637
657
  const edits = select.getEntityRecordNonTransientEdits(kind, name, recordId);
638
658
  const record = {
639
659
  [entityIdKey]: recordId,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/core-data/src/actions.js"],"names":["castArray","isEqual","find","v4","uuid","apiFetch","addQueryArgs","deprecated","receiveItems","removeItems","receiveQueriedItems","getKindEntities","DEFAULT_ENTITY_KEY","createBatch","STORE_NAME","receiveUserQuery","queryID","users","type","receiveCurrentUser","currentUser","addEntities","entities","receiveEntityRecords","kind","name","records","query","invalidateCache","edits","map","record","status","title","action","receiveCurrentTheme","currentTheme","__experimentalReceiveCurrentGlobalStylesId","currentGlobalStylesId","id","__experimentalReceiveThemeBaseGlobalStyles","stylesheet","globalStyles","__experimentalReceiveThemeGlobalStyleVariations","variations","receiveThemeSupports","since","receiveEmbedPreview","url","preview","deleteEntityRecord","recordId","__unstableFetch","dispatch","entity","error","deletedRecord","__experimentalNoFetch","lock","__unstableAcquireStoreLock","exclusive","path","baseURL","method","_error","__unstableReleaseStoreLock","editEntityRecord","options","select","getEntity","Error","transientEdits","mergedEdits","getRawEntityRecord","editedRecord","getEditedEntityRecord","edit","Object","keys","reduce","acc","key","recordValue","editedRecordValue","value","undefined","meta","undo","undoIgnore","undoEdit","getUndoEdit","isUndo","redo","redoEdit","getRedoEdit","isRedo","__unstableCreateUndoLevel","saveEntityRecord","isAutosave","resolveSelect","entityIdKey","entries","evaluatedValue","updatedRecord","persistedRecord","getCurrentUser","currentUserId","autosavePost","getAutosave","data","includes","newRecord","receiveAutosaves","__unstablePrePersist","__experimentalBatch","requests","batch","api","add","saveEditedEntityRecord","resultPromises","request","results","Promise","all","run","hasEditsForEntityRecord","getEntityRecordNonTransientEdits","__experimentalSaveSpecifiedEntityEdits","itemsToSave","editsToSave","some","item","receiveUploadPermissions","hasUploadPermissions","alternative","receiveUserPermission","isAllowed","postId","autosaves"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,SAAT,EAAoBC,OAApB,EAA6BC,IAA7B,QAAyC,QAAzC;AACA,SAASC,EAAE,IAAIC,IAAf,QAA2B,MAA3B;AAEA;AACA;AACA;;AACA,OAAOC,QAAP,MAAqB,sBAArB;AACA,SAASC,YAAT,QAA6B,gBAA7B;AACA,OAAOC,UAAP,MAAuB,uBAAvB;AAEA;AACA;AACA;;AACA,SAASC,YAAT,EAAuBC,WAAvB,EAAoCC,mBAApC,QAA+D,gBAA/D;AACA,SAASC,eAAT,EAA0BC,kBAA1B,QAAoD,YAApD;AACA,SAASC,WAAT,QAA4B,SAA5B;AACA,SAASC,UAAT,QAA2B,QAA3B;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,gBAAT,CAA2BC,OAA3B,EAAoCC,KAApC,EAA4C;AAClD,SAAO;AACNC,IAAAA,IAAI,EAAE,oBADA;AAEND,IAAAA,KAAK,EAAEjB,SAAS,CAAEiB,KAAF,CAFV;AAGND,IAAAA;AAHM,GAAP;AAKA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASG,kBAAT,CAA6BC,WAA7B,EAA2C;AACjD,SAAO;AACNF,IAAAA,IAAI,EAAE,sBADA;AAENE,IAAAA;AAFM,GAAP;AAIA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,WAAT,CAAsBC,QAAtB,EAAiC;AACvC,SAAO;AACNJ,IAAAA,IAAI,EAAE,cADA;AAENI,IAAAA;AAFM,GAAP;AAIA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,oBAAT,CACNC,IADM,EAENC,IAFM,EAGNC,OAHM,EAINC,KAJM,EAOL;AAAA,MAFDC,eAEC,uEAFiB,KAEjB;AAAA,MADDC,KACC;;AACD;AACA;AACA,MAAKL,IAAI,KAAK,UAAd,EAA2B;AAC1BE,IAAAA,OAAO,GAAG1B,SAAS,CAAE0B,OAAF,CAAT,CAAqBI,GAArB,CAA4BC,MAAF,IACnCA,MAAM,CAACC,MAAP,KAAkB,YAAlB,GAAiC,EAAE,GAAGD,MAAL;AAAaE,MAAAA,KAAK,EAAE;AAApB,KAAjC,GAA4DF,MADnD,CAAV;AAGA;;AACD,MAAIG,MAAJ;;AACA,MAAKP,KAAL,EAAa;AACZO,IAAAA,MAAM,GAAGxB,mBAAmB,CAAEgB,OAAF,EAAWC,KAAX,EAAkBE,KAAlB,CAA5B;AACA,GAFD,MAEO;AACNK,IAAAA,MAAM,GAAG1B,YAAY,CAAEkB,OAAF,EAAWG,KAAX,CAArB;AACA;;AAED,SAAO,EACN,GAAGK,MADG;AAENV,IAAAA,IAFM;AAGNC,IAAAA,IAHM;AAING,IAAAA;AAJM,GAAP;AAMA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASO,mBAAT,CAA8BC,YAA9B,EAA6C;AACnD,SAAO;AACNlB,IAAAA,IAAI,EAAE,uBADA;AAENkB,IAAAA;AAFM,GAAP;AAIA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,0CAAT,CACNC,qBADM,EAEL;AACD,SAAO;AACNpB,IAAAA,IAAI,EAAE,kCADA;AAENqB,IAAAA,EAAE,EAAED;AAFE,GAAP;AAIA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASE,0CAAT,CACNC,UADM,EAENC,YAFM,EAGL;AACD,SAAO;AACNxB,IAAAA,IAAI,EAAE,6BADA;AAENuB,IAAAA,UAFM;AAGNC,IAAAA;AAHM,GAAP;AAKA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,+CAAT,CACNF,UADM,EAENG,UAFM,EAGL;AACD,SAAO;AACN1B,IAAAA,IAAI,EAAE,uCADA;AAENuB,IAAAA,UAFM;AAGNG,IAAAA;AAHM,GAAP;AAKA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,oBAAT,GAAgC;AACtCtC,EAAAA,UAAU,CAAE,iDAAF,EAAqD;AAC9DuC,IAAAA,KAAK,EAAE;AADuD,GAArD,CAAV;AAIA,SAAO;AACN5B,IAAAA,IAAI,EAAE;AADA,GAAP;AAGA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAAS6B,mBAAT,CAA8BC,GAA9B,EAAmCC,OAAnC,EAA6C;AACnD,SAAO;AACN/B,IAAAA,IAAI,EAAE,uBADA;AAEN8B,IAAAA,GAFM;AAGNC,IAAAA;AAHM,GAAP;AAKA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMC,kBAAkB,GAAG,UACjC1B,IADiC,EAEjCC,IAFiC,EAGjC0B,QAHiC,EAIjCxB,KAJiC;AAAA,MAKjC;AAAEyB,IAAAA,eAAe,GAAG/C;AAApB,GALiC,uEAKA,EALA;AAAA,SAM7B,cAA0B;AAAA,QAAlB;AAAEgD,MAAAA;AAAF,KAAkB;AAC9B,UAAM/B,QAAQ,GAAG,MAAM+B,QAAQ,CAAE1C,eAAe,CAAEa,IAAF,CAAjB,CAA/B;AACA,UAAM8B,MAAM,GAAGpD,IAAI,CAAEoB,QAAF,EAAY;AAAEE,MAAAA,IAAF;AAAQC,MAAAA;AAAR,KAAZ,CAAnB;AACA,QAAI8B,KAAJ;AACA,QAAIC,aAAa,GAAG,KAApB;;AACA,QAAK,CAAEF,MAAF,IAAYA,MAAZ,aAAYA,MAAZ,eAAYA,MAAM,CAAEG,qBAAzB,EAAiD;AAChD;AACA;;AAED,UAAMC,IAAI,GAAG,MAAML,QAAQ,CAACM,0BAAT,CAClB7C,UADkB,EAElB,CAAE,UAAF,EAAc,MAAd,EAAsBU,IAAtB,EAA4BC,IAA5B,EAAkC0B,QAAlC,CAFkB,EAGlB;AAAES,MAAAA,SAAS,EAAE;AAAb,KAHkB,CAAnB;;AAMA,QAAI;AACHP,MAAAA,QAAQ,CAAE;AACTnC,QAAAA,IAAI,EAAE,4BADG;AAETM,QAAAA,IAFS;AAGTC,QAAAA,IAHS;AAIT0B,QAAAA;AAJS,OAAF,CAAR;;AAOA,UAAI;AACH,YAAIU,IAAI,GAAI,GAAGP,MAAM,CAACQ,OAAS,IAAIX,QAAU,EAA7C;;AAEA,YAAKxB,KAAL,EAAa;AACZkC,UAAAA,IAAI,GAAGvD,YAAY,CAAEuD,IAAF,EAAQlC,KAAR,CAAnB;AACA;;AAED6B,QAAAA,aAAa,GAAG,MAAMJ,eAAe,CAAE;AACtCS,UAAAA,IADsC;AAEtCE,UAAAA,MAAM,EAAE;AAF8B,SAAF,CAArC;AAKA,cAAMV,QAAQ,CAAE5C,WAAW,CAAEe,IAAF,EAAQC,IAAR,EAAc0B,QAAd,EAAwB,IAAxB,CAAb,CAAd;AACA,OAbD,CAaE,OAAQa,MAAR,EAAiB;AAClBT,QAAAA,KAAK,GAAGS,MAAR;AACA;;AAEDX,MAAAA,QAAQ,CAAE;AACTnC,QAAAA,IAAI,EAAE,6BADG;AAETM,QAAAA,IAFS;AAGTC,QAAAA,IAHS;AAIT0B,QAAAA,QAJS;AAKTI,QAAAA;AALS,OAAF,CAAR;AAQA,aAAOC,aAAP;AACA,KAlCD,SAkCU;AACTH,MAAAA,QAAQ,CAACY,0BAAT,CAAqCP,IAArC;AACA;AACD,GA1DiC;AAAA,CAA3B;AA4DP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMQ,gBAAgB,GAAG,UAC/B1C,IAD+B,EAE/BC,IAF+B,EAG/B0B,QAH+B,EAI/BtB,KAJ+B;AAAA,MAK/BsC,OAL+B,uEAKrB,EALqB;AAAA,SAM3B,SAA4B;AAAA,QAA1B;AAAEC,MAAAA,MAAF;AAAUf,MAAAA;AAAV,KAA0B;AAChC,UAAMC,MAAM,GAAGc,MAAM,CAACC,SAAP,CAAkB7C,IAAlB,EAAwBC,IAAxB,CAAf;;AACA,QAAK,CAAE6B,MAAP,EAAgB;AACf,YAAM,IAAIgB,KAAJ,CACJ,4BAA4B9C,IAAM,KAAKC,IAAM,kCADzC,CAAN;AAGA;;AACD,UAAM;AAAE8C,MAAAA,cAAc,GAAG,EAAnB;AAAuBC,MAAAA,WAAW,GAAG;AAArC,QAA4ClB,MAAlD;AACA,UAAMvB,MAAM,GAAGqC,MAAM,CAACK,kBAAP,CAA2BjD,IAA3B,EAAiCC,IAAjC,EAAuC0B,QAAvC,CAAf;AACA,UAAMuB,YAAY,GAAGN,MAAM,CAACO,qBAAP,CAA8BnD,IAA9B,EAAoCC,IAApC,EAA0C0B,QAA1C,CAArB;AAEA,UAAMyB,IAAI,GAAG;AACZpD,MAAAA,IADY;AAEZC,MAAAA,IAFY;AAGZ0B,MAAAA,QAHY;AAIZ;AACA;AACAtB,MAAAA,KAAK,EAAEgD,MAAM,CAACC,IAAP,CAAajD,KAAb,EAAqBkD,MAArB,CAA6B,CAAEC,GAAF,EAAOC,GAAP,KAAgB;AACnD,cAAMC,WAAW,GAAGnD,MAAM,CAAEkD,GAAF,CAA1B;AACA,cAAME,iBAAiB,GAAGT,YAAY,CAAEO,GAAF,CAAtC;AACA,cAAMG,KAAK,GAAGZ,WAAW,CAAES,GAAF,CAAX,GACX,EAAE,GAAGE,iBAAL;AAAwB,aAAGtD,KAAK,CAAEoD,GAAF;AAAhC,SADW,GAEXpD,KAAK,CAAEoD,GAAF,CAFR;AAGAD,QAAAA,GAAG,CAAEC,GAAF,CAAH,GAAahF,OAAO,CAAEiF,WAAF,EAAeE,KAAf,CAAP,GAAgCC,SAAhC,GAA4CD,KAAzD;AACA,eAAOJ,GAAP;AACA,OARM,EAQJ,EARI,CANK;AAeZT,MAAAA;AAfY,KAAb;AAiBAlB,IAAAA,QAAQ,CAAE;AACTnC,MAAAA,IAAI,EAAE,oBADG;AAET,SAAG0D,IAFM;AAGTU,MAAAA,IAAI,EAAE;AACLC,QAAAA,IAAI,EAAE,CAAEpB,OAAO,CAACqB,UAAV,IAAwB,EAC7B,GAAGZ,IAD0B;AAE7B;AACA/C,UAAAA,KAAK,EAAEgD,MAAM,CAACC,IAAP,CAAajD,KAAb,EAAqBkD,MAArB,CAA6B,CAAEC,GAAF,EAAOC,GAAP,KAAgB;AACnDD,YAAAA,GAAG,CAAEC,GAAF,CAAH,GAAaP,YAAY,CAAEO,GAAF,CAAzB;AACA,mBAAOD,GAAP;AACA,WAHM,EAGJ,EAHI;AAHsB;AADzB;AAHG,KAAF,CAAR;AAcA,GAhD+B;AAAA,CAAzB;AAkDP;AACA;AACA;AACA;;AACA,OAAO,MAAMO,IAAI,GAAG,MAAM,SAA4B;AAAA,MAA1B;AAAEnB,IAAAA,MAAF;AAAUf,IAAAA;AAAV,GAA0B;AACrD,QAAMoC,QAAQ,GAAGrB,MAAM,CAACsB,WAAP,EAAjB;;AACA,MAAK,CAAED,QAAP,EAAkB;AACjB;AACA;;AACDpC,EAAAA,QAAQ,CAAE;AACTnC,IAAAA,IAAI,EAAE,oBADG;AAET,OAAGuE,QAFM;AAGTH,IAAAA,IAAI,EAAE;AAAEK,MAAAA,MAAM,EAAE;AAAV;AAHG,GAAF,CAAR;AAKA,CAVM;AAYP;AACA;AACA;AACA;;AACA,OAAO,MAAMC,IAAI,GAAG,MAAM,SAA4B;AAAA,MAA1B;AAAExB,IAAAA,MAAF;AAAUf,IAAAA;AAAV,GAA0B;AACrD,QAAMwC,QAAQ,GAAGzB,MAAM,CAAC0B,WAAP,EAAjB;;AACA,MAAK,CAAED,QAAP,EAAkB;AACjB;AACA;;AACDxC,EAAAA,QAAQ,CAAE;AACTnC,IAAAA,IAAI,EAAE,oBADG;AAET,OAAG2E,QAFM;AAGTP,IAAAA,IAAI,EAAE;AAAES,MAAAA,MAAM,EAAE;AAAV;AAHG,GAAF,CAAR;AAKA,CAVM;AAYP;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,yBAAT,GAAqC;AAC3C,SAAO;AAAE9E,IAAAA,IAAI,EAAE;AAAR,GAAP;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAM+E,gBAAgB,GAAG,UAC/BzE,IAD+B,EAE/BC,IAF+B,EAG/BM,MAH+B;AAAA,MAI/B;AAAEmE,IAAAA,UAAU,GAAG,KAAf;AAAsB9C,IAAAA,eAAe,GAAG/C;AAAxC,GAJ+B,uEAIsB,EAJtB;AAAA,SAK3B,eAAiD;AAAA,QAAzC;AAAE+D,MAAAA,MAAF;AAAU+B,MAAAA,aAAV;AAAyB9C,MAAAA;AAAzB,KAAyC;AACrD,UAAM/B,QAAQ,GAAG,MAAM+B,QAAQ,CAAE1C,eAAe,CAAEa,IAAF,CAAjB,CAA/B;AACA,UAAM8B,MAAM,GAAGpD,IAAI,CAAEoB,QAAF,EAAY;AAAEE,MAAAA,IAAF;AAAQC,MAAAA;AAAR,KAAZ,CAAnB;;AACA,QAAK,CAAE6B,MAAF,IAAYA,MAAZ,aAAYA,MAAZ,eAAYA,MAAM,CAAEG,qBAAzB,EAAiD;AAChD;AACA;;AACD,UAAM2C,WAAW,GAAG9C,MAAM,CAAC2B,GAAP,IAAcrE,kBAAlC;AACA,UAAMuC,QAAQ,GAAGpB,MAAM,CAAEqE,WAAF,CAAvB;AAEA,UAAM1C,IAAI,GAAG,MAAML,QAAQ,CAACM,0BAAT,CAClB7C,UADkB,EAElB,CAAE,UAAF,EAAc,MAAd,EAAsBU,IAAtB,EAA4BC,IAA5B,EAAkC0B,QAAQ,IAAI/C,IAAI,EAAlD,CAFkB,EAGlB;AAAEwD,MAAAA,SAAS,EAAE;AAAb,KAHkB,CAAnB;;AAMA,QAAI;AACH;AACA;AACA,WAAM,MAAM,CAAEqB,GAAF,EAAOG,KAAP,CAAZ,IAA8BP,MAAM,CAACwB,OAAP,CAAgBtE,MAAhB,CAA9B,EAAyD;AACxD,YAAK,OAAOqD,KAAP,KAAiB,UAAtB,EAAmC;AAClC,gBAAMkB,cAAc,GAAGlB,KAAK,CAC3BhB,MAAM,CAACO,qBAAP,CAA8BnD,IAA9B,EAAoCC,IAApC,EAA0C0B,QAA1C,CAD2B,CAA5B;AAGAE,UAAAA,QAAQ,CAACa,gBAAT,CACC1C,IADD,EAECC,IAFD,EAGC0B,QAHD,EAIC;AACC,aAAE8B,GAAF,GAASqB;AADV,WAJD,EAOC;AAAEd,YAAAA,UAAU,EAAE;AAAd,WAPD;AASAzD,UAAAA,MAAM,CAAEkD,GAAF,CAAN,GAAgBqB,cAAhB;AACA;AACD;;AAEDjD,MAAAA,QAAQ,CAAE;AACTnC,QAAAA,IAAI,EAAE,0BADG;AAETM,QAAAA,IAFS;AAGTC,QAAAA,IAHS;AAIT0B,QAAAA,QAJS;AAKT+C,QAAAA;AALS,OAAF,CAAR;AAOA,UAAIK,aAAJ;AACA,UAAIhD,KAAJ;;AACA,UAAI;AACH,cAAMM,IAAI,GAAI,GAAGP,MAAM,CAACQ,OAAS,GAChCX,QAAQ,GAAG,MAAMA,QAAT,GAAoB,EAC5B,EAFD;AAGA,cAAMqD,eAAe,GAAGpC,MAAM,CAACK,kBAAP,CACvBjD,IADuB,EAEvBC,IAFuB,EAGvB0B,QAHuB,CAAxB;;AAMA,YAAK+C,UAAL,EAAkB;AACjB;AACA;AACA;AACA;AACA,gBAAM9E,WAAW,GAAGgD,MAAM,CAACqC,cAAP,EAApB;AACA,gBAAMC,aAAa,GAAGtF,WAAW,GAAGA,WAAW,CAACmB,EAAf,GAAoB8C,SAArD;AACA,gBAAMsB,YAAY,GAAG,MAAMR,aAAa,CAACS,WAAd,CAC1BJ,eAAe,CAACtF,IADU,EAE1BsF,eAAe,CAACjE,EAFU,EAG1BmE,aAH0B,CAA3B,CAPiB,CAYjB;AACA;AACA;AACA;;AACA,cAAIG,IAAI,GAAG,EAAE,GAAGL,eAAL;AAAsB,eAAGG,YAAzB;AAAuC,eAAG5E;AAA1C,WAAX;AACA8E,UAAAA,IAAI,GAAGhC,MAAM,CAACC,IAAP,CAAa+B,IAAb,EAAoB9B,MAApB,CACN,CAAEC,GAAF,EAAOC,GAAP,KAAgB;AACf,gBACC,CAAE,OAAF,EAAW,SAAX,EAAsB,SAAtB,EAAkC6B,QAAlC,CAA4C7B,GAA5C,CADD,EAEE;AACDD,cAAAA,GAAG,CAAEC,GAAF,CAAH,GAAa4B,IAAI,CAAE5B,GAAF,CAAjB;AACA;;AACD,mBAAOD,GAAP;AACA,WARK,EASN;AACChD,YAAAA,MAAM,EACL6E,IAAI,CAAC7E,MAAL,KAAgB,YAAhB,GACG,OADH,GAEG6E,IAAI,CAAC7E;AAJV,WATM,CAAP;AAgBAuE,UAAAA,aAAa,GAAG,MAAMnD,eAAe,CAAE;AACtCS,YAAAA,IAAI,EAAG,GAAGA,IAAM,YADsB;AAEtCE,YAAAA,MAAM,EAAE,MAF8B;AAGtC8C,YAAAA;AAHsC,WAAF,CAArC,CAjCiB,CAuCjB;AACA;AACA;;AACA,cAAKL,eAAe,CAACjE,EAAhB,KAAuBgE,aAAa,CAAChE,EAA1C,EAA+C;AAC9C,gBAAIwE,SAAS,GAAG,EACf,GAAGP,eADY;AAEf,iBAAGK,IAFY;AAGf,iBAAGN;AAHY,aAAhB;AAKAQ,YAAAA,SAAS,GAAGlC,MAAM,CAACC,IAAP,CAAaiC,SAAb,EAAyBhC,MAAzB,CACX,CAAEC,GAAF,EAAOC,GAAP,KAAgB;AACf;AACA,kBACC,CAAE,OAAF,EAAW,SAAX,EAAsB,SAAtB,EAAkC6B,QAAlC,CACC7B,GADD,CADD,EAIE;AACDD,gBAAAA,GAAG,CAAEC,GAAF,CAAH,GAAa8B,SAAS,CAAE9B,GAAF,CAAtB;AACA,eAND,MAMO,IAAKA,GAAG,KAAK,QAAb,EAAwB;AAC9B;AACA;AACAD,gBAAAA,GAAG,CAAEC,GAAF,CAAH,GACCuB,eAAe,CAACxE,MAAhB,KAA2B,YAA3B,IACA+E,SAAS,CAAC/E,MAAV,KAAqB,OADrB,GAEG+E,SAAS,CAAC/E,MAFb,GAGGwE,eAAe,CAACxE,MAJpB;AAKA,eARM,MAQA;AACN;AACAgD,gBAAAA,GAAG,CAAEC,GAAF,CAAH,GAAauB,eAAe,CAAEvB,GAAF,CAA5B;AACA;;AACD,qBAAOD,GAAP;AACA,aAtBU,EAuBX,EAvBW,CAAZ;AAyBA3B,YAAAA,QAAQ,CAAC9B,oBAAT,CACCC,IADD,EAECC,IAFD,EAGCsF,SAHD,EAIC1B,SAJD,EAKC,IALD;AAOA,WAtCD,MAsCO;AACNhC,YAAAA,QAAQ,CAAC2D,gBAAT,CACCR,eAAe,CAACjE,EADjB,EAECgE,aAFD;AAIA;AACD,SAtFD,MAsFO;AACN,cAAI1E,KAAK,GAAGE,MAAZ;;AACA,cAAKuB,MAAM,CAAC2D,oBAAZ,EAAmC;AAClCpF,YAAAA,KAAK,GAAG,EACP,GAAGA,KADI;AAEP,iBAAGyB,MAAM,CAAC2D,oBAAP,CACFT,eADE,EAEF3E,KAFE;AAFI,aAAR;AAOA;;AACD0E,UAAAA,aAAa,GAAG,MAAMnD,eAAe,CAAE;AACtCS,YAAAA,IADsC;AAEtCE,YAAAA,MAAM,EAAEZ,QAAQ,GAAG,KAAH,GAAW,MAFW;AAGtC0D,YAAAA,IAAI,EAAEhF;AAHgC,WAAF,CAArC;AAKAwB,UAAAA,QAAQ,CAAC9B,oBAAT,CACCC,IADD,EAECC,IAFD,EAGC8E,aAHD,EAIClB,SAJD,EAKC,IALD,EAMCxD,KAND;AAQA;AACD,OAzHD,CAyHE,OAAQmC,MAAR,EAAiB;AAClBT,QAAAA,KAAK,GAAGS,MAAR;AACA;;AACDX,MAAAA,QAAQ,CAAE;AACTnC,QAAAA,IAAI,EAAE,2BADG;AAETM,QAAAA,IAFS;AAGTC,QAAAA,IAHS;AAIT0B,QAAAA,QAJS;AAKTI,QAAAA,KALS;AAMT2C,QAAAA;AANS,OAAF,CAAR;AASA,aAAOK,aAAP;AACA,KApKD,SAoKU;AACTlD,MAAAA,QAAQ,CAACY,0BAAT,CAAqCP,IAArC;AACA;AACD,GA3L+B;AAAA,CAAzB;AA6LP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMwD,mBAAmB,GAAKC,QAAF,IAAgB,eAA0B;AAAA,MAAlB;AAAE9D,IAAAA;AAAF,GAAkB;AAC5E,QAAM+D,KAAK,GAAGvG,WAAW,EAAzB;AACA,QAAMwG,GAAG,GAAG;AACXpB,IAAAA,gBAAgB,CAAEzE,IAAF,EAAQC,IAAR,EAAcM,MAAd,EAAsBoC,OAAtB,EAAgC;AAC/C,aAAOiD,KAAK,CAACE,GAAN,CAAaA,GAAF,IACjBjE,QAAQ,CAAC4C,gBAAT,CAA2BzE,IAA3B,EAAiCC,IAAjC,EAAuCM,MAAvC,EAA+C,EAC9C,GAAGoC,OAD2C;AAE9Cf,QAAAA,eAAe,EAAEkE;AAF6B,OAA/C,CADM,CAAP;AAMA,KARU;;AASXC,IAAAA,sBAAsB,CAAE/F,IAAF,EAAQC,IAAR,EAAc0B,QAAd,EAAwBgB,OAAxB,EAAkC;AACvD,aAAOiD,KAAK,CAACE,GAAN,CAAaA,GAAF,IACjBjE,QAAQ,CAACkE,sBAAT,CAAiC/F,IAAjC,EAAuCC,IAAvC,EAA6C0B,QAA7C,EAAuD,EACtD,GAAGgB,OADmD;AAEtDf,QAAAA,eAAe,EAAEkE;AAFqC,OAAvD,CADM,CAAP;AAMA,KAhBU;;AAiBXpE,IAAAA,kBAAkB,CAAE1B,IAAF,EAAQC,IAAR,EAAc0B,QAAd,EAAwBxB,KAAxB,EAA+BwC,OAA/B,EAAyC;AAC1D,aAAOiD,KAAK,CAACE,GAAN,CAAaA,GAAF,IACjBjE,QAAQ,CAACH,kBAAT,CAA6B1B,IAA7B,EAAmCC,IAAnC,EAAyC0B,QAAzC,EAAmDxB,KAAnD,EAA0D,EACzD,GAAGwC,OADsD;AAEzDf,QAAAA,eAAe,EAAEkE;AAFwC,OAA1D,CADM,CAAP;AAMA;;AAxBU,GAAZ;AA0BA,QAAME,cAAc,GAAGL,QAAQ,CAACrF,GAAT,CAAgB2F,OAAF,IAAeA,OAAO,CAAEJ,GAAF,CAApC,CAAvB;AACA,QAAM,GAAI,GAAGK,OAAP,IAAmB,MAAMC,OAAO,CAACC,GAAR,CAAa,CAC3CR,KAAK,CAACS,GAAN,EAD2C,EAE3C,GAAGL,cAFwC,CAAb,CAA/B;AAIA,SAAOE,OAAP;AACA,CAlCM;AAoCP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMH,sBAAsB,GAAG,CACrC/F,IADqC,EAErCC,IAFqC,EAGrC0B,QAHqC,EAIrCgB,OAJqC,KAKjC,eAAkC;AAAA,MAA1B;AAAEC,IAAAA,MAAF;AAAUf,IAAAA;AAAV,GAA0B;;AACtC,MAAK,CAAEe,MAAM,CAAC0D,uBAAP,CAAgCtG,IAAhC,EAAsCC,IAAtC,EAA4C0B,QAA5C,CAAP,EAAgE;AAC/D;AACA;;AACD,QAAM7B,QAAQ,GAAG,MAAM+B,QAAQ,CAAE1C,eAAe,CAAEa,IAAF,CAAjB,CAA/B;AACA,QAAM8B,MAAM,GAAGpD,IAAI,CAAEoB,QAAF,EAAY;AAAEE,IAAAA,IAAF;AAAQC,IAAAA;AAAR,GAAZ,CAAnB;;AACA,MAAK,CAAE6B,MAAP,EAAgB;AACf;AACA;;AACD,QAAM8C,WAAW,GAAG9C,MAAM,CAAC2B,GAAP,IAAcrE,kBAAlC;AAEA,QAAMiB,KAAK,GAAGuC,MAAM,CAAC2D,gCAAP,CACbvG,IADa,EAEbC,IAFa,EAGb0B,QAHa,CAAd;AAKA,QAAMpB,MAAM,GAAG;AAAE,KAAEqE,WAAF,GAAiBjD,QAAnB;AAA6B,OAAGtB;AAAhC,GAAf;AACA,SAAO,MAAMwB,QAAQ,CAAC4C,gBAAT,CAA2BzE,IAA3B,EAAiCC,IAAjC,EAAuCM,MAAvC,EAA+CoC,OAA/C,CAAb;AACA,CAvBM;AAyBP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAM6D,sCAAsC,GAAG,CACrDxG,IADqD,EAErDC,IAFqD,EAGrD0B,QAHqD,EAIrD8E,WAJqD,EAKrD9D,OALqD,KAMjD,eAAkC;AAAA,MAA1B;AAAEC,IAAAA,MAAF;AAAUf,IAAAA;AAAV,GAA0B;;AACtC,MAAK,CAAEe,MAAM,CAAC0D,uBAAP,CAAgCtG,IAAhC,EAAsCC,IAAtC,EAA4C0B,QAA5C,CAAP,EAAgE;AAC/D;AACA;;AACD,QAAMtB,KAAK,GAAGuC,MAAM,CAAC2D,gCAAP,CACbvG,IADa,EAEbC,IAFa,EAGb0B,QAHa,CAAd;AAKA,QAAM+E,WAAW,GAAG,EAApB;;AACA,OAAM,MAAMtD,IAAZ,IAAoB/C,KAApB,EAA4B;AAC3B,QAAKoG,WAAW,CAACE,IAAZ,CAAoBC,IAAF,IAAYA,IAAI,KAAKxD,IAAvC,CAAL,EAAqD;AACpDsD,MAAAA,WAAW,CAAEtD,IAAF,CAAX,GAAsB/C,KAAK,CAAE+C,IAAF,CAA3B;AACA;AACD;;AACD,SAAO,MAAMvB,QAAQ,CAAC4C,gBAAT,CAA2BzE,IAA3B,EAAiCC,IAAjC,EAAuCyG,WAAvC,EAAoD/D,OAApD,CAAb;AACA,CAtBM;AAwBP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASkE,wBAAT,CAAmCC,oBAAnC,EAA0D;AAChE/H,EAAAA,UAAU,CAAE,qDAAF,EAAyD;AAClEuC,IAAAA,KAAK,EAAE,KAD2D;AAElEyF,IAAAA,WAAW,EAAE;AAFqD,GAAzD,CAAV;AAKA,SAAOC,qBAAqB,CAAE,cAAF,EAAkBF,oBAAlB,CAA5B;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASE,qBAAT,CAAgCvD,GAAhC,EAAqCwD,SAArC,EAAiD;AACvD,SAAO;AACNvH,IAAAA,IAAI,EAAE,yBADA;AAEN+D,IAAAA,GAFM;AAGNwD,IAAAA;AAHM,GAAP;AAKA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASzB,gBAAT,CAA2B0B,MAA3B,EAAmCC,SAAnC,EAA+C;AACrD,SAAO;AACNzH,IAAAA,IAAI,EAAE,mBADA;AAENwH,IAAAA,MAFM;AAGNC,IAAAA,SAAS,EAAE3I,SAAS,CAAE2I,SAAF;AAHd,GAAP;AAKA","sourcesContent":["/**\n * External dependencies\n */\nimport { castArray, isEqual, find } from 'lodash';\nimport { v4 as uuid } from 'uuid';\n\n/**\n * WordPress dependencies\n */\nimport apiFetch from '@wordpress/api-fetch';\nimport { addQueryArgs } from '@wordpress/url';\nimport deprecated from '@wordpress/deprecated';\n\n/**\n * Internal dependencies\n */\nimport { receiveItems, removeItems, receiveQueriedItems } from './queried-data';\nimport { getKindEntities, DEFAULT_ENTITY_KEY } from './entities';\nimport { createBatch } from './batch';\nimport { STORE_NAME } from './name';\n\n/**\n * Returns an action object used in signalling that authors have been received.\n *\n * @param {string} queryID Query ID.\n * @param {Array|Object} users Users received.\n *\n * @return {Object} Action object.\n */\nexport function receiveUserQuery( queryID, users ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_QUERY',\n\t\tusers: castArray( users ),\n\t\tqueryID,\n\t};\n}\n\n/**\n * Returns an action used in signalling that the current user has been received.\n *\n * @param {Object} currentUser Current user object.\n *\n * @return {Object} Action object.\n */\nexport function receiveCurrentUser( currentUser ) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_USER',\n\t\tcurrentUser,\n\t};\n}\n\n/**\n * Returns an action object used in adding new entities.\n *\n * @param {Array} entities Entities received.\n *\n * @return {Object} Action object.\n */\nexport function addEntities( entities ) {\n\treturn {\n\t\ttype: 'ADD_ENTITIES',\n\t\tentities,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that entity records have been received.\n *\n * @param {string} kind Kind of the received entity.\n * @param {string} name Name of the received entity.\n * @param {Array|Object} records Records received.\n * @param {?Object} query Query Object.\n * @param {?boolean} invalidateCache Should invalidate query caches.\n * @param {?Object} edits Edits to reset.\n * @return {Object} Action object.\n */\nexport function receiveEntityRecords(\n\tkind,\n\tname,\n\trecords,\n\tquery,\n\tinvalidateCache = false,\n\tedits\n) {\n\t// Auto drafts should not have titles, but some plugins rely on them so we can't filter this\n\t// on the server.\n\tif ( kind === 'postType' ) {\n\t\trecords = castArray( records ).map( ( record ) =>\n\t\t\trecord.status === 'auto-draft' ? { ...record, title: '' } : record\n\t\t);\n\t}\n\tlet action;\n\tif ( query ) {\n\t\taction = receiveQueriedItems( records, query, edits );\n\t} else {\n\t\taction = receiveItems( records, edits );\n\t}\n\n\treturn {\n\t\t...action,\n\t\tkind,\n\t\tname,\n\t\tinvalidateCache,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the current theme has been received.\n *\n * @param {Object} currentTheme The current theme.\n *\n * @return {Object} Action object.\n */\nexport function receiveCurrentTheme( currentTheme ) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_THEME',\n\t\tcurrentTheme,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the current global styles id has been received.\n *\n * @param {string} currentGlobalStylesId The current global styles id.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveCurrentGlobalStylesId(\n\tcurrentGlobalStylesId\n) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_GLOBAL_STYLES_ID',\n\t\tid: currentGlobalStylesId,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the theme base global styles have been received\n *\n * @param {string} stylesheet The theme's identifier\n * @param {Object} globalStyles The global styles object.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveThemeBaseGlobalStyles(\n\tstylesheet,\n\tglobalStyles\n) {\n\treturn {\n\t\ttype: 'RECEIVE_THEME_GLOBAL_STYLES',\n\t\tstylesheet,\n\t\tglobalStyles,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the theme global styles variations have been received.\n *\n * @param {string} stylesheet The theme's identifier\n * @param {Array} variations The global styles variations.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveThemeGlobalStyleVariations(\n\tstylesheet,\n\tvariations\n) {\n\treturn {\n\t\ttype: 'RECEIVE_THEME_GLOBAL_STYLE_VARIATIONS',\n\t\tstylesheet,\n\t\tvariations,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the index has been received.\n *\n * @deprecated since WP 5.9, this is not useful anymore, use the selector direclty.\n *\n * @return {Object} Action object.\n */\nexport function receiveThemeSupports() {\n\tdeprecated( \"wp.data.dispatch( 'core' ).receiveThemeSupports\", {\n\t\tsince: '5.9',\n\t} );\n\n\treturn {\n\t\ttype: 'DO_NOTHING',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the preview data for\n * a given URl has been received.\n *\n * @param {string} url URL to preview the embed for.\n * @param {*} preview Preview data.\n *\n * @return {Object} Action object.\n */\nexport function receiveEmbedPreview( url, preview ) {\n\treturn {\n\t\ttype: 'RECEIVE_EMBED_PREVIEW',\n\t\turl,\n\t\tpreview,\n\t};\n}\n\n/**\n * Action triggered to delete an entity record.\n *\n * @param {string} kind Kind of the deleted entity.\n * @param {string} name Name of the deleted entity.\n * @param {string} recordId Record ID of the deleted entity.\n * @param {?Object} query Special query parameters for the\n * DELETE API call.\n * @param {Object} [options] Delete options.\n * @param {Function} [options.__unstableFetch] Internal use only. Function to\n * call instead of `apiFetch()`.\n * Must return a promise.\n */\nexport const deleteEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\tquery,\n\t{ __unstableFetch = apiFetch } = {}\n) => async ( { dispatch } ) => {\n\tconst entities = await dispatch( getKindEntities( kind ) );\n\tconst entity = find( entities, { kind, name } );\n\tlet error;\n\tlet deletedRecord = false;\n\tif ( ! entity || entity?.__experimentalNoFetch ) {\n\t\treturn;\n\t}\n\n\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\tSTORE_NAME,\n\t\t[ 'entities', 'data', kind, name, recordId ],\n\t\t{ exclusive: true }\n\t);\n\n\ttry {\n\t\tdispatch( {\n\t\t\ttype: 'DELETE_ENTITY_RECORD_START',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t} );\n\n\t\ttry {\n\t\t\tlet path = `${ entity.baseURL }/${ recordId }`;\n\n\t\t\tif ( query ) {\n\t\t\t\tpath = addQueryArgs( path, query );\n\t\t\t}\n\n\t\t\tdeletedRecord = await __unstableFetch( {\n\t\t\t\tpath,\n\t\t\t\tmethod: 'DELETE',\n\t\t\t} );\n\n\t\t\tawait dispatch( removeItems( kind, name, recordId, true ) );\n\t\t} catch ( _error ) {\n\t\t\terror = _error;\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'DELETE_ENTITY_RECORD_FINISH',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\terror,\n\t\t} );\n\n\t\treturn deletedRecord;\n\t} finally {\n\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t}\n};\n\n/**\n * Returns an action object that triggers an\n * edit to an entity record.\n *\n * @param {string} kind Kind of the edited entity record.\n * @param {string} name Name of the edited entity record.\n * @param {number} recordId Record ID of the edited entity record.\n * @param {Object} edits The edits.\n * @param {Object} options Options for the edit.\n * @param {boolean} [options.undoIgnore] Whether to ignore the edit in undo history or not.\n *\n * @return {Object} Action object.\n */\nexport const editEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\tedits,\n\toptions = {}\n) => ( { select, dispatch } ) => {\n\tconst entity = select.getEntity( kind, name );\n\tif ( ! entity ) {\n\t\tthrow new Error(\n\t\t\t`The entity being edited (${ kind }, ${ name }) does not have a loaded config.`\n\t\t);\n\t}\n\tconst { transientEdits = {}, mergedEdits = {} } = entity;\n\tconst record = select.getRawEntityRecord( kind, name, recordId );\n\tconst editedRecord = select.getEditedEntityRecord( kind, name, recordId );\n\n\tconst edit = {\n\t\tkind,\n\t\tname,\n\t\trecordId,\n\t\t// Clear edits when they are equal to their persisted counterparts\n\t\t// so that the property is not considered dirty.\n\t\tedits: Object.keys( edits ).reduce( ( acc, key ) => {\n\t\t\tconst recordValue = record[ key ];\n\t\t\tconst editedRecordValue = editedRecord[ key ];\n\t\t\tconst value = mergedEdits[ key ]\n\t\t\t\t? { ...editedRecordValue, ...edits[ key ] }\n\t\t\t\t: edits[ key ];\n\t\t\tacc[ key ] = isEqual( recordValue, value ) ? undefined : value;\n\t\t\treturn acc;\n\t\t}, {} ),\n\t\ttransientEdits,\n\t};\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...edit,\n\t\tmeta: {\n\t\t\tundo: ! options.undoIgnore && {\n\t\t\t\t...edit,\n\t\t\t\t// Send the current values for things like the first undo stack entry.\n\t\t\t\tedits: Object.keys( edits ).reduce( ( acc, key ) => {\n\t\t\t\t\tacc[ key ] = editedRecord[ key ];\n\t\t\t\t\treturn acc;\n\t\t\t\t}, {} ),\n\t\t\t},\n\t\t},\n\t} );\n};\n\n/**\n * Action triggered to undo the last edit to\n * an entity record, if any.\n */\nexport const undo = () => ( { select, dispatch } ) => {\n\tconst undoEdit = select.getUndoEdit();\n\tif ( ! undoEdit ) {\n\t\treturn;\n\t}\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...undoEdit,\n\t\tmeta: { isUndo: true },\n\t} );\n};\n\n/**\n * Action triggered to redo the last undoed\n * edit to an entity record, if any.\n */\nexport const redo = () => ( { select, dispatch } ) => {\n\tconst redoEdit = select.getRedoEdit();\n\tif ( ! redoEdit ) {\n\t\treturn;\n\t}\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...redoEdit,\n\t\tmeta: { isRedo: true },\n\t} );\n};\n\n/**\n * Forces the creation of a new undo level.\n *\n * @return {Object} Action object.\n */\nexport function __unstableCreateUndoLevel() {\n\treturn { type: 'CREATE_UNDO_LEVEL' };\n}\n\n/**\n * Action triggered to save an entity record.\n *\n * @param {string} kind Kind of the received entity.\n * @param {string} name Name of the received entity.\n * @param {Object} record Record to be saved.\n * @param {Object} options Saving options.\n * @param {boolean} [options.isAutosave=false] Whether this is an autosave.\n * @param {Function} [options.__unstableFetch] Internal use only. Function to\n * call instead of `apiFetch()`.\n * Must return a promise.\n */\nexport const saveEntityRecord = (\n\tkind,\n\tname,\n\trecord,\n\t{ isAutosave = false, __unstableFetch = apiFetch } = {}\n) => async ( { select, resolveSelect, dispatch } ) => {\n\tconst entities = await dispatch( getKindEntities( kind ) );\n\tconst entity = find( entities, { kind, name } );\n\tif ( ! entity || entity?.__experimentalNoFetch ) {\n\t\treturn;\n\t}\n\tconst entityIdKey = entity.key || DEFAULT_ENTITY_KEY;\n\tconst recordId = record[ entityIdKey ];\n\n\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\tSTORE_NAME,\n\t\t[ 'entities', 'data', kind, name, recordId || uuid() ],\n\t\t{ exclusive: true }\n\t);\n\n\ttry {\n\t\t// Evaluate optimized edits.\n\t\t// (Function edits that should be evaluated on save to avoid expensive computations on every edit.)\n\t\tfor ( const [ key, value ] of Object.entries( record ) ) {\n\t\t\tif ( typeof value === 'function' ) {\n\t\t\t\tconst evaluatedValue = value(\n\t\t\t\t\tselect.getEditedEntityRecord( kind, name, recordId )\n\t\t\t\t);\n\t\t\t\tdispatch.editEntityRecord(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\trecordId,\n\t\t\t\t\t{\n\t\t\t\t\t\t[ key ]: evaluatedValue,\n\t\t\t\t\t},\n\t\t\t\t\t{ undoIgnore: true }\n\t\t\t\t);\n\t\t\t\trecord[ key ] = evaluatedValue;\n\t\t\t}\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SAVE_ENTITY_RECORD_START',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\tisAutosave,\n\t\t} );\n\t\tlet updatedRecord;\n\t\tlet error;\n\t\ttry {\n\t\t\tconst path = `${ entity.baseURL }${\n\t\t\t\trecordId ? '/' + recordId : ''\n\t\t\t}`;\n\t\t\tconst persistedRecord = select.getRawEntityRecord(\n\t\t\t\tkind,\n\t\t\t\tname,\n\t\t\t\trecordId\n\t\t\t);\n\n\t\t\tif ( isAutosave ) {\n\t\t\t\t// Most of this autosave logic is very specific to posts.\n\t\t\t\t// This is fine for now as it is the only supported autosave,\n\t\t\t\t// but ideally this should all be handled in the back end,\n\t\t\t\t// so the client just sends and receives objects.\n\t\t\t\tconst currentUser = select.getCurrentUser();\n\t\t\t\tconst currentUserId = currentUser ? currentUser.id : undefined;\n\t\t\t\tconst autosavePost = await resolveSelect.getAutosave(\n\t\t\t\t\tpersistedRecord.type,\n\t\t\t\t\tpersistedRecord.id,\n\t\t\t\t\tcurrentUserId\n\t\t\t\t);\n\t\t\t\t// Autosaves need all expected fields to be present.\n\t\t\t\t// So we fallback to the previous autosave and then\n\t\t\t\t// to the actual persisted entity if the edits don't\n\t\t\t\t// have a value.\n\t\t\t\tlet data = { ...persistedRecord, ...autosavePost, ...record };\n\t\t\t\tdata = Object.keys( data ).reduce(\n\t\t\t\t\t( acc, key ) => {\n\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t[ 'title', 'excerpt', 'content' ].includes( key )\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tacc[ key ] = data[ key ];\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn acc;\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tstatus:\n\t\t\t\t\t\t\tdata.status === 'auto-draft'\n\t\t\t\t\t\t\t\t? 'draft'\n\t\t\t\t\t\t\t\t: data.status,\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tupdatedRecord = await __unstableFetch( {\n\t\t\t\t\tpath: `${ path }/autosaves`,\n\t\t\t\t\tmethod: 'POST',\n\t\t\t\t\tdata,\n\t\t\t\t} );\n\n\t\t\t\t// An autosave may be processed by the server as a regular save\n\t\t\t\t// when its update is requested by the author and the post had\n\t\t\t\t// draft or auto-draft status.\n\t\t\t\tif ( persistedRecord.id === updatedRecord.id ) {\n\t\t\t\t\tlet newRecord = {\n\t\t\t\t\t\t...persistedRecord,\n\t\t\t\t\t\t...data,\n\t\t\t\t\t\t...updatedRecord,\n\t\t\t\t\t};\n\t\t\t\t\tnewRecord = Object.keys( newRecord ).reduce(\n\t\t\t\t\t\t( acc, key ) => {\n\t\t\t\t\t\t\t// These properties are persisted in autosaves.\n\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t[ 'title', 'excerpt', 'content' ].includes(\n\t\t\t\t\t\t\t\t\tkey\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\tacc[ key ] = newRecord[ key ];\n\t\t\t\t\t\t\t} else if ( key === 'status' ) {\n\t\t\t\t\t\t\t\t// Status is only persisted in autosaves when going from\n\t\t\t\t\t\t\t\t// \"auto-draft\" to \"draft\".\n\t\t\t\t\t\t\t\tacc[ key ] =\n\t\t\t\t\t\t\t\t\tpersistedRecord.status === 'auto-draft' &&\n\t\t\t\t\t\t\t\t\tnewRecord.status === 'draft'\n\t\t\t\t\t\t\t\t\t\t? newRecord.status\n\t\t\t\t\t\t\t\t\t\t: persistedRecord.status;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t// These properties are not persisted in autosaves.\n\t\t\t\t\t\t\t\tacc[ key ] = persistedRecord[ key ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn acc;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{}\n\t\t\t\t\t);\n\t\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\tnewRecord,\n\t\t\t\t\t\tundefined,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tdispatch.receiveAutosaves(\n\t\t\t\t\t\tpersistedRecord.id,\n\t\t\t\t\t\tupdatedRecord\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet edits = record;\n\t\t\t\tif ( entity.__unstablePrePersist ) {\n\t\t\t\t\tedits = {\n\t\t\t\t\t\t...edits,\n\t\t\t\t\t\t...entity.__unstablePrePersist(\n\t\t\t\t\t\t\tpersistedRecord,\n\t\t\t\t\t\t\tedits\n\t\t\t\t\t\t),\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tupdatedRecord = await __unstableFetch( {\n\t\t\t\t\tpath,\n\t\t\t\t\tmethod: recordId ? 'PUT' : 'POST',\n\t\t\t\t\tdata: edits,\n\t\t\t\t} );\n\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\tupdatedRecord,\n\t\t\t\t\tundefined,\n\t\t\t\t\ttrue,\n\t\t\t\t\tedits\n\t\t\t\t);\n\t\t\t}\n\t\t} catch ( _error ) {\n\t\t\terror = _error;\n\t\t}\n\t\tdispatch( {\n\t\t\ttype: 'SAVE_ENTITY_RECORD_FINISH',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\terror,\n\t\t\tisAutosave,\n\t\t} );\n\n\t\treturn updatedRecord;\n\t} finally {\n\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t}\n};\n\n/**\n * Runs multiple core-data actions at the same time using one API request.\n *\n * Example:\n *\n * ```\n * const [ savedRecord, updatedRecord, deletedRecord ] =\n * await dispatch( 'core' ).__experimentalBatch( [\n * ( { saveEntityRecord } ) => saveEntityRecord( 'root', 'widget', widget ),\n * ( { saveEditedEntityRecord } ) => saveEntityRecord( 'root', 'widget', 123 ),\n * ( { deleteEntityRecord } ) => deleteEntityRecord( 'root', 'widget', 123, null ),\n * ] );\n * ```\n *\n * @param {Array} requests Array of functions which are invoked simultaneously.\n * Each function is passed an object containing\n * `saveEntityRecord`, `saveEditedEntityRecord`, and\n * `deleteEntityRecord`.\n *\n * @return {(thunkArgs: Object) => Promise} A promise that resolves to an array containing the return\n * values of each function given in `requests`.\n */\nexport const __experimentalBatch = ( requests ) => async ( { dispatch } ) => {\n\tconst batch = createBatch();\n\tconst api = {\n\t\tsaveEntityRecord( kind, name, record, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.saveEntityRecord( kind, name, record, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t\tsaveEditedEntityRecord( kind, name, recordId, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.saveEditedEntityRecord( kind, name, recordId, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t\tdeleteEntityRecord( kind, name, recordId, query, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.deleteEntityRecord( kind, name, recordId, query, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t};\n\tconst resultPromises = requests.map( ( request ) => request( api ) );\n\tconst [ , ...results ] = await Promise.all( [\n\t\tbatch.run(),\n\t\t...resultPromises,\n\t] );\n\treturn results;\n};\n\n/**\n * Action triggered to save an entity record's edits.\n *\n * @param {string} kind Kind of the entity.\n * @param {string} name Name of the entity.\n * @param {Object} recordId ID of the record.\n * @param {Object} options Saving options.\n */\nexport const saveEditedEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\toptions\n) => async ( { select, dispatch } ) => {\n\tif ( ! select.hasEditsForEntityRecord( kind, name, recordId ) ) {\n\t\treturn;\n\t}\n\tconst entities = await dispatch( getKindEntities( kind ) );\n\tconst entity = find( entities, { kind, name } );\n\tif ( ! entity ) {\n\t\treturn;\n\t}\n\tconst entityIdKey = entity.key || DEFAULT_ENTITY_KEY;\n\n\tconst edits = select.getEntityRecordNonTransientEdits(\n\t\tkind,\n\t\tname,\n\t\trecordId\n\t);\n\tconst record = { [ entityIdKey ]: recordId, ...edits };\n\treturn await dispatch.saveEntityRecord( kind, name, record, options );\n};\n\n/**\n * Action triggered to save only specified properties for the entity.\n *\n * @param {string} kind Kind of the entity.\n * @param {string} name Name of the entity.\n * @param {Object} recordId ID of the record.\n * @param {Array} itemsToSave List of entity properties to save.\n * @param {Object} options Saving options.\n */\nexport const __experimentalSaveSpecifiedEntityEdits = (\n\tkind,\n\tname,\n\trecordId,\n\titemsToSave,\n\toptions\n) => async ( { select, dispatch } ) => {\n\tif ( ! select.hasEditsForEntityRecord( kind, name, recordId ) ) {\n\t\treturn;\n\t}\n\tconst edits = select.getEntityRecordNonTransientEdits(\n\t\tkind,\n\t\tname,\n\t\trecordId\n\t);\n\tconst editsToSave = {};\n\tfor ( const edit in edits ) {\n\t\tif ( itemsToSave.some( ( item ) => item === edit ) ) {\n\t\t\teditsToSave[ edit ] = edits[ edit ];\n\t\t}\n\t}\n\treturn await dispatch.saveEntityRecord( kind, name, editsToSave, options );\n};\n\n/**\n * Returns an action object used in signalling that Upload permissions have been received.\n *\n * @deprecated since WP 5.9, use receiveUserPermission instead.\n *\n * @param {boolean} hasUploadPermissions Does the user have permission to upload files?\n *\n * @return {Object} Action object.\n */\nexport function receiveUploadPermissions( hasUploadPermissions ) {\n\tdeprecated( \"wp.data.dispatch( 'core' ).receiveUploadPermissions\", {\n\t\tsince: '5.9',\n\t\talternative: 'receiveUserPermission',\n\t} );\n\n\treturn receiveUserPermission( 'create/media', hasUploadPermissions );\n}\n\n/**\n * Returns an action object used in signalling that the current user has\n * permission to perform an action on a REST resource.\n *\n * @param {string} key A key that represents the action and REST resource.\n * @param {boolean} isAllowed Whether or not the user can perform the action.\n *\n * @return {Object} Action object.\n */\nexport function receiveUserPermission( key, isAllowed ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_PERMISSION',\n\t\tkey,\n\t\tisAllowed,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the autosaves for a\n * post have been received.\n *\n * @param {number} postId The id of the post that is parent to the autosave.\n * @param {Array|Object} autosaves An array of autosaves or singular autosave object.\n *\n * @return {Object} Action object.\n */\nexport function receiveAutosaves( postId, autosaves ) {\n\treturn {\n\t\ttype: 'RECEIVE_AUTOSAVES',\n\t\tpostId,\n\t\tautosaves: castArray( autosaves ),\n\t};\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/core-data/src/actions.js"],"names":["castArray","isEqual","find","v4","uuid","apiFetch","addQueryArgs","deprecated","receiveItems","removeItems","receiveQueriedItems","getOrLoadEntitiesConfig","DEFAULT_ENTITY_KEY","createBatch","STORE_NAME","receiveUserQuery","queryID","users","type","receiveCurrentUser","currentUser","addEntities","entities","receiveEntityRecords","kind","name","records","query","invalidateCache","edits","map","record","status","title","action","receiveCurrentTheme","currentTheme","__experimentalReceiveCurrentGlobalStylesId","currentGlobalStylesId","id","__experimentalReceiveThemeBaseGlobalStyles","stylesheet","globalStyles","__experimentalReceiveThemeGlobalStyleVariations","variations","receiveThemeSupports","since","receiveEmbedPreview","url","preview","deleteEntityRecord","recordId","__unstableFetch","throwOnError","dispatch","configs","entityConfig","error","deletedRecord","__experimentalNoFetch","lock","__unstableAcquireStoreLock","exclusive","hasError","path","baseURL","method","_error","__unstableReleaseStoreLock","editEntityRecord","options","select","getEntityConfig","Error","transientEdits","mergedEdits","getRawEntityRecord","editedRecord","getEditedEntityRecord","edit","Object","keys","reduce","acc","key","recordValue","editedRecordValue","value","undefined","meta","undo","undoIgnore","undoEdit","getUndoEdit","isUndo","redo","redoEdit","getRedoEdit","isRedo","__unstableCreateUndoLevel","saveEntityRecord","isAutosave","resolveSelect","entityIdKey","entries","evaluatedValue","updatedRecord","persistedRecord","getCurrentUser","currentUserId","autosavePost","getAutosave","data","includes","newRecord","receiveAutosaves","__unstablePrePersist","__experimentalBatch","requests","batch","api","add","saveEditedEntityRecord","resultPromises","request","results","Promise","all","run","hasEditsForEntityRecord","getEntityRecordNonTransientEdits","__experimentalSaveSpecifiedEntityEdits","itemsToSave","editsToSave","some","item","receiveUploadPermissions","hasUploadPermissions","alternative","receiveUserPermission","isAllowed","postId","autosaves"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { castArray, isEqual, find } from 'lodash';\nimport { v4 as uuid } from 'uuid';\n\n/**\n * WordPress dependencies\n */\nimport apiFetch from '@wordpress/api-fetch';\nimport { addQueryArgs } from '@wordpress/url';\nimport deprecated from '@wordpress/deprecated';\n\n/**\n * Internal dependencies\n */\nimport { receiveItems, removeItems, receiveQueriedItems } from './queried-data';\nimport { getOrLoadEntitiesConfig, DEFAULT_ENTITY_KEY } from './entities';\nimport { createBatch } from './batch';\nimport { STORE_NAME } from './name';\n\n/**\n * Returns an action object used in signalling that authors have been received.\n *\n * @param {string} queryID Query ID.\n * @param {Array|Object} users Users received.\n *\n * @return {Object} Action object.\n */\nexport function receiveUserQuery( queryID, users ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_QUERY',\n\t\tusers: castArray( users ),\n\t\tqueryID,\n\t};\n}\n\n/**\n * Returns an action used in signalling that the current user has been received.\n *\n * @param {Object} currentUser Current user object.\n *\n * @return {Object} Action object.\n */\nexport function receiveCurrentUser( currentUser ) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_USER',\n\t\tcurrentUser,\n\t};\n}\n\n/**\n * Returns an action object used in adding new entities.\n *\n * @param {Array} entities Entities received.\n *\n * @return {Object} Action object.\n */\nexport function addEntities( entities ) {\n\treturn {\n\t\ttype: 'ADD_ENTITIES',\n\t\tentities,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that entity records have been received.\n *\n * @param {string} kind Kind of the received entity record.\n * @param {string} name Name of the received entity record.\n * @param {Array|Object} records Records received.\n * @param {?Object} query Query Object.\n * @param {?boolean} invalidateCache Should invalidate query caches.\n * @param {?Object} edits Edits to reset.\n * @return {Object} Action object.\n */\nexport function receiveEntityRecords(\n\tkind,\n\tname,\n\trecords,\n\tquery,\n\tinvalidateCache = false,\n\tedits\n) {\n\t// Auto drafts should not have titles, but some plugins rely on them so we can't filter this\n\t// on the server.\n\tif ( kind === 'postType' ) {\n\t\trecords = castArray( records ).map( ( record ) =>\n\t\t\trecord.status === 'auto-draft' ? { ...record, title: '' } : record\n\t\t);\n\t}\n\tlet action;\n\tif ( query ) {\n\t\taction = receiveQueriedItems( records, query, edits );\n\t} else {\n\t\taction = receiveItems( records, edits );\n\t}\n\n\treturn {\n\t\t...action,\n\t\tkind,\n\t\tname,\n\t\tinvalidateCache,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the current theme has been received.\n *\n * @param {Object} currentTheme The current theme.\n *\n * @return {Object} Action object.\n */\nexport function receiveCurrentTheme( currentTheme ) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_THEME',\n\t\tcurrentTheme,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the current global styles id has been received.\n *\n * @param {string} currentGlobalStylesId The current global styles id.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveCurrentGlobalStylesId(\n\tcurrentGlobalStylesId\n) {\n\treturn {\n\t\ttype: 'RECEIVE_CURRENT_GLOBAL_STYLES_ID',\n\t\tid: currentGlobalStylesId,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the theme base global styles have been received\n *\n * @param {string} stylesheet The theme's identifier\n * @param {Object} globalStyles The global styles object.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveThemeBaseGlobalStyles(\n\tstylesheet,\n\tglobalStyles\n) {\n\treturn {\n\t\ttype: 'RECEIVE_THEME_GLOBAL_STYLES',\n\t\tstylesheet,\n\t\tglobalStyles,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the theme global styles variations have been received.\n *\n * @param {string} stylesheet The theme's identifier\n * @param {Array} variations The global styles variations.\n *\n * @return {Object} Action object.\n */\nexport function __experimentalReceiveThemeGlobalStyleVariations(\n\tstylesheet,\n\tvariations\n) {\n\treturn {\n\t\ttype: 'RECEIVE_THEME_GLOBAL_STYLE_VARIATIONS',\n\t\tstylesheet,\n\t\tvariations,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the index has been received.\n *\n * @deprecated since WP 5.9, this is not useful anymore, use the selector direclty.\n *\n * @return {Object} Action object.\n */\nexport function receiveThemeSupports() {\n\tdeprecated( \"wp.data.dispatch( 'core' ).receiveThemeSupports\", {\n\t\tsince: '5.9',\n\t} );\n\n\treturn {\n\t\ttype: 'DO_NOTHING',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the preview data for\n * a given URl has been received.\n *\n * @param {string} url URL to preview the embed for.\n * @param {*} preview Preview data.\n *\n * @return {Object} Action object.\n */\nexport function receiveEmbedPreview( url, preview ) {\n\treturn {\n\t\ttype: 'RECEIVE_EMBED_PREVIEW',\n\t\turl,\n\t\tpreview,\n\t};\n}\n\n/**\n * Action triggered to delete an entity record.\n *\n * @param {string} kind Kind of the deleted entity.\n * @param {string} name Name of the deleted entity.\n * @param {string} recordId Record ID of the deleted entity.\n * @param {?Object} query Special query parameters for the\n * DELETE API call.\n * @param {Object} [options] Delete options.\n * @param {Function} [options.__unstableFetch] Internal use only. Function to\n * call instead of `apiFetch()`.\n * Must return a promise.\n * @param {boolean} [options.throwOnError=false] If false, this action suppresses all\n * the exceptions. Defaults to false.\n */\nexport const deleteEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\tquery,\n\t{ __unstableFetch = apiFetch, throwOnError = false } = {}\n) => async ( { dispatch } ) => {\n\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind ) );\n\tconst entityConfig = find( configs, { kind, name } );\n\tlet error;\n\tlet deletedRecord = false;\n\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\treturn;\n\t}\n\n\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\tSTORE_NAME,\n\t\t[ 'entities', 'records', kind, name, recordId ],\n\t\t{ exclusive: true }\n\t);\n\n\ttry {\n\t\tdispatch( {\n\t\t\ttype: 'DELETE_ENTITY_RECORD_START',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t} );\n\n\t\tlet hasError = false;\n\t\ttry {\n\t\t\tlet path = `${ entityConfig.baseURL }/${ recordId }`;\n\n\t\t\tif ( query ) {\n\t\t\t\tpath = addQueryArgs( path, query );\n\t\t\t}\n\n\t\t\tdeletedRecord = await __unstableFetch( {\n\t\t\t\tpath,\n\t\t\t\tmethod: 'DELETE',\n\t\t\t} );\n\n\t\t\tawait dispatch( removeItems( kind, name, recordId, true ) );\n\t\t} catch ( _error ) {\n\t\t\thasError = true;\n\t\t\terror = _error;\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'DELETE_ENTITY_RECORD_FINISH',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\terror,\n\t\t} );\n\n\t\tif ( hasError && throwOnError ) {\n\t\t\tthrow error;\n\t\t}\n\n\t\treturn deletedRecord;\n\t} finally {\n\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t}\n};\n\n/**\n * Returns an action object that triggers an\n * edit to an entity record.\n *\n * @param {string} kind Kind of the edited entity record.\n * @param {string} name Name of the edited entity record.\n * @param {number} recordId Record ID of the edited entity record.\n * @param {Object} edits The edits.\n * @param {Object} options Options for the edit.\n * @param {boolean} [options.undoIgnore] Whether to ignore the edit in undo history or not.\n *\n * @return {Object} Action object.\n */\nexport const editEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\tedits,\n\toptions = {}\n) => ( { select, dispatch } ) => {\n\tconst entityConfig = select.getEntityConfig( kind, name );\n\tif ( ! entityConfig ) {\n\t\tthrow new Error(\n\t\t\t`The entity being edited (${ kind }, ${ name }) does not have a loaded config.`\n\t\t);\n\t}\n\tconst { transientEdits = {}, mergedEdits = {} } = entityConfig;\n\tconst record = select.getRawEntityRecord( kind, name, recordId );\n\tconst editedRecord = select.getEditedEntityRecord( kind, name, recordId );\n\n\tconst edit = {\n\t\tkind,\n\t\tname,\n\t\trecordId,\n\t\t// Clear edits when they are equal to their persisted counterparts\n\t\t// so that the property is not considered dirty.\n\t\tedits: Object.keys( edits ).reduce( ( acc, key ) => {\n\t\t\tconst recordValue = record[ key ];\n\t\t\tconst editedRecordValue = editedRecord[ key ];\n\t\t\tconst value = mergedEdits[ key ]\n\t\t\t\t? { ...editedRecordValue, ...edits[ key ] }\n\t\t\t\t: edits[ key ];\n\t\t\tacc[ key ] = isEqual( recordValue, value ) ? undefined : value;\n\t\t\treturn acc;\n\t\t}, {} ),\n\t\ttransientEdits,\n\t};\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...edit,\n\t\tmeta: {\n\t\t\tundo: ! options.undoIgnore && {\n\t\t\t\t...edit,\n\t\t\t\t// Send the current values for things like the first undo stack entry.\n\t\t\t\tedits: Object.keys( edits ).reduce( ( acc, key ) => {\n\t\t\t\t\tacc[ key ] = editedRecord[ key ];\n\t\t\t\t\treturn acc;\n\t\t\t\t}, {} ),\n\t\t\t},\n\t\t},\n\t} );\n};\n\n/**\n * Action triggered to undo the last edit to\n * an entity record, if any.\n */\nexport const undo = () => ( { select, dispatch } ) => {\n\tconst undoEdit = select.getUndoEdit();\n\tif ( ! undoEdit ) {\n\t\treturn;\n\t}\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...undoEdit,\n\t\tmeta: { isUndo: true },\n\t} );\n};\n\n/**\n * Action triggered to redo the last undoed\n * edit to an entity record, if any.\n */\nexport const redo = () => ( { select, dispatch } ) => {\n\tconst redoEdit = select.getRedoEdit();\n\tif ( ! redoEdit ) {\n\t\treturn;\n\t}\n\tdispatch( {\n\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t...redoEdit,\n\t\tmeta: { isRedo: true },\n\t} );\n};\n\n/**\n * Forces the creation of a new undo level.\n *\n * @return {Object} Action object.\n */\nexport function __unstableCreateUndoLevel() {\n\treturn { type: 'CREATE_UNDO_LEVEL' };\n}\n\n/**\n * Action triggered to save an entity record.\n *\n * @param {string} kind Kind of the received entity.\n * @param {string} name Name of the received entity.\n * @param {Object} record Record to be saved.\n * @param {Object} options Saving options.\n * @param {boolean} [options.isAutosave=false] Whether this is an autosave.\n * @param {Function} [options.__unstableFetch] Internal use only. Function to\n * call instead of `apiFetch()`.\n * Must return a promise.\n * @param {boolean} [options.throwOnError=false] If false, this action suppresses all\n * the exceptions. Defaults to false.\n */\nexport const saveEntityRecord = (\n\tkind,\n\tname,\n\trecord,\n\t{\n\t\tisAutosave = false,\n\t\t__unstableFetch = apiFetch,\n\t\tthrowOnError = false,\n\t} = {}\n) => async ( { select, resolveSelect, dispatch } ) => {\n\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind ) );\n\tconst entityConfig = find( configs, { kind, name } );\n\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\treturn;\n\t}\n\tconst entityIdKey = entityConfig.key || DEFAULT_ENTITY_KEY;\n\tconst recordId = record[ entityIdKey ];\n\n\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\tSTORE_NAME,\n\t\t[ 'entities', 'records', kind, name, recordId || uuid() ],\n\t\t{ exclusive: true }\n\t);\n\n\ttry {\n\t\t// Evaluate optimized edits.\n\t\t// (Function edits that should be evaluated on save to avoid expensive computations on every edit.)\n\t\tfor ( const [ key, value ] of Object.entries( record ) ) {\n\t\t\tif ( typeof value === 'function' ) {\n\t\t\t\tconst evaluatedValue = value(\n\t\t\t\t\tselect.getEditedEntityRecord( kind, name, recordId )\n\t\t\t\t);\n\t\t\t\tdispatch.editEntityRecord(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\trecordId,\n\t\t\t\t\t{\n\t\t\t\t\t\t[ key ]: evaluatedValue,\n\t\t\t\t\t},\n\t\t\t\t\t{ undoIgnore: true }\n\t\t\t\t);\n\t\t\t\trecord[ key ] = evaluatedValue;\n\t\t\t}\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SAVE_ENTITY_RECORD_START',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\tisAutosave,\n\t\t} );\n\t\tlet updatedRecord;\n\t\tlet error;\n\t\tlet hasError = false;\n\t\ttry {\n\t\t\tconst path = `${ entityConfig.baseURL }${\n\t\t\t\trecordId ? '/' + recordId : ''\n\t\t\t}`;\n\t\t\tconst persistedRecord = select.getRawEntityRecord(\n\t\t\t\tkind,\n\t\t\t\tname,\n\t\t\t\trecordId\n\t\t\t);\n\n\t\t\tif ( isAutosave ) {\n\t\t\t\t// Most of this autosave logic is very specific to posts.\n\t\t\t\t// This is fine for now as it is the only supported autosave,\n\t\t\t\t// but ideally this should all be handled in the back end,\n\t\t\t\t// so the client just sends and receives objects.\n\t\t\t\tconst currentUser = select.getCurrentUser();\n\t\t\t\tconst currentUserId = currentUser ? currentUser.id : undefined;\n\t\t\t\tconst autosavePost = await resolveSelect.getAutosave(\n\t\t\t\t\tpersistedRecord.type,\n\t\t\t\t\tpersistedRecord.id,\n\t\t\t\t\tcurrentUserId\n\t\t\t\t);\n\t\t\t\t// Autosaves need all expected fields to be present.\n\t\t\t\t// So we fallback to the previous autosave and then\n\t\t\t\t// to the actual persisted entity if the edits don't\n\t\t\t\t// have a value.\n\t\t\t\tlet data = { ...persistedRecord, ...autosavePost, ...record };\n\t\t\t\tdata = Object.keys( data ).reduce(\n\t\t\t\t\t( acc, key ) => {\n\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t[ 'title', 'excerpt', 'content' ].includes( key )\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tacc[ key ] = data[ key ];\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn acc;\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tstatus:\n\t\t\t\t\t\t\tdata.status === 'auto-draft'\n\t\t\t\t\t\t\t\t? 'draft'\n\t\t\t\t\t\t\t\t: data.status,\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tupdatedRecord = await __unstableFetch( {\n\t\t\t\t\tpath: `${ path }/autosaves`,\n\t\t\t\t\tmethod: 'POST',\n\t\t\t\t\tdata,\n\t\t\t\t} );\n\n\t\t\t\t// An autosave may be processed by the server as a regular save\n\t\t\t\t// when its update is requested by the author and the post had\n\t\t\t\t// draft or auto-draft status.\n\t\t\t\tif ( persistedRecord.id === updatedRecord.id ) {\n\t\t\t\t\tlet newRecord = {\n\t\t\t\t\t\t...persistedRecord,\n\t\t\t\t\t\t...data,\n\t\t\t\t\t\t...updatedRecord,\n\t\t\t\t\t};\n\t\t\t\t\tnewRecord = Object.keys( newRecord ).reduce(\n\t\t\t\t\t\t( acc, key ) => {\n\t\t\t\t\t\t\t// These properties are persisted in autosaves.\n\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t[ 'title', 'excerpt', 'content' ].includes(\n\t\t\t\t\t\t\t\t\tkey\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\tacc[ key ] = newRecord[ key ];\n\t\t\t\t\t\t\t} else if ( key === 'status' ) {\n\t\t\t\t\t\t\t\t// Status is only persisted in autosaves when going from\n\t\t\t\t\t\t\t\t// \"auto-draft\" to \"draft\".\n\t\t\t\t\t\t\t\tacc[ key ] =\n\t\t\t\t\t\t\t\t\tpersistedRecord.status === 'auto-draft' &&\n\t\t\t\t\t\t\t\t\tnewRecord.status === 'draft'\n\t\t\t\t\t\t\t\t\t\t? newRecord.status\n\t\t\t\t\t\t\t\t\t\t: persistedRecord.status;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t// These properties are not persisted in autosaves.\n\t\t\t\t\t\t\t\tacc[ key ] = persistedRecord[ key ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn acc;\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{}\n\t\t\t\t\t);\n\t\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\tnewRecord,\n\t\t\t\t\t\tundefined,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tdispatch.receiveAutosaves(\n\t\t\t\t\t\tpersistedRecord.id,\n\t\t\t\t\t\tupdatedRecord\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet edits = record;\n\t\t\t\tif ( entityConfig.__unstablePrePersist ) {\n\t\t\t\t\tedits = {\n\t\t\t\t\t\t...edits,\n\t\t\t\t\t\t...entityConfig.__unstablePrePersist(\n\t\t\t\t\t\t\tpersistedRecord,\n\t\t\t\t\t\t\tedits\n\t\t\t\t\t\t),\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tupdatedRecord = await __unstableFetch( {\n\t\t\t\t\tpath,\n\t\t\t\t\tmethod: recordId ? 'PUT' : 'POST',\n\t\t\t\t\tdata: edits,\n\t\t\t\t} );\n\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\tupdatedRecord,\n\t\t\t\t\tundefined,\n\t\t\t\t\ttrue,\n\t\t\t\t\tedits\n\t\t\t\t);\n\t\t\t}\n\t\t} catch ( _error ) {\n\t\t\thasError = true;\n\t\t\terror = _error;\n\t\t}\n\t\tdispatch( {\n\t\t\ttype: 'SAVE_ENTITY_RECORD_FINISH',\n\t\t\tkind,\n\t\t\tname,\n\t\t\trecordId,\n\t\t\terror,\n\t\t\tisAutosave,\n\t\t} );\n\n\t\tif ( hasError && throwOnError ) {\n\t\t\tthrow error;\n\t\t}\n\n\t\treturn updatedRecord;\n\t} finally {\n\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t}\n};\n\n/**\n * Runs multiple core-data actions at the same time using one API request.\n *\n * Example:\n *\n * ```\n * const [ savedRecord, updatedRecord, deletedRecord ] =\n * await dispatch( 'core' ).__experimentalBatch( [\n * ( { saveEntityRecord } ) => saveEntityRecord( 'root', 'widget', widget ),\n * ( { saveEditedEntityRecord } ) => saveEntityRecord( 'root', 'widget', 123 ),\n * ( { deleteEntityRecord } ) => deleteEntityRecord( 'root', 'widget', 123, null ),\n * ] );\n * ```\n *\n * @param {Array} requests Array of functions which are invoked simultaneously.\n * Each function is passed an object containing\n * `saveEntityRecord`, `saveEditedEntityRecord`, and\n * `deleteEntityRecord`.\n *\n * @return {(thunkArgs: Object) => Promise} A promise that resolves to an array containing the return\n * values of each function given in `requests`.\n */\nexport const __experimentalBatch = ( requests ) => async ( { dispatch } ) => {\n\tconst batch = createBatch();\n\tconst api = {\n\t\tsaveEntityRecord( kind, name, record, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.saveEntityRecord( kind, name, record, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t\tsaveEditedEntityRecord( kind, name, recordId, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.saveEditedEntityRecord( kind, name, recordId, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t\tdeleteEntityRecord( kind, name, recordId, query, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch.deleteEntityRecord( kind, name, recordId, query, {\n\t\t\t\t\t...options,\n\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t} )\n\t\t\t);\n\t\t},\n\t};\n\tconst resultPromises = requests.map( ( request ) => request( api ) );\n\tconst [ , ...results ] = await Promise.all( [\n\t\tbatch.run(),\n\t\t...resultPromises,\n\t] );\n\treturn results;\n};\n\n/**\n * Action triggered to save an entity record's edits.\n *\n * @param {string} kind Kind of the entity.\n * @param {string} name Name of the entity.\n * @param {Object} recordId ID of the record.\n * @param {Object} options Saving options.\n */\nexport const saveEditedEntityRecord = (\n\tkind,\n\tname,\n\trecordId,\n\toptions\n) => async ( { select, dispatch } ) => {\n\tif ( ! select.hasEditsForEntityRecord( kind, name, recordId ) ) {\n\t\treturn;\n\t}\n\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind ) );\n\tconst entityConfig = find( configs, { kind, name } );\n\tif ( ! entityConfig ) {\n\t\treturn;\n\t}\n\tconst entityIdKey = entityConfig.key || DEFAULT_ENTITY_KEY;\n\n\tconst edits = select.getEntityRecordNonTransientEdits(\n\t\tkind,\n\t\tname,\n\t\trecordId\n\t);\n\tconst record = { [ entityIdKey ]: recordId, ...edits };\n\treturn await dispatch.saveEntityRecord( kind, name, record, options );\n};\n\n/**\n * Action triggered to save only specified properties for the entity.\n *\n * @param {string} kind Kind of the entity.\n * @param {string} name Name of the entity.\n * @param {Object} recordId ID of the record.\n * @param {Array} itemsToSave List of entity properties to save.\n * @param {Object} options Saving options.\n */\nexport const __experimentalSaveSpecifiedEntityEdits = (\n\tkind,\n\tname,\n\trecordId,\n\titemsToSave,\n\toptions\n) => async ( { select, dispatch } ) => {\n\tif ( ! select.hasEditsForEntityRecord( kind, name, recordId ) ) {\n\t\treturn;\n\t}\n\tconst edits = select.getEntityRecordNonTransientEdits(\n\t\tkind,\n\t\tname,\n\t\trecordId\n\t);\n\tconst editsToSave = {};\n\tfor ( const edit in edits ) {\n\t\tif ( itemsToSave.some( ( item ) => item === edit ) ) {\n\t\t\teditsToSave[ edit ] = edits[ edit ];\n\t\t}\n\t}\n\treturn await dispatch.saveEntityRecord( kind, name, editsToSave, options );\n};\n\n/**\n * Returns an action object used in signalling that Upload permissions have been received.\n *\n * @deprecated since WP 5.9, use receiveUserPermission instead.\n *\n * @param {boolean} hasUploadPermissions Does the user have permission to upload files?\n *\n * @return {Object} Action object.\n */\nexport function receiveUploadPermissions( hasUploadPermissions ) {\n\tdeprecated( \"wp.data.dispatch( 'core' ).receiveUploadPermissions\", {\n\t\tsince: '5.9',\n\t\talternative: 'receiveUserPermission',\n\t} );\n\n\treturn receiveUserPermission( 'create/media', hasUploadPermissions );\n}\n\n/**\n * Returns an action object used in signalling that the current user has\n * permission to perform an action on a REST resource.\n *\n * @param {string} key A key that represents the action and REST resource.\n * @param {boolean} isAllowed Whether or not the user can perform the action.\n *\n * @return {Object} Action object.\n */\nexport function receiveUserPermission( key, isAllowed ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_PERMISSION',\n\t\tkey,\n\t\tisAllowed,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the autosaves for a\n * post have been received.\n *\n * @param {number} postId The id of the post that is parent to the autosave.\n * @param {Array|Object} autosaves An array of autosaves or singular autosave object.\n *\n * @return {Object} Action object.\n */\nexport function receiveAutosaves( postId, autosaves ) {\n\treturn {\n\t\ttype: 'RECEIVE_AUTOSAVES',\n\t\tpostId,\n\t\tautosaves: castArray( autosaves ),\n\t};\n}\n"]}
@@ -15,11 +15,14 @@ import { __ } from '@wordpress/i18n';
15
15
  import { addEntities } from './actions';
16
16
  export const DEFAULT_ENTITY_KEY = 'id';
17
17
  const POST_RAW_ATTRIBUTES = ['title', 'excerpt', 'content'];
18
- export const defaultEntities = [{
18
+ export const rootEntitiesConfig = [{
19
19
  label: __('Base'),
20
20
  name: '__unstableBase',
21
21
  kind: 'root',
22
- baseURL: '/'
22
+ baseURL: '/',
23
+ baseURLParams: {
24
+ _fields: ['description', 'gmt_offset', 'home', 'name', 'site_icon', 'site_icon_url', 'site_logo', 'timezone_string', 'url'].join(',')
25
+ }
23
26
  }, {
24
27
  label: __('Site'),
25
28
  name: 'site',
@@ -46,7 +49,8 @@ export const defaultEntities = [{
46
49
  context: 'edit'
47
50
  },
48
51
  plural: 'mediaItems',
49
- label: __('Media')
52
+ label: __('Media'),
53
+ rawAttributes: ['caption', 'title', 'description']
50
54
  }, {
51
55
  name: 'taxonomy',
52
56
  kind: 'root',
@@ -179,11 +183,11 @@ export const defaultEntities = [{
179
183
  },
180
184
  key: 'plugin'
181
185
  }];
182
- export const kinds = [{
183
- name: 'postType',
186
+ export const additionalEntityConfigLoaders = [{
187
+ kind: 'postType',
184
188
  loadEntities: loadPostTypeEntities
185
189
  }, {
186
- name: 'taxonomy',
190
+ kind: 'taxonomy',
187
191
  loadEntities: loadTaxonomyEntities
188
192
  }];
189
193
  /**
@@ -281,6 +285,15 @@ async function loadTaxonomyEntities() {
281
285
  /**
282
286
  * Returns the entity's getter method name given its kind and name.
283
287
  *
288
+ * @example
289
+ * ```js
290
+ * const nameSingular = getMethodName( 'root', 'theme', 'get' );
291
+ * // nameSingular is getRootTheme
292
+ *
293
+ * const namePlural = getMethodName( 'root', 'theme', 'set' );
294
+ * // namePlural is setRootThemes
295
+ * ```
296
+ *
284
297
  * @param {string} kind Entity kind.
285
298
  * @param {string} name Entity name.
286
299
  * @param {string} prefix Function prefix.
@@ -293,13 +306,13 @@ async function loadTaxonomyEntities() {
293
306
  export const getMethodName = function (kind, name) {
294
307
  let prefix = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'get';
295
308
  let usePlural = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
296
- const entity = find(defaultEntities, {
309
+ const entityConfig = find(rootEntitiesConfig, {
297
310
  kind,
298
311
  name
299
312
  });
300
313
  const kindPrefix = kind === 'root' ? '' : upperFirst(camelCase(kind));
301
314
  const nameSuffix = upperFirst(camelCase(name)) + (usePlural ? 's' : '');
302
- const suffix = usePlural && entity.plural ? upperFirst(camelCase(entity.plural)) : nameSuffix;
315
+ const suffix = usePlural && entityConfig !== null && entityConfig !== void 0 && entityConfig.plural ? upperFirst(camelCase(entityConfig.plural)) : nameSuffix;
303
316
  return `${prefix}${kindPrefix}${suffix}`;
304
317
  };
305
318
  /**
@@ -307,30 +320,30 @@ export const getMethodName = function (kind, name) {
307
320
  *
308
321
  * @param {string} kind Kind
309
322
  *
310
- * @return {Array} Entities
323
+ * @return {(thunkArgs: object) => Promise<Array>} Entities
311
324
  */
312
325
 
313
- export const getKindEntities = kind => async _ref => {
326
+ export const getOrLoadEntitiesConfig = kind => async _ref => {
314
327
  let {
315
328
  select,
316
329
  dispatch
317
330
  } = _ref;
318
- let entities = select.getEntitiesByKind(kind);
331
+ let configs = select.getEntitiesConfig(kind);
319
332
 
320
- if (entities && entities.length !== 0) {
321
- return entities;
333
+ if (configs && configs.length !== 0) {
334
+ return configs;
322
335
  }
323
336
 
324
- const kindConfig = find(kinds, {
325
- name: kind
337
+ const loader = find(additionalEntityConfigLoaders, {
338
+ kind
326
339
  });
327
340
 
328
- if (!kindConfig) {
341
+ if (!loader) {
329
342
  return [];
330
343
  }
331
344
 
332
- entities = await kindConfig.loadEntities();
333
- dispatch(addEntities(entities));
334
- return entities;
345
+ configs = await loader.loadEntities();
346
+ dispatch(addEntities(configs));
347
+ return configs;
335
348
  };
336
349
  //# sourceMappingURL=entities.js.map