@wordpress/core-data 4.0.2 → 4.0.6

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 (65) hide show
  1. package/README.md +3 -5
  2. package/build/actions.js +79 -34
  3. package/build/actions.js.map +1 -1
  4. package/build/entities.js +51 -9
  5. package/build/entities.js.map +1 -1
  6. package/build/fetch/__experimental-fetch-url-data.js +1 -1
  7. package/build/fetch/__experimental-fetch-url-data.js.map +1 -1
  8. package/build/index.js +0 -7
  9. package/build/index.js.map +1 -1
  10. package/build/queried-data/get-query-parts.js +2 -0
  11. package/build/queried-data/get-query-parts.js.map +1 -1
  12. package/build/reducer.js +16 -18
  13. package/build/reducer.js.map +1 -1
  14. package/build/resolvers.js +48 -31
  15. package/build/resolvers.js.map +1 -1
  16. package/build/selectors.js +70 -10
  17. package/build/selectors.js.map +1 -1
  18. package/build/utils/forward-resolver.js +23 -0
  19. package/build/utils/forward-resolver.js.map +1 -0
  20. package/build/utils/index.js +3 -3
  21. package/build/utils/index.js.map +1 -1
  22. package/build-module/actions.js +74 -33
  23. package/build-module/actions.js.map +1 -1
  24. package/build-module/entities.js +51 -9
  25. package/build-module/entities.js.map +1 -1
  26. package/build-module/fetch/__experimental-fetch-url-data.js +1 -1
  27. package/build-module/fetch/__experimental-fetch-url-data.js.map +1 -1
  28. package/build-module/index.js +0 -5
  29. package/build-module/index.js.map +1 -1
  30. package/build-module/queried-data/get-query-parts.js +2 -0
  31. package/build-module/queried-data/get-query-parts.js.map +1 -1
  32. package/build-module/reducer.js +14 -16
  33. package/build-module/reducer.js.map +1 -1
  34. package/build-module/resolvers.js +51 -37
  35. package/build-module/resolvers.js.map +1 -1
  36. package/build-module/selectors.js +64 -8
  37. package/build-module/selectors.js.map +1 -1
  38. package/build-module/utils/forward-resolver.js +15 -0
  39. package/build-module/utils/forward-resolver.js.map +1 -0
  40. package/build-module/utils/index.js +1 -1
  41. package/build-module/utils/index.js.map +1 -1
  42. package/package.json +10 -11
  43. package/src/actions.js +83 -52
  44. package/src/entities.js +36 -6
  45. package/src/fetch/__experimental-fetch-url-data.js +1 -1
  46. package/src/index.js +0 -3
  47. package/src/queried-data/get-query-parts.js +2 -0
  48. package/src/reducer.js +14 -17
  49. package/src/resolvers.js +67 -42
  50. package/src/selectors.js +143 -35
  51. package/src/test/actions.js +116 -37
  52. package/src/test/selectors.js +56 -1
  53. package/src/utils/forward-resolver.js +14 -0
  54. package/src/utils/index.js +1 -1
  55. package/build/controls.js +0 -44
  56. package/build/controls.js.map +0 -1
  57. package/build/utils/if-not-resolved.js +0 -31
  58. package/build/utils/if-not-resolved.js.map +0 -1
  59. package/build-module/controls.js +0 -31
  60. package/build-module/controls.js.map +0 -1
  61. package/build-module/utils/if-not-resolved.js +0 -23
  62. package/build-module/utils/if-not-resolved.js.map +0 -1
  63. package/src/controls.js +0 -31
  64. package/src/utils/if-not-resolved.js +0 -22
  65. package/src/utils/test/if-not-resolved.js +0 -76
package/README.md CHANGED
@@ -12,7 +12,7 @@ Install the module
12
12
  npm install @wordpress/core-data --save
13
13
  ```
14
14
 
15
- _This package assumes that your code will run in an **ES2015+** environment. If you're using an environment that has limited or no support for ES2015+ such as IE browsers then using [core-js](https://github.com/zloirock/core-js) will add polyfills for these methods._
15
+ _This package assumes that your code will run in an **ES2015+** environment. If you're using an environment that has limited or no support for such language features and APIs, you should include [the polyfill shipped in `@wordpress/babel-preset-default`](https://github.com/WordPress/gutenberg/tree/HEAD/packages/babel-preset-default#polyfill) in your code._
16
16
 
17
17
  ## Example
18
18
 
@@ -160,11 +160,9 @@ _Returns_
160
160
 
161
161
  ### receiveThemeSupports
162
162
 
163
- Returns an action object used in signalling that the index has been received.
164
-
165
- _Parameters_
163
+ > **Deprecated** since WP 5.9, this is not useful anymore, use the selector direclty.
166
164
 
167
- - _themeSupports_ `Object`: Theme support for the current theme.
165
+ Returns an action object used in signalling that the index has been received.
168
166
 
169
167
  _Returns_
170
168
 
package/build/actions.js CHANGED
@@ -10,33 +10,32 @@ exports.receiveCurrentUser = receiveCurrentUser;
10
10
  exports.addEntities = addEntities;
11
11
  exports.receiveEntityRecords = receiveEntityRecords;
12
12
  exports.receiveCurrentTheme = receiveCurrentTheme;
13
+ exports.__experimentalReceiveCurrentGlobalStylesId = __experimentalReceiveCurrentGlobalStylesId;
14
+ exports.__experimentalReceiveThemeBaseGlobalStyles = __experimentalReceiveThemeBaseGlobalStyles;
13
15
  exports.receiveThemeSupports = receiveThemeSupports;
14
16
  exports.receiveEmbedPreview = receiveEmbedPreview;
15
17
  exports.__unstableCreateUndoLevel = __unstableCreateUndoLevel;
16
- exports.__experimentalBatch = __experimentalBatch;
17
18
  exports.receiveUploadPermissions = receiveUploadPermissions;
18
19
  exports.receiveUserPermission = receiveUserPermission;
19
20
  exports.receiveAutosaves = receiveAutosaves;
20
- exports.__experimentalSaveSpecifiedEntityEdits = exports.saveEditedEntityRecord = exports.saveEntityRecord = exports.redo = exports.undo = exports.editEntityRecord = exports.deleteEntityRecord = void 0;
21
+ exports.__experimentalSaveSpecifiedEntityEdits = exports.saveEditedEntityRecord = exports.__experimentalBatch = exports.saveEntityRecord = exports.redo = exports.undo = exports.editEntityRecord = exports.deleteEntityRecord = void 0;
21
22
 
22
23
  var _lodash = require("lodash");
23
24
 
24
25
  var _uuid = require("uuid");
25
26
 
26
- var _dataControls = require("@wordpress/data-controls");
27
-
28
27
  var _apiFetch = _interopRequireDefault(require("@wordpress/api-fetch"));
29
28
 
30
29
  var _url = require("@wordpress/url");
31
30
 
31
+ var _deprecated = _interopRequireDefault(require("@wordpress/deprecated"));
32
+
32
33
  var _queriedData = require("./queried-data");
33
34
 
34
35
  var _entities = require("./entities");
35
36
 
36
37
  var _batch = require("./batch");
37
38
 
38
- var _controls = require("./controls");
39
-
40
39
  var _name = require("./name");
41
40
 
42
41
  /**
@@ -147,19 +146,53 @@ function receiveCurrentTheme(currentTheme) {
147
146
  currentTheme
148
147
  };
149
148
  }
149
+ /**
150
+ * Returns an action object used in signalling that the current global styles id has been received.
151
+ *
152
+ * @param {string} currentGlobalStylesId The current global styles id.
153
+ *
154
+ * @return {Object} Action object.
155
+ */
156
+
157
+
158
+ function __experimentalReceiveCurrentGlobalStylesId(currentGlobalStylesId) {
159
+ return {
160
+ type: 'RECEIVE_CURRENT_GLOBAL_STYLES_ID',
161
+ id: currentGlobalStylesId
162
+ };
163
+ }
164
+ /**
165
+ * Returns an action object used in signalling that the theme base global styles have been received
166
+ *
167
+ * @param {string} stylesheet The theme's identifier
168
+ * @param {Object} globalStyles The global styles object.
169
+ *
170
+ * @return {Object} Action object.
171
+ */
172
+
173
+
174
+ function __experimentalReceiveThemeBaseGlobalStyles(stylesheet, globalStyles) {
175
+ return {
176
+ type: 'RECEIVE_THEME_GLOBAL_STYLES',
177
+ stylesheet,
178
+ globalStyles
179
+ };
180
+ }
150
181
  /**
151
182
  * Returns an action object used in signalling that the index has been received.
152
183
  *
153
- * @param {Object} themeSupports Theme support for the current theme.
184
+ * @deprecated since WP 5.9, this is not useful anymore, use the selector direclty.
154
185
  *
155
186
  * @return {Object} Action object.
156
187
  */
157
188
 
158
189
 
159
- function receiveThemeSupports(themeSupports) {
190
+ function receiveThemeSupports() {
191
+ (0, _deprecated.default)("wp.data.dispatch( 'core' ).receiveThemeSupports", {
192
+ since: '5.9'
193
+ });
160
194
  return {
161
- type: 'RECEIVE_THEME_SUPPORTS',
162
- themeSupports
195
+ type: 'DO_NOTHING'
163
196
  };
164
197
  }
165
198
  /**
@@ -208,7 +241,7 @@ const deleteEntityRecord = (kind, name, recordId, query, {
208
241
  let error;
209
242
  let deletedRecord = false;
210
243
 
211
- if (!entity) {
244
+ if (!entity || entity !== null && entity !== void 0 && entity.__experimentalNoFetch) {
212
245
  return;
213
246
  }
214
247
 
@@ -269,7 +302,7 @@ const deleteEntityRecord = (kind, name, recordId, query, {
269
302
 
270
303
  exports.deleteEntityRecord = deleteEntityRecord;
271
304
 
272
- const editEntityRecord = (kind, name, recordId, edits, options = {}) => async ({
305
+ const editEntityRecord = (kind, name, recordId, edits, options = {}) => ({
273
306
  select,
274
307
  dispatch
275
308
  }) => {
@@ -302,7 +335,7 @@ const editEntityRecord = (kind, name, recordId, edits, options = {}) => async ({
302
335
  }, {}),
303
336
  transientEdits
304
337
  };
305
- return await dispatch({
338
+ dispatch({
306
339
  type: 'EDIT_ENTITY_RECORD',
307
340
  ...edit,
308
341
  meta: {
@@ -414,7 +447,7 @@ const saveEntityRecord = (kind, name, record, {
414
447
  name
415
448
  });
416
449
 
417
- if (!entity) {
450
+ if (!entity || entity !== null && entity !== void 0 && entity.__experimentalNoFetch) {
418
451
  return;
419
452
  }
420
453
 
@@ -430,7 +463,7 @@ const saveEntityRecord = (kind, name, record, {
430
463
  for (const [key, value] of Object.entries(record)) {
431
464
  if (typeof value === 'function') {
432
465
  const evaluatedValue = value(select.getEditedEntityRecord(kind, name, recordId));
433
- await dispatch.editEntityRecord(kind, name, recordId, {
466
+ dispatch.editEntityRecord(kind, name, recordId, {
434
467
  [key]: evaluatedValue
435
468
  }, {
436
469
  undoIgnore: true
@@ -439,7 +472,7 @@ const saveEntityRecord = (kind, name, record, {
439
472
  }
440
473
  }
441
474
 
442
- await dispatch({
475
+ dispatch({
443
476
  type: 'SAVE_ENTITY_RECORD_START',
444
477
  kind,
445
478
  name,
@@ -478,12 +511,11 @@ const saveEntityRecord = (kind, name, record, {
478
511
  }, {
479
512
  status: data.status === 'auto-draft' ? 'draft' : data.status
480
513
  });
481
- const options = {
514
+ updatedRecord = await __unstableFetch({
482
515
  path: `${path}/autosaves`,
483
516
  method: 'POST',
484
517
  data
485
- };
486
- updatedRecord = await __unstableFetch(options); // An autosave may be processed by the server as a regular save
518
+ }); // An autosave may be processed by the server as a regular save
487
519
  // when its update is requested by the author and the post had
488
520
  // draft or auto-draft status.
489
521
 
@@ -507,9 +539,9 @@ const saveEntityRecord = (kind, name, record, {
507
539
 
508
540
  return acc;
509
541
  }, {});
510
- await dispatch.receiveEntityRecords(kind, name, newRecord, undefined, true);
542
+ dispatch.receiveEntityRecords(kind, name, newRecord, undefined, true);
511
543
  } else {
512
- await dispatch.receiveAutosaves(persistedRecord.id, updatedRecord);
544
+ dispatch.receiveAutosaves(persistedRecord.id, updatedRecord);
513
545
  }
514
546
  } else {
515
547
  let edits = record;
@@ -520,13 +552,12 @@ const saveEntityRecord = (kind, name, record, {
520
552
  };
521
553
  }
522
554
 
523
- const options = {
555
+ updatedRecord = await __unstableFetch({
524
556
  path,
525
557
  method: recordId ? 'PUT' : 'POST',
526
558
  data: edits
527
- };
528
- updatedRecord = await __unstableFetch(options);
529
- await dispatch.receiveEntityRecords(kind, name, updatedRecord, undefined, true, edits);
559
+ });
560
+ dispatch.receiveEntityRecords(kind, name, updatedRecord, undefined, true, edits);
530
561
  }
531
562
  } catch (_error) {
532
563
  error = _error;
@@ -542,7 +573,7 @@ const saveEntityRecord = (kind, name, record, {
542
573
  });
543
574
  return updatedRecord;
544
575
  } finally {
545
- await dispatch.__unstableReleaseStoreLock(lock);
576
+ dispatch.__unstableReleaseStoreLock(lock);
546
577
  }
547
578
  };
548
579
  /**
@@ -571,33 +602,34 @@ const saveEntityRecord = (kind, name, record, {
571
602
 
572
603
  exports.saveEntityRecord = saveEntityRecord;
573
604
 
574
- function* __experimentalBatch(requests) {
605
+ const __experimentalBatch = requests => async ({
606
+ dispatch
607
+ }) => {
575
608
  const batch = (0, _batch.createBatch)();
576
- const dispatch = yield (0, _controls.getDispatch)();
577
609
  const api = {
578
610
  saveEntityRecord(kind, name, record, options) {
579
- return batch.add(add => dispatch(_name.STORE_NAME).saveEntityRecord(kind, name, record, { ...options,
611
+ return batch.add(add => dispatch.saveEntityRecord(kind, name, record, { ...options,
580
612
  __unstableFetch: add
581
613
  }));
582
614
  },
583
615
 
584
616
  saveEditedEntityRecord(kind, name, recordId, options) {
585
- return batch.add(add => dispatch(_name.STORE_NAME).saveEditedEntityRecord(kind, name, recordId, { ...options,
617
+ return batch.add(add => dispatch.saveEditedEntityRecord(kind, name, recordId, { ...options,
586
618
  __unstableFetch: add
587
619
  }));
588
620
  },
589
621
 
590
622
  deleteEntityRecord(kind, name, recordId, query, options) {
591
- return batch.add(add => dispatch(_name.STORE_NAME).deleteEntityRecord(kind, name, recordId, query, { ...options,
623
+ return batch.add(add => dispatch.deleteEntityRecord(kind, name, recordId, query, { ...options,
592
624
  __unstableFetch: add
593
625
  }));
594
626
  }
595
627
 
596
628
  };
597
629
  const resultPromises = requests.map(request => request(api));
598
- const [, ...results] = yield (0, _dataControls.__unstableAwaitPromise)(Promise.all([batch.run(), ...resultPromises]));
630
+ const [, ...results] = await Promise.all([batch.run(), ...resultPromises]);
599
631
  return results;
600
- }
632
+ };
601
633
  /**
602
634
  * Action triggered to save an entity record's edits.
603
635
  *
@@ -608,6 +640,8 @@ function* __experimentalBatch(requests) {
608
640
  */
609
641
 
610
642
 
643
+ exports.__experimentalBatch = __experimentalBatch;
644
+
611
645
  const saveEditedEntityRecord = (kind, name, recordId, options) => async ({
612
646
  select,
613
647
  dispatch
@@ -616,9 +650,20 @@ const saveEditedEntityRecord = (kind, name, recordId, options) => async ({
616
650
  return;
617
651
  }
618
652
 
653
+ const entities = await dispatch((0, _entities.getKindEntities)(kind));
654
+ const entity = (0, _lodash.find)(entities, {
655
+ kind,
656
+ name
657
+ });
658
+
659
+ if (!entity) {
660
+ return;
661
+ }
662
+
663
+ const entityIdKey = entity.key || _entities.DEFAULT_ENTITY_KEY;
619
664
  const edits = select.getEntityRecordNonTransientEdits(kind, name, recordId);
620
665
  const record = {
621
- id: recordId,
666
+ [entityIdKey]: recordId,
622
667
  ...edits
623
668
  };
624
669
  return await dispatch.saveEntityRecord(kind, name, record, options);
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/core-data/src/actions.js"],"names":["receiveUserQuery","queryID","users","type","receiveCurrentUser","currentUser","addEntities","entities","receiveEntityRecords","kind","name","records","query","invalidateCache","edits","map","record","status","title","action","receiveCurrentTheme","currentTheme","receiveThemeSupports","themeSupports","receiveEmbedPreview","url","preview","deleteEntityRecord","recordId","__unstableFetch","triggerFetch","dispatch","entity","error","deletedRecord","lock","__unstableAcquireStoreLock","STORE_NAME","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","DEFAULT_ENTITY_KEY","entries","evaluatedValue","updatedRecord","persistedRecord","getCurrentUser","currentUserId","id","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","isAllowed","receiveUserPermission","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 { __unstableAwaitPromise } from '@wordpress/data-controls';\nimport triggerFetch from '@wordpress/api-fetch';\nimport { addQueryArgs } from '@wordpress/url';\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 { getDispatch } from './controls';\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 index has been received.\n *\n * @param {Object} themeSupports Theme support for the current theme.\n *\n * @return {Object} Action object.\n */\nexport function receiveThemeSupports( themeSupports ) {\n\treturn {\n\t\ttype: 'RECEIVE_THEME_SUPPORTS',\n\t\tthemeSupports,\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 = triggerFetch } = {}\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 ) {\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) => async ( { 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\treturn await dispatch( {\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 *\n * @return {undefined}\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 *\n * @return {undefined}\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 = triggerFetch } = {}\n) => async ( { select, resolveSelect, dispatch } ) => {\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\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\tawait dispatch.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\tawait dispatch( {\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 = 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\tconst options = {\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\t\t\t\tupdatedRecord = await __unstableFetch( options );\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\tawait dispatch.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\tawait dispatch.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\tconst options = {\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\tupdatedRecord = await __unstableFetch( options );\n\t\t\t\tawait dispatch.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\tawait dispatch.__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 {Promise} A promise that resolves to an array containing the return\n * values of each function given in `requests`.\n */\nexport function* __experimentalBatch( requests ) {\n\tconst batch = createBatch();\n\tconst dispatch = yield getDispatch();\n\tconst api = {\n\t\tsaveEntityRecord( kind, name, record, options ) {\n\t\t\treturn batch.add( ( add ) =>\n\t\t\t\tdispatch( STORE_NAME ).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( STORE_NAME ).saveEditedEntityRecord(\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...options,\n\t\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t\t}\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( STORE_NAME ).deleteEntityRecord(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\trecordId,\n\t\t\t\t\tquery,\n\t\t\t\t\t{\n\t\t\t\t\t\t...options,\n\t\t\t\t\t\t__unstableFetch: add,\n\t\t\t\t\t}\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 ] = yield __unstableAwaitPromise(\n\t\tPromise.all( [ batch.run(), ...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 edits = select.getEntityRecordNonTransientEdits(\n\t\tkind,\n\t\tname,\n\t\trecordId\n\t);\n\tconst record = { id: 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 * @param {boolean} hasUploadPermissions Does the user have permission to upload files?\n *\n * @return {Object} Action object.\n */\nexport function receiveUploadPermissions( hasUploadPermissions ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_PERMISSION',\n\t\tkey: 'create/media',\n\t\tisAllowed: hasUploadPermissions,\n\t};\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":["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","receiveThemeSupports","since","receiveEmbedPreview","url","preview","deleteEntityRecord","recordId","__unstableFetch","apiFetch","dispatch","entity","error","deletedRecord","__experimentalNoFetch","lock","__unstableAcquireStoreLock","STORE_NAME","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","DEFAULT_ENTITY_KEY","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","isAllowed","receiveUserPermission","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 { 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 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 *\n * @return {undefined}\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 *\n * @return {undefined}\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 = 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 {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 * @param {boolean} hasUploadPermissions Does the user have permission to upload files?\n *\n * @return {Object} Action object.\n */\nexport function receiveUploadPermissions( hasUploadPermissions ) {\n\treturn {\n\t\ttype: 'RECEIVE_USER_PERMISSION',\n\t\tkey: 'create/media',\n\t\tisAllowed: hasUploadPermissions,\n\t};\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"]}
package/build/entities.js CHANGED
@@ -33,7 +33,7 @@ const defaultEntities = [{
33
33
  label: (0, _i18n.__)('Base'),
34
34
  name: '__unstableBase',
35
35
  kind: 'root',
36
- baseURL: ''
36
+ baseURL: '/'
37
37
  }, {
38
38
  label: (0, _i18n.__)('Site'),
39
39
  name: 'site',
@@ -122,7 +122,7 @@ const defaultEntities = [{
122
122
  }, {
123
123
  name: 'menu',
124
124
  kind: 'root',
125
- baseURL: '/__experimental/menus',
125
+ baseURL: '/wp/v2/menus',
126
126
  baseURLParams: {
127
127
  context: 'edit'
128
128
  },
@@ -131,22 +131,58 @@ const defaultEntities = [{
131
131
  }, {
132
132
  name: 'menuItem',
133
133
  kind: 'root',
134
- baseURL: '/__experimental/menu-items',
134
+ baseURL: '/wp/v2/menu-items',
135
135
  baseURLParams: {
136
136
  context: 'edit'
137
137
  },
138
138
  plural: 'menuItems',
139
- label: (0, _i18n.__)('Menu Item')
139
+ label: (0, _i18n.__)('Menu Item'),
140
+ rawAttributes: ['title', 'content']
140
141
  }, {
141
142
  name: 'menuLocation',
142
143
  kind: 'root',
143
- baseURL: '/__experimental/menu-locations',
144
+ baseURL: '/wp/v2/menu-locations',
144
145
  baseURLParams: {
145
146
  context: 'edit'
146
147
  },
147
148
  plural: 'menuLocations',
148
149
  label: (0, _i18n.__)('Menu Location'),
149
150
  key: 'name'
151
+ }, {
152
+ name: 'navigationArea',
153
+ kind: 'root',
154
+ baseURL: '/wp/v2/block-navigation-areas',
155
+ baseURLParams: {
156
+ context: 'edit'
157
+ },
158
+ plural: 'navigationAreas',
159
+ label: (0, _i18n.__)('Navigation Area'),
160
+ key: 'name',
161
+ getTitle: record => record === null || record === void 0 ? void 0 : record.description
162
+ }, {
163
+ label: (0, _i18n.__)('Global Styles'),
164
+ name: 'globalStyles',
165
+ kind: 'root',
166
+ baseURL: '/wp/v2/global-styles',
167
+ baseURLParams: {
168
+ context: 'edit'
169
+ },
170
+ plural: 'globalStylesVariations',
171
+ // should be different than name
172
+ getTitle: record => {
173
+ var _record$title;
174
+
175
+ return (record === null || record === void 0 ? void 0 : (_record$title = record.title) === null || _record$title === void 0 ? void 0 : _record$title.rendered) || (record === null || record === void 0 ? void 0 : record.title);
176
+ }
177
+ }, {
178
+ label: (0, _i18n.__)('Themes'),
179
+ name: 'theme',
180
+ kind: 'root',
181
+ baseURL: '/wp/v2/themes',
182
+ baseURLParams: {
183
+ context: 'edit'
184
+ },
185
+ key: 'stylesheet'
150
186
  }];
151
187
  exports.defaultEntities = defaultEntities;
152
188
  const kinds = [{
@@ -197,10 +233,13 @@ async function loadPostTypeEntities() {
197
233
  path: '/wp/v2/types?context=edit'
198
234
  });
199
235
  return (0, _lodash.map)(postTypes, (postType, name) => {
236
+ var _postType$rest_namesp;
237
+
200
238
  const isTemplate = ['wp_template', 'wp_template_part'].includes(name);
239
+ const namespace = (_postType$rest_namesp = postType === null || postType === void 0 ? void 0 : postType.rest_namespace) !== null && _postType$rest_namesp !== void 0 ? _postType$rest_namesp : 'wp/v2';
201
240
  return {
202
241
  kind: 'postType',
203
- baseURL: '/wp/v2/' + postType.rest_base,
242
+ baseURL: `/${namespace}/${postType.rest_base}`,
204
243
  baseURLParams: {
205
244
  context: 'edit'
206
245
  },
@@ -215,9 +254,9 @@ async function loadPostTypeEntities() {
215
254
  },
216
255
  rawAttributes: POST_RAW_ATTRIBUTES,
217
256
  getTitle: record => {
218
- var _record$title;
257
+ var _record$title2;
219
258
 
220
- return (record === null || record === void 0 ? void 0 : (_record$title = record.title) === null || _record$title === void 0 ? void 0 : _record$title.rendered) || (record === null || record === void 0 ? void 0 : record.title) || (isTemplate ? (0, _lodash.startCase)(record.slug) : String(record.id));
259
+ return (record === null || record === void 0 ? void 0 : (_record$title2 = record.title) === null || _record$title2 === void 0 ? void 0 : _record$title2.rendered) || (record === null || record === void 0 ? void 0 : record.title) || (isTemplate ? (0, _lodash.startCase)(record.slug) : String(record.id));
221
260
  },
222
261
  __unstablePrePersist: isTemplate ? undefined : prePersistPostType,
223
262
  __unstable_rest_base: postType.rest_base
@@ -236,9 +275,12 @@ async function loadTaxonomyEntities() {
236
275
  path: '/wp/v2/taxonomies?context=edit'
237
276
  });
238
277
  return (0, _lodash.map)(taxonomies, (taxonomy, name) => {
278
+ var _taxonomy$rest_namesp;
279
+
280
+ const namespace = (_taxonomy$rest_namesp = taxonomy === null || taxonomy === void 0 ? void 0 : taxonomy.rest_namespace) !== null && _taxonomy$rest_namesp !== void 0 ? _taxonomy$rest_namesp : 'wp/v2';
239
281
  return {
240
282
  kind: 'taxonomy',
241
- baseURL: '/wp/v2/' + taxonomy.rest_base,
283
+ baseURL: `/${namespace}/${taxonomy.rest_base}`,
242
284
  baseURLParams: {
243
285
  context: 'edit'
244
286
  },