@plait/mind 0.2.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/README.md +24 -0
- package/constants/default.d.ts +12 -0
- package/constants/index.d.ts +2 -0
- package/constants/node.d.ts +17 -0
- package/draw/abstract.d.ts +4 -0
- package/draw/indented-link.d.ts +3 -0
- package/draw/link/abstract-link.d.ts +3 -0
- package/draw/link/logic-link.d.ts +3 -0
- package/draw/link.d.ts +3 -0
- package/draw/richtext.d.ts +14 -0
- package/draw/shape.d.ts +3 -0
- package/esm2020/constants/default.mjs +13 -0
- package/esm2020/constants/index.mjs +3 -0
- package/esm2020/constants/node.mjs +19 -0
- package/esm2020/draw/abstract.mjs +48 -0
- package/esm2020/draw/indented-link.mjs +44 -0
- package/esm2020/draw/link/abstract-link.mjs +42 -0
- package/esm2020/draw/link/logic-link.mjs +51 -0
- package/esm2020/draw/link.mjs +158 -0
- package/esm2020/draw/richtext.mjs +35 -0
- package/esm2020/draw/shape.mjs +18 -0
- package/esm2020/interfaces/abstract.mjs +6 -0
- package/esm2020/interfaces/element-data.mjs +2 -0
- package/esm2020/interfaces/element.mjs +59 -0
- package/esm2020/interfaces/index.mjs +6 -0
- package/esm2020/interfaces/layout.mjs +19 -0
- package/esm2020/interfaces/node.mjs +23 -0
- package/esm2020/interfaces/types.mjs +13 -0
- package/esm2020/layout-option.mjs +72 -0
- package/esm2020/mind.component.mjs +50 -0
- package/esm2020/mind.module.mjs +21 -0
- package/esm2020/node.component.mjs +742 -0
- package/esm2020/plait-mind.mjs +5 -0
- package/esm2020/plugins/emoji/emoji-base.component.mjs +21 -0
- package/esm2020/plugins/emoji/emoji.drawer.mjs +79 -0
- package/esm2020/plugins/emoji/emoji.mjs +15 -0
- package/esm2020/plugins/emoji/index.mjs +4 -0
- package/esm2020/plugins/emoji/with-mind-emoji.mjs +8 -0
- package/esm2020/plugins/with-abstract.mjs +92 -0
- package/esm2020/plugins/with-dnd.mjs +276 -0
- package/esm2020/plugins/with-mind.mjs +183 -0
- package/esm2020/public-api.mjs +14 -0
- package/esm2020/queries/get-available-sublayouts-by-element.mjs +29 -0
- package/esm2020/queries/get-branch-mindmap-layouts-by-element.mjs +18 -0
- package/esm2020/queries/get-correct-layout-by-element.mjs +50 -0
- package/esm2020/queries/get-layout-by-element.mjs +16 -0
- package/esm2020/queries/get-layout-parent-by-element.mjs +17 -0
- package/esm2020/queries/index.mjs +13 -0
- package/esm2020/transforms/index.mjs +10 -0
- package/esm2020/transforms/layout.mjs +23 -0
- package/esm2020/transforms/node.mjs +44 -0
- package/esm2020/utils/abstract/common.mjs +25 -0
- package/esm2020/utils/abstract/resize.mjs +169 -0
- package/esm2020/utils/clipboard.mjs +71 -0
- package/esm2020/utils/colors.mjs +41 -0
- package/esm2020/utils/direction-corrector.mjs +54 -0
- package/esm2020/utils/direction-detector.mjs +56 -0
- package/esm2020/utils/draw-placeholder.mjs +311 -0
- package/esm2020/utils/drop-target-corrector.mjs +86 -0
- package/esm2020/utils/graph.mjs +24 -0
- package/esm2020/utils/index.mjs +14 -0
- package/esm2020/utils/is-virtual-key.mjs +13 -0
- package/esm2020/utils/layout.mjs +105 -0
- package/esm2020/utils/mindmap.mjs +295 -0
- package/esm2020/utils/node-space.mjs +72 -0
- package/esm2020/utils/node.mjs +6 -0
- package/esm2020/utils/path.mjs +11 -0
- package/esm2020/utils/point-placement.mjs +99 -0
- package/esm2020/utils/shape.mjs +17 -0
- package/esm2020/utils/weak-maps.mjs +3 -0
- package/fesm2015/plait-mind.mjs +3583 -0
- package/fesm2015/plait-mind.mjs.map +1 -0
- package/fesm2020/plait-mind.mjs +3595 -0
- package/fesm2020/plait-mind.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/interfaces/abstract.d.ts +4 -0
- package/interfaces/element-data.d.ts +11 -0
- package/interfaces/element.d.ts +39 -0
- package/interfaces/index.d.ts +5 -0
- package/interfaces/layout.d.ts +10 -0
- package/interfaces/node.d.ts +33 -0
- package/interfaces/types.d.ts +11 -0
- package/layout-option.d.ts +2 -0
- package/mind.component.d.ts +16 -0
- package/mind.module.d.ts +11 -0
- package/node.component.d.ts +60 -0
- package/package.json +31 -0
- package/plugins/emoji/emoji-base.component.d.ts +12 -0
- package/plugins/emoji/emoji.d.ts +6 -0
- package/plugins/emoji/emoji.drawer.d.ts +22 -0
- package/plugins/emoji/index.d.ts +3 -0
- package/plugins/emoji/with-mind-emoji.d.ts +8 -0
- package/plugins/with-abstract.d.ts +2 -0
- package/plugins/with-dnd.d.ts +11 -0
- package/plugins/with-mind.d.ts +2 -0
- package/public-api.d.ts +10 -0
- package/queries/get-available-sublayouts-by-element.d.ts +8 -0
- package/queries/get-branch-mindmap-layouts-by-element.d.ts +3 -0
- package/queries/get-correct-layout-by-element.d.ts +9 -0
- package/queries/get-layout-by-element.d.ts +3 -0
- package/queries/get-layout-parent-by-element.d.ts +8 -0
- package/queries/index.d.ts +7 -0
- package/styles/styles.scss +99 -0
- package/transforms/index.d.ts +7 -0
- package/transforms/layout.d.ts +3 -0
- package/transforms/node.d.ts +8 -0
- package/utils/abstract/common.d.ts +5 -0
- package/utils/abstract/resize.d.ts +21 -0
- package/utils/clipboard.d.ts +7 -0
- package/utils/colors.d.ts +4 -0
- package/utils/direction-corrector.d.ts +3 -0
- package/utils/direction-detector.d.ts +9 -0
- package/utils/draw-placeholder.d.ts +42 -0
- package/utils/drop-target-corrector.d.ts +8 -0
- package/utils/graph.d.ts +5 -0
- package/utils/index.d.ts +13 -0
- package/utils/is-virtual-key.d.ts +1 -0
- package/utils/layout.d.ts +12 -0
- package/utils/mindmap.d.ts +33 -0
- package/utils/node-space.d.ts +9 -0
- package/utils/node.d.ts +2 -0
- package/utils/path.d.ts +4 -0
- package/utils/point-placement.d.ts +8 -0
- package/utils/shape.d.ts +3 -0
- package/utils/weak-maps.d.ts +5 -0
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhaXQtbWluZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3BsYWl0LW1pbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class MindEmojiBaseComponent {
|
|
4
|
+
get nativeElement() {
|
|
5
|
+
return this.elementRef.nativeElement;
|
|
6
|
+
}
|
|
7
|
+
constructor(elementRef) {
|
|
8
|
+
this.elementRef = elementRef;
|
|
9
|
+
this.fontSize = 14;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
MindEmojiBaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindEmojiBaseComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
13
|
+
MindEmojiBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: MindEmojiBaseComponent, inputs: { fontSize: "fontSize", emojiItem: "emojiItem" }, ngImport: i0 });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindEmojiBaseComponent, decorators: [{
|
|
15
|
+
type: Directive
|
|
16
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { fontSize: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], emojiItem: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}] } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9wbHVnaW5zL2Vtb2ppL2Vtb2ppLWJhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUk3RCxNQUFNLE9BQU8sc0JBQXNCO0lBTy9CLElBQUksYUFBYTtRQUNiLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7SUFDekMsQ0FBQztJQUVELFlBQXNCLFVBQW1DO1FBQW5DLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBVHpELGFBQVEsR0FBVyxFQUFFLENBQUM7SUFTc0MsQ0FBQzs7bUhBWHBELHNCQUFzQjt1R0FBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7a0JBRGxDLFNBQVM7aUdBR04sUUFBUTtzQkFEUCxLQUFLO2dCQUlOLFNBQVM7c0JBRFIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEVtb2ppSXRlbSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvZWxlbWVudC1kYXRhJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgTWluZEVtb2ppQmFzZUNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBmb250U2l6ZTogbnVtYmVyID0gMTQ7XG5cbiAgICBASW5wdXQoKVxuICAgIGVtb2ppSXRlbSE6IEVtb2ppSXRlbTtcblxuICAgIGdldCBuYXRpdmVFbGVtZW50KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHJvdGVjdGVkIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+KSB7fVxufVxuIl19
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { MindElement, PlaitMind } from '../../interfaces';
|
|
2
|
+
import { createForeignObject } from '@plait/richtext';
|
|
3
|
+
import { createG } from '@plait/core';
|
|
4
|
+
import { getRectangleByNode } from '../../utils/graph';
|
|
5
|
+
import { getEmojiFontSize, getEmojisRectangle } from './emoji';
|
|
6
|
+
import { NodeSpace } from '../../utils/node-space';
|
|
7
|
+
export class EmojiDrawer {
|
|
8
|
+
constructor(board, viewContainerRef) {
|
|
9
|
+
this.board = board;
|
|
10
|
+
this.viewContainerRef = viewContainerRef;
|
|
11
|
+
this.componentRef = null;
|
|
12
|
+
}
|
|
13
|
+
draw(emoji, element) {
|
|
14
|
+
this.destroy();
|
|
15
|
+
const componentType = this.board.drawEmoji(emoji, element);
|
|
16
|
+
this.componentRef = this.viewContainerRef.createComponent(componentType);
|
|
17
|
+
this.componentRef.instance.emojiItem = emoji;
|
|
18
|
+
const fontSize = PlaitMind.isMind(element) ? 18 : 14;
|
|
19
|
+
this.componentRef.instance.fontSize = fontSize;
|
|
20
|
+
}
|
|
21
|
+
get nativeElement() {
|
|
22
|
+
if (this.componentRef) {
|
|
23
|
+
return this.componentRef.instance.nativeElement;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
destroy() {
|
|
30
|
+
if (this.componentRef) {
|
|
31
|
+
this.componentRef.destroy();
|
|
32
|
+
this.componentRef = null;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
export class EmojisDrawer {
|
|
37
|
+
constructor(board, viewContainerRef) {
|
|
38
|
+
this.board = board;
|
|
39
|
+
this.viewContainerRef = viewContainerRef;
|
|
40
|
+
this.emojiDrawers = [];
|
|
41
|
+
}
|
|
42
|
+
drawEmojis(element) {
|
|
43
|
+
this.destroy();
|
|
44
|
+
if (MindElement.hasEmojis(element)) {
|
|
45
|
+
const node = MindElement.getNode(element);
|
|
46
|
+
this.g = createG();
|
|
47
|
+
this.g.classList.add('emojis');
|
|
48
|
+
let { x, y } = getRectangleByNode(MindElement.getNode(element));
|
|
49
|
+
x = x + NodeSpace.getEmojiHorizontalSpace(element);
|
|
50
|
+
y = y + NodeSpace.getEmojiVerticalSpace(element);
|
|
51
|
+
const { width, height } = getEmojisRectangle(element);
|
|
52
|
+
const fontSize = getEmojiFontSize(element);
|
|
53
|
+
const foreignObject = createForeignObject(x, y, width, height);
|
|
54
|
+
this.g.append(foreignObject);
|
|
55
|
+
const container = document.createElement('div');
|
|
56
|
+
container.classList.add('node-emojis-container');
|
|
57
|
+
container.classList.add(`emoji-font-size-${fontSize}`);
|
|
58
|
+
foreignObject.append(container);
|
|
59
|
+
this.emojiDrawers = element.data.emojis.map(emojiItem => {
|
|
60
|
+
const drawer = new EmojiDrawer(this.board, this.viewContainerRef);
|
|
61
|
+
drawer.draw(emojiItem, element);
|
|
62
|
+
return drawer;
|
|
63
|
+
});
|
|
64
|
+
this.emojiDrawers.forEach(drawer => {
|
|
65
|
+
container.append(drawer.nativeElement);
|
|
66
|
+
});
|
|
67
|
+
return this.g;
|
|
68
|
+
}
|
|
69
|
+
return undefined;
|
|
70
|
+
}
|
|
71
|
+
destroy() {
|
|
72
|
+
if (this.g) {
|
|
73
|
+
this.g.remove();
|
|
74
|
+
}
|
|
75
|
+
this.emojiDrawers.forEach(drawer => drawer.destroy());
|
|
76
|
+
this.emojiDrawers = [];
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji.drawer.js","sourceRoot":"","sources":["../../../../../packages/mind/src/plugins/emoji/emoji.drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, ViewContainerRef } from '@angular/core';\nimport { EmojiItem, MindElement, PlaitMind } from '../../interfaces';\nimport { MindEmojiBaseComponent } from './emoji-base.component';\nimport { PlaitMindEmojiBoard } from './with-mind-emoji';\nimport { createForeignObject } from '@plait/richtext';\nimport { createG } from '@plait/core';\nimport { getRectangleByNode } from '../../utils/graph';\nimport { getEmojiFontSize, getEmojisRectangle } from './emoji';\nimport { NodeSpace } from '../../utils/node-space';\n\nexport class EmojiDrawer {\n    componentRef: ComponentRef<MindEmojiBaseComponent> | null = null;\n\n    constructor(private board: PlaitMindEmojiBoard, private viewContainerRef: ViewContainerRef) {}\n\n    draw(emoji: EmojiItem, element: MindElement) {\n        this.destroy();\n        const componentType = this.board.drawEmoji(emoji, element);\n        this.componentRef = this.viewContainerRef.createComponent(componentType);\n        this.componentRef.instance.emojiItem = emoji;\n        const fontSize = PlaitMind.isMind(element) ? 18 : 14;\n        this.componentRef.instance.fontSize = fontSize;\n    }\n\n    get nativeElement() {\n        if (this.componentRef) {\n            return this.componentRef.instance.nativeElement;\n        } else {\n            return null;\n        }\n    }\n\n    destroy() {\n        if (this.componentRef) {\n            this.componentRef.destroy();\n            this.componentRef = null;\n        }\n    }\n}\n\nexport class EmojisDrawer {\n    emojiDrawers: EmojiDrawer[] = [];\n\n    g?: SVGGElement;\n\n    constructor(private board: PlaitMindEmojiBoard, private viewContainerRef: ViewContainerRef) {}\n\n    drawEmojis(element: MindElement) {\n        this.destroy();\n        if (MindElement.hasEmojis(element)) {\n            const node = MindElement.getNode(element);\n            this.g = createG();\n            this.g.classList.add('emojis');\n            let { x, y } = getRectangleByNode(MindElement.getNode(element));\n            x = x + NodeSpace.getEmojiHorizontalSpace(element);\n            y = y + NodeSpace.getEmojiVerticalSpace(element);\n            const { width, height } = getEmojisRectangle(element);\n            const fontSize = getEmojiFontSize(element);\n            const foreignObject = createForeignObject(x, y, width, height);\n            this.g.append(foreignObject);\n            const container = document.createElement('div');\n            container.classList.add('node-emojis-container');\n            container.classList.add(`emoji-font-size-${fontSize}`);\n            foreignObject.append(container);\n            this.emojiDrawers = element.data.emojis.map(emojiItem => {\n                const drawer = new EmojiDrawer(this.board, this.viewContainerRef);\n                drawer.draw(emojiItem, element);\n                return drawer;\n            });\n            this.emojiDrawers.forEach(drawer => {\n                container.append(drawer.nativeElement!);\n            });\n            return this.g;\n        }\n        return undefined;\n    }\n\n    destroy() {\n        if (this.g) {\n            this.g.remove();\n        }\n        this.emojiDrawers.forEach(drawer => drawer.destroy());\n        this.emojiDrawers = [];\n    }\n}\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PlaitMind } from '../../interfaces';
|
|
2
|
+
export function getEmojisRectangle(element) {
|
|
3
|
+
const count = element.data.emojis.length;
|
|
4
|
+
const fontSize = getEmojiFontSize(element);
|
|
5
|
+
return { width: fontSize * count, height: fontSize * 1.5 };
|
|
6
|
+
}
|
|
7
|
+
export function getEmojiFontSize(element) {
|
|
8
|
+
if (PlaitMind.isMind(element)) {
|
|
9
|
+
return 18;
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
return 14;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9wbHVnaW5zL2Vtb2ppL2Vtb2ppLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBMEIsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFckUsTUFBTSxVQUFVLGtCQUFrQixDQUFDLE9BQStCO0lBQzlELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQztJQUN6QyxNQUFNLFFBQVEsR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFFBQVEsR0FBRyxLQUFLLEVBQUUsTUFBTSxFQUFFLFFBQVEsR0FBRyxHQUFHLEVBQUUsQ0FBQztBQUMvRCxDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLE9BQStCO0lBQzVELElBQUksU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUMzQixPQUFPLEVBQUUsQ0FBQztLQUNiO1NBQU07UUFDSCxPQUFPLEVBQUUsQ0FBQztLQUNiO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVtb2ppRGF0YSwgTWluZEVsZW1lbnQsIFBsYWl0TWluZCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RW1vamlzUmVjdGFuZ2xlKGVsZW1lbnQ6IE1pbmRFbGVtZW50PEVtb2ppRGF0YT4pIHtcbiAgICBjb25zdCBjb3VudCA9IGVsZW1lbnQuZGF0YS5lbW9qaXMubGVuZ3RoO1xuICAgIGNvbnN0IGZvbnRTaXplID0gZ2V0RW1vamlGb250U2l6ZShlbGVtZW50KTtcbiAgICByZXR1cm4geyB3aWR0aDogZm9udFNpemUgKiBjb3VudCwgaGVpZ2h0OiBmb250U2l6ZSAqIDEuNSB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RW1vamlGb250U2l6ZShlbGVtZW50OiBNaW5kRWxlbWVudDxFbW9qaURhdGE+KSB7XG4gICAgaWYgKFBsYWl0TWluZC5pc01pbmQoZWxlbWVudCkpIHtcbiAgICAgICAgcmV0dXJuIDE4O1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiAxNDtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './with-mind-emoji';
|
|
2
|
+
export * from './emoji';
|
|
3
|
+
export * from './emoji-base.component';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9wbHVnaW5zL2Vtb2ppL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2l0aC1taW5kLWVtb2ppJztcbmV4cG9ydCAqIGZyb20gJy4vZW1vamknO1xuZXhwb3J0ICogZnJvbSAnLi9lbW9qaS1iYXNlLmNvbXBvbmVudCc7Il19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export const withEmoji = (board) => {
|
|
2
|
+
const newBoard = board;
|
|
3
|
+
newBoard.drawEmoji = (emoji, element) => {
|
|
4
|
+
throw new Error('Not implement drawEmoji method error.');
|
|
5
|
+
};
|
|
6
|
+
return newBoard;
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1taW5kLWVtb2ppLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvcGx1Z2lucy9lbW9qaS93aXRoLW1pbmQtZW1vamkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBU0EsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQzNDLE1BQU0sUUFBUSxHQUFHLEtBQXlDLENBQUM7SUFFM0QsUUFBUSxDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQWdCLEVBQUUsT0FBb0IsRUFBRSxFQUFFO1FBQzVELE1BQU0sSUFBSSxLQUFLLENBQUMsdUNBQXVDLENBQUMsQ0FBQztJQUM3RCxDQUFDLENBQUE7SUFFRCxPQUFPLFFBQVEsQ0FBQztBQUNwQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRUeXBlLCBQbGFpdEJvYXJkLCBQbGFpdFBsdWdpbiB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IEVtb2ppSXRlbSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvZWxlbWVudC1kYXRhJztcbmltcG9ydCB7IE1pbmRFbW9qaUJhc2VDb21wb25lbnQgfSBmcm9tICcuL2Vtb2ppLWJhc2UuY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdE1pbmRFbW9qaUJvYXJkIGV4dGVuZHMgUGxhaXRCb2FyZCB7XG4gICAgZHJhd0Vtb2ppOiAoZW1vamk6IEVtb2ppSXRlbSwgZWxlbWVudDogTWluZEVsZW1lbnQpID0+IENvbXBvbmVudFR5cGU8TWluZEVtb2ppQmFzZUNvbXBvbmVudD47XG59XG5cbmV4cG9ydCBjb25zdCB3aXRoRW1vamkgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBuZXdCb2FyZCA9IGJvYXJkIGFzIFBsYWl0Qm9hcmQgJiBQbGFpdE1pbmRFbW9qaUJvYXJkO1xuXG4gICAgbmV3Qm9hcmQuZHJhd0Vtb2ppID0gKGVtb2ppOiBFbW9qaUl0ZW0sIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSA9PiB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignTm90IGltcGxlbWVudCBkcmF3RW1vamkgbWV0aG9kIGVycm9yLicpO1xuICAgIH1cblxuICAgIHJldHVybiBuZXdCb2FyZDtcbn07Il19
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { BOARD_TO_HOST, PlaitBoard, PlaitElement, Transforms, getSelectedElements, toPoint, transformPoint } from '@plait/core';
|
|
2
|
+
import { AbstractNode, isHorizontalLayout, isStandardLayout } from '@plait/layouts';
|
|
3
|
+
import { AbstractHandlePosition, MindElement } from '../interfaces';
|
|
4
|
+
import { MindmapQueries } from '../public-api';
|
|
5
|
+
import { findLocationLeftIndex, getHitAbstractHandle, getLocationScope } from '../utils/abstract/resize';
|
|
6
|
+
import { separateChildren } from '../utils/abstract/common';
|
|
7
|
+
export const withAbstract = (board) => {
|
|
8
|
+
const { mousedown, mousemove, mouseup } = board;
|
|
9
|
+
let activeAbstractElement;
|
|
10
|
+
let abstractHandlePosition;
|
|
11
|
+
let startPoint;
|
|
12
|
+
let newProperty;
|
|
13
|
+
board.mousedown = (event) => {
|
|
14
|
+
const activeAbstractElements = getSelectedElements(board).filter(element => AbstractNode.isAbstract(element));
|
|
15
|
+
const host = BOARD_TO_HOST.get(board);
|
|
16
|
+
const point = transformPoint(board, toPoint(event.x, event.y, host));
|
|
17
|
+
activeAbstractElement = activeAbstractElements.find(element => {
|
|
18
|
+
abstractHandlePosition = getHitAbstractHandle(board, element, point);
|
|
19
|
+
return abstractHandlePosition;
|
|
20
|
+
});
|
|
21
|
+
if (activeAbstractElement) {
|
|
22
|
+
startPoint = point;
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
mousedown(event);
|
|
26
|
+
};
|
|
27
|
+
board.mousemove = (event) => {
|
|
28
|
+
getSelectedElements(board);
|
|
29
|
+
const host = BOARD_TO_HOST.get(board);
|
|
30
|
+
const endPoint = transformPoint(board, toPoint(event.x, event.y, host));
|
|
31
|
+
if (abstractHandlePosition && activeAbstractElement) {
|
|
32
|
+
const abstractComponent = PlaitElement.getComponent(activeAbstractElement);
|
|
33
|
+
const element = abstractComponent.element;
|
|
34
|
+
const nodeLayout = MindmapQueries.getCorrectLayoutByElement(activeAbstractElement);
|
|
35
|
+
const isHorizontal = isHorizontalLayout(nodeLayout);
|
|
36
|
+
const parentElement = MindElement.getParent(element);
|
|
37
|
+
let children = parentElement.children;
|
|
38
|
+
const parentLayout = MindmapQueries.getLayoutByElement(parentElement);
|
|
39
|
+
if (isStandardLayout(parentLayout)) {
|
|
40
|
+
const rightNodeCount = parentElement.rightNodeCount;
|
|
41
|
+
const { leftChildren, rightChildren } = separateChildren(parentElement);
|
|
42
|
+
if (activeAbstractElement.end < rightNodeCount) {
|
|
43
|
+
children = rightChildren;
|
|
44
|
+
}
|
|
45
|
+
if (activeAbstractElement.start >= rightNodeCount) {
|
|
46
|
+
children = leftChildren;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
const resizingLocation = isHorizontal ? endPoint[1] : endPoint[0];
|
|
50
|
+
const parent = MindElement.getNode(parentElement);
|
|
51
|
+
const scope = getLocationScope(board, abstractHandlePosition, children, element, parent, isHorizontal);
|
|
52
|
+
const location = Math.min(scope.max, Math.max(scope.min, resizingLocation));
|
|
53
|
+
let locationIndex = findLocationLeftIndex(board, children, location, isHorizontal);
|
|
54
|
+
const isPropertyUnchanged = (abstractHandlePosition === AbstractHandlePosition.start &&
|
|
55
|
+
locationIndex + 1 === activeAbstractElement.start) ||
|
|
56
|
+
(abstractHandlePosition === AbstractHandlePosition.end && locationIndex === activeAbstractElement.end);
|
|
57
|
+
if (isPropertyUnchanged) {
|
|
58
|
+
newProperty = undefined;
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
if (isStandardLayout(parent.layout)) {
|
|
62
|
+
const rightNodeCount = parent.origin.rightNodeCount;
|
|
63
|
+
let start = element.start;
|
|
64
|
+
if (start >= rightNodeCount) {
|
|
65
|
+
locationIndex += rightNodeCount;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
newProperty =
|
|
69
|
+
abstractHandlePosition === AbstractHandlePosition.start ? { start: locationIndex + 1 } : { end: locationIndex };
|
|
70
|
+
}
|
|
71
|
+
abstractComponent.updateAbstractIncludedOutline(location, abstractHandlePosition);
|
|
72
|
+
}
|
|
73
|
+
mousemove(event);
|
|
74
|
+
};
|
|
75
|
+
board.mouseup = (event) => {
|
|
76
|
+
startPoint = undefined;
|
|
77
|
+
abstractHandlePosition = null;
|
|
78
|
+
if (activeAbstractElement) {
|
|
79
|
+
if (newProperty) {
|
|
80
|
+
const path = PlaitBoard.findPath(board, activeAbstractElement);
|
|
81
|
+
Transforms.setNode(board, newProperty, path);
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
const abstractComponent = PlaitElement.getComponent(activeAbstractElement);
|
|
85
|
+
abstractComponent.updateAbstractIncludedOutline();
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
mouseup(event);
|
|
89
|
+
};
|
|
90
|
+
return board;
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-abstract.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-abstract.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BOARD_TO_HOST,\n    PlaitBoard,\n    PlaitElement,\n    PlaitPlugin,\n    Point,\n    Transforms,\n    getSelectedElements,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { AbstractNode, LayoutNode, MindmapLayoutType, isHorizontalLayout, isStandardLayout } from '@plait/layouts';\nimport { AbstractHandlePosition, MindElement } from '../interfaces';\nimport { MindNodeComponent, MindmapQueries } from '../public-api';\nimport { findLocationLeftIndex, getHitAbstractHandle, getLocationScope } from '../utils/abstract/resize';\nimport { separateChildren } from '../utils/abstract/common';\n\nexport const withAbstract: PlaitPlugin = (board: PlaitBoard) => {\n    const { mousedown, mousemove, mouseup } = board;\n    let activeAbstractElement: PlaitElement | undefined;\n    let abstractHandlePosition: AbstractHandlePosition | null;\n    let startPoint: Point | undefined;\n    let newProperty: { end: number } | { start: number } | undefined;\n\n    board.mousedown = (event: MouseEvent) => {\n        const activeAbstractElements = getSelectedElements(board).filter(element => AbstractNode.isAbstract(element));\n        const host = BOARD_TO_HOST.get(board);\n        const point = transformPoint(board, toPoint(event.x, event.y, host!));\n\n        activeAbstractElement = activeAbstractElements.find(element => {\n            abstractHandlePosition = getHitAbstractHandle(board, element as MindElement, point);\n            return abstractHandlePosition;\n        });\n\n        if (activeAbstractElement) {\n            startPoint = point;\n            return;\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        getSelectedElements(board);\n        const host = BOARD_TO_HOST.get(board);\n        const endPoint = transformPoint(board, toPoint(event.x, event.y, host!));\n\n        if (abstractHandlePosition && activeAbstractElement) {\n            const abstractComponent = PlaitElement.getComponent(activeAbstractElement) as MindNodeComponent;\n            const element = abstractComponent.element;\n            const nodeLayout = MindmapQueries.getCorrectLayoutByElement(activeAbstractElement as MindElement) as MindmapLayoutType;\n            const isHorizontal = isHorizontalLayout(nodeLayout);\n            const parentElement = MindElement.getParent(element);\n\n            let children = parentElement.children;\n\n            const parentLayout = MindmapQueries.getLayoutByElement(parentElement);\n            if (isStandardLayout(parentLayout)) {\n                const rightNodeCount = parentElement.rightNodeCount!;\n                const { leftChildren, rightChildren } = separateChildren(parentElement);\n                if ((activeAbstractElement as MindElement).end! < rightNodeCount) {\n                    children = rightChildren;\n                }\n                if ((activeAbstractElement as MindElement).start! >= rightNodeCount) {\n                    children = leftChildren;\n                }\n            }\n\n            const resizingLocation = isHorizontal ? endPoint[1] : endPoint[0];\n            const parent = (MindElement.getNode(parentElement) as unknown) as LayoutNode;\n            const scope = getLocationScope(board, abstractHandlePosition, children, element, parent, isHorizontal);\n            const location = Math.min(scope.max, Math.max(scope.min, resizingLocation));\n\n            let locationIndex = findLocationLeftIndex(board, children, location, isHorizontal);\n\n            const isPropertyUnchanged =\n                (abstractHandlePosition === AbstractHandlePosition.start &&\n                    locationIndex + 1 === (activeAbstractElement as MindElement).start!) ||\n                (abstractHandlePosition === AbstractHandlePosition.end && locationIndex === (activeAbstractElement as MindElement).end!);\n\n            if (isPropertyUnchanged) {\n                newProperty = undefined;\n            } else {\n                if (isStandardLayout(parent.layout)) {\n                    const rightNodeCount = parent.origin.rightNodeCount;\n                    let start = element.start!;\n                    if (start >= rightNodeCount) {\n                        locationIndex += rightNodeCount;\n                    }\n                }\n\n                newProperty =\n                    abstractHandlePosition === AbstractHandlePosition.start ? { start: locationIndex + 1 } : { end: locationIndex };\n            }\n\n            abstractComponent!.updateAbstractIncludedOutline(location, abstractHandlePosition);\n        }\n        mousemove(event);\n    };\n\n    board.mouseup = (event: MouseEvent) => {\n        startPoint = undefined;\n        abstractHandlePosition = null;\n        if (activeAbstractElement) {\n            if (newProperty) {\n                const path = PlaitBoard.findPath(board, activeAbstractElement);\n                Transforms.setNode(board, newProperty, path);\n            } else {\n                const abstractComponent = PlaitElement.getComponent(activeAbstractElement) as MindNodeComponent;\n                abstractComponent!.updateAbstractIncludedOutline();\n            }\n        }\n        mouseup(event);\n    };\n    return board;\n};\n"]}
|
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
import { createG, distanceBetweenPointAndPoint, IS_TEXT_EDITABLE, Path, PlaitBoard, toPoint, transformPoint, Transforms, ELEMENT_TO_COMPONENT, getSelectedElements } from '@plait/core';
|
|
2
|
+
import { isBottomLayout, isHorizontalLogicLayout, isIndentedLayout, isLeftLayout, isRightLayout, isStandardLayout, isTopLayout, isVerticalLogicLayout } from '@plait/layouts';
|
|
3
|
+
import { updateForeignObject } from '@plait/richtext';
|
|
4
|
+
import { BASE } from '../constants';
|
|
5
|
+
import { getRichtextRectangleByNode } from '../draw/richtext';
|
|
6
|
+
import { drawRectangleNode } from '../draw/shape';
|
|
7
|
+
import { PlaitMind } from '../interfaces/element';
|
|
8
|
+
import { directionCorrector, directionDetector, drawPlaceholderDropNodeG, findUpElement, isChildElement, readjustmentDropTarget } from '../utils';
|
|
9
|
+
import { getRectangleByNode, hitMindmapElement } from '../utils/graph';
|
|
10
|
+
import { MINDMAP_ELEMENT_TO_COMPONENT } from '../utils/weak-maps';
|
|
11
|
+
import { MindmapQueries } from '../queries';
|
|
12
|
+
const DRAG_MOVE_BUFFER = 5;
|
|
13
|
+
export const withDnd = (board) => {
|
|
14
|
+
const { mousedown, mousemove, globalMouseup, keydown } = board;
|
|
15
|
+
let activeElement;
|
|
16
|
+
let startPoint;
|
|
17
|
+
let fakeDragNodeG;
|
|
18
|
+
let fakeDropNodeG;
|
|
19
|
+
let dropTarget = null;
|
|
20
|
+
board.mousedown = (event) => {
|
|
21
|
+
if (board.options.readonly || IS_TEXT_EDITABLE.get(board) || event.button === 2) {
|
|
22
|
+
mousedown(event);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
// 确认是否 hit 节点
|
|
26
|
+
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
27
|
+
const selectedElements = getSelectedElements(board);
|
|
28
|
+
board.children.forEach((value) => {
|
|
29
|
+
if (activeElement) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (PlaitMind.isMind(value)) {
|
|
33
|
+
const mindmapComponent = ELEMENT_TO_COMPONENT.get(value);
|
|
34
|
+
const root = mindmapComponent?.root;
|
|
35
|
+
root.eachNode((node) => {
|
|
36
|
+
if (activeElement) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (hitMindmapElement(board, point, node.origin) && !node.origin.isRoot && selectedElements.length <= 1) {
|
|
40
|
+
activeElement = node.origin;
|
|
41
|
+
startPoint = point;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
if (activeElement) {
|
|
47
|
+
event.preventDefault();
|
|
48
|
+
}
|
|
49
|
+
mousedown(event);
|
|
50
|
+
};
|
|
51
|
+
board.mousemove = (event) => {
|
|
52
|
+
if (!board.options.readonly && activeElement && startPoint) {
|
|
53
|
+
const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
54
|
+
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
55
|
+
if (distance < DRAG_MOVE_BUFFER) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
if (!isDragging(board)) {
|
|
59
|
+
setIsDragging(board, true);
|
|
60
|
+
fakeDragNodeG = createG();
|
|
61
|
+
fakeDragNodeG.classList.add('dragging', 'fake-node', 'plait-board-attached');
|
|
62
|
+
fakeDropNodeG = createG();
|
|
63
|
+
addActiveOnDragOrigin(activeElement);
|
|
64
|
+
PlaitBoard.getHost(board).appendChild(fakeDropNodeG);
|
|
65
|
+
PlaitBoard.getHost(board).appendChild(fakeDragNodeG);
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
fakeDragNodeG?.childNodes.forEach(node => {
|
|
69
|
+
node.remove();
|
|
70
|
+
});
|
|
71
|
+
fakeDropNodeG?.childNodes.forEach(node => {
|
|
72
|
+
node.remove();
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
// fake dragging origin node
|
|
76
|
+
const offsetX = endPoint[0] - startPoint[0];
|
|
77
|
+
const offsetY = endPoint[1] - startPoint[1];
|
|
78
|
+
const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement);
|
|
79
|
+
const roughSVG = PlaitBoard.getRoughSVG(board);
|
|
80
|
+
const fakeDraggingNode = {
|
|
81
|
+
...activeComponent.node,
|
|
82
|
+
children: [],
|
|
83
|
+
x: activeComponent.node.x + offsetX,
|
|
84
|
+
y: activeComponent.node.y + offsetY
|
|
85
|
+
};
|
|
86
|
+
const textRectangle = getRichtextRectangleByNode(activeComponent.node);
|
|
87
|
+
const fakeNodeG = drawRectangleNode(board, fakeDraggingNode);
|
|
88
|
+
const richtextG = activeComponent.richtextG?.cloneNode(true);
|
|
89
|
+
updateForeignObject(richtextG, textRectangle.width + BASE * 10, textRectangle.height, textRectangle.x + offsetX, textRectangle.y + offsetY);
|
|
90
|
+
fakeDragNodeG?.append(fakeNodeG);
|
|
91
|
+
fakeDragNodeG?.append(richtextG);
|
|
92
|
+
// drop position detect
|
|
93
|
+
const { x, y } = getRectangleByNode(fakeDraggingNode);
|
|
94
|
+
const detectCenterPoint = [x + textRectangle.width / 2, y + textRectangle.height / 2];
|
|
95
|
+
let detectResult = null;
|
|
96
|
+
board.children.forEach((value) => {
|
|
97
|
+
if (detectResult) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
if (PlaitMind.isMind(value)) {
|
|
101
|
+
const mindmapComponent = ELEMENT_TO_COMPONENT.get(value);
|
|
102
|
+
const root = mindmapComponent?.root;
|
|
103
|
+
root.eachNode((node) => {
|
|
104
|
+
if (detectResult) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
const directions = directionDetector(node, detectCenterPoint);
|
|
108
|
+
if (directions) {
|
|
109
|
+
detectResult = directionCorrector(node, directions);
|
|
110
|
+
}
|
|
111
|
+
dropTarget = null;
|
|
112
|
+
if (detectResult && isValidTarget(activeComponent.node.origin, node.origin)) {
|
|
113
|
+
dropTarget = { target: node.origin, detectResult: detectResult[0] };
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
if (dropTarget?.target) {
|
|
119
|
+
dropTarget = readjustmentDropTarget(dropTarget);
|
|
120
|
+
drawPlaceholderDropNodeG(dropTarget, roughSVG, fakeDropNodeG);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
mousemove(event);
|
|
124
|
+
};
|
|
125
|
+
board.globalMouseup = (event) => {
|
|
126
|
+
if (!board.options.readonly && activeElement) {
|
|
127
|
+
if (dropTarget?.target) {
|
|
128
|
+
const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement);
|
|
129
|
+
const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(dropTarget.target);
|
|
130
|
+
let targetPath = PlaitBoard.findPath(board, targetComponent.element);
|
|
131
|
+
const mindmapElement = findUpElement(dropTarget.target).root;
|
|
132
|
+
const mindmapComponent = ELEMENT_TO_COMPONENT.get(mindmapElement);
|
|
133
|
+
const layout = MindmapQueries.getCorrectLayoutByElement(mindmapComponent?.root.origin);
|
|
134
|
+
targetPath = updatePathByLayoutAndDropTarget(targetPath, layout, dropTarget);
|
|
135
|
+
const originPath = PlaitBoard.findPath(board, activeComponent.element);
|
|
136
|
+
let newElement = { isCollapsed: false }, rightTargetPath = PlaitBoard.findPath(board, targetComponent.element);
|
|
137
|
+
if (isStandardLayout(layout)) {
|
|
138
|
+
updateRightNodeCount(board, activeComponent, targetComponent, dropTarget.detectResult);
|
|
139
|
+
}
|
|
140
|
+
if (dropTarget.detectResult === 'right') {
|
|
141
|
+
if (targetComponent.node.origin.isRoot) {
|
|
142
|
+
targetPath = PlaitBoard.findPath(board, targetComponent.element);
|
|
143
|
+
targetPath.push(0);
|
|
144
|
+
const rightNodeCount = targetComponent.node.origin.rightNodeCount + 1;
|
|
145
|
+
newElement = { isCollapsed: false, rightNodeCount };
|
|
146
|
+
}
|
|
147
|
+
Transforms.setNode(board, newElement, rightTargetPath);
|
|
148
|
+
}
|
|
149
|
+
Transforms.moveNode(board, originPath, targetPath);
|
|
150
|
+
}
|
|
151
|
+
if (isDragging(board)) {
|
|
152
|
+
removeActiveOnDragOrigin(activeElement);
|
|
153
|
+
}
|
|
154
|
+
setIsDragging(board, false);
|
|
155
|
+
activeElement = null;
|
|
156
|
+
fakeDragNodeG?.remove();
|
|
157
|
+
fakeDragNodeG = undefined;
|
|
158
|
+
fakeDropNodeG?.remove();
|
|
159
|
+
fakeDropNodeG = undefined;
|
|
160
|
+
dropTarget = null;
|
|
161
|
+
}
|
|
162
|
+
globalMouseup(event);
|
|
163
|
+
};
|
|
164
|
+
board.keydown = (event) => {
|
|
165
|
+
keydown(event);
|
|
166
|
+
};
|
|
167
|
+
return board;
|
|
168
|
+
};
|
|
169
|
+
export const isValidTarget = (origin, target) => {
|
|
170
|
+
return origin !== target && !isChildElement(origin, target);
|
|
171
|
+
};
|
|
172
|
+
export const addActiveOnDragOrigin = (activeElement, isOrigin = true) => {
|
|
173
|
+
const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement);
|
|
174
|
+
if (isOrigin) {
|
|
175
|
+
activeComponent.g.classList.add('dragging-origin');
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
activeComponent.g.classList.add('dragging-child');
|
|
179
|
+
}
|
|
180
|
+
!activeElement.isCollapsed &&
|
|
181
|
+
activeElement.children.forEach(child => {
|
|
182
|
+
addActiveOnDragOrigin(child, false);
|
|
183
|
+
});
|
|
184
|
+
};
|
|
185
|
+
export const removeActiveOnDragOrigin = (activeElement, isOrigin = true) => {
|
|
186
|
+
const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement);
|
|
187
|
+
if (isOrigin) {
|
|
188
|
+
activeComponent.g.classList.remove('dragging-origin');
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
activeComponent.g.classList.remove('dragging-child');
|
|
192
|
+
}
|
|
193
|
+
!activeElement.isCollapsed &&
|
|
194
|
+
activeElement.children.forEach(child => {
|
|
195
|
+
removeActiveOnDragOrigin(child, false);
|
|
196
|
+
});
|
|
197
|
+
};
|
|
198
|
+
const updatePathByLayoutAndDropTarget = (targetPath, layout, dropTarget) => {
|
|
199
|
+
// 上下布局:左右是兄弟节点,上下是子节点
|
|
200
|
+
if (isVerticalLogicLayout(layout)) {
|
|
201
|
+
if (isTopLayout(layout) && dropTarget.detectResult === 'top') {
|
|
202
|
+
targetPath.push(dropTarget.target.children.length);
|
|
203
|
+
}
|
|
204
|
+
if (isBottomLayout(layout) && dropTarget.detectResult === 'bottom') {
|
|
205
|
+
targetPath.push(dropTarget.target.children.length);
|
|
206
|
+
}
|
|
207
|
+
// 如果是左,位置不变,右则插入到下一个兄弟节点
|
|
208
|
+
if (dropTarget.detectResult === 'right') {
|
|
209
|
+
targetPath = Path.next(targetPath);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
// 水平布局/标准布局:上下是兄弟节点,左右是子节点
|
|
213
|
+
if (isHorizontalLogicLayout(layout)) {
|
|
214
|
+
if (dropTarget.detectResult === 'right') {
|
|
215
|
+
targetPath.push(dropTarget.target.children.length);
|
|
216
|
+
}
|
|
217
|
+
if (dropTarget.detectResult === 'left') {
|
|
218
|
+
targetPath.push(dropTarget.target.children.length);
|
|
219
|
+
}
|
|
220
|
+
// 如果是上,位置不变,下插入到下一个兄弟节点
|
|
221
|
+
if (dropTarget.detectResult === 'bottom') {
|
|
222
|
+
targetPath = Path.next(targetPath);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
// 缩进布局:上下是兄弟节点,左右是子节点,但上(左上/右上),探测到上是子节点,下则位置不变,反之同理。
|
|
226
|
+
if (isIndentedLayout(layout)) {
|
|
227
|
+
if (isTopLayout(layout) && dropTarget.detectResult === 'top') {
|
|
228
|
+
targetPath = Path.next(targetPath);
|
|
229
|
+
}
|
|
230
|
+
if (isBottomLayout(layout) && dropTarget.detectResult === 'bottom') {
|
|
231
|
+
targetPath = Path.next(targetPath);
|
|
232
|
+
}
|
|
233
|
+
if (isLeftLayout(layout) && dropTarget.detectResult === 'left') {
|
|
234
|
+
targetPath.push(dropTarget.target.children.length);
|
|
235
|
+
}
|
|
236
|
+
if (isRightLayout(layout) && dropTarget.detectResult === 'right') {
|
|
237
|
+
targetPath.push(dropTarget.target.children.length);
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
return targetPath;
|
|
241
|
+
};
|
|
242
|
+
export const updateRightNodeCount = (board, activeComponent, targetComponent, detectResult) => {
|
|
243
|
+
let rightNodeCount;
|
|
244
|
+
const mindmapElement = findUpElement(targetComponent.node.origin).root;
|
|
245
|
+
const mindmapComponent = ELEMENT_TO_COMPONENT.get(mindmapElement);
|
|
246
|
+
const activeIndex = mindmapComponent?.root.children.indexOf(activeComponent.node);
|
|
247
|
+
const targetIndex = mindmapComponent?.root.children.indexOf(targetComponent.node);
|
|
248
|
+
const isActiveOnRight = activeIndex !== -1 && activeIndex <= activeComponent.parent.origin.rightNodeCount - 1;
|
|
249
|
+
const isTargetOnRight = targetComponent.parent && targetIndex !== -1 && targetIndex <= targetComponent.parent.origin.rightNodeCount - 1;
|
|
250
|
+
const isBothOnRight = isActiveOnRight && isTargetOnRight;
|
|
251
|
+
const rootChildCount = mindmapComponent.root.children?.length;
|
|
252
|
+
const rootRightNodeCount = mindmapComponent?.root.origin.rightNodeCount;
|
|
253
|
+
if (!isBothOnRight) {
|
|
254
|
+
if (isActiveOnRight) {
|
|
255
|
+
rightNodeCount = rootChildCount < rootRightNodeCount ? rootChildCount - 1 : rootRightNodeCount - 1;
|
|
256
|
+
Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, activeComponent.parent.origin));
|
|
257
|
+
}
|
|
258
|
+
if (isTargetOnRight && detectResult !== 'right') {
|
|
259
|
+
rightNodeCount = rootChildCount < rootRightNodeCount ? rootRightNodeCount : rootRightNodeCount + 1;
|
|
260
|
+
Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, targetComponent.parent.origin));
|
|
261
|
+
}
|
|
262
|
+
//二级子节点拖动到根节点左侧
|
|
263
|
+
if (targetComponent.node.origin.isRoot && detectResult === 'left' && activeIndex === -1) {
|
|
264
|
+
rightNodeCount = rootChildCount;
|
|
265
|
+
Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, targetComponent.element));
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
};
|
|
269
|
+
const IS_DRAGGING = new WeakMap();
|
|
270
|
+
export const isDragging = (board) => {
|
|
271
|
+
return !!IS_DRAGGING.get(board);
|
|
272
|
+
};
|
|
273
|
+
export const setIsDragging = (board, state) => {
|
|
274
|
+
IS_DRAGGING.set(board, state);
|
|
275
|
+
};
|
|
276
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-dnd.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-dnd.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,OAAO,EACP,4BAA4B,EAC5B,gBAAgB,EAChB,IAAI,EACJ,UAAU,EAIV,OAAO,EACP,cAAc,EACd,UAAU,EACV,oBAAoB,EACpB,mBAAmB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,EACH,cAAc,EACd,uBAAuB,EACvB,gBAAgB,EAChB,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,WAAW,EACX,qBAAqB,EAExB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEtD,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,0BAA0B,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAClD,OAAO,EAAe,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAG/D,OAAO,EACH,kBAAkB,EAClB,iBAAiB,EACjB,wBAAwB,EACxB,aAAa,EACb,cAAc,EACd,sBAAsB,EACzB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAE,4BAA4B,EAAE,MAAM,oBAAoB,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAG5C,MAAM,gBAAgB,GAAG,CAAC,CAAC;AAE3B,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,KAAiB,EAAE,EAAE;IACzC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAE/D,IAAI,aAAiC,CAAC;IACtC,IAAI,UAAiB,CAAC;IACtB,IAAI,aAAsC,CAAC;IAC3C,IAAI,aAAsC,CAAC;IAC3C,IAAI,UAAU,GAA+D,IAAI,CAAC;IAElF,KAAK,CAAC,SAAS,GAAG,CAAC,KAAiB,EAAE,EAAE;QACpC,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7E,SAAS,CAAC,KAAK,CAAC,CAAC;YACjB,OAAO;SACV;QAED,cAAc;QACd,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1F,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;QACpD,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAmB,EAAE,EAAE;YAC3C,IAAI,aAAa,EAAE;gBACf,OAAO;aACV;YACD,IAAI,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;gBACzB,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAuB,CAAC;gBAC/E,MAAM,IAAI,GAAG,gBAAgB,EAAE,IAAI,CAAC;gBACnC,IAAY,CAAC,QAAQ,CAAC,CAAC,IAAiB,EAAE,EAAE;oBACzC,IAAI,aAAa,EAAE;wBACf,OAAO;qBACV;oBACD,IAAI,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,gBAAgB,CAAC,MAAM,IAAI,CAAC,EAAE;wBACrG,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC;wBAC5B,UAAU,GAAG,KAAK,CAAC;qBACtB;gBACL,CAAC,CAAC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,EAAE;YACf,KAAK,CAAC,cAAc,EAAE,CAAC;SAC1B;QAED,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,KAAK,CAAC,SAAS,GAAG,CAAC,KAAiB,EAAE,EAAE;QACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,aAAa,IAAI,UAAU,EAAE;YACxD,MAAM,QAAQ,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC7F,MAAM,QAAQ,GAAG,4BAA4B,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;YACtG,IAAI,QAAQ,GAAG,gBAAgB,EAAE;gBAC7B,OAAO;aACV;YAED,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;gBACpB,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;gBAC3B,aAAa,GAAG,OAAO,EAAE,CAAC;gBAC1B,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,sBAAsB,CAAC,CAAC;gBAC7E,aAAa,GAAG,OAAO,EAAE,CAAC;gBAC1B,qBAAqB,CAAC,aAAa,CAAC,CAAC;gBACrC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;gBACrD,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;aACxD;iBAAM;gBACH,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBACrC,IAAI,CAAC,MAAM,EAAE,CAAC;gBAClB,CAAC,CAAC,CAAC;gBACH,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBACrC,IAAI,CAAC,MAAM,EAAE,CAAC;gBAClB,CAAC,CAAC,CAAC;aACN;YAED,4BAA4B;YAC5B,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC5C,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;YAC5C,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,aAAa,CAAsB,CAAC;YAC7F,MAAM,QAAQ,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC/C,MAAM,gBAAgB,GAAgB;gBAClC,GAAG,eAAe,CAAC,IAAI;gBACvB,QAAQ,EAAE,EAAE;gBACZ,CAAC,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,OAAO;gBACnC,CAAC,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC,GAAG,OAAO;aACtC,CAAC;YACF,MAAM,aAAa,GAAG,0BAA0B,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YACvE,MAAM,SAAS,GAAG,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC;YAC7D,MAAM,SAAS,GAAG,eAAe,CAAC,SAAS,EAAE,SAAS,CAAC,IAAI,CAAgB,CAAC;YAC5E,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,KAAK,GAAG,IAAI,GAAG,EAAE,EAAE,aAAa,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,GAAG,OAAO,EAAE,aAAa,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC;YAC5I,aAAa,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;YACjC,aAAa,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;YAEjC,uBAAuB;YACvB,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,kBAAkB,CAAC,gBAAgB,CAAC,CAAC;YACtD,MAAM,iBAAiB,GAAG,CAAC,CAAC,GAAG,aAAa,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,GAAG,CAAC,CAAU,CAAC;YAE/F,IAAI,YAAY,GAA0B,IAAI,CAAC;YAC/C,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAmB,EAAE,EAAE;gBAC3C,IAAI,YAAY,EAAE;oBACd,OAAO;iBACV;gBACD,IAAI,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBACzB,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAuB,CAAC;oBAC/E,MAAM,IAAI,GAAG,gBAAgB,EAAE,IAAI,CAAC;oBAEnC,IAAY,CAAC,QAAQ,CAAC,CAAC,IAAiB,EAAE,EAAE;wBACzC,IAAI,YAAY,EAAE;4BACd,OAAO;yBACV;wBACD,MAAM,UAAU,GAAG,iBAAiB,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC;wBAC9D,IAAI,UAAU,EAAE;4BACZ,YAAY,GAAG,kBAAkB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;yBACvD;wBACD,UAAU,GAAG,IAAI,CAAC;wBAClB,IAAI,YAAY,IAAI,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE;4BACzE,UAAU,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;yBACvE;oBACL,CAAC,CAAC,CAAC;iBACN;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,UAAU,EAAE,MAAM,EAAE;gBACpB,UAAU,GAAG,sBAAsB,CAAC,UAAU,CAAC,CAAC;gBAChD,wBAAwB,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;aACjE;SACJ;QAED,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,KAAK,CAAC,aAAa,GAAG,CAAC,KAAiB,EAAE,EAAE;QACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,IAAI,aAAa,EAAE;YAC1C,IAAI,UAAU,EAAE,MAAM,EAAE;gBACpB,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,aAAa,CAAsB,CAAC;gBAC7F,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,CAAsB,CAAC;gBACjG,IAAI,UAAU,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;gBACrE,MAAM,cAAc,GAAG,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC;gBAC7D,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,GAAG,CAAC,cAA2B,CAAuB,CAAC;gBACrG,MAAM,MAAM,GAAG,cAAc,CAAC,yBAAyB,CAAC,gBAAgB,EAAE,IAAI,CAAC,MAAqB,CAAC,CAAC;gBACtG,UAAU,GAAG,+BAA+B,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;gBAC7E,MAAM,UAAU,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;gBACvE,IAAI,UAAU,GAAyB,EAAE,WAAW,EAAE,KAAK,EAAE,EACzD,eAAe,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;gBAE1E,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;oBAC1B,oBAAoB,CAAC,KAAK,EAAE,eAAe,EAAE,eAAe,EAAE,UAAU,CAAC,YAAY,CAAC,CAAC;iBAC1F;gBAED,IAAI,UAAU,CAAC,YAAY,KAAK,OAAO,EAAE;oBACrC,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;wBACpC,UAAU,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC;wBACjE,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;wBACnB,MAAM,cAAc,GAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,cAAyB,GAAG,CAAC,CAAC;wBAClF,UAAU,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC;qBACvD;oBACD,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,EAAE,eAAuB,CAAC,CAAC;iBAClE;gBAED,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;aACtD;YAED,IAAI,UAAU,CAAC,KAAK,CAAC,EAAE;gBACnB,wBAAwB,CAAC,aAAa,CAAC,CAAC;aAC3C;YACD,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAC5B,aAAa,GAAG,IAAI,CAAC;YACrB,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,aAAa,GAAG,SAAS,CAAC;YAC1B,aAAa,EAAE,MAAM,EAAE,CAAC;YACxB,aAAa,GAAG,SAAS,CAAC;YAC1B,UAAU,GAAG,IAAI,CAAC;SACrB;QACD,aAAa,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC,CAAC;IAEF,KAAK,CAAC,OAAO,GAAG,CAAC,KAAoB,EAAE,EAAE;QACrC,OAAO,CAAC,KAAK,CAAC,CAAC;IACnB,CAAC,CAAC;IAEF,OAAO,KAAK,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,MAAmB,EAAE,MAAmB,EAAE,EAAE;IACtE,OAAO,MAAM,KAAK,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAChE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,aAA0B,EAAE,QAAQ,GAAG,IAAI,EAAE,EAAE;IACjF,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,aAAa,CAAsB,CAAC;IAC7F,IAAI,QAAQ,EAAE;QACV,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;KACtD;SAAM;QACH,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;KACrD;IACD,CAAC,aAAa,CAAC,WAAW;QACtB,aAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACnC,qBAAqB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;AACX,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,aAA0B,EAAE,QAAQ,GAAG,IAAI,EAAE,EAAE;IACpF,MAAM,eAAe,GAAG,4BAA4B,CAAC,GAAG,CAAC,aAAa,CAAsB,CAAC;IAC7F,IAAI,QAAQ,EAAE;QACV,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;KACzD;SAAM;QACH,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;KACxD;IACD,CAAC,aAAa,CAAC,WAAW;QACtB,aAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACnC,wBAAwB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;AACX,CAAC,CAAC;AAEF,MAAM,+BAA+B,GAAG,CACpC,UAAgB,EAChB,MAAyB,EACzB,UAA+D,EACjE,EAAE;IACA,sBAAsB;IACtB,IAAI,qBAAqB,CAAC,MAAM,CAAC,EAAE;QAC/B,IAAI,WAAW,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,KAAK,EAAE;YAC1D,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;QACD,IAAI,cAAc,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,QAAQ,EAAE;YAChE,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;QACD,yBAAyB;QACzB,IAAI,UAAU,CAAC,YAAY,KAAK,OAAO,EAAE;YACrC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;KACJ;IACD,2BAA2B;IAC3B,IAAI,uBAAuB,CAAC,MAAM,CAAC,EAAE;QACjC,IAAI,UAAU,CAAC,YAAY,KAAK,OAAO,EAAE;YACrC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;QACD,IAAI,UAAU,CAAC,YAAY,KAAK,MAAM,EAAE;YACpC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;QACD,wBAAwB;QACxB,IAAI,UAAU,CAAC,YAAY,KAAK,QAAQ,EAAE;YACtC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;KACJ;IACD,sDAAsD;IACtD,IAAI,gBAAgB,CAAC,MAAM,CAAC,EAAE;QAC1B,IAAI,WAAW,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,KAAK,EAAE;YAC1D,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;QACD,IAAI,cAAc,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,QAAQ,EAAE;YAChE,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACtC;QACD,IAAI,YAAY,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,MAAM,EAAE;YAC5D,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;QACD,IAAI,aAAa,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,YAAY,KAAK,OAAO,EAAE;YAC9D,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACtD;KACJ;IACD,OAAO,UAAU,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAChC,KAAiB,EACjB,eAAkC,EAClC,eAAkC,EAClC,YAA0B,EAC5B,EAAE;IACA,IAAI,cAAc,CAAC;IACnB,MAAM,cAAc,GAAG,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC;IACvE,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,GAAG,CAAC,cAA2B,CAAuB,CAAC;IACrG,MAAM,WAAW,GAAG,gBAAgB,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAW,CAAC;IAC5F,MAAM,WAAW,GAAG,gBAAgB,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAW,CAAC;IAC5F,MAAM,eAAe,GAAG,WAAW,KAAK,CAAC,CAAC,IAAI,WAAW,IAAK,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,cAAyB,GAAG,CAAC,CAAC;IAC1H,MAAM,eAAe,GACjB,eAAe,CAAC,MAAM,IAAI,WAAW,KAAK,CAAC,CAAC,IAAI,WAAW,IAAK,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,cAAyB,GAAG,CAAC,CAAC;IAChI,MAAM,aAAa,GAAG,eAAe,IAAI,eAAe,CAAC;IACzD,MAAM,cAAc,GAAG,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAgB,CAAC;IACxE,MAAM,kBAAkB,GAAG,gBAAgB,EAAE,IAAI,CAAC,MAAM,CAAC,cAAwB,CAAC;IAElF,IAAI,CAAC,aAAa,EAAE;QAChB,IAAI,eAAe,EAAE;YACjB,cAAc,GAAG,cAAc,GAAG,kBAAkB,CAAC,CAAC,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,GAAG,CAAC,CAAC;YACnG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,cAAc,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;SAC5G;QAED,IAAI,eAAe,IAAI,YAAY,KAAK,OAAO,EAAE;YAC7C,cAAc,GAAG,cAAc,GAAG,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,GAAG,CAAC,CAAC;YACnG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,cAAc,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;SAC5G;QAED,eAAe;QACf,IAAI,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,YAAY,KAAK,MAAM,IAAI,WAAW,KAAK,CAAC,CAAC,EAAE;YACrF,cAAc,GAAG,cAAc,CAAC;YAChC,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,cAAc,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC;SACtG;KACJ;AACL,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,IAAI,OAAO,EAAuB,CAAC;AAEvD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,KAAiB,EAAE,EAAE;IAC5C,OAAO,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACpC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAAiB,EAAE,KAAc,EAAE,EAAE;IAC/D,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAClC,CAAC,CAAC","sourcesContent":["import {\n    createG,\n    distanceBetweenPointAndPoint,\n    IS_TEXT_EDITABLE,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    PlaitPlugin,\n    Point,\n    toPoint,\n    transformPoint,\n    Transforms,\n    ELEMENT_TO_COMPONENT,\n    getSelectedElements\n} from '@plait/core';\nimport {\n    isBottomLayout,\n    isHorizontalLogicLayout,\n    isIndentedLayout,\n    isLeftLayout,\n    isRightLayout,\n    isStandardLayout,\n    isTopLayout,\n    isVerticalLogicLayout,\n    MindmapLayoutType\n} from '@plait/layouts';\nimport { updateForeignObject } from '@plait/richtext';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { BASE } from '../constants';\nimport { getRichtextRectangleByNode } from '../draw/richtext';\nimport { drawRectangleNode } from '../draw/shape';\nimport { MindElement, PlaitMind } from '../interfaces/element';\nimport { DetectResult, MindmapNode } from '../interfaces/node';\nimport { MindNodeComponent } from '../node.component';\nimport {\n    directionCorrector,\n    directionDetector,\n    drawPlaceholderDropNodeG,\n    findUpElement,\n    isChildElement,\n    readjustmentDropTarget\n} from '../utils';\nimport { getRectangleByNode, hitMindmapElement } from '../utils/graph';\nimport { MINDMAP_ELEMENT_TO_COMPONENT } from '../utils/weak-maps';\nimport { MindmapQueries } from '../queries';\nimport { PlaitMindComponent } from '../mind.component';\n\nconst DRAG_MOVE_BUFFER = 5;\n\nexport const withDnd = (board: PlaitBoard) => {\n    const { mousedown, mousemove, globalMouseup, keydown } = board;\n\n    let activeElement: MindElement | null;\n    let startPoint: Point;\n    let fakeDragNodeG: SVGGElement | undefined;\n    let fakeDropNodeG: SVGGElement | undefined;\n    let dropTarget: { target: MindElement; detectResult: DetectResult } | null = null;\n\n    board.mousedown = (event: MouseEvent) => {\n        if (board.options.readonly || IS_TEXT_EDITABLE.get(board) || event.button === 2) {\n            mousedown(event);\n            return;\n        }\n\n        // 确认是否 hit 节点\n        const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const selectedElements = getSelectedElements(board);\n        board.children.forEach((value: PlaitElement) => {\n            if (activeElement) {\n                return;\n            }\n            if (PlaitMind.isMind(value)) {\n                const mindmapComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                const root = mindmapComponent?.root;\n                (root as any).eachNode((node: MindmapNode) => {\n                    if (activeElement) {\n                        return;\n                    }\n                    if (hitMindmapElement(board, point, node.origin) && !node.origin.isRoot && selectedElements.length <= 1) {\n                        activeElement = node.origin;\n                        startPoint = point;\n                    }\n                });\n            }\n        });\n\n        if (activeElement) {\n            event.preventDefault();\n        }\n\n        mousedown(event);\n    };\n\n    board.mousemove = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement && startPoint) {\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 < DRAG_MOVE_BUFFER) {\n                return;\n            }\n\n            if (!isDragging(board)) {\n                setIsDragging(board, true);\n                fakeDragNodeG = createG();\n                fakeDragNodeG.classList.add('dragging', 'fake-node', 'plait-board-attached');\n                fakeDropNodeG = createG();\n                addActiveOnDragOrigin(activeElement);\n                PlaitBoard.getHost(board).appendChild(fakeDropNodeG);\n                PlaitBoard.getHost(board).appendChild(fakeDragNodeG);\n            } else {\n                fakeDragNodeG?.childNodes.forEach(node => {\n                    node.remove();\n                });\n                fakeDropNodeG?.childNodes.forEach(node => {\n                    node.remove();\n                });\n            }\n\n            // fake dragging origin node\n            const offsetX = endPoint[0] - startPoint[0];\n            const offsetY = endPoint[1] - startPoint[1];\n            const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement) as MindNodeComponent;\n            const roughSVG = PlaitBoard.getRoughSVG(board);\n            const fakeDraggingNode: MindmapNode = {\n                ...activeComponent.node,\n                children: [],\n                x: activeComponent.node.x + offsetX,\n                y: activeComponent.node.y + offsetY\n            };\n            const textRectangle = getRichtextRectangleByNode(activeComponent.node);\n            const fakeNodeG = drawRectangleNode(board, fakeDraggingNode);\n            const richtextG = activeComponent.richtextG?.cloneNode(true) as SVGGElement;\n            updateForeignObject(richtextG, textRectangle.width + BASE * 10, textRectangle.height, textRectangle.x + offsetX, textRectangle.y + offsetY);\n            fakeDragNodeG?.append(fakeNodeG);\n            fakeDragNodeG?.append(richtextG);\n\n            // drop position detect\n            const { x, y } = getRectangleByNode(fakeDraggingNode);\n            const detectCenterPoint = [x + textRectangle.width / 2, y + textRectangle.height / 2] as Point;\n\n            let detectResult: DetectResult[] | null = null;\n            board.children.forEach((value: PlaitElement) => {\n                if (detectResult) {\n                    return;\n                }\n                if (PlaitMind.isMind(value)) {\n                    const mindmapComponent = ELEMENT_TO_COMPONENT.get(value) as PlaitMindComponent;\n                    const root = mindmapComponent?.root;\n\n                    (root as any).eachNode((node: MindmapNode) => {\n                        if (detectResult) {\n                            return;\n                        }\n                        const directions = directionDetector(node, detectCenterPoint);\n                        if (directions) {\n                            detectResult = directionCorrector(node, directions);\n                        }\n                        dropTarget = null;\n                        if (detectResult && isValidTarget(activeComponent.node.origin, node.origin)) {\n                            dropTarget = { target: node.origin, detectResult: detectResult[0] };\n                        }\n                    });\n                }\n            });\n\n            if (dropTarget?.target) {\n                dropTarget = readjustmentDropTarget(dropTarget);\n                drawPlaceholderDropNodeG(dropTarget, roughSVG, fakeDropNodeG);\n            }\n        }\n\n        mousemove(event);\n    };\n\n    board.globalMouseup = (event: MouseEvent) => {\n        if (!board.options.readonly && activeElement) {\n            if (dropTarget?.target) {\n                const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement) as MindNodeComponent;\n                const targetComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(dropTarget.target) as MindNodeComponent;\n                let targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                const mindmapElement = findUpElement(dropTarget.target).root;\n                const mindmapComponent = ELEMENT_TO_COMPONENT.get(mindmapElement as PlaitMind) as PlaitMindComponent;\n                const layout = MindmapQueries.getCorrectLayoutByElement(mindmapComponent?.root.origin as MindElement);\n                targetPath = updatePathByLayoutAndDropTarget(targetPath, layout, dropTarget);\n                const originPath = PlaitBoard.findPath(board, activeComponent.element);\n                let newElement: Partial<MindElement> = { isCollapsed: false },\n                    rightTargetPath = PlaitBoard.findPath(board, targetComponent.element);\n\n                if (isStandardLayout(layout)) {\n                    updateRightNodeCount(board, activeComponent, targetComponent, dropTarget.detectResult);\n                }\n\n                if (dropTarget.detectResult === 'right') {\n                    if (targetComponent.node.origin.isRoot) {\n                        targetPath = PlaitBoard.findPath(board, targetComponent.element);\n                        targetPath.push(0);\n                        const rightNodeCount = (targetComponent.node.origin.rightNodeCount as number) + 1;\n                        newElement = { isCollapsed: false, rightNodeCount };\n                    }\n                    Transforms.setNode(board, newElement, rightTargetPath as Path);\n                }\n\n                Transforms.moveNode(board, originPath, targetPath);\n            }\n\n            if (isDragging(board)) {\n                removeActiveOnDragOrigin(activeElement);\n            }\n            setIsDragging(board, false);\n            activeElement = null;\n            fakeDragNodeG?.remove();\n            fakeDragNodeG = undefined;\n            fakeDropNodeG?.remove();\n            fakeDropNodeG = undefined;\n            dropTarget = null;\n        }\n        globalMouseup(event);\n    };\n\n    board.keydown = (event: KeyboardEvent) => {\n        keydown(event);\n    };\n\n    return board;\n};\n\nexport const isValidTarget = (origin: MindElement, target: MindElement) => {\n    return origin !== target && !isChildElement(origin, target);\n};\n\nexport const addActiveOnDragOrigin = (activeElement: MindElement, isOrigin = true) => {\n    const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement) as MindNodeComponent;\n    if (isOrigin) {\n        activeComponent.g.classList.add('dragging-origin');\n    } else {\n        activeComponent.g.classList.add('dragging-child');\n    }\n    !activeElement.isCollapsed &&\n        activeElement.children.forEach(child => {\n            addActiveOnDragOrigin(child, false);\n        });\n};\n\nexport const removeActiveOnDragOrigin = (activeElement: MindElement, isOrigin = true) => {\n    const activeComponent = MINDMAP_ELEMENT_TO_COMPONENT.get(activeElement) as MindNodeComponent;\n    if (isOrigin) {\n        activeComponent.g.classList.remove('dragging-origin');\n    } else {\n        activeComponent.g.classList.remove('dragging-child');\n    }\n    !activeElement.isCollapsed &&\n        activeElement.children.forEach(child => {\n            removeActiveOnDragOrigin(child, false);\n        });\n};\n\nconst updatePathByLayoutAndDropTarget = (\n    targetPath: Path,\n    layout: MindmapLayoutType,\n    dropTarget: { target: MindElement; detectResult: DetectResult }\n) => {\n    // 上下布局：左右是兄弟节点，上下是子节点\n    if (isVerticalLogicLayout(layout)) {\n        if (isTopLayout(layout) && dropTarget.detectResult === 'top') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n        if (isBottomLayout(layout) && dropTarget.detectResult === 'bottom') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n        // 如果是左，位置不变，右则插入到下一个兄弟节点\n        if (dropTarget.detectResult === 'right') {\n            targetPath = Path.next(targetPath);\n        }\n    }\n    // 水平布局/标准布局：上下是兄弟节点，左右是子节点\n    if (isHorizontalLogicLayout(layout)) {\n        if (dropTarget.detectResult === 'right') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n        if (dropTarget.detectResult === 'left') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n        // 如果是上，位置不变，下插入到下一个兄弟节点\n        if (dropTarget.detectResult === 'bottom') {\n            targetPath = Path.next(targetPath);\n        }\n    }\n    // 缩进布局：上下是兄弟节点，左右是子节点，但上（左上/右上），探测到上是子节点，下则位置不变，反之同理。\n    if (isIndentedLayout(layout)) {\n        if (isTopLayout(layout) && dropTarget.detectResult === 'top') {\n            targetPath = Path.next(targetPath);\n        }\n        if (isBottomLayout(layout) && dropTarget.detectResult === 'bottom') {\n            targetPath = Path.next(targetPath);\n        }\n        if (isLeftLayout(layout) && dropTarget.detectResult === 'left') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n        if (isRightLayout(layout) && dropTarget.detectResult === 'right') {\n            targetPath.push(dropTarget.target.children.length);\n        }\n    }\n    return targetPath;\n};\n\nexport const updateRightNodeCount = (\n    board: PlaitBoard,\n    activeComponent: MindNodeComponent,\n    targetComponent: MindNodeComponent,\n    detectResult: DetectResult\n) => {\n    let rightNodeCount;\n    const mindmapElement = findUpElement(targetComponent.node.origin).root;\n    const mindmapComponent = ELEMENT_TO_COMPONENT.get(mindmapElement as PlaitMind) as PlaitMindComponent;\n    const activeIndex = mindmapComponent?.root.children.indexOf(activeComponent.node) as number;\n    const targetIndex = mindmapComponent?.root.children.indexOf(targetComponent.node) as number;\n    const isActiveOnRight = activeIndex !== -1 && activeIndex <= (activeComponent.parent.origin.rightNodeCount as number) - 1;\n    const isTargetOnRight =\n        targetComponent.parent && targetIndex !== -1 && targetIndex <= (targetComponent.parent.origin.rightNodeCount as number) - 1;\n    const isBothOnRight = isActiveOnRight && isTargetOnRight;\n    const rootChildCount = mindmapComponent.root.children?.length as number;\n    const rootRightNodeCount = mindmapComponent?.root.origin.rightNodeCount as number;\n\n    if (!isBothOnRight) {\n        if (isActiveOnRight) {\n            rightNodeCount = rootChildCount < rootRightNodeCount ? rootChildCount - 1 : rootRightNodeCount - 1;\n            Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, activeComponent.parent.origin));\n        }\n\n        if (isTargetOnRight && detectResult !== 'right') {\n            rightNodeCount = rootChildCount < rootRightNodeCount ? rootRightNodeCount : rootRightNodeCount + 1;\n            Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, targetComponent.parent.origin));\n        }\n\n        //二级子节点拖动到根节点左侧\n        if (targetComponent.node.origin.isRoot && detectResult === 'left' && activeIndex === -1) {\n            rightNodeCount = rootChildCount;\n            Transforms.setNode(board, { rightNodeCount }, PlaitBoard.findPath(board, targetComponent.element));\n        }\n    }\n};\n\nconst IS_DRAGGING = new WeakMap<PlaitBoard, boolean>();\n\nexport const isDragging = (board: PlaitBoard) => {\n    return !!IS_DRAGGING.get(board);\n};\n\nexport const setIsDragging = (board: PlaitBoard, state: boolean) => {\n    IS_DRAGGING.set(board, state);\n};\n"]}
|