UNPKG

@terrible-lexical/react

Version:

This package provides Lexical components and hooks for React applications.

42 lines (36 loc) 1.37 kB
/** * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * */ import {useLexicalComposerContext} from '@terrible-lexical/react/src/LexicalComposerContext'; import {useEffect} from 'react'; type Props = { defaultSelection?: 'rootStart' | 'rootEnd'; }; export function AutoFocusPlugin({defaultSelection}: Props): null { const [editor] = useLexicalComposerContext(); useEffect(() => { editor.focus( () => { // If we try and move selection to the same point with setBaseAndExtent, it won't // trigger a re-focus on the element. So in the case this occurs, we'll need to correct it. // Normally this is fine, Selection API !== Focus API, but fore the intents of the naming // of this plugin, which should preserve focus too. const activeElement = document.activeElement; const rootElement = editor.getRootElement() as HTMLDivElement; if ( rootElement !== null && (activeElement === null || !rootElement.contains(activeElement)) ) { // Note: preventScroll won't work in Webkit. rootElement.focus({preventScroll: true}); } }, {defaultSelection}, ); }, [defaultSelection, editor]); return null; }