UNPKG

@lexical/react

Version:

This package provides Lexical components and hooks for React applications.

48 lines (42 loc) 1.5 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. * */ 'use strict'; var LexicalComposerContext = require('@lexical/react/LexicalComposerContext'); var react = require('react'); /** * 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. * */ function AutoFocusPlugin({ defaultSelection }) { const [editor] = LexicalComposerContext.useLexicalComposerContext(); react.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(); if (rootElement !== null && (activeElement === null || !rootElement.contains(activeElement))) { // Note: preventScroll won't work in Webkit. rootElement.focus({ preventScroll: true }); } }, { defaultSelection }); }, [defaultSelection, editor]); return null; } exports.AutoFocusPlugin = AutoFocusPlugin;