From ac83185b2d4d80b437805bf812c170eb4bd3e9e6 Mon Sep 17 00:00:00 2001 From: George Hotelling Date: Fri, 7 Aug 2020 11:47:51 -0400 Subject: [PATCH] Fixed space bar for RichText in Firefox --- packages/block-library/src/details/edit.js | 46 +++++++++++----------- packages/rich-text/src/component/index.js | 5 +++ 2 files changed, 28 insertions(+), 23 deletions(-) diff --git a/packages/block-library/src/details/edit.js b/packages/block-library/src/details/edit.js index 269fb373015b43..2a7c230d38c869 100644 --- a/packages/block-library/src/details/edit.js +++ b/packages/block-library/src/details/edit.js @@ -12,32 +12,32 @@ import { ToggleControl } from '@wordpress/components'; import { useEffect, useRef } from '@wordpress/element'; import { SPACE } from '@wordpress/keycodes'; -export default ( { +export default function DetalsEdit( { attributes, className, clientId, isSelected, setAttributes, -} ) => { +} ) { const summaryRef = useRef( null ); + const keyUpListener = ( e ) => { + if ( e.keyCode === SPACE ) { + e.preventDefault(); + } + }; + + const clickListener = ( e ) => e.preventDefault(); + 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( 'keyup', keyUpListener ); summaryRef.current.addEventListener( 'click', clickListener ); return () => { - summaryRef.current.removeEventListener( 'keyup', keyDownListener ); + summaryRef.current.removeEventListener( 'keyup', keyUpListener ); summaryRef.current.removeEventListener( 'click', clickListener ); }; }, [ summaryRef.current ] ); @@ -63,18 +63,18 @@ export default ( { />
- - - setAttributes( { summaryContent } ) - } - placeholder={ __( 'Write a summary…' ) } - aria-label={ __( 'Summary text' ) } - /> - + + setAttributes( { summaryContent } ) + } + ref={ summaryRef } + placeholder={ __( 'Write a summary…' ) } + aria-label={ __( 'Summary text' ) } + />
); -}; +} diff --git a/packages/rich-text/src/component/index.js b/packages/rich-text/src/component/index.js index 76d8fc64d13268..ad70861aa0c549 100644 --- a/packages/rich-text/src/component/index.js +++ b/packages/rich-text/src/component/index.js @@ -527,6 +527,11 @@ function RichText( { function handleSpace( event ) { const { keyCode, shiftKey, altKey, metaKey, ctrlKey } = event; + if ( keyCode === SPACE && TagName === 'summary' ) { + handleChange( insert( createRecord(), ' ' ) ); + return; + } + if ( // Only override when no modifiers are pressed. shiftKey ||