@plait/mind 0.77.3 → 0.78.0-next.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.
- package/fesm2022/plait-mind.mjs +2 -2
- package/fesm2022/plait-mind.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/abstract-node.mjs +0 -5
- package/esm2022/constants/default.mjs +0 -17
- package/esm2022/constants/index.mjs +0 -5
- package/esm2022/constants/node-style.mjs +0 -19
- package/esm2022/constants/node-topic-style.mjs +0 -7
- package/esm2022/constants/theme.mjs +0 -73
- package/esm2022/emoji/emoji-base.component.mjs +0 -6
- package/esm2022/emoji/index.mjs +0 -3
- package/esm2022/emoji/with-emoji.mjs +0 -8
- package/esm2022/generators/node-active.generator.mjs +0 -46
- package/esm2022/generators/node-collapse.generator.mjs +0 -108
- package/esm2022/generators/node-emojis.generator.mjs +0 -63
- package/esm2022/generators/node-plus.generator.mjs +0 -100
- package/esm2022/generators/node-shape.generator.mjs +0 -22
- package/esm2022/interfaces/element-data.mjs +0 -2
- package/esm2022/interfaces/element.mjs +0 -103
- package/esm2022/interfaces/index.mjs +0 -8
- package/esm2022/interfaces/layout.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -14
- package/esm2022/interfaces/options.mjs +0 -2
- package/esm2022/interfaces/pointer.mjs +0 -5
- package/esm2022/interfaces/theme-color.mjs +0 -57
- package/esm2022/interfaces/types.mjs +0 -13
- package/esm2022/mind-node.component.mjs +0 -193
- package/esm2022/mind.component.mjs +0 -34
- package/esm2022/plait-mind.mjs +0 -5
- package/esm2022/plugins/with-abstract-resize.board.mjs +0 -12
- package/esm2022/plugins/with-abstract-resize.mjs +0 -112
- package/esm2022/plugins/with-mind-create.mjs +0 -104
- package/esm2022/plugins/with-mind-extend.mjs +0 -7
- package/esm2022/plugins/with-mind-fragment.mjs +0 -101
- package/esm2022/plugins/with-mind-hotkey.mjs +0 -62
- package/esm2022/plugins/with-mind.board.mjs +0 -2
- package/esm2022/plugins/with-mind.mjs +0 -148
- package/esm2022/plugins/with-node-dnd.mjs +0 -176
- package/esm2022/plugins/with-node-hover-hit-test.mjs +0 -23
- package/esm2022/plugins/with-node-image-resize.mjs +0 -46
- package/esm2022/plugins/with-node-image.mjs +0 -113
- package/esm2022/plugins/with-node-resize.mjs +0 -69
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/queries/get-available-sublayouts-by-element.mjs +0 -23
- package/esm2022/queries/get-branch-layouts.mjs +0 -18
- package/esm2022/queries/get-correct-layout-by-element.mjs +0 -48
- package/esm2022/queries/get-layout-by-element.mjs +0 -18
- package/esm2022/queries/index.mjs +0 -11
- package/esm2022/transforms/abstract-node.mjs +0 -73
- package/esm2022/transforms/emoji.mjs +0 -41
- package/esm2022/transforms/image.mjs +0 -31
- package/esm2022/transforms/index.mjs +0 -30
- package/esm2022/transforms/layout.mjs +0 -19
- package/esm2022/transforms/node.mjs +0 -99
- package/esm2022/transforms/property.mjs +0 -34
- package/esm2022/utils/abstract/common.mjs +0 -170
- package/esm2022/utils/abstract/resize.mjs +0 -194
- package/esm2022/utils/clipboard.mjs +0 -108
- package/esm2022/utils/common.mjs +0 -26
- package/esm2022/utils/dnd/common.mjs +0 -59
- package/esm2022/utils/dnd/detector.mjs +0 -176
- package/esm2022/utils/draw/abstract-outline.mjs +0 -118
- package/esm2022/utils/draw/node-dnd.mjs +0 -164
- package/esm2022/utils/draw/node-link/abstract-link.mjs +0 -60
- package/esm2022/utils/draw/node-link/draw-link.mjs +0 -9
- package/esm2022/utils/draw/node-link/indented-link.mjs +0 -46
- package/esm2022/utils/draw/node-link/logic-link.mjs +0 -76
- package/esm2022/utils/draw/node-shape.mjs +0 -26
- package/esm2022/utils/index.mjs +0 -17
- package/esm2022/utils/layout.mjs +0 -105
- package/esm2022/utils/mind.mjs +0 -98
- package/esm2022/utils/node/adjust-node.mjs +0 -36
- package/esm2022/utils/node/common.mjs +0 -15
- package/esm2022/utils/node/create-node.mjs +0 -46
- package/esm2022/utils/node/dynamic-width.mjs +0 -14
- package/esm2022/utils/node/image.mjs +0 -15
- package/esm2022/utils/node/index.mjs +0 -6
- package/esm2022/utils/node/right-node-count.mjs +0 -45
- package/esm2022/utils/node-hover/extend.mjs +0 -50
- package/esm2022/utils/node-style/branch.mjs +0 -63
- package/esm2022/utils/node-style/common.mjs +0 -4
- package/esm2022/utils/node-style/index.mjs +0 -4
- package/esm2022/utils/node-style/shape.mjs +0 -37
- package/esm2022/utils/normalize.mjs +0 -40
- package/esm2022/utils/path.mjs +0 -12
- package/esm2022/utils/point-placement.mjs +0 -119
- package/esm2022/utils/position/emoji.mjs +0 -31
- package/esm2022/utils/position/image.mjs +0 -36
- package/esm2022/utils/position/index.mjs +0 -5
- package/esm2022/utils/position/node.mjs +0 -36
- package/esm2022/utils/position/topic.mjs +0 -16
- package/esm2022/utils/space/emoji.mjs +0 -20
- package/esm2022/utils/space/index.mjs +0 -4
- package/esm2022/utils/space/layout-options.mjs +0 -69
- package/esm2022/utils/space/node-space.mjs +0 -134
- package/esm2022/utils/weak-maps.mjs +0 -2
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
import { PlaitElement, RectangleClient, getRectangleByElements, getSelectedElements } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../../interfaces';
|
|
3
|
-
import { AbstractNode, isHorizontalLayout } from '@plait/layouts';
|
|
4
|
-
import { ABSTRACT_HANDLE_MASK_WIDTH, ABSTRACT_INCLUDED_OUTLINE_OFFSET } from '../../constants/abstract-node';
|
|
5
|
-
import { MindQueries } from '../../queries';
|
|
6
|
-
import { getCorrectStartEnd } from '@plait/layouts';
|
|
7
|
-
import { AbstractHandlePosition } from '../../plugins/with-abstract-resize.board';
|
|
8
|
-
import { NodeActiveGenerator } from '../../generators/node-active.generator';
|
|
9
|
-
export const getRectangleByResizingLocation = (abstractRectangle, location, activeHandlePosition, isHorizontal) => {
|
|
10
|
-
if (isHorizontal) {
|
|
11
|
-
if (activeHandlePosition === AbstractHandlePosition.start) {
|
|
12
|
-
return {
|
|
13
|
-
...abstractRectangle,
|
|
14
|
-
y: location,
|
|
15
|
-
height: abstractRectangle.height + abstractRectangle.y - location
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
return {
|
|
20
|
-
...abstractRectangle,
|
|
21
|
-
height: location - abstractRectangle.y
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
if (activeHandlePosition === AbstractHandlePosition.start) {
|
|
27
|
-
return {
|
|
28
|
-
...abstractRectangle,
|
|
29
|
-
x: location,
|
|
30
|
-
width: abstractRectangle.width + abstractRectangle.x - location
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
return {
|
|
35
|
-
...abstractRectangle,
|
|
36
|
-
width: location - abstractRectangle.x
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
export const getLocationScope = (board, handlePosition, parentChildren, element, parent, isHorizontal) => {
|
|
42
|
-
const node = MindElement.getNode(element);
|
|
43
|
-
const { start, end } = getCorrectStartEnd(node.origin, parent);
|
|
44
|
-
const startNode = parentChildren[start];
|
|
45
|
-
const endNode = parentChildren[end];
|
|
46
|
-
if (handlePosition === AbstractHandlePosition.start) {
|
|
47
|
-
const abstractNode = parentChildren.filter(child => AbstractNode.isAbstract(child) && child.end < element.start);
|
|
48
|
-
let minNode;
|
|
49
|
-
if (abstractNode.length) {
|
|
50
|
-
const index = abstractNode
|
|
51
|
-
.map(node => {
|
|
52
|
-
const { end } = getCorrectStartEnd(node, parent);
|
|
53
|
-
return end;
|
|
54
|
-
})
|
|
55
|
-
.sort((a, b) => b - a)[0];
|
|
56
|
-
minNode = parentChildren[index + 1];
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
minNode = parentChildren[0];
|
|
60
|
-
}
|
|
61
|
-
const minNodeRectangle = getRectangleByElements(board, [minNode], true);
|
|
62
|
-
const endNodeRectangle = getRectangleByElements(board, [endNode], false);
|
|
63
|
-
if (isHorizontal) {
|
|
64
|
-
return {
|
|
65
|
-
max: endNodeRectangle.y - ABSTRACT_INCLUDED_OUTLINE_OFFSET,
|
|
66
|
-
min: minNodeRectangle.y - ABSTRACT_INCLUDED_OUTLINE_OFFSET
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
return {
|
|
71
|
-
max: endNodeRectangle.x - ABSTRACT_INCLUDED_OUTLINE_OFFSET,
|
|
72
|
-
min: minNodeRectangle.x - ABSTRACT_INCLUDED_OUTLINE_OFFSET
|
|
73
|
-
};
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
const abstractNode = parentChildren.filter(child => AbstractNode.isAbstract(child) && child.start > element.end);
|
|
78
|
-
let maxNode;
|
|
79
|
-
if (abstractNode.length) {
|
|
80
|
-
const index = abstractNode
|
|
81
|
-
.map(node => {
|
|
82
|
-
const { start } = getCorrectStartEnd(node, parent);
|
|
83
|
-
return start;
|
|
84
|
-
})
|
|
85
|
-
.sort((a, b) => a - b)[0];
|
|
86
|
-
maxNode = parentChildren[index - 1];
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
const children = parentChildren.filter(child => !AbstractNode.isAbstract(child));
|
|
90
|
-
maxNode = parentChildren[children.length - 1];
|
|
91
|
-
}
|
|
92
|
-
const maxNodeRectangle = getRectangleByElements(board, [maxNode], true);
|
|
93
|
-
const startNodeRectangle = getRectangleByElements(board, [startNode], false);
|
|
94
|
-
if (isHorizontal) {
|
|
95
|
-
return {
|
|
96
|
-
max: maxNodeRectangle.y + maxNodeRectangle.height + ABSTRACT_INCLUDED_OUTLINE_OFFSET,
|
|
97
|
-
min: startNodeRectangle.y + startNodeRectangle.height + ABSTRACT_INCLUDED_OUTLINE_OFFSET
|
|
98
|
-
};
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
return {
|
|
102
|
-
max: maxNodeRectangle.x + maxNodeRectangle.width + ABSTRACT_INCLUDED_OUTLINE_OFFSET,
|
|
103
|
-
min: startNodeRectangle.x + startNodeRectangle.width + ABSTRACT_INCLUDED_OUTLINE_OFFSET
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
};
|
|
108
|
-
export const getHitAbstractHandle = (board, element, point) => {
|
|
109
|
-
const nodeLayout = MindQueries.getCorrectLayoutByElement(board, element);
|
|
110
|
-
const isHorizontal = isHorizontalLayout(nodeLayout);
|
|
111
|
-
const parentElement = MindElement.getParent(element);
|
|
112
|
-
const includedElements = parentElement.children.slice(element.start, element.end + 1);
|
|
113
|
-
let abstractRectangle = getRectangleByElements(board, includedElements, true);
|
|
114
|
-
abstractRectangle = RectangleClient.getOutlineRectangle(abstractRectangle, -ABSTRACT_INCLUDED_OUTLINE_OFFSET);
|
|
115
|
-
const startHandleRec = getAbstractHandleRectangle(abstractRectangle, isHorizontal, AbstractHandlePosition.start);
|
|
116
|
-
const endHandleRec = getAbstractHandleRectangle(abstractRectangle, isHorizontal, AbstractHandlePosition.end);
|
|
117
|
-
const pointRec = RectangleClient.getRectangleByPoints([point, point]);
|
|
118
|
-
if (RectangleClient.isHit(pointRec, startHandleRec))
|
|
119
|
-
return AbstractHandlePosition.start;
|
|
120
|
-
if (RectangleClient.isHit(pointRec, endHandleRec))
|
|
121
|
-
return AbstractHandlePosition.end;
|
|
122
|
-
return undefined;
|
|
123
|
-
};
|
|
124
|
-
export const getAbstractHandleRectangle = (rectangle, isHorizontal, position) => {
|
|
125
|
-
let result;
|
|
126
|
-
if (position === AbstractHandlePosition.start) {
|
|
127
|
-
const location = isHorizontal ? rectangle.y : rectangle.x;
|
|
128
|
-
result = getRectangleByResizingLocation(rectangle, location + ABSTRACT_HANDLE_MASK_WIDTH / 2, AbstractHandlePosition.end, isHorizontal);
|
|
129
|
-
result = getRectangleByResizingLocation(result, location - ABSTRACT_HANDLE_MASK_WIDTH / 2, position, isHorizontal);
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
const location = isHorizontal ? rectangle.y + rectangle.height : rectangle.x + rectangle.width;
|
|
133
|
-
result = getRectangleByResizingLocation(rectangle, location - ABSTRACT_HANDLE_MASK_WIDTH / 2, AbstractHandlePosition.start, isHorizontal);
|
|
134
|
-
result = getRectangleByResizingLocation(result, location + ABSTRACT_HANDLE_MASK_WIDTH / 2, position, isHorizontal);
|
|
135
|
-
}
|
|
136
|
-
return result;
|
|
137
|
-
};
|
|
138
|
-
export function findLocationLeftIndex(board, parentChildren, location, isHorizontal) {
|
|
139
|
-
const children = parentChildren.filter(child => {
|
|
140
|
-
return !AbstractNode.isAbstract(child);
|
|
141
|
-
});
|
|
142
|
-
const recArray = children.map(child => {
|
|
143
|
-
return getRectangleByElements(board, [child], false);
|
|
144
|
-
});
|
|
145
|
-
const firstRec = getRectangleByElements(board, [children[0]], true);
|
|
146
|
-
const fakeLeftRec = {
|
|
147
|
-
x: firstRec.x - firstRec.width,
|
|
148
|
-
y: firstRec.y - firstRec.height,
|
|
149
|
-
width: firstRec.width,
|
|
150
|
-
height: firstRec.height
|
|
151
|
-
};
|
|
152
|
-
const lastRec = getRectangleByElements(board, [children[children.length - 1]], true);
|
|
153
|
-
const fakeRightRec = {
|
|
154
|
-
x: lastRec.x + lastRec.width,
|
|
155
|
-
y: lastRec.y + lastRec.height,
|
|
156
|
-
width: lastRec.width,
|
|
157
|
-
height: lastRec.height
|
|
158
|
-
};
|
|
159
|
-
recArray.push(fakeRightRec);
|
|
160
|
-
recArray.unshift(fakeLeftRec);
|
|
161
|
-
for (let i = 0; i < recArray.length - 1; i++) {
|
|
162
|
-
const recXOrY = isHorizontal ? recArray[i].y : recArray[i].x;
|
|
163
|
-
const recWidthOrHeight = isHorizontal ? recArray[i].height : recArray[i].width;
|
|
164
|
-
if (location >= recXOrY + recWidthOrHeight / 2 &&
|
|
165
|
-
location <= recArray[i + 1][isHorizontal ? 'y' : 'x'] + recArray[i + 1][isHorizontal ? 'height' : 'width'] / 2) {
|
|
166
|
-
return i - 1;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
return 0;
|
|
170
|
-
}
|
|
171
|
-
export function handleTouchedAbstract(board, touchedAbstract, endPoint) {
|
|
172
|
-
let touchedHandle;
|
|
173
|
-
const abstract = getSelectedElements(board).filter(element => AbstractNode.isAbstract(element)).find(element => {
|
|
174
|
-
touchedHandle = getHitAbstractHandle(board, element, endPoint);
|
|
175
|
-
return touchedHandle;
|
|
176
|
-
});
|
|
177
|
-
if (touchedAbstract === abstract) {
|
|
178
|
-
return touchedAbstract;
|
|
179
|
-
}
|
|
180
|
-
if (touchedAbstract) {
|
|
181
|
-
const ref = PlaitElement.getElementRef(touchedAbstract);
|
|
182
|
-
const activeGenerator = ref.getGenerator(NodeActiveGenerator.key);
|
|
183
|
-
activeGenerator.updateAbstractOutline(touchedAbstract);
|
|
184
|
-
touchedAbstract = undefined;
|
|
185
|
-
}
|
|
186
|
-
if (abstract) {
|
|
187
|
-
touchedAbstract = abstract;
|
|
188
|
-
const ref = PlaitElement.getElementRef(touchedAbstract);
|
|
189
|
-
const activeGenerator = ref.getGenerator(NodeActiveGenerator.key);
|
|
190
|
-
activeGenerator.updateAbstractOutline(touchedAbstract, touchedHandle);
|
|
191
|
-
}
|
|
192
|
-
return touchedAbstract;
|
|
193
|
-
}
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../../../packages/mind/src/utils/abstract/resize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient, getRectangleByElements, getSelectedElements } from '@plait/core';\nimport { MindElement } from '../../interfaces';\nimport { AbstractNode, LayoutNode, MindLayoutType, isHorizontalLayout } from '@plait/layouts';\nimport { ABSTRACT_HANDLE_MASK_WIDTH, ABSTRACT_INCLUDED_OUTLINE_OFFSET } from '../../constants/abstract-node';\nimport { MindQueries } from '../../queries';\nimport { getCorrectStartEnd } from '@plait/layouts';\nimport { MindNodeComponent } from '../../mind-node.component';\nimport { AbstractHandlePosition } from '../../plugins/with-abstract-resize.board';\nimport { PlaitCommonElementRef } from '@plait/common';\nimport { NodeActiveGenerator } from '../../generators/node-active.generator';\n\nexport const getRectangleByResizingLocation = (\n    abstractRectangle: RectangleClient,\n    location: number,\n    activeHandlePosition: AbstractHandlePosition,\n    isHorizontal: boolean\n) => {\n    if (isHorizontal) {\n        if (activeHandlePosition === AbstractHandlePosition.start) {\n            return {\n                ...abstractRectangle,\n                y: location,\n                height: abstractRectangle.height + abstractRectangle.y - location\n            };\n        } else {\n            return {\n                ...abstractRectangle,\n                height: location - abstractRectangle.y\n            };\n        }\n    } else {\n        if (activeHandlePosition === AbstractHandlePosition.start) {\n            return {\n                ...abstractRectangle,\n                x: location,\n                width: abstractRectangle.width + abstractRectangle.x - location\n            };\n        } else {\n            return {\n                ...abstractRectangle,\n                width: location - abstractRectangle.x\n            };\n        }\n    }\n};\n\nexport const getLocationScope = (\n    board: PlaitBoard,\n    handlePosition: AbstractHandlePosition,\n    parentChildren: MindElement[],\n    element: MindElement,\n    parent: LayoutNode,\n    isHorizontal: boolean\n) => {\n    const node = (MindElement.getNode(element) as unknown) as LayoutNode;\n    const { start, end } = getCorrectStartEnd(node.origin as AbstractNode, parent);\n\n    const startNode = parentChildren[start];\n    const endNode = parentChildren[end];\n\n    if (handlePosition === AbstractHandlePosition.start) {\n        const abstractNode = parentChildren.filter(child => AbstractNode.isAbstract(child) && child.end < element.start!);\n        let minNode;\n\n        if (abstractNode.length) {\n            const index = abstractNode\n                .map(node => {\n                    const { end } = getCorrectStartEnd(node as AbstractNode, parent);\n                    return end;\n                })\n                .sort((a, b) => b - a)[0];\n            minNode = parentChildren[index + 1];\n        } else {\n            minNode = parentChildren[0];\n        }\n\n        const minNodeRectangle = getRectangleByElements(board, [minNode], true);\n        const endNodeRectangle = getRectangleByElements(board, [endNode], false);\n\n        if (isHorizontal) {\n            return {\n                max: endNodeRectangle.y - ABSTRACT_INCLUDED_OUTLINE_OFFSET,\n                min: minNodeRectangle.y - ABSTRACT_INCLUDED_OUTLINE_OFFSET\n            };\n        } else {\n            return {\n                max: endNodeRectangle.x - ABSTRACT_INCLUDED_OUTLINE_OFFSET,\n                min: minNodeRectangle.x - ABSTRACT_INCLUDED_OUTLINE_OFFSET\n            };\n        }\n    } else {\n        const abstractNode = parentChildren.filter(child => AbstractNode.isAbstract(child) && child.start > element.end!);\n        let maxNode;\n\n        if (abstractNode.length) {\n            const index = abstractNode\n                .map(node => {\n                    const { start } = getCorrectStartEnd(node as AbstractNode, parent);\n                    return start;\n                })\n                .sort((a, b) => a - b)[0];\n            maxNode = parentChildren[index - 1];\n        } else {\n            const children = parentChildren.filter(child => !AbstractNode.isAbstract(child));\n            maxNode = parentChildren[children.length - 1];\n        }\n\n        const maxNodeRectangle = getRectangleByElements(board, [maxNode], true);\n        const startNodeRectangle = getRectangleByElements(board, [startNode], false);\n\n        if (isHorizontal) {\n            return {\n                max: maxNodeRectangle.y + maxNodeRectangle.height + ABSTRACT_INCLUDED_OUTLINE_OFFSET,\n                min: startNodeRectangle.y + startNodeRectangle.height + ABSTRACT_INCLUDED_OUTLINE_OFFSET\n            };\n        } else {\n            return {\n                max: maxNodeRectangle.x + maxNodeRectangle.width + ABSTRACT_INCLUDED_OUTLINE_OFFSET,\n                min: startNodeRectangle.x + startNodeRectangle.width + ABSTRACT_INCLUDED_OUTLINE_OFFSET\n            };\n        }\n    }\n};\n\nexport const getHitAbstractHandle = (board: PlaitBoard, element: MindElement, point: Point) => {\n    const nodeLayout = MindQueries.getCorrectLayoutByElement(board, element) as MindLayoutType;\n    const isHorizontal = isHorizontalLayout(nodeLayout);\n\n    const parentElement = MindElement.getParent(element);\n    const includedElements = parentElement.children.slice(element.start!, element.end! + 1);\n    let abstractRectangle = getRectangleByElements(board, includedElements, true);\n    abstractRectangle = RectangleClient.getOutlineRectangle(abstractRectangle, -ABSTRACT_INCLUDED_OUTLINE_OFFSET);\n\n    const startHandleRec = getAbstractHandleRectangle(abstractRectangle, isHorizontal, AbstractHandlePosition.start);\n    const endHandleRec = getAbstractHandleRectangle(abstractRectangle, isHorizontal, AbstractHandlePosition.end);\n\n    const pointRec = RectangleClient.getRectangleByPoints([point, point]);\n    if (RectangleClient.isHit(pointRec, startHandleRec)) return AbstractHandlePosition.start;\n    if (RectangleClient.isHit(pointRec, endHandleRec)) return AbstractHandlePosition.end;\n    return undefined;\n};\n\nexport const getAbstractHandleRectangle = (rectangle: RectangleClient, isHorizontal: boolean, position: AbstractHandlePosition) => {\n    let result;\n    if (position === AbstractHandlePosition.start) {\n        const location = isHorizontal ? rectangle.y : rectangle.x;\n\n        result = getRectangleByResizingLocation(\n            rectangle,\n            location + ABSTRACT_HANDLE_MASK_WIDTH / 2,\n            AbstractHandlePosition.end,\n            isHorizontal\n        );\n        result = getRectangleByResizingLocation(result, location - ABSTRACT_HANDLE_MASK_WIDTH / 2, position, isHorizontal);\n    } else {\n        const location = isHorizontal ? rectangle.y + rectangle.height : rectangle.x + rectangle.width;\n\n        result = getRectangleByResizingLocation(\n            rectangle,\n            location - ABSTRACT_HANDLE_MASK_WIDTH / 2,\n            AbstractHandlePosition.start,\n            isHorizontal\n        );\n        result = getRectangleByResizingLocation(result, location + ABSTRACT_HANDLE_MASK_WIDTH / 2, position, isHorizontal);\n    }\n    return result;\n};\n\nexport function findLocationLeftIndex(board: PlaitBoard, parentChildren: MindElement[], location: number, isHorizontal: boolean) {\n    const children = parentChildren.filter(child => {\n        return !AbstractNode.isAbstract(child);\n    });\n    const recArray = children.map(child => {\n        return getRectangleByElements(board, [child], false);\n    });\n\n    const firstRec = getRectangleByElements(board, [children[0]], true);\n    const fakeLeftRec = {\n        x: firstRec.x - firstRec.width,\n        y: firstRec.y - firstRec.height,\n        width: firstRec.width,\n        height: firstRec.height\n    };\n    const lastRec = getRectangleByElements(board, [children[children.length - 1]], true);\n    const fakeRightRec = {\n        x: lastRec.x + lastRec.width,\n        y: lastRec.y + lastRec.height,\n        width: lastRec.width,\n        height: lastRec.height\n    };\n\n    recArray.push(fakeRightRec);\n    recArray.unshift(fakeLeftRec);\n\n    for (let i = 0; i < recArray.length - 1; i++) {\n        const recXOrY = isHorizontal ? recArray[i].y : recArray[i].x;\n        const recWidthOrHeight = isHorizontal ? recArray[i].height : recArray[i].width;\n\n        if (\n            location >= recXOrY + recWidthOrHeight / 2 &&\n            location <= recArray[i + 1][isHorizontal ? 'y' : 'x'] + recArray[i + 1][isHorizontal ? 'height' : 'width'] / 2\n        ) {\n            return i - 1;\n        }\n    }\n    return 0;\n}\n\nexport function handleTouchedAbstract(board: PlaitBoard, touchedAbstract: MindElement | undefined, endPoint: Point) {\n    let touchedHandle;\n    const abstract = (getSelectedElements(board).filter(element => AbstractNode.isAbstract(element)) as MindElement[]).find(element => {\n        touchedHandle = getHitAbstractHandle(board, element as MindElement, endPoint);\n        return touchedHandle;\n    });\n\n    if (touchedAbstract === abstract) {\n        return touchedAbstract;\n    }\n\n    if (touchedAbstract) {\n        const ref = PlaitElement.getElementRef<PlaitCommonElementRef>(touchedAbstract);\n        const activeGenerator = ref.getGenerator<NodeActiveGenerator>(NodeActiveGenerator.key);\n        activeGenerator.updateAbstractOutline(touchedAbstract);\n        touchedAbstract = undefined;\n    }\n\n    if (abstract) {\n        touchedAbstract = abstract;\n        const ref = PlaitElement.getElementRef<PlaitCommonElementRef>(touchedAbstract);\n        const activeGenerator = ref.getGenerator<NodeActiveGenerator>(NodeActiveGenerator.key);\n        activeGenerator.updateAbstractOutline(touchedAbstract, touchedHandle);\n    }\n\n    return touchedAbstract;\n}\n"]}
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { getSelectedElements, PlaitBoard, Transforms, WritableClipboardOperationType } from '@plait/core';
|
|
2
|
-
import { MindElement, PlaitMind } from '../interfaces';
|
|
3
|
-
import { copyNewNode } from './mind';
|
|
4
|
-
import { getRectangleByNode } from './position/node';
|
|
5
|
-
import { AbstractNode, getNonAbstractChildren } from '@plait/layouts';
|
|
6
|
-
import { getRelativeStartEndByAbstractRef, getOverallAbstracts, getValidAbstractRefs } from './abstract/common';
|
|
7
|
-
import { createMindElement } from './node/create-node';
|
|
8
|
-
import { adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode } from './node/adjust-node';
|
|
9
|
-
import { findNewChildNodePath } from './path';
|
|
10
|
-
import { getFontSizeBySlateElement } from './space/node-space';
|
|
11
|
-
import { buildText } from '@plait/common';
|
|
12
|
-
import { getTopicSize } from './common';
|
|
13
|
-
export const buildClipboardData = (board, selectedElements, startPoint) => {
|
|
14
|
-
let result = [];
|
|
15
|
-
// get overall abstract
|
|
16
|
-
const overallAbstracts = getOverallAbstracts(board, selectedElements);
|
|
17
|
-
// get valid abstract refs
|
|
18
|
-
const validAbstractRefs = getValidAbstractRefs(board, [...selectedElements, ...overallAbstracts]);
|
|
19
|
-
// keep correct order
|
|
20
|
-
const newSelectedElements = selectedElements.filter((value) => !validAbstractRefs.find((ref) => ref.abstract === value));
|
|
21
|
-
newSelectedElements.push(...validAbstractRefs.map((value) => value.abstract));
|
|
22
|
-
const selectedMindNodes = newSelectedElements.map((value) => MindElement.getNode(value));
|
|
23
|
-
newSelectedElements.forEach((element, index) => {
|
|
24
|
-
// handle relative location
|
|
25
|
-
const nodeRectangle = getRectangleByNode(selectedMindNodes[index]);
|
|
26
|
-
const points = [[nodeRectangle.x - startPoint[0], nodeRectangle.y - startPoint[1]]];
|
|
27
|
-
// handle invalid abstract
|
|
28
|
-
const abstractRef = validAbstractRefs.find((ref) => ref.abstract === element);
|
|
29
|
-
if (AbstractNode.isAbstract(element) && abstractRef) {
|
|
30
|
-
const { start, end } = getRelativeStartEndByAbstractRef(abstractRef, newSelectedElements);
|
|
31
|
-
result.push({
|
|
32
|
-
...element,
|
|
33
|
-
points,
|
|
34
|
-
start,
|
|
35
|
-
end
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
if (AbstractNode.isAbstract(element)) {
|
|
40
|
-
let newElement = { ...element, points };
|
|
41
|
-
delete newElement.start;
|
|
42
|
-
delete newElement.end;
|
|
43
|
-
result.push(newElement);
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
result.push({
|
|
47
|
-
...element,
|
|
48
|
-
points: points
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
return result;
|
|
54
|
-
};
|
|
55
|
-
export const insertClipboardData = (board, elements, targetPoint, operationType) => {
|
|
56
|
-
let newElement, path;
|
|
57
|
-
const selectedElements = getSelectedElements(board);
|
|
58
|
-
let newELements = [];
|
|
59
|
-
const hasTargetParent = selectedElements.length === 1;
|
|
60
|
-
const targetParent = selectedElements[0];
|
|
61
|
-
const targetParentPath = targetParent && PlaitBoard.findPath(board, targetParent);
|
|
62
|
-
const nonAbstractChildrenLength = targetParent && getNonAbstractChildren(targetParent).length;
|
|
63
|
-
elements.forEach((item, index) => {
|
|
64
|
-
newElement = copyNewNode(item);
|
|
65
|
-
if (hasTargetParent && operationType !== WritableClipboardOperationType.duplicate) {
|
|
66
|
-
if (item.isRoot) {
|
|
67
|
-
newElement = adjustRootToNode(board, newElement);
|
|
68
|
-
const { width, height } = getTopicSizeByElement(newElement, targetParent);
|
|
69
|
-
newElement.width = width;
|
|
70
|
-
newElement.height = height;
|
|
71
|
-
}
|
|
72
|
-
// handle abstract start and end
|
|
73
|
-
if (AbstractNode.isAbstract(newElement)) {
|
|
74
|
-
newElement.start = newElement.start + nonAbstractChildrenLength;
|
|
75
|
-
newElement.end = newElement.end + nonAbstractChildrenLength;
|
|
76
|
-
}
|
|
77
|
-
path = [...targetParentPath, nonAbstractChildrenLength + index];
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
const point = [targetPoint[0] + item.points[0][0], targetPoint[1] + item.points[0][1]];
|
|
81
|
-
newElement.points = [point];
|
|
82
|
-
if (AbstractNode.isAbstract(item)) {
|
|
83
|
-
newElement = adjustAbstractToNode(newElement);
|
|
84
|
-
}
|
|
85
|
-
if (!item.isRoot) {
|
|
86
|
-
newElement = adjustNodeToRoot(board, newElement);
|
|
87
|
-
const { width, height } = getTopicSizeByElement(newElement);
|
|
88
|
-
newElement.width = width;
|
|
89
|
-
newElement.height = height;
|
|
90
|
-
}
|
|
91
|
-
path = [board.children.length];
|
|
92
|
-
}
|
|
93
|
-
newELements.push(newElement);
|
|
94
|
-
Transforms.insertNode(board, newElement, path);
|
|
95
|
-
return;
|
|
96
|
-
});
|
|
97
|
-
Transforms.addSelectionWithTemporaryElements(board, newELements);
|
|
98
|
-
};
|
|
99
|
-
export const insertClipboardText = (board, targetParent, text) => {
|
|
100
|
-
const { width, height } = getTopicSize(false, PlaitMind.isMind(targetParent), buildText(text));
|
|
101
|
-
const newElement = createMindElement(text, Math.max(width, getFontSizeBySlateElement(text)), height, {});
|
|
102
|
-
Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));
|
|
103
|
-
Transforms.addSelectionWithTemporaryElements(board, [newElement]);
|
|
104
|
-
};
|
|
105
|
-
export const getTopicSizeByElement = (element, parentElement) => {
|
|
106
|
-
return getTopicSize(PlaitMind.isMind(element), (parentElement && PlaitMind.isMind(parentElement)) || false, element.data.topic, element.manualWidth);
|
|
107
|
-
};
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { getSelectedElements, Path, PlaitBoard, PlaitElement, Point, Transforms, WritableClipboardOperationType } from '@plait/core';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { copyNewNode } from './mind';\nimport { getRectangleByNode } from './position/node';\nimport { AbstractNode, getNonAbstractChildren } from '@plait/layouts';\nimport { getRelativeStartEndByAbstractRef, getOverallAbstracts, getValidAbstractRefs } from './abstract/common';\nimport { createMindElement } from './node/create-node';\nimport { adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode } from './node/adjust-node';\nimport { Element } from 'slate';\nimport { findNewChildNodePath } from './path';\nimport { PlaitMindBoard } from '../plugins/with-mind.board';\nimport { getFontSizeBySlateElement } from './space/node-space';\nimport { buildText } from '@plait/common';\nimport { getTopicSize } from './common';\n\nexport const buildClipboardData = (board: PlaitBoard, selectedElements: MindElement[], startPoint: Point) => {\n    let result: MindElement[] = [];\n\n    // get overall abstract\n    const overallAbstracts = getOverallAbstracts(board, selectedElements) as MindElement[];\n    // get valid abstract refs\n    const validAbstractRefs = getValidAbstractRefs(board, [...selectedElements, ...overallAbstracts]);\n\n    // keep correct order\n    const newSelectedElements = selectedElements.filter((value) => !validAbstractRefs.find((ref) => ref.abstract === value));\n    newSelectedElements.push(...validAbstractRefs.map((value) => value.abstract));\n\n    const selectedMindNodes = newSelectedElements.map((value) => MindElement.getNode(value));\n    newSelectedElements.forEach((element, index) => {\n        // handle relative location\n        const nodeRectangle = getRectangleByNode(selectedMindNodes[index]);\n        const points = [[nodeRectangle.x - startPoint[0], nodeRectangle.y - startPoint[1]]] as Point[];\n\n        // handle invalid abstract\n        const abstractRef = validAbstractRefs.find((ref) => ref.abstract === element);\n        if (AbstractNode.isAbstract(element) && abstractRef) {\n            const { start, end } = getRelativeStartEndByAbstractRef(abstractRef, newSelectedElements);\n            result.push({\n                ...element,\n                points,\n                start,\n                end\n            });\n        } else {\n            if (AbstractNode.isAbstract(element)) {\n                let newElement = { ...element, points } as MindElement;\n                delete newElement.start;\n                delete newElement.end;\n                result.push(newElement);\n            } else {\n                result.push({\n                    ...element,\n                    points: points\n                });\n            }\n        }\n    });\n    return result;\n};\n\nexport const insertClipboardData = (\n    board: PlaitMindBoard,\n    elements: PlaitElement[],\n    targetPoint: Point,\n    operationType?: WritableClipboardOperationType\n) => {\n    let newElement: MindElement, path: Path;\n    const selectedElements = getSelectedElements(board);\n    let newELements: PlaitElement[] = [];\n\n    const hasTargetParent = selectedElements.length === 1;\n    const targetParent = selectedElements[0];\n    const targetParentPath = targetParent && PlaitBoard.findPath(board, targetParent);\n    const nonAbstractChildrenLength = targetParent && getNonAbstractChildren(targetParent).length;\n\n    elements.forEach((item: PlaitElement, index: number) => {\n        newElement = copyNewNode(item as MindElement);\n        if (hasTargetParent && operationType !== WritableClipboardOperationType.duplicate) {\n            if (item.isRoot) {\n                newElement = adjustRootToNode(board, newElement);\n                const { width, height } = getTopicSizeByElement(newElement, targetParent as MindElement);\n                newElement.width = width;\n                newElement.height = height;\n            }\n            // handle abstract start and end\n            if (AbstractNode.isAbstract(newElement)) {\n                newElement.start = newElement.start + nonAbstractChildrenLength;\n                newElement.end = newElement.end + nonAbstractChildrenLength;\n            }\n            path = [...targetParentPath, nonAbstractChildrenLength + index];\n        } else {\n            const point: Point = [targetPoint[0] + item.points![0][0], targetPoint[1] + item.points![0][1]];\n            newElement.points = [point];\n            if (AbstractNode.isAbstract(item)) {\n                newElement = adjustAbstractToNode(newElement);\n            }\n            if (!item.isRoot) {\n                newElement = adjustNodeToRoot(board, newElement);\n                const { width, height } = getTopicSizeByElement(newElement);\n                newElement.width = width;\n                newElement.height = height;\n            }\n            path = [board.children.length];\n        }\n        newELements.push(newElement);\n        Transforms.insertNode(board, newElement, path);\n        return;\n    });\n    Transforms.addSelectionWithTemporaryElements(board, newELements);\n};\n\nexport const insertClipboardText = (board: PlaitMindBoard, targetParent: PlaitElement, text: string | Element) => {\n    const { width, height } = getTopicSize(false, PlaitMind.isMind(targetParent), buildText(text));\n    const newElement = createMindElement(text, Math.max(width, getFontSizeBySlateElement(text)), height, {});\n    Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));\n    Transforms.addSelectionWithTemporaryElements(board, [newElement]);\n};\n\nexport const getTopicSizeByElement = (element: MindElement, parentElement?: MindElement) => {\n    return getTopicSize(\n        PlaitMind.isMind(element),\n        (parentElement && PlaitMind.isMind(parentElement)) || false,\n        element.data.topic,\n        element.manualWidth\n    );\n};\n"]}
|
package/esm2022/utils/common.mjs
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { getI18nValue } from '@plait/core';
|
|
2
|
-
import { MindI18nKey } from '../constants/default';
|
|
3
|
-
import { ROOT_TOPIC_FONT_SIZE, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE } from '../constants';
|
|
4
|
-
import { DEFAULT_FONT_FAMILY, measureElement } from '@plait/common';
|
|
5
|
-
export const MIND_CENTRAL_TEXT = '中心主题';
|
|
6
|
-
export const ABSTRACT_NODE_TEXT = '概要';
|
|
7
|
-
export const getDefaultMindNameText = (board) => {
|
|
8
|
-
return getI18nValue(board, MindI18nKey.mindCentralText, MIND_CENTRAL_TEXT);
|
|
9
|
-
};
|
|
10
|
-
export const getAbstractNodeText = (board) => {
|
|
11
|
-
return getI18nValue(board, MindI18nKey.abstractNodeText, ABSTRACT_NODE_TEXT);
|
|
12
|
-
};
|
|
13
|
-
export const getTopicSize = (isRoot, isBranch, topic, manualWidth) => {
|
|
14
|
-
let fontFamily = DEFAULT_FONT_FAMILY;
|
|
15
|
-
let fontSize = TOPIC_FONT_SIZE;
|
|
16
|
-
if (isRoot) {
|
|
17
|
-
fontFamily = DEFAULT_FONT_FAMILY;
|
|
18
|
-
fontSize = ROOT_TOPIC_FONT_SIZE;
|
|
19
|
-
}
|
|
20
|
-
else if (isBranch) {
|
|
21
|
-
fontFamily = DEFAULT_FONT_FAMILY;
|
|
22
|
-
}
|
|
23
|
-
const maxWidth = fontSize * TOPIC_DEFAULT_MAX_WORD_COUNT;
|
|
24
|
-
return measureElement(topic, { fontSize, fontFamily }, manualWidth ? manualWidth : maxWidth);
|
|
25
|
-
};
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvdXRpbHMvY29tbW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSxhQUFhLENBQUM7QUFDdkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSw0QkFBNEIsRUFBRSxlQUFlLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbkcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGNBQWMsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFFdEYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDO0FBRXhDLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksQ0FBQztBQUV2QyxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUN4RCxPQUFPLFlBQVksQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0FBQy9FLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQ3JELE9BQU8sWUFBWSxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsZ0JBQWdCLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztBQUNqRixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxNQUFlLEVBQUUsUUFBaUIsRUFBRSxLQUF1QixFQUFFLFdBQW9CLEVBQUUsRUFBRTtJQUM5RyxJQUFJLFVBQVUsR0FBRyxtQkFBbUIsQ0FBQztJQUNyQyxJQUFJLFFBQVEsR0FBRyxlQUFlLENBQUM7SUFDL0IsSUFBSSxNQUFNLEVBQUUsQ0FBQztRQUNULFVBQVUsR0FBRyxtQkFBbUIsQ0FBQztRQUNqQyxRQUFRLEdBQUcsb0JBQW9CLENBQUM7SUFDcEMsQ0FBQztTQUFNLElBQUksUUFBUSxFQUFFLENBQUM7UUFDbEIsVUFBVSxHQUFHLG1CQUFtQixDQUFDO0lBQ3JDLENBQUM7SUFDRCxNQUFNLFFBQVEsR0FBRyxRQUFRLEdBQUcsNEJBQTRCLENBQUM7SUFDekQsT0FBTyxjQUFjLENBQUMsS0FBSyxFQUFFLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUNqRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRJMThuVmFsdWUsIFBsYWl0Qm9hcmQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBNaW5kSTE4bktleSB9IGZyb20gJy4uL2NvbnN0YW50cy9kZWZhdWx0JztcbmltcG9ydCB7IFJPT1RfVE9QSUNfRk9OVF9TSVpFLCBUT1BJQ19ERUZBVUxUX01BWF9XT1JEX0NPVU5ULCBUT1BJQ19GT05UX1NJWkUgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgREVGQVVMVF9GT05UX0ZBTUlMWSwgbWVhc3VyZUVsZW1lbnQsIFBhcmFncmFwaEVsZW1lbnQgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcblxuZXhwb3J0IGNvbnN0IE1JTkRfQ0VOVFJBTF9URVhUID0gJ+S4reW/g+S4u+mimCc7XG5cbmV4cG9ydCBjb25zdCBBQlNUUkFDVF9OT0RFX1RFWFQgPSAn5qaC6KaBJztcblxuZXhwb3J0IGNvbnN0IGdldERlZmF1bHRNaW5kTmFtZVRleHQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICByZXR1cm4gZ2V0STE4blZhbHVlKGJvYXJkLCBNaW5kSTE4bktleS5taW5kQ2VudHJhbFRleHQsIE1JTkRfQ0VOVFJBTF9URVhUKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRBYnN0cmFjdE5vZGVUZXh0ID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgcmV0dXJuIGdldEkxOG5WYWx1ZShib2FyZCwgTWluZEkxOG5LZXkuYWJzdHJhY3ROb2RlVGV4dCwgQUJTVFJBQ1RfTk9ERV9URVhUKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUb3BpY1NpemUgPSAoaXNSb290OiBib29sZWFuLCBpc0JyYW5jaDogYm9vbGVhbiwgdG9waWM6IFBhcmFncmFwaEVsZW1lbnQsIG1hbnVhbFdpZHRoPzogbnVtYmVyKSA9PiB7XG4gICAgbGV0IGZvbnRGYW1pbHkgPSBERUZBVUxUX0ZPTlRfRkFNSUxZO1xuICAgIGxldCBmb250U2l6ZSA9IFRPUElDX0ZPTlRfU0laRTtcbiAgICBpZiAoaXNSb290KSB7XG4gICAgICAgIGZvbnRGYW1pbHkgPSBERUZBVUxUX0ZPTlRfRkFNSUxZO1xuICAgICAgICBmb250U2l6ZSA9IFJPT1RfVE9QSUNfRk9OVF9TSVpFO1xuICAgIH0gZWxzZSBpZiAoaXNCcmFuY2gpIHtcbiAgICAgICAgZm9udEZhbWlseSA9IERFRkFVTFRfRk9OVF9GQU1JTFk7XG4gICAgfVxuICAgIGNvbnN0IG1heFdpZHRoID0gZm9udFNpemUgKiBUT1BJQ19ERUZBVUxUX01BWF9XT1JEX0NPVU5UO1xuICAgIHJldHVybiBtZWFzdXJlRWxlbWVudCh0b3BpYywgeyBmb250U2l6ZSwgZm9udEZhbWlseSB9LCBtYW51YWxXaWR0aCA/IG1hbnVhbFdpZHRoIDogbWF4V2lkdGgpO1xufTtcbiJdfQ==
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { getNonAbstractChildren, isStandardLayout } from '@plait/layouts';
|
|
2
|
-
import { PlaitMind } from '../../interfaces/element';
|
|
3
|
-
import { PlaitBoard, PlaitElement, setDragging } from '@plait/core';
|
|
4
|
-
import { getRootLayout } from '../layout';
|
|
5
|
-
export const addActiveOnDragOrigin = (activeElement) => {
|
|
6
|
-
PlaitElement.getElementG(activeElement).classList.add('dragging-node');
|
|
7
|
-
!activeElement.isCollapsed &&
|
|
8
|
-
activeElement.children.forEach(child => {
|
|
9
|
-
addActiveOnDragOrigin(child);
|
|
10
|
-
});
|
|
11
|
-
};
|
|
12
|
-
export const removeActiveOnDragOrigin = (activeElement) => {
|
|
13
|
-
PlaitElement.getElementG(activeElement).classList.remove('dragging-node');
|
|
14
|
-
!activeElement.isCollapsed &&
|
|
15
|
-
activeElement.children.forEach(child => {
|
|
16
|
-
removeActiveOnDragOrigin(child);
|
|
17
|
-
});
|
|
18
|
-
};
|
|
19
|
-
export const setMindDragging = (board, state) => {
|
|
20
|
-
setDragging(board, state);
|
|
21
|
-
if (state) {
|
|
22
|
-
PlaitBoard.getBoardContainer(board).classList.add('mind-node-dragging');
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
PlaitBoard.getBoardContainer(board).classList.remove('mind-node-dragging');
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
export const hasPreviousOrNextOfDropPath = (parent, dropTarget, dropPath) => {
|
|
29
|
-
let children = getNonAbstractChildren(parent);
|
|
30
|
-
if (PlaitMind.isMind(parent) && isStandardLayout(getRootLayout(parent))) {
|
|
31
|
-
const isDropRight = isDropStandardRight(parent, dropTarget);
|
|
32
|
-
if (isDropRight) {
|
|
33
|
-
children = children.slice(0, parent.rightNodeCount);
|
|
34
|
-
}
|
|
35
|
-
if (!isDropRight) {
|
|
36
|
-
children = children.slice(parent.rightNodeCount, children.length);
|
|
37
|
-
dropPath = [...dropPath, dropPath[dropPath.length - 1] - parent.rightNodeCount];
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
let hasPreviousNode = dropPath[dropPath.length - 1] !== 0;
|
|
41
|
-
let hasNextNode = dropPath[dropPath.length - 1] !== (children?.length || 0);
|
|
42
|
-
if (parent.isCollapsed) {
|
|
43
|
-
hasNextNode = false;
|
|
44
|
-
hasPreviousNode = false;
|
|
45
|
-
}
|
|
46
|
-
return {
|
|
47
|
-
hasPreviousNode,
|
|
48
|
-
hasNextNode
|
|
49
|
-
};
|
|
50
|
-
};
|
|
51
|
-
export const isDropStandardRight = (parent, dropTarget) => {
|
|
52
|
-
const target = dropTarget.target;
|
|
53
|
-
return ((PlaitMind.isMind(parent) &&
|
|
54
|
-
isStandardLayout(getRootLayout(parent)) &&
|
|
55
|
-
parent.children.indexOf(target) !== -1 &&
|
|
56
|
-
parent.children.indexOf(target) < parent.rightNodeCount) ||
|
|
57
|
-
(PlaitMind.isMind(target) && isStandardLayout(getRootLayout(target)) && dropTarget.detectResult === 'right'));
|
|
58
|
-
};
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvdXRpbHMvZG5kL2NvbW1vbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMxRSxPQUFPLEVBQWUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDbEUsT0FBTyxFQUFRLFVBQVUsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFHMUMsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsQ0FBQyxhQUEwQixFQUFFLEVBQUU7SUFDaEUsWUFBWSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBRXZFLENBQUMsYUFBYSxDQUFDLFdBQVc7UUFDdEIsYUFBYSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDbkMscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7QUFDWCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLGFBQTBCLEVBQUUsRUFBRTtJQUNuRSxZQUFZLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDMUUsQ0FBQyxhQUFhLENBQUMsV0FBVztRQUN0QixhQUFhLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNuQyx3QkFBd0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQyxDQUFDLENBQUMsQ0FBQztBQUNYLENBQUMsQ0FBQztBQUVGLE1BQU0s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ZW4sIGlzU3RhbmRhcmRMYXlvdXQgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBNaW5kRWxlbWVudCwgUGxhaXRNaW5kIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBhdGgsIFBsYWl0Qm9hcmQsIFBsYWl0RWxlbWVudCwgc2V0RHJhZ2dpbmcgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBnZXRSb290TGF5b3V0IH0gZnJvbSAnLi4vbGF5b3V0JztcbmltcG9ydCB7IERldGVjdFJlc3VsdCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvbm9kZSc7XG5cbmV4cG9ydCBjb25zdCBhZGRBY3RpdmVPbkRyYWdPcmlnaW4gPSAoYWN0aXZlRWxlbWVudDogTWluZEVsZW1lbnQpID0+IHtcbiAgICBQbGFpdEVsZW1lbnQuZ2V0RWxlbWVudEcoYWN0aXZlRWxlbWVudCkuY2xhc3NMaXN0LmFkZCgnZHJhZ2dpbmctbm9kZScpO1xuXG4gICAgIWFjdGl2ZUVsZW1lbnQuaXNDb2xsYXBzZWQgJiZcbiAgICAgICAgYWN0aXZlRWxlbWVudC5jaGlsZHJlbi5mb3JFYWNoKGNoaWxkID0+IHtcbiAgICAgICAgICAgIGFkZEFjdGl2ZU9uRHJhZ09yaWdpbihjaGlsZCk7XG4gICAgICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IHJlbW92ZUFjdGl2ZU9uRHJhZ09yaWdpbiA9IChhY3RpdmVFbGVtZW50OiBNaW5kRWxlbWVudCkgPT4ge1xuICAgIFBsYWl0RWxlbWVudC5nZXRFbGVtZW50RyhhY3RpdmVFbGVtZW50KS5jbGFzc0xpc3QucmVtb3ZlKCdkcmFnZ2luZy1ub2RlJyk7XG4gICAgIWFjdGl2ZUVsZW1lbnQuaXNDb2xsYXBzZWQgJiZcbiAgICAgICAgYWN0aXZlRWxlbWVudC5jaGlsZHJlbi5mb3JFYWNoKGNoaWxkID0+IHtcbiAgICAgICAgICAgIHJlbW92ZUFjdGl2ZU9uRHJhZ09yaWdpbihjaGlsZCk7XG4gICAgICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IHNldE1pbmREcmFnZ2luZyA9IChib2FyZDogUGxhaXRCb2FyZCwgc3RhdGU6IGJvb2xlYW4pID0+IHtcbiAgICBzZXREcmFnZ2luZyhib2FyZCwgc3RhdGUpO1xuICAgIGlmIChzdGF0ZSkge1xuICAgICAgICBQbGFpdEJvYXJkLmdldEJvYXJkQ29udGFpbmVyKGJvYXJkKS5jbGFzc0xpc3QuYWRkKCdtaW5kLW5vZGUtZHJhZ2dpbmcnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgICBQbGFpdEJvYXJkLmdldEJvYXJkQ29udGFpbmVyKGJvYXJkKS5jbGFzc0xpc3QucmVtb3ZlKCdtaW5kLW5vZGUtZHJhZ2dpbmcnKTtcbiAgICB9XG59O1xuXG5leHBvcnQgY29uc3QgaGFzUHJldmlvdXNPck5leHRPZkRyb3BQYXRoID0gKFxuICAgIHBhcmVudDogTWluZEVsZW1lbnQsXG4gICAgZHJvcFRhcmdldDoge1xuICAgICAgICB0YXJnZXQ6IE1pbmRFbGVtZW50O1xuICAgICAgICBkZXRlY3RSZXN1bHQ6IERldGVjdFJlc3VsdDtcbiAgICB9LFxuICAgIGRyb3BQYXRoOiBQYXRoXG4pID0+IHtcbiAgICBsZXQgY2hpbGRyZW4gPSBnZXROb25BYnN0cmFjdENoaWxkcmVuKHBhcmVudCk7XG5cbiAgICBpZiAoUGxhaXRNaW5kLmlzTWluZChwYXJlbnQpICYmIGlzU3RhbmRhcmRMYXlvdXQoZ2V0Um9vdExheW91dChwYXJlbnQpKSkge1xuICAgICAgICBjb25zdCBpc0Ryb3BSaWdodCA9IGlzRHJvcFN0YW5kYXJkUmlnaHQocGFyZW50LCBkcm9wVGFyZ2V0KTtcblxuICAgICAgICBpZiAoaXNEcm9wUmlnaHQpIHtcbiAgICAgICAgICAgIGNoaWxkcmVuID0gY2hpbGRyZW4uc2xpY2UoMCwgcGFyZW50LnJpZ2h0Tm9kZUNvdW50ISk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFpc0Ryb3BSaWdodCkge1xuICAgICAgICAgICAgY2hpbGRyZW4gPSBjaGlsZHJlbi5zbGljZShwYXJlbnQucmlnaHROb2RlQ291bnQhLCBjaGlsZHJlbi5sZW5ndGgpO1xuICAgICAgICAgICAgZHJvcFBhdGggPSBbLi4uZHJvcFBhdGgsIGRyb3BQYXRoW2Ryb3BQYXRoLmxlbmd0aCAtIDFdIC0gcGFyZW50LnJpZ2h0Tm9kZUNvdW50IV07XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBsZXQgaGFzUHJldmlvdXNOb2RlID0gZHJvcFBhdGhbZHJvcFBhdGgubGVuZ3RoIC0gMV0gIT09IDA7XG4gICAgbGV0IGhhc05leHROb2RlID0gZHJvcFBhdGhbZHJvcFBhdGgubGVuZ3RoIC0gMV0gIT09IChjaGlsZHJlbj8ubGVuZ3RoIHx8IDApO1xuXG4gICAgaWYgKHBhcmVudC5pc0NvbGxhcHNlZCkge1xuICAgICAgICBoYXNOZXh0Tm9kZSA9IGZhbHNlO1xuICAgICAgICBoYXNQcmV2aW91c05vZGUgPSBmYWxzZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgICBoYXNQcmV2aW91c05vZGUsXG4gICAgICAgIGhhc05leHROb2RlXG4gICAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc0Ryb3BTdGFuZGFyZFJpZ2h0ID0gKFxuICAgIHBhcmVudDogTWluZEVsZW1lbnQsXG4gICAgZHJvcFRhcmdldDoge1xuICAgICAgICB0YXJnZXQ6IE1pbmRFbGVtZW50O1xuICAgICAgICBkZXRlY3RSZXN1bHQ6IERldGVjdFJlc3VsdDtcbiAgICB9XG4pID0+IHtcbiAgICBjb25zdCB0YXJnZXQgPSBkcm9wVGFyZ2V0LnRhcmdldDtcblxuICAgIHJldHVybiAoXG4gICAgICAgIChQbGFpdE1pbmQuaXNNaW5kKHBhcmVudCkgJiZcbiAgICAgICAgICAgIGlzU3RhbmRhcmRMYXlvdXQoZ2V0Um9vdExheW91dChwYXJlbnQpKSAmJlxuICAgICAgICAgICAgcGFyZW50LmNoaWxkcmVuLmluZGV4T2YodGFyZ2V0KSAhPT0gLTEgJiZcbiAgICAgICAgICAgIHBhcmVudC5jaGlsZHJlbi5pbmRleE9mKHRhcmdldCkgPCBwYXJlbnQucmlnaHROb2RlQ291bnQhKSB8fFxuICAgICAgICAoUGxhaXRNaW5kLmlzTWluZCh0YXJnZXQpICYmIGlzU3RhbmRhcmRMYXlvdXQoZ2V0Um9vdExheW91dCh0YXJnZXQpKSAmJiBkcm9wVGFyZ2V0LmRldGVjdFJlc3VsdCA9PT0gJ3JpZ2h0JylcbiAgICApO1xufTtcbiJdfQ==
|