@plait/mind 0.2.2 → 0.3.1
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/{drawer/base/base.d.ts → base/base.drawer.d.ts} +1 -1
- package/{plugins/emoji → base}/emoji-base.component.d.ts +2 -2
- package/{plugins/emoji → base}/index.d.ts +1 -1
- package/draw/abstract.d.ts +2 -1
- package/draw/indented-link.d.ts +1 -1
- package/draw/link/logic-link.d.ts +1 -1
- package/draw/node.d.ts +5 -0
- package/draw/topic.d.ts +16 -0
- package/{plugins/emoji → drawer}/emoji.drawer.d.ts +3 -3
- package/drawer/quick-insert.drawer.d.ts +1 -1
- package/esm2020/base/base.drawer.mjs +17 -0
- package/esm2020/base/emoji-base.component.mjs +33 -0
- package/esm2020/base/index.mjs +3 -0
- package/esm2020/draw/abstract.mjs +8 -7
- package/esm2020/draw/indented-link.mjs +3 -3
- package/esm2020/draw/link/abstract-link.mjs +9 -15
- package/esm2020/draw/link/logic-link.mjs +9 -9
- package/esm2020/draw/node.mjs +21 -0
- package/esm2020/draw/topic.mjs +32 -0
- package/esm2020/drawer/emoji.drawer.mjs +73 -0
- package/esm2020/drawer/quick-insert.drawer.mjs +3 -3
- package/esm2020/interfaces/index.mjs +2 -2
- package/esm2020/interfaces/pointer.mjs +5 -0
- package/esm2020/mind.component.mjs +2 -2
- package/esm2020/mind.module.mjs +5 -5
- package/esm2020/node.component.mjs +11 -10
- package/esm2020/plugins/with-abstract-resize.board.mjs +12 -0
- package/esm2020/plugins/with-abstract-resize.mjs +107 -0
- package/esm2020/plugins/with-mind-create.mjs +85 -0
- package/esm2020/plugins/with-mind-extend.mjs +11 -0
- package/esm2020/plugins/with-mind.board.mjs +2 -0
- package/esm2020/plugins/with-mind.mjs +30 -16
- package/esm2020/plugins/with-node-dnd.mjs +162 -0
- package/esm2020/public-api.mjs +5 -3
- package/esm2020/transforms/abstract-node.mjs +3 -2
- package/esm2020/transforms/emoji.mjs +37 -0
- package/esm2020/transforms/index.mjs +7 -3
- package/esm2020/transforms/node.mjs +40 -33
- package/esm2020/utils/abstract/common.mjs +64 -31
- package/esm2020/utils/abstract/resize.mjs +3 -2
- package/esm2020/utils/clipboard.mjs +16 -18
- package/esm2020/utils/dnd/common.mjs +35 -0
- package/esm2020/utils/dnd/detector.mjs +268 -0
- package/esm2020/utils/dnd/draw.mjs +161 -0
- package/esm2020/utils/index.mjs +6 -6
- package/esm2020/utils/mind.mjs +6 -129
- package/esm2020/utils/node/adjust-node.mjs +49 -0
- package/esm2020/utils/node/common.mjs +6 -0
- package/esm2020/utils/node/create-node.mjs +61 -0
- package/esm2020/utils/node/index.mjs +4 -0
- package/esm2020/utils/point-placement.mjs +22 -2
- package/esm2020/utils/position/emoji.mjs +31 -0
- package/esm2020/utils/position/index.mjs +4 -0
- package/esm2020/utils/position/node.mjs +34 -0
- package/esm2020/utils/position/topic.mjs +14 -0
- package/esm2020/utils/space/emoji.mjs +19 -0
- package/esm2020/utils/space/layout-options.mjs +72 -0
- package/esm2020/utils/space/node-space.mjs +77 -0
- package/fesm2015/plait-mind.mjs +1464 -1631
- package/fesm2015/plait-mind.mjs.map +1 -1
- package/fesm2020/plait-mind.mjs +1486 -1642
- package/fesm2020/plait-mind.mjs.map +1 -1
- package/interfaces/index.d.ts +1 -1
- package/interfaces/pointer.d.ts +3 -0
- package/mind.module.d.ts +2 -2
- package/node.component.d.ts +3 -3
- package/package.json +3 -3
- package/{interfaces/abstract.d.ts → plugins/with-abstract-resize.board.d.ts} +2 -2
- package/plugins/with-mind-create.d.ts +11 -0
- package/plugins/with-mind-extend.d.ts +3 -0
- package/plugins/{with-extend-mind.d.ts → with-mind.board.d.ts} +4 -4
- package/plugins/with-mind.d.ts +1 -1
- package/public-api.d.ts +4 -2
- package/styles/styles.scss +5 -2
- package/transforms/abstract-node.d.ts +1 -1
- package/transforms/emoji.d.ts +6 -0
- package/transforms/index.d.ts +3 -0
- package/transforms/node.d.ts +5 -5
- package/utils/abstract/common.d.ts +19 -4
- package/utils/abstract/resize.d.ts +2 -1
- package/utils/dnd/common.d.ts +7 -0
- package/utils/dnd/detector.d.ts +31 -0
- package/utils/dnd/draw.d.ts +9 -0
- package/utils/index.d.ts +5 -5
- package/utils/mind.d.ts +3 -22
- package/utils/node/adjust-node.d.ts +5 -0
- package/utils/{node.d.ts → node/common.d.ts} +1 -1
- package/utils/node/create-node.d.ts +14 -0
- package/utils/node/index.d.ts +3 -0
- package/utils/point-placement.d.ts +8 -1
- package/utils/position/emoji.d.ts +7 -0
- package/utils/position/index.d.ts +3 -0
- package/utils/position/node.d.ts +12 -0
- package/utils/position/topic.d.ts +16 -0
- package/utils/space/emoji.d.ts +7 -0
- package/{layout-option.d.ts → utils/space/layout-options.d.ts} +1 -1
- package/utils/{node-space.d.ts → space/node-space.d.ts} +4 -4
- package/draw/link.d.ts +0 -3
- package/draw/richtext.d.ts +0 -15
- package/draw/shape.d.ts +0 -3
- package/esm2020/draw/link.mjs +0 -160
- package/esm2020/draw/richtext.mjs +0 -39
- package/esm2020/draw/shape.mjs +0 -18
- package/esm2020/drawer/base/base.mjs +0 -17
- package/esm2020/interfaces/abstract.mjs +0 -12
- package/esm2020/layout-option.mjs +0 -72
- package/esm2020/plugins/emoji/emoji-base.component.mjs +0 -33
- package/esm2020/plugins/emoji/emoji.drawer.mjs +0 -72
- package/esm2020/plugins/emoji/emoji.mjs +0 -47
- package/esm2020/plugins/emoji/index.mjs +0 -3
- package/esm2020/plugins/with-abstract.mjs +0 -106
- package/esm2020/plugins/with-dnd.mjs +0 -179
- package/esm2020/plugins/with-extend-mind.mjs +0 -11
- package/esm2020/utils/direction-corrector.mjs +0 -54
- package/esm2020/utils/direction-detector.mjs +0 -56
- package/esm2020/utils/dnd.mjs +0 -122
- package/esm2020/utils/draw-placeholder.mjs +0 -313
- package/esm2020/utils/drop-target-corrector.mjs +0 -87
- package/esm2020/utils/graph.mjs +0 -24
- package/esm2020/utils/node-space.mjs +0 -77
- package/esm2020/utils/node.mjs +0 -6
- package/plugins/emoji/emoji.d.ts +0 -11
- package/utils/direction-corrector.d.ts +0 -4
- package/utils/direction-detector.d.ts +0 -9
- package/utils/dnd.d.ts +0 -16
- package/utils/draw-placeholder.d.ts +0 -42
- package/utils/drop-target-corrector.d.ts +0 -9
- package/utils/graph.d.ts +0 -5
- /package/plugins/{with-abstract.d.ts → with-abstract-resize.d.ts} +0 -0
- /package/plugins/{with-dnd.d.ts → with-node-dnd.d.ts} +0 -0
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import { isStandardLayout, isIndentedLayout, isVerticalLogicLayout, isTopLayout, MindLayoutType, getNonAbstractChildren } from '@plait/layouts';
|
|
2
|
-
import { MindQueries } from '../queries';
|
|
3
|
-
import { isMixedLayout } from './layout';
|
|
4
|
-
import { PlaitElement } from '@plait/core';
|
|
5
|
-
/* 根据布局调整 target 以及 direction */
|
|
6
|
-
export const readjustmentDropTarget = (board, dropTarget) => {
|
|
7
|
-
const { target, detectResult } = dropTarget;
|
|
8
|
-
const newDropTarget = { target, detectResult };
|
|
9
|
-
const targetComponent = PlaitElement.getComponent(target);
|
|
10
|
-
if (targetComponent.node.children.length > 0 && dropTarget.detectResult) {
|
|
11
|
-
const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);
|
|
12
|
-
const parentLayout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin);
|
|
13
|
-
const children = getNonAbstractChildren(targetComponent.node);
|
|
14
|
-
if (['right', 'left'].includes(dropTarget.detectResult)) {
|
|
15
|
-
if (!isMixedLayout(parentLayout, layout)) {
|
|
16
|
-
if (targetComponent.node.origin.isRoot) {
|
|
17
|
-
const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);
|
|
18
|
-
// 标准布局,根节点
|
|
19
|
-
if (isStandardLayout(layout)) {
|
|
20
|
-
const rightNodeCount = targetComponent.node.origin.rightNodeCount;
|
|
21
|
-
if (detectResult === 'left') {
|
|
22
|
-
// 作为左的第一个节点
|
|
23
|
-
if (targetComponent.node.children.length === rightNodeCount) {
|
|
24
|
-
return newDropTarget;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
else {
|
|
28
|
-
// 作为右的第一个节点或最后一个节点
|
|
29
|
-
if (rightNodeCount === 0) {
|
|
30
|
-
newDropTarget.target = target;
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
newDropTarget.target = targetComponent.node.children[rightNodeCount - 1].origin;
|
|
34
|
-
newDropTarget.detectResult = 'bottom';
|
|
35
|
-
}
|
|
36
|
-
return newDropTarget;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
// 缩进布局探测到第一个子节点
|
|
41
|
-
if (isIndentedLayout(parentLayout)) {
|
|
42
|
-
newDropTarget.target = targetComponent.node.children[0].origin;
|
|
43
|
-
newDropTarget.detectResult = isTopLayout(parentLayout) ? 'bottom' : 'top';
|
|
44
|
-
return newDropTarget;
|
|
45
|
-
}
|
|
46
|
-
// 上下布局的根节点只可以探测到上或者下,子节点的左右探测不处理,跳过。
|
|
47
|
-
if (isVerticalLogicLayout(parentLayout)) {
|
|
48
|
-
return newDropTarget;
|
|
49
|
-
}
|
|
50
|
-
// 剩下是水平布局的默认情况:插入最后一个子节点的下方
|
|
51
|
-
const lastChildNodeIndex = children.length - 1;
|
|
52
|
-
newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;
|
|
53
|
-
newDropTarget.detectResult = 'bottom';
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
// 处理左右布局下的混合布局
|
|
57
|
-
if ([MindLayoutType.left, MindLayoutType.right].includes(parentLayout)) {
|
|
58
|
-
const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);
|
|
59
|
-
if (isIndentedLayout(layout)) {
|
|
60
|
-
newDropTarget.target = targetComponent.node.children[0].origin;
|
|
61
|
-
newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';
|
|
62
|
-
return newDropTarget;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
if (['top', 'bottom'].includes(dropTarget.detectResult)) {
|
|
68
|
-
// 缩进布局移动至第一个节点
|
|
69
|
-
if (targetComponent.node.origin.isRoot && isIndentedLayout(layout)) {
|
|
70
|
-
newDropTarget.target = targetComponent.node.children[0].origin;
|
|
71
|
-
newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';
|
|
72
|
-
return newDropTarget;
|
|
73
|
-
}
|
|
74
|
-
// 上下布局,插到右边
|
|
75
|
-
const parentLayout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin);
|
|
76
|
-
if (isVerticalLogicLayout(parentLayout)) {
|
|
77
|
-
const lastChildNodeIndex = children.length - 1;
|
|
78
|
-
newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;
|
|
79
|
-
newDropTarget.detectResult = 'right';
|
|
80
|
-
return newDropTarget;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
return newDropTarget;
|
|
84
|
-
}
|
|
85
|
-
return dropTarget;
|
|
86
|
-
};
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-target-corrector.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/drop-target-corrector.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    isStandardLayout,\n    isIndentedLayout,\n    isVerticalLogicLayout,\n    isTopLayout,\n    MindLayoutType,\n    getNonAbstractChildren\n} from '@plait/layouts';\nimport { DetectResult, MindElement } from '../interfaces';\nimport { MindNodeComponent } from '../node.component';\nimport { MindQueries } from '../queries';\nimport { isMixedLayout } from './layout';\nimport { PlaitBoard, PlaitElement } from '@plait/core';\n\n/* 根据布局调整 target 以及 direction */\nexport const readjustmentDropTarget = (\n    board: PlaitBoard,\n    dropTarget: {\n        target: MindElement;\n        detectResult: DetectResult;\n    }\n): { target: MindElement; detectResult: DetectResult } => {\n    const { target, detectResult } = dropTarget;\n    const newDropTarget = { target, detectResult };\n    const targetComponent = PlaitElement.getComponent(target) as MindNodeComponent;\n    if (targetComponent.node.children.length > 0 && dropTarget.detectResult) {\n        const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);\n        const parentLayout = MindQueries.getCorrectLayoutByElement(\n            board,\n            targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin\n        );\n        const children = getNonAbstractChildren(targetComponent.node);\n        if (['right', 'left'].includes(dropTarget.detectResult)) {\n            if (!isMixedLayout(parentLayout, layout)) {\n                if (targetComponent.node.origin.isRoot) {\n                    const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);\n                    // 标准布局，根节点\n                    if (isStandardLayout(layout)) {\n                        const rightNodeCount = targetComponent.node.origin.rightNodeCount as number;\n                        if (detectResult === 'left') {\n                            // 作为左的第一个节点\n                            if (targetComponent.node.children.length === rightNodeCount) {\n                                return newDropTarget;\n                            }\n                        } else {\n                            // 作为右的第一个节点或最后一个节点\n                            if (rightNodeCount === 0) {\n                                newDropTarget.target = target;\n                            } else {\n                                newDropTarget.target = targetComponent.node.children[rightNodeCount - 1].origin;\n                                newDropTarget.detectResult = 'bottom';\n                            }\n                            return newDropTarget;\n                        }\n                    }\n                }\n\n                // 缩进布局探测到第一个子节点\n                if (isIndentedLayout(parentLayout)) {\n                    newDropTarget.target = targetComponent.node.children[0].origin;\n                    newDropTarget.detectResult = isTopLayout(parentLayout) ? 'bottom' : 'top';\n                    return newDropTarget;\n                }\n                // 上下布局的根节点只可以探测到上或者下，子节点的左右探测不处理，跳过。\n                if (isVerticalLogicLayout(parentLayout)) {\n                    return newDropTarget;\n                }\n                // 剩下是水平布局的默认情况：插入最后一个子节点的下方\n                const lastChildNodeIndex = children.length - 1;\n                newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;\n                newDropTarget.detectResult = 'bottom';\n            } else {\n                // 处理左右布局下的混合布局\n                if ([MindLayoutType.left, MindLayoutType.right].includes(parentLayout)) {\n                    const layout = MindQueries.getCorrectLayoutByElement(board, targetComponent.node.origin);\n                    if (isIndentedLayout(layout)) {\n                        newDropTarget.target = targetComponent.node.children[0].origin;\n                        newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';\n                        return newDropTarget;\n                    }\n                }\n            }\n        }\n        if (['top', 'bottom'].includes(dropTarget.detectResult)) {\n            // 缩进布局移动至第一个节点\n            if (targetComponent.node.origin.isRoot && isIndentedLayout(layout)) {\n                newDropTarget.target = targetComponent.node.children[0].origin;\n                newDropTarget.detectResult = isTopLayout(layout) ? 'bottom' : 'top';\n                return newDropTarget;\n            }\n            // 上下布局，插到右边\n            const parentLayout = MindQueries.getCorrectLayoutByElement(\n                board,\n                targetComponent.node.origin.isRoot ? targetComponent.node.origin : targetComponent.node.parent.origin\n            );\n            if (isVerticalLogicLayout(parentLayout)) {\n                const lastChildNodeIndex = children.length - 1;\n                newDropTarget.target = targetComponent.node.children[lastChildNodeIndex].origin;\n                newDropTarget.detectResult = 'right';\n                return newDropTarget;\n            }\n        }\n        return newDropTarget;\n    }\n    return dropTarget;\n};\n"]}
|
package/esm2020/utils/graph.mjs
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { distanceBetweenPointAndRectangle } from '@plait/core';
|
|
2
|
-
import { ELEMENT_TO_NODE } from './weak-maps';
|
|
3
|
-
export function getRectangleByNode(node) {
|
|
4
|
-
const x = node.x + node.hGap;
|
|
5
|
-
let y = node.y + node.vGap;
|
|
6
|
-
const width = node.width - node.hGap * 2;
|
|
7
|
-
const height = node.height - node.vGap * 2;
|
|
8
|
-
return {
|
|
9
|
-
x,
|
|
10
|
-
y,
|
|
11
|
-
width,
|
|
12
|
-
height
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
export function hitMindElement(board, point, element) {
|
|
16
|
-
const node = ELEMENT_TO_NODE.get(element);
|
|
17
|
-
if (node && distanceBetweenPointAndRectangle(point[0], point[1], getRectangleByNode(node)) === 0) {
|
|
18
|
-
return true;
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
return false;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy91dGlscy9ncmFwaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQXNDLGdDQUFnQyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRW5HLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFOUMsTUFBTSxVQUFVLGtCQUFrQixDQUFDLElBQWM7SUFDN0MsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQzdCLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztJQUMzQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBQ3pDLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7SUFDM0MsT0FBTztRQUNILENBQUM7UUFDRCxDQUFDO1FBQ0QsS0FBSztRQUNMLE1BQU07S0FDVCxDQUFDO0FBQ04sQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUMsS0FBaUIsRUFBRSxLQUFZLEVBQUUsT0FBb0I7SUFDaEYsTUFBTSxJQUFJLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMxQyxJQUFJLElBQUksSUFBSSxnQ0FBZ0MsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQzlGLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7U0FBTTtRQUNILE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmROb2RlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQsIFBvaW50LCBSZWN0YW5nbGVDbGllbnQsIGRpc3RhbmNlQmV0d2VlblBvaW50QW5kUmVjdGFuZ2xlIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEVMRU1FTlRfVE9fTk9ERSB9IGZyb20gJy4vd2Vhay1tYXBzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldFJlY3RhbmdsZUJ5Tm9kZShub2RlOiBNaW5kTm9kZSk6IFJlY3RhbmdsZUNsaWVudCB7XG4gICAgY29uc3QgeCA9IG5vZGUueCArIG5vZGUuaEdhcDtcbiAgICBsZXQgeSA9IG5vZGUueSArIG5vZGUudkdhcDtcbiAgICBjb25zdCB3aWR0aCA9IG5vZGUud2lkdGggLSBub2RlLmhHYXAgKiAyO1xuICAgIGNvbnN0IGhlaWdodCA9IG5vZGUuaGVpZ2h0IC0gbm9kZS52R2FwICogMjtcbiAgICByZXR1cm4ge1xuICAgICAgICB4LFxuICAgICAgICB5LFxuICAgICAgICB3aWR0aCxcbiAgICAgICAgaGVpZ2h0XG4gICAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGhpdE1pbmRFbGVtZW50KGJvYXJkOiBQbGFpdEJvYXJkLCBwb2ludDogUG9pbnQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSB7XG4gICAgY29uc3Qgbm9kZSA9IEVMRU1FTlRfVE9fTk9ERS5nZXQoZWxlbWVudCk7XG4gICAgaWYgKG5vZGUgJiYgZGlzdGFuY2VCZXR3ZWVuUG9pbnRBbmRSZWN0YW5nbGUocG9pbnRbMF0sIHBvaW50WzFdLCBnZXRSZWN0YW5nbGVCeU5vZGUobm9kZSkpID09PSAwKSB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { BASE } from '../constants/default';
|
|
2
|
-
import { PlaitMind } from '../interfaces/element';
|
|
3
|
-
import { MindElement } from '../interfaces/element';
|
|
4
|
-
import { getEmojisWidthHeight } from '../plugins/emoji/emoji';
|
|
5
|
-
const NodeDefaultSpace = {
|
|
6
|
-
horizontal: {
|
|
7
|
-
nodeAndText: BASE * 3,
|
|
8
|
-
emojiAndText: BASE * 1.5
|
|
9
|
-
},
|
|
10
|
-
vertical: {
|
|
11
|
-
nodeAndText: BASE * 1.5
|
|
12
|
-
}
|
|
13
|
-
};
|
|
14
|
-
const RootDefaultSpace = {
|
|
15
|
-
horizontal: {
|
|
16
|
-
nodeAndText: BASE * 4,
|
|
17
|
-
emojiAndText: BASE * 2
|
|
18
|
-
},
|
|
19
|
-
vertical: {
|
|
20
|
-
nodeAndText: BASE * 2
|
|
21
|
-
}
|
|
22
|
-
};
|
|
23
|
-
const getHorizontalSpaceBetweenNodeAndText = (board, element) => {
|
|
24
|
-
const isMind = PlaitMind.isMind(element);
|
|
25
|
-
const nodeAndText = isMind ? RootDefaultSpace.horizontal.nodeAndText : NodeDefaultSpace.horizontal.nodeAndText;
|
|
26
|
-
return nodeAndText;
|
|
27
|
-
};
|
|
28
|
-
const getVerticalSpaceBetweenNodeAndText = (element) => {
|
|
29
|
-
const isMind = PlaitMind.isMind(element);
|
|
30
|
-
const nodeAndText = isMind ? RootDefaultSpace.vertical.nodeAndText : NodeDefaultSpace.vertical.nodeAndText;
|
|
31
|
-
return nodeAndText;
|
|
32
|
-
};
|
|
33
|
-
const getSpaceEmojiAndText = (element) => {
|
|
34
|
-
const isMind = PlaitMind.isMind(element);
|
|
35
|
-
const emojiAndText = isMind ? RootDefaultSpace.horizontal.emojiAndText : NodeDefaultSpace.horizontal.emojiAndText;
|
|
36
|
-
return emojiAndText;
|
|
37
|
-
};
|
|
38
|
-
export const NodeSpace = {
|
|
39
|
-
getNodeWidth(board, element) {
|
|
40
|
-
const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
|
|
41
|
-
if (MindElement.hasEmojis(element)) {
|
|
42
|
-
return (NodeSpace.getEmojiLeftSpace(board, element) +
|
|
43
|
-
getEmojisWidthHeight(board, element).width +
|
|
44
|
-
getSpaceEmojiAndText(element) +
|
|
45
|
-
element.width +
|
|
46
|
-
nodeAndText);
|
|
47
|
-
}
|
|
48
|
-
return nodeAndText + element.width + nodeAndText;
|
|
49
|
-
},
|
|
50
|
-
getNodeHeight(element) {
|
|
51
|
-
const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);
|
|
52
|
-
return nodeAndText + element.height + nodeAndText;
|
|
53
|
-
},
|
|
54
|
-
getTextLeftSpace(board, element) {
|
|
55
|
-
const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
|
|
56
|
-
if (MindElement.hasEmojis(element)) {
|
|
57
|
-
return NodeSpace.getEmojiLeftSpace(board, element) + getEmojisWidthHeight(board, element).width + getSpaceEmojiAndText(element);
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
return nodeAndText;
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
getTextTopSpace(element) {
|
|
64
|
-
const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);
|
|
65
|
-
return nodeAndText;
|
|
66
|
-
},
|
|
67
|
-
getEmojiLeftSpace(board, element) {
|
|
68
|
-
const options = board.getMindOptions();
|
|
69
|
-
const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
|
|
70
|
-
return nodeAndText - options.emojiPadding;
|
|
71
|
-
},
|
|
72
|
-
getEmojiTopSpace(element) {
|
|
73
|
-
const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);
|
|
74
|
-
return nodeAndText;
|
|
75
|
-
}
|
|
76
|
-
};
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1zcGFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3V0aWxzL25vZGUtc3BhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFHcEQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFOUQsTUFBTSxnQkFBZ0IsR0FBRztJQUNyQixVQUFVLEVBQUU7UUFDUixXQUFXLEVBQUUsSUFBSSxHQUFHLENBQUM7UUFDckIsWUFBWSxFQUFFLElBQUksR0FBRyxHQUFHO0tBQzNCO0lBQ0QsUUFBUSxFQUFFO1FBQ04sV0FBVyxFQUFFLElBQUksR0FBRyxHQUFHO0tBQzFCO0NBQ0osQ0FBQztBQUVGLE1BQU0sZ0JBQWdCLEdBQUc7SUFDckIsVUFBVSxFQUFFO1FBQ1IsV0FBVyxFQUFFLElBQUksR0FBRyxDQUFDO1FBQ3JCLFlBQVksRUFBRSxJQUFJLEdBQUcsQ0FBQztLQUN6QjtJQUNELFFBQVEsRUFBRTtRQUNOLFdBQVcsRUFBRSxJQUFJLEdBQUcsQ0FBQztLQUN4QjtDQUNKLENBQUM7QUFFRixNQUFNLG9DQUFvQyxHQUFHLENBQUMsS0FBcUIsRUFBRSxPQUFvQixFQUFFLEVBQUU7SUFDekYsTUFBTSxNQUFNLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN6QyxNQUFNLFdBQVcsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUM7SUFDL0csT0FBTyxXQUFXLENBQUM7QUFDdkIsQ0FB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eyBCQVNFIH0gZnJvbSAnLi4vY29uc3RhbnRzL2RlZmF1bHQnO1xuaW1wb3J0IHsgUGxhaXRNaW5kIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0TWluZEJvYXJkIH0gZnJvbSAnLi4vcGx1Z2lucy93aXRoLWV4dGVuZC1taW5kJztcbmltcG9ydCB7IEVtb2ppRGF0YSB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudC1kYXRhJztcbmltcG9ydCB7IGdldEVtb2ppc1dpZHRoSGVpZ2h0IH0gZnJvbSAnLi4vcGx1Z2lucy9lbW9qaS9lbW9qaSc7XG5cbmNvbnN0IE5vZGVEZWZhdWx0U3BhY2UgPSB7XG4gICAgaG9yaXpvbnRhbDoge1xuICAgICAgICBub2RlQW5kVGV4dDogQkFTRSAqIDMsXG4gICAgICAgIGVtb2ppQW5kVGV4dDogQkFTRSAqIDEuNVxuICAgIH0sXG4gICAgdmVydGljYWw6IHtcbiAgICAgICAgbm9kZUFuZFRleHQ6IEJBU0UgKiAxLjVcbiAgICB9XG59O1xuXG5jb25zdCBSb290RGVmYXVsdFNwYWNlID0ge1xuICAgIGhvcml6b250YWw6IHtcbiAgICAgICAgbm9kZUFuZFRleHQ6IEJBU0UgKiA0LFxuICAgICAgICBlbW9qaUFuZFRleHQ6IEJBU0UgKiAyXG4gICAgfSxcbiAgICB2ZXJ0aWNhbDoge1xuICAgICAgICBub2RlQW5kVGV4dDogQkFTRSAqIDJcbiAgICB9XG59O1xuXG5jb25zdCBnZXRIb3Jpem9udGFsU3BhY2VCZXR3ZWVuTm9kZUFuZFRleHQgPSAoYm9hcmQ6IFBsYWl0TWluZEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IGlzTWluZCA9IFBsYWl0TWluZC5pc01pbmQoZWxlbWVudCk7XG4gICAgY29uc3Qgbm9kZUFuZFRleHQgPSBpc01pbmQgPyBSb290RGVmYXVsdFNwYWNlLmhvcml6b250YWwubm9kZUFuZFRleHQgOiBOb2RlRGVmYXVsdFNwYWNlLmhvcml6b250YWwubm9kZUFuZFRleHQ7XG4gICAgcmV0dXJuIG5vZGVBbmRUZXh0O1xufTtcblxuY29uc3QgZ2V0VmVydGljYWxTcGFjZUJldHdlZW5Ob2RlQW5kVGV4dCA9IChlbGVtZW50OiBNaW5kRWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IGlzTWluZCA9IFBsYWl0TWluZC5pc01pbmQoZWxlbWVudCk7XG4gICAgY29uc3Qgbm9kZUFuZFRleHQgPSBpc01pbmQgPyBSb290RGVmYXVsdFNwYWNlLnZlcnRpY2FsLm5vZGVBbmRUZXh0IDogTm9kZURlZmF1bHRTcGFjZS52ZXJ0aWNhbC5ub2RlQW5kVGV4dDtcbiAgICByZXR1cm4gbm9kZUFuZFRleHQ7XG59O1xuXG5jb25zdCBnZXRTcGFjZUVtb2ppQW5kVGV4dCA9IChlbGVtZW50OiBNaW5kRWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IGlzTWluZCA9IFBsYWl0TWluZC5pc01pbmQoZWxlbWVudCk7XG4gICAgY29uc3QgZW1vamlBbmRUZXh0ID0gaXNNaW5kID8gUm9vdERlZmF1bHRTcGFjZS5ob3Jpem9udGFsLmVtb2ppQW5kVGV4dCA6IE5vZGVEZWZhdWx0U3BhY2UuaG9yaXpvbnRhbC5lbW9qaUFuZFRleHQ7XG4gICAgcmV0dXJuIGVtb2ppQW5kVGV4dDtcbn07XG5cbmV4cG9ydCBjb25zdCBOb2RlU3BhY2UgPSB7XG4gICAgZ2V0Tm9kZVdpZHRoKGJvYXJkOiBQbGFpdE1pbmRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgbm9kZUFuZFRleHQgPSBnZXRIb3Jpem9udGFsU3BhY2VCZXR3ZWVuTm9kZUFuZFRleHQoYm9hcmQsIGVsZW1lbnQpO1xuICAgICAgICBpZiAoTWluZEVsZW1lbnQuaGFzRW1vamlzKGVsZW1lbnQpKSB7XG4gICAgICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgICAgIE5vZGVTcGFjZS5nZXRFbW9qaUxlZnRTcGFjZShib2FyZCwgZWxlbWVudCkgK1xuICAgICAgICAgICAgICAgIGdldEVtb2ppc1dpZHRoSGVpZ2h0KGJvYXJkLCBlbGVtZW50KS53aWR0aCArXG4gICAgICAgICAgICAgICAgZ2V0U3BhY2VFbW9qaUFuZFRleHQoZWxlbWVudCkgK1xuICAgICAgICAgICAgICAgIGVsZW1lbnQud2lkdGggK1xuICAgICAgICAgICAgICAgIG5vZGVBbmRUZXh0XG4gICAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBub2RlQW5kVGV4dCArIGVsZW1lbnQud2lkdGggKyBub2RlQW5kVGV4dDtcbiAgICB9LFxuICAgIGdldE5vZGVIZWlnaHQoZWxlbWVudDogTWluZEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3Qgbm9kZUFuZFRleHQgPSBnZXRWZXJ0aWNhbFNwYWNlQmV0d2Vlbk5vZGVBbmRUZXh0KGVsZW1lbnQpO1xuICAgICAgICByZXR1cm4gbm9kZUFuZFRleHQgKyBlbGVtZW50LmhlaWdodCArIG5vZGVBbmRUZXh0O1xuICAgIH0sXG4gICAgZ2V0VGV4dExlZnRTcGFjZShib2FyZDogUGxhaXRNaW5kQm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSB7XG4gICAgICAgIGNvbnN0IG5vZGVBbmRUZXh0ID0gZ2V0SG9yaXpvbnRhbFNwYWNlQmV0d2Vlbk5vZGVBbmRUZXh0KGJvYXJkLCBlbGVtZW50KTtcbiAgICAgICAgaWYgKE1pbmRFbGVtZW50Lmhhc0Vtb2ppcyhlbGVtZW50KSkge1xuICAgICAgICAgICAgcmV0dXJuIE5vZGVTcGFjZS5nZXRFbW9qaUxlZnRTcGFjZShib2FyZCwgZWxlbWVudCkgKyBnZXRFbW9qaXNXaWR0aEhlaWdodChib2FyZCwgZWxlbWVudCkud2lkdGggKyBnZXRTcGFjZUVtb2ppQW5kVGV4dChlbGVtZW50KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBub2RlQW5kVGV4dDtcbiAgICAgICAgfVxuICAgIH0sXG4gICAgZ2V0VGV4dFRvcFNwYWNlKGVsZW1lbnQ6IE1pbmRFbGVtZW50KSB7XG4gICAgICAgIGNvbnN0IG5vZGVBbmRUZXh0ID0gZ2V0VmVydGljYWxTcGFjZUJldHdlZW5Ob2RlQW5kVGV4dChlbGVtZW50KTtcbiAgICAgICAgcmV0dXJuIG5vZGVBbmRUZXh0O1xuICAgIH0sXG4gICAgZ2V0RW1vamlMZWZ0U3BhY2UoYm9hcmQ6IFBsYWl0TWluZEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudDxFbW9qaURhdGE+KSB7XG4gICAgICAgIGNvbnN0IG9wdGlvbnMgPSBib2FyZC5nZXRNaW5kT3B0aW9ucygpO1xuICAgICAgICBjb25zdCBub2RlQW5kVGV4dCA9IGdldEhvcml6b250YWxTcGFjZUJldHdlZW5Ob2RlQW5kVGV4dChib2FyZCwgZWxlbWVudCk7XG4gICAgICAgIHJldHVybiBub2RlQW5kVGV4dCAtIG9wdGlvbnMuZW1vamlQYWRkaW5nO1xuICAgIH0sXG4gICAgZ2V0RW1vamlUb3BTcGFjZShlbGVtZW50OiBNaW5kRWxlbWVudCkge1xuICAgICAgICBjb25zdCBub2RlQW5kVGV4dCA9IGdldFZlcnRpY2FsU3BhY2VCZXR3ZWVuTm9kZUFuZFRleHQoZWxlbWVudCk7XG4gICAgICAgIHJldHVybiBub2RlQW5kVGV4dDtcbiAgICB9XG59O1xuIl19
|
package/esm2020/utils/node.mjs
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { ELEMENT_TO_COMPONENT } from '@plait/core';
|
|
2
|
-
export function enterNodeEditing(element) {
|
|
3
|
-
const component = ELEMENT_TO_COMPONENT.get(element);
|
|
4
|
-
component.startEditText(false, false);
|
|
5
|
-
}
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3V0aWxzL25vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBSW5ELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxPQUFvQjtJQUNqRCxNQUFNLFNBQVMsR0FBRyxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFzQixDQUFDO0lBQ3pFLFNBQVMsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQzFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFTEVNRU5UX1RPX0NPTVBPTkVOVCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IE1pbmROb2RlQ29tcG9uZW50IH0gZnJvbSAnLi4vbm9kZS5jb21wb25lbnQnO1xuXG5leHBvcnQgZnVuY3Rpb24gZW50ZXJOb2RlRWRpdGluZyhlbGVtZW50OiBNaW5kRWxlbWVudCkge1xuICAgIGNvbnN0IGNvbXBvbmVudCA9IEVMRU1FTlRfVE9fQ09NUE9ORU5ULmdldChlbGVtZW50KSBhcyBNaW5kTm9kZUNvbXBvbmVudDtcbiAgICBjb21wb25lbnQuc3RhcnRFZGl0VGV4dChmYWxzZSwgZmFsc2UpO1xufVxuIl19
|
package/plugins/emoji/emoji.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, Point, RectangleClient } from '@plait/core';
|
|
2
|
-
import { EmojiData, MindElement } from '../../interfaces';
|
|
3
|
-
import { PlaitMindBoard } from '../with-extend-mind';
|
|
4
|
-
export declare function getEmojisWidthHeight(board: PlaitMindBoard, element: MindElement<EmojiData>): {
|
|
5
|
-
width: number;
|
|
6
|
-
height: number;
|
|
7
|
-
};
|
|
8
|
-
export declare function getEmojiFontSize(element: MindElement<EmojiData>): number;
|
|
9
|
-
export declare function getEmojiRectangle(board: PlaitMindBoard, element: MindElement<EmojiData>): RectangleClient;
|
|
10
|
-
export declare function getEmojiForeignRectangle(board: PlaitMindBoard, element: MindElement<EmojiData>): RectangleClient;
|
|
11
|
-
export declare const isHitEmojis: (board: PlaitBoard, element: MindElement<EmojiData>, point: Point) => boolean;
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { DetectResult, MindNode } from '../interfaces';
|
|
2
|
-
import { PlaitBoard } from '@plait/core';
|
|
3
|
-
export declare const directionCorrector: (board: PlaitBoard, node: MindNode, detectResults: DetectResult[]) => DetectResult[] | null;
|
|
4
|
-
export declare const getAllowedDirection: (detectResults: DetectResult[], illegalDirections: DetectResult[]) => DetectResult[] | null;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { Point } from '@plait/core';
|
|
2
|
-
import { DetectResult, MindNode } from '../interfaces';
|
|
3
|
-
/**
|
|
4
|
-
*
|
|
5
|
-
* @param targetNode
|
|
6
|
-
* @param centerPoint
|
|
7
|
-
* @returns DetectResult[] | null
|
|
8
|
-
*/
|
|
9
|
-
export declare const directionDetector: (targetNode: MindNode, centerPoint: Point) => DetectResult[] | null;
|
package/utils/dnd.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { MindElement } from '../interfaces/element';
|
|
2
|
-
import { MindNodeComponent } from '../node.component';
|
|
3
|
-
import { Path, PlaitBoard } from '@plait/core';
|
|
4
|
-
import { MindLayoutType } from '@plait/layouts';
|
|
5
|
-
import { DetectResult } from '../interfaces/node';
|
|
6
|
-
export declare const isValidTarget: (origin: MindElement, target: MindElement) => boolean;
|
|
7
|
-
export declare const addActiveOnDragOrigin: (activeElement: MindElement, isOrigin?: boolean) => void;
|
|
8
|
-
export declare const removeActiveOnDragOrigin: (activeElement: MindElement, isOrigin?: boolean) => void;
|
|
9
|
-
export declare const updatePathByLayoutAndDropTarget: (targetPath: Path, layout: MindLayoutType, dropTarget: {
|
|
10
|
-
target: MindElement;
|
|
11
|
-
detectResult: DetectResult;
|
|
12
|
-
}) => Path;
|
|
13
|
-
export declare const updateRightNodeCount: (board: PlaitBoard, activeComponent: MindNodeComponent, targetComponent: MindNodeComponent, detectResult: DetectResult) => void;
|
|
14
|
-
export declare const isDragging: (board: PlaitBoard) => boolean;
|
|
15
|
-
export declare const setIsDragging: (board: PlaitBoard, state: boolean) => void;
|
|
16
|
-
export declare const updateAbstractInDnd: (board: PlaitBoard, deletableElements: MindElement[], originPath: Path) => void;
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { DetectResult, MindElement, MindNode } from '../interfaces';
|
|
2
|
-
import { MindNodeComponent } from '../node.component';
|
|
3
|
-
import { PlaitBoard } from '@plait/core';
|
|
4
|
-
import { MindLayoutType } from '@plait/layouts';
|
|
5
|
-
export declare const drawPlaceholderDropNodeG: (board: PlaitBoard, dropTarget: {
|
|
6
|
-
target: MindElement;
|
|
7
|
-
detectResult: DetectResult;
|
|
8
|
-
}, fakeDropNodeG: SVGGElement | undefined) => void;
|
|
9
|
-
export declare const drawCurvePlaceholderDropNodeG: (board: PlaitBoard, targetRect: {
|
|
10
|
-
x: number;
|
|
11
|
-
y: number;
|
|
12
|
-
width: number;
|
|
13
|
-
height: number;
|
|
14
|
-
}, detectResult: DetectResult, targetIndex: number, targetComponent: MindNodeComponent, parentComponent: MindNodeComponent, fakeDropNodeG: SVGGElement | undefined) => void;
|
|
15
|
-
export declare const drawStraightDropNodeG: (board: PlaitBoard, targetRect: {
|
|
16
|
-
x: number;
|
|
17
|
-
y: number;
|
|
18
|
-
width: number;
|
|
19
|
-
height: number;
|
|
20
|
-
}, detectResult: DetectResult, targetComponent: MindNodeComponent, fakeDropNodeG: SVGGElement | undefined) => void;
|
|
21
|
-
export declare const getHorizontalFakeY: (detectResult: 'top' | 'bottom', targetIndex: number, parentNode: MindNode, targetRect: {
|
|
22
|
-
x: number;
|
|
23
|
-
y: number;
|
|
24
|
-
width: number;
|
|
25
|
-
height: number;
|
|
26
|
-
}, layout: MindLayoutType, fakeY: number) => number;
|
|
27
|
-
export declare const getIndentedFakePoint: (layout: MindLayoutType, pointOptions: {
|
|
28
|
-
fakeX: number;
|
|
29
|
-
fakeY: number;
|
|
30
|
-
x: number;
|
|
31
|
-
y: number;
|
|
32
|
-
width: number;
|
|
33
|
-
height: number;
|
|
34
|
-
strokeWidth: number;
|
|
35
|
-
}) => {
|
|
36
|
-
fakeX: number;
|
|
37
|
-
fakeY: number;
|
|
38
|
-
};
|
|
39
|
-
export declare const drawIndentNodeG: (board: PlaitBoard, fakeDropNodeG: SVGGElement, fakePoint: {
|
|
40
|
-
fakeX: number;
|
|
41
|
-
fakeY: number;
|
|
42
|
-
}, node: MindNode) => void;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DetectResult, MindElement } from '../interfaces';
|
|
2
|
-
import { PlaitBoard } from '@plait/core';
|
|
3
|
-
export declare const readjustmentDropTarget: (board: PlaitBoard, dropTarget: {
|
|
4
|
-
target: MindElement;
|
|
5
|
-
detectResult: DetectResult;
|
|
6
|
-
}) => {
|
|
7
|
-
target: MindElement;
|
|
8
|
-
detectResult: DetectResult;
|
|
9
|
-
};
|
package/utils/graph.d.ts
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { MindNode } from '../interfaces/node';
|
|
2
|
-
import { PlaitBoard, Point, RectangleClient } from '@plait/core';
|
|
3
|
-
import { MindElement } from '../interfaces';
|
|
4
|
-
export declare function getRectangleByNode(node: MindNode): RectangleClient;
|
|
5
|
-
export declare function hitMindElement(board: PlaitBoard, point: Point, element: MindElement): boolean;
|
|
File without changes
|
|
File without changes
|