diff --git a/packages/block-editor/src/components/inserter/menu.js b/packages/block-editor/src/components/inserter/menu.js index 019a37bffdde2..f1e387c5a5963 100644 --- a/packages/block-editor/src/components/inserter/menu.js +++ b/packages/block-editor/src/components/inserter/menu.js @@ -54,15 +54,17 @@ function InserterMenu( }, ref ) { - const isZoomOutMode = useSelect( - ( select ) => unlock( select( blockEditorStore ) ).isZoomOut(), - [] - ); - const hasSectionRootClientId = useSelect( - ( select ) => - !! unlock( select( blockEditorStore ) ).getSectionRootClientId(), - [] - ); + const { isZoomOutMode, hasSectionRootClientId } = useSelect( ( select ) => { + const { isZoomOut, getSectionRootClientId } = unlock( + select( blockEditorStore ) + ); + + return { + isZoomOutMode: isZoomOut(), + hasSectionRootClientId: !! getSectionRootClientId(), + }; + }, [] ); + const [ filterValue, setFilterValue, delayedFilterValue ] = useDebouncedInput( __experimentalFilterValue ); const [ hoveredItem, setHoveredItem ] = useState( null ); diff --git a/packages/editor/src/components/header/index.js b/packages/editor/src/components/header/index.js index d0af73e7dcb0c..b32fda6d031b1 100644 --- a/packages/editor/src/components/header/index.js +++ b/packages/editor/src/components/header/index.js @@ -68,6 +68,7 @@ function Header( { showIconLabels, hasFixedToolbar, hasBlockSelection, + hasSectionRootClientId, } = useSelect( ( select ) => { const { get: getPreference } = select( preferencesStore ); const { @@ -75,6 +76,9 @@ function Header( { getCurrentPostType, isPublishSidebarOpened: _isPublishSidebarOpened, } = select( editorStore ); + const { getBlockSelectionStart, getSectionRootClientId } = unlock( + select( blockEditorStore ) + ); return { postType: getCurrentPostType(), @@ -82,14 +86,14 @@ function Header( { isPublishSidebarOpened: _isPublishSidebarOpened(), showIconLabels: getPreference( 'core', 'showIconLabels' ), hasFixedToolbar: getPreference( 'core', 'fixedToolbar' ), - hasBlockSelection: - !! select( blockEditorStore ).getBlockSelectionStart(), + hasBlockSelection: !! getBlockSelectionStart(), + hasSectionRootClientId: !! getSectionRootClientId(), }; }, [] ); - const canBeZoomedOut = [ 'post', 'page', 'wp_template' ].includes( - postType - ); + const canBeZoomedOut = + [ 'post', 'page', 'wp_template' ].includes( postType ) && + hasSectionRootClientId; const disablePreviewOption = [ NAVIGATION_POST_TYPE, @@ -107,12 +111,6 @@ function Header( { ( ! hasBlockSelection || isBlockToolsCollapsed ) ) ); const hasBackButton = useHasBackButton(); - const hasSectionRootClientId = useSelect( - ( select ) => - !! unlock( select( blockEditorStore ) ).getSectionRootClientId(), - [] - ); - /* * The edit-post-header classname is only kept for backward compatibility * as some plugins might be relying on its presence. @@ -180,11 +178,9 @@ function Header( { forceIsAutosaveable={ forceIsDirty } /> - { canBeZoomedOut && - isWideViewport && - hasSectionRootClientId && ( - - ) } + { isWideViewport && canBeZoomedOut && ( + + ) } { ( isWideViewport || ! showIconLabels ) && (