From d442fa681eaad9d5700460d54c4d947421c35ca3 Mon Sep 17 00:00:00 2001 From: Andrew Duthie Date: Wed, 15 Nov 2017 15:21:39 -0500 Subject: [PATCH] Visual Editor: Hide sibling inserter by CSS --- .../components/block-list/sibling-inserter.js | 84 +++---------------- editor/components/block-list/style.scss | 19 +++-- test/e2e/integration/002-adding-blocks.js | 2 +- 3 files changed, 26 insertions(+), 79 deletions(-) diff --git a/editor/components/block-list/sibling-inserter.js b/editor/components/block-list/sibling-inserter.js index 1270d92f62e66f..17300a5ceadf40 100644 --- a/editor/components/block-list/sibling-inserter.js +++ b/editor/components/block-list/sibling-inserter.js @@ -8,7 +8,6 @@ import classnames from 'classnames'; * WordPress dependencies */ import { Component } from '@wordpress/element'; -import { focus } from '@wordpress/utils'; /** * Internal dependencies @@ -25,67 +24,17 @@ class BlockListSiblingInserter extends Component { constructor() { super( ...arguments ); - this.bindNode = this.bindNode.bind( this ); - this.focusFirstTabbable = this.focusFirstTabbable.bind( this ); - this.show = this.toggleVisible.bind( this, true ); - this.hide = this.toggleVisible.bind( this, false ); - this.showAndFocus = this.showAndFocus.bind( this ); - this.suspendToggleVisible = this.suspendToggleVisible.bind( this ); + this.forceVisibleWhileInserting = this.forceVisibleWhileInserting.bind( this ); this.state = { - isVisible: false, - isToggleVisibleSuspended: false, + isForcedVisible: false, }; } - componentDidUpdate( prevProps, prevState ) { - const { visibleViaFocus, state } = this; - const { isVisible, isToggleVisibleSuspended } = state; - if ( isVisible && ! prevState.isVisible && visibleViaFocus ) { - this.focusFirstTabbable(); - - // Reset for next toggle visible - this.visibleViaFocus = false; - } - - // If inserter is closed, we must check to see if focus is still within - // the inserter, since it may have been closed by clicking outside. We - // want to retain visible if still focused, or hide otherwise. - if ( ! isToggleVisibleSuspended && prevState.isToggleVisibleSuspended && - ! this.node.contains( document.activeElement ) ) { - this.toggleVisible( false ); - } - } - - bindNode( node ) { - this.node = node; - } - - focusFirstTabbable() { - // Sibling inserter doesn't render its inserter button until after it - // becomes visible by focus or hover. If visible by focus, move focus - // into the now-visible button. - const tabbable = focus.tabbable.find( this.node ); - if ( tabbable.length ) { - tabbable[ 0 ].focus(); - } - } - - toggleVisible( isVisible ) { - if ( ! this.state.isToggleVisibleSuspended ) { - this.setState( { isVisible } ); - } - } - - showAndFocus() { - this.toggleVisible( true ); - this.visibleViaFocus = true; - } - - suspendToggleVisible( isOpen ) { + forceVisibleWhileInserting( isOpen ) { // Prevent mouseout and blur while navigating the open inserter menu // from causing the inserter to be unmounted. - this.setState( { isToggleVisibleSuspended: isOpen } ); + this.setState( { isForcedVisible: isOpen } ); } render() { @@ -94,33 +43,26 @@ class BlockListSiblingInserter extends Component { } const { insertIndex, showInsertionPoint } = this.props; - const { isVisible } = this.state; + const { isForcedVisible } = this.state; const classes = classnames( 'editor-block-list__sibling-inserter', { - 'is-visible': isVisible || showInsertionPoint, + 'is-forced-visible': isForcedVisible || showInsertionPoint, } ); return (
+ className={ classes }> { showInsertionPoint && (
) } - { isVisible && - - } +
); } diff --git a/editor/components/block-list/style.scss b/editor/components/block-list/style.scss index 5a06ad1916160f..b896388aad6b6b 100644 --- a/editor/components/block-list/style.scss +++ b/editor/components/block-list/style.scss @@ -388,9 +388,6 @@ position: relative; max-width: $visual-editor-max-width + ( 2 * $block-mover-padding-visible ) - ( 2 * $block-padding ); margin: 0 auto; - opacity: 0; - transition: opacity 0.25s ease-in-out; - transition-delay: 0.3s; @include break-small { max-width: $visual-editor-max-width - ( 2 * $block-padding ); @@ -400,10 +397,6 @@ top: #{ -1 * ( $block-spacing / 2 ) }; } - &.is-visible { - opacity: 1; - } - &:before { content: ''; position: absolute; @@ -425,6 +418,18 @@ margin: 0; } + .editor-inserter__toggle { + opacity: 0; + transition: opacity 0.25s ease-in-out; + transition-delay: 0.3s; + } + + &.is-forced-visible .editor-inserter__toggle, + &:hover .editor-inserter__toggle, + .editor-inserter__toggle:focus { + opacity: 1; + } + .editor-inserter__toggle.components-button { margin: 0; padding: 4px; diff --git a/test/e2e/integration/002-adding-blocks.js b/test/e2e/integration/002-adding-blocks.js index 156c32312f2584..5f5c8c48c07b94 100644 --- a/test/e2e/integration/002-adding-blocks.js +++ b/test/e2e/integration/002-adding-blocks.js @@ -20,7 +20,7 @@ describe( 'Adding blocks', () => { cy.get( lastBlockSelector ).type( 'Quote block' ); // Using the regular inserter - cy.get( '.editor-visual-editor [aria-label="Insert block"]' ).click(); + cy.get( '.editor-visual-editor__inserter [aria-label="Insert block"]' ).click(); cy.get( '[placeholder="Search for a block"]' ).type( 'code' ); cy.get( '.editor-inserter__block' ).contains( 'Code' ).click(); cy.get( '[placeholder="Write codeā€¦"]' ).type( 'Code block' );