From 71205beeda70397eb95a81fac51f81b205934a12 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Fri, 22 Jan 2021 12:28:55 +0100 Subject: [PATCH 1/4] Fix insertion point --- .../components/block-list/insertion-point.js | 110 ++++++++++++------ 1 file changed, 73 insertions(+), 37 deletions(-) diff --git a/packages/block-editor/src/components/block-list/insertion-point.js b/packages/block-editor/src/components/block-list/insertion-point.js index e393710dc5a47..52a06a7b513c8 100644 --- a/packages/block-editor/src/components/block-list/insertion-point.js +++ b/packages/block-editor/src/components/block-list/insertion-point.js @@ -53,7 +53,13 @@ function InsertionPointPopover( { const { selectBlock } = useDispatch( 'core/block-editor' ); const ref = useRef(); - const { previousElement, nextElement, orientation, isHidden } = useSelect( + const { + previousElement, + nextElement, + orientation, + isHidden, + nextClientId, + } = useSelect( ( select ) => { const { getBlockOrder, @@ -69,13 +75,16 @@ function InsertionPointPopover( { ? getBlockRootClientId( clientId ) : rootClientId; const blockOrder = getBlockOrder( targetRootClientId ); - if ( blockOrder.length < 2 ) { + if ( ! blockOrder.length ) { return {}; } - const next = clientId + const previous = clientId ? clientId : blockOrder[ blockOrder.length - 1 ]; - const previous = blockOrder[ blockOrder.indexOf( next ) - 1 ]; + const isLast = previous === blockOrder[ blockOrder.length - 1 ]; + const next = isLast + ? null + : blockOrder[ blockOrder.indexOf( previous ) + 1 ]; const { hasReducedUI } = getSettings(); const multiSelectedBlockClientIds = getMultiSelectedBlockClientIds(); const selectedBlockClientId = getSelectedBlockClientId(); @@ -86,12 +95,14 @@ function InsertionPointPopover( { return { previousElement: getBlockDOMNode( previous, ownerDocument ), nextElement: getBlockDOMNode( next, ownerDocument ), + nextClientId: next, isHidden: hasReducedUI || ( hasMultiSelection() - ? multiSelectedBlockClientIds.includes( clientId ) - : blockOrientation === 'vertical' && - clientId === selectedBlockClientId ), + ? next && multiSelectedBlockClientIds.includes( next ) + : next && + blockOrientation === 'vertical' && + next === selectedBlockClientId ), orientation: blockOrientation, }; }, @@ -99,40 +110,61 @@ function InsertionPointPopover( { ); const style = useMemo( () => { - if ( ! previousElement || ! nextElement ) { + if ( ! previousElement ) { return {}; } const previousRect = previousElement.getBoundingClientRect(); - const nextRect = nextElement.getBoundingClientRect(); - - return orientation === 'vertical' - ? { - width: previousElement.offsetWidth, - height: nextRect.top - previousRect.bottom, - } - : { - width: isRTL() - ? previousRect.left - nextRect.right - : nextRect.left - previousRect.right, - height: previousElement.offsetHeight, - }; + const nextRect = nextElement + ? nextElement.getBoundingClientRect() + : null; + + if ( orientation === 'vertical' ) { + return { + width: previousElement.offsetWidth, + height: nextRect ? nextRect.top - previousRect.bottom : 0, + }; + } + + let width = 0; + if ( nextElement ) { + width = isRTL() + ? previousRect.left - nextRect.right + : nextRect.left - previousRect.right; + } + + return { + width, + height: previousElement.offsetHeight, + }; }, [ previousElement, nextElement ] ); const getAnchorRect = useCallback( () => { const previousRect = previousElement.getBoundingClientRect(); - const nextRect = nextElement.getBoundingClientRect(); + const nextRect = nextElement + ? nextElement.getBoundingClientRect() + : null; if ( orientation === 'vertical' ) { return { top: previousRect.bottom, left: previousRect.left, right: previousRect.right, - bottom: nextRect.top, + bottom: nextRect ? nextRect.top : previousRect.bottom, }; } + + if ( isRTL() ) { + return { + top: previousRect.top, + left: nextRect ? nextRect.right : previousRect.left, + right: previousRect.left, + bottom: previousRect.bottom, + }; + } + return { top: previousRect.top, - left: isRTL() ? nextRect.right : previousRect.right, - right: isRTL() ? previousRect.left : nextRect.left, + left: previousRect.right, + right: nextRect ? nextRect.left : previousRect.right, bottom: previousRect.bottom, }; }, [ previousElement, nextElement ] ); @@ -192,7 +224,7 @@ function InsertionPointPopover( { ) } { ! isHidden && ( isInserterShown || isInserterForced ) && ( ) } @@ -228,7 +260,7 @@ export default function useInsertionPoint( ref ) { getBlockListSettings: _getBlockListSettings, isMultiSelecting: _isMultiSelecting(), isInserterVisible: isBlockInsertionPointVisible(), - selectedClientId: order[ insertionPoint.index ], + selectedClientId: order[ insertionPoint.index - 1 ], selectedRootClientId: insertionPoint.rootClientId, }; }, [] ); @@ -261,16 +293,20 @@ export default function useInsertionPoint( ref ) { const rect = event.target.getBoundingClientRect(); const offsetTop = event.clientY - rect.top; const offsetLeft = event.clientX - rect.left; - let element = Array.from( event.target.children ).find( - ( blockEl ) => { - return ( - ( orientation === 'vertical' && - blockEl.offsetTop > offsetTop ) || - ( orientation === 'horizontal' && - blockEl.offsetLeft > offsetLeft ) - ); - } - ); + + const children = Array.from( event.target.children ); + const nextElement = children.find( ( blockEl ) => { + return ( + ( orientation === 'vertical' && + blockEl.offsetTop > offsetTop ) || + ( orientation === 'horizontal' && + blockEl.offsetLeft > offsetLeft ) + ); + } ); + + let element = nextElement + ? children[ children.indexOf( nextElement ) - 1 ] + : children[ children.length - 1 ]; if ( ! element ) { return; From f554936c88532f3f068ae91b60e722b4ad16ed79 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Fri, 22 Jan 2021 12:53:20 +0100 Subject: [PATCH 2/4] Uncomment insertion point assertion --- packages/e2e-tests/specs/widgets/adding-widgets.test.js | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/packages/e2e-tests/specs/widgets/adding-widgets.test.js b/packages/e2e-tests/specs/widgets/adding-widgets.test.js index 3fd2fe3c744a5..7db8bb38e1cc0 100644 --- a/packages/e2e-tests/specs/widgets/adding-widgets.test.js +++ b/packages/e2e-tests/specs/widgets/adding-widgets.test.js @@ -64,7 +64,6 @@ describe( 'Widgets screen', () => { return addParagraphBlock; } - /* async function expectInsertionPointIndicatorToBeBelowLastBlock( widgetArea ) { @@ -82,7 +81,6 @@ describe( 'Widgets screen', () => { insertionPointIndicatorBoundingBox.y > lastBlockBoundingBox.y ).toBe( true ); } - */ async function getInlineInserterButton() { return await page.waitForSelector( @@ -124,9 +122,9 @@ describe( 'Widgets screen', () => { addParagraphBlock = await getParagraphBlockInGlobalInserter(); await addParagraphBlock.hover(); - /*await expectInsertionPointIndicatorToBeBelowLastBlock( + await expectInsertionPointIndicatorToBeBelowLastBlock( firstWidgetArea - );*/ + ); await addParagraphBlock.click(); await page.keyboard.type( 'Second Paragraph' ); From 6ddee2b22170415e9eed66a5ad84459eaa2a3f6b Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Mon, 25 Jan 2021 10:37:30 +0100 Subject: [PATCH 3/4] Fix deadzones handling --- .../block-editor/src/components/block-list/insertion-point.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/block-editor/src/components/block-list/insertion-point.js b/packages/block-editor/src/components/block-list/insertion-point.js index 52a06a7b513c8..8b1eed5fd0e45 100644 --- a/packages/block-editor/src/components/block-list/insertion-point.js +++ b/packages/block-editor/src/components/block-list/insertion-point.js @@ -179,8 +179,8 @@ function InsertionPointPopover( { ); function onClick( event ) { - if ( event.target === ref.current ) { - selectBlock( clientId, -1 ); + if ( event.target === ref.current && nextClientId ) { + selectBlock( nextClientId, -1 ); } } From 9829ec67646a6bc50cef34e6d96ec1646bc210d1 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Wed, 27 Jan 2021 08:58:33 +0100 Subject: [PATCH 4/4] Fix inserting at the end of a block list --- .../components/block-list/insertion-point.js | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/packages/block-editor/src/components/block-list/insertion-point.js b/packages/block-editor/src/components/block-list/insertion-point.js index 8b1eed5fd0e45..db2653b031bc7 100644 --- a/packages/block-editor/src/components/block-list/insertion-point.js +++ b/packages/block-editor/src/components/block-list/insertion-point.js @@ -23,7 +23,11 @@ import { isRTL } from '@wordpress/i18n'; import Inserter from '../inserter'; import { getBlockDOMNode } from '../../utils/dom'; -function InsertionPointInserter( { clientId, setIsInserterForced } ) { +function InsertionPointInserter( { + clientId, + rootClientId, + setIsInserterForced, +} ) { return (
setIsInserterForced( false ) } @@ -43,7 +48,7 @@ function InsertionPointInserter( { clientId, setIsInserterForced } ) { function InsertionPointPopover( { clientId, - rootClientId, + selectedRootClientId, isInserterShown, isInserterForced, setIsInserterForced, @@ -59,6 +64,7 @@ function InsertionPointPopover( { orientation, isHidden, nextClientId, + rootClientId, } = useSelect( ( select ) => { const { @@ -73,7 +79,7 @@ function InsertionPointPopover( { const { ownerDocument } = containerRef.current; const targetRootClientId = clientId ? getBlockRootClientId( clientId ) - : rootClientId; + : selectedRootClientId; const blockOrder = getBlockOrder( targetRootClientId ); if ( ! blockOrder.length ) { return {}; @@ -104,9 +110,10 @@ function InsertionPointPopover( { blockOrientation === 'vertical' && next === selectedBlockClientId ), orientation: blockOrientation, + rootClientId: targetRootClientId, }; }, - [ clientId, rootClientId ] + [ clientId, selectedRootClientId ] ); const style = useMemo( () => { @@ -224,6 +231,7 @@ function InsertionPointPopover( { ) } { ! isHidden && ( isInserterShown || isInserterForced ) && ( @@ -373,7 +381,7 @@ export default function useInsertionPoint( ref ) { clientId={ isInserterVisible ? selectedClientId : inserterClientId } - rootClientId={ selectedRootClientId } + selectedRootClientId={ selectedRootClientId } isInserterShown={ isInserterShown } isInserterForced={ isInserterForced } setIsInserterForced={ ( value ) => {