From 6264256e6cf5eb97ee5686bf31221ee045aa0ede Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BAlia=20Roldi?= Date: Wed, 22 Nov 2023 18:48:43 -0300 Subject: [PATCH 1/2] select on click --- .../lib/corePlugins/ImageSelection.ts | 3 +- .../test/corePlugins/imageSelectionTest.ts | 58 ++++++++++++++++++- 2 files changed, 58 insertions(+), 3 deletions(-) diff --git a/packages/roosterjs-editor-core/lib/corePlugins/ImageSelection.ts b/packages/roosterjs-editor-core/lib/corePlugins/ImageSelection.ts index 0041b247fc9..153602d4b31 100644 --- a/packages/roosterjs-editor-core/lib/corePlugins/ImageSelection.ts +++ b/packages/roosterjs-editor-core/lib/corePlugins/ImageSelection.ts @@ -43,7 +43,8 @@ export default class ImageSelection implements EditorPlugin { if ( safeInstanceOf(target, 'HTMLImageElement') && target.isContentEditable && - event.rawEvent.button != mouseMiddleButton + event.rawEvent.button != mouseMiddleButton && + event.isClicking ) { this.editor.select(target); } diff --git a/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts b/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts index 60331218a62..d134c723571 100644 --- a/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts +++ b/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts @@ -7,6 +7,8 @@ import { ImageSelectionRange, PluginEvent, PluginEventType, + PluginMouseUpEvent, + PluginMouseDownEvent, } from 'roosterjs-editor-types'; export * from 'roosterjs-editor-dom/test/DomTestHelper'; @@ -58,8 +60,8 @@ describe('ImageSelectionPlugin |', () => { editor.setContent(``); const target = document.getElementById(imageId); editorIsFeatureEnabled.and.returnValue(true); - simulateMouseEvent('mousedown', target!, 0); - simulateMouseEvent('mouseup', target!, 0); + imageSelection.onPluginEvent(mouseDown(target!, 0)); + imageSelection.onPluginEvent(mouseup(target!, 0, true)); editor.focus(); const selection = editor.getSelectionRangeEx(); @@ -67,6 +69,19 @@ describe('ImageSelectionPlugin |', () => { expect(selection.areAllCollapsed).toBe(false); }); + it('should not be triggered in mouse up left click', () => { + editor.setContent(``); + const target = document.getElementById(imageId); + editorIsFeatureEnabled.and.returnValue(true); + imageSelection.onPluginEvent(mouseDown(target!, 0)); + imageSelection.onPluginEvent(mouseup(target!, 0, false)); + editor.focus(); + + const selection = editor.getSelectionRangeEx(); + expect(selection.type).toBe(SelectionRangeTypes.Normal); + expect(selection.areAllCollapsed).toBe(true); + }); + it('should handle a ESCAPE KEY in a image', () => { editor.setContent(``); const target = document.getElementById(imageId); @@ -204,6 +219,45 @@ describe('ImageSelectionPlugin |', () => { }; }; + const mouseup = ( + target: HTMLElement, + keyNumber: number, + isClicking: boolean + ): PluginMouseUpEvent => { + const rect = target.getBoundingClientRect(); + return { + eventType: PluginEventType.MouseUp, + rawEvent: { + target: target, + view: window, + bubbles: true, + cancelable: true, + clientX: rect.left, + clientY: rect.top, + shiftKey: false, + button: keyNumber, + }, + isClicking, + }; + }; + + const mouseDown = (target: HTMLElement, keyNumber: number): PluginMouseDownEvent => { + const rect = target.getBoundingClientRect(); + return { + eventType: PluginEventType.MouseDown, + rawEvent: { + target: target, + view: window, + bubbles: true, + cancelable: true, + clientX: rect.left, + clientY: rect.top, + shiftKey: false, + button: keyNumber, + }, + }; + }; + function simulateMouseEvent(mouseEvent: string, target: HTMLElement, keyNumber: number) { const rect = target.getBoundingClientRect(); var event = new MouseEvent(mouseEvent, { From 006fcae997ab97fc0c8f1baf0903afa67319ae46 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BAlia=20Roldi?= Date: Wed, 22 Nov 2023 18:54:38 -0300 Subject: [PATCH 2/2] test --- .../test/corePlugins/imageSelectionTest.ts | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts b/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts index d134c723571..c5ac7e4e940 100644 --- a/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts +++ b/packages/roosterjs-editor-core/test/corePlugins/imageSelectionTest.ts @@ -257,18 +257,4 @@ describe('ImageSelectionPlugin |', () => { }, }; }; - - function simulateMouseEvent(mouseEvent: string, target: HTMLElement, keyNumber: number) { - const rect = target.getBoundingClientRect(); - var event = new MouseEvent(mouseEvent, { - view: window, - bubbles: true, - cancelable: true, - clientX: rect.left, - clientY: rect.top, - shiftKey: false, - button: keyNumber, - }); - target.dispatchEvent(event); - } });