@wordpress/core-data 6.32.0 → 6.34.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (181) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +3 -3
  3. package/build/actions.js.map +1 -1
  4. package/build/batch/create-batch.js.map +1 -1
  5. package/build/batch/default-processor.js.map +1 -1
  6. package/build/batch/index.js.map +1 -1
  7. package/build/entities.js.map +1 -1
  8. package/build/entity-provider.js.map +1 -1
  9. package/build/entity-types/attachment.js.map +1 -1
  10. package/build/entity-types/base-entity-records.js.map +1 -1
  11. package/build/entity-types/comment.js.map +1 -1
  12. package/build/entity-types/global-styles-revision.js.map +1 -1
  13. package/build/entity-types/helpers.js.map +1 -1
  14. package/build/entity-types/index.js.map +1 -1
  15. package/build/entity-types/menu-location.js.map +1 -1
  16. package/build/entity-types/nav-menu-item.js.map +1 -1
  17. package/build/entity-types/nav-menu.js.map +1 -1
  18. package/build/entity-types/page.js.map +1 -1
  19. package/build/entity-types/plugin.js.map +1 -1
  20. package/build/entity-types/post-revision.js.map +1 -1
  21. package/build/entity-types/post.js.map +1 -1
  22. package/build/entity-types/settings.js.map +1 -1
  23. package/build/entity-types/sidebar.js.map +1 -1
  24. package/build/entity-types/taxonomy.js.map +1 -1
  25. package/build/entity-types/theme.js.map +1 -1
  26. package/build/entity-types/type.js.map +1 -1
  27. package/build/entity-types/user.js.map +1 -1
  28. package/build/entity-types/widget-type.js.map +1 -1
  29. package/build/entity-types/widget.js.map +1 -1
  30. package/build/entity-types/wp-template-part.js.map +1 -1
  31. package/build/entity-types/wp-template.js.map +1 -1
  32. package/build/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
  33. package/build/fetch/__experimental-fetch-url-data.js.map +1 -1
  34. package/build/fetch/index.js.map +1 -1
  35. package/build/footnotes/get-footnotes-order.js.map +1 -1
  36. package/build/footnotes/get-rich-text-values-cached.js.map +1 -1
  37. package/build/footnotes/index.js +9 -3
  38. package/build/footnotes/index.js.map +1 -1
  39. package/build/hooks/constants.js.map +1 -1
  40. package/build/hooks/index.js +1 -1
  41. package/build/hooks/index.js.map +1 -1
  42. package/build/hooks/memoize.js.map +1 -1
  43. package/build/hooks/use-entity-record.js.map +1 -1
  44. package/build/hooks/use-entity-records.js.map +1 -1
  45. package/build/hooks/use-query-select.js.map +1 -1
  46. package/build/hooks/use-resource-permissions.js +4 -0
  47. package/build/hooks/use-resource-permissions.js.map +1 -1
  48. package/build/index.js +1 -1
  49. package/build/index.js.map +1 -1
  50. package/build/locks/actions.js.map +1 -1
  51. package/build/locks/engine.js.map +1 -1
  52. package/build/locks/reducer.js.map +1 -1
  53. package/build/locks/selectors.js.map +1 -1
  54. package/build/locks/utils.js.map +1 -1
  55. package/build/name.js.map +1 -1
  56. package/build/private-apis.js.map +1 -1
  57. package/build/private-selectors.js +3 -5
  58. package/build/private-selectors.js.map +1 -1
  59. package/build/queried-data/actions.js.map +1 -1
  60. package/build/queried-data/get-query-parts.js.map +1 -1
  61. package/build/queried-data/index.js.map +1 -1
  62. package/build/queried-data/reducer.js.map +1 -1
  63. package/build/queried-data/selectors.js +6 -2
  64. package/build/queried-data/selectors.js.map +1 -1
  65. package/build/reducer.js.map +1 -1
  66. package/build/resolvers.js +25 -21
  67. package/build/resolvers.js.map +1 -1
  68. package/build/selectors.js +41 -18
  69. package/build/selectors.js.map +1 -1
  70. package/build/sync.js.map +1 -1
  71. package/build/types.js.map +1 -1
  72. package/build/utils/conservative-map-item.js.map +1 -1
  73. package/build/utils/forward-resolver.js.map +1 -1
  74. package/build/utils/get-nested-value.js.map +1 -1
  75. package/build/utils/get-normalized-comma-separable.js.map +1 -1
  76. package/build/utils/if-matching-action.js.map +1 -1
  77. package/build/utils/index.js.map +1 -1
  78. package/build/utils/is-numeric-id.js.map +1 -1
  79. package/build/utils/is-raw-attribute.js.map +1 -1
  80. package/build/utils/on-sub-key.js.map +1 -1
  81. package/build/utils/replace-action.js.map +1 -1
  82. package/build/utils/set-nested-value.js.map +1 -1
  83. package/build/utils/with-weak-map-cache.js.map +1 -1
  84. package/build-module/actions.js.map +1 -1
  85. package/build-module/batch/create-batch.js.map +1 -1
  86. package/build-module/batch/default-processor.js.map +1 -1
  87. package/build-module/batch/index.js.map +1 -1
  88. package/build-module/entities.js.map +1 -1
  89. package/build-module/entity-provider.js.map +1 -1
  90. package/build-module/entity-types/attachment.js.map +1 -1
  91. package/build-module/entity-types/base-entity-records.js.map +1 -1
  92. package/build-module/entity-types/comment.js.map +1 -1
  93. package/build-module/entity-types/global-styles-revision.js.map +1 -1
  94. package/build-module/entity-types/helpers.js.map +1 -1
  95. package/build-module/entity-types/index.js.map +1 -1
  96. package/build-module/entity-types/menu-location.js.map +1 -1
  97. package/build-module/entity-types/nav-menu-item.js.map +1 -1
  98. package/build-module/entity-types/nav-menu.js.map +1 -1
  99. package/build-module/entity-types/page.js.map +1 -1
  100. package/build-module/entity-types/plugin.js.map +1 -1
  101. package/build-module/entity-types/post-revision.js.map +1 -1
  102. package/build-module/entity-types/post.js.map +1 -1
  103. package/build-module/entity-types/settings.js.map +1 -1
  104. package/build-module/entity-types/sidebar.js.map +1 -1
  105. package/build-module/entity-types/taxonomy.js.map +1 -1
  106. package/build-module/entity-types/theme.js.map +1 -1
  107. package/build-module/entity-types/type.js.map +1 -1
  108. package/build-module/entity-types/user.js.map +1 -1
  109. package/build-module/entity-types/widget-type.js.map +1 -1
  110. package/build-module/entity-types/widget.js.map +1 -1
  111. package/build-module/entity-types/wp-template-part.js.map +1 -1
  112. package/build-module/entity-types/wp-template.js.map +1 -1
  113. package/build-module/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
  114. package/build-module/fetch/__experimental-fetch-url-data.js.map +1 -1
  115. package/build-module/fetch/index.js.map +1 -1
  116. package/build-module/footnotes/get-footnotes-order.js.map +1 -1
  117. package/build-module/footnotes/get-rich-text-values-cached.js.map +1 -1
  118. package/build-module/footnotes/index.js +9 -3
  119. package/build-module/footnotes/index.js.map +1 -1
  120. package/build-module/hooks/constants.js.map +1 -1
  121. package/build-module/hooks/index.js.map +1 -1
  122. package/build-module/hooks/memoize.js.map +1 -1
  123. package/build-module/hooks/use-entity-record.js.map +1 -1
  124. package/build-module/hooks/use-entity-records.js.map +1 -1
  125. package/build-module/hooks/use-query-select.js.map +1 -1
  126. package/build-module/hooks/use-resource-permissions.js +5 -0
  127. package/build-module/hooks/use-resource-permissions.js.map +1 -1
  128. package/build-module/index.js.map +1 -1
  129. package/build-module/locks/actions.js.map +1 -1
  130. package/build-module/locks/engine.js.map +1 -1
  131. package/build-module/locks/reducer.js.map +1 -1
  132. package/build-module/locks/selectors.js.map +1 -1
  133. package/build-module/locks/utils.js.map +1 -1
  134. package/build-module/name.js.map +1 -1
  135. package/build-module/private-apis.js.map +1 -1
  136. package/build-module/private-selectors.js +1 -6
  137. package/build-module/private-selectors.js.map +1 -1
  138. package/build-module/queried-data/actions.js.map +1 -1
  139. package/build-module/queried-data/get-query-parts.js.map +1 -1
  140. package/build-module/queried-data/index.js.map +1 -1
  141. package/build-module/queried-data/reducer.js.map +1 -1
  142. package/build-module/queried-data/selectors.js +5 -1
  143. package/build-module/queried-data/selectors.js.map +1 -1
  144. package/build-module/reducer.js.map +1 -1
  145. package/build-module/resolvers.js +25 -21
  146. package/build-module/resolvers.js.map +1 -1
  147. package/build-module/selectors.js +36 -12
  148. package/build-module/selectors.js.map +1 -1
  149. package/build-module/sync.js.map +1 -1
  150. package/build-module/types.js.map +1 -1
  151. package/build-module/utils/conservative-map-item.js.map +1 -1
  152. package/build-module/utils/forward-resolver.js.map +1 -1
  153. package/build-module/utils/get-nested-value.js.map +1 -1
  154. package/build-module/utils/get-normalized-comma-separable.js.map +1 -1
  155. package/build-module/utils/if-matching-action.js.map +1 -1
  156. package/build-module/utils/index.js.map +1 -1
  157. package/build-module/utils/is-numeric-id.js.map +1 -1
  158. package/build-module/utils/is-raw-attribute.js.map +1 -1
  159. package/build-module/utils/on-sub-key.js.map +1 -1
  160. package/build-module/utils/replace-action.js.map +1 -1
  161. package/build-module/utils/set-nested-value.js.map +1 -1
  162. package/build-module/utils/with-weak-map-cache.js.map +1 -1
  163. package/build-types/actions.d.ts.map +1 -1
  164. package/build-types/entities.d.ts.map +1 -1
  165. package/build-types/footnotes/index.d.ts.map +1 -1
  166. package/build-types/index.d.ts +2 -2
  167. package/build-types/private-selectors.d.ts.map +1 -1
  168. package/build-types/queried-data/selectors.d.ts.map +1 -1
  169. package/build-types/resolvers.d.ts +2 -1
  170. package/build-types/resolvers.d.ts.map +1 -1
  171. package/build-types/selectors.d.ts +2 -2
  172. package/build-types/selectors.d.ts.map +1 -1
  173. package/package.json +17 -18
  174. package/src/footnotes/index.js +9 -3
  175. package/src/hooks/test/use-entity-record.js +1 -1
  176. package/src/private-selectors.ts +1 -6
  177. package/src/queried-data/selectors.js +5 -1
  178. package/src/resolvers.js +34 -30
  179. package/src/selectors.ts +23 -13
  180. package/src/test/resolvers.js +4 -3
  181. package/tsconfig.tsbuildinfo +1 -1
@@ -1 +1 @@
1
- {"version":3,"names":["_changeCase","require","_url","_htmlEntities","_apiFetch","_interopRequireDefault","_name","_entities","_utils","_sync","_fetch","getAuthors","query","dispatch","path","addQueryArgs","users","apiFetch","receiveUserQuery","exports","getCurrentUser","currentUser","receiveCurrentUser","getEntityRecord","kind","name","key","select","configs","getOrLoadEntitiesConfig","entityConfig","find","config","__experimentalNoFetch","lock","__unstableAcquireStoreLock","STORE_NAME","exclusive","window","__experimentalEnableSync","syncConfig","process","env","IS_GUTENBERG_PLUGIN","objectId","getSyncObjectId","getSyncProvider","bootstrap","syncObjectType","record","receiveEntityRecords","type","recordId","edits","meta","undo","undefined","_fields","Set","getNormalizedCommaSeparable","DEFAULT_ENTITY_KEY","join","baseURL","baseURLParams","include","hasRecords","hasEntityRecords","__unstableReleaseStoreLock","getRawEntityRecord","forwardResolver","getEditedEntityRecord","getEntityRecords","records","supportsPagination","per_page","response","parse","Object","values","json","totalItems","parseInt","headers","get","totalPages","map","split","forEach","field","hasOwnProperty","context","resolutionsArgs","filter","selectorName","args","shouldInvalidate","action","invalidateCache","getCurrentTheme","resolveSelect","activeThemes","status","receiveCurrentTheme","getThemeSupports","getEmbedPreview","url","embedProxyResponse","receiveEmbedPreview","error","canUser","requestedAction","resource","id","registry","hasStartedResolution","resourcePath","retrievedActions","includes","Error","relatedAction","isAlreadyResolving","method","allowHeader","allowedMethods","allow","permissions","methods","create","read","update","delete","actionName","methodName","entries","receiveUserPermission","canUserEditEntityRecord","__unstable_rest_base","getAutosaves","postType","postId","rest_base","restBase","rest_namespace","restNamespace","getPostType","autosaves","length","receiveAutosaves","getAutosave","__experimentalGetTemplateForLink","link","template","then","data","e","__experimentalGetCurrentGlobalStylesId","globalStylesURL","_links","href","globalStylesObject","__experimentalReceiveCurrentGlobalStylesId","__experimentalGetCurrentThemeBaseGlobalStyles","currentTheme","themeGlobalStyles","stylesheet","__experimentalReceiveThemeBaseGlobalStyles","__experimentalGetCurrentThemeGlobalStylesVariations","variations","__experimentalReceiveThemeGlobalStyleVariations","getCurrentThemeGlobalStylesRevisions","globalStylesId","revisionsURL","resetRevisions","revisions","revision","fromEntries","value","camelCase","receiveThemeGlobalStyleRevisions","getBlockPatterns","patterns","fetchBlockPatterns","getBlockPatternCategories","categories","getUserPatternCategories","patternCategories","mappedPatternCategories","userCategory","label","decodeEntities","slug","getNavigationFallbackId","fallback","_embed","_embedded","self","receiveNavigationFallbackId","existingFallbackEntityRecord","invalidateNavigationQueries","finishResolution","getDefaultTemplateId","receiveDefaultTemplateId","getRevisions","recordKey","revisionKey","getRevisionsUrl","isPaginated","receiveRevisions","getRevision"],"sources":["@wordpress/core-data/src/resolvers.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport { camelCase } from 'change-case';\n\n/**\n * WordPress dependencies\n */\nimport { addQueryArgs } from '@wordpress/url';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport apiFetch from '@wordpress/api-fetch';\n\n/**\n * Internal dependencies\n */\nimport { STORE_NAME } from './name';\nimport { getOrLoadEntitiesConfig, DEFAULT_ENTITY_KEY } from './entities';\nimport { forwardResolver, getNormalizedCommaSeparable } from './utils';\nimport { getSyncProvider } from './sync';\nimport { fetchBlockPatterns } from './fetch';\n\n/**\n * Requests authors from the REST API.\n *\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request.\n */\nexport const getAuthors =\n\t( query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst path = addQueryArgs(\n\t\t\t'/wp/v2/users/?who=authors&per_page=100',\n\t\t\tquery\n\t\t);\n\t\tconst users = await apiFetch( { path } );\n\t\tdispatch.receiveUserQuery( path, users );\n\t};\n\n/**\n * Requests the current user from the REST API.\n */\nexport const getCurrentUser =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst currentUser = await apiFetch( { path: '/wp/v2/users/me' } );\n\t\tdispatch.receiveCurrentUser( currentUser );\n\t};\n\n/**\n * Requests an entity's record from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} key Record's key\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getEntityRecord =\n\t( kind, name, key = '', query ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\t\tSTORE_NAME,\n\t\t\t[ 'entities', 'records', kind, name, key ],\n\t\t\t{ exclusive: false }\n\t\t);\n\n\t\ttry {\n\t\t\t// Entity supports configs,\n\t\t\t// use the sync algorithm instead of the old fetch behavior.\n\t\t\tif (\n\t\t\t\twindow.__experimentalEnableSync &&\n\t\t\t\tentityConfig.syncConfig &&\n\t\t\t\t! query\n\t\t\t) {\n\t\t\t\tif ( process.env.IS_GUTENBERG_PLUGIN ) {\n\t\t\t\t\tconst objectId = entityConfig.getSyncObjectId( key );\n\n\t\t\t\t\t// Loads the persisted document.\n\t\t\t\t\tawait getSyncProvider().bootstrap(\n\t\t\t\t\t\tentityConfig.syncObjectType,\n\t\t\t\t\t\tobjectId,\n\t\t\t\t\t\t( record ) => {\n\t\t\t\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\t\t\t\tkind,\n\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\trecord,\n\t\t\t\t\t\t\t\tquery\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\n\t\t\t\t\t// Boostraps the edited document as well (and load from peers).\n\t\t\t\t\tawait getSyncProvider().bootstrap(\n\t\t\t\t\t\tentityConfig.syncObjectType + '--edit',\n\t\t\t\t\t\tobjectId,\n\t\t\t\t\t\t( record ) => {\n\t\t\t\t\t\t\tdispatch( {\n\t\t\t\t\t\t\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t\t\t\t\t\t\tkind,\n\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\trecordId: key,\n\t\t\t\t\t\t\t\tedits: record,\n\t\t\t\t\t\t\t\tmeta: {\n\t\t\t\t\t\t\t\t\tundo: undefined,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif ( query !== undefined && query._fields ) {\n\t\t\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t\t\t// the ID.\n\t\t\t\t\tquery = {\n\t\t\t\t\t\t...query,\n\t\t\t\t\t\t_fields: [\n\t\t\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t\t\t...( getNormalizedCommaSeparable(\n\t\t\t\t\t\t\t\t\tquery._fields\n\t\t\t\t\t\t\t\t) || [] ),\n\t\t\t\t\t\t\t\tentityConfig.key || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t\t\t] ),\n\t\t\t\t\t\t].join(),\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\t// Disable reason: While true that an early return could leave `path`\n\t\t\t\t// unused, it's important that path is derived using the query prior to\n\t\t\t\t// additional query modifications in the condition below, since those\n\t\t\t\t// modifications are relevant to how the data is tracked in state, and not\n\t\t\t\t// for how the request is made to the REST API.\n\n\t\t\t\t// eslint-disable-next-line @wordpress/no-unused-vars-before-return\n\t\t\t\tconst path = addQueryArgs(\n\t\t\t\t\tentityConfig.baseURL + ( key ? '/' + key : '' ),\n\t\t\t\t\t{\n\t\t\t\t\t\t...entityConfig.baseURLParams,\n\t\t\t\t\t\t...query,\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\tif ( query !== undefined ) {\n\t\t\t\t\tquery = { ...query, include: [ key ] };\n\n\t\t\t\t\t// The resolution cache won't consider query as reusable based on the\n\t\t\t\t\t// fields, so it's tested here, prior to initiating the REST request,\n\t\t\t\t\t// and without causing `getEntityRecords` resolution to occur.\n\t\t\t\t\tconst hasRecords = select.hasEntityRecords(\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\tquery\n\t\t\t\t\t);\n\t\t\t\t\tif ( hasRecords ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst record = await apiFetch( { path } );\n\t\t\t\tdispatch.receiveEntityRecords( kind, name, record, query );\n\t\t\t}\n\t\t} finally {\n\t\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t\t}\n\t};\n\n/**\n * Requests an entity's record from the REST API.\n */\nexport const getRawEntityRecord = forwardResolver( 'getEntityRecord' );\n\n/**\n * Requests an entity's record from the REST API.\n */\nexport const getEditedEntityRecord = forwardResolver( 'getEntityRecord' );\n\n/**\n * Requests the entity's records from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {Object?} query Query Object. If requesting specific fields, fields\n * must always include the ID.\n */\nexport const getEntityRecords =\n\t( kind, name, query = {} ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\t\tSTORE_NAME,\n\t\t\t[ 'entities', 'records', kind, name ],\n\t\t\t{ exclusive: false }\n\t\t);\n\n\t\ttry {\n\t\t\tif ( query._fields ) {\n\t\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t\t// the ID.\n\t\t\t\tquery = {\n\t\t\t\t\t...query,\n\t\t\t\t\t_fields: [\n\t\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\t\tentityConfig.key || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t\t] ),\n\t\t\t\t\t].join(),\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tconst path = addQueryArgs( entityConfig.baseURL, {\n\t\t\t\t...entityConfig.baseURLParams,\n\t\t\t\t...query,\n\t\t\t} );\n\n\t\t\tlet records, meta;\n\t\t\tif ( entityConfig.supportsPagination && query.per_page !== -1 ) {\n\t\t\t\tconst response = await apiFetch( { path, parse: false } );\n\t\t\t\trecords = Object.values( await response.json() );\n\t\t\t\tmeta = {\n\t\t\t\t\ttotalItems: parseInt(\n\t\t\t\t\t\tresponse.headers.get( 'X-WP-Total' )\n\t\t\t\t\t),\n\t\t\t\t\ttotalPages: parseInt(\n\t\t\t\t\t\tresponse.headers.get( 'X-WP-TotalPages' )\n\t\t\t\t\t),\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\trecords = Object.values( await apiFetch( { path } ) );\n\t\t\t}\n\n\t\t\t// If we request fields but the result doesn't contain the fields,\n\t\t\t// explicitly set these fields as \"undefined\"\n\t\t\t// that way we consider the query \"fulfilled\".\n\t\t\tif ( query._fields ) {\n\t\t\t\trecords = records.map( ( record ) => {\n\t\t\t\t\tquery._fields.split( ',' ).forEach( ( field ) => {\n\t\t\t\t\t\tif ( ! record.hasOwnProperty( field ) ) {\n\t\t\t\t\t\t\trecord[ field ] = undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn record;\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\tkind,\n\t\t\t\tname,\n\t\t\t\trecords,\n\t\t\t\tquery,\n\t\t\t\tfalse,\n\t\t\t\tundefined,\n\t\t\t\tmeta\n\t\t\t);\n\n\t\t\t// When requesting all fields, the list of results can be used to\n\t\t\t// resolve the `getEntityRecord` selector in addition to `getEntityRecords`.\n\t\t\t// See https://github.com/WordPress/gutenberg/pull/26575\n\t\t\tif ( ! query?._fields && ! query.context ) {\n\t\t\t\tconst key = entityConfig.key || DEFAULT_ENTITY_KEY;\n\t\t\t\tconst resolutionsArgs = records\n\t\t\t\t\t.filter( ( record ) => record[ key ] )\n\t\t\t\t\t.map( ( record ) => [ kind, name, record[ key ] ] );\n\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'START_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getEntityRecord',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'FINISH_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getEntityRecord',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t}\n\t\t} finally {\n\t\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t\t}\n\t};\n\ngetEntityRecords.shouldInvalidate = ( action, kind, name ) => {\n\treturn (\n\t\t( action.type === 'RECEIVE_ITEMS' || action.type === 'REMOVE_ITEMS' ) &&\n\t\taction.invalidateCache &&\n\t\tkind === action.kind &&\n\t\tname === action.name\n\t);\n};\n\n/**\n * Requests the current theme.\n */\nexport const getCurrentTheme =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst activeThemes = await resolveSelect.getEntityRecords(\n\t\t\t'root',\n\t\t\t'theme',\n\t\t\t{ status: 'active' }\n\t\t);\n\n\t\tdispatch.receiveCurrentTheme( activeThemes[ 0 ] );\n\t};\n\n/**\n * Requests theme supports data from the index.\n */\nexport const getThemeSupports = forwardResolver( 'getCurrentTheme' );\n\n/**\n * Requests a preview from the Embed API.\n *\n * @param {string} url URL to get the preview for.\n */\nexport const getEmbedPreview =\n\t( url ) =>\n\tasync ( { dispatch } ) => {\n\t\ttry {\n\t\t\tconst embedProxyResponse = await apiFetch( {\n\t\t\t\tpath: addQueryArgs( '/oembed/1.0/proxy', { url } ),\n\t\t\t} );\n\t\t\tdispatch.receiveEmbedPreview( url, embedProxyResponse );\n\t\t} catch ( error ) {\n\t\t\t// Embed API 404s if the URL cannot be embedded, so we have to catch the error from the apiRequest here.\n\t\t\tdispatch.receiveEmbedPreview( url, false );\n\t\t}\n\t};\n\n/**\n * Checks whether the current user can perform the given action on the given\n * REST resource.\n *\n * @param {string} requestedAction Action to check. One of: 'create', 'read', 'update',\n * 'delete'.\n * @param {string} resource REST resource to check, e.g. 'media' or 'posts'.\n * @param {?string} id ID of the rest resource to check.\n */\nexport const canUser =\n\t( requestedAction, resource, id ) =>\n\tasync ( { dispatch, registry } ) => {\n\t\tconst { hasStartedResolution } = registry.select( STORE_NAME );\n\n\t\tconst resourcePath = id ? `${ resource }/${ id }` : resource;\n\t\tconst retrievedActions = [ 'create', 'read', 'update', 'delete' ];\n\n\t\tif ( ! retrievedActions.includes( requestedAction ) ) {\n\t\t\tthrow new Error( `'${ requestedAction }' is not a valid action.` );\n\t\t}\n\n\t\t// Prevent resolving the same resource twice.\n\t\tfor ( const relatedAction of retrievedActions ) {\n\t\t\tif ( relatedAction === requestedAction ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tconst isAlreadyResolving = hasStartedResolution( 'canUser', [\n\t\t\t\trelatedAction,\n\t\t\t\tresource,\n\t\t\t\tid,\n\t\t\t] );\n\t\t\tif ( isAlreadyResolving ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tlet response;\n\t\ttry {\n\t\t\tresponse = await apiFetch( {\n\t\t\t\tpath: `/wp/v2/${ resourcePath }`,\n\t\t\t\tmethod: 'OPTIONS',\n\t\t\t\tparse: false,\n\t\t\t} );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our OPTIONS request comes back with an API error (4xx or\n\t\t\t// 5xx). The previously determined isAllowed value will remain in the store.\n\t\t\treturn;\n\t\t}\n\n\t\t// Optional chaining operator is used here because the API requests don't\n\t\t// return the expected result in the native version. Instead, API requests\n\t\t// only return the result, without including response properties like the headers.\n\t\tconst allowHeader = response.headers?.get( 'allow' );\n\t\tconst allowedMethods = allowHeader?.allow || allowHeader || '';\n\n\t\tconst permissions = {};\n\t\tconst methods = {\n\t\t\tcreate: 'POST',\n\t\t\tread: 'GET',\n\t\t\tupdate: 'PUT',\n\t\t\tdelete: 'DELETE',\n\t\t};\n\t\tfor ( const [ actionName, methodName ] of Object.entries( methods ) ) {\n\t\t\tpermissions[ actionName ] = allowedMethods.includes( methodName );\n\t\t}\n\n\t\tfor ( const action of retrievedActions ) {\n\t\t\tdispatch.receiveUserPermission(\n\t\t\t\t`${ action }/${ resourcePath }`,\n\t\t\t\tpermissions[ action ]\n\t\t\t);\n\t\t}\n\t};\n\n/**\n * Checks whether the current user can perform the given action on the given\n * REST resource.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {string} recordId Record's id.\n */\nexport const canUserEditEntityRecord =\n\t( kind, name, recordId ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst resource = entityConfig.__unstable_rest_base;\n\t\tawait dispatch( canUser( 'update', resource, recordId ) );\n\t};\n\n/**\n * Request autosave data from the REST API.\n *\n * @param {string} postType The type of the parent post.\n * @param {number} postId The id of the parent post.\n */\nexport const getAutosaves =\n\t( postType, postId ) =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst { rest_base: restBase, rest_namespace: restNamespace = 'wp/v2' } =\n\t\t\tawait resolveSelect.getPostType( postType );\n\t\tconst autosaves = await apiFetch( {\n\t\t\tpath: `/${ restNamespace }/${ restBase }/${ postId }/autosaves?context=edit`,\n\t\t} );\n\n\t\tif ( autosaves && autosaves.length ) {\n\t\t\tdispatch.receiveAutosaves( postId, autosaves );\n\t\t}\n\t};\n\n/**\n * Request autosave data from the REST API.\n *\n * This resolver exists to ensure the underlying autosaves are fetched via\n * `getAutosaves` when a call to the `getAutosave` selector is made.\n *\n * @param {string} postType The type of the parent post.\n * @param {number} postId The id of the parent post.\n */\nexport const getAutosave =\n\t( postType, postId ) =>\n\tasync ( { resolveSelect } ) => {\n\t\tawait resolveSelect.getAutosaves( postType, postId );\n\t};\n\n/**\n * Retrieve the frontend template used for a given link.\n *\n * @param {string} link Link.\n */\nexport const __experimentalGetTemplateForLink =\n\t( link ) =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tlet template;\n\t\ttry {\n\t\t\t// This is NOT calling a REST endpoint but rather ends up with a response from\n\t\t\t// an Ajax function which has a different shape from a WP_REST_Response.\n\t\t\ttemplate = await apiFetch( {\n\t\t\t\turl: addQueryArgs( link, {\n\t\t\t\t\t'_wp-find-template': true,\n\t\t\t\t} ),\n\t\t\t} ).then( ( { data } ) => data );\n\t\t} catch ( e ) {\n\t\t\t// For non-FSE themes, it is possible that this request returns an error.\n\t\t}\n\n\t\tif ( ! template ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst record = await resolveSelect.getEntityRecord(\n\t\t\t'postType',\n\t\t\t'wp_template',\n\t\t\ttemplate.id\n\t\t);\n\n\t\tif ( record ) {\n\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t'postType',\n\t\t\t\t'wp_template',\n\t\t\t\t[ record ],\n\t\t\t\t{\n\t\t\t\t\t'find-template': link,\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\t};\n\n__experimentalGetTemplateForLink.shouldInvalidate = ( action ) => {\n\treturn (\n\t\t( action.type === 'RECEIVE_ITEMS' || action.type === 'REMOVE_ITEMS' ) &&\n\t\taction.invalidateCache &&\n\t\taction.kind === 'postType' &&\n\t\taction.name === 'wp_template'\n\t);\n};\n\nexport const __experimentalGetCurrentGlobalStylesId =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst activeThemes = await resolveSelect.getEntityRecords(\n\t\t\t'root',\n\t\t\t'theme',\n\t\t\t{ status: 'active' }\n\t\t);\n\t\tconst globalStylesURL =\n\t\t\tactiveThemes?.[ 0 ]?._links?.[ 'wp:user-global-styles' ]?.[ 0 ]\n\t\t\t\t?.href;\n\t\tif ( globalStylesURL ) {\n\t\t\tconst globalStylesObject = await apiFetch( {\n\t\t\t\turl: globalStylesURL,\n\t\t\t} );\n\t\t\tdispatch.__experimentalReceiveCurrentGlobalStylesId(\n\t\t\t\tglobalStylesObject.id\n\t\t\t);\n\t\t}\n\t};\n\nexport const __experimentalGetCurrentThemeBaseGlobalStyles =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst currentTheme = await resolveSelect.getCurrentTheme();\n\t\tconst themeGlobalStyles = await apiFetch( {\n\t\t\tpath: `/wp/v2/global-styles/themes/${ currentTheme.stylesheet }`,\n\t\t} );\n\t\tdispatch.__experimentalReceiveThemeBaseGlobalStyles(\n\t\t\tcurrentTheme.stylesheet,\n\t\t\tthemeGlobalStyles\n\t\t);\n\t};\n\nexport const __experimentalGetCurrentThemeGlobalStylesVariations =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst currentTheme = await resolveSelect.getCurrentTheme();\n\t\tconst variations = await apiFetch( {\n\t\t\tpath: `/wp/v2/global-styles/themes/${ currentTheme.stylesheet }/variations`,\n\t\t} );\n\t\tdispatch.__experimentalReceiveThemeGlobalStyleVariations(\n\t\t\tcurrentTheme.stylesheet,\n\t\t\tvariations\n\t\t);\n\t};\n\n/**\n * Fetches and returns the revisions of the current global styles theme.\n */\nexport const getCurrentThemeGlobalStylesRevisions =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst globalStylesId =\n\t\t\tawait resolveSelect.__experimentalGetCurrentGlobalStylesId();\n\t\tconst record = globalStylesId\n\t\t\t? await resolveSelect.getEntityRecord(\n\t\t\t\t\t'root',\n\t\t\t\t\t'globalStyles',\n\t\t\t\t\tglobalStylesId\n\t\t\t )\n\t\t\t: undefined;\n\t\tconst revisionsURL = record?._links?.[ 'version-history' ]?.[ 0 ]?.href;\n\n\t\tif ( revisionsURL ) {\n\t\t\tconst resetRevisions = await apiFetch( {\n\t\t\t\turl: revisionsURL,\n\t\t\t} );\n\t\t\tconst revisions = resetRevisions?.map( ( revision ) =>\n\t\t\t\tObject.fromEntries(\n\t\t\t\t\tObject.entries( revision ).map( ( [ key, value ] ) => [\n\t\t\t\t\t\tcamelCase( key ),\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t] )\n\t\t\t\t)\n\t\t\t);\n\t\t\tdispatch.receiveThemeGlobalStyleRevisions(\n\t\t\t\tglobalStylesId,\n\t\t\t\trevisions\n\t\t\t);\n\t\t}\n\t};\n\ngetCurrentThemeGlobalStylesRevisions.shouldInvalidate = ( action ) => {\n\treturn (\n\t\taction.type === 'SAVE_ENTITY_RECORD_FINISH' &&\n\t\taction.kind === 'root' &&\n\t\t! action.error &&\n\t\taction.name === 'globalStyles'\n\t);\n};\n\nexport const getBlockPatterns =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst patterns = await fetchBlockPatterns();\n\t\tdispatch( { type: 'RECEIVE_BLOCK_PATTERNS', patterns } );\n\t};\n\nexport const getBlockPatternCategories =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst categories = await apiFetch( {\n\t\t\tpath: '/wp/v2/block-patterns/categories',\n\t\t} );\n\t\tdispatch( { type: 'RECEIVE_BLOCK_PATTERN_CATEGORIES', categories } );\n\t};\n\nexport const getUserPatternCategories =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst patternCategories = await resolveSelect.getEntityRecords(\n\t\t\t'taxonomy',\n\t\t\t'wp_pattern_category',\n\t\t\t{\n\t\t\t\tper_page: -1,\n\t\t\t\t_fields: 'id,name,description,slug',\n\t\t\t\tcontext: 'view',\n\t\t\t}\n\t\t);\n\n\t\tconst mappedPatternCategories =\n\t\t\tpatternCategories?.map( ( userCategory ) => ( {\n\t\t\t\t...userCategory,\n\t\t\t\tlabel: decodeEntities( userCategory.name ),\n\t\t\t\tname: userCategory.slug,\n\t\t\t} ) ) || [];\n\n\t\tdispatch( {\n\t\t\ttype: 'RECEIVE_USER_PATTERN_CATEGORIES',\n\t\t\tpatternCategories: mappedPatternCategories,\n\t\t} );\n\t};\n\nexport const getNavigationFallbackId =\n\t() =>\n\tasync ( { dispatch, select } ) => {\n\t\tconst fallback = await apiFetch( {\n\t\t\tpath: addQueryArgs( '/wp-block-editor/v1/navigation-fallback', {\n\t\t\t\t_embed: true,\n\t\t\t} ),\n\t\t} );\n\n\t\tconst record = fallback?._embedded?.self;\n\n\t\tdispatch.receiveNavigationFallbackId( fallback?.id );\n\n\t\tif ( record ) {\n\t\t\t// If the fallback is already in the store, don't invalidate navigation queries.\n\t\t\t// Otherwise, invalidate the cache for the scenario where there were no Navigation\n\t\t\t// posts in the state and the fallback created one.\n\t\t\tconst existingFallbackEntityRecord = select.getEntityRecord(\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\tfallback.id\n\t\t\t);\n\t\t\tconst invalidateNavigationQueries = ! existingFallbackEntityRecord;\n\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\trecord,\n\t\t\t\tundefined,\n\t\t\t\tinvalidateNavigationQueries\n\t\t\t);\n\n\t\t\t// Resolve to avoid further network requests.\n\t\t\tdispatch.finishResolution( 'getEntityRecord', [\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\tfallback.id,\n\t\t\t] );\n\t\t}\n\t};\n\nexport const getDefaultTemplateId =\n\t( query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst template = await apiFetch( {\n\t\t\tpath: addQueryArgs( '/wp/v2/templates/lookup', query ),\n\t\t} );\n\t\tif ( template ) {\n\t\t\tdispatch.receiveDefaultTemplateId( query, template.id );\n\t\t}\n\t};\n\n/**\n * Requests an entity's revisions from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} recordKey The key of the entity record whose revisions you want to fetch.\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getRevisions =\n\t( kind, name, recordKey, query = {} ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( query._fields ) {\n\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t// the ID.\n\t\t\tquery = {\n\t\t\t\t...query,\n\t\t\t\t_fields: [\n\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\tentityConfig.revisionKey || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t] ),\n\t\t\t\t].join(),\n\t\t\t};\n\t\t}\n\n\t\tconst path = addQueryArgs(\n\t\t\tentityConfig.getRevisionsUrl( recordKey ),\n\t\t\tquery\n\t\t);\n\n\t\tlet records, response;\n\t\tconst meta = {};\n\t\tconst isPaginated =\n\t\t\tentityConfig.supportsPagination && query.per_page !== -1;\n\t\ttry {\n\t\t\tresponse = await apiFetch( { path, parse: ! isPaginated } );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our request comes back with an API error.\n\t\t\treturn;\n\t\t}\n\n\t\tif ( response ) {\n\t\t\tif ( isPaginated ) {\n\t\t\t\trecords = Object.values( await response.json() );\n\t\t\t\tmeta.totalItems = parseInt(\n\t\t\t\t\tresponse.headers.get( 'X-WP-Total' )\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\trecords = Object.values( response );\n\t\t\t}\n\n\t\t\t// If we request fields but the result doesn't contain the fields,\n\t\t\t// explicitly set these fields as \"undefined\"\n\t\t\t// that way we consider the query \"fulfilled\".\n\t\t\tif ( query._fields ) {\n\t\t\t\trecords = records.map( ( record ) => {\n\t\t\t\t\tquery._fields.split( ',' ).forEach( ( field ) => {\n\t\t\t\t\t\tif ( ! record.hasOwnProperty( field ) ) {\n\t\t\t\t\t\t\trecord[ field ] = undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn record;\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\tdispatch.receiveRevisions(\n\t\t\t\tkind,\n\t\t\t\tname,\n\t\t\t\trecordKey,\n\t\t\t\trecords,\n\t\t\t\tquery,\n\t\t\t\tfalse,\n\t\t\t\tmeta\n\t\t\t);\n\n\t\t\t// When requesting all fields, the list of results can be used to\n\t\t\t// resolve the `getRevision` selector in addition to `getRevisions`.\n\t\t\tif ( ! query?._fields && ! query.context ) {\n\t\t\t\tconst key = entityConfig.key || DEFAULT_ENTITY_KEY;\n\t\t\t\tconst resolutionsArgs = records\n\t\t\t\t\t.filter( ( record ) => record[ key ] )\n\t\t\t\t\t.map( ( record ) => [\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\trecordKey,\n\t\t\t\t\t\trecord[ key ],\n\t\t\t\t\t] );\n\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'START_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getRevision',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'FINISH_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getRevision',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t};\n\n// Invalidate cache when a new revision is created.\ngetRevisions.shouldInvalidate = ( action, kind, name, recordKey ) =>\n\taction.type === 'SAVE_ENTITY_RECORD_FINISH' &&\n\tname === action.name &&\n\tkind === action.kind &&\n\t! action.error &&\n\trecordKey === action.recordId;\n\n/**\n * Requests a specific Entity revision from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} recordKey The key of the entity record whose revisions you want to fetch.\n * @param {number|string} revisionKey The revision's key.\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getRevision =\n\t( kind, name, recordKey, revisionKey, query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( query !== undefined && query._fields ) {\n\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t// the ID.\n\t\t\tquery = {\n\t\t\t\t...query,\n\t\t\t\t_fields: [\n\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\tentityConfig.revisionKey || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t] ),\n\t\t\t\t].join(),\n\t\t\t};\n\t\t}\n\t\tconst path = addQueryArgs(\n\t\t\tentityConfig.getRevisionsUrl( recordKey, revisionKey ),\n\t\t\tquery\n\t\t);\n\n\t\tlet record;\n\t\ttry {\n\t\t\trecord = await apiFetch( { path } );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our request comes back with an API error.\n\t\t\treturn;\n\t\t}\n\n\t\tif ( record ) {\n\t\t\tdispatch.receiveRevisions( kind, name, recordKey, record, query );\n\t\t}\n\t};\n"],"mappings":"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"}
1
+ {"version":3,"names":["_changeCase","require","_url","_htmlEntities","_apiFetch","_interopRequireDefault","_name","_entities","_utils","_sync","_fetch","getAuthors","query","dispatch","path","addQueryArgs","users","apiFetch","receiveUserQuery","exports","getCurrentUser","currentUser","receiveCurrentUser","getEntityRecord","kind","name","key","select","configs","getOrLoadEntitiesConfig","entityConfig","find","config","__experimentalNoFetch","lock","__unstableAcquireStoreLock","STORE_NAME","exclusive","window","__experimentalEnableSync","syncConfig","process","env","IS_GUTENBERG_PLUGIN","objectId","getSyncObjectId","getSyncProvider","bootstrap","syncObjectType","record","receiveEntityRecords","type","recordId","edits","meta","undo","undefined","_fields","Set","getNormalizedCommaSeparable","DEFAULT_ENTITY_KEY","join","baseURL","baseURLParams","include","hasRecords","hasEntityRecords","__unstableReleaseStoreLock","getRawEntityRecord","forwardResolver","getEditedEntityRecord","getEntityRecords","registry","records","supportsPagination","per_page","response","parse","Object","values","json","totalItems","parseInt","headers","get","totalPages","map","split","forEach","field","hasOwnProperty","batch","context","resolutionsArgs","filter","selectorName","args","e","shouldInvalidate","action","invalidateCache","getCurrentTheme","resolveSelect","activeThemes","status","receiveCurrentTheme","getThemeSupports","getEmbedPreview","url","embedProxyResponse","receiveEmbedPreview","error","canUser","requestedAction","resource","id","hasStartedResolution","resourcePath","retrievedActions","includes","Error","relatedAction","isAlreadyResolving","method","allowHeader","allowedMethods","allow","permissions","methods","create","read","update","delete","actionName","methodName","entries","receiveUserPermission","canUserEditEntityRecord","__unstable_rest_base","getAutosaves","postType","postId","rest_base","restBase","rest_namespace","restNamespace","getPostType","autosaves","length","receiveAutosaves","getAutosave","__experimentalGetTemplateForLink","link","template","then","data","__experimentalGetCurrentGlobalStylesId","globalStylesURL","_links","href","globalStylesObject","__experimentalReceiveCurrentGlobalStylesId","__experimentalGetCurrentThemeBaseGlobalStyles","currentTheme","themeGlobalStyles","stylesheet","__experimentalReceiveThemeBaseGlobalStyles","__experimentalGetCurrentThemeGlobalStylesVariations","variations","__experimentalReceiveThemeGlobalStyleVariations","getCurrentThemeGlobalStylesRevisions","globalStylesId","revisionsURL","resetRevisions","revisions","revision","fromEntries","value","camelCase","receiveThemeGlobalStyleRevisions","getBlockPatterns","patterns","fetchBlockPatterns","getBlockPatternCategories","categories","getUserPatternCategories","patternCategories","mappedPatternCategories","userCategory","label","decodeEntities","slug","getNavigationFallbackId","fallback","_embed","_embedded","self","receiveNavigationFallbackId","existingFallbackEntityRecord","invalidateNavigationQueries","finishResolution","getDefaultTemplateId","receiveDefaultTemplateId","getRevisions","recordKey","revisionKey","getRevisionsUrl","isPaginated","receiveRevisions","getRevision"],"sources":["@wordpress/core-data/src/resolvers.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport { camelCase } from 'change-case';\n\n/**\n * WordPress dependencies\n */\nimport { addQueryArgs } from '@wordpress/url';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport apiFetch from '@wordpress/api-fetch';\n\n/**\n * Internal dependencies\n */\nimport { STORE_NAME } from './name';\nimport { getOrLoadEntitiesConfig, DEFAULT_ENTITY_KEY } from './entities';\nimport { forwardResolver, getNormalizedCommaSeparable } from './utils';\nimport { getSyncProvider } from './sync';\nimport { fetchBlockPatterns } from './fetch';\n\n/**\n * Requests authors from the REST API.\n *\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request.\n */\nexport const getAuthors =\n\t( query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst path = addQueryArgs(\n\t\t\t'/wp/v2/users/?who=authors&per_page=100',\n\t\t\tquery\n\t\t);\n\t\tconst users = await apiFetch( { path } );\n\t\tdispatch.receiveUserQuery( path, users );\n\t};\n\n/**\n * Requests the current user from the REST API.\n */\nexport const getCurrentUser =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst currentUser = await apiFetch( { path: '/wp/v2/users/me' } );\n\t\tdispatch.receiveCurrentUser( currentUser );\n\t};\n\n/**\n * Requests an entity's record from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} key Record's key\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getEntityRecord =\n\t( kind, name, key = '', query ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\t\tSTORE_NAME,\n\t\t\t[ 'entities', 'records', kind, name, key ],\n\t\t\t{ exclusive: false }\n\t\t);\n\n\t\ttry {\n\t\t\t// Entity supports configs,\n\t\t\t// use the sync algorithm instead of the old fetch behavior.\n\t\t\tif (\n\t\t\t\twindow.__experimentalEnableSync &&\n\t\t\t\tentityConfig.syncConfig &&\n\t\t\t\t! query\n\t\t\t) {\n\t\t\t\tif ( process.env.IS_GUTENBERG_PLUGIN ) {\n\t\t\t\t\tconst objectId = entityConfig.getSyncObjectId( key );\n\n\t\t\t\t\t// Loads the persisted document.\n\t\t\t\t\tawait getSyncProvider().bootstrap(\n\t\t\t\t\t\tentityConfig.syncObjectType,\n\t\t\t\t\t\tobjectId,\n\t\t\t\t\t\t( record ) => {\n\t\t\t\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\t\t\t\tkind,\n\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\trecord,\n\t\t\t\t\t\t\t\tquery\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\n\t\t\t\t\t// Boostraps the edited document as well (and load from peers).\n\t\t\t\t\tawait getSyncProvider().bootstrap(\n\t\t\t\t\t\tentityConfig.syncObjectType + '--edit',\n\t\t\t\t\t\tobjectId,\n\t\t\t\t\t\t( record ) => {\n\t\t\t\t\t\t\tdispatch( {\n\t\t\t\t\t\t\t\ttype: 'EDIT_ENTITY_RECORD',\n\t\t\t\t\t\t\t\tkind,\n\t\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\t\trecordId: key,\n\t\t\t\t\t\t\t\tedits: record,\n\t\t\t\t\t\t\t\tmeta: {\n\t\t\t\t\t\t\t\t\tundo: undefined,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif ( query !== undefined && query._fields ) {\n\t\t\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t\t\t// the ID.\n\t\t\t\t\tquery = {\n\t\t\t\t\t\t...query,\n\t\t\t\t\t\t_fields: [\n\t\t\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t\t\t...( getNormalizedCommaSeparable(\n\t\t\t\t\t\t\t\t\tquery._fields\n\t\t\t\t\t\t\t\t) || [] ),\n\t\t\t\t\t\t\t\tentityConfig.key || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t\t\t] ),\n\t\t\t\t\t\t].join(),\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\t// Disable reason: While true that an early return could leave `path`\n\t\t\t\t// unused, it's important that path is derived using the query prior to\n\t\t\t\t// additional query modifications in the condition below, since those\n\t\t\t\t// modifications are relevant to how the data is tracked in state, and not\n\t\t\t\t// for how the request is made to the REST API.\n\n\t\t\t\t// eslint-disable-next-line @wordpress/no-unused-vars-before-return\n\t\t\t\tconst path = addQueryArgs(\n\t\t\t\t\tentityConfig.baseURL + ( key ? '/' + key : '' ),\n\t\t\t\t\t{\n\t\t\t\t\t\t...entityConfig.baseURLParams,\n\t\t\t\t\t\t...query,\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\tif ( query !== undefined ) {\n\t\t\t\t\tquery = { ...query, include: [ key ] };\n\n\t\t\t\t\t// The resolution cache won't consider query as reusable based on the\n\t\t\t\t\t// fields, so it's tested here, prior to initiating the REST request,\n\t\t\t\t\t// and without causing `getEntityRecords` resolution to occur.\n\t\t\t\t\tconst hasRecords = select.hasEntityRecords(\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\tquery\n\t\t\t\t\t);\n\t\t\t\t\tif ( hasRecords ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst record = await apiFetch( { path } );\n\t\t\t\tdispatch.receiveEntityRecords( kind, name, record, query );\n\t\t\t}\n\t\t} finally {\n\t\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t\t}\n\t};\n\n/**\n * Requests an entity's record from the REST API.\n */\nexport const getRawEntityRecord = forwardResolver( 'getEntityRecord' );\n\n/**\n * Requests an entity's record from the REST API.\n */\nexport const getEditedEntityRecord = forwardResolver( 'getEntityRecord' );\n\n/**\n * Requests the entity's records from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {Object?} query Query Object. If requesting specific fields, fields\n * must always include the ID.\n */\nexport const getEntityRecords =\n\t( kind, name, query = {} ) =>\n\tasync ( { dispatch, registry } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst lock = await dispatch.__unstableAcquireStoreLock(\n\t\t\tSTORE_NAME,\n\t\t\t[ 'entities', 'records', kind, name ],\n\t\t\t{ exclusive: false }\n\t\t);\n\n\t\ttry {\n\t\t\tif ( query._fields ) {\n\t\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t\t// the ID.\n\t\t\t\tquery = {\n\t\t\t\t\t...query,\n\t\t\t\t\t_fields: [\n\t\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\t\tentityConfig.key || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t\t] ),\n\t\t\t\t\t].join(),\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tconst path = addQueryArgs( entityConfig.baseURL, {\n\t\t\t\t...entityConfig.baseURLParams,\n\t\t\t\t...query,\n\t\t\t} );\n\n\t\t\tlet records, meta;\n\t\t\tif ( entityConfig.supportsPagination && query.per_page !== -1 ) {\n\t\t\t\tconst response = await apiFetch( { path, parse: false } );\n\t\t\t\trecords = Object.values( await response.json() );\n\t\t\t\tmeta = {\n\t\t\t\t\ttotalItems: parseInt(\n\t\t\t\t\t\tresponse.headers.get( 'X-WP-Total' )\n\t\t\t\t\t),\n\t\t\t\t\ttotalPages: parseInt(\n\t\t\t\t\t\tresponse.headers.get( 'X-WP-TotalPages' )\n\t\t\t\t\t),\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\trecords = Object.values( await apiFetch( { path } ) );\n\t\t\t}\n\n\t\t\t// If we request fields but the result doesn't contain the fields,\n\t\t\t// explicitly set these fields as \"undefined\"\n\t\t\t// that way we consider the query \"fulfilled\".\n\t\t\tif ( query._fields ) {\n\t\t\t\trecords = records.map( ( record ) => {\n\t\t\t\t\tquery._fields.split( ',' ).forEach( ( field ) => {\n\t\t\t\t\t\tif ( ! record.hasOwnProperty( field ) ) {\n\t\t\t\t\t\t\trecord[ field ] = undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn record;\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\tregistry.batch( () => {\n\t\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t\tkind,\n\t\t\t\t\tname,\n\t\t\t\t\trecords,\n\t\t\t\t\tquery,\n\t\t\t\t\tfalse,\n\t\t\t\t\tundefined,\n\t\t\t\t\tmeta\n\t\t\t\t);\n\n\t\t\t\t// When requesting all fields, the list of results can be used to\n\t\t\t\t// resolve the `getEntityRecord` selector in addition to `getEntityRecords`.\n\t\t\t\t// See https://github.com/WordPress/gutenberg/pull/26575\n\t\t\t\tif ( ! query?._fields && ! query.context ) {\n\t\t\t\t\tconst key = entityConfig.key || DEFAULT_ENTITY_KEY;\n\t\t\t\t\tconst resolutionsArgs = records\n\t\t\t\t\t\t.filter( ( record ) => record[ key ] )\n\t\t\t\t\t\t.map( ( record ) => [ kind, name, record[ key ] ] );\n\n\t\t\t\t\tdispatch( {\n\t\t\t\t\t\ttype: 'START_RESOLUTIONS',\n\t\t\t\t\t\tselectorName: 'getEntityRecord',\n\t\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t\t} );\n\t\t\t\t\tdispatch( {\n\t\t\t\t\t\ttype: 'FINISH_RESOLUTIONS',\n\t\t\t\t\t\tselectorName: 'getEntityRecord',\n\t\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t\t} );\n\t\t\t\t}\n\n\t\t\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t\t\t} );\n\t\t} catch ( e ) {\n\t\t\tdispatch.__unstableReleaseStoreLock( lock );\n\t\t}\n\t};\n\ngetEntityRecords.shouldInvalidate = ( action, kind, name ) => {\n\treturn (\n\t\t( action.type === 'RECEIVE_ITEMS' || action.type === 'REMOVE_ITEMS' ) &&\n\t\taction.invalidateCache &&\n\t\tkind === action.kind &&\n\t\tname === action.name\n\t);\n};\n\n/**\n * Requests the current theme.\n */\nexport const getCurrentTheme =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst activeThemes = await resolveSelect.getEntityRecords(\n\t\t\t'root',\n\t\t\t'theme',\n\t\t\t{ status: 'active' }\n\t\t);\n\n\t\tdispatch.receiveCurrentTheme( activeThemes[ 0 ] );\n\t};\n\n/**\n * Requests theme supports data from the index.\n */\nexport const getThemeSupports = forwardResolver( 'getCurrentTheme' );\n\n/**\n * Requests a preview from the Embed API.\n *\n * @param {string} url URL to get the preview for.\n */\nexport const getEmbedPreview =\n\t( url ) =>\n\tasync ( { dispatch } ) => {\n\t\ttry {\n\t\t\tconst embedProxyResponse = await apiFetch( {\n\t\t\t\tpath: addQueryArgs( '/oembed/1.0/proxy', { url } ),\n\t\t\t} );\n\t\t\tdispatch.receiveEmbedPreview( url, embedProxyResponse );\n\t\t} catch ( error ) {\n\t\t\t// Embed API 404s if the URL cannot be embedded, so we have to catch the error from the apiRequest here.\n\t\t\tdispatch.receiveEmbedPreview( url, false );\n\t\t}\n\t};\n\n/**\n * Checks whether the current user can perform the given action on the given\n * REST resource.\n *\n * @param {string} requestedAction Action to check. One of: 'create', 'read', 'update',\n * 'delete'.\n * @param {string} resource REST resource to check, e.g. 'media' or 'posts'.\n * @param {?string} id ID of the rest resource to check.\n */\nexport const canUser =\n\t( requestedAction, resource, id ) =>\n\tasync ( { dispatch, registry } ) => {\n\t\tconst { hasStartedResolution } = registry.select( STORE_NAME );\n\n\t\tconst resourcePath = id ? `${ resource }/${ id }` : resource;\n\t\tconst retrievedActions = [ 'create', 'read', 'update', 'delete' ];\n\n\t\tif ( ! retrievedActions.includes( requestedAction ) ) {\n\t\t\tthrow new Error( `'${ requestedAction }' is not a valid action.` );\n\t\t}\n\n\t\t// Prevent resolving the same resource twice.\n\t\tfor ( const relatedAction of retrievedActions ) {\n\t\t\tif ( relatedAction === requestedAction ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tconst isAlreadyResolving = hasStartedResolution( 'canUser', [\n\t\t\t\trelatedAction,\n\t\t\t\tresource,\n\t\t\t\tid,\n\t\t\t] );\n\t\t\tif ( isAlreadyResolving ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tlet response;\n\t\ttry {\n\t\t\tresponse = await apiFetch( {\n\t\t\t\tpath: `/wp/v2/${ resourcePath }`,\n\t\t\t\tmethod: 'OPTIONS',\n\t\t\t\tparse: false,\n\t\t\t} );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our OPTIONS request comes back with an API error (4xx or\n\t\t\t// 5xx). The previously determined isAllowed value will remain in the store.\n\t\t\treturn;\n\t\t}\n\n\t\t// Optional chaining operator is used here because the API requests don't\n\t\t// return the expected result in the native version. Instead, API requests\n\t\t// only return the result, without including response properties like the headers.\n\t\tconst allowHeader = response.headers?.get( 'allow' );\n\t\tconst allowedMethods = allowHeader?.allow || allowHeader || '';\n\n\t\tconst permissions = {};\n\t\tconst methods = {\n\t\t\tcreate: 'POST',\n\t\t\tread: 'GET',\n\t\t\tupdate: 'PUT',\n\t\t\tdelete: 'DELETE',\n\t\t};\n\t\tfor ( const [ actionName, methodName ] of Object.entries( methods ) ) {\n\t\t\tpermissions[ actionName ] = allowedMethods.includes( methodName );\n\t\t}\n\n\t\tfor ( const action of retrievedActions ) {\n\t\t\tdispatch.receiveUserPermission(\n\t\t\t\t`${ action }/${ resourcePath }`,\n\t\t\t\tpermissions[ action ]\n\t\t\t);\n\t\t}\n\t};\n\n/**\n * Checks whether the current user can perform the given action on the given\n * REST resource.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {string} recordId Record's id.\n */\nexport const canUserEditEntityRecord =\n\t( kind, name, recordId ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\t\tif ( ! entityConfig ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst resource = entityConfig.__unstable_rest_base;\n\t\tawait dispatch( canUser( 'update', resource, recordId ) );\n\t};\n\n/**\n * Request autosave data from the REST API.\n *\n * @param {string} postType The type of the parent post.\n * @param {number} postId The id of the parent post.\n */\nexport const getAutosaves =\n\t( postType, postId ) =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst { rest_base: restBase, rest_namespace: restNamespace = 'wp/v2' } =\n\t\t\tawait resolveSelect.getPostType( postType );\n\t\tconst autosaves = await apiFetch( {\n\t\t\tpath: `/${ restNamespace }/${ restBase }/${ postId }/autosaves?context=edit`,\n\t\t} );\n\n\t\tif ( autosaves && autosaves.length ) {\n\t\t\tdispatch.receiveAutosaves( postId, autosaves );\n\t\t}\n\t};\n\n/**\n * Request autosave data from the REST API.\n *\n * This resolver exists to ensure the underlying autosaves are fetched via\n * `getAutosaves` when a call to the `getAutosave` selector is made.\n *\n * @param {string} postType The type of the parent post.\n * @param {number} postId The id of the parent post.\n */\nexport const getAutosave =\n\t( postType, postId ) =>\n\tasync ( { resolveSelect } ) => {\n\t\tawait resolveSelect.getAutosaves( postType, postId );\n\t};\n\n/**\n * Retrieve the frontend template used for a given link.\n *\n * @param {string} link Link.\n */\nexport const __experimentalGetTemplateForLink =\n\t( link ) =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tlet template;\n\t\ttry {\n\t\t\t// This is NOT calling a REST endpoint but rather ends up with a response from\n\t\t\t// an Ajax function which has a different shape from a WP_REST_Response.\n\t\t\ttemplate = await apiFetch( {\n\t\t\t\turl: addQueryArgs( link, {\n\t\t\t\t\t'_wp-find-template': true,\n\t\t\t\t} ),\n\t\t\t} ).then( ( { data } ) => data );\n\t\t} catch ( e ) {\n\t\t\t// For non-FSE themes, it is possible that this request returns an error.\n\t\t}\n\n\t\tif ( ! template ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst record = await resolveSelect.getEntityRecord(\n\t\t\t'postType',\n\t\t\t'wp_template',\n\t\t\ttemplate.id\n\t\t);\n\n\t\tif ( record ) {\n\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t'postType',\n\t\t\t\t'wp_template',\n\t\t\t\t[ record ],\n\t\t\t\t{\n\t\t\t\t\t'find-template': link,\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\t};\n\n__experimentalGetTemplateForLink.shouldInvalidate = ( action ) => {\n\treturn (\n\t\t( action.type === 'RECEIVE_ITEMS' || action.type === 'REMOVE_ITEMS' ) &&\n\t\taction.invalidateCache &&\n\t\taction.kind === 'postType' &&\n\t\taction.name === 'wp_template'\n\t);\n};\n\nexport const __experimentalGetCurrentGlobalStylesId =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst activeThemes = await resolveSelect.getEntityRecords(\n\t\t\t'root',\n\t\t\t'theme',\n\t\t\t{ status: 'active' }\n\t\t);\n\t\tconst globalStylesURL =\n\t\t\tactiveThemes?.[ 0 ]?._links?.[ 'wp:user-global-styles' ]?.[ 0 ]\n\t\t\t\t?.href;\n\t\tif ( globalStylesURL ) {\n\t\t\tconst globalStylesObject = await apiFetch( {\n\t\t\t\turl: globalStylesURL,\n\t\t\t} );\n\t\t\tdispatch.__experimentalReceiveCurrentGlobalStylesId(\n\t\t\t\tglobalStylesObject.id\n\t\t\t);\n\t\t}\n\t};\n\nexport const __experimentalGetCurrentThemeBaseGlobalStyles =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst currentTheme = await resolveSelect.getCurrentTheme();\n\t\tconst themeGlobalStyles = await apiFetch( {\n\t\t\tpath: `/wp/v2/global-styles/themes/${ currentTheme.stylesheet }`,\n\t\t} );\n\t\tdispatch.__experimentalReceiveThemeBaseGlobalStyles(\n\t\t\tcurrentTheme.stylesheet,\n\t\t\tthemeGlobalStyles\n\t\t);\n\t};\n\nexport const __experimentalGetCurrentThemeGlobalStylesVariations =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst currentTheme = await resolveSelect.getCurrentTheme();\n\t\tconst variations = await apiFetch( {\n\t\t\tpath: `/wp/v2/global-styles/themes/${ currentTheme.stylesheet }/variations`,\n\t\t} );\n\t\tdispatch.__experimentalReceiveThemeGlobalStyleVariations(\n\t\t\tcurrentTheme.stylesheet,\n\t\t\tvariations\n\t\t);\n\t};\n\n/**\n * Fetches and returns the revisions of the current global styles theme.\n */\nexport const getCurrentThemeGlobalStylesRevisions =\n\t() =>\n\tasync ( { resolveSelect, dispatch } ) => {\n\t\tconst globalStylesId =\n\t\t\tawait resolveSelect.__experimentalGetCurrentGlobalStylesId();\n\t\tconst record = globalStylesId\n\t\t\t? await resolveSelect.getEntityRecord(\n\t\t\t\t\t'root',\n\t\t\t\t\t'globalStyles',\n\t\t\t\t\tglobalStylesId\n\t\t\t )\n\t\t\t: undefined;\n\t\tconst revisionsURL = record?._links?.[ 'version-history' ]?.[ 0 ]?.href;\n\n\t\tif ( revisionsURL ) {\n\t\t\tconst resetRevisions = await apiFetch( {\n\t\t\t\turl: revisionsURL,\n\t\t\t} );\n\t\t\tconst revisions = resetRevisions?.map( ( revision ) =>\n\t\t\t\tObject.fromEntries(\n\t\t\t\t\tObject.entries( revision ).map( ( [ key, value ] ) => [\n\t\t\t\t\t\tcamelCase( key ),\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t] )\n\t\t\t\t)\n\t\t\t);\n\t\t\tdispatch.receiveThemeGlobalStyleRevisions(\n\t\t\t\tglobalStylesId,\n\t\t\t\trevisions\n\t\t\t);\n\t\t}\n\t};\n\ngetCurrentThemeGlobalStylesRevisions.shouldInvalidate = ( action ) => {\n\treturn (\n\t\taction.type === 'SAVE_ENTITY_RECORD_FINISH' &&\n\t\taction.kind === 'root' &&\n\t\t! action.error &&\n\t\taction.name === 'globalStyles'\n\t);\n};\n\nexport const getBlockPatterns =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst patterns = await fetchBlockPatterns();\n\t\tdispatch( { type: 'RECEIVE_BLOCK_PATTERNS', patterns } );\n\t};\n\nexport const getBlockPatternCategories =\n\t() =>\n\tasync ( { dispatch } ) => {\n\t\tconst categories = await apiFetch( {\n\t\t\tpath: '/wp/v2/block-patterns/categories',\n\t\t} );\n\t\tdispatch( { type: 'RECEIVE_BLOCK_PATTERN_CATEGORIES', categories } );\n\t};\n\nexport const getUserPatternCategories =\n\t() =>\n\tasync ( { dispatch, resolveSelect } ) => {\n\t\tconst patternCategories = await resolveSelect.getEntityRecords(\n\t\t\t'taxonomy',\n\t\t\t'wp_pattern_category',\n\t\t\t{\n\t\t\t\tper_page: -1,\n\t\t\t\t_fields: 'id,name,description,slug',\n\t\t\t\tcontext: 'view',\n\t\t\t}\n\t\t);\n\n\t\tconst mappedPatternCategories =\n\t\t\tpatternCategories?.map( ( userCategory ) => ( {\n\t\t\t\t...userCategory,\n\t\t\t\tlabel: decodeEntities( userCategory.name ),\n\t\t\t\tname: userCategory.slug,\n\t\t\t} ) ) || [];\n\n\t\tdispatch( {\n\t\t\ttype: 'RECEIVE_USER_PATTERN_CATEGORIES',\n\t\t\tpatternCategories: mappedPatternCategories,\n\t\t} );\n\t};\n\nexport const getNavigationFallbackId =\n\t() =>\n\tasync ( { dispatch, select } ) => {\n\t\tconst fallback = await apiFetch( {\n\t\t\tpath: addQueryArgs( '/wp-block-editor/v1/navigation-fallback', {\n\t\t\t\t_embed: true,\n\t\t\t} ),\n\t\t} );\n\n\t\tconst record = fallback?._embedded?.self;\n\n\t\tdispatch.receiveNavigationFallbackId( fallback?.id );\n\n\t\tif ( record ) {\n\t\t\t// If the fallback is already in the store, don't invalidate navigation queries.\n\t\t\t// Otherwise, invalidate the cache for the scenario where there were no Navigation\n\t\t\t// posts in the state and the fallback created one.\n\t\t\tconst existingFallbackEntityRecord = select.getEntityRecord(\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\tfallback.id\n\t\t\t);\n\t\t\tconst invalidateNavigationQueries = ! existingFallbackEntityRecord;\n\t\t\tdispatch.receiveEntityRecords(\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\trecord,\n\t\t\t\tundefined,\n\t\t\t\tinvalidateNavigationQueries\n\t\t\t);\n\n\t\t\t// Resolve to avoid further network requests.\n\t\t\tdispatch.finishResolution( 'getEntityRecord', [\n\t\t\t\t'postType',\n\t\t\t\t'wp_navigation',\n\t\t\t\tfallback.id,\n\t\t\t] );\n\t\t}\n\t};\n\nexport const getDefaultTemplateId =\n\t( query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst template = await apiFetch( {\n\t\t\tpath: addQueryArgs( '/wp/v2/templates/lookup', query ),\n\t\t} );\n\t\tif ( template ) {\n\t\t\tdispatch.receiveDefaultTemplateId( query, template.id );\n\t\t}\n\t};\n\n/**\n * Requests an entity's revisions from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} recordKey The key of the entity record whose revisions you want to fetch.\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getRevisions =\n\t( kind, name, recordKey, query = {} ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( query._fields ) {\n\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t// the ID.\n\t\t\tquery = {\n\t\t\t\t...query,\n\t\t\t\t_fields: [\n\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\tentityConfig.revisionKey || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t] ),\n\t\t\t\t].join(),\n\t\t\t};\n\t\t}\n\n\t\tconst path = addQueryArgs(\n\t\t\tentityConfig.getRevisionsUrl( recordKey ),\n\t\t\tquery\n\t\t);\n\n\t\tlet records, response;\n\t\tconst meta = {};\n\t\tconst isPaginated =\n\t\t\tentityConfig.supportsPagination && query.per_page !== -1;\n\t\ttry {\n\t\t\tresponse = await apiFetch( { path, parse: ! isPaginated } );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our request comes back with an API error.\n\t\t\treturn;\n\t\t}\n\n\t\tif ( response ) {\n\t\t\tif ( isPaginated ) {\n\t\t\t\trecords = Object.values( await response.json() );\n\t\t\t\tmeta.totalItems = parseInt(\n\t\t\t\t\tresponse.headers.get( 'X-WP-Total' )\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\trecords = Object.values( response );\n\t\t\t}\n\n\t\t\t// If we request fields but the result doesn't contain the fields,\n\t\t\t// explicitly set these fields as \"undefined\"\n\t\t\t// that way we consider the query \"fulfilled\".\n\t\t\tif ( query._fields ) {\n\t\t\t\trecords = records.map( ( record ) => {\n\t\t\t\t\tquery._fields.split( ',' ).forEach( ( field ) => {\n\t\t\t\t\t\tif ( ! record.hasOwnProperty( field ) ) {\n\t\t\t\t\t\t\trecord[ field ] = undefined;\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn record;\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\tdispatch.receiveRevisions(\n\t\t\t\tkind,\n\t\t\t\tname,\n\t\t\t\trecordKey,\n\t\t\t\trecords,\n\t\t\t\tquery,\n\t\t\t\tfalse,\n\t\t\t\tmeta\n\t\t\t);\n\n\t\t\t// When requesting all fields, the list of results can be used to\n\t\t\t// resolve the `getRevision` selector in addition to `getRevisions`.\n\t\t\tif ( ! query?._fields && ! query.context ) {\n\t\t\t\tconst key = entityConfig.key || DEFAULT_ENTITY_KEY;\n\t\t\t\tconst resolutionsArgs = records\n\t\t\t\t\t.filter( ( record ) => record[ key ] )\n\t\t\t\t\t.map( ( record ) => [\n\t\t\t\t\t\tkind,\n\t\t\t\t\t\tname,\n\t\t\t\t\t\trecordKey,\n\t\t\t\t\t\trecord[ key ],\n\t\t\t\t\t] );\n\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'START_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getRevision',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t\tdispatch( {\n\t\t\t\t\ttype: 'FINISH_RESOLUTIONS',\n\t\t\t\t\tselectorName: 'getRevision',\n\t\t\t\t\targs: resolutionsArgs,\n\t\t\t\t} );\n\t\t\t}\n\t\t}\n\t};\n\n// Invalidate cache when a new revision is created.\ngetRevisions.shouldInvalidate = ( action, kind, name, recordKey ) =>\n\taction.type === 'SAVE_ENTITY_RECORD_FINISH' &&\n\tname === action.name &&\n\tkind === action.kind &&\n\t! action.error &&\n\trecordKey === action.recordId;\n\n/**\n * Requests a specific Entity revision from the REST API.\n *\n * @param {string} kind Entity kind.\n * @param {string} name Entity name.\n * @param {number|string} recordKey The key of the entity record whose revisions you want to fetch.\n * @param {number|string} revisionKey The revision's key.\n * @param {Object|undefined} query Optional object of query parameters to\n * include with request. If requesting specific\n * fields, fields must always include the ID.\n */\nexport const getRevision =\n\t( kind, name, recordKey, revisionKey, query ) =>\n\tasync ( { dispatch } ) => {\n\t\tconst configs = await dispatch( getOrLoadEntitiesConfig( kind, name ) );\n\t\tconst entityConfig = configs.find(\n\t\t\t( config ) => config.name === name && config.kind === kind\n\t\t);\n\n\t\tif ( ! entityConfig || entityConfig?.__experimentalNoFetch ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( query !== undefined && query._fields ) {\n\t\t\t// If requesting specific fields, items and query association to said\n\t\t\t// records are stored by ID reference. Thus, fields must always include\n\t\t\t// the ID.\n\t\t\tquery = {\n\t\t\t\t...query,\n\t\t\t\t_fields: [\n\t\t\t\t\t...new Set( [\n\t\t\t\t\t\t...( getNormalizedCommaSeparable( query._fields ) ||\n\t\t\t\t\t\t\t[] ),\n\t\t\t\t\t\tentityConfig.revisionKey || DEFAULT_ENTITY_KEY,\n\t\t\t\t\t] ),\n\t\t\t\t].join(),\n\t\t\t};\n\t\t}\n\t\tconst path = addQueryArgs(\n\t\t\tentityConfig.getRevisionsUrl( recordKey, revisionKey ),\n\t\t\tquery\n\t\t);\n\n\t\tlet record;\n\t\ttry {\n\t\t\trecord = await apiFetch( { path } );\n\t\t} catch ( error ) {\n\t\t\t// Do nothing if our request comes back with an API error.\n\t\t\treturn;\n\t\t}\n\n\t\tif ( record ) {\n\t\t\tdispatch.receiveRevisions( kind, name, recordKey, record, query );\n\t\t}\n\t};\n"],"mappings":"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","ignoreList":[]}
@@ -50,7 +50,6 @@ exports.isDeletingEntityRecord = isDeletingEntityRecord;
50
50
  exports.isPreviewEmbedFallback = isPreviewEmbedFallback;
51
51
  exports.isRequestingEmbedPreview = void 0;
52
52
  exports.isSavingEntityRecord = isSavingEntityRecord;
53
- var _rememo = _interopRequireDefault(require("rememo"));
54
53
  var _data = require("@wordpress/data");
55
54
  var _url = require("@wordpress/url");
56
55
  var _deprecated = _interopRequireDefault(require("@wordpress/deprecated"));
@@ -59,15 +58,24 @@ var _queriedData = require("./queried-data");
59
58
  var _entities = require("./entities");
60
59
  var _utils = require("./utils");
61
60
  /**
62
- * External dependencies
61
+ * WordPress dependencies
63
62
  */
64
63
 
65
64
  /**
66
- * WordPress dependencies
65
+ * Internal dependencies
67
66
  */
68
67
 
68
+ // This is an incomplete, high-level approximation of the State type.
69
+ // It makes the selectors slightly more safe, but is intended to evolve
70
+ // into a more detailed representation over time.
71
+ // See https://github.com/WordPress/gutenberg/pull/40025#discussion_r865410589 for more context.
72
+
69
73
  /**
70
- * Internal dependencies
74
+ * HTTP Query parameters sent with the API request to fetch the entity records.
75
+ */
76
+
77
+ /**
78
+ * Arguments for EntityRecord selectors.
71
79
  */
72
80
 
73
81
  /**
@@ -130,7 +138,7 @@ function getCurrentUser(state) {
130
138
  *
131
139
  * @return Users list.
132
140
  */
133
- const getUserQueryResults = exports.getUserQueryResults = (0, _rememo.default)((state, queryID) => {
141
+ const getUserQueryResults = exports.getUserQueryResults = (0, _data.createSelector)((state, queryID) => {
134
142
  var _state$users$queries$;
135
143
  const queryResults = (_state$users$queries$ = state.users.queries[queryID]) !== null && _state$users$queries$ !== void 0 ? _state$users$queries$ : [];
136
144
  return queryResults.map(id => state.users.byId[id]);
@@ -161,7 +169,7 @@ function getEntitiesByKind(state, kind) {
161
169
  *
162
170
  * @return Array of entities with config matching kind.
163
171
  */
164
- const getEntitiesConfig = exports.getEntitiesConfig = (0, _rememo.default)((state, kind) => state.entities.config.filter(entity => entity.kind === kind), (state, kind) => state.entities.config);
172
+ const getEntitiesConfig = exports.getEntitiesConfig = (0, _data.createSelector)((state, kind) => state.entities.config.filter(entity => entity.kind === kind), (state, kind) => state.entities.config);
165
173
  /**
166
174
  * Returns the entity config given its kind and name.
167
175
  *
@@ -232,7 +240,7 @@ function getEntityConfig(state, kind, name) {
232
240
  *
233
241
  * @return Record.
234
242
  */
235
- const getEntityRecord = exports.getEntityRecord = (0, _rememo.default)((state, kind, name, key, query) => {
243
+ const getEntityRecord = exports.getEntityRecord = (0, _data.createSelector)((state, kind, name, key, query) => {
236
244
  var _query$context;
237
245
  const queriedState = state.entities.records?.[kind]?.[name]?.queriedData;
238
246
  if (!queriedState) {
@@ -308,7 +316,7 @@ function __experimentalGetEntityRecordNoResolver(state, kind, name, key) {
308
316
  *
309
317
  * @return Object with the entity's raw attributes.
310
318
  */
311
- const getRawEntityRecord = exports.getRawEntityRecord = (0, _rememo.default)((state, kind, name, key) => {
319
+ const getRawEntityRecord = exports.getRawEntityRecord = (0, _data.createSelector)((state, kind, name, key) => {
312
320
  const record = getEntityRecord(state, kind, name, key);
313
321
  return record && Object.keys(record).reduce((accumulator, _key) => {
314
322
  if ((0, _utils.isRawAttribute)(getEntityConfig(state, kind, name), _key)) {
@@ -414,9 +422,13 @@ const getEntityRecordsTotalPages = (state, kind, name, query) => {
414
422
  if (!queriedState) {
415
423
  return null;
416
424
  }
417
- if (query.per_page === -1) return 1;
425
+ if (query.per_page === -1) {
426
+ return 1;
427
+ }
418
428
  const totalItems = (0, _queriedData.getQueriedTotalItems)(queriedState, query);
419
- if (!totalItems) return totalItems;
429
+ if (!totalItems) {
430
+ return totalItems;
431
+ }
420
432
  // If `per_page` is not set and the query relies on the defaults of the
421
433
  // REST endpoint, get the info from query's meta.
422
434
  if (!query.per_page) {
@@ -432,7 +444,7 @@ exports.getEntityRecordsTotalPages = getEntityRecordsTotalPages;
432
444
  *
433
445
  * @return The list of updated records
434
446
  */
435
- const __experimentalGetDirtyEntityRecords = exports.__experimentalGetDirtyEntityRecords = (0, _rememo.default)(state => {
447
+ const __experimentalGetDirtyEntityRecords = exports.__experimentalGetDirtyEntityRecords = (0, _data.createSelector)(state => {
436
448
  const {
437
449
  entities: {
438
450
  records
@@ -471,7 +483,7 @@ const __experimentalGetDirtyEntityRecords = exports.__experimentalGetDirtyEntity
471
483
  *
472
484
  * @return The list of records being saved.
473
485
  */
474
- const __experimentalGetEntitiesBeingSaved = exports.__experimentalGetEntitiesBeingSaved = (0, _rememo.default)(state => {
486
+ const __experimentalGetEntitiesBeingSaved = exports.__experimentalGetEntitiesBeingSaved = (0, _data.createSelector)(state => {
475
487
  const {
476
488
  entities: {
477
489
  records
@@ -528,7 +540,7 @@ function getEntityRecordEdits(state, kind, name, recordId) {
528
540
  *
529
541
  * @return The entity record's non transient edits.
530
542
  */
531
- const getEntityRecordNonTransientEdits = exports.getEntityRecordNonTransientEdits = (0, _rememo.default)((state, kind, name, recordId) => {
543
+ const getEntityRecordNonTransientEdits = exports.getEntityRecordNonTransientEdits = (0, _data.createSelector)((state, kind, name, recordId) => {
532
544
  const {
533
545
  transientEdits
534
546
  } = getEntityConfig(state, kind, name) || {};
@@ -569,10 +581,21 @@ function hasEditsForEntityRecord(state, kind, name, recordId) {
569
581
  *
570
582
  * @return The entity record, merged with its edits.
571
583
  */
572
- const getEditedEntityRecord = exports.getEditedEntityRecord = (0, _rememo.default)((state, kind, name, recordId) => ({
573
- ...getRawEntityRecord(state, kind, name, recordId),
574
- ...getEntityRecordEdits(state, kind, name, recordId)
575
- }), (state, kind, name, recordId, query) => {
584
+ const getEditedEntityRecord = exports.getEditedEntityRecord = (0, _data.createSelector)((state, kind, name, recordId) => {
585
+ const raw = getRawEntityRecord(state, kind, name, recordId);
586
+ const edited = getEntityRecordEdits(state, kind, name, recordId);
587
+ // Never return a non-falsy empty object. Unfortunately we can't return
588
+ // undefined or null because we were previously returning an empty
589
+ // object, so trying to read properties from the result would throw.
590
+ // Using false here is a workaround to avoid breaking changes.
591
+ if (!raw && !edited) {
592
+ return false;
593
+ }
594
+ return {
595
+ ...raw,
596
+ ...edited
597
+ };
598
+ }, (state, kind, name, recordId, query) => {
576
599
  var _query$context4;
577
600
  const context = (_query$context4 = query?.context) !== null && _query$context4 !== void 0 ? _query$context4 : 'default';
578
601
  return [state.entities.config, state.entities.records?.[kind]?.[name]?.queriedData.items[context]?.[recordId], state.entities.records?.[kind]?.[name]?.queriedData.itemIsComplete[context]?.[recordId], state.entities.records?.[kind]?.[name]?.edits?.[recordId]];
@@ -1047,7 +1070,7 @@ const getRevisions = (state, kind, name, recordKey, query) => {
1047
1070
  * @return Record.
1048
1071
  */
1049
1072
  exports.getRevisions = getRevisions;
1050
- const getRevision = exports.getRevision = (0, _rememo.default)((state, kind, name, recordKey, revisionKey, query) => {
1073
+ const getRevision = exports.getRevision = (0, _data.createSelector)((state, kind, name, recordKey, revisionKey, query) => {
1051
1074
  var _query$context5;
1052
1075
  const queriedState = state.entities.records?.[kind]?.[name]?.revisions?.[recordKey];
1053
1076
  if (!queriedState) {