diff --git a/packages/block-editor/src/components/off-canvas-editor/block.js b/packages/block-editor/src/components/off-canvas-editor/block.js index 4d5e2e7ea8c49f..e338c4c35c9573 100644 --- a/packages/block-editor/src/components/off-canvas-editor/block.js +++ b/packages/block-editor/src/components/off-canvas-editor/block.js @@ -54,6 +54,7 @@ function ListViewBlock( { isExpanded, selectedClientIds, preventAnnouncement, + selectBlockInCanvas, } ) { const cellRef = useRef( null ); const [ isHovered, setIsHovered ] = useState( false ); @@ -245,7 +246,13 @@ function ListViewBlock( {
{ + event.preventDefault(); + } + } onToggleExpanded={ toggleExpanded } isSelected={ isSelected } position={ position } diff --git a/packages/block-editor/src/components/off-canvas-editor/branch.js b/packages/block-editor/src/components/off-canvas-editor/branch.js index 0c2b541f3199a1..e752bcbc6cae54 100644 --- a/packages/block-editor/src/components/off-canvas-editor/branch.js +++ b/packages/block-editor/src/components/off-canvas-editor/branch.js @@ -4,9 +4,6 @@ import { memo } from '@wordpress/element'; import { AsyncModeProvider, useSelect } from '@wordpress/data'; -/** - * Internal dependencies - */ /** * Internal dependencies */ @@ -92,6 +89,7 @@ function ListViewBranch( props ) { isExpanded, parentId, shouldShowInnerBlocks = true, + selectBlockInCanvas, } = props; const isContentLocked = useSelect( @@ -174,6 +172,7 @@ function ListViewBranch( props ) { isExpanded={ shouldExpand } listPosition={ nextPosition } selectedClientIds={ selectedClientIds } + selectBlockInCanvas={ selectBlockInCanvas } /> ) } { ! showBlock && ( @@ -194,6 +193,7 @@ function ListViewBranch( props ) { isBranchSelected={ isSelectedBranch } selectedClientIds={ selectedClientIds } isExpanded={ isExpanded } + selectBlockInCanvas={ selectBlockInCanvas } /> ) } diff --git a/packages/block-editor/src/components/off-canvas-editor/index.js b/packages/block-editor/src/components/off-canvas-editor/index.js index df48b8b0046ad3..dd88b9ec43cc94 100644 --- a/packages/block-editor/src/components/off-canvas-editor/index.js +++ b/packages/block-editor/src/components/off-canvas-editor/index.js @@ -50,15 +50,22 @@ export const BLOCK_LIST_ITEM_HEIGHT = 36; /** * Show a hierarchical list of blocks. * - * @param {Object} props Components props. - * @param {string} props.id An HTML element id for the root element of ListView. - * @param {Array} props.blocks Custom subset of block client IDs to be used instead of the default hierarchy. - * @param {boolean} props.showBlockMovers Flag to enable block movers - * @param {boolean} props.isExpanded Flag to determine whether nested levels are expanded by default. - * @param {Object} ref Forwarded ref + * @param {Object} props Components props. + * @param {string} props.id An HTML element id for the root element of ListView. + * @param {Array} props.blocks Custom subset of block client IDs to be used instead of the default hierarchy. + * @param {boolean} props.showBlockMovers Flag to enable block movers + * @param {boolean} props.isExpanded Flag to determine whether nested levels are expanded by default. + * @param {boolean} props.selectBlockInCanvas Flag to determine whether the list view should be a block selection mechanism,. + * @param {Object} ref Forwarded ref */ function __ExperimentalOffCanvasEditor( - { id, blocks, showBlockMovers = false, isExpanded = false }, + { + id, + blocks, + showBlockMovers = false, + isExpanded = false, + selectBlockInCanvas = true, + }, ref ) { const { clientIdsTree, draggedClientIds, selectedClientIds } = @@ -199,6 +206,7 @@ function __ExperimentalOffCanvasEditor( selectedClientIds={ selectedClientIds } isExpanded={ isExpanded } shouldShowInnerBlocks={ shouldShowInnerBlocks } + selectBlockInCanvas={ selectBlockInCanvas } /> diff --git a/packages/block-library/src/navigation/edit/index.js b/packages/block-library/src/navigation/edit/index.js index 918b609f92a0e7..51e473fffdd687 100644 --- a/packages/block-library/src/navigation/edit/index.js +++ b/packages/block-library/src/navigation/edit/index.js @@ -9,6 +9,7 @@ import classnames from 'classnames'; import { useState, useEffect, useRef, Platform } from '@wordpress/element'; import { addQueryArgs } from '@wordpress/url'; import { + __experimentalOffCanvasEditor as OffCanvasEditor, InspectorControls, useBlockProps, __experimentalRecursionProvider as RecursionProvider, @@ -82,6 +83,9 @@ function Navigation( { hasColorSettings = true, customPlaceholder: CustomPlaceholder = null, } ) { + const isOffCanvasNavigationEditorEnabled = + window?.__experimentalEnableOffCanvasNavigationEditor === true; + const { openSubmenusOnClick, overlayMenu, @@ -676,18 +680,27 @@ function Navigation( { /* translators: %s: The name of a menu. */ actionLabel={ __( "Switch to '%s'" ) } /> - + { isOffCanvasNavigationEditorEnabled && ( + + ) } + { ! isOffCanvasNavigationEditorEnabled && ( + + ) } { stylingInspectorControls } @@ -759,18 +772,20 @@ function Navigation( { /* translators: %s: The name of a menu. */ actionLabel={ __( "Switch to '%s'" ) } /> - + { ! isOffCanvasNavigationEditorEnabled && ( + + ) } @@ -877,18 +892,27 @@ function Navigation( { /* translators: %s: The name of a menu. */ actionLabel={ __( "Switch to '%s'" ) } /> - + { isOffCanvasNavigationEditorEnabled && ( + + ) } + { ! isOffCanvasNavigationEditorEnabled && ( + + ) } { stylingInspectorControls } @@ -915,6 +939,21 @@ function Navigation( { } } /> ) } + { isOffCanvasNavigationEditorEnabled && ( + + ) } ) } diff --git a/packages/block-library/src/navigation/editor.scss b/packages/block-library/src/navigation/editor.scss index f669b39cb65869..9e7b9ff91e943f 100644 --- a/packages/block-library/src/navigation/editor.scss +++ b/packages/block-library/src/navigation/editor.scss @@ -582,6 +582,13 @@ body.editor-styles-wrapper margin-bottom: $grid-unit-20; } +// increased specificity to override button variant +// for the manage menus button in the advanced area +// of the navigation block +.components-button.is-link.wp-block-navigation-manage-menus-button { + margin-bottom: $grid-unit-20; +} + .wp-block-navigation__overlay-menu-preview { display: flex; align-items: center;