diff --git a/packages/block-editor/src/components/block-settings-menu/block-settings-dropdown.js b/packages/block-editor/src/components/block-settings-menu/block-settings-dropdown.js index b9caee7c338beb..fa0690b357eeb6 100644 --- a/packages/block-editor/src/components/block-settings-menu/block-settings-dropdown.js +++ b/packages/block-editor/src/components/block-settings-menu/block-settings-dropdown.js @@ -253,15 +253,13 @@ export function BlockSettingsDropdown( { clientId={ firstBlockClientId } /> ) } - { ( ! isContentOnly || isZoomOut ) && ( - - ) } + { canDuplicate && ( ) } - + { ! isContentOnly && ! isZoomOut && ( + + ) } { typeof children === 'function' ? children( { onClose } ) : Children.map( ( child ) => diff --git a/packages/editor/src/components/provider/index.js b/packages/editor/src/components/provider/index.js index 68d7bd1d3f4f5b..4b8a3b6b23c251 100644 --- a/packages/editor/src/components/provider/index.js +++ b/packages/editor/src/components/provider/index.js @@ -13,7 +13,6 @@ import { BlockEditorProvider, BlockContextProvider, privateApis as blockEditorPrivateApis, - store as blockEditorStore, } from '@wordpress/block-editor'; import { store as noticesStore } from '@wordpress/notices'; import { privateApis as editPatternsPrivateApis } from '@wordpress/patterns'; @@ -207,14 +206,6 @@ export const ExperimentalEditorProvider = withRegistryProvider( [ post.type ] ); - const isZoomOut = useSelect( ( select ) => { - const { isZoomOut: _isZoomOut } = unlock( - select( blockEditorStore ) - ); - - return _isZoomOut(); - } ); - const shouldRenderTemplate = !! template && mode !== 'post-only'; const rootLevelPost = shouldRenderTemplate ? template : post; const defaultBlockContext = useMemo( () => { @@ -367,13 +358,9 @@ export const ExperimentalEditorProvider = withRegistryProvider( { children } { ! settings.isPreviewMode && ( <> - { ! isZoomOut && ( - <> - - - - - ) } + + + { mode === 'template-locked' && ( ) } diff --git a/packages/patterns/src/components/index.js b/packages/patterns/src/components/index.js index 6fddc593911f46..adc9f2ea93a126 100644 --- a/packages/patterns/src/components/index.js +++ b/packages/patterns/src/components/index.js @@ -1,15 +1,40 @@ /** * WordPress dependencies */ -import { BlockSettingsMenuControls } from '@wordpress/block-editor'; +import { + BlockSettingsMenuControls, + store as blockEditorStore, +} from '@wordpress/block-editor'; +import { useSelect } from '@wordpress/data'; /** * Internal dependencies */ import PatternConvertButton from './pattern-convert-button'; import PatternsManageButton from './patterns-manage-button'; +import { unlock } from '../lock-unlock'; export default function PatternsMenuItems( { rootClientId } ) { + const { isZoomOut, isContentOnly } = useSelect( ( select ) => { + const { + isZoomOut: _isZoomOut, + getBlockEditingMode, + getSelectedBlockClientIds, + } = unlock( select( blockEditorStore ) ); + + const selectedBlockClientIds = getSelectedBlockClientIds(); + const firstBlockClientId = selectedBlockClientIds[ 0 ]; + return { + isZoomOut: _isZoomOut(), + isContentOnly: + getBlockEditingMode( firstBlockClientId ) === 'contentOnly', + }; + } ); + + if ( isZoomOut || isContentOnly ) { + return; + } + return ( { ( { selectedClientIds, onClose } ) => (