Skip to content

Commit

Permalink
Revert "Fix: Can't type space if RichText component is inside butto…
Browse files Browse the repository at this point in the history
…n/summary in Firefox (#50540)"

This reverts commit ce1ef42.
  • Loading branch information
Aljullu committed Jul 27, 2023
1 parent c08b078 commit e3ff402
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 28 deletions.
2 changes: 1 addition & 1 deletion packages/block-editor/src/components/rich-text/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -402,7 +402,7 @@ function RichTextWrapper(
disableLineBreaks,
onSplitAtEnd,
} ),
useFirefoxCompat( { value, onChange } ),
useFirefoxCompat(),
anchorRef,
] ) }
contentEditable={ true }
Expand Down
Original file line number Diff line number Diff line change
@@ -1,21 +1,15 @@
/**
* WordPress dependencies
*/
import { useRef } from '@wordpress/element';
import { useRefEffect } from '@wordpress/compose';
import { useSelect } from '@wordpress/data';
import { SPACE } from '@wordpress/keycodes';
import { insert } from '@wordpress/rich-text';

/**
* Internal dependencies
*/
import { store as blockEditorStore } from '../../store';

export function useFirefoxCompat( props ) {
const propsRef = useRef( props );
propsRef.current = props;

export function useFirefoxCompat() {
const { isMultiSelecting } = useSelect( blockEditorStore );
return useRefEffect( ( element ) => {
function onFocus() {
Expand All @@ -37,29 +31,9 @@ export function useFirefoxCompat( props ) {
}
}

// If a contenteditable element is inside a button/summary element,
// it is not possible to type a space in Firefox. Therefore, cancel
// the default event and insert a space explicitly.
// See: https://bugzilla.mozilla.org/show_bug.cgi?id=1822860
function onKeyDown( event ) {
if ( event.keyCode !== SPACE ) {
return;
}

if ( element.closest( 'button, summary' ) === null ) {
return;
}

const { value, onChange } = propsRef.current;
onChange( insert( value, ' ' ) );
event.preventDefault();
}

element.addEventListener( 'focus', onFocus );
element.addEventListener( 'keydown', onKeyDown );
return () => {
element.removeEventListener( 'focus', onFocus );
element.removeEventListener( 'keydown', onKeyDown );
};
}, [] );
}

0 comments on commit e3ff402

Please sign in to comment.