@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.
- package/CHANGELOG.md +7 -0
- package/README.md +41 -8
- package/build/actions.js +61 -41
- package/build/actions.js.map +1 -1
- package/build/entities.js +36 -23
- package/build/entities.js.map +1 -1
- package/build/entity-provider.js +46 -44
- package/build/entity-provider.js.map +1 -1
- package/build/entity-types/{base-entity-types.js → base-entity-records.js} +9 -9
- package/build/entity-types/base-entity-records.js.map +1 -0
- package/build/fetch/__experimental-fetch-link-suggestions.js +1 -1
- package/build/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
- package/build/fetch/__experimental-fetch-url-data.js +1 -1
- package/build/fetch/__experimental-fetch-url-data.js.map +1 -1
- package/build/hooks/use-entity-record.js +15 -5
- package/build/hooks/use-entity-record.js.map +1 -1
- package/build/hooks/use-entity-records.js +17 -5
- package/build/hooks/use-entity-records.js.map +1 -1
- package/build/index.js +9 -21
- package/build/index.js.map +1 -1
- package/build/queried-data/actions.js +4 -4
- package/build/queried-data/actions.js.map +1 -1
- package/build/queried-data/get-query-parts.js +7 -3
- package/build/queried-data/get-query-parts.js.map +1 -1
- package/build/queried-data/reducer.js +8 -6
- package/build/queried-data/reducer.js.map +1 -1
- package/build/reducer.js +16 -16
- package/build/reducer.js.map +1 -1
- package/build/resolvers.js +17 -23
- package/build/resolvers.js.map +1 -1
- package/build/selectors.js +92 -51
- package/build/selectors.js.map +1 -1
- package/build/utils/conservative-map-item.js +1 -1
- package/build/utils/conservative-map-item.js.map +1 -1
- package/build/utils/is-raw-attribute.js +1 -1
- package/build/utils/is-raw-attribute.js.map +1 -1
- package/build-module/actions.js +62 -42
- package/build-module/actions.js.map +1 -1
- package/build-module/entities.js +32 -19
- package/build-module/entities.js.map +1 -1
- package/build-module/entity-provider.js +47 -45
- package/build-module/entity-provider.js.map +1 -1
- package/build-module/entity-types/{base-entity-types.js → base-entity-records.js} +7 -7
- package/build-module/entity-types/base-entity-records.js.map +1 -0
- package/build-module/fetch/__experimental-fetch-link-suggestions.js +1 -1
- package/build-module/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
- package/build-module/fetch/__experimental-fetch-url-data.js +1 -1
- package/build-module/fetch/__experimental-fetch-url-data.js.map +1 -1
- package/build-module/hooks/use-entity-record.js +15 -5
- package/build-module/hooks/use-entity-record.js.map +1 -1
- package/build-module/hooks/use-entity-records.js +17 -5
- package/build-module/hooks/use-entity-records.js.map +1 -1
- package/build-module/index.js +10 -22
- package/build-module/index.js.map +1 -1
- package/build-module/queried-data/actions.js +4 -4
- package/build-module/queried-data/actions.js.map +1 -1
- package/build-module/queried-data/get-query-parts.js +7 -3
- package/build-module/queried-data/get-query-parts.js.map +1 -1
- package/build-module/queried-data/reducer.js +8 -6
- package/build-module/queried-data/reducer.js.map +1 -1
- package/build-module/reducer.js +17 -17
- package/build-module/reducer.js.map +1 -1
- package/build-module/resolvers.js +18 -24
- package/build-module/resolvers.js.map +1 -1
- package/build-module/selectors.js +88 -51
- package/build-module/selectors.js.map +1 -1
- package/build-module/utils/conservative-map-item.js +1 -1
- package/build-module/utils/conservative-map-item.js.map +1 -1
- package/build-module/utils/is-raw-attribute.js +1 -1
- package/build-module/utils/is-raw-attribute.js.map +1 -1
- package/package.json +11 -11
- package/src/actions.js +62 -42
- package/src/entities.js +43 -17
- package/src/entity-provider.js +50 -44
- package/src/entity-types/attachment.ts +5 -5
- package/src/entity-types/{base-entity-types.ts → base-entity-records.ts} +5 -5
- package/src/entity-types/comment.ts +5 -5
- package/src/entity-types/helpers.ts +1 -1
- package/src/entity-types/index.ts +4 -4
- package/src/entity-types/menu-location.ts +5 -5
- package/src/entity-types/nav-menu-item.ts +10 -5
- package/src/entity-types/nav-menu.ts +5 -5
- package/src/entity-types/navigation-area.ts +5 -5
- package/src/entity-types/page.ts +5 -5
- package/src/entity-types/plugin.ts +10 -5
- package/src/entity-types/post.ts +5 -5
- package/src/entity-types/settings.ts +10 -5
- package/src/entity-types/sidebar.ts +6 -7
- package/src/entity-types/taxonomy.ts +5 -5
- package/src/entity-types/theme.ts +5 -5
- package/src/entity-types/type.ts +5 -5
- package/src/entity-types/user.ts +10 -5
- package/src/entity-types/widget-type.ts +5 -5
- package/src/entity-types/widget.ts +5 -5
- package/src/entity-types/wp-template-part.ts +5 -5
- package/src/entity-types/wp-template.ts +5 -5
- package/src/fetch/__experimental-fetch-link-suggestions.js +1 -1
- package/src/fetch/__experimental-fetch-url-data.js +1 -0
- package/src/hooks/use-entity-record.ts +19 -8
- package/src/hooks/use-entity-records.ts +26 -9
- package/src/index.js +10 -15
- package/src/locks/test/selectors.js +4 -4
- package/src/queried-data/actions.js +4 -4
- package/src/queried-data/get-query-parts.js +5 -5
- package/src/queried-data/reducer.js +6 -6
- package/src/reducer.js +17 -17
- package/src/resolvers.js +25 -30
- package/src/selectors.js +92 -53
- package/src/test/actions.js +138 -33
- package/src/test/entities.js +11 -11
- package/src/test/reducer.js +4 -4
- package/src/test/resolvers.js +5 -5
- package/src/test/selectors.js +22 -22
- package/src/utils/conservative-map-item.js +1 -1
- package/src/utils/is-raw-attribute.js +1 -1
- package/src/utils/test/is-raw-attribute.js +4 -4
- package/build/entity-types/base-entity-types.js.map +0 -1
- 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
|
|
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"]}
|
package/build-module/actions.js
CHANGED
|
@@ -15,7 +15,7 @@ import deprecated from '@wordpress/deprecated';
|
|
|
15
15
|
*/
|
|
16
16
|
|
|
17
17
|
import { receiveItems, removeItems, receiveQueriedItems } from './queried-data';
|
|
18
|
-
import {
|
|
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
|
|
200
|
-
* @param {string} name
|
|
201
|
-
* @param {string} recordId
|
|
202
|
-
* @param {?Object} query
|
|
203
|
-
*
|
|
204
|
-
* @param {Object} [options]
|
|
205
|
-
* @param {Function} [options.__unstableFetch]
|
|
206
|
-
*
|
|
207
|
-
*
|
|
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
|
|
219
|
-
const
|
|
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 (!
|
|
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', '
|
|
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 = `${
|
|
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
|
|
302
|
+
const entityConfig = select.getEntityConfig(kind, name);
|
|
293
303
|
|
|
294
|
-
if (!
|
|
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
|
-
} =
|
|
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
|
|
399
|
-
* @param {string} name
|
|
400
|
-
* @param {Object} record
|
|
401
|
-
* @param {Object} options
|
|
402
|
-
* @param {boolean} [options.isAutosave=false]
|
|
403
|
-
* @param {Function} [options.__unstableFetch]
|
|
404
|
-
*
|
|
405
|
-
*
|
|
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
|
|
420
|
-
const
|
|
432
|
+
const configs = await dispatch(getOrLoadEntitiesConfig(kind));
|
|
433
|
+
const entityConfig = find(configs, {
|
|
421
434
|
kind,
|
|
422
435
|
name
|
|
423
436
|
});
|
|
424
437
|
|
|
425
|
-
if (!
|
|
438
|
+
if (!entityConfig || entityConfig !== null && entityConfig !== void 0 && entityConfig.__experimentalNoFetch) {
|
|
426
439
|
return;
|
|
427
440
|
}
|
|
428
441
|
|
|
429
|
-
const entityIdKey =
|
|
442
|
+
const entityIdKey = entityConfig.key || DEFAULT_ENTITY_KEY;
|
|
430
443
|
const recordId = record[entityIdKey];
|
|
431
|
-
const lock = await dispatch.__unstableAcquireStoreLock(STORE_NAME, ['entities', '
|
|
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 = `${
|
|
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 (
|
|
538
|
+
if (entityConfig.__unstablePrePersist) {
|
|
525
539
|
edits = { ...edits,
|
|
526
|
-
...
|
|
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
|
|
627
|
-
const
|
|
646
|
+
const configs = await dispatch(getOrLoadEntitiesConfig(kind));
|
|
647
|
+
const entityConfig = find(configs, {
|
|
628
648
|
kind,
|
|
629
649
|
name
|
|
630
650
|
});
|
|
631
651
|
|
|
632
|
-
if (!
|
|
652
|
+
if (!entityConfig) {
|
|
633
653
|
return;
|
|
634
654
|
}
|
|
635
655
|
|
|
636
|
-
const entityIdKey =
|
|
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":"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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 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"]}
|
package/build-module/entities.js
CHANGED
|
@@ -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
|
|
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
|
|
183
|
-
|
|
186
|
+
export const additionalEntityConfigLoaders = [{
|
|
187
|
+
kind: 'postType',
|
|
184
188
|
loadEntities: loadPostTypeEntities
|
|
185
189
|
}, {
|
|
186
|
-
|
|
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
|
|
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 &&
|
|
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
|
|
326
|
+
export const getOrLoadEntitiesConfig = kind => async _ref => {
|
|
314
327
|
let {
|
|
315
328
|
select,
|
|
316
329
|
dispatch
|
|
317
330
|
} = _ref;
|
|
318
|
-
let
|
|
331
|
+
let configs = select.getEntitiesConfig(kind);
|
|
319
332
|
|
|
320
|
-
if (
|
|
321
|
-
return
|
|
333
|
+
if (configs && configs.length !== 0) {
|
|
334
|
+
return configs;
|
|
322
335
|
}
|
|
323
336
|
|
|
324
|
-
const
|
|
325
|
-
|
|
337
|
+
const loader = find(additionalEntityConfigLoaders, {
|
|
338
|
+
kind
|
|
326
339
|
});
|
|
327
340
|
|
|
328
|
-
if (!
|
|
341
|
+
if (!loader) {
|
|
329
342
|
return [];
|
|
330
343
|
}
|
|
331
344
|
|
|
332
|
-
|
|
333
|
-
dispatch(addEntities(
|
|
334
|
-
return
|
|
345
|
+
configs = await loader.loadEntities();
|
|
346
|
+
dispatch(addEntities(configs));
|
|
347
|
+
return configs;
|
|
335
348
|
};
|
|
336
349
|
//# sourceMappingURL=entities.js.map
|