diff --git a/packages/block-editor/src/components/list-view/block-contents.js b/packages/block-editor/src/components/list-view/block-contents.js index e3550bcd39eb14..8d5b03395f3e20 100644 --- a/packages/block-editor/src/components/list-view/block-contents.js +++ b/packages/block-editor/src/components/list-view/block-contents.js @@ -47,7 +47,7 @@ const ListViewBlockContents = forwardRef( [] ); - const { renderAdditionalBlockUI, insertedBlock, setInsertedBlock } = + const { AdditionalBlockContent, insertedBlock, setInsertedBlock } = useListViewContext(); const isBlockMoveTarget = @@ -67,12 +67,13 @@ const ListViewBlockContents = forwardRef( return ( <> - { renderAdditionalBlockUI && - renderAdditionalBlockUI( - block, - insertedBlock, - setInsertedBlock - ) } + { AdditionalBlockContent && ( + + ) } { ( { draggable, onDragStart, onDragEnd } ) => ( { showAppender={ false } rootClientId={ null } onSelect={ null } - renderAdditionalBlockUI={ null } + additionalBlockContent={ null } blockSettingsMenu={ undefined } /> ); diff --git a/packages/block-library/src/navigation/edit/menu-inspector-controls.js b/packages/block-library/src/navigation/edit/menu-inspector-controls.js index 23f005beb43502..79ab409d62b602 100644 --- a/packages/block-library/src/navigation/edit/menu-inspector-controls.js +++ b/packages/block-library/src/navigation/edit/menu-inspector-controls.js @@ -33,6 +33,48 @@ const BLOCKS_WITH_LINK_UI_SUPPORT = [ 'core/navigation-submenu', ]; +function AdditionalBlockContent( { block, insertedBlock, setInsertedBlock } ) { + const { updateBlockAttributes } = useDispatch( blockEditorStore ); + + const supportsLinkControls = BLOCKS_WITH_LINK_UI_SUPPORT?.includes( + insertedBlock?.name + ); + const blockWasJustInserted = insertedBlock?.clientId === block.clientId; + const showLinkControls = supportsLinkControls && blockWasJustInserted; + + if ( ! showLinkControls ) { + return null; + } + + const setInsertedBlockAttributes = + ( _insertedBlockClientId ) => ( _updatedAttributes ) => { + if ( ! _insertedBlockClientId ) return; + updateBlockAttributes( _insertedBlockClientId, _updatedAttributes ); + }; + + return ( + { + setInsertedBlock( null ); + } } + hasCreateSuggestion={ false } + onChange={ ( updatedValue ) => { + updateAttributes( + updatedValue, + setInsertedBlockAttributes( insertedBlock?.clientId ), + insertedBlock?.attributes + ); + setInsertedBlock( null ); + } } + onCancel={ () => { + setInsertedBlock( null ); + } } + /> + ); +} + const MainContent = ( { clientId, currentMenuId, @@ -52,14 +94,6 @@ const MainContent = ( { [ clientId ] ); - const { updateBlockAttributes } = useDispatch( blockEditorStore ); - - const setInsertedBlockAttributes = - ( _insertedBlockClientId ) => ( _updatedAttributes ) => { - if ( ! _insertedBlockClientId ) return; - updateBlockAttributes( _insertedBlockClientId, _updatedAttributes ); - }; - const { navigationMenu } = useNavigationMenu( currentMenuId ); if ( currentMenuId && isNavigationMenuMissing ) { @@ -80,47 +114,6 @@ const MainContent = ( { 'You have not yet created any menus. Displaying a list of your Pages' ); - const renderLinkUI = ( - currentBlock, - lastInsertedBlock, - setLastInsertedBlock - ) => { - const blockSupportsLinkUI = BLOCKS_WITH_LINK_UI_SUPPORT?.includes( - lastInsertedBlock?.name - ); - const currentBlockWasJustInserted = - lastInsertedBlock?.clientId === currentBlock.clientId; - - const shouldShowLinkUIForBlock = - blockSupportsLinkUI && currentBlockWasJustInserted; - - return ( - shouldShowLinkUIForBlock && ( - { - setLastInsertedBlock( null ); - } } - hasCreateSuggestion={ false } - onChange={ ( updatedValue ) => { - updateAttributes( - updatedValue, - setInsertedBlockAttributes( - lastInsertedBlock?.clientId - ), - lastInsertedBlock?.attributes - ); - setLastInsertedBlock( null ); - } } - onCancel={ () => { - setLastInsertedBlock( null ); - } } - /> - ) - ); - }; - return (
{ clientIdsTree.length === 0 && ( @@ -135,7 +128,7 @@ const MainContent = ( { description={ description } showAppender blockSettingsMenu={ LeafMoreMenu } - renderAdditionalBlockUI={ renderLinkUI } + additionalBlockContent={ AdditionalBlockContent } />
);