@plait/mind 0.39.0 → 0.40.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,122 +1,57 @@
1
- import { MERGING, PRESS_AND_MOVE_BUFFER, PlaitBoard, PlaitElement, PlaitNode, ResizeCursorClass, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, getSelectedElements, preventTouchMove, throttleRAF, toPoint, transformPoint } from '@plait/core';
1
+ import { PlaitBoard, PlaitNode, ResizeCursorClass, distanceBetweenPointAndRectangle, getSelectedElements } from '@plait/core';
2
2
  import { MindElement } from '../interfaces/element';
3
3
  import { getRectangleByNode } from '../utils/position/node';
4
4
  import { NodeSpace } from '../utils/space/node-space';
5
5
  import { MindTransforms } from '../transforms';
6
6
  import { EXTEND_OFFSET } from '../constants/default';
7
7
  import { isDragging } from '../utils/dnd/common';
8
+ import { withResize } from '@plait/common';
8
9
  export const withNodeResize = (board) => {
9
- const { pointerDown, pointerMove, globalPointerUp } = board;
10
- let targetElement = null;
11
10
  let targetElementRef = null;
12
- let startPoint = null;
13
- board.pointerDown = (event) => {
14
- if (PlaitBoard.isReadonly(board)) {
15
- pointerDown(event);
16
- return;
17
- }
18
- const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
19
- const newTargetElement = getSelectedTarget(board, point);
20
- if (newTargetElement) {
21
- PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew']);
22
- targetElement = newTargetElement;
23
- startPoint = [event.x, event.y];
24
- preventTouchMove(board, event, true);
25
- }
26
- pointerDown(event);
27
- };
28
- board.pointerMove = (event) => {
29
- if (PlaitBoard.isReadonly(board) || PlaitBoard.hasBeenTextEditing(board)) {
30
- pointerMove(event);
31
- return;
32
- }
33
- if (startPoint && targetElement && !isMindNodeResizing(board)) {
34
- // prevent text from being selected
35
- event.preventDefault();
36
- const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
37
- const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
38
- if (distance > PRESS_AND_MOVE_BUFFER) {
39
- addResizing(board, targetElement);
40
- targetElementRef = {
41
- minWidth: NodeSpace.getNodeResizableMinWidth(board, targetElement),
42
- currentWidth: NodeSpace.getNodeDynamicWidth(board, targetElement),
43
- path: PlaitBoard.findPath(board, targetElement),
44
- textManage: MindElement.getTextManage(targetElement)
11
+ const options = {
12
+ key: 'mind-node',
13
+ canResize: () => {
14
+ return !isDragging(board);
15
+ },
16
+ detect: (point) => {
17
+ const newTargetElement = getSelectedTarget(board, point);
18
+ if (newTargetElement) {
19
+ return {
20
+ element: newTargetElement,
21
+ handle: null,
22
+ cursorClass: ResizeCursorClass.ew
45
23
  };
46
- MERGING.set(board, true);
47
24
  }
48
- }
49
- if (isMindNodeResizing(board) && startPoint && targetElementRef) {
50
- // prevent text from being selected
51
- event.preventDefault();
52
- preventTouchMove(board, event, true);
53
- throttleRAF(() => {
54
- if (!startPoint) {
55
- return;
56
- }
57
- const endPoint = [event.x, event.y];
58
- const offsetX = endPoint[0] - startPoint[0];
59
- const zoom = board.viewport.zoom;
60
- let resizedWidth = targetElementRef.currentWidth + offsetX / zoom;
61
- if (resizedWidth <= targetElementRef.minWidth) {
62
- resizedWidth = targetElementRef.minWidth;
63
- }
64
- const newTarget = PlaitNode.get(board, targetElementRef.path);
65
- if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
66
- targetElementRef.textManage.updateRectangleWidth(resizedWidth);
67
- const { height } = targetElementRef.textManage.getSize();
68
- MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
69
- }
70
- });
71
- return;
72
- }
73
- else {
74
- // press and start drag when node is non selected
75
- if (!isDragging(board)) {
76
- const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
77
- const newTargetElement = getSelectedTarget(board, point);
78
- if (newTargetElement) {
79
- PlaitBoard.getBoardContainer(board).classList.add(`mind-${ResizeCursorClass['ew']}`);
80
- }
81
- else {
82
- PlaitBoard.getBoardContainer(board).classList.remove(`mind-${ResizeCursorClass['ew']}`);
83
- }
25
+ return null;
26
+ },
27
+ beforeResize: (resizeRef) => {
28
+ targetElementRef = {
29
+ minWidth: NodeSpace.getNodeResizableMinWidth(board, resizeRef.element),
30
+ currentWidth: NodeSpace.getNodeDynamicWidth(board, resizeRef.element),
31
+ path: PlaitBoard.findPath(board, resizeRef.element),
32
+ textManage: MindElement.getTextManage(resizeRef.element)
33
+ };
34
+ },
35
+ onResize: (resizeRef, resizeState) => {
36
+ const zoom = board.viewport.zoom;
37
+ let resizedWidth = targetElementRef.currentWidth + resizeState.offsetX / zoom;
38
+ if (resizedWidth <= targetElementRef.minWidth) {
39
+ resizedWidth = targetElementRef.minWidth;
84
40
  }
85
- }
86
- pointerMove(event);
87
- };
88
- board.globalPointerUp = (event) => {
89
- globalPointerUp(event);
90
- if (isMindNodeResizing(board) || targetElement) {
91
- targetElement && removeResizing(board, targetElement);
41
+ const newTarget = PlaitNode.get(board, targetElementRef.path);
42
+ if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
43
+ targetElementRef.textManage.updateRectangleWidth(resizedWidth);
44
+ const { height } = targetElementRef.textManage.getSize();
45
+ MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
46
+ }
47
+ },
48
+ afterResize: (resizeRef) => {
92
49
  targetElementRef = null;
93
- targetElement = null;
94
- startPoint = null;
95
- MERGING.set(board, false);
96
- preventTouchMove(board, event, false);
97
50
  }
98
51
  };
52
+ withResize(board, options);
99
53
  return board;
100
54
  };
101
- export const IS_MIND_NODE_RESIZING = new WeakMap();
102
- export const isMindNodeResizing = (board) => {
103
- return !!IS_MIND_NODE_RESIZING.get(board);
104
- };
105
- export const addResizing = (board, element) => {
106
- PlaitBoard.getBoardContainer(board).classList.add('mind-node-resizing');
107
- const component = PlaitElement.getComponent(element);
108
- component.g.classList.add('resizing');
109
- IS_MIND_NODE_RESIZING.set(board, true);
110
- };
111
- export const removeResizing = (board, element) => {
112
- PlaitBoard.getBoardContainer(board).classList.remove('mind-node-resizing');
113
- PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew']);
114
- const component = PlaitElement.getComponent(element);
115
- if (component && component.g) {
116
- component.g.classList.remove('resizing');
117
- }
118
- IS_MIND_NODE_RESIZING.set(board, false);
119
- };
120
55
  export const getSelectedTarget = (board, point) => {
121
56
  const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value));
122
57
  if (selectedElements.length > 0) {
@@ -133,4 +68,4 @@ export const getResizeActiveRectangle = (board, element) => {
133
68
  const rectangle = getRectangleByNode(node);
134
69
  return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };
135
70
  };
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-resize.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    MERGING,\n    PRESS_AND_MOVE_BUFFER,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    PlaitNode,\n    Point,\n    RectangleClient,\n    ResizeCursorClass,\n    distanceBetweenPointAndPoint,\n    distanceBetweenPointAndRectangle,\n    getSelectedElements,\n    preventTouchMove,\n    throttleRAF,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { MindElement } from '../interfaces/element';\nimport { getRectangleByNode } from '../utils/position/node';\nimport { NodeSpace } from '../utils/space/node-space';\nimport { PlaitMindBoard } from './with-mind.board';\nimport { MindNodeComponent } from '../mind-node.component';\nimport { MindTransforms } from '../transforms';\nimport { TextManage } from '@plait/text';\nimport { EXTEND_OFFSET } from '../constants/default';\nimport { isDragging } from '../utils/dnd/common';\n\ninterface TargetElementRef {\n    minWidth: number;\n    currentWidth: number;\n    path: Path;\n    textManage: TextManage;\n}\n\nexport const withNodeResize = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, globalPointerUp } = board;\n    let targetElement: MindElement | null = null;\n    let targetElementRef: TargetElementRef | null = null;\n    let startPoint: Point | null = null;\n\n    board.pointerDown = (event: PointerEvent) => {\n        if (PlaitBoard.isReadonly(board)) {\n            pointerDown(event);\n            return;\n        }\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n        if (newTargetElement) {\n            PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew']);\n            targetElement = newTargetElement;\n            startPoint = [event.x, event.y];\n            preventTouchMove(board, event, true);\n        }\n\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        if (PlaitBoard.isReadonly(board) || PlaitBoard.hasBeenTextEditing(board)) {\n            pointerMove(event);\n            return;\n        }\n\n        if (startPoint && targetElement && !isMindNodeResizing(board)) {\n            // prevent text from being selected\n            event.preventDefault();\n            const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);\n            if (distance > PRESS_AND_MOVE_BUFFER) {\n                addResizing(board, targetElement);\n                targetElementRef = {\n                    minWidth: NodeSpace.getNodeResizableMinWidth(board as PlaitMindBoard, targetElement),\n                    currentWidth: NodeSpace.getNodeDynamicWidth(board as PlaitMindBoard, targetElement),\n                    path: PlaitBoard.findPath(board, targetElement),\n                    textManage: MindElement.getTextManage(targetElement)\n                };\n                MERGING.set(board, true);\n            }\n        }\n\n        if (isMindNodeResizing(board) && startPoint && targetElementRef) {\n            // prevent text from being selected\n            event.preventDefault();\n            preventTouchMove(board, event, true);\n            throttleRAF(() => {\n                if (!startPoint) {\n                    return;\n                }\n\n                const endPoint = [event.x, event.y];\n                const offsetX = endPoint[0] - startPoint![0];\n                const zoom = board.viewport.zoom;\n                let resizedWidth = targetElementRef!.currentWidth + offsetX / zoom;\n                if (resizedWidth <= targetElementRef!.minWidth) {\n                    resizedWidth = targetElementRef!.minWidth;\n                }\n\n                const newTarget = PlaitNode.get<MindElement>(board, targetElementRef!.path);\n                if (newTarget && NodeSpace.getNodeTopicMinWidth(board as PlaitMindBoard, newTarget) !== resizedWidth) {\n                    targetElementRef!.textManage.updateRectangleWidth(resizedWidth);\n                    const { height } = targetElementRef!.textManage.getSize();\n                    MindTransforms.setNodeManualWidth(board as PlaitMindBoard, newTarget, resizedWidth * zoom, height);\n                }\n            });\n            return;\n        } else {\n            // press and start drag when node is non selected\n            if (!isDragging(board)) {\n                const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n                const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n                if (newTargetElement) {\n                    PlaitBoard.getBoardContainer(board).classList.add(`mind-${ResizeCursorClass['ew']}`);\n                } else {\n                    PlaitBoard.getBoardContainer(board).classList.remove(`mind-${ResizeCursorClass['ew']}`);\n                }\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        globalPointerUp(event);\n\n        if (isMindNodeResizing(board) || targetElement) {\n            targetElement && removeResizing(board, targetElement);\n            targetElementRef = null;\n            targetElement = null;\n            startPoint = null;\n            MERGING.set(board, false);\n            preventTouchMove(board, event, false);\n        }\n    };\n\n    return board;\n};\n\nexport const IS_MIND_NODE_RESIZING = new WeakMap<PlaitBoard, boolean>();\n\nexport const isMindNodeResizing = (board: PlaitBoard) => {\n    return !!IS_MIND_NODE_RESIZING.get(board);\n};\n\nexport const addResizing = (board: PlaitBoard, element: MindElement) => {\n    PlaitBoard.getBoardContainer(board).classList.add('mind-node-resizing');\n    const component = PlaitElement.getComponent(element);\n    component.g.classList.add('resizing');\n    IS_MIND_NODE_RESIZING.set(board, true);\n};\n\nexport const removeResizing = (board: PlaitBoard, element: MindElement) => {\n    PlaitBoard.getBoardContainer(board).classList.remove('mind-node-resizing');\n    PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew']);\n    const component = PlaitElement.getComponent(element);\n    if (component && component.g) {\n        component.g.classList.remove('resizing');\n    }\n    IS_MIND_NODE_RESIZING.set(board, false);\n};\n\nexport const getSelectedTarget = (board: PlaitMindBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value)) as MindElement[];\n    if (selectedElements.length > 0) {\n        const target = selectedElements.find(value => {\n            const rectangle = getResizeActiveRectangle(board, value);\n            return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;\n        });\n        return target ? target : null;\n    }\n\n    return null;\n};\n\nexport const getResizeActiveRectangle = (board: PlaitBoard, element: MindElement): RectangleClient => {\n    const node = MindElement.getNode(element);\n    const rectangle = getRectangleByNode(node);\n    return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };\n};\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-resize.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Path,\n    PlaitBoard,\n    PlaitNode,\n    Point,\n    RectangleClient,\n    ResizeCursorClass,\n    distanceBetweenPointAndRectangle,\n    getSelectedElements\n} from '@plait/core';\nimport { MindElement } from '../interfaces/element';\nimport { getRectangleByNode } from '../utils/position/node';\nimport { NodeSpace } from '../utils/space/node-space';\nimport { PlaitMindBoard } from './with-mind.board';\nimport { MindTransforms } from '../transforms';\nimport { TextManage } from '@plait/text';\nimport { EXTEND_OFFSET } from '../constants/default';\nimport { isDragging } from '../utils/dnd/common';\nimport { ResizeRef, ResizeState, WithResizeOptions, withResize } from '@plait/common';\n\ninterface TargetElementRef {\n    minWidth: number;\n    currentWidth: number;\n    path: Path;\n    textManage: TextManage;\n}\n\nexport const withNodeResize = (board: PlaitBoard) => {\n    let targetElementRef: TargetElementRef | null = null;\n    const options: WithResizeOptions<MindElement, null> = {\n        key: 'mind-node',\n        canResize: () => {\n            return !isDragging(board);\n        },\n        detect: (point: Point) => {\n            const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n            if (newTargetElement) {\n                return {\n                    element: newTargetElement,\n                    handle: null,\n                    cursorClass: ResizeCursorClass.ew\n                };\n            }\n            return null;\n        },\n        beforeResize: (resizeRef: ResizeRef<MindElement, null>) => {\n            targetElementRef = {\n                minWidth: NodeSpace.getNodeResizableMinWidth(board as PlaitMindBoard, resizeRef.element),\n                currentWidth: NodeSpace.getNodeDynamicWidth(board as PlaitMindBoard, resizeRef.element),\n                path: PlaitBoard.findPath(board, resizeRef.element),\n                textManage: MindElement.getTextManage(resizeRef.element)\n            };\n        },\n        onResize: (resizeRef: ResizeRef<MindElement, null>, resizeState: ResizeState) => {\n            const zoom = board.viewport.zoom;\n            let resizedWidth = targetElementRef!.currentWidth + resizeState.offsetX / zoom;\n            if (resizedWidth <= targetElementRef!.minWidth) {\n                resizedWidth = targetElementRef!.minWidth;\n            }\n            const newTarget = PlaitNode.get<MindElement>(board, targetElementRef!.path);\n            if (newTarget && NodeSpace.getNodeTopicMinWidth(board as PlaitMindBoard, newTarget) !== resizedWidth) {\n                targetElementRef!.textManage.updateRectangleWidth(resizedWidth);\n                const { height } = targetElementRef!.textManage.getSize();\n                MindTransforms.setNodeManualWidth(board as PlaitMindBoard, newTarget, resizedWidth * zoom, height);\n            }\n        },\n        afterResize: (resizeRef: ResizeRef<MindElement, null>) => {\n            targetElementRef = null;\n        }\n    };\n    withResize<MindElement, null>(board, options);\n    return board;\n};\n\nexport const getSelectedTarget = (board: PlaitMindBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value)) as MindElement[];\n    if (selectedElements.length > 0) {\n        const target = selectedElements.find(value => {\n            const rectangle = getResizeActiveRectangle(board, value);\n            return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;\n        });\n        return target ? target : null;\n    }\n    return null;\n};\n\nexport const getResizeActiveRectangle = (board: PlaitBoard, element: MindElement): RectangleClient => {\n    const node = MindElement.getNode(element);\n    const rectangle = getRectangleByNode(node);\n    return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };\n};\n"]}
@@ -1,10 +1,10 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { Component, ChangeDetectionStrategy, NgZone, Directive, Input, HostListener } from '@angular/core';
3
- import { DefaultThemeColor, ColorfulThemeColor, SoftThemeColor, RetroThemeColor, DarkThemeColor, StarryThemeColor, PlaitElement, PlaitNode, Path, isNullOrUndefined, PlaitBoard, distanceBetweenPointAndRectangle, RectangleClient, getSelectedElements, idCreator, Transforms, clearSelectedElement, addSelectedElement, depthFirstRecursion, getIsRecursionFunc, drawRoundRectangle, drawLinearPath, drawBezierPath, createG, updateForeignObject, getRectangleByElements, NODE_TO_PARENT, createForeignObject, setStrokeLinecap, ACTIVE_STROKE_WIDTH, createText, PlaitPointerType, NODE_TO_INDEX, PlaitChildrenElementComponent, isMainPointer, transformPoint, toPoint, getHitElementByPoint, distanceBetweenPointAndPoint, CoreTransforms, BOARD_TO_HOST, BoardTransforms, throttleRAF, removeSelectedElement, PlaitHistoryBoard, temporaryDisableSelection, hotkeys, setClipboardDataByMedia, getClipboardDataByMedia, ResizeCursorClass, preventTouchMove, PRESS_AND_MOVE_BUFFER, MERGING, setClipboardData, setClipboardDataByText, getDataFromClipboard, PlaitPluginKey } from '@plait/core';
3
+ import { DefaultThemeColor, ColorfulThemeColor, SoftThemeColor, RetroThemeColor, DarkThemeColor, StarryThemeColor, PlaitElement, PlaitNode, Path, isNullOrUndefined, PlaitBoard, distanceBetweenPointAndRectangle, RectangleClient, getSelectedElements, idCreator, Transforms, clearSelectedElement, addSelectedElement, depthFirstRecursion, getIsRecursionFunc, drawRoundRectangle, drawLinearPath, drawBezierPath, createG, updateForeignObject, getRectangleByElements, NODE_TO_PARENT, createForeignObject, setStrokeLinecap, ACTIVE_STROKE_WIDTH, createText, PlaitPointerType, NODE_TO_INDEX, PlaitChildrenElementComponent, isMainPointer, transformPoint, toPoint, getHitElementByPoint, distanceBetweenPointAndPoint, CoreTransforms, BOARD_TO_HOST, BoardTransforms, throttleRAF, removeSelectedElement, PlaitHistoryBoard, temporaryDisableSelection, hotkeys, setClipboardDataByMedia, getClipboardDataByMedia, ResizeCursorClass, setClipboardData, setClipboardDataByText, getDataFromClipboard, PlaitPluginKey } from '@plait/core';
4
4
  import { MindLayoutType, AbstractNode, isIndentedLayout, isHorizontalLayout, isHorizontalLogicLayout, ConnectingPosition, getNonAbstractChildren, isStandardLayout, isLeftLayout, isRightLayout, isVerticalLogicLayout, isTopLayout, isBottomLayout, getCorrectStartEnd, getAbstractLayout, GlobalLayout } from '@plait/layouts';
5
5
  import { PlaitMarkEditor, MarkTypes, DEFAULT_FONT_SIZE, TEXT_DEFAULT_HEIGHT, buildText, getTextSize, TextManage, ExitOrigin, getTextFromClipboard } from '@plait/text';
6
6
  import { fromEvent, Subject } from 'rxjs';
7
- import { RESIZE_HANDLE_DIAMETER, getRectangleResizeHandleRefs, addElementOfFocusedImage, removeElementOfFocusedImage, Generator, CommonPluginElement, ImageGenerator, WithTextPluginKey, isDrawingMode, isDndMode, setCreationMode, BoardCreationMode, isExpandHotkey, isTabHotkey, isEnterHotkey, isVirtualKey, isDelete, isSpaceHotkey, getElementOfFocusedImage, MediaKeys, acceptImageTypes, buildImage, ResizeHandle, withResize } from '@plait/common';
7
+ import { RESIZE_HANDLE_DIAMETER, getRectangleResizeHandleRefs, addElementOfFocusedImage, removeElementOfFocusedImage, Generator, CommonPluginElement, ImageGenerator, WithTextPluginKey, isDrawingMode, isDndMode, setCreationMode, BoardCreationMode, isExpandHotkey, isTabHotkey, isEnterHotkey, isVirtualKey, isDelete, isSpaceHotkey, getElementOfFocusedImage, MediaKeys, acceptImageTypes, buildImage, withResize, ResizeHandle } from '@plait/common';
8
8
  import { Node as Node$1, Path as Path$1 } from 'slate';
9
9
  import { pointsOnBezierCurves } from 'points-on-curve';
10
10
  import { take, filter } from 'rxjs/operators';
@@ -3762,117 +3762,51 @@ const withNodeImage = (board) => {
3762
3762
  };
3763
3763
 
3764
3764
  const withNodeResize = (board) => {
3765
- const { pointerDown, pointerMove, globalPointerUp } = board;
3766
- let targetElement = null;
3767
3765
  let targetElementRef = null;
3768
- let startPoint = null;
3769
- board.pointerDown = (event) => {
3770
- if (PlaitBoard.isReadonly(board)) {
3771
- pointerDown(event);
3772
- return;
3773
- }
3774
- const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
3775
- const newTargetElement = getSelectedTarget(board, point);
3776
- if (newTargetElement) {
3777
- PlaitBoard.getBoardContainer(board).classList.add(ResizeCursorClass['ew']);
3778
- targetElement = newTargetElement;
3779
- startPoint = [event.x, event.y];
3780
- preventTouchMove(board, event, true);
3781
- }
3782
- pointerDown(event);
3783
- };
3784
- board.pointerMove = (event) => {
3785
- if (PlaitBoard.isReadonly(board) || PlaitBoard.hasBeenTextEditing(board)) {
3786
- pointerMove(event);
3787
- return;
3788
- }
3789
- if (startPoint && targetElement && !isMindNodeResizing(board)) {
3790
- // prevent text from being selected
3791
- event.preventDefault();
3792
- const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
3793
- const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
3794
- if (distance > PRESS_AND_MOVE_BUFFER) {
3795
- addResizing(board, targetElement);
3796
- targetElementRef = {
3797
- minWidth: NodeSpace.getNodeResizableMinWidth(board, targetElement),
3798
- currentWidth: NodeSpace.getNodeDynamicWidth(board, targetElement),
3799
- path: PlaitBoard.findPath(board, targetElement),
3800
- textManage: MindElement.getTextManage(targetElement)
3766
+ const options = {
3767
+ key: 'mind-node',
3768
+ canResize: () => {
3769
+ return !isDragging(board);
3770
+ },
3771
+ detect: (point) => {
3772
+ const newTargetElement = getSelectedTarget(board, point);
3773
+ if (newTargetElement) {
3774
+ return {
3775
+ element: newTargetElement,
3776
+ handle: null,
3777
+ cursorClass: ResizeCursorClass.ew
3801
3778
  };
3802
- MERGING.set(board, true);
3803
3779
  }
3804
- }
3805
- if (isMindNodeResizing(board) && startPoint && targetElementRef) {
3806
- // prevent text from being selected
3807
- event.preventDefault();
3808
- preventTouchMove(board, event, true);
3809
- throttleRAF(() => {
3810
- if (!startPoint) {
3811
- return;
3812
- }
3813
- const endPoint = [event.x, event.y];
3814
- const offsetX = endPoint[0] - startPoint[0];
3815
- const zoom = board.viewport.zoom;
3816
- let resizedWidth = targetElementRef.currentWidth + offsetX / zoom;
3817
- if (resizedWidth <= targetElementRef.minWidth) {
3818
- resizedWidth = targetElementRef.minWidth;
3819
- }
3820
- const newTarget = PlaitNode.get(board, targetElementRef.path);
3821
- if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
3822
- targetElementRef.textManage.updateRectangleWidth(resizedWidth);
3823
- const { height } = targetElementRef.textManage.getSize();
3824
- MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
3825
- }
3826
- });
3827
- return;
3828
- }
3829
- else {
3830
- // press and start drag when node is non selected
3831
- if (!isDragging(board)) {
3832
- const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
3833
- const newTargetElement = getSelectedTarget(board, point);
3834
- if (newTargetElement) {
3835
- PlaitBoard.getBoardContainer(board).classList.add(`mind-${ResizeCursorClass['ew']}`);
3836
- }
3837
- else {
3838
- PlaitBoard.getBoardContainer(board).classList.remove(`mind-${ResizeCursorClass['ew']}`);
3839
- }
3780
+ return null;
3781
+ },
3782
+ beforeResize: (resizeRef) => {
3783
+ targetElementRef = {
3784
+ minWidth: NodeSpace.getNodeResizableMinWidth(board, resizeRef.element),
3785
+ currentWidth: NodeSpace.getNodeDynamicWidth(board, resizeRef.element),
3786
+ path: PlaitBoard.findPath(board, resizeRef.element),
3787
+ textManage: MindElement.getTextManage(resizeRef.element)
3788
+ };
3789
+ },
3790
+ onResize: (resizeRef, resizeState) => {
3791
+ const zoom = board.viewport.zoom;
3792
+ let resizedWidth = targetElementRef.currentWidth + resizeState.offsetX / zoom;
3793
+ if (resizedWidth <= targetElementRef.minWidth) {
3794
+ resizedWidth = targetElementRef.minWidth;
3840
3795
  }
3841
- }
3842
- pointerMove(event);
3843
- };
3844
- board.globalPointerUp = (event) => {
3845
- globalPointerUp(event);
3846
- if (isMindNodeResizing(board) || targetElement) {
3847
- targetElement && removeResizing(board, targetElement);
3796
+ const newTarget = PlaitNode.get(board, targetElementRef.path);
3797
+ if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
3798
+ targetElementRef.textManage.updateRectangleWidth(resizedWidth);
3799
+ const { height } = targetElementRef.textManage.getSize();
3800
+ MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
3801
+ }
3802
+ },
3803
+ afterResize: (resizeRef) => {
3848
3804
  targetElementRef = null;
3849
- targetElement = null;
3850
- startPoint = null;
3851
- MERGING.set(board, false);
3852
- preventTouchMove(board, event, false);
3853
3805
  }
3854
3806
  };
3807
+ withResize(board, options);
3855
3808
  return board;
3856
3809
  };
3857
- const IS_MIND_NODE_RESIZING = new WeakMap();
3858
- const isMindNodeResizing = (board) => {
3859
- return !!IS_MIND_NODE_RESIZING.get(board);
3860
- };
3861
- const addResizing = (board, element) => {
3862
- PlaitBoard.getBoardContainer(board).classList.add('mind-node-resizing');
3863
- const component = PlaitElement.getComponent(element);
3864
- component.g.classList.add('resizing');
3865
- IS_MIND_NODE_RESIZING.set(board, true);
3866
- };
3867
- const removeResizing = (board, element) => {
3868
- PlaitBoard.getBoardContainer(board).classList.remove('mind-node-resizing');
3869
- PlaitBoard.getBoardContainer(board).classList.remove(ResizeCursorClass['ew']);
3870
- const component = PlaitElement.getComponent(element);
3871
- if (component && component.g) {
3872
- component.g.classList.remove('resizing');
3873
- }
3874
- IS_MIND_NODE_RESIZING.set(board, false);
3875
- };
3876
3810
  const getSelectedTarget = (board, point) => {
3877
3811
  const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value));
3878
3812
  if (selectedElements.length > 0) {