From f77195300210adf387df5e815c24aef72c0cbeba Mon Sep 17 00:00:00 2001 From: George Hotelling Date: Tue, 4 Aug 2020 12:05:03 -0400 Subject: [PATCH] Using a summary element in the edit view --- packages/block-library/src/details/edit.js | 79 ++++++++++--------- .../block-library/src/details/editor.scss | 14 +--- 2 files changed, 42 insertions(+), 51 deletions(-) diff --git a/packages/block-library/src/details/edit.js b/packages/block-library/src/details/edit.js index c6ff26894113ea..269fb373015b43 100644 --- a/packages/block-library/src/details/edit.js +++ b/packages/block-library/src/details/edit.js @@ -1,8 +1,3 @@ -/** - * External dependencies - */ -import classnames from 'classnames'; - /** * WordPress dependencies */ @@ -14,6 +9,8 @@ import { import { __ } from '@wordpress/i18n'; import { useSelect } from '@wordpress/data'; import { ToggleControl } from '@wordpress/components'; +import { useEffect, useRef } from '@wordpress/element'; +import { SPACE } from '@wordpress/keycodes'; export default ( { attributes, @@ -22,34 +19,38 @@ export default ( { isSelected, setAttributes, } ) => { - const innerBlockSelected = useSelect( + const summaryRef = useRef( null ); + + useEffect( () => { + if ( ! summaryRef.current ) { + return; + } + + const keyDownListener = ( e ) => { + if ( e.keyCode === SPACE ) { + e.preventDefault(); + } + }; + + const clickListener = ( e ) => e.preventDefault(); + + summaryRef.current.addEventListener( 'keyup', keyDownListener ); + summaryRef.current.addEventListener( 'click', clickListener ); + return () => { + summaryRef.current.removeEventListener( 'keyup', keyDownListener ); + summaryRef.current.removeEventListener( 'click', clickListener ); + }; + }, [ summaryRef.current ] ); + + const isInnerBlockSelected = useSelect( ( select ) => select( 'core/block-editor' ).hasSelectedInnerBlock( clientId ), [ clientId ] ); const showInnerBlocks = - attributes.initialOpen || isSelected || innerBlockSelected; - - const classes = classnames( - { - 'is-open': showInnerBlocks, - }, - className - ); + attributes.initialOpen || isSelected || isInnerBlockSelected; - /* You may be wondering why we don't just use a
element here. - * The problem we are trying to solve is that a is basically a - * button, and when it has focus, it eats the space key. - * - * That's a problem if you want to use a component inside your - * . Each time you press space, it toggles the rest of the - *
, and it doesn't even add a space to your . - * - * Then there's the fact that the space exists for a11y reasons. If you - * catch the event and preventDefault() then you've remove the way for - * keyboard users to toggle the
. - */ return ( <> @@ -61,19 +62,19 @@ export default ( { checked={ attributes.initialOpen } /> -
- - setAttributes( { summaryContent } ) - } - placeholder={ __( 'Write a summary…' ) } - aria-label={ __( 'Summary text' ) } - /> - { showInnerBlocks && } -
+
+ + + setAttributes( { summaryContent } ) + } + placeholder={ __( 'Write a summary…' ) } + aria-label={ __( 'Summary text' ) } + /> + + +
); }; diff --git a/packages/block-library/src/details/editor.scss b/packages/block-library/src/details/editor.scss index 9acb7134ac67de..5c06909f94520f 100644 --- a/packages/block-library/src/details/editor.scss +++ b/packages/block-library/src/details/editor.scss @@ -1,15 +1,5 @@ .wp-block-details { - .block-library-details__pseudo-summary { - &::before { - display: inline-block; - content: "▶ "; - } - } - -} - -.wp-block-details.is-open { - .block-library-details__pseudo-summary::before { - transform: rotate(90deg); + summary .rich-text { + display: inline; } }