@wordpress/core-data 7.0.0 → 7.1.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 +2 -0
- package/build/entity-types/helpers.js.map +1 -1
- package/build/entity-types/plugin.js.map +1 -1
- package/build/entity-types/theme.js.map +1 -1
- package/build/fetch/__experimental-fetch-link-suggestions.js +89 -118
- package/build/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
- package/build/queried-data/reducer.js +3 -3
- package/build/queried-data/reducer.js.map +1 -1
- package/build/reducer.js +1 -1
- package/build/reducer.js.map +1 -1
- package/build/resolvers.js +1 -1
- package/build/resolvers.js.map +1 -1
- package/build-module/entity-types/helpers.js.map +1 -1
- package/build-module/entity-types/plugin.js.map +1 -1
- package/build-module/entity-types/theme.js.map +1 -1
- package/build-module/fetch/__experimental-fetch-link-suggestions.js +86 -118
- package/build-module/fetch/__experimental-fetch-link-suggestions.js.map +1 -1
- package/build-module/queried-data/reducer.js +3 -3
- package/build-module/queried-data/reducer.js.map +1 -1
- package/build-module/reducer.js +1 -1
- package/build-module/reducer.js.map +1 -1
- package/build-module/resolvers.js +1 -1
- package/build-module/resolvers.js.map +1 -1
- package/build-types/entity-types/helpers.d.ts +1 -1
- package/build-types/entity-types/plugin.d.ts +1 -1
- package/build-types/entity-types/plugin.d.ts.map +1 -1
- package/build-types/entity-types/theme.d.ts +9 -0
- package/build-types/entity-types/theme.d.ts.map +1 -1
- package/build-types/fetch/__experimental-fetch-link-suggestions.d.ts +48 -84
- package/build-types/fetch/__experimental-fetch-link-suggestions.d.ts.map +1 -1
- package/build-types/queried-data/reducer.d.ts.map +1 -1
- package/package.json +17 -17
- package/src/entity-types/helpers.ts +1 -1
- package/src/entity-types/plugin.ts +1 -1
- package/src/entity-types/theme.ts +10 -0
- package/src/fetch/__experimental-fetch-link-suggestions.ts +296 -0
- package/src/fetch/test/__experimental-fetch-link-suggestions.js +95 -1
- package/src/queried-data/reducer.js +4 -3
- package/src/reducer.js +1 -1
- package/src/resolvers.js +1 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/src/fetch/__experimental-fetch-link-suggestions.js +0 -237
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["camelCase","addQueryArgs","decodeEntities","apiFetch","STORE_NAME","getOrLoadEntitiesConfig","DEFAULT_ENTITY_KEY","forwardResolver","getNormalizedCommaSeparable","getSyncProvider","fetchBlockPatterns","getAuthors","query","dispatch","path","users","receiveUserQuery","getCurrentUser","currentUser","receiveCurrentUser","getEntityRecord","kind","name","key","select","configs","entityConfig","find","config","__experimentalNoFetch","lock","__unstableAcquireStoreLock","exclusive","window","__experimentalEnableSync","syncConfig","globalThis","IS_GUTENBERG_PLUGIN","objectId","getSyncObjectId","bootstrap","syncObjectType","record","receiveEntityRecords","type","recordId","edits","meta","undo","undefined","_fields","Set","join","baseURL","baseURLParams","include","hasRecords","hasEntityRecords","__unstableReleaseStoreLock","getRawEntityRecord","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","receiveThemeGlobalStyleRevisions","getBlockPatterns","patterns","getBlockPatternCategories","categories","getUserPatternCategories","patternCategories","mappedPatternCategories","userCategory","label","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 ( globalThis.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\t// Endpoint may return an empty object if no template is found.\n\t\tif ( template?.id ) {\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":[]}
|
|
1
|
+
{"version":3,"names":["camelCase","addQueryArgs","decodeEntities","apiFetch","STORE_NAME","getOrLoadEntitiesConfig","DEFAULT_ENTITY_KEY","forwardResolver","getNormalizedCommaSeparable","getSyncProvider","fetchBlockPatterns","getAuthors","query","dispatch","path","users","receiveUserQuery","getCurrentUser","currentUser","receiveCurrentUser","getEntityRecord","kind","name","key","select","configs","entityConfig","find","config","__experimentalNoFetch","lock","__unstableAcquireStoreLock","exclusive","window","__experimentalEnableSync","syncConfig","globalThis","IS_GUTENBERG_PLUGIN","objectId","getSyncObjectId","bootstrap","syncObjectType","record","receiveEntityRecords","type","recordId","edits","meta","undo","undefined","_fields","Set","join","baseURL","baseURLParams","include","hasRecords","hasEntityRecords","__unstableReleaseStoreLock","getRawEntityRecord","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","receiveThemeGlobalStyleRevisions","getBlockPatterns","patterns","getBlockPatternCategories","categories","getUserPatternCategories","patternCategories","mappedPatternCategories","userCategory","label","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 ( globalThis.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\t// Endpoint may return an empty object if no template is found.\n\t\tif ( template?.id ) {\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":[]}
|
|
@@ -101,7 +101,7 @@ export interface RenderedText<C extends Context> {
|
|
|
101
101
|
* For example, in the block editor, content.rendered could used as a visual preview, and
|
|
102
102
|
* content.raw could be used to populate the code editor.
|
|
103
103
|
*
|
|
104
|
-
* When updating these rendered fields,
|
|
104
|
+
* When updating these rendered fields, JavaScript is not be able to properly render arbitrary block
|
|
105
105
|
* markup. Therefore, it stores only the raw markup without the rendered part. And since that's a string,
|
|
106
106
|
* the entire field becomes a string.
|
|
107
107
|
*
|
|
@@ -57,6 +57,6 @@ declare module './base-entity-records' {
|
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
|
-
export type PluginStatus = 'active' | 'inactive';
|
|
60
|
+
export type PluginStatus = 'active' | 'inactive' | 'network-active';
|
|
61
61
|
export type Plugin<C extends Context = 'edit'> = OmitNevers<_BaseEntityRecords.Plugin<C>>;
|
|
62
62
|
//# sourceMappingURL=plugin.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../../src/entity-types/plugin.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EACX,OAAO,EACP,eAAe,EACf,YAAY,EACZ,UAAU,EACV,MAAM,WAAW,CAAC;AAEnB,OAAO,KAAK,EAAE,iBAAiB,IAAI,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAErF,OAAO,QAAQ,uBAAuB,CAAC;IACtC,UAAiB,iBAAiB,CAAC;QAClC,UAAiB,MAAM,CAAE,CAAC,SAAS,OAAO;YACzC;;eAEG;YACH,MAAM,EAAE,MAAM,CAAC;YACf;;eAEG;YACH,MAAM,EAAE,YAAY,CAAC;YACrB;;eAEG;YACH,IAAI,EAAE,MAAM,CAAC;YACb;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YAC1D;;eAEG;YACH,MAAM,EAAE,eAAe,CACtB,MAAM,CAAE,MAAM,EAAE,MAAM,CAAE,EACxB,MAAM,GAAG,MAAM,EACf,CAAC,CACD,CAAC;YACF;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YAC1D;;eAEG;YACH,WAAW,EAAE,eAAe,CAC3B,YAAY,CAAE,MAAM,CAAE,EACtB,MAAM,GAAG,MAAM,EACf,CAAC,CACD,CAAC;YACF;;eAEG;YACH,OAAO,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YACvD;;eAEG;YACH,YAAY,EAAE,OAAO,CAAC;YACtB;;eAEG;YACH,WAAW,EAAE,MAAM,CAAC;YACpB;;eAEG;YACH,YAAY,EAAE,MAAM,CAAC;YACrB;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;SAC1D;KACD;CACD;AAED,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../../src/entity-types/plugin.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EACX,OAAO,EACP,eAAe,EACf,YAAY,EACZ,UAAU,EACV,MAAM,WAAW,CAAC;AAEnB,OAAO,KAAK,EAAE,iBAAiB,IAAI,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAErF,OAAO,QAAQ,uBAAuB,CAAC;IACtC,UAAiB,iBAAiB,CAAC;QAClC,UAAiB,MAAM,CAAE,CAAC,SAAS,OAAO;YACzC;;eAEG;YACH,MAAM,EAAE,MAAM,CAAC;YACf;;eAEG;YACH,MAAM,EAAE,YAAY,CAAC;YACrB;;eAEG;YACH,IAAI,EAAE,MAAM,CAAC;YACb;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YAC1D;;eAEG;YACH,MAAM,EAAE,eAAe,CACtB,MAAM,CAAE,MAAM,EAAE,MAAM,CAAE,EACxB,MAAM,GAAG,MAAM,EACf,CAAC,CACD,CAAC;YACF;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YAC1D;;eAEG;YACH,WAAW,EAAE,eAAe,CAC3B,YAAY,CAAE,MAAM,CAAE,EACtB,MAAM,GAAG,MAAM,EACf,CAAC,CACD,CAAC;YACF;;eAEG;YACH,OAAO,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;YACvD;;eAEG;YACH,YAAY,EAAE,OAAO,CAAC;YACtB;;eAEG;YACH,WAAW,EAAE,MAAM,CAAC;YACpB;;eAEG;YACH,YAAY,EAAE,MAAM,CAAC;YACrB;;eAEG;YACH,UAAU,EAAE,eAAe,CAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC,CAAE,CAAC;SAC1D;KACD;CACD;AAED,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,UAAU,GAAG,gBAAgB,CAAC;AACpE,MAAM,MAAM,MAAM,CAAE,CAAC,SAAS,OAAO,GAAG,MAAM,IAAK,UAAU,CAC5D,kBAAkB,CAAC,MAAM,CAAE,CAAC,CAAE,CAC9B,CAAC"}
|
|
@@ -125,6 +125,10 @@ declare module './base-entity-records' {
|
|
|
125
125
|
* Custom font sizes if defined by the theme.
|
|
126
126
|
*/
|
|
127
127
|
'editor-font-sizes': boolean | FontSize[];
|
|
128
|
+
/**
|
|
129
|
+
* Custom spacing sizes if defined by the theme.
|
|
130
|
+
*/
|
|
131
|
+
'editor-spacing-sizes': boolean | SpacingSize[];
|
|
128
132
|
/**
|
|
129
133
|
* Custom gradient presets if defined by the theme.
|
|
130
134
|
*/
|
|
@@ -202,6 +206,11 @@ declare module './base-entity-records' {
|
|
|
202
206
|
size: number;
|
|
203
207
|
slug: string;
|
|
204
208
|
}
|
|
209
|
+
interface SpacingSize {
|
|
210
|
+
name: string;
|
|
211
|
+
size: number;
|
|
212
|
+
slug: string;
|
|
213
|
+
}
|
|
205
214
|
interface GradientPreset {
|
|
206
215
|
name: string;
|
|
207
216
|
gradient: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/entity-types/theme.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/entity-types/theme.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,35 +1,36 @@
|
|
|
1
|
-
export
|
|
2
|
-
/**
|
|
3
|
-
* Filters the search by type
|
|
4
|
-
*/
|
|
5
|
-
export type WPLinkSearchType = 'attachment' | 'post' | 'term' | 'post-format';
|
|
6
|
-
/**
|
|
7
|
-
* A link with an id may be of kind post-type or taxonomy
|
|
8
|
-
*/
|
|
9
|
-
export type WPKind = 'post-type' | 'taxonomy';
|
|
10
|
-
export type WPLinkSearchOptions = {
|
|
1
|
+
export type SearchOptions = {
|
|
11
2
|
/**
|
|
12
3
|
* Displays initial search suggestions, when true.
|
|
13
4
|
*/
|
|
14
|
-
isInitialSuggestions?: boolean
|
|
5
|
+
isInitialSuggestions?: boolean;
|
|
6
|
+
/**
|
|
7
|
+
* Search options for initial suggestions.
|
|
8
|
+
*/
|
|
9
|
+
initialSuggestionsSearchOptions?: Omit<SearchOptions, 'isInitialSuggestions' | 'initialSuggestionsSearchOptions'>;
|
|
15
10
|
/**
|
|
16
11
|
* Filters by search type.
|
|
17
12
|
*/
|
|
18
|
-
type?:
|
|
13
|
+
type?: 'attachment' | 'post' | 'term' | 'post-format';
|
|
19
14
|
/**
|
|
20
15
|
* Slug of the post-type or taxonomy.
|
|
21
16
|
*/
|
|
22
|
-
subtype?: string
|
|
17
|
+
subtype?: string;
|
|
23
18
|
/**
|
|
24
19
|
* Which page of results to return.
|
|
25
20
|
*/
|
|
26
|
-
page?: number
|
|
21
|
+
page?: number;
|
|
27
22
|
/**
|
|
28
23
|
* Search results per page.
|
|
29
24
|
*/
|
|
30
|
-
perPage?: number
|
|
25
|
+
perPage?: number;
|
|
31
26
|
};
|
|
32
|
-
export type
|
|
27
|
+
export type EditorSettings = {
|
|
28
|
+
/**
|
|
29
|
+
* Disables post formats, when true.
|
|
30
|
+
*/
|
|
31
|
+
disablePostFormats?: boolean;
|
|
32
|
+
};
|
|
33
|
+
export type SearchResult = {
|
|
33
34
|
/**
|
|
34
35
|
* Post or term id.
|
|
35
36
|
*/
|
|
@@ -49,76 +50,17 @@ export type WPLinkSearchResult = {
|
|
|
49
50
|
/**
|
|
50
51
|
* Link kind of post-type or taxonomy
|
|
51
52
|
*/
|
|
52
|
-
kind?:
|
|
53
|
-
};
|
|
54
|
-
export type WPLinkSearchResultAugments = {
|
|
55
|
-
/**
|
|
56
|
-
* Contains kind information.
|
|
57
|
-
*/
|
|
58
|
-
meta?: {
|
|
59
|
-
kind: WPKind;
|
|
60
|
-
} | undefined;
|
|
61
|
-
/**
|
|
62
|
-
* Optional subtype if it exists.
|
|
63
|
-
*/
|
|
64
|
-
subtype?: WPKind | undefined;
|
|
65
|
-
};
|
|
66
|
-
export type WPLinkSearchResultAugmented = WPLinkSearchResult & WPLinkSearchResultAugments;
|
|
67
|
-
export type WPEditorSettings = {
|
|
68
|
-
/**
|
|
69
|
-
* Disables post formats, when true.
|
|
70
|
-
*/
|
|
71
|
-
disablePostFormats?: boolean | undefined;
|
|
53
|
+
kind?: string;
|
|
72
54
|
};
|
|
73
55
|
/**
|
|
74
|
-
*
|
|
56
|
+
* Fetches link suggestions from the WordPress API.
|
|
75
57
|
*
|
|
76
|
-
*
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* A link with an id may be of kind post-type or taxonomy
|
|
58
|
+
* WordPress does not support searching multiple tables at once, e.g. posts and terms, so we
|
|
59
|
+
* perform multiple queries at the same time and then merge the results together.
|
|
80
60
|
*
|
|
81
|
-
* @
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
* @typedef WPLinkSearchOptions
|
|
85
|
-
*
|
|
86
|
-
* @property {boolean} [isInitialSuggestions] Displays initial search suggestions, when true.
|
|
87
|
-
* @property {WPLinkSearchType} [type] Filters by search type.
|
|
88
|
-
* @property {string} [subtype] Slug of the post-type or taxonomy.
|
|
89
|
-
* @property {number} [page] Which page of results to return.
|
|
90
|
-
* @property {number} [perPage] Search results per page.
|
|
91
|
-
*/
|
|
92
|
-
/**
|
|
93
|
-
* @typedef WPLinkSearchResult
|
|
94
|
-
*
|
|
95
|
-
* @property {number} id Post or term id.
|
|
96
|
-
* @property {string} url Link url.
|
|
97
|
-
* @property {string} title Title of the link.
|
|
98
|
-
* @property {string} type The taxonomy or post type slug or type URL.
|
|
99
|
-
* @property {WPKind} [kind] Link kind of post-type or taxonomy
|
|
100
|
-
*/
|
|
101
|
-
/**
|
|
102
|
-
* @typedef WPLinkSearchResultAugments
|
|
103
|
-
*
|
|
104
|
-
* @property {{kind: WPKind}} [meta] Contains kind information.
|
|
105
|
-
* @property {WPKind} [subtype] Optional subtype if it exists.
|
|
106
|
-
*/
|
|
107
|
-
/**
|
|
108
|
-
* @typedef {WPLinkSearchResult & WPLinkSearchResultAugments} WPLinkSearchResultAugmented
|
|
109
|
-
*/
|
|
110
|
-
/**
|
|
111
|
-
* @typedef WPEditorSettings
|
|
112
|
-
*
|
|
113
|
-
* @property {boolean} [ disablePostFormats ] Disables post formats, when true.
|
|
114
|
-
*/
|
|
115
|
-
/**
|
|
116
|
-
* Fetches link suggestions from the API.
|
|
117
|
-
*
|
|
118
|
-
* @async
|
|
119
|
-
* @param {string} search
|
|
120
|
-
* @param {WPLinkSearchOptions} [searchOptions]
|
|
121
|
-
* @param {WPEditorSettings} [settings]
|
|
61
|
+
* @param search
|
|
62
|
+
* @param searchOptions
|
|
63
|
+
* @param editorSettings
|
|
122
64
|
*
|
|
123
65
|
* @example
|
|
124
66
|
* ```js
|
|
@@ -133,7 +75,29 @@ export type WPEditorSettings = {
|
|
|
133
75
|
* searchOptions
|
|
134
76
|
* ) => fetchLinkSuggestions( search, searchOptions, settings );
|
|
135
77
|
* ```
|
|
136
|
-
* @return {Promise< WPLinkSearchResult[] >} List of search suggestions
|
|
137
78
|
*/
|
|
138
|
-
|
|
79
|
+
export default function fetchLinkSuggestions(search: string, searchOptions?: SearchOptions, editorSettings?: EditorSettings): Promise<SearchResult[]>;
|
|
80
|
+
/**
|
|
81
|
+
* Sort search results by relevance to the given query.
|
|
82
|
+
*
|
|
83
|
+
* Sorting is necessary as we're querying multiple endpoints and merging the results. For example
|
|
84
|
+
* a taxonomy title might be more relevant than a post title, but by default taxonomy results will
|
|
85
|
+
* be ordered after all the (potentially irrelevant) post results.
|
|
86
|
+
*
|
|
87
|
+
* We sort by scoring each result, where the score is the number of tokens in the title that are
|
|
88
|
+
* also in the search query, divided by the total number of tokens in the title. This gives us a
|
|
89
|
+
* score between 0 and 1, where 1 is a perfect match.
|
|
90
|
+
*
|
|
91
|
+
* @param results
|
|
92
|
+
* @param search
|
|
93
|
+
*/
|
|
94
|
+
export declare function sortResults(results: SearchResult[], search: string): SearchResult[];
|
|
95
|
+
/**
|
|
96
|
+
* Turns text into an array of tokens, with whitespace and punctuation removed.
|
|
97
|
+
*
|
|
98
|
+
* For example, `"I'm having a ball."` becomes `[ "im", "having", "a", "ball" ]`.
|
|
99
|
+
*
|
|
100
|
+
* @param text
|
|
101
|
+
*/
|
|
102
|
+
export declare function tokenize(text: string): string[];
|
|
139
103
|
//# sourceMappingURL=__experimental-fetch-link-suggestions.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"__experimental-fetch-link-suggestions.d.ts","sourceRoot":"","sources":["../../src/fetch/__experimental-fetch-link-suggestions.
|
|
1
|
+
{"version":3,"file":"__experimental-fetch-link-suggestions.d.ts","sourceRoot":"","sources":["../../src/fetch/__experimental-fetch-link-suggestions.ts"],"names":[],"mappings":"AAQA,MAAM,MAAM,aAAa,GAAG;IAC3B;;OAEG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B;;OAEG;IACH,+BAA+B,CAAC,EAAE,IAAI,CACrC,aAAa,EACb,sBAAsB,GAAG,iCAAiC,CAC1D,CAAC;IACF;;OAEG;IACH,IAAI,CAAC,EAAE,YAAY,GAAG,MAAM,GAAG,MAAM,GAAG,aAAa,CAAC;IACtD;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC5B;;OAEG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AAiBF,MAAM,MAAM,YAAY,GAAG;IAC1B;;OAEG;IACH,EAAE,EAAE,MAAM,CAAC;IACX;;OAEG;IACH,GAAG,EAAE,MAAM,CAAC;IACZ;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC;IACd;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAA8B,oBAAoB,CACjD,MAAM,EAAE,MAAM,EACd,aAAa,GAAE,aAAkB,EACjC,cAAc,GAAE,cAAmB,GACjC,OAAO,CAAE,YAAY,EAAE,CAAE,CA0I3B;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,WAAW,CAAE,OAAO,EAAE,YAAY,EAAE,EAAE,MAAM,EAAE,MAAM,kBAiBnE;AAED;;;;;;GAMG;AACH,wBAAgB,QAAQ,CAAE,IAAI,EAAE,MAAM,GAAI,MAAM,EAAE,CAIjD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reducer.d.ts","sourceRoot":"","sources":["../../src/queried-data/reducer.js"],"names":[],"mappings":"AA4BA;;;;;;;;;;GAUG;AACH,0CAPY,MAAM,MAAM,CAAC,sBACd,MAAM,EAAE,QACR,MAAM,WACN,MAAM,GAEL,MAAM,EAAE,CA+BnB;AAyBD;;;;;;;;GAQG;AACH,
|
|
1
|
+
{"version":3,"file":"reducer.d.ts","sourceRoot":"","sources":["../../src/queried-data/reducer.js"],"names":[],"mappings":"AA4BA;;;;;;;;;;GAUG;AACH,0CAPY,MAAM,MAAM,CAAC,sBACd,MAAM,EAAE,QACR,MAAM,WACN,MAAM,GAEL,MAAM,EAAE,CA+BnB;AAyBD;;;;;;;;GAQG;AACH,oDA8BC;AAED;;;;;;;;;;;GAWG;AACH;;;;;QAFmB,MAAM;YAAQ,MAAM,GAAC,OAAO;;EA6C9C"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@wordpress/core-data",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.1.0",
|
|
4
4
|
"description": "Access to and manipulation of core WordPress entities.",
|
|
5
5
|
"author": "The WordPress Contributors",
|
|
6
6
|
"license": "GPL-2.0-or-later",
|
|
@@ -32,21 +32,21 @@
|
|
|
32
32
|
],
|
|
33
33
|
"dependencies": {
|
|
34
34
|
"@babel/runtime": "^7.16.0",
|
|
35
|
-
"@wordpress/api-fetch": "^7.
|
|
36
|
-
"@wordpress/block-editor": "^13.
|
|
37
|
-
"@wordpress/blocks": "^13.
|
|
38
|
-
"@wordpress/compose": "^7.
|
|
39
|
-
"@wordpress/data": "^10.
|
|
40
|
-
"@wordpress/deprecated": "^4.
|
|
41
|
-
"@wordpress/element": "^6.
|
|
42
|
-
"@wordpress/html-entities": "^4.
|
|
43
|
-
"@wordpress/i18n": "^5.
|
|
44
|
-
"@wordpress/is-shallow-equal": "^5.
|
|
45
|
-
"@wordpress/private-apis": "^1.
|
|
46
|
-
"@wordpress/rich-text": "^7.
|
|
47
|
-
"@wordpress/sync": "^1.
|
|
48
|
-
"@wordpress/undo-manager": "^1.
|
|
49
|
-
"@wordpress/url": "^4.
|
|
35
|
+
"@wordpress/api-fetch": "^7.1.0",
|
|
36
|
+
"@wordpress/block-editor": "^13.1.0",
|
|
37
|
+
"@wordpress/blocks": "^13.1.0",
|
|
38
|
+
"@wordpress/compose": "^7.1.0",
|
|
39
|
+
"@wordpress/data": "^10.1.0",
|
|
40
|
+
"@wordpress/deprecated": "^4.1.0",
|
|
41
|
+
"@wordpress/element": "^6.1.0",
|
|
42
|
+
"@wordpress/html-entities": "^4.1.0",
|
|
43
|
+
"@wordpress/i18n": "^5.1.0",
|
|
44
|
+
"@wordpress/is-shallow-equal": "^5.1.0",
|
|
45
|
+
"@wordpress/private-apis": "^1.1.0",
|
|
46
|
+
"@wordpress/rich-text": "^7.1.0",
|
|
47
|
+
"@wordpress/sync": "^1.1.0",
|
|
48
|
+
"@wordpress/undo-manager": "^1.1.0",
|
|
49
|
+
"@wordpress/url": "^4.1.0",
|
|
50
50
|
"change-case": "^4.1.2",
|
|
51
51
|
"equivalent-key-map": "^0.2.2",
|
|
52
52
|
"fast-deep-equal": "^3.1.3",
|
|
@@ -60,5 +60,5 @@
|
|
|
60
60
|
"publishConfig": {
|
|
61
61
|
"access": "public"
|
|
62
62
|
},
|
|
63
|
-
"gitHead": "
|
|
63
|
+
"gitHead": "66d3bf12e67d16deddc4b4a9ec42e1d0bed3479a"
|
|
64
64
|
}
|
|
@@ -132,7 +132,7 @@ export interface RenderedText< C extends Context > {
|
|
|
132
132
|
* For example, in the block editor, content.rendered could used as a visual preview, and
|
|
133
133
|
* content.raw could be used to populate the code editor.
|
|
134
134
|
*
|
|
135
|
-
* When updating these rendered fields,
|
|
135
|
+
* When updating these rendered fields, JavaScript is not be able to properly render arbitrary block
|
|
136
136
|
* markup. Therefore, it stores only the raw markup without the rendered part. And since that's a string,
|
|
137
137
|
* the entire field becomes a string.
|
|
138
138
|
*
|
|
@@ -73,7 +73,7 @@ declare module './base-entity-records' {
|
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
|
|
76
|
-
export type PluginStatus = 'active' | 'inactive';
|
|
76
|
+
export type PluginStatus = 'active' | 'inactive' | 'network-active';
|
|
77
77
|
export type Plugin< C extends Context = 'edit' > = OmitNevers<
|
|
78
78
|
_BaseEntityRecords.Plugin< C >
|
|
79
79
|
>;
|
|
@@ -129,6 +129,10 @@ declare module './base-entity-records' {
|
|
|
129
129
|
* Custom font sizes if defined by the theme.
|
|
130
130
|
*/
|
|
131
131
|
'editor-font-sizes': boolean | FontSize[];
|
|
132
|
+
/**
|
|
133
|
+
* Custom spacing sizes if defined by the theme.
|
|
134
|
+
*/
|
|
135
|
+
'editor-spacing-sizes': boolean | SpacingSize[];
|
|
132
136
|
/**
|
|
133
137
|
* Custom gradient presets if defined by the theme.
|
|
134
138
|
*/
|
|
@@ -212,6 +216,12 @@ declare module './base-entity-records' {
|
|
|
212
216
|
slug: string;
|
|
213
217
|
}
|
|
214
218
|
|
|
219
|
+
export interface SpacingSize {
|
|
220
|
+
name: string;
|
|
221
|
+
size: number;
|
|
222
|
+
slug: string;
|
|
223
|
+
}
|
|
224
|
+
|
|
215
225
|
export interface GradientPreset {
|
|
216
226
|
name: string;
|
|
217
227
|
gradient: string;
|