@wordpress/editor 14.32.1-next.b8c8708f3.0 → 14.33.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/bindings/api.js +2 -2
- package/build/bindings/api.js.map +3 -3
- package/build/bindings/post-data.js +50 -13
- package/build/bindings/post-data.js.map +3 -3
- package/build/bindings/term-data.js +165 -0
- package/build/bindings/term-data.js.map +7 -0
- package/build/components/collab-sidebar/add-comment.js +11 -15
- package/build/components/collab-sidebar/add-comment.js.map +2 -2
- package/build/components/collab-sidebar/comment-menu-item.js +1 -1
- package/build/components/collab-sidebar/comment-menu-item.js.map +2 -2
- package/build/components/collab-sidebar/comments.js +89 -67
- package/build/components/collab-sidebar/comments.js.map +2 -2
- package/build/components/collab-sidebar/constants.js +3 -0
- package/build/components/collab-sidebar/constants.js.map +2 -2
- package/build/components/collab-sidebar/hooks.js +13 -6
- package/build/components/collab-sidebar/hooks.js.map +2 -2
- package/build/components/collab-sidebar/index.js +28 -15
- package/build/components/collab-sidebar/index.js.map +3 -3
- package/build/components/post-fields/index.js +3 -25
- package/build/components/post-fields/index.js.map +2 -2
- package/build/components/post-template/create-new-template-modal.js +2 -1
- package/build/components/post-template/create-new-template-modal.js.map +2 -2
- package/build/components/provider/index.js +3 -2
- package/build/components/provider/index.js.map +2 -2
- package/build/components/provider/use-hide-blocks-from-inserter.js +4 -26
- package/build/components/provider/use-hide-blocks-from-inserter.js.map +3 -3
- package/build/store/actions.js +12 -11
- package/build/store/actions.js.map +2 -2
- package/build-module/bindings/api.js +2 -2
- package/build-module/bindings/api.js.map +2 -2
- package/build-module/bindings/post-data.js +50 -13
- package/build-module/bindings/post-data.js.map +2 -2
- package/build-module/bindings/term-data.js +145 -0
- package/build-module/bindings/term-data.js.map +7 -0
- package/build-module/components/collab-sidebar/add-comment.js +12 -16
- package/build-module/components/collab-sidebar/add-comment.js.map +2 -2
- package/build-module/components/collab-sidebar/comment-menu-item.js +1 -1
- package/build-module/components/collab-sidebar/comment-menu-item.js.map +2 -2
- package/build-module/components/collab-sidebar/comments.js +89 -67
- package/build-module/components/collab-sidebar/comments.js.map +2 -2
- package/build-module/components/collab-sidebar/constants.js +2 -0
- package/build-module/components/collab-sidebar/constants.js.map +2 -2
- package/build-module/components/collab-sidebar/hooks.js +13 -6
- package/build-module/components/collab-sidebar/hooks.js.map +2 -2
- package/build-module/components/collab-sidebar/index.js +33 -16
- package/build-module/components/collab-sidebar/index.js.map +2 -2
- package/build-module/components/post-fields/index.js +4 -26
- package/build-module/components/post-fields/index.js.map +2 -2
- package/build-module/components/post-template/create-new-template-modal.js +2 -1
- package/build-module/components/post-template/create-new-template-modal.js.map +2 -2
- package/build-module/components/provider/index.js +3 -2
- package/build-module/components/provider/index.js.map +2 -2
- package/build-module/components/provider/use-hide-blocks-from-inserter.js +4 -26
- package/build-module/components/provider/use-hide-blocks-from-inserter.js.map +2 -2
- package/build-module/store/actions.js +12 -11
- package/build-module/store/actions.js.map +2 -2
- package/build-style/style-rtl.css +1 -0
- package/build-style/style.css +1 -0
- package/build-types/bindings/post-data.d.ts +7 -4
- package/build-types/bindings/term-data.d.ts +42 -0
- package/build-types/bindings/term-data.d.ts.map +1 -0
- package/build-types/components/collab-sidebar/add-comment.d.ts.map +1 -1
- package/build-types/components/collab-sidebar/comments.d.ts.map +1 -1
- package/build-types/components/collab-sidebar/constants.d.ts +1 -0
- package/build-types/components/collab-sidebar/constants.d.ts.map +1 -1
- package/build-types/components/collab-sidebar/hooks.d.ts.map +1 -1
- package/build-types/components/collab-sidebar/index.d.ts.map +1 -1
- package/build-types/components/post-fields/index.d.ts +1 -5
- package/build-types/components/post-fields/index.d.ts.map +1 -1
- package/build-types/components/post-template/create-new-template-modal.d.ts.map +1 -1
- package/build-types/components/provider/index.d.ts.map +1 -1
- package/build-types/components/provider/use-hide-blocks-from-inserter.d.ts.map +1 -1
- package/build-types/store/actions.d.ts.map +1 -1
- package/package.json +38 -38
- package/src/bindings/api.js +2 -2
- package/src/bindings/post-data.js +80 -17
- package/src/bindings/term-data.js +224 -0
- package/src/components/collab-sidebar/add-comment.js +12 -23
- package/src/components/collab-sidebar/comment-menu-item.js +1 -1
- package/src/components/collab-sidebar/comments.js +111 -63
- package/src/components/collab-sidebar/constants.js +1 -0
- package/src/components/collab-sidebar/hooks.js +16 -9
- package/src/components/collab-sidebar/index.js +66 -49
- package/src/components/collab-sidebar/style.scss +1 -0
- package/src/components/post-fields/index.ts +5 -42
- package/src/components/post-template/create-new-template-modal.js +1 -0
- package/src/components/provider/index.js +5 -2
- package/src/components/provider/use-hide-blocks-from-inserter.js +6 -37
- package/src/store/actions.js +15 -17
- package/tsconfig.tsbuildinfo +1 -1
- package/build/bindings/entity.js +0 -78
- package/build/bindings/entity.js.map +0 -7
- package/build-module/bindings/entity.js +0 -58
- package/build-module/bindings/entity.js.map +0 -7
- package/build-types/bindings/entity.d.ts +0 -16
- package/build-types/bindings/entity.d.ts.map +0 -1
- package/src/bindings/entity.js +0 -89
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/store/actions.js"],
|
|
4
|
-
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { speak } from '@wordpress/a11y';\nimport apiFetch from '@wordpress/api-fetch';\nimport deprecated from '@wordpress/deprecated';\nimport {\n\tparse,\n\tsynchronizeBlocksWithTemplate,\n\t__unstableSerializeAndClean,\n} from '@wordpress/blocks';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { store as coreStore } from '@wordpress/core-data';\nimport { store as blockEditorStore } from '@wordpress/block-editor';\nimport {\n\tapplyFilters,\n\tapplyFiltersAsync,\n\tdoActionAsync,\n} from '@wordpress/hooks';\nimport { store as preferencesStore } from '@wordpress/preferences';\nimport { __, sprintf } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport { localAutosaveSet } from './local-autosave';\nimport {\n\tgetNotificationArgumentsForSaveSuccess,\n\tgetNotificationArgumentsForSaveFail,\n\tgetNotificationArgumentsForTrashFail,\n} from './utils/notice-builder';\nimport { unlock } from '../lock-unlock';\n/**\n * Returns an action generator used in signalling that editor has initialized with\n * the specified post object and editor settings.\n *\n * @param {Object} post Post object.\n * @param {Object} edits Initial edited attributes object.\n * @param {Array} [template] Block Template.\n */\nexport const setupEditor =\n\t( post, edits, template ) =>\n\t( { dispatch } ) => {\n\t\tdispatch.setEditedPost( post.type, post.id );\n\t\t// Apply a template for new posts only, if exists.\n\t\tconst isNewPost = post.status === 'auto-draft';\n\t\tif ( isNewPost && template ) {\n\t\t\t// In order to ensure maximum of a single parse during setup, edits are\n\t\t\t// included as part of editor setup action. Assume edited content as\n\t\t\t// canonical if provided, falling back to post.\n\t\t\tlet content;\n\t\t\tif ( 'content' in edits ) {\n\t\t\t\tcontent = edits.content;\n\t\t\t} else {\n\t\t\t\tcontent = post.content.raw;\n\t\t\t}\n\t\t\tlet blocks = parse( content );\n\t\t\tblocks = synchronizeBlocksWithTemplate( blocks, template );\n\t\t\tdispatch.resetEditorBlocks( blocks, {\n\t\t\t\t__unstableShouldCreateUndoLevel: false,\n\t\t\t} );\n\t\t}\n\t\tif (\n\t\t\tedits &&\n\t\t\tObject.values( edits ).some(\n\t\t\t\t( [ key, edit ] ) =>\n\t\t\t\t\tedit !== ( post[ key ]?.raw ?? post[ key ] )\n\t\t\t)\n\t\t) {\n\t\t\tdispatch.editPost( edits );\n\t\t}\n\t};\n\n/**\n * Returns an action object signalling that the editor is being destroyed and\n * that any necessary state or side-effect cleanup should occur.\n *\n * @deprecated\n *\n * @return {Object} Action object.\n */\nexport function __experimentalTearDownEditor() {\n\tdeprecated(\n\t\t\"wp.data.dispatch( 'core/editor' ).__experimentalTearDownEditor\",\n\t\t{\n\t\t\tsince: '6.5',\n\t\t}\n\t);\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Returns an action object used in signalling that the latest version of the\n * post has been received, either by initialization or save.\n *\n * @deprecated Since WordPress 6.0.\n */\nexport function resetPost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).resetPost\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Initialize the editor with the setupEditorState action',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Returns an action object used in signalling that a patch of updates for the\n * latest version of the post have been received.\n *\n * @return {Object} Action object.\n * @deprecated since Gutenberg 9.7.0.\n */\nexport function updatePost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).updatePost\", {\n\t\tsince: '5.7',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn {\n\t\ttype: 'DO_NOTHING',\n\t};\n}\n\n/**\n * Setup the editor state.\n *\n * @deprecated\n *\n * @param {Object} post Post object.\n */\nexport function setupEditorState( post ) {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).setupEditorState\", {\n\t\tsince: '6.5',\n\t\talternative: \"wp.data.dispatch( 'core/editor' ).setEditedPost\",\n\t} );\n\treturn setEditedPost( post.type, post.id );\n}\n\n/**\n * Returns an action that sets the current post Type and post ID.\n *\n * @param {string} postType Post Type.\n * @param {string} postId Post ID.\n *\n * @return {Object} Action object.\n */\nexport function setEditedPost( postType, postId ) {\n\treturn {\n\t\ttype: 'SET_EDITED_POST',\n\t\tpostType,\n\t\tpostId,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that attributes of the post have\n * been edited.\n *\n * @param {Object} edits Post attributes to edit.\n * @param {Object} [options] Options for the edit.\n *\n * @example\n * ```js\n * // Update the post title\n * wp.data.dispatch( 'core/editor' ).editPost( { title: `${ newTitle }` } );\n * ```\n *\n * @return {Object} Action object\n */\nexport const editPost =\n\t( edits, options ) =>\n\t( { select, registry } ) => {\n\t\tconst { id, type } = select.getCurrentPost();\n\t\tregistry\n\t\t\t.dispatch( coreStore )\n\t\t\t.editEntityRecord( 'postType', type, id, edits, options );\n\t};\n\n/**\n * Action for saving the current post in the editor.\n *\n * @param {Object} [options]\n */\nexport const savePost =\n\t( options = {} ) =>\n\tasync ( { select, dispatch, registry } ) => {\n\t\tif ( ! select.isEditedPostSaveable() ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst content = select.getEditedPostContent();\n\n\t\tif ( ! options.isAutosave ) {\n\t\t\tdispatch.editPost( { content }, { undoIgnore: true } );\n\t\t}\n\n\t\tconst previousRecord = select.getCurrentPost();\n\t\tlet edits = {\n\t\t\tid: previousRecord.id,\n\t\t\t...registry\n\t\t\t\t.select( coreStore )\n\t\t\t\t.getEntityRecordNonTransientEdits(\n\t\t\t\t\t'postType',\n\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\tpreviousRecord.id\n\t\t\t\t),\n\t\t\tcontent,\n\t\t};\n\t\tdispatch( { type: 'REQUEST_POST_UPDATE_START', options } );\n\n\t\tlet error = false;\n\t\ttry {\n\t\t\tedits = await applyFiltersAsync(\n\t\t\t\t'editor.preSavePost',\n\t\t\t\tedits,\n\t\t\t\toptions\n\t\t\t);\n\t\t} catch ( err ) {\n\t\t\terror = err;\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait registry\n\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t.saveEntityRecord(\n\t\t\t\t\t\t'postType',\n\t\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\t\tedits,\n\t\t\t\t\t\toptions\n\t\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror =\n\t\t\t\t\terr.message && err.code !== 'unknown_error'\n\t\t\t\t\t\t? err.message\n\t\t\t\t\t\t: __( 'An error occurred while updating.' );\n\t\t\t}\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\terror = registry\n\t\t\t\t.select( coreStore )\n\t\t\t\t.getLastEntitySaveError(\n\t\t\t\t\t'postType',\n\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\tpreviousRecord.id\n\t\t\t\t);\n\t\t}\n\n\t\t// Run the hook with legacy unstable name for backward compatibility\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait applyFilters(\n\t\t\t\t\t'editor.__unstableSavePost',\n\t\t\t\t\tPromise.resolve(),\n\t\t\t\t\toptions\n\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror = err;\n\t\t\t}\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait doActionAsync(\n\t\t\t\t\t'editor.savePost',\n\t\t\t\t\t{ id: previousRecord.id, type: previousRecord.type },\n\t\t\t\t\toptions\n\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror = err;\n\t\t\t}\n\t\t}\n\t\tdispatch( { type: 'REQUEST_POST_UPDATE_FINISH', options } );\n\n\t\tif (\n\t\t\t! options.isAutosave &&\n\t\t\tpreviousRecord.type === 'wp_template' &&\n\t\t\t( typeof previousRecord.id === 'number' ||\n\t\t\t\t/^\\d+$/.test( previousRecord.id ) )\n\t\t) {\n\t\t\ttemplateActivationNotice( { select, dispatch, registry } );\n\t\t}\n\n\t\tif ( error ) {\n\t\t\tconst args = getNotificationArgumentsForSaveFail( {\n\t\t\t\tpost: previousRecord,\n\t\t\t\tedits,\n\t\t\t\terror,\n\t\t\t} );\n\t\t\tif ( args.length ) {\n\t\t\t\tregistry.dispatch( noticesStore ).createErrorNotice( ...args );\n\t\t\t}\n\t\t} else {\n\t\t\tconst updatedRecord = select.getCurrentPost();\n\t\t\tconst args = getNotificationArgumentsForSaveSuccess( {\n\t\t\t\tpreviousPost: previousRecord,\n\t\t\t\tpost: updatedRecord,\n\t\t\t\tpostType: await registry\n\t\t\t\t\t.resolveSelect( coreStore )\n\t\t\t\t\t.getPostType( updatedRecord.type ),\n\t\t\t\toptions,\n\t\t\t} );\n\t\t\tif ( args.length ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t.createSuccessNotice( ...args );\n\t\t\t}\n\t\t\t// Make sure that any edits after saving create an undo level and are\n\t\t\t// considered for change detection.\n\t\t\tif ( ! options.isAutosave ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( blockEditorStore )\n\t\t\t\t\t.__unstableMarkLastChangeAsPersistent();\n\t\t\t}\n\t\t}\n\t};\n\nasync function templateActivationNotice( { select, registry } ) {\n\tconst editorSettings = select.getEditorSettings();\n\n\t// Don't open for focused entity.\n\tif ( editorSettings.onNavigateToPreviousEntityRecord ) {\n\t\treturn;\n\t}\n\n\tconst { id, slug } = select.getCurrentPost();\n\tconst site = await registry\n\t\t.select( coreStore )\n\t\t.getEntityRecord( 'root', 'site' );\n\n\t// Already active.\n\tif ( site.active_templates[ slug ] === id ) {\n\t\treturn;\n\t}\n\n\tawait registry.dispatch( noticesStore ).createNotice(\n\t\t'info',\n\t\tsprintf(\n\t\t\t// translators: %s: template slug\n\t\t\t__( 'This is a \"%s\" template. Do you want to activate it?' ),\n\t\t\tslug\n\t\t),\n\t\t{\n\t\t\tid: 'template-activate-notice',\n\t\t\tactions: [\n\t\t\t\t{\n\t\t\t\t\tlabel: __( 'Activate' ),\n\t\t\t\t\tonClick: async () => {\n\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t.removeNotice( 'template-activate-notice' );\n\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t.createNotice(\n\t\t\t\t\t\t\t\t'info',\n\t\t\t\t\t\t\t\t__( 'Activating template\u2026' ),\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tid: 'template-activating-notice',\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tconst currentSite = await registry\n\t\t\t\t\t\t\t\t.select( coreStore )\n\t\t\t\t\t\t\t\t.getEntityRecord( 'root', 'site' );\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t\t\t\t.saveEntityRecord(\n\t\t\t\t\t\t\t\t\t'root',\n\t\t\t\t\t\t\t\t\t'site',\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tactive_templates: {\n\t\t\t\t\t\t\t\t\t\t\t...currentSite.active_templates,\n\t\t\t\t\t\t\t\t\t\t\t[ slug ]: id,\n\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{ throwOnError: true }\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.removeNotice( 'template-activating-notice' );\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.createSuccessNotice(\n\t\t\t\t\t\t\t\t\t__( 'Template activated.' )\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} catch ( error ) {\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.removeNotice( 'template-activating-notice' );\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.createErrorNotice(\n\t\t\t\t\t\t\t\t\t__( 'Template activation failed.' )\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t// Rethrow for debugging.\n\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t}\n\t);\n}\n\n/**\n * Action for refreshing the current post.\n *\n * @deprecated Since WordPress 6.0.\n */\nexport function refreshPost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).refreshPost\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Action for trashing the current post in the editor.\n */\nexport const trashPost =\n\t() =>\n\tasync ( { select, dispatch, registry } ) => {\n\t\tconst postTypeSlug = select.getCurrentPostType();\n\t\tconst postType = await registry\n\t\t\t.resolveSelect( coreStore )\n\t\t\t.getPostType( postTypeSlug );\n\t\tconst { rest_base: restBase, rest_namespace: restNamespace = 'wp/v2' } =\n\t\t\tpostType;\n\t\tdispatch( { type: 'REQUEST_POST_DELETE_START' } );\n\t\ttry {\n\t\t\tconst post = select.getCurrentPost();\n\t\t\tawait apiFetch( {\n\t\t\t\tpath: `/${ restNamespace }/${ restBase }/${ post.id }`,\n\t\t\t\tmethod: 'DELETE',\n\t\t\t} );\n\n\t\t\tawait dispatch.savePost();\n\t\t} catch ( error ) {\n\t\t\tregistry\n\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t.createErrorNotice(\n\t\t\t\t\t...getNotificationArgumentsForTrashFail( { error } )\n\t\t\t\t);\n\t\t}\n\t\tdispatch( { type: 'REQUEST_POST_DELETE_FINISH' } );\n\t};\n\n/**\n * Action that autosaves the current post. This\n * includes server-side autosaving (default) and client-side (a.k.a. local)\n * autosaving (e.g. on the Web, the post might be committed to Session\n * Storage).\n *\n * @param {Object} [options] Extra flags to identify the autosave.\n * @param {boolean} [options.local] Whether to perform a local autosave.\n */\nexport const autosave =\n\t( { local = false, ...options } = {} ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tconst post = select.getCurrentPost();\n\n\t\t// Currently template autosaving is not supported.\n\t\tif ( post.type === 'wp_template' ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( local ) {\n\t\t\tconst isPostNew = select.isEditedPostNew();\n\t\t\tconst title = select.getEditedPostAttribute( 'title' );\n\t\t\tconst content = select.getEditedPostAttribute( 'content' );\n\t\t\tconst excerpt = select.getEditedPostAttribute( 'excerpt' );\n\t\t\tlocalAutosaveSet( post.id, isPostNew, title, content, excerpt );\n\t\t} else {\n\t\t\tawait dispatch.savePost( { isAutosave: true, ...options } );\n\t\t}\n\t};\n\nexport const __unstableSaveForPreview =\n\t( { forceIsAutosaveable } = {} ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tif (\n\t\t\t( forceIsAutosaveable || select.isEditedPostAutosaveable() ) &&\n\t\t\t! select.isPostLocked()\n\t\t) {\n\t\t\tconst isDraft = [ 'draft', 'auto-draft' ].includes(\n\t\t\t\tselect.getEditedPostAttribute( 'status' )\n\t\t\t);\n\t\t\tif ( isDraft ) {\n\t\t\t\tawait dispatch.savePost( { isPreview: true } );\n\t\t\t} else {\n\t\t\t\tawait dispatch.autosave( { isPreview: true } );\n\t\t\t}\n\t\t}\n\n\t\treturn select.getEditedPostPreviewLink();\n\t};\n\n/**\n * Action that restores last popped state in undo history.\n */\nexport const redo =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( coreStore ).redo();\n\t};\n\n/**\n * Action that pops a record from undo history and undoes the edit.\n */\nexport const undo =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( coreStore ).undo();\n\t};\n\n/**\n * Action that creates an undo history record.\n *\n * @deprecated Since WordPress 6.0\n */\nexport function createUndoLevel() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).createUndoLevel\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Action that locks the editor.\n *\n * @param {Object} lock Details about the post lock status, user, and nonce.\n * @return {Object} Action object.\n */\nexport function updatePostLock( lock ) {\n\treturn {\n\t\ttype: 'UPDATE_POST_LOCK',\n\t\tlock,\n\t};\n}\n\n/**\n * Enable the publish sidebar.\n */\nexport const enablePublishSidebar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'isPublishSidebarEnabled', true );\n\t};\n\n/**\n * Disables the publish sidebar.\n */\nexport const disablePublishSidebar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'isPublishSidebarEnabled', false );\n\t};\n\n/**\n * Action that locks post saving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * const { subscribe } = wp.data;\n *\n * const initialPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );\n *\n * // Only allow publishing posts that are set to a future date.\n * if ( 'publish' !== initialPostStatus ) {\n *\n * \t// Track locking.\n * \tlet locked = false;\n *\n * \t// Watch for the publish event.\n * \tlet unssubscribe = subscribe( () => {\n * \t\tconst currentPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );\n * \t\tif ( 'publish' !== currentPostStatus ) {\n *\n * \t\t\t// Compare the post date to the current date, lock the post if the date isn't in the future.\n * \t\t\tconst postDate = new Date( wp.data.select( 'core/editor' ).getEditedPostAttribute( 'date' ) );\n * \t\t\tconst currentDate = new Date();\n * \t\t\tif ( postDate.getTime() <= currentDate.getTime() ) {\n * \t\t\t\tif ( ! locked ) {\n * \t\t\t\t\tlocked = true;\n * \t\t\t\t\twp.data.dispatch( 'core/editor' ).lockPostSaving( 'futurelock' );\n * \t\t\t\t}\n * \t\t\t} else {\n * \t\t\t\tif ( locked ) {\n * \t\t\t\t\tlocked = false;\n * \t\t\t\t\twp.data.dispatch( 'core/editor' ).unlockPostSaving( 'futurelock' );\n * \t\t\t\t}\n * \t\t\t}\n * \t\t}\n * \t} );\n * }\n * ```\n *\n * @return {Object} Action object\n */\nexport function lockPostSaving( lockName ) {\n\treturn {\n\t\ttype: 'LOCK_POST_SAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that unlocks post saving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Unlock post saving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).unlockPostSaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function unlockPostSaving( lockName ) {\n\treturn {\n\t\ttype: 'UNLOCK_POST_SAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that locks post autosaving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Lock post autosaving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).lockPostAutosaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function lockPostAutosaving( lockName ) {\n\treturn {\n\t\ttype: 'LOCK_POST_AUTOSAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that unlocks post autosaving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Unlock post saving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).unlockPostAutosaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function unlockPostAutosaving( lockName ) {\n\treturn {\n\t\ttype: 'UNLOCK_POST_AUTOSAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Returns an action object used to signal that the blocks have been updated.\n *\n * @param {Array} blocks Block Array.\n * @param {Object} [options] Optional options.\n */\nexport const resetEditorBlocks =\n\t( blocks, options = {} ) =>\n\t( { select, dispatch, registry } ) => {\n\t\tconst { __unstableShouldCreateUndoLevel, selection } = options;\n\t\tconst edits = { blocks, selection };\n\n\t\tif ( __unstableShouldCreateUndoLevel !== false ) {\n\t\t\tconst { id, type } = select.getCurrentPost();\n\t\t\tconst noChange =\n\t\t\t\tregistry\n\t\t\t\t\t.select( coreStore )\n\t\t\t\t\t.getEditedEntityRecord( 'postType', type, id ).blocks ===\n\t\t\t\tedits.blocks;\n\t\t\tif ( noChange ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t.__unstableCreateUndoLevel( 'postType', type, id );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// We create a new function here on every persistent edit\n\t\t\t// to make sure the edit makes the post dirty and creates\n\t\t\t// a new undo level.\n\t\t\tedits.content = ( { blocks: blocksForSerialization = [] } ) =>\n\t\t\t\t__unstableSerializeAndClean( blocksForSerialization );\n\t\t}\n\n\t\tdispatch.editPost( edits );\n\t};\n\n/*\n * Returns an action object used in signalling that the post editor settings have been updated.\n *\n * @param {Object} settings Updated settings\n *\n * @return {Object} Action object\n */\nexport function updateEditorSettings( settings ) {\n\treturn {\n\t\ttype: 'UPDATE_EDITOR_SETTINGS',\n\t\tsettings,\n\t};\n}\n\n/**\n * Returns an action used to set the rendering mode of the post editor. We support multiple rendering modes:\n *\n * - `post-only`: This mode extracts the post blocks from the template and renders only those. The idea is to allow the user to edit the post/page in isolation without the wrapping template.\n * - `template-locked`: This mode renders both the template and the post blocks but the template blocks are locked and can't be edited. The post blocks are editable.\n *\n * @param {string} mode Mode (one of 'post-only' or 'template-locked').\n */\nexport const setRenderingMode =\n\t( mode ) =>\n\t( { dispatch, registry, select } ) => {\n\t\tif ( select.__unstableIsEditorReady() ) {\n\t\t\t// We clear the block selection but we also need to clear the selection from the core store.\n\t\t\tregistry.dispatch( blockEditorStore ).clearSelectedBlock();\n\t\t\tdispatch.editPost( { selection: undefined }, { undoIgnore: true } );\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SET_RENDERING_MODE',\n\t\t\tmode,\n\t\t} );\n\t};\n\n/**\n * Action that changes the width of the editing canvas.\n *\n * @param {string} deviceType\n *\n * @return {Object} Action object.\n */\nexport function setDeviceType( deviceType ) {\n\treturn {\n\t\ttype: 'SET_DEVICE_TYPE',\n\t\tdeviceType,\n\t};\n}\n\n/**\n * Returns an action object used to enable or disable a panel in the editor.\n *\n * @param {string} panelName A string that identifies the panel to enable or disable.\n *\n * @return {Object} Action object.\n */\nexport const toggleEditorPanelEnabled =\n\t( panelName ) =>\n\t( { registry } ) => {\n\t\tconst inactivePanels =\n\t\t\tregistry\n\t\t\t\t.select( preferencesStore )\n\t\t\t\t.get( 'core', 'inactivePanels' ) ?? [];\n\n\t\tconst isPanelInactive = !! inactivePanels?.includes( panelName );\n\n\t\t// If the panel is inactive, remove it to enable it, else add it to\n\t\t// make it inactive.\n\t\tlet updatedInactivePanels;\n\t\tif ( isPanelInactive ) {\n\t\t\tupdatedInactivePanels = inactivePanels.filter(\n\t\t\t\t( invactivePanelName ) => invactivePanelName !== panelName\n\t\t\t);\n\t\t} else {\n\t\t\tupdatedInactivePanels = [ ...inactivePanels, panelName ];\n\t\t}\n\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'inactivePanels', updatedInactivePanels );\n\t};\n\n/**\n * Opens a closed panel and closes an open panel.\n *\n * @param {string} panelName A string that identifies the panel to open or close.\n */\nexport const toggleEditorPanelOpened =\n\t( panelName ) =>\n\t( { registry } ) => {\n\t\tconst openPanels =\n\t\t\tregistry.select( preferencesStore ).get( 'core', 'openPanels' ) ??\n\t\t\t[];\n\n\t\tconst isPanelOpen = !! openPanels?.includes( panelName );\n\n\t\t// If the panel is open, remove it to close it, else add it to\n\t\t// make it open.\n\t\tlet updatedOpenPanels;\n\t\tif ( isPanelOpen ) {\n\t\t\tupdatedOpenPanels = openPanels.filter(\n\t\t\t\t( openPanelName ) => openPanelName !== panelName\n\t\t\t);\n\t\t} else {\n\t\t\tupdatedOpenPanels = [ ...openPanels, panelName ];\n\t\t}\n\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'openPanels', updatedOpenPanels );\n\t};\n\n/**\n * Returns an action object used to remove a panel from the editor.\n *\n * @param {string} panelName A string that identifies the panel to remove.\n *\n * @return {Object} Action object.\n */\nexport function removeEditorPanel( panelName ) {\n\treturn {\n\t\ttype: 'REMOVE_PANEL',\n\t\tpanelName,\n\t};\n}\n\n/**\n * Returns an action object used to open/close the inserter.\n *\n * @param {boolean|Object} value Whether the inserter should be\n * opened (true) or closed (false).\n * To specify an insertion point,\n * use an object.\n * @param {string} value.rootClientId The root client ID to insert at.\n * @param {number} value.insertionIndex The index to insert at.\n * @param {string} value.filterValue A query to filter the inserter results.\n * @param {Function} value.onSelect A callback when an item is selected.\n * @param {string} value.tab The tab to open in the inserter.\n * @param {string} value.category The category to initialize in the inserter.\n *\n * @return {Object} Action object.\n */\nexport const setIsInserterOpened =\n\t( value ) =>\n\t( { dispatch, registry } ) => {\n\t\tif (\n\t\t\ttypeof value === 'object' &&\n\t\t\tvalue.hasOwnProperty( 'rootClientId' ) &&\n\t\t\tvalue.hasOwnProperty( 'insertionIndex' )\n\t\t) {\n\t\t\tunlock( registry.dispatch( blockEditorStore ) ).setInsertionPoint( {\n\t\t\t\trootClientId: value.rootClientId,\n\t\t\t\tindex: value.insertionIndex,\n\t\t\t} );\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SET_IS_INSERTER_OPENED',\n\t\t\tvalue,\n\t\t} );\n\t};\n\n/**\n * Returns an action object used to open/close the list view.\n *\n * @param {boolean} isOpen A boolean representing whether the list view should be opened or closed.\n * @return {Object} Action object.\n */\nexport function setIsListViewOpened( isOpen ) {\n\treturn {\n\t\ttype: 'SET_IS_LIST_VIEW_OPENED',\n\t\tisOpen,\n\t};\n}\n\n/**\n * Action that toggles Distraction free mode.\n * Distraction free mode expects there are no sidebars, as due to the\n * z-index values set, you can't close sidebars.\n *\n * @param {Object} [options={}] Optional configuration object\n * @param {boolean} [options.createNotice=true] Whether to create a notice\n */\nexport const toggleDistractionFree =\n\t( { createNotice = true } = {} ) =>\n\t( { dispatch, registry } ) => {\n\t\tconst isDistractionFree = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'distractionFree' );\n\t\tif ( isDistractionFree ) {\n\t\t\tregistry\n\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t.set( 'core', 'fixedToolbar', false );\n\t\t}\n\t\tif ( ! isDistractionFree ) {\n\t\t\tregistry.batch( () => {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t.set( 'core', 'fixedToolbar', true );\n\t\t\t\tdispatch.setIsInserterOpened( false );\n\t\t\t\tdispatch.setIsListViewOpened( false );\n\t\t\t\tunlock(\n\t\t\t\t\tregistry.dispatch( blockEditorStore )\n\t\t\t\t).resetZoomLevel();\n\t\t\t} );\n\t\t}\n\t\tregistry.batch( () => {\n\t\t\tregistry\n\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t.set( 'core', 'distractionFree', ! isDistractionFree );\n\n\t\t\tif ( createNotice ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t.createInfoNotice(\n\t\t\t\t\t\tisDistractionFree\n\t\t\t\t\t\t\t? __( 'Distraction free mode deactivated.' )\n\t\t\t\t\t\t\t: __( 'Distraction free mode activated.' ),\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tid: 'core/editor/distraction-free-mode/notice',\n\t\t\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\t\t\tactions: [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\t\t\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\t\t\tregistry.batch( () => {\n\t\t\t\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t\t\t\t.set(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'core',\n\t\t\t\t\t\t\t\t\t\t\t\t\t'fixedToolbar',\n\t\t\t\t\t\t\t\t\t\t\t\t\tisDistractionFree\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t\t\t\t.toggle(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'core',\n\t\t\t\t\t\t\t\t\t\t\t\t\t'distractionFree'\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t\t\t\t},\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}\n\t\t} );\n\t};\n\n/**\n * Action that toggles the Spotlight Mode view option.\n */\nexport const toggleSpotlightMode =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).toggle( 'core', 'focusMode' );\n\n\t\tconst isFocusMode = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'focusMode' );\n\n\t\tregistry\n\t\t\t.dispatch( noticesStore )\n\t\t\t.createInfoNotice(\n\t\t\t\tisFocusMode\n\t\t\t\t\t? __( 'Spotlight mode activated.' )\n\t\t\t\t\t: __( 'Spotlight mode deactivated.' ),\n\t\t\t\t{\n\t\t\t\t\tid: 'core/editor/toggle-spotlight-mode/notice',\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t.toggle( 'core', 'focusMode' );\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);\n\t};\n\n/**\n * Action that toggles the Top Toolbar view option.\n */\nexport const toggleTopToolbar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).toggle( 'core', 'fixedToolbar' );\n\n\t\tconst isTopToolbar = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'fixedToolbar' );\n\n\t\tregistry\n\t\t\t.dispatch( noticesStore )\n\t\t\t.createInfoNotice(\n\t\t\t\tisTopToolbar\n\t\t\t\t\t? __( 'Top toolbar activated.' )\n\t\t\t\t\t: __( 'Top toolbar deactivated.' ),\n\t\t\t\t{\n\t\t\t\t\tid: 'core/editor/toggle-top-toolbar/notice',\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\n\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t.toggle( 'core', 'fixedToolbar' );\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);\n\t};\n\n/**\n * Triggers an action used to switch editor mode.\n *\n * @param {string} mode The editor mode.\n */\nexport const switchEditorMode =\n\t( mode ) =>\n\t( { dispatch, registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).set( 'core', 'editorMode', mode );\n\n\t\tif ( mode !== 'visual' ) {\n\t\t\t// Unselect blocks when we switch to a non visual mode.\n\t\t\tregistry.dispatch( blockEditorStore ).clearSelectedBlock();\n\t\t\t// Exit zoom out state when switching to a non visual mode.\n\t\t\tunlock( registry.dispatch( blockEditorStore ) ).resetZoomLevel();\n\t\t}\n\n\t\tif ( mode === 'visual' ) {\n\t\t\tspeak( __( 'Visual editor selected' ), 'assertive' );\n\t\t} else if ( mode === 'text' ) {\n\t\t\tconst isDistractionFree = registry\n\t\t\t\t.select( preferencesStore )\n\t\t\t\t.get( 'core', 'distractionFree' );\n\t\t\tif ( isDistractionFree ) {\n\t\t\t\tdispatch.toggleDistractionFree();\n\t\t\t}\n\t\t\tspeak( __( 'Code editor selected' ), 'assertive' );\n\t\t}\n\t};\n\n/**\n * Returns an action object used in signalling that the user opened the publish\n * sidebar.\n *\n * @return {Object} Action object\n */\nexport function openPublishSidebar() {\n\treturn {\n\t\ttype: 'OPEN_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the user closed the\n * publish sidebar.\n *\n * @return {Object} Action object.\n */\nexport function closePublishSidebar() {\n\treturn {\n\t\ttype: 'CLOSE_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the user toggles the publish sidebar.\n *\n * @return {Object} Action object\n */\nexport function togglePublishSidebar() {\n\treturn {\n\t\ttype: 'TOGGLE_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Backward compatibility\n */\n\nconst getBlockEditorAction =\n\t( name ) =>\n\t( ...args ) =>\n\t( { registry } ) => {\n\t\tdeprecated( \"`wp.data.dispatch( 'core/editor' ).\" + name + '`', {\n\t\t\tsince: '5.3',\n\t\t\talternative:\n\t\t\t\t\"`wp.data.dispatch( 'core/block-editor' ).\" + name + '`',\n\t\t\tversion: '6.2',\n\t\t} );\n\t\tregistry.dispatch( blockEditorStore )[ name ]( ...args );\n\t};\n\n/**\n * @see resetBlocks in core/block-editor store.\n */\nexport const resetBlocks = getBlockEditorAction( 'resetBlocks' );\n\n/**\n * @see receiveBlocks in core/block-editor store.\n */\nexport const receiveBlocks = getBlockEditorAction( 'receiveBlocks' );\n\n/**\n * @see updateBlock in core/block-editor store.\n */\nexport const updateBlock = getBlockEditorAction( 'updateBlock' );\n\n/**\n * @see updateBlockAttributes in core/block-editor store.\n */\nexport const updateBlockAttributes = getBlockEditorAction(\n\t'updateBlockAttributes'\n);\n\n/**\n * @see selectBlock in core/block-editor store.\n */\nexport const selectBlock = getBlockEditorAction( 'selectBlock' );\n\n/**\n * @see startMultiSelect in core/block-editor store.\n */\nexport const startMultiSelect = getBlockEditorAction( 'startMultiSelect' );\n\n/**\n * @see stopMultiSelect in core/block-editor store.\n */\nexport const stopMultiSelect = getBlockEditorAction( 'stopMultiSelect' );\n\n/**\n * @see multiSelect in core/block-editor store.\n */\nexport const multiSelect = getBlockEditorAction( 'multiSelect' );\n\n/**\n * @see clearSelectedBlock in core/block-editor store.\n */\nexport const clearSelectedBlock = getBlockEditorAction( 'clearSelectedBlock' );\n\n/**\n * @see toggleSelection in core/block-editor store.\n */\nexport const toggleSelection = getBlockEditorAction( 'toggleSelection' );\n\n/**\n * @see replaceBlocks in core/block-editor store.\n */\nexport const replaceBlocks = getBlockEditorAction( 'replaceBlocks' );\n\n/**\n * @see replaceBlock in core/block-editor store.\n */\nexport const replaceBlock = getBlockEditorAction( 'replaceBlock' );\n\n/**\n * @see moveBlocksDown in core/block-editor store.\n */\nexport const moveBlocksDown = getBlockEditorAction( 'moveBlocksDown' );\n\n/**\n * @see moveBlocksUp in core/block-editor store.\n */\nexport const moveBlocksUp = getBlockEditorAction( 'moveBlocksUp' );\n\n/**\n * @see moveBlockToPosition in core/block-editor store.\n */\nexport const moveBlockToPosition = getBlockEditorAction(\n\t'moveBlockToPosition'\n);\n\n/**\n * @see insertBlock in core/block-editor store.\n */\nexport const insertBlock = getBlockEditorAction( 'insertBlock' );\n\n/**\n * @see insertBlocks in core/block-editor store.\n */\nexport const insertBlocks = getBlockEditorAction( 'insertBlocks' );\n\n/**\n * @see showInsertionPoint in core/block-editor store.\n */\nexport const showInsertionPoint = getBlockEditorAction( 'showInsertionPoint' );\n\n/**\n * @see hideInsertionPoint in core/block-editor store.\n */\nexport const hideInsertionPoint = getBlockEditorAction( 'hideInsertionPoint' );\n\n/**\n * @see setTemplateValidity in core/block-editor store.\n */\nexport const setTemplateValidity = getBlockEditorAction(\n\t'setTemplateValidity'\n);\n\n/**\n * @see synchronizeTemplate in core/block-editor store.\n */\nexport const synchronizeTemplate = getBlockEditorAction(\n\t'synchronizeTemplate'\n);\n\n/**\n * @see mergeBlocks in core/block-editor store.\n */\nexport const mergeBlocks = getBlockEditorAction( 'mergeBlocks' );\n\n/**\n * @see removeBlocks in core/block-editor store.\n */\nexport const removeBlocks = getBlockEditorAction( 'removeBlocks' );\n\n/**\n * @see removeBlock in core/block-editor store.\n */\nexport const removeBlock = getBlockEditorAction( 'removeBlock' );\n\n/**\n * @see toggleBlockMode in core/block-editor store.\n */\nexport const toggleBlockMode = getBlockEditorAction( 'toggleBlockMode' );\n\n/**\n * @see startTyping in core/block-editor store.\n */\nexport const startTyping = getBlockEditorAction( 'startTyping' );\n\n/**\n * @see stopTyping in core/block-editor store.\n */\nexport const stopTyping = getBlockEditorAction( 'stopTyping' );\n\n/**\n * @see enterFormattedText in core/block-editor store.\n */\nexport const enterFormattedText = getBlockEditorAction( 'enterFormattedText' );\n\n/**\n * @see exitFormattedText in core/block-editor store.\n */\nexport const exitFormattedText = getBlockEditorAction( 'exitFormattedText' );\n\n/**\n * @see insertDefaultBlock in core/block-editor store.\n */\nexport const insertDefaultBlock = getBlockEditorAction( 'insertDefaultBlock' );\n\n/**\n * @see updateBlockListSettings in core/block-editor store.\n */\nexport const updateBlockListSettings = getBlockEditorAction(\n\t'updateBlockListSettings'\n);\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { speak } from '@wordpress/a11y';\nimport apiFetch from '@wordpress/api-fetch';\nimport deprecated from '@wordpress/deprecated';\nimport {\n\tparse,\n\tsynchronizeBlocksWithTemplate,\n\t__unstableSerializeAndClean,\n} from '@wordpress/blocks';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { store as coreStore } from '@wordpress/core-data';\nimport { store as blockEditorStore } from '@wordpress/block-editor';\nimport {\n\tapplyFilters,\n\tapplyFiltersAsync,\n\tdoActionAsync,\n} from '@wordpress/hooks';\nimport { store as preferencesStore } from '@wordpress/preferences';\nimport { __, sprintf } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport { localAutosaveSet } from './local-autosave';\nimport {\n\tgetNotificationArgumentsForSaveSuccess,\n\tgetNotificationArgumentsForSaveFail,\n\tgetNotificationArgumentsForTrashFail,\n} from './utils/notice-builder';\nimport { unlock } from '../lock-unlock';\n/**\n * Returns an action generator used in signalling that editor has initialized with\n * the specified post object and editor settings.\n *\n * @param {Object} post Post object.\n * @param {Object} edits Initial edited attributes object.\n * @param {Array} [template] Block Template.\n */\nexport const setupEditor =\n\t( post, edits, template ) =>\n\t( { dispatch } ) => {\n\t\tdispatch.setEditedPost( post.type, post.id );\n\t\t// Apply a template for new posts only, if exists.\n\t\tconst isNewPost = post.status === 'auto-draft';\n\t\tif ( isNewPost && template ) {\n\t\t\t// In order to ensure maximum of a single parse during setup, edits are\n\t\t\t// included as part of editor setup action. Assume edited content as\n\t\t\t// canonical if provided, falling back to post.\n\t\t\tlet content;\n\t\t\tif ( 'content' in edits ) {\n\t\t\t\tcontent = edits.content;\n\t\t\t} else {\n\t\t\t\tcontent = post.content.raw;\n\t\t\t}\n\t\t\tlet blocks = parse( content );\n\t\t\tblocks = synchronizeBlocksWithTemplate( blocks, template );\n\t\t\tdispatch.resetEditorBlocks( blocks, {\n\t\t\t\t__unstableShouldCreateUndoLevel: false,\n\t\t\t} );\n\t\t}\n\t\tif (\n\t\t\tedits &&\n\t\t\tObject.values( edits ).some(\n\t\t\t\t( [ key, edit ] ) =>\n\t\t\t\t\tedit !== ( post[ key ]?.raw ?? post[ key ] )\n\t\t\t)\n\t\t) {\n\t\t\tdispatch.editPost( edits );\n\t\t}\n\t};\n\n/**\n * Returns an action object signalling that the editor is being destroyed and\n * that any necessary state or side-effect cleanup should occur.\n *\n * @deprecated\n *\n * @return {Object} Action object.\n */\nexport function __experimentalTearDownEditor() {\n\tdeprecated(\n\t\t\"wp.data.dispatch( 'core/editor' ).__experimentalTearDownEditor\",\n\t\t{\n\t\t\tsince: '6.5',\n\t\t}\n\t);\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Returns an action object used in signalling that the latest version of the\n * post has been received, either by initialization or save.\n *\n * @deprecated Since WordPress 6.0.\n */\nexport function resetPost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).resetPost\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Initialize the editor with the setupEditorState action',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Returns an action object used in signalling that a patch of updates for the\n * latest version of the post have been received.\n *\n * @return {Object} Action object.\n * @deprecated since Gutenberg 9.7.0.\n */\nexport function updatePost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).updatePost\", {\n\t\tsince: '5.7',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn {\n\t\ttype: 'DO_NOTHING',\n\t};\n}\n\n/**\n * Setup the editor state.\n *\n * @deprecated\n *\n * @param {Object} post Post object.\n */\nexport function setupEditorState( post ) {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).setupEditorState\", {\n\t\tsince: '6.5',\n\t\talternative: \"wp.data.dispatch( 'core/editor' ).setEditedPost\",\n\t} );\n\treturn setEditedPost( post.type, post.id );\n}\n\n/**\n * Returns an action that sets the current post Type and post ID.\n *\n * @param {string} postType Post Type.\n * @param {string} postId Post ID.\n *\n * @return {Object} Action object.\n */\nexport function setEditedPost( postType, postId ) {\n\treturn {\n\t\ttype: 'SET_EDITED_POST',\n\t\tpostType,\n\t\tpostId,\n\t};\n}\n\n/**\n * Returns an action object used in signalling that attributes of the post have\n * been edited.\n *\n * @param {Object} edits Post attributes to edit.\n * @param {Object} [options] Options for the edit.\n *\n * @example\n * ```js\n * // Update the post title\n * wp.data.dispatch( 'core/editor' ).editPost( { title: `${ newTitle }` } );\n * ```\n *\n * @return {Object} Action object\n */\nexport const editPost =\n\t( edits, options ) =>\n\t( { select, registry } ) => {\n\t\tconst { id, type } = select.getCurrentPost();\n\t\tregistry\n\t\t\t.dispatch( coreStore )\n\t\t\t.editEntityRecord( 'postType', type, id, edits, options );\n\t};\n\n/**\n * Action for saving the current post in the editor.\n *\n * @param {Object} [options]\n */\nexport const savePost =\n\t( options = {} ) =>\n\tasync ( { select, dispatch, registry } ) => {\n\t\tif ( ! select.isEditedPostSaveable() ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst content = select.getEditedPostContent();\n\n\t\tif ( ! options.isAutosave ) {\n\t\t\tdispatch.editPost( { content }, { undoIgnore: true } );\n\t\t}\n\n\t\tconst previousRecord = select.getCurrentPost();\n\t\tlet edits = {\n\t\t\tid: previousRecord.id,\n\t\t\t...registry\n\t\t\t\t.select( coreStore )\n\t\t\t\t.getEntityRecordNonTransientEdits(\n\t\t\t\t\t'postType',\n\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\tpreviousRecord.id\n\t\t\t\t),\n\t\t\tcontent,\n\t\t};\n\t\tdispatch( { type: 'REQUEST_POST_UPDATE_START', options } );\n\n\t\tlet error = false;\n\t\ttry {\n\t\t\tedits = await applyFiltersAsync(\n\t\t\t\t'editor.preSavePost',\n\t\t\t\tedits,\n\t\t\t\toptions\n\t\t\t);\n\t\t} catch ( err ) {\n\t\t\terror = err;\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait registry\n\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t.saveEntityRecord(\n\t\t\t\t\t\t'postType',\n\t\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\t\tedits,\n\t\t\t\t\t\toptions\n\t\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror =\n\t\t\t\t\terr.message && err.code !== 'unknown_error'\n\t\t\t\t\t\t? err.message\n\t\t\t\t\t\t: __( 'An error occurred while updating.' );\n\t\t\t}\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\terror = registry\n\t\t\t\t.select( coreStore )\n\t\t\t\t.getLastEntitySaveError(\n\t\t\t\t\t'postType',\n\t\t\t\t\tpreviousRecord.type,\n\t\t\t\t\tpreviousRecord.id\n\t\t\t\t);\n\t\t}\n\n\t\t// Run the hook with legacy unstable name for backward compatibility\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait applyFilters(\n\t\t\t\t\t'editor.__unstableSavePost',\n\t\t\t\t\tPromise.resolve(),\n\t\t\t\t\toptions\n\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror = err;\n\t\t\t}\n\t\t}\n\n\t\tif ( ! error ) {\n\t\t\ttry {\n\t\t\t\tawait doActionAsync(\n\t\t\t\t\t'editor.savePost',\n\t\t\t\t\t{ id: previousRecord.id, type: previousRecord.type },\n\t\t\t\t\toptions\n\t\t\t\t);\n\t\t\t} catch ( err ) {\n\t\t\t\terror = err;\n\t\t\t}\n\t\t}\n\t\tdispatch( { type: 'REQUEST_POST_UPDATE_FINISH', options } );\n\n\t\tif (\n\t\t\t! options.isAutosave &&\n\t\t\tpreviousRecord.type === 'wp_template' &&\n\t\t\t( typeof previousRecord.id === 'number' ||\n\t\t\t\t/^\\d+$/.test( previousRecord.id ) )\n\t\t) {\n\t\t\ttemplateActivationNotice( { select, dispatch, registry } );\n\t\t}\n\n\t\tif ( error ) {\n\t\t\tconst args = getNotificationArgumentsForSaveFail( {\n\t\t\t\tpost: previousRecord,\n\t\t\t\tedits,\n\t\t\t\terror,\n\t\t\t} );\n\t\t\tif ( args.length ) {\n\t\t\t\tregistry.dispatch( noticesStore ).createErrorNotice( ...args );\n\t\t\t}\n\t\t} else {\n\t\t\tconst updatedRecord = select.getCurrentPost();\n\t\t\tconst args = getNotificationArgumentsForSaveSuccess( {\n\t\t\t\tpreviousPost: previousRecord,\n\t\t\t\tpost: updatedRecord,\n\t\t\t\tpostType: await registry\n\t\t\t\t\t.resolveSelect( coreStore )\n\t\t\t\t\t.getPostType( updatedRecord.type ),\n\t\t\t\toptions,\n\t\t\t} );\n\t\t\tif ( args.length ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t.createSuccessNotice( ...args );\n\t\t\t}\n\t\t\t// Make sure that any edits after saving create an undo level and are\n\t\t\t// considered for change detection.\n\t\t\tif ( ! options.isAutosave ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( blockEditorStore )\n\t\t\t\t\t.__unstableMarkLastChangeAsPersistent();\n\t\t\t}\n\t\t}\n\t};\n\nasync function templateActivationNotice( { select, registry } ) {\n\tconst editorSettings = select.getEditorSettings();\n\n\t// Don't open for focused entity.\n\tif ( editorSettings.onNavigateToPreviousEntityRecord ) {\n\t\treturn;\n\t}\n\n\tconst { id, slug } = select.getCurrentPost();\n\tconst site = await registry\n\t\t.select( coreStore )\n\t\t.getEntityRecord( 'root', 'site' );\n\n\t// Already active.\n\tif ( site.active_templates[ slug ] === id ) {\n\t\treturn;\n\t}\n\n\tconst currentTheme = await registry\n\t\t.resolveSelect( coreStore )\n\t\t.getCurrentTheme();\n\tconst templateType = currentTheme?.default_template_types.find(\n\t\t( type ) => type.slug === slug\n\t);\n\n\tawait registry.dispatch( noticesStore ).createNotice(\n\t\t'info',\n\t\tsprintf(\n\t\t\t// translators: %s: The name (or slug) of the type of template.\n\t\t\t__( 'Do you want to activate this \"%s\" template?' ),\n\t\t\ttemplateType?.title ?? slug\n\t\t),\n\t\t{\n\t\t\tid: 'template-activate-notice',\n\t\t\tactions: [\n\t\t\t\t{\n\t\t\t\t\tlabel: __( 'Activate' ),\n\t\t\t\t\tonClick: async () => {\n\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t.createNotice(\n\t\t\t\t\t\t\t\t'info',\n\t\t\t\t\t\t\t\t__( 'Activating template\u2026' ),\n\t\t\t\t\t\t\t\t{ id: 'template-activate-notice' }\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tconst currentSite = await registry\n\t\t\t\t\t\t\t\t.select( coreStore )\n\t\t\t\t\t\t\t\t.getEntityRecord( 'root', 'site' );\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t\t\t\t.saveEntityRecord(\n\t\t\t\t\t\t\t\t\t'root',\n\t\t\t\t\t\t\t\t\t'site',\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tactive_templates: {\n\t\t\t\t\t\t\t\t\t\t\t...currentSite.active_templates,\n\t\t\t\t\t\t\t\t\t\t\t[ slug ]: id,\n\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t{ throwOnError: true }\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.createSuccessNotice(\n\t\t\t\t\t\t\t\t\t__( 'Template activated.' ),\n\t\t\t\t\t\t\t\t\t{ id: 'template-activate-notice' }\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} catch ( error ) {\n\t\t\t\t\t\t\tawait registry\n\t\t\t\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t\t\t\t.createErrorNotice(\n\t\t\t\t\t\t\t\t\t__( 'Template activation failed.' ),\n\t\t\t\t\t\t\t\t\t{ id: 'template-activate-notice' }\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t// Rethrow for debugging.\n\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t],\n\t\t}\n\t);\n}\n\n/**\n * Action for refreshing the current post.\n *\n * @deprecated Since WordPress 6.0.\n */\nexport function refreshPost() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).refreshPost\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Action for trashing the current post in the editor.\n */\nexport const trashPost =\n\t() =>\n\tasync ( { select, dispatch, registry } ) => {\n\t\tconst postTypeSlug = select.getCurrentPostType();\n\t\tconst postType = await registry\n\t\t\t.resolveSelect( coreStore )\n\t\t\t.getPostType( postTypeSlug );\n\t\tconst { rest_base: restBase, rest_namespace: restNamespace = 'wp/v2' } =\n\t\t\tpostType;\n\t\tdispatch( { type: 'REQUEST_POST_DELETE_START' } );\n\t\ttry {\n\t\t\tconst post = select.getCurrentPost();\n\t\t\tawait apiFetch( {\n\t\t\t\tpath: `/${ restNamespace }/${ restBase }/${ post.id }`,\n\t\t\t\tmethod: 'DELETE',\n\t\t\t} );\n\n\t\t\tawait dispatch.savePost();\n\t\t} catch ( error ) {\n\t\t\tregistry\n\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t.createErrorNotice(\n\t\t\t\t\t...getNotificationArgumentsForTrashFail( { error } )\n\t\t\t\t);\n\t\t}\n\t\tdispatch( { type: 'REQUEST_POST_DELETE_FINISH' } );\n\t};\n\n/**\n * Action that autosaves the current post. This\n * includes server-side autosaving (default) and client-side (a.k.a. local)\n * autosaving (e.g. on the Web, the post might be committed to Session\n * Storage).\n *\n * @param {Object} [options] Extra flags to identify the autosave.\n * @param {boolean} [options.local] Whether to perform a local autosave.\n */\nexport const autosave =\n\t( { local = false, ...options } = {} ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tconst post = select.getCurrentPost();\n\n\t\t// Currently template autosaving is not supported.\n\t\tif ( post.type === 'wp_template' ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( local ) {\n\t\t\tconst isPostNew = select.isEditedPostNew();\n\t\t\tconst title = select.getEditedPostAttribute( 'title' );\n\t\t\tconst content = select.getEditedPostAttribute( 'content' );\n\t\t\tconst excerpt = select.getEditedPostAttribute( 'excerpt' );\n\t\t\tlocalAutosaveSet( post.id, isPostNew, title, content, excerpt );\n\t\t} else {\n\t\t\tawait dispatch.savePost( { isAutosave: true, ...options } );\n\t\t}\n\t};\n\nexport const __unstableSaveForPreview =\n\t( { forceIsAutosaveable } = {} ) =>\n\tasync ( { select, dispatch } ) => {\n\t\tif (\n\t\t\t( forceIsAutosaveable || select.isEditedPostAutosaveable() ) &&\n\t\t\t! select.isPostLocked()\n\t\t) {\n\t\t\tconst isDraft = [ 'draft', 'auto-draft' ].includes(\n\t\t\t\tselect.getEditedPostAttribute( 'status' )\n\t\t\t);\n\t\t\tif ( isDraft ) {\n\t\t\t\tawait dispatch.savePost( { isPreview: true } );\n\t\t\t} else {\n\t\t\t\tawait dispatch.autosave( { isPreview: true } );\n\t\t\t}\n\t\t}\n\n\t\treturn select.getEditedPostPreviewLink();\n\t};\n\n/**\n * Action that restores last popped state in undo history.\n */\nexport const redo =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( coreStore ).redo();\n\t};\n\n/**\n * Action that pops a record from undo history and undoes the edit.\n */\nexport const undo =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( coreStore ).undo();\n\t};\n\n/**\n * Action that creates an undo history record.\n *\n * @deprecated Since WordPress 6.0\n */\nexport function createUndoLevel() {\n\tdeprecated( \"wp.data.dispatch( 'core/editor' ).createUndoLevel\", {\n\t\tsince: '6.0',\n\t\tversion: '6.3',\n\t\talternative: 'Use the core entities store instead',\n\t} );\n\treturn { type: 'DO_NOTHING' };\n}\n\n/**\n * Action that locks the editor.\n *\n * @param {Object} lock Details about the post lock status, user, and nonce.\n * @return {Object} Action object.\n */\nexport function updatePostLock( lock ) {\n\treturn {\n\t\ttype: 'UPDATE_POST_LOCK',\n\t\tlock,\n\t};\n}\n\n/**\n * Enable the publish sidebar.\n */\nexport const enablePublishSidebar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'isPublishSidebarEnabled', true );\n\t};\n\n/**\n * Disables the publish sidebar.\n */\nexport const disablePublishSidebar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'isPublishSidebarEnabled', false );\n\t};\n\n/**\n * Action that locks post saving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * const { subscribe } = wp.data;\n *\n * const initialPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );\n *\n * // Only allow publishing posts that are set to a future date.\n * if ( 'publish' !== initialPostStatus ) {\n *\n * \t// Track locking.\n * \tlet locked = false;\n *\n * \t// Watch for the publish event.\n * \tlet unssubscribe = subscribe( () => {\n * \t\tconst currentPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );\n * \t\tif ( 'publish' !== currentPostStatus ) {\n *\n * \t\t\t// Compare the post date to the current date, lock the post if the date isn't in the future.\n * \t\t\tconst postDate = new Date( wp.data.select( 'core/editor' ).getEditedPostAttribute( 'date' ) );\n * \t\t\tconst currentDate = new Date();\n * \t\t\tif ( postDate.getTime() <= currentDate.getTime() ) {\n * \t\t\t\tif ( ! locked ) {\n * \t\t\t\t\tlocked = true;\n * \t\t\t\t\twp.data.dispatch( 'core/editor' ).lockPostSaving( 'futurelock' );\n * \t\t\t\t}\n * \t\t\t} else {\n * \t\t\t\tif ( locked ) {\n * \t\t\t\t\tlocked = false;\n * \t\t\t\t\twp.data.dispatch( 'core/editor' ).unlockPostSaving( 'futurelock' );\n * \t\t\t\t}\n * \t\t\t}\n * \t\t}\n * \t} );\n * }\n * ```\n *\n * @return {Object} Action object\n */\nexport function lockPostSaving( lockName ) {\n\treturn {\n\t\ttype: 'LOCK_POST_SAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that unlocks post saving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Unlock post saving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).unlockPostSaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function unlockPostSaving( lockName ) {\n\treturn {\n\t\ttype: 'UNLOCK_POST_SAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that locks post autosaving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Lock post autosaving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).lockPostAutosaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function lockPostAutosaving( lockName ) {\n\treturn {\n\t\ttype: 'LOCK_POST_AUTOSAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Action that unlocks post autosaving.\n *\n * @param {string} lockName The lock name.\n *\n * @example\n * ```\n * // Unlock post saving with the lock key `mylock`:\n * wp.data.dispatch( 'core/editor' ).unlockPostAutosaving( 'mylock' );\n * ```\n *\n * @return {Object} Action object\n */\nexport function unlockPostAutosaving( lockName ) {\n\treturn {\n\t\ttype: 'UNLOCK_POST_AUTOSAVING',\n\t\tlockName,\n\t};\n}\n\n/**\n * Returns an action object used to signal that the blocks have been updated.\n *\n * @param {Array} blocks Block Array.\n * @param {Object} [options] Optional options.\n */\nexport const resetEditorBlocks =\n\t( blocks, options = {} ) =>\n\t( { select, dispatch, registry } ) => {\n\t\tconst { __unstableShouldCreateUndoLevel, selection } = options;\n\t\tconst edits = { blocks, selection };\n\n\t\tif ( __unstableShouldCreateUndoLevel !== false ) {\n\t\t\tconst { id, type } = select.getCurrentPost();\n\t\t\tconst noChange =\n\t\t\t\tregistry\n\t\t\t\t\t.select( coreStore )\n\t\t\t\t\t.getEditedEntityRecord( 'postType', type, id ).blocks ===\n\t\t\t\tedits.blocks;\n\t\t\tif ( noChange ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( coreStore )\n\t\t\t\t\t.__unstableCreateUndoLevel( 'postType', type, id );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// We create a new function here on every persistent edit\n\t\t\t// to make sure the edit makes the post dirty and creates\n\t\t\t// a new undo level.\n\t\t\tedits.content = ( { blocks: blocksForSerialization = [] } ) =>\n\t\t\t\t__unstableSerializeAndClean( blocksForSerialization );\n\t\t}\n\n\t\tdispatch.editPost( edits );\n\t};\n\n/*\n * Returns an action object used in signalling that the post editor settings have been updated.\n *\n * @param {Object} settings Updated settings\n *\n * @return {Object} Action object\n */\nexport function updateEditorSettings( settings ) {\n\treturn {\n\t\ttype: 'UPDATE_EDITOR_SETTINGS',\n\t\tsettings,\n\t};\n}\n\n/**\n * Returns an action used to set the rendering mode of the post editor. We support multiple rendering modes:\n *\n * - `post-only`: This mode extracts the post blocks from the template and renders only those. The idea is to allow the user to edit the post/page in isolation without the wrapping template.\n * - `template-locked`: This mode renders both the template and the post blocks but the template blocks are locked and can't be edited. The post blocks are editable.\n *\n * @param {string} mode Mode (one of 'post-only' or 'template-locked').\n */\nexport const setRenderingMode =\n\t( mode ) =>\n\t( { dispatch, registry, select } ) => {\n\t\tif ( select.__unstableIsEditorReady() ) {\n\t\t\t// We clear the block selection but we also need to clear the selection from the core store.\n\t\t\tregistry.dispatch( blockEditorStore ).clearSelectedBlock();\n\t\t\tdispatch.editPost( { selection: undefined }, { undoIgnore: true } );\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SET_RENDERING_MODE',\n\t\t\tmode,\n\t\t} );\n\t};\n\n/**\n * Action that changes the width of the editing canvas.\n *\n * @param {string} deviceType\n *\n * @return {Object} Action object.\n */\nexport function setDeviceType( deviceType ) {\n\treturn {\n\t\ttype: 'SET_DEVICE_TYPE',\n\t\tdeviceType,\n\t};\n}\n\n/**\n * Returns an action object used to enable or disable a panel in the editor.\n *\n * @param {string} panelName A string that identifies the panel to enable or disable.\n *\n * @return {Object} Action object.\n */\nexport const toggleEditorPanelEnabled =\n\t( panelName ) =>\n\t( { registry } ) => {\n\t\tconst inactivePanels =\n\t\t\tregistry\n\t\t\t\t.select( preferencesStore )\n\t\t\t\t.get( 'core', 'inactivePanels' ) ?? [];\n\n\t\tconst isPanelInactive = !! inactivePanels?.includes( panelName );\n\n\t\t// If the panel is inactive, remove it to enable it, else add it to\n\t\t// make it inactive.\n\t\tlet updatedInactivePanels;\n\t\tif ( isPanelInactive ) {\n\t\t\tupdatedInactivePanels = inactivePanels.filter(\n\t\t\t\t( invactivePanelName ) => invactivePanelName !== panelName\n\t\t\t);\n\t\t} else {\n\t\t\tupdatedInactivePanels = [ ...inactivePanels, panelName ];\n\t\t}\n\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'inactivePanels', updatedInactivePanels );\n\t};\n\n/**\n * Opens a closed panel and closes an open panel.\n *\n * @param {string} panelName A string that identifies the panel to open or close.\n */\nexport const toggleEditorPanelOpened =\n\t( panelName ) =>\n\t( { registry } ) => {\n\t\tconst openPanels =\n\t\t\tregistry.select( preferencesStore ).get( 'core', 'openPanels' ) ??\n\t\t\t[];\n\n\t\tconst isPanelOpen = !! openPanels?.includes( panelName );\n\n\t\t// If the panel is open, remove it to close it, else add it to\n\t\t// make it open.\n\t\tlet updatedOpenPanels;\n\t\tif ( isPanelOpen ) {\n\t\t\tupdatedOpenPanels = openPanels.filter(\n\t\t\t\t( openPanelName ) => openPanelName !== panelName\n\t\t\t);\n\t\t} else {\n\t\t\tupdatedOpenPanels = [ ...openPanels, panelName ];\n\t\t}\n\n\t\tregistry\n\t\t\t.dispatch( preferencesStore )\n\t\t\t.set( 'core', 'openPanels', updatedOpenPanels );\n\t};\n\n/**\n * Returns an action object used to remove a panel from the editor.\n *\n * @param {string} panelName A string that identifies the panel to remove.\n *\n * @return {Object} Action object.\n */\nexport function removeEditorPanel( panelName ) {\n\treturn {\n\t\ttype: 'REMOVE_PANEL',\n\t\tpanelName,\n\t};\n}\n\n/**\n * Returns an action object used to open/close the inserter.\n *\n * @param {boolean|Object} value Whether the inserter should be\n * opened (true) or closed (false).\n * To specify an insertion point,\n * use an object.\n * @param {string} value.rootClientId The root client ID to insert at.\n * @param {number} value.insertionIndex The index to insert at.\n * @param {string} value.filterValue A query to filter the inserter results.\n * @param {Function} value.onSelect A callback when an item is selected.\n * @param {string} value.tab The tab to open in the inserter.\n * @param {string} value.category The category to initialize in the inserter.\n *\n * @return {Object} Action object.\n */\nexport const setIsInserterOpened =\n\t( value ) =>\n\t( { dispatch, registry } ) => {\n\t\tif (\n\t\t\ttypeof value === 'object' &&\n\t\t\tvalue.hasOwnProperty( 'rootClientId' ) &&\n\t\t\tvalue.hasOwnProperty( 'insertionIndex' )\n\t\t) {\n\t\t\tunlock( registry.dispatch( blockEditorStore ) ).setInsertionPoint( {\n\t\t\t\trootClientId: value.rootClientId,\n\t\t\t\tindex: value.insertionIndex,\n\t\t\t} );\n\t\t}\n\n\t\tdispatch( {\n\t\t\ttype: 'SET_IS_INSERTER_OPENED',\n\t\t\tvalue,\n\t\t} );\n\t};\n\n/**\n * Returns an action object used to open/close the list view.\n *\n * @param {boolean} isOpen A boolean representing whether the list view should be opened or closed.\n * @return {Object} Action object.\n */\nexport function setIsListViewOpened( isOpen ) {\n\treturn {\n\t\ttype: 'SET_IS_LIST_VIEW_OPENED',\n\t\tisOpen,\n\t};\n}\n\n/**\n * Action that toggles Distraction free mode.\n * Distraction free mode expects there are no sidebars, as due to the\n * z-index values set, you can't close sidebars.\n *\n * @param {Object} [options={}] Optional configuration object\n * @param {boolean} [options.createNotice=true] Whether to create a notice\n */\nexport const toggleDistractionFree =\n\t( { createNotice = true } = {} ) =>\n\t( { dispatch, registry } ) => {\n\t\tconst isDistractionFree = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'distractionFree' );\n\t\tif ( isDistractionFree ) {\n\t\t\tregistry\n\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t.set( 'core', 'fixedToolbar', false );\n\t\t}\n\t\tif ( ! isDistractionFree ) {\n\t\t\tregistry.batch( () => {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t.set( 'core', 'fixedToolbar', true );\n\t\t\t\tdispatch.setIsInserterOpened( false );\n\t\t\t\tdispatch.setIsListViewOpened( false );\n\t\t\t\tunlock(\n\t\t\t\t\tregistry.dispatch( blockEditorStore )\n\t\t\t\t).resetZoomLevel();\n\t\t\t} );\n\t\t}\n\t\tregistry.batch( () => {\n\t\t\tregistry\n\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t.set( 'core', 'distractionFree', ! isDistractionFree );\n\n\t\t\tif ( createNotice ) {\n\t\t\t\tregistry\n\t\t\t\t\t.dispatch( noticesStore )\n\t\t\t\t\t.createInfoNotice(\n\t\t\t\t\t\tisDistractionFree\n\t\t\t\t\t\t\t? __( 'Distraction free mode deactivated.' )\n\t\t\t\t\t\t\t: __( 'Distraction free mode activated.' ),\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tid: 'core/editor/distraction-free-mode/notice',\n\t\t\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\t\t\tactions: [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\t\t\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\t\t\tregistry.batch( () => {\n\t\t\t\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t\t\t\t.set(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'core',\n\t\t\t\t\t\t\t\t\t\t\t\t\t'fixedToolbar',\n\t\t\t\t\t\t\t\t\t\t\t\t\tisDistractionFree\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t\t\t\t.toggle(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'core',\n\t\t\t\t\t\t\t\t\t\t\t\t\t'distractionFree'\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t\t\t\t},\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}\n\t\t} );\n\t};\n\n/**\n * Action that toggles the Spotlight Mode view option.\n */\nexport const toggleSpotlightMode =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).toggle( 'core', 'focusMode' );\n\n\t\tconst isFocusMode = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'focusMode' );\n\n\t\tregistry\n\t\t\t.dispatch( noticesStore )\n\t\t\t.createInfoNotice(\n\t\t\t\tisFocusMode\n\t\t\t\t\t? __( 'Spotlight mode activated.' )\n\t\t\t\t\t: __( 'Spotlight mode deactivated.' ),\n\t\t\t\t{\n\t\t\t\t\tid: 'core/editor/toggle-spotlight-mode/notice',\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t.toggle( 'core', 'focusMode' );\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);\n\t};\n\n/**\n * Action that toggles the Top Toolbar view option.\n */\nexport const toggleTopToolbar =\n\t() =>\n\t( { registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).toggle( 'core', 'fixedToolbar' );\n\n\t\tconst isTopToolbar = registry\n\t\t\t.select( preferencesStore )\n\t\t\t.get( 'core', 'fixedToolbar' );\n\n\t\tregistry\n\t\t\t.dispatch( noticesStore )\n\t\t\t.createInfoNotice(\n\t\t\t\tisTopToolbar\n\t\t\t\t\t? __( 'Top toolbar activated.' )\n\t\t\t\t\t: __( 'Top toolbar deactivated.' ),\n\t\t\t\t{\n\t\t\t\t\tid: 'core/editor/toggle-top-toolbar/notice',\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t\tactions: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: __( 'Undo' ),\n\n\t\t\t\t\t\t\tonClick: () => {\n\t\t\t\t\t\t\t\tregistry\n\t\t\t\t\t\t\t\t\t.dispatch( preferencesStore )\n\t\t\t\t\t\t\t\t\t.toggle( 'core', 'fixedToolbar' );\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);\n\t};\n\n/**\n * Triggers an action used to switch editor mode.\n *\n * @param {string} mode The editor mode.\n */\nexport const switchEditorMode =\n\t( mode ) =>\n\t( { dispatch, registry } ) => {\n\t\tregistry.dispatch( preferencesStore ).set( 'core', 'editorMode', mode );\n\n\t\tif ( mode !== 'visual' ) {\n\t\t\t// Unselect blocks when we switch to a non visual mode.\n\t\t\tregistry.dispatch( blockEditorStore ).clearSelectedBlock();\n\t\t\t// Exit zoom out state when switching to a non visual mode.\n\t\t\tunlock( registry.dispatch( blockEditorStore ) ).resetZoomLevel();\n\t\t}\n\n\t\tif ( mode === 'visual' ) {\n\t\t\tspeak( __( 'Visual editor selected' ), 'assertive' );\n\t\t} else if ( mode === 'text' ) {\n\t\t\tconst isDistractionFree = registry\n\t\t\t\t.select( preferencesStore )\n\t\t\t\t.get( 'core', 'distractionFree' );\n\t\t\tif ( isDistractionFree ) {\n\t\t\t\tdispatch.toggleDistractionFree();\n\t\t\t}\n\t\t\tspeak( __( 'Code editor selected' ), 'assertive' );\n\t\t}\n\t};\n\n/**\n * Returns an action object used in signalling that the user opened the publish\n * sidebar.\n *\n * @return {Object} Action object\n */\nexport function openPublishSidebar() {\n\treturn {\n\t\ttype: 'OPEN_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the user closed the\n * publish sidebar.\n *\n * @return {Object} Action object.\n */\nexport function closePublishSidebar() {\n\treturn {\n\t\ttype: 'CLOSE_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Returns an action object used in signalling that the user toggles the publish sidebar.\n *\n * @return {Object} Action object\n */\nexport function togglePublishSidebar() {\n\treturn {\n\t\ttype: 'TOGGLE_PUBLISH_SIDEBAR',\n\t};\n}\n\n/**\n * Backward compatibility\n */\n\nconst getBlockEditorAction =\n\t( name ) =>\n\t( ...args ) =>\n\t( { registry } ) => {\n\t\tdeprecated( \"`wp.data.dispatch( 'core/editor' ).\" + name + '`', {\n\t\t\tsince: '5.3',\n\t\t\talternative:\n\t\t\t\t\"`wp.data.dispatch( 'core/block-editor' ).\" + name + '`',\n\t\t\tversion: '6.2',\n\t\t} );\n\t\tregistry.dispatch( blockEditorStore )[ name ]( ...args );\n\t};\n\n/**\n * @see resetBlocks in core/block-editor store.\n */\nexport const resetBlocks = getBlockEditorAction( 'resetBlocks' );\n\n/**\n * @see receiveBlocks in core/block-editor store.\n */\nexport const receiveBlocks = getBlockEditorAction( 'receiveBlocks' );\n\n/**\n * @see updateBlock in core/block-editor store.\n */\nexport const updateBlock = getBlockEditorAction( 'updateBlock' );\n\n/**\n * @see updateBlockAttributes in core/block-editor store.\n */\nexport const updateBlockAttributes = getBlockEditorAction(\n\t'updateBlockAttributes'\n);\n\n/**\n * @see selectBlock in core/block-editor store.\n */\nexport const selectBlock = getBlockEditorAction( 'selectBlock' );\n\n/**\n * @see startMultiSelect in core/block-editor store.\n */\nexport const startMultiSelect = getBlockEditorAction( 'startMultiSelect' );\n\n/**\n * @see stopMultiSelect in core/block-editor store.\n */\nexport const stopMultiSelect = getBlockEditorAction( 'stopMultiSelect' );\n\n/**\n * @see multiSelect in core/block-editor store.\n */\nexport const multiSelect = getBlockEditorAction( 'multiSelect' );\n\n/**\n * @see clearSelectedBlock in core/block-editor store.\n */\nexport const clearSelectedBlock = getBlockEditorAction( 'clearSelectedBlock' );\n\n/**\n * @see toggleSelection in core/block-editor store.\n */\nexport const toggleSelection = getBlockEditorAction( 'toggleSelection' );\n\n/**\n * @see replaceBlocks in core/block-editor store.\n */\nexport const replaceBlocks = getBlockEditorAction( 'replaceBlocks' );\n\n/**\n * @see replaceBlock in core/block-editor store.\n */\nexport const replaceBlock = getBlockEditorAction( 'replaceBlock' );\n\n/**\n * @see moveBlocksDown in core/block-editor store.\n */\nexport const moveBlocksDown = getBlockEditorAction( 'moveBlocksDown' );\n\n/**\n * @see moveBlocksUp in core/block-editor store.\n */\nexport const moveBlocksUp = getBlockEditorAction( 'moveBlocksUp' );\n\n/**\n * @see moveBlockToPosition in core/block-editor store.\n */\nexport const moveBlockToPosition = getBlockEditorAction(\n\t'moveBlockToPosition'\n);\n\n/**\n * @see insertBlock in core/block-editor store.\n */\nexport const insertBlock = getBlockEditorAction( 'insertBlock' );\n\n/**\n * @see insertBlocks in core/block-editor store.\n */\nexport const insertBlocks = getBlockEditorAction( 'insertBlocks' );\n\n/**\n * @see showInsertionPoint in core/block-editor store.\n */\nexport const showInsertionPoint = getBlockEditorAction( 'showInsertionPoint' );\n\n/**\n * @see hideInsertionPoint in core/block-editor store.\n */\nexport const hideInsertionPoint = getBlockEditorAction( 'hideInsertionPoint' );\n\n/**\n * @see setTemplateValidity in core/block-editor store.\n */\nexport const setTemplateValidity = getBlockEditorAction(\n\t'setTemplateValidity'\n);\n\n/**\n * @see synchronizeTemplate in core/block-editor store.\n */\nexport const synchronizeTemplate = getBlockEditorAction(\n\t'synchronizeTemplate'\n);\n\n/**\n * @see mergeBlocks in core/block-editor store.\n */\nexport const mergeBlocks = getBlockEditorAction( 'mergeBlocks' );\n\n/**\n * @see removeBlocks in core/block-editor store.\n */\nexport const removeBlocks = getBlockEditorAction( 'removeBlocks' );\n\n/**\n * @see removeBlock in core/block-editor store.\n */\nexport const removeBlock = getBlockEditorAction( 'removeBlock' );\n\n/**\n * @see toggleBlockMode in core/block-editor store.\n */\nexport const toggleBlockMode = getBlockEditorAction( 'toggleBlockMode' );\n\n/**\n * @see startTyping in core/block-editor store.\n */\nexport const startTyping = getBlockEditorAction( 'startTyping' );\n\n/**\n * @see stopTyping in core/block-editor store.\n */\nexport const stopTyping = getBlockEditorAction( 'stopTyping' );\n\n/**\n * @see enterFormattedText in core/block-editor store.\n */\nexport const enterFormattedText = getBlockEditorAction( 'enterFormattedText' );\n\n/**\n * @see exitFormattedText in core/block-editor store.\n */\nexport const exitFormattedText = getBlockEditorAction( 'exitFormattedText' );\n\n/**\n * @see insertDefaultBlock in core/block-editor store.\n */\nexport const insertDefaultBlock = getBlockEditorAction( 'insertDefaultBlock' );\n\n/**\n * @see updateBlockListSettings in core/block-editor store.\n */\nexport const updateBlockListSettings = getBlockEditorAction(\n\t'updateBlockListSettings'\n);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["deprecated", "coreStore", "noticesStore", "blockEditorStore", "apiFetch", "preferencesStore"]
|
|
7
7
|
}
|
|
@@ -2,12 +2,12 @@ import { registerBlockBindingsSource } from "@wordpress/blocks";
|
|
|
2
2
|
import patternOverrides from "./pattern-overrides";
|
|
3
3
|
import postData from "./post-data";
|
|
4
4
|
import postMeta from "./post-meta";
|
|
5
|
-
import
|
|
5
|
+
import termData from "./term-data";
|
|
6
6
|
function registerCoreBlockBindingsSources() {
|
|
7
7
|
registerBlockBindingsSource(patternOverrides);
|
|
8
8
|
registerBlockBindingsSource(postData);
|
|
9
9
|
registerBlockBindingsSource(postMeta);
|
|
10
|
-
registerBlockBindingsSource(
|
|
10
|
+
registerBlockBindingsSource(termData);
|
|
11
11
|
}
|
|
12
12
|
export {
|
|
13
13
|
registerCoreBlockBindingsSources
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/bindings/api.js"],
|
|
4
|
-
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { registerBlockBindingsSource } from '@wordpress/blocks';\n\n/**\n * Internal dependencies\n */\nimport patternOverrides from './pattern-overrides';\nimport postData from './post-data';\nimport postMeta from './post-meta';\nimport
|
|
5
|
-
"mappings": "AAGA,SAAS,mCAAmC;AAK5C,OAAO,sBAAsB;AAC7B,OAAO,cAAc;AACrB,OAAO,cAAc;AACrB,OAAO,
|
|
4
|
+
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { registerBlockBindingsSource } from '@wordpress/blocks';\n\n/**\n * Internal dependencies\n */\nimport patternOverrides from './pattern-overrides';\nimport postData from './post-data';\nimport postMeta from './post-meta';\nimport termData from './term-data';\n\n/**\n * Function to register core block bindings sources provided by the editor.\n *\n * @example\n * ```js\n * import { registerCoreBlockBindingsSources } from '@wordpress/editor';\n *\n * registerCoreBlockBindingsSources();\n * ```\n */\nexport function registerCoreBlockBindingsSources() {\n\tregisterBlockBindingsSource( patternOverrides );\n\tregisterBlockBindingsSource( postData );\n\tregisterBlockBindingsSource( postMeta );\n\tregisterBlockBindingsSource( termData );\n}\n"],
|
|
5
|
+
"mappings": "AAGA,SAAS,mCAAmC;AAK5C,OAAO,sBAAsB;AAC7B,OAAO,cAAc;AACrB,OAAO,cAAc;AACrB,OAAO,cAAc;AAYd,SAAS,mCAAmC;AAClD,8BAA6B,gBAAiB;AAC9C,8BAA6B,QAAS;AACtC,8BAA6B,QAAS;AACtC,8BAA6B,QAAS;AACvC;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,13 +1,30 @@
|
|
|
1
1
|
import { __ } from "@wordpress/i18n";
|
|
2
2
|
import { store as coreDataStore } from "@wordpress/core-data";
|
|
3
|
-
|
|
3
|
+
import { store as blockEditorStore } from "@wordpress/block-editor";
|
|
4
|
+
const NAVIGATION_BLOCK_TYPES = [
|
|
5
|
+
"core/navigation-link",
|
|
6
|
+
"core/navigation-submenu"
|
|
7
|
+
];
|
|
8
|
+
function getPostDataFields(select, context, clientId) {
|
|
4
9
|
const { getEditedEntityRecord } = select(coreDataStore);
|
|
10
|
+
const { getBlockAttributes, getBlockName } = select(blockEditorStore);
|
|
5
11
|
let entityDataValues, dataFields;
|
|
6
|
-
|
|
12
|
+
const blockName = getBlockName?.(clientId);
|
|
13
|
+
const isNavigationBlock = NAVIGATION_BLOCK_TYPES.includes(blockName);
|
|
14
|
+
let postId, postType;
|
|
15
|
+
if (isNavigationBlock) {
|
|
16
|
+
const blockAttributes = getBlockAttributes?.(clientId);
|
|
17
|
+
postId = blockAttributes?.id;
|
|
18
|
+
postType = blockAttributes?.type;
|
|
19
|
+
} else {
|
|
20
|
+
postId = context?.postId;
|
|
21
|
+
postType = context?.postType;
|
|
22
|
+
}
|
|
23
|
+
if (postType && postId) {
|
|
7
24
|
entityDataValues = getEditedEntityRecord(
|
|
8
25
|
"postType",
|
|
9
|
-
|
|
10
|
-
|
|
26
|
+
postType,
|
|
27
|
+
postId
|
|
11
28
|
);
|
|
12
29
|
dataFields = {
|
|
13
30
|
date: {
|
|
@@ -19,6 +36,11 @@ function getPostDataFields(select, context) {
|
|
|
19
36
|
label: __("Post Modified Date"),
|
|
20
37
|
value: entityDataValues?.modified,
|
|
21
38
|
type: "string"
|
|
39
|
+
},
|
|
40
|
+
link: {
|
|
41
|
+
label: __("Post Link"),
|
|
42
|
+
value: entityDataValues?.link,
|
|
43
|
+
type: "string"
|
|
22
44
|
}
|
|
23
45
|
};
|
|
24
46
|
}
|
|
@@ -29,20 +51,25 @@ function getPostDataFields(select, context) {
|
|
|
29
51
|
}
|
|
30
52
|
var post_data_default = {
|
|
31
53
|
name: "core/post-data",
|
|
32
|
-
getValues({ select, context, bindings }) {
|
|
33
|
-
const dataFields = getPostDataFields(select, context);
|
|
54
|
+
getValues({ select, context, bindings, clientId }) {
|
|
55
|
+
const dataFields = getPostDataFields(select, context, clientId);
|
|
34
56
|
const newValues = {};
|
|
35
57
|
for (const [attributeName, source] of Object.entries(bindings)) {
|
|
36
|
-
const fieldKey = source.args.key;
|
|
58
|
+
const fieldKey = globalThis.IS_GUTENBERG_PLUGIN ? source.args.field || source.args.key : source.args.field;
|
|
37
59
|
const { value: fieldValue, label: fieldLabel } = dataFields?.[fieldKey] || {};
|
|
38
60
|
newValues[attributeName] = fieldValue ?? fieldLabel ?? fieldKey;
|
|
39
61
|
}
|
|
40
62
|
return newValues;
|
|
41
63
|
},
|
|
42
|
-
setValues({ dispatch, context, bindings }) {
|
|
64
|
+
setValues({ dispatch, context, bindings, clientId, select }) {
|
|
65
|
+
const { getBlockName } = select(blockEditorStore);
|
|
66
|
+
const blockName = getBlockName?.(clientId);
|
|
67
|
+
if (NAVIGATION_BLOCK_TYPES.includes(blockName)) {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
43
70
|
const newData = {};
|
|
44
71
|
Object.values(bindings).forEach(({ args, newValue }) => {
|
|
45
|
-
newData[args.
|
|
72
|
+
newData[args.field] = newValue;
|
|
46
73
|
});
|
|
47
74
|
dispatch(coreDataStore).editEntityRecord(
|
|
48
75
|
"postType",
|
|
@@ -52,13 +79,19 @@ var post_data_default = {
|
|
|
52
79
|
);
|
|
53
80
|
},
|
|
54
81
|
canUserEditValue({ select, context, args }) {
|
|
82
|
+
const { getBlockName, getSelectedBlockClientId } = select(blockEditorStore);
|
|
83
|
+
const clientId = getSelectedBlockClientId();
|
|
84
|
+
const blockName = getBlockName?.(clientId);
|
|
85
|
+
if (NAVIGATION_BLOCK_TYPES.includes(blockName)) {
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
55
88
|
if (context?.query || context?.queryId) {
|
|
56
89
|
return false;
|
|
57
90
|
}
|
|
58
91
|
if (!context?.postType) {
|
|
59
92
|
return false;
|
|
60
93
|
}
|
|
61
|
-
const fieldValue = getPostDataFields(select, context)?.[args.
|
|
94
|
+
const fieldValue = getPostDataFields(select, context, void 0)?.[args.field]?.value;
|
|
62
95
|
if (fieldValue === void 0) {
|
|
63
96
|
return false;
|
|
64
97
|
}
|
|
@@ -73,19 +106,23 @@ var post_data_default = {
|
|
|
73
106
|
return true;
|
|
74
107
|
},
|
|
75
108
|
getFieldsList({ select, context }) {
|
|
76
|
-
|
|
109
|
+
const clientId = select(blockEditorStore).getSelectedBlockClientId();
|
|
110
|
+
return getPostDataFields(select, context, clientId);
|
|
77
111
|
},
|
|
78
112
|
editorUI({ select, context }) {
|
|
79
|
-
const selectedBlock = select(
|
|
113
|
+
const selectedBlock = select(blockEditorStore).getSelectedBlock();
|
|
80
114
|
if (selectedBlock?.name !== "core/post-date") {
|
|
81
115
|
return {};
|
|
82
116
|
}
|
|
117
|
+
if (NAVIGATION_BLOCK_TYPES.includes(selectedBlock?.name)) {
|
|
118
|
+
return {};
|
|
119
|
+
}
|
|
83
120
|
const postDataFields = Object.entries(
|
|
84
121
|
getPostDataFields(select, context) || {}
|
|
85
122
|
).map(([key, field]) => ({
|
|
86
123
|
label: field.label,
|
|
87
124
|
args: {
|
|
88
|
-
key
|
|
125
|
+
field: key
|
|
89
126
|
},
|
|
90
127
|
type: field.type
|
|
91
128
|
}));
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/bindings/post-data.js"],
|
|
4
|
-
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { store as coreDataStore } from '@wordpress/core-data';\n\n/**\n * Gets a list of post data fields with their values and labels\n * to be consumed in the needed callbacks.\n * If the value is not available based on context, like in templates,\n * it falls back to the default value, label, or key.\n *\n * @param {Object} select
|
|
5
|
-
"mappings": "AAGA,SAAS,UAAU;AACnB,SAAS,SAAS,qBAAqB;
|
|
4
|
+
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { store as coreDataStore } from '@wordpress/core-data';\nimport { store as blockEditorStore } from '@wordpress/block-editor';\n\n// Navigation block types that use special handling for backwards compatibility\nconst NAVIGATION_BLOCK_TYPES = [\n\t'core/navigation-link',\n\t'core/navigation-submenu',\n];\n\n/**\n * Gets a list of post data fields with their values and labels\n * to be consumed in the needed callbacks.\n * If the value is not available based on context, like in templates,\n * it falls back to the default value, label, or key.\n *\n * @param {Object} select The select function from the data store.\n * @param {Object} context The context provided.\n * @param {string} clientId The block client ID used to read attributes.\n * @return {Object} List of post data fields with their value and label.\n *\n * @example\n * ```js\n * {\n * field_1_key: {\n * label: 'Field 1 Label',\n * value: 'Field 1 Value',\n * },\n * field_2_key: {\n * label: 'Field 2 Label',\n * value: 'Field 2 Value',\n * },\n * ...\n * }\n * ```\n */\nfunction getPostDataFields( select, context, clientId ) {\n\tconst { getEditedEntityRecord } = select( coreDataStore );\n\tconst { getBlockAttributes, getBlockName } = select( blockEditorStore );\n\n\tlet entityDataValues, dataFields;\n\n\t/*\n\t * BACKWARDS COMPATIBILITY: Hardcoded exception for navigation blocks.\n\t * Required for WordPress 6.9+ navigation blocks. DO NOT REMOVE.\n\t */\n\tconst blockName = getBlockName?.( clientId );\n\tconst isNavigationBlock = NAVIGATION_BLOCK_TYPES.includes( blockName );\n\n\tlet postId, postType;\n\n\tif ( isNavigationBlock ) {\n\t\t// Navigation blocks: read from block attributes\n\t\tconst blockAttributes = getBlockAttributes?.( clientId );\n\t\tpostId = blockAttributes?.id;\n\t\tpostType = blockAttributes?.type;\n\t} else {\n\t\t// All other blocks: use context\n\t\tpostId = context?.postId;\n\t\tpostType = context?.postType;\n\t}\n\n\t// Try to get the current entity data values using resolved identifiers.\n\tif ( postType && postId ) {\n\t\tentityDataValues = getEditedEntityRecord(\n\t\t\t'postType',\n\t\t\tpostType,\n\t\t\tpostId\n\t\t);\n\t\tdataFields = {\n\t\t\tdate: {\n\t\t\t\tlabel: __( 'Post Date' ),\n\t\t\t\tvalue: entityDataValues?.date,\n\t\t\t\ttype: 'string',\n\t\t\t},\n\t\t\tmodified: {\n\t\t\t\tlabel: __( 'Post Modified Date' ),\n\t\t\t\tvalue: entityDataValues?.modified,\n\t\t\t\ttype: 'string',\n\t\t\t},\n\t\t\tlink: {\n\t\t\t\tlabel: __( 'Post Link' ),\n\t\t\t\tvalue: entityDataValues?.link,\n\t\t\t\ttype: 'string',\n\t\t\t},\n\t\t};\n\t}\n\n\tif ( ! Object.keys( dataFields || {} ).length ) {\n\t\treturn null;\n\t}\n\n\treturn dataFields;\n}\n\n/**\n * @type {WPBlockBindingsSource}\n */\nexport default {\n\tname: 'core/post-data',\n\tgetValues( { select, context, bindings, clientId } ) {\n\t\tconst dataFields = getPostDataFields( select, context, clientId );\n\n\t\tconst newValues = {};\n\t\tfor ( const [ attributeName, source ] of Object.entries( bindings ) ) {\n\t\t\t// Use the value, the field label, or the field key.\n\t\t\tconst fieldKey = globalThis.IS_GUTENBERG_PLUGIN\n\t\t\t\t? source.args.field || source.args.key\n\t\t\t\t: source.args.field;\n\t\t\tconst { value: fieldValue, label: fieldLabel } =\n\t\t\t\tdataFields?.[ fieldKey ] || {};\n\t\t\tnewValues[ attributeName ] = fieldValue ?? fieldLabel ?? fieldKey;\n\t\t}\n\t\treturn newValues;\n\t},\n\tsetValues( { dispatch, context, bindings, clientId, select } ) {\n\t\tconst { getBlockName } = select( blockEditorStore );\n\n\t\tconst blockName = getBlockName?.( clientId );\n\n\t\t// Navigaton block types are read-only.\n\t\t// See https://github.com/WordPress/gutenberg/pull/72165.\n\t\tif ( NAVIGATION_BLOCK_TYPES.includes( blockName ) ) {\n\t\t\treturn false;\n\t\t}\n\t\tconst newData = {};\n\t\tObject.values( bindings ).forEach( ( { args, newValue } ) => {\n\t\t\tnewData[ args.field ] = newValue;\n\t\t} );\n\n\t\tdispatch( coreDataStore ).editEntityRecord(\n\t\t\t'postType',\n\t\t\tcontext?.postType,\n\t\t\tcontext?.postId,\n\t\t\tnewData\n\t\t);\n\t},\n\tcanUserEditValue( { select, context, args } ) {\n\t\tconst { getBlockName, getSelectedBlockClientId } =\n\t\t\tselect( blockEditorStore );\n\t\tconst clientId = getSelectedBlockClientId();\n\t\tconst blockName = getBlockName?.( clientId );\n\n\t\t// Navigaton block types are read-only.\n\t\t// See https://github.com/WordPress/gutenberg/pull/72165.\n\t\tif ( NAVIGATION_BLOCK_TYPES.includes( blockName ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Lock editing in query loop.\n\t\tif ( context?.query || context?.queryId ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Lock editing when `postType` is not defined.\n\t\tif ( ! context?.postType ) {\n\t\t\treturn false;\n\t\t}\n\n\t\tconst fieldValue = getPostDataFields( select, context, undefined )?.[\n\t\t\targs.field\n\t\t]?.value;\n\t\t// Empty string or `false` could be a valid value, so we need to check if the field value is undefined.\n\t\tif ( fieldValue === undefined ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Check that the user has the capability to edit post data.\n\t\tconst canUserEdit = select( coreDataStore ).canUser( 'update', {\n\t\t\tkind: 'postType',\n\t\t\tname: context?.postType,\n\t\t\tid: context?.postId,\n\t\t} );\n\t\tif ( ! canUserEdit ) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t},\n\tgetFieldsList( { select, context } ) {\n\t\tconst clientId = select( blockEditorStore ).getSelectedBlockClientId();\n\t\t// Deprecated, will be removed after 6.9.\n\t\treturn getPostDataFields( select, context, clientId );\n\t},\n\teditorUI( { select, context } ) {\n\t\tconst selectedBlock = select( blockEditorStore ).getSelectedBlock();\n\t\tif ( selectedBlock?.name !== 'core/post-date' ) {\n\t\t\treturn {};\n\t\t}\n\t\t// Exit early for navigation blocks (read-only)\n\t\tif ( NAVIGATION_BLOCK_TYPES.includes( selectedBlock?.name ) ) {\n\t\t\treturn {};\n\t\t}\n\t\tconst postDataFields = Object.entries(\n\t\t\tgetPostDataFields( select, context ) || {}\n\t\t).map( ( [ key, field ] ) => ( {\n\t\t\tlabel: field.label,\n\t\t\targs: {\n\t\t\t\tfield: key,\n\t\t\t},\n\t\t\ttype: field.type,\n\t\t} ) );\n\t\t/*\n\t\t * We need to define the data as [{ label: string, value: any, type: https://developer.wordpress.org/block-editor/reference-guides/block-api/block-attributes/#type-validation }]\n\t\t */\n\t\treturn {\n\t\t\tmode: 'dropdown',\n\t\t\tdata: postDataFields,\n\t\t};\n\t},\n};\n"],
|
|
5
|
+
"mappings": "AAGA,SAAS,UAAU;AACnB,SAAS,SAAS,qBAAqB;AACvC,SAAS,SAAS,wBAAwB;AAG1C,MAAM,yBAAyB;AAAA,EAC9B;AAAA,EACA;AACD;AA4BA,SAAS,kBAAmB,QAAQ,SAAS,UAAW;AACvD,QAAM,EAAE,sBAAsB,IAAI,OAAQ,aAAc;AACxD,QAAM,EAAE,oBAAoB,aAAa,IAAI,OAAQ,gBAAiB;AAEtE,MAAI,kBAAkB;AAMtB,QAAM,YAAY,eAAgB,QAAS;AAC3C,QAAM,oBAAoB,uBAAuB,SAAU,SAAU;AAErE,MAAI,QAAQ;AAEZ,MAAK,mBAAoB;AAExB,UAAM,kBAAkB,qBAAsB,QAAS;AACvD,aAAS,iBAAiB;AAC1B,eAAW,iBAAiB;AAAA,EAC7B,OAAO;AAEN,aAAS,SAAS;AAClB,eAAW,SAAS;AAAA,EACrB;AAGA,MAAK,YAAY,QAAS;AACzB,uBAAmB;AAAA,MAClB;AAAA,MACA;AAAA,MACA;AAAA,IACD;AACA,iBAAa;AAAA,MACZ,MAAM;AAAA,QACL,OAAO,GAAI,WAAY;AAAA,QACvB,OAAO,kBAAkB;AAAA,QACzB,MAAM;AAAA,MACP;AAAA,MACA,UAAU;AAAA,QACT,OAAO,GAAI,oBAAqB;AAAA,QAChC,OAAO,kBAAkB;AAAA,QACzB,MAAM;AAAA,MACP;AAAA,MACA,MAAM;AAAA,QACL,OAAO,GAAI,WAAY;AAAA,QACvB,OAAO,kBAAkB;AAAA,QACzB,MAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AAEA,MAAK,CAAE,OAAO,KAAM,cAAc,CAAC,CAAE,EAAE,QAAS;AAC/C,WAAO;AAAA,EACR;AAEA,SAAO;AACR;AAKA,IAAO,oBAAQ;AAAA,EACd,MAAM;AAAA,EACN,UAAW,EAAE,QAAQ,SAAS,UAAU,SAAS,GAAI;AACpD,UAAM,aAAa,kBAAmB,QAAQ,SAAS,QAAS;AAEhE,UAAM,YAAY,CAAC;AACnB,eAAY,CAAE,eAAe,MAAO,KAAK,OAAO,QAAS,QAAS,GAAI;AAErE,YAAM,WAAW,WAAW,sBACzB,OAAO,KAAK,SAAS,OAAO,KAAK,MACjC,OAAO,KAAK;AACf,YAAM,EAAE,OAAO,YAAY,OAAO,WAAW,IAC5C,aAAc,QAAS,KAAK,CAAC;AAC9B,gBAAW,aAAc,IAAI,cAAc,cAAc;AAAA,IAC1D;AACA,WAAO;AAAA,EACR;AAAA,EACA,UAAW,EAAE,UAAU,SAAS,UAAU,UAAU,OAAO,GAAI;AAC9D,UAAM,EAAE,aAAa,IAAI,OAAQ,gBAAiB;AAElD,UAAM,YAAY,eAAgB,QAAS;AAI3C,QAAK,uBAAuB,SAAU,SAAU,GAAI;AACnD,aAAO;AAAA,IACR;AACA,UAAM,UAAU,CAAC;AACjB,WAAO,OAAQ,QAAS,EAAE,QAAS,CAAE,EAAE,MAAM,SAAS,MAAO;AAC5D,cAAS,KAAK,KAAM,IAAI;AAAA,IACzB,CAAE;AAEF,aAAU,aAAc,EAAE;AAAA,MACzB;AAAA,MACA,SAAS;AAAA,MACT,SAAS;AAAA,MACT;AAAA,IACD;AAAA,EACD;AAAA,EACA,iBAAkB,EAAE,QAAQ,SAAS,KAAK,GAAI;AAC7C,UAAM,EAAE,cAAc,yBAAyB,IAC9C,OAAQ,gBAAiB;AAC1B,UAAM,WAAW,yBAAyB;AAC1C,UAAM,YAAY,eAAgB,QAAS;AAI3C,QAAK,uBAAuB,SAAU,SAAU,GAAI;AACnD,aAAO;AAAA,IACR;AAGA,QAAK,SAAS,SAAS,SAAS,SAAU;AACzC,aAAO;AAAA,IACR;AAGA,QAAK,CAAE,SAAS,UAAW;AAC1B,aAAO;AAAA,IACR;AAEA,UAAM,aAAa,kBAAmB,QAAQ,SAAS,MAAU,IAChE,KAAK,KACN,GAAG;AAEH,QAAK,eAAe,QAAY;AAC/B,aAAO;AAAA,IACR;AAGA,UAAM,cAAc,OAAQ,aAAc,EAAE,QAAS,UAAU;AAAA,MAC9D,MAAM;AAAA,MACN,MAAM,SAAS;AAAA,MACf,IAAI,SAAS;AAAA,IACd,CAAE;AACF,QAAK,CAAE,aAAc;AACpB,aAAO;AAAA,IACR;AAEA,WAAO;AAAA,EACR;AAAA,EACA,cAAe,EAAE,QAAQ,QAAQ,GAAI;AACpC,UAAM,WAAW,OAAQ,gBAAiB,EAAE,yBAAyB;AAErE,WAAO,kBAAmB,QAAQ,SAAS,QAAS;AAAA,EACrD;AAAA,EACA,SAAU,EAAE,QAAQ,QAAQ,GAAI;AAC/B,UAAM,gBAAgB,OAAQ,gBAAiB,EAAE,iBAAiB;AAClE,QAAK,eAAe,SAAS,kBAAmB;AAC/C,aAAO,CAAC;AAAA,IACT;AAEA,QAAK,uBAAuB,SAAU,eAAe,IAAK,GAAI;AAC7D,aAAO,CAAC;AAAA,IACT;AACA,UAAM,iBAAiB,OAAO;AAAA,MAC7B,kBAAmB,QAAQ,OAAQ,KAAK,CAAC;AAAA,IAC1C,EAAE,IAAK,CAAE,CAAE,KAAK,KAAM,OAAS;AAAA,MAC9B,OAAO,MAAM;AAAA,MACb,MAAM;AAAA,QACL,OAAO;AAAA,MACR;AAAA,MACA,MAAM,MAAM;AAAA,IACb,EAAI;AAIJ,WAAO;AAAA,MACN,MAAM;AAAA,MACN,MAAM;AAAA,IACP;AAAA,EACD;AACD;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { __ } from "@wordpress/i18n";
|
|
2
|
+
import { store as coreDataStore } from "@wordpress/core-data";
|
|
3
|
+
import { store as blockEditorStore } from "@wordpress/block-editor";
|
|
4
|
+
const NAVIGATION_BLOCK_TYPES = [
|
|
5
|
+
"core/navigation-link",
|
|
6
|
+
"core/navigation-submenu"
|
|
7
|
+
];
|
|
8
|
+
function createDataFields(termDataValues, idValue) {
|
|
9
|
+
return {
|
|
10
|
+
id: {
|
|
11
|
+
label: __("Term ID"),
|
|
12
|
+
value: idValue,
|
|
13
|
+
type: "string"
|
|
14
|
+
},
|
|
15
|
+
name: {
|
|
16
|
+
label: __("Name"),
|
|
17
|
+
value: termDataValues?.name,
|
|
18
|
+
type: "string"
|
|
19
|
+
},
|
|
20
|
+
slug: {
|
|
21
|
+
label: __("Slug"),
|
|
22
|
+
value: termDataValues?.slug,
|
|
23
|
+
type: "string"
|
|
24
|
+
},
|
|
25
|
+
link: {
|
|
26
|
+
label: __("Link"),
|
|
27
|
+
value: termDataValues?.link,
|
|
28
|
+
type: "string"
|
|
29
|
+
},
|
|
30
|
+
description: {
|
|
31
|
+
label: __("Description"),
|
|
32
|
+
value: termDataValues?.description,
|
|
33
|
+
type: "string"
|
|
34
|
+
},
|
|
35
|
+
parent: {
|
|
36
|
+
label: __("Parent ID"),
|
|
37
|
+
value: termDataValues?.parent,
|
|
38
|
+
type: "string"
|
|
39
|
+
},
|
|
40
|
+
count: {
|
|
41
|
+
label: __("Count"),
|
|
42
|
+
value: `(${termDataValues?.count ?? 0})`,
|
|
43
|
+
type: "string"
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
function getTermDataFields(select, context, clientId) {
|
|
48
|
+
const { getEntityRecord } = select(coreDataStore);
|
|
49
|
+
const { getBlockAttributes, getBlockName } = select(blockEditorStore);
|
|
50
|
+
let termDataValues, dataFields;
|
|
51
|
+
const blockName = getBlockName?.(clientId);
|
|
52
|
+
const isNavigationBlock = NAVIGATION_BLOCK_TYPES.includes(blockName);
|
|
53
|
+
let termId, taxonomy;
|
|
54
|
+
if (isNavigationBlock) {
|
|
55
|
+
const blockAttributes = getBlockAttributes?.(clientId);
|
|
56
|
+
termId = blockAttributes?.id;
|
|
57
|
+
const typeFromAttributes = blockAttributes?.type;
|
|
58
|
+
taxonomy = typeFromAttributes === "tag" ? "post_tag" : typeFromAttributes;
|
|
59
|
+
} else {
|
|
60
|
+
termId = context?.termId;
|
|
61
|
+
taxonomy = context?.taxonomy;
|
|
62
|
+
}
|
|
63
|
+
if (taxonomy && termId) {
|
|
64
|
+
termDataValues = getEntityRecord("taxonomy", taxonomy, termId);
|
|
65
|
+
if (!termDataValues && context?.termData) {
|
|
66
|
+
termDataValues = context.termData;
|
|
67
|
+
}
|
|
68
|
+
if (termDataValues) {
|
|
69
|
+
dataFields = createDataFields(termDataValues, termId);
|
|
70
|
+
}
|
|
71
|
+
} else if (context?.termData) {
|
|
72
|
+
termDataValues = context.termData;
|
|
73
|
+
dataFields = createDataFields(
|
|
74
|
+
termDataValues,
|
|
75
|
+
termDataValues?.term_id
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
if (!dataFields || !Object.keys(dataFields).length) {
|
|
79
|
+
return null;
|
|
80
|
+
}
|
|
81
|
+
return dataFields;
|
|
82
|
+
}
|
|
83
|
+
var term_data_default = {
|
|
84
|
+
name: "core/term-data",
|
|
85
|
+
usesContext: ["taxonomy", "termId", "termData"],
|
|
86
|
+
getValues({ select, context, bindings, clientId }) {
|
|
87
|
+
const dataFields = getTermDataFields(select, context, clientId);
|
|
88
|
+
const newValues = {};
|
|
89
|
+
for (const [attributeName, source] of Object.entries(bindings)) {
|
|
90
|
+
const fieldKey = source.args.field;
|
|
91
|
+
const { value: fieldValue, label: fieldLabel } = dataFields?.[fieldKey] || {};
|
|
92
|
+
newValues[attributeName] = fieldValue ?? fieldLabel ?? fieldKey;
|
|
93
|
+
}
|
|
94
|
+
return newValues;
|
|
95
|
+
},
|
|
96
|
+
// eslint-disable-next-line no-unused-vars
|
|
97
|
+
setValues({ dispatch, context, bindings }) {
|
|
98
|
+
return false;
|
|
99
|
+
},
|
|
100
|
+
canUserEditValue({ select, context, args }) {
|
|
101
|
+
const { getBlockName, getSelectedBlockClientId } = select(blockEditorStore);
|
|
102
|
+
const clientId = getSelectedBlockClientId();
|
|
103
|
+
const blockName = getBlockName?.(clientId);
|
|
104
|
+
if (NAVIGATION_BLOCK_TYPES.includes(blockName)) {
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
if (context?.termQuery) {
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
if (!context?.taxonomy || !context?.termId) {
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
const fieldValue = getTermDataFields(select, context, void 0)?.[args.field]?.value;
|
|
114
|
+
if (fieldValue === void 0) {
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
return false;
|
|
118
|
+
},
|
|
119
|
+
getFieldsList({ select, context }) {
|
|
120
|
+
return getTermDataFields(select, context);
|
|
121
|
+
},
|
|
122
|
+
editorUI({ select, context }) {
|
|
123
|
+
const selectedBlock = select(blockEditorStore).getSelectedBlock();
|
|
124
|
+
if (NAVIGATION_BLOCK_TYPES.includes(selectedBlock?.name)) {
|
|
125
|
+
return {};
|
|
126
|
+
}
|
|
127
|
+
const termDataFields = Object.entries(
|
|
128
|
+
getTermDataFields(select, context) || {}
|
|
129
|
+
).map(([key, field]) => ({
|
|
130
|
+
label: field.label,
|
|
131
|
+
type: field.type,
|
|
132
|
+
args: {
|
|
133
|
+
field: key
|
|
134
|
+
}
|
|
135
|
+
}));
|
|
136
|
+
return {
|
|
137
|
+
mode: "dropdown",
|
|
138
|
+
data: termDataFields
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
export {
|
|
143
|
+
term_data_default as default
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=term-data.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/bindings/term-data.js"],
|
|
4
|
+
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { store as coreDataStore } from '@wordpress/core-data';\nimport { store as blockEditorStore } from '@wordpress/block-editor';\n\n// Navigation block types that use special handling for backwards compatibility\nconst NAVIGATION_BLOCK_TYPES = [\n\t'core/navigation-link',\n\t'core/navigation-submenu',\n];\n\n/**\n * Creates the data fields object with the given term data values and ID value.\n *\n * @param {Object} termDataValues The term data values.\n * @param {string|number} idValue The ID value to use.\n * @return {Object} The data fields object.\n */\nfunction createDataFields( termDataValues, idValue ) {\n\treturn {\n\t\tid: {\n\t\t\tlabel: __( 'Term ID' ),\n\t\t\tvalue: idValue,\n\t\t\ttype: 'string',\n\t\t},\n\t\tname: {\n\t\t\tlabel: __( 'Name' ),\n\t\t\tvalue: termDataValues?.name,\n\t\t\ttype: 'string',\n\t\t},\n\t\tslug: {\n\t\t\tlabel: __( 'Slug' ),\n\t\t\tvalue: termDataValues?.slug,\n\t\t\ttype: 'string',\n\t\t},\n\t\tlink: {\n\t\t\tlabel: __( 'Link' ),\n\t\t\tvalue: termDataValues?.link,\n\t\t\ttype: 'string',\n\t\t},\n\t\tdescription: {\n\t\t\tlabel: __( 'Description' ),\n\t\t\tvalue: termDataValues?.description,\n\t\t\ttype: 'string',\n\t\t},\n\t\tparent: {\n\t\t\tlabel: __( 'Parent ID' ),\n\t\t\tvalue: termDataValues?.parent,\n\t\t\ttype: 'string',\n\t\t},\n\t\tcount: {\n\t\t\tlabel: __( 'Count' ),\n\t\t\tvalue: `(${ termDataValues?.count ?? 0 })`,\n\t\t\ttype: 'string',\n\t\t},\n\t};\n}\n\n/**\n * Gets a list of term data fields with their values and labels\n * to be consumed in the needed callbacks.\n * If the value is not available based on context, like in templates,\n * it falls back to the default value, label, or key.\n *\n * @param {Object} select The select function from the data store.\n * @param {Object} context The context provided.\n * @param {string} clientId The block client ID used to read attributes.\n * @return {Object} List of term data fields with their value and label.\n *\n * @example\n * ```js\n * {\n * name: {\n * label: 'Term Name',\n * value: 'Category Name',\n * },\n * count: {\n * label: 'Term Count',\n * value: 5,\n * },\n * ...\n * }\n * ```\n */\nfunction getTermDataFields( select, context, clientId ) {\n\tconst { getEntityRecord } = select( coreDataStore );\n\tconst { getBlockAttributes, getBlockName } = select( blockEditorStore );\n\n\tlet termDataValues, dataFields;\n\n\t/*\n\t * BACKWARDS COMPATIBILITY: Hardcoded exception for navigation blocks.\n\t * Required for WordPress 6.9+ navigation blocks. DO NOT REMOVE.\n\t */\n\tconst blockName = getBlockName?.( clientId );\n\tconst isNavigationBlock = NAVIGATION_BLOCK_TYPES.includes( blockName );\n\n\tlet termId, taxonomy;\n\n\tif ( isNavigationBlock ) {\n\t\t// Navigation blocks: read from block attributes\n\t\tconst blockAttributes = getBlockAttributes?.( clientId );\n\t\ttermId = blockAttributes?.id;\n\t\tconst typeFromAttributes = blockAttributes?.type;\n\t\ttaxonomy =\n\t\t\ttypeFromAttributes === 'tag' ? 'post_tag' : typeFromAttributes;\n\t} else {\n\t\t// All other blocks: use context\n\t\ttermId = context?.termId;\n\t\ttaxonomy = context?.taxonomy;\n\t}\n\n\tif ( taxonomy && termId ) {\n\t\ttermDataValues = getEntityRecord( 'taxonomy', taxonomy, termId );\n\n\t\tif ( ! termDataValues && context?.termData ) {\n\t\t\ttermDataValues = context.termData;\n\t\t}\n\n\t\tif ( termDataValues ) {\n\t\t\tdataFields = createDataFields( termDataValues, termId );\n\t\t}\n\t} else if ( context?.termData ) {\n\t\ttermDataValues = context.termData;\n\t\tdataFields = createDataFields(\n\t\t\ttermDataValues,\n\t\t\ttermDataValues?.term_id\n\t\t);\n\t}\n\n\tif ( ! dataFields || ! Object.keys( dataFields ).length ) {\n\t\treturn null;\n\t}\n\n\treturn dataFields;\n}\n\n/**\n * @type {WPBlockBindingsSource}\n */\nexport default {\n\tname: 'core/term-data',\n\tusesContext: [ 'taxonomy', 'termId', 'termData' ],\n\tgetValues( { select, context, bindings, clientId } ) {\n\t\tconst dataFields = getTermDataFields( select, context, clientId );\n\n\t\tconst newValues = {};\n\t\tfor ( const [ attributeName, source ] of Object.entries( bindings ) ) {\n\t\t\t// Use the value, the field label, or the field key.\n\t\t\tconst fieldKey = source.args.field;\n\t\t\tconst { value: fieldValue, label: fieldLabel } =\n\t\t\t\tdataFields?.[ fieldKey ] || {};\n\t\t\tnewValues[ attributeName ] = fieldValue ?? fieldLabel ?? fieldKey;\n\t\t}\n\t\treturn newValues;\n\t},\n\t// eslint-disable-next-line no-unused-vars\n\tsetValues( { dispatch, context, bindings } ) {\n\t\t// Terms are typically not editable through block bindings in most contexts.\n\t\treturn false;\n\t},\n\tcanUserEditValue( { select, context, args } ) {\n\t\tconst { getBlockName, getSelectedBlockClientId } =\n\t\t\tselect( blockEditorStore );\n\n\t\tconst clientId = getSelectedBlockClientId();\n\t\tconst blockName = getBlockName?.( clientId );\n\n\t\t// Navigaton block types are read-only.\n\t\t// See https://github.com/WordPress/gutenberg/pull/72165.\n\t\tif ( NAVIGATION_BLOCK_TYPES.includes( blockName ) ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Terms are typically read-only when displayed.\n\t\tif ( context?.termQuery ) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Lock editing when `taxonomy` or `termId` is not defined.\n\t\tif ( ! context?.taxonomy || ! context?.termId ) {\n\t\t\treturn false;\n\t\t}\n\n\t\tconst fieldValue = getTermDataFields( select, context, undefined )?.[\n\t\t\targs.field\n\t\t]?.value;\n\t\t// Empty string or `false` could be a valid value, so we need to check if the field value is undefined.\n\t\tif ( fieldValue === undefined ) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn false;\n\t},\n\tgetFieldsList( { select, context } ) {\n\t\t// Deprecated, will be removed after 6.9.\n\t\treturn getTermDataFields( select, context );\n\t},\n\teditorUI( { select, context } ) {\n\t\tconst selectedBlock = select( blockEditorStore ).getSelectedBlock();\n\t\t// Exit early for navigation blocks (read-only)\n\t\tif ( NAVIGATION_BLOCK_TYPES.includes( selectedBlock?.name ) ) {\n\t\t\treturn {};\n\t\t}\n\t\tconst termDataFields = Object.entries(\n\t\t\tgetTermDataFields( select, context ) || {}\n\t\t).map( ( [ key, field ] ) => ( {\n\t\t\tlabel: field.label,\n\t\t\ttype: field.type,\n\t\t\targs: {\n\t\t\t\tfield: key,\n\t\t\t},\n\t\t} ) );\n\t\t/*\n\t\t * We need to define the data as [{ label: string, value: any, type: https://developer.wordpress.org/block-editor/reference-guides/block-api/block-attributes/#type-validation }]\n\t\t */\n\t\treturn {\n\t\t\tmode: 'dropdown',\n\t\t\tdata: termDataFields,\n\t\t};\n\t},\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|