From eaf3cc5c753473657f7b5c457e66cf63a8183a55 Mon Sep 17 00:00:00 2001 From: Andrea Fercia Date: Thu, 7 Jul 2022 11:05:07 +0200 Subject: [PATCH] Use setTimeout only when the focus on mount target is the first tabbable element. --- .../src/hooks/use-focus-on-mount/index.js | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/packages/compose/src/hooks/use-focus-on-mount/index.js b/packages/compose/src/hooks/use-focus-on-mount/index.js index a081c75afe2b8f..2703e57b599c54 100644 --- a/packages/compose/src/hooks/use-focus-on-mount/index.js +++ b/packages/compose/src/hooks/use-focus-on-mount/index.js @@ -40,23 +40,23 @@ export default function useFocusOnMount( focusOnMount = 'firstElement' ) { return; } - const focusTimeout = setTimeout( () => { - let target = node; - - if ( focusOnMountRef.current === 'firstElement' ) { - const firstTabbable = focus.tabbable.find( node )[ 0 ]; - - if ( firstTabbable ) { - target = /** @type {HTMLElement} */ ( firstTabbable ); - } - } - - target.focus( { + if ( focusOnMountRef.current !== 'firstElement' ) { + node.focus( { // When focusing newly mounted dialogs, // the position of the popover is often not right on the first render // This prevents the layout shifts when focusing the dialogs. preventScroll: true, } ); + + return; + } + + const focusTimeout = setTimeout( () => { + const firstTabbable = focus.tabbable.find( node )[ 0 ]; + + if ( firstTabbable ) { + /** @type {HTMLElement} */ ( firstTabbable ).focus(); + } }, 0 ); return () => clearTimeout( focusTimeout );