UNPKG

@terrible-lexical/react

Version:

This package provides Lexical components and hooks for React applications.

51 lines (44 loc) 1.43 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 type {EditorState, LexicalEditor} from 'terrible-lexical'; import {useLexicalComposerContext} from '@terrible-lexical/react/src/LexicalComposerContext'; import useLayoutEffect from '@terrible-lexical/shared/src/useLayoutEffect'; export function OnChangePlugin({ ignoreHistoryMergeTagChange = true, ignoreSelectionChange = false, onChange, }: { ignoreHistoryMergeTagChange?: boolean; ignoreSelectionChange?: boolean; onChange: ( editorState: EditorState, editor: LexicalEditor, tags: Set<string>, ) => void; }): null { const [editor] = useLexicalComposerContext(); useLayoutEffect(() => { if (onChange) { return editor.registerUpdateListener( ({editorState, dirtyElements, dirtyLeaves, prevEditorState, tags}) => { if ( (ignoreSelectionChange && dirtyElements.size === 0 && dirtyLeaves.size === 0) || (ignoreHistoryMergeTagChange && tags.has('history-merge')) || prevEditorState.isEmpty() ) { return; } onChange(editorState, editor, tags); }, ); } }, [editor, ignoreHistoryMergeTagChange, ignoreSelectionChange, onChange]); return null; }