From 74d3b80a2beb96cb04fb74f9d956e78ee7158d68 Mon Sep 17 00:00:00 2001 From: Yuriy Demidov Date: Wed, 2 Oct 2024 12:00:04 +0300 Subject: [PATCH] fix(SelectionContext): save editor state when start to select content with mouse (#395) --- .../behavior/SelectionContext/index.ts | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/extensions/behavior/SelectionContext/index.ts b/src/extensions/behavior/SelectionContext/index.ts index 25d18fde..31123f42 100644 --- a/src/extensions/behavior/SelectionContext/index.ts +++ b/src/extensions/behavior/SelectionContext/index.ts @@ -1,6 +1,6 @@ import {keydownHandler} from 'prosemirror-keymap'; -import {EditorState, Plugin, PluginSpec, TextSelection} from 'prosemirror-state'; -import {EditorProps, EditorView} from 'prosemirror-view'; +import {type EditorState, Plugin, type PluginSpec, TextSelection} from 'prosemirror-state'; +import type {EditorProps, EditorView} from 'prosemirror-view'; import {ActionStorage, ExtensionAuto} from '../../../core'; import {isCodeBlock} from '../../../utils/nodes'; @@ -22,13 +22,14 @@ export const SelectionContext: ExtensionAuto = (builder } }; +type TinyState = Pick; + class SelectionTooltip implements PluginSpec { private destroyed = false; private tooltip: TooltipView; private hideTimeoutRef: ReturnType | null = null; - private _prevState?: EditorState | null; private _isMousePressed = false; constructor(actions: ActionStorage, menuConfig: ContextConfig) { @@ -50,6 +51,10 @@ class SelectionTooltip implements PluginSpec { }), handleDOMEvents: { mousedown: (view) => { + const startState: TinyState = { + doc: view.state.doc, + selection: view.state.selection, + }; this._isMousePressed = true; this.cancelTooltipHiding(); this.tooltip.hide(view); @@ -57,7 +62,7 @@ class SelectionTooltip implements PluginSpec { const onMouseUp = () => { if (this.destroyed) return; this._isMousePressed = false; - this.update(view, this._prevState); + this.update(view, startState); }; document.addEventListener('mouseup', onMouseUp, {once: true}); @@ -78,11 +83,9 @@ class SelectionTooltip implements PluginSpec { }; } - private update(view: EditorView, prevState?: EditorState | null) { - this._prevState = prevState; + private update(view: EditorView, prevState?: TinyState) { if (this._isMousePressed) return; - this._prevState = null; this.cancelTooltipHiding(); // Don't show tooltip if editor not mounted to the DOM