@terrible-lexical/react
Version:
This package provides Lexical components and hooks for React applications.
42 lines (36 loc) • 1.37 kB
text/typescript
/**
* 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;
}