From 484272c262e89978c361a70244c6bd92ab5f675f Mon Sep 17 00:00:00 2001 From: Jorge Date: Wed, 17 Apr 2019 16:12:44 +0100 Subject: [PATCH] Fix: Insert Before and Insert After appear even when default block can not be inserted. --- .../src/components/block-actions/index.js | 35 ++++++++++++------- .../components/block-settings-menu/index.js | 12 +++++-- 2 files changed, 32 insertions(+), 15 deletions(-) diff --git a/packages/block-editor/src/components/block-actions/index.js b/packages/block-editor/src/components/block-actions/index.js index ffb14ffca8c5eb..3e12269b074e33 100644 --- a/packages/block-editor/src/components/block-actions/index.js +++ b/packages/block-editor/src/components/block-actions/index.js @@ -11,48 +11,57 @@ import { withSelect, withDispatch } from '@wordpress/data'; import { cloneBlock, hasBlockSupport, switchToBlockType } from '@wordpress/blocks'; function BlockActions( { + canDuplicate, + canInsertDefaultBlock, + children, + isLocked, onDuplicate, - onRemove, - onInsertBefore, - onInsertAfter, onGroup, + onInsertAfter, + onInsertBefore, + onRemove, onUngroup, - isLocked, - canDuplicate, - children, } ) { return children( { + canDuplicate, + canInsertDefaultBlock, + isLocked, onDuplicate, - onRemove, + onGroup, onInsertAfter, onInsertBefore, - onGroup, + onRemove, onUngroup, - isLocked, - canDuplicate, } ); } export default compose( [ withSelect( ( select, props ) => { const { + canInsertBlockType, + getBlockRootClientId, getBlocksByClientId, getTemplateLock, - getBlockRootClientId, } = select( 'core/block-editor' ); + const { getDefaultBlockName } = select( 'core/blocks' ); const blocks = getBlocksByClientId( props.clientIds ); const canDuplicate = every( blocks, ( block ) => { return !! block && hasBlockSupport( block.name, 'multiple', true ); } ); const rootClientId = getBlockRootClientId( props.clientIds[ 0 ] ); + const canInsertDefaultBlock = canInsertBlockType( + getDefaultBlockName(), + rootClientId + ); return { - isLocked: !! getTemplateLock( rootClientId ), blocks, canDuplicate, - rootClientId, + canInsertDefaultBlock, extraProps: props, + isLocked: !! getTemplateLock( rootClientId ), + rootClientId, }; } ), withDispatch( ( dispatch, props, { select } ) => { diff --git a/packages/block-editor/src/components/block-settings-menu/index.js b/packages/block-editor/src/components/block-settings-menu/index.js index 005be38e380b43..527f84ab0ca984 100644 --- a/packages/block-editor/src/components/block-settings-menu/index.js +++ b/packages/block-editor/src/components/block-settings-menu/index.js @@ -32,7 +32,15 @@ export function BlockSettingsMenu( { clientIds } ) { return ( - { ( { onDuplicate, onRemove, onInsertAfter, onInsertBefore, canDuplicate, isLocked } ) => ( + { ( { + canDuplicate, + canInsertDefaultBlock, + isLocked, + onDuplicate, + onInsertAfter, + onInsertBefore, + onRemove, + } ) => ( ) } - { ! isLocked && ( + { canInsertDefaultBlock && ( <>