@plait/mind 0.77.3 → 0.78.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/plait-mind.mjs +2 -2
- package/fesm2022/plait-mind.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/abstract-node.mjs +0 -5
- package/esm2022/constants/default.mjs +0 -17
- package/esm2022/constants/index.mjs +0 -5
- package/esm2022/constants/node-style.mjs +0 -19
- package/esm2022/constants/node-topic-style.mjs +0 -7
- package/esm2022/constants/theme.mjs +0 -73
- package/esm2022/emoji/emoji-base.component.mjs +0 -6
- package/esm2022/emoji/index.mjs +0 -3
- package/esm2022/emoji/with-emoji.mjs +0 -8
- package/esm2022/generators/node-active.generator.mjs +0 -46
- package/esm2022/generators/node-collapse.generator.mjs +0 -108
- package/esm2022/generators/node-emojis.generator.mjs +0 -63
- package/esm2022/generators/node-plus.generator.mjs +0 -100
- package/esm2022/generators/node-shape.generator.mjs +0 -22
- package/esm2022/interfaces/element-data.mjs +0 -2
- package/esm2022/interfaces/element.mjs +0 -103
- package/esm2022/interfaces/index.mjs +0 -8
- package/esm2022/interfaces/layout.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -14
- package/esm2022/interfaces/options.mjs +0 -2
- package/esm2022/interfaces/pointer.mjs +0 -5
- package/esm2022/interfaces/theme-color.mjs +0 -57
- package/esm2022/interfaces/types.mjs +0 -13
- package/esm2022/mind-node.component.mjs +0 -193
- package/esm2022/mind.component.mjs +0 -34
- package/esm2022/plait-mind.mjs +0 -5
- package/esm2022/plugins/with-abstract-resize.board.mjs +0 -12
- package/esm2022/plugins/with-abstract-resize.mjs +0 -112
- package/esm2022/plugins/with-mind-create.mjs +0 -104
- package/esm2022/plugins/with-mind-extend.mjs +0 -7
- package/esm2022/plugins/with-mind-fragment.mjs +0 -101
- package/esm2022/plugins/with-mind-hotkey.mjs +0 -62
- package/esm2022/plugins/with-mind.board.mjs +0 -2
- package/esm2022/plugins/with-mind.mjs +0 -148
- package/esm2022/plugins/with-node-dnd.mjs +0 -176
- package/esm2022/plugins/with-node-hover-hit-test.mjs +0 -23
- package/esm2022/plugins/with-node-image-resize.mjs +0 -46
- package/esm2022/plugins/with-node-image.mjs +0 -113
- package/esm2022/plugins/with-node-resize.mjs +0 -69
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/queries/get-available-sublayouts-by-element.mjs +0 -23
- package/esm2022/queries/get-branch-layouts.mjs +0 -18
- package/esm2022/queries/get-correct-layout-by-element.mjs +0 -48
- package/esm2022/queries/get-layout-by-element.mjs +0 -18
- package/esm2022/queries/index.mjs +0 -11
- package/esm2022/transforms/abstract-node.mjs +0 -73
- package/esm2022/transforms/emoji.mjs +0 -41
- package/esm2022/transforms/image.mjs +0 -31
- package/esm2022/transforms/index.mjs +0 -30
- package/esm2022/transforms/layout.mjs +0 -19
- package/esm2022/transforms/node.mjs +0 -99
- package/esm2022/transforms/property.mjs +0 -34
- package/esm2022/utils/abstract/common.mjs +0 -170
- package/esm2022/utils/abstract/resize.mjs +0 -194
- package/esm2022/utils/clipboard.mjs +0 -108
- package/esm2022/utils/common.mjs +0 -26
- package/esm2022/utils/dnd/common.mjs +0 -59
- package/esm2022/utils/dnd/detector.mjs +0 -176
- package/esm2022/utils/draw/abstract-outline.mjs +0 -118
- package/esm2022/utils/draw/node-dnd.mjs +0 -164
- package/esm2022/utils/draw/node-link/abstract-link.mjs +0 -60
- package/esm2022/utils/draw/node-link/draw-link.mjs +0 -9
- package/esm2022/utils/draw/node-link/indented-link.mjs +0 -46
- package/esm2022/utils/draw/node-link/logic-link.mjs +0 -76
- package/esm2022/utils/draw/node-shape.mjs +0 -26
- package/esm2022/utils/index.mjs +0 -17
- package/esm2022/utils/layout.mjs +0 -105
- package/esm2022/utils/mind.mjs +0 -98
- package/esm2022/utils/node/adjust-node.mjs +0 -36
- package/esm2022/utils/node/common.mjs +0 -15
- package/esm2022/utils/node/create-node.mjs +0 -46
- package/esm2022/utils/node/dynamic-width.mjs +0 -14
- package/esm2022/utils/node/image.mjs +0 -15
- package/esm2022/utils/node/index.mjs +0 -6
- package/esm2022/utils/node/right-node-count.mjs +0 -45
- package/esm2022/utils/node-hover/extend.mjs +0 -50
- package/esm2022/utils/node-style/branch.mjs +0 -63
- package/esm2022/utils/node-style/common.mjs +0 -4
- package/esm2022/utils/node-style/index.mjs +0 -4
- package/esm2022/utils/node-style/shape.mjs +0 -37
- package/esm2022/utils/normalize.mjs +0 -40
- package/esm2022/utils/path.mjs +0 -12
- package/esm2022/utils/point-placement.mjs +0 -119
- package/esm2022/utils/position/emoji.mjs +0 -31
- package/esm2022/utils/position/image.mjs +0 -36
- package/esm2022/utils/position/index.mjs +0 -5
- package/esm2022/utils/position/node.mjs +0 -36
- package/esm2022/utils/position/topic.mjs +0 -16
- package/esm2022/utils/space/emoji.mjs +0 -20
- package/esm2022/utils/space/index.mjs +0 -4
- package/esm2022/utils/space/layout-options.mjs +0 -69
- package/esm2022/utils/space/node-space.mjs +0 -134
- package/esm2022/utils/weak-maps.mjs +0 -2
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, isMainPointer, hotkeys, PlaitPointerType, addSelectedElement, getSelectedElements, getHitElementByPoint, temporaryDisableSelection, WritableClipboardType, toHostPoint, toViewBoxPoint, createClipboardContext, isContextmenu, PlaitElement } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../interfaces';
|
|
3
|
-
import { addImageFocus, removeImageFocus } from '../utils/node/image';
|
|
4
|
-
import { isHitImage } from '../utils';
|
|
5
|
-
import { MindTransforms } from '../transforms';
|
|
6
|
-
import { acceptImageTypes, buildImage, getElementOfFocusedImage, ImageGenerator } from '@plait/common';
|
|
7
|
-
import { DEFAULT_MIND_IMAGE_WIDTH } from '../constants';
|
|
8
|
-
export const withNodeImage = (board) => {
|
|
9
|
-
const { keyDown, pointerUp, globalPointerUp, buildFragment, insertFragment, deleteFragment, afterChange } = board;
|
|
10
|
-
board.pointerUp = (event) => {
|
|
11
|
-
const elementOfFocusedImage = getElementOfFocusedImage(board);
|
|
12
|
-
if (elementOfFocusedImage &&
|
|
13
|
-
MindElement.isMindElement(board, elementOfFocusedImage) &&
|
|
14
|
-
!isContextmenu(event) &&
|
|
15
|
-
(PlaitBoard.isReadonly(board) || !isMainPointer(event) || !PlaitBoard.isPointer(board, PlaitPointerType.selection))) {
|
|
16
|
-
removeImageFocus(board, elementOfFocusedImage);
|
|
17
|
-
pointerUp(event);
|
|
18
|
-
return;
|
|
19
|
-
}
|
|
20
|
-
if (PlaitBoard.isReadonly(board)) {
|
|
21
|
-
pointerUp(event);
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));
|
|
25
|
-
const hitElement = getHitElementByPoint(board, point);
|
|
26
|
-
const isHitImageResult = hitElement &&
|
|
27
|
-
MindElement.isMindElement(board, hitElement) &&
|
|
28
|
-
MindElement.hasImage(hitElement) &&
|
|
29
|
-
isHitImage(board, hitElement, point);
|
|
30
|
-
if (isHitImageResult && elementOfFocusedImage && hitElement === elementOfFocusedImage) {
|
|
31
|
-
temporaryDisableSelection(board);
|
|
32
|
-
pointerUp(event);
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
if (elementOfFocusedImage && MindElement.isMindElement(board, elementOfFocusedImage)) {
|
|
36
|
-
removeImageFocus(board, elementOfFocusedImage);
|
|
37
|
-
}
|
|
38
|
-
if (isHitImageResult && hitElement) {
|
|
39
|
-
temporaryDisableSelection(board);
|
|
40
|
-
addImageFocus(board, hitElement);
|
|
41
|
-
}
|
|
42
|
-
pointerUp(event);
|
|
43
|
-
};
|
|
44
|
-
board.keyDown = (event) => {
|
|
45
|
-
const selectedImageElement = getElementOfFocusedImage(board);
|
|
46
|
-
if (!PlaitBoard.isReadonly(board) && selectedImageElement && (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {
|
|
47
|
-
addSelectedElement(board, selectedImageElement);
|
|
48
|
-
MindTransforms.removeImage(board, selectedImageElement);
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
keyDown(event);
|
|
52
|
-
};
|
|
53
|
-
board.globalPointerUp = (event) => {
|
|
54
|
-
if (PlaitBoard.isFocus(board)) {
|
|
55
|
-
const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);
|
|
56
|
-
const selectedImageElement = getElementOfFocusedImage(board);
|
|
57
|
-
// Clear image selection when mouse board outside area
|
|
58
|
-
if (selectedImageElement && MindElement.isMindElement(board, selectedImageElement) && !isInBoard) {
|
|
59
|
-
removeImageFocus(board, selectedImageElement);
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
globalPointerUp(event);
|
|
63
|
-
};
|
|
64
|
-
board.buildFragment = (clipboardContext, rectangle, operationType, originData) => {
|
|
65
|
-
const selectedImageElement = getElementOfFocusedImage(board);
|
|
66
|
-
if (selectedImageElement) {
|
|
67
|
-
clipboardContext = createClipboardContext(WritableClipboardType.medias, [selectedImageElement.data.image], '');
|
|
68
|
-
}
|
|
69
|
-
return buildFragment(clipboardContext, rectangle, operationType, originData);
|
|
70
|
-
};
|
|
71
|
-
board.deleteFragment = (elements) => {
|
|
72
|
-
const selectedImageElement = getElementOfFocusedImage(board);
|
|
73
|
-
if (selectedImageElement) {
|
|
74
|
-
MindTransforms.removeImage(board, selectedImageElement);
|
|
75
|
-
}
|
|
76
|
-
deleteFragment(elements);
|
|
77
|
-
};
|
|
78
|
-
board.insertFragment = (clipboardData, targetPoint, operationType) => {
|
|
79
|
-
const selectedElements = getSelectedElements(board);
|
|
80
|
-
const isSelectedImage = !!getElementOfFocusedImage(board);
|
|
81
|
-
const isSingleSelection = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);
|
|
82
|
-
if (isSelectedImage || isSingleSelection) {
|
|
83
|
-
if (clipboardData?.files?.length) {
|
|
84
|
-
const acceptImageArray = acceptImageTypes.map((type) => 'image/' + type);
|
|
85
|
-
const selectedElement = (selectedElements[0] || getElementOfFocusedImage(board));
|
|
86
|
-
if (acceptImageArray.includes(clipboardData.files[0].type)) {
|
|
87
|
-
const imageFile = clipboardData.files[0];
|
|
88
|
-
buildImage(board, imageFile, DEFAULT_MIND_IMAGE_WIDTH, (imageItem) => {
|
|
89
|
-
MindTransforms.setImage(board, selectedElement, imageItem);
|
|
90
|
-
});
|
|
91
|
-
return;
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
if (clipboardData?.medias?.length) {
|
|
95
|
-
const selectedElement = (selectedElements[0] || getElementOfFocusedImage(board));
|
|
96
|
-
MindTransforms.setImage(board, selectedElement, clipboardData.medias[0]);
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
insertFragment(clipboardData, targetPoint, operationType);
|
|
101
|
-
};
|
|
102
|
-
board.afterChange = () => {
|
|
103
|
-
afterChange();
|
|
104
|
-
const selectedImageElement = getElementOfFocusedImage(board);
|
|
105
|
-
if (selectedImageElement && MindElement.isMindElement(board, selectedImageElement)) {
|
|
106
|
-
const commonElementRef = PlaitElement.getElementRef(selectedImageElement);
|
|
107
|
-
const imageGenerator = commonElementRef.getGenerator(ImageGenerator.key);
|
|
108
|
-
imageGenerator.setFocus(selectedImageElement, true);
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
return board;
|
|
112
|
-
};
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-image.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-image.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    isMainPointer,\n    PlaitOptionsBoard,\n    hotkeys,\n    PlaitPointerType,\n    addSelectedElement,\n    Point,\n    getSelectedElements,\n    RectangleClient,\n    getHitElementByPoint,\n    temporaryDisableSelection,\n    WritableClipboardType,\n    toHostPoint,\n    toViewBoxPoint,\n    WritableClipboardContext,\n    createClipboardContext,\n    ClipboardData,\n    isContextmenu,\n    PlaitElement,\n    WritableClipboardOperationType\n} from '@plait/core';\nimport { MindElement } from '../interfaces';\nimport { ImageData } from '../interfaces/element-data';\nimport { addImageFocus, removeImageFocus } from '../utils/node/image';\nimport { isHitImage } from '../utils';\nimport { MindTransforms } from '../transforms';\nimport { acceptImageTypes, buildImage, getElementOfFocusedImage, ImageGenerator, PlaitCommonElementRef } from '@plait/common';\nimport { DEFAULT_MIND_IMAGE_WIDTH } from '../constants';\n\nexport const withNodeImage = (board: PlaitBoard) => {\n    const { keyDown, pointerUp, globalPointerUp, buildFragment, insertFragment, deleteFragment, afterChange } = board;\n\n    board.pointerUp = (event: PointerEvent) => {\n        const elementOfFocusedImage = getElementOfFocusedImage(board);\n        if (\n            elementOfFocusedImage &&\n            MindElement.isMindElement(board, elementOfFocusedImage) &&\n            !isContextmenu(event) &&\n            (PlaitBoard.isReadonly(board) || !isMainPointer(event) || !PlaitBoard.isPointer(board, PlaitPointerType.selection))\n        ) {\n            removeImageFocus(board, elementOfFocusedImage as MindElement<ImageData>);\n            pointerUp(event);\n            return;\n        }\n        if (PlaitBoard.isReadonly(board)) {\n            pointerUp(event);\n            return;\n        }\n        const point = toViewBoxPoint(board, toHostPoint(board, event.x, event.y));\n        const hitElement = getHitElementByPoint(board, point);\n        const isHitImageResult =\n            hitElement &&\n            MindElement.isMindElement(board, hitElement) &&\n            MindElement.hasImage(hitElement) &&\n            isHitImage(board, hitElement as MindElement<ImageData>, point);\n        if (isHitImageResult && elementOfFocusedImage && hitElement === elementOfFocusedImage) {\n            temporaryDisableSelection(board as PlaitOptionsBoard);\n            pointerUp(event);\n            return;\n        }\n        if (elementOfFocusedImage && MindElement.isMindElement(board, elementOfFocusedImage)) {\n            removeImageFocus(board, elementOfFocusedImage as MindElement<ImageData>);\n        }\n        if (isHitImageResult && hitElement) {\n            temporaryDisableSelection(board as PlaitOptionsBoard);\n            addImageFocus(board, hitElement as MindElement<ImageData>);\n        }\n        pointerUp(event);\n    };\n\n    board.keyDown = (event: KeyboardEvent) => {\n        const selectedImageElement = getElementOfFocusedImage(board);\n        if (!PlaitBoard.isReadonly(board) && selectedImageElement && (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {\n            addSelectedElement(board, selectedImageElement);\n            MindTransforms.removeImage(board, selectedImageElement as MindElement<ImageData>);\n            return;\n        }\n        keyDown(event);\n    };\n\n    board.globalPointerUp = (event: PointerEvent) => {\n        if (PlaitBoard.isFocus(board)) {\n            const isInBoard = event.target instanceof Node && PlaitBoard.getBoardContainer(board).contains(event.target);\n            const selectedImageElement = getElementOfFocusedImage(board);\n            // Clear image selection when mouse board outside area\n            if (selectedImageElement && MindElement.isMindElement(board, selectedImageElement) && !isInBoard) {\n                removeImageFocus(board, selectedImageElement as MindElement<ImageData>);\n            }\n        }\n        globalPointerUp(event);\n    };\n\n    board.buildFragment = (\n        clipboardContext: WritableClipboardContext | null,\n        rectangle: RectangleClient | null,\n        operationType: WritableClipboardOperationType,\n        originData?: PlaitElement[]\n    ) => {\n        const selectedImageElement = getElementOfFocusedImage(board) as MindElement<ImageData>;\n        if (selectedImageElement) {\n            clipboardContext = createClipboardContext(WritableClipboardType.medias, [selectedImageElement.data.image], '');\n        }\n        return buildFragment(clipboardContext, rectangle, operationType, originData);\n    };\n\n    board.deleteFragment = (elements: PlaitElement[]) => {\n        const selectedImageElement = getElementOfFocusedImage(board);\n        if (selectedImageElement) {\n            MindTransforms.removeImage(board, selectedImageElement as MindElement<ImageData>);\n        }\n        deleteFragment(elements);\n    };\n\n    board.insertFragment = (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {\n        const selectedElements = getSelectedElements(board);\n        const isSelectedImage = !!getElementOfFocusedImage(board);\n        const isSingleSelection = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);\n        if (isSelectedImage || isSingleSelection) {\n            if (clipboardData?.files?.length) {\n                const acceptImageArray = acceptImageTypes.map((type) => 'image/' + type);\n                const selectedElement = (selectedElements[0] || getElementOfFocusedImage(board)) as MindElement;\n                if (acceptImageArray.includes(clipboardData.files[0].type)) {\n                    const imageFile = clipboardData.files[0];\n                    buildImage(board, imageFile, DEFAULT_MIND_IMAGE_WIDTH, (imageItem) => {\n                        MindTransforms.setImage(board, selectedElement, imageItem);\n                    });\n                    return;\n                }\n            }\n            if (clipboardData?.medias?.length) {\n                const selectedElement = (selectedElements[0] || getElementOfFocusedImage(board)) as MindElement;\n                MindTransforms.setImage(board, selectedElement, clipboardData.medias[0]);\n                return;\n            }\n        }\n        insertFragment(clipboardData, targetPoint, operationType);\n    };\n\n    board.afterChange = () => {\n        afterChange();\n        const selectedImageElement = getElementOfFocusedImage(board);\n        if (selectedImageElement && MindElement.isMindElement(board, selectedImageElement)) {\n            const commonElementRef = PlaitElement.getElementRef<PlaitCommonElementRef>(selectedImageElement);\n            const imageGenerator = commonElementRef.getGenerator<ImageGenerator>(ImageGenerator.key);\n            imageGenerator.setFocus(selectedImageElement, true);\n        }\n    };\n\n    return board;\n};\n"]}
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, PlaitNode, Point, ResizeCursorClass, distanceBetweenPointAndRectangle, getSelectedElements } from '@plait/core';
|
|
2
|
-
import { MindElement } from '../interfaces/element';
|
|
3
|
-
import { getRectangleByNode } from '../utils/position/node';
|
|
4
|
-
import { NodeSpace } from '../utils/space/node-space';
|
|
5
|
-
import { MindTransforms } from '../transforms';
|
|
6
|
-
import { EXTEND_OFFSET } from '../constants/default';
|
|
7
|
-
import { getFirstTextManage, withResize } from '@plait/common';
|
|
8
|
-
export const withNodeResize = (board) => {
|
|
9
|
-
let targetElementRef = null;
|
|
10
|
-
const options = {
|
|
11
|
-
key: 'mind-node',
|
|
12
|
-
canResize: () => {
|
|
13
|
-
return true;
|
|
14
|
-
},
|
|
15
|
-
hitTest: (point) => {
|
|
16
|
-
const newTargetElement = getSelectedTarget(board, point);
|
|
17
|
-
if (newTargetElement) {
|
|
18
|
-
return {
|
|
19
|
-
element: newTargetElement,
|
|
20
|
-
handle: null,
|
|
21
|
-
cursorClass: ResizeCursorClass.ew
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
return null;
|
|
25
|
-
},
|
|
26
|
-
beforeResize: (resizeRef) => {
|
|
27
|
-
targetElementRef = {
|
|
28
|
-
minWidth: NodeSpace.getNodeResizableMinWidth(board, resizeRef.element),
|
|
29
|
-
currentWidth: NodeSpace.getNodeDynamicWidth(board, resizeRef.element),
|
|
30
|
-
path: PlaitBoard.findPath(board, resizeRef.element),
|
|
31
|
-
textManage: getFirstTextManage(resizeRef.element)
|
|
32
|
-
};
|
|
33
|
-
},
|
|
34
|
-
onResize: (resizeRef, resizeState) => {
|
|
35
|
-
let resizedWidth = targetElementRef.currentWidth + Point.getOffsetX(resizeState.startPoint, resizeState.endPoint);
|
|
36
|
-
if (resizedWidth <= targetElementRef.minWidth) {
|
|
37
|
-
resizedWidth = targetElementRef.minWidth;
|
|
38
|
-
}
|
|
39
|
-
const newTarget = PlaitNode.get(board, targetElementRef.path);
|
|
40
|
-
if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
|
|
41
|
-
targetElementRef.textManage.updateRectangleWidth(resizedWidth);
|
|
42
|
-
const { height } = targetElementRef.textManage.getSize(undefined, resizedWidth);
|
|
43
|
-
MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth, height);
|
|
44
|
-
}
|
|
45
|
-
},
|
|
46
|
-
afterResize: (resizeRef) => {
|
|
47
|
-
targetElementRef = null;
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
withResize(board, options);
|
|
51
|
-
return board;
|
|
52
|
-
};
|
|
53
|
-
export const getSelectedTarget = (board, point) => {
|
|
54
|
-
const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value));
|
|
55
|
-
if (selectedElements.length > 0) {
|
|
56
|
-
const target = selectedElements.find(value => {
|
|
57
|
-
const rectangle = getResizeActiveRectangle(board, value);
|
|
58
|
-
return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;
|
|
59
|
-
});
|
|
60
|
-
return target ? target : null;
|
|
61
|
-
}
|
|
62
|
-
return null;
|
|
63
|
-
};
|
|
64
|
-
export const getResizeActiveRectangle = (board, element) => {
|
|
65
|
-
const node = MindElement.getNode(element);
|
|
66
|
-
const rectangle = getRectangleByNode(node);
|
|
67
|
-
return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };
|
|
68
|
-
};
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-node-resize.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-node-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Path,\n    PlaitBoard,\n    PlaitNode,\n    Point,\n    RectangleClient,\n    ResizeCursorClass,\n    distanceBetweenPointAndRectangle,\n    getSelectedElements,\n    isDragging\n} from '@plait/core';\nimport { MindElement } from '../interfaces/element';\nimport { getRectangleByNode } from '../utils/position/node';\nimport { NodeSpace } from '../utils/space/node-space';\nimport { PlaitMindBoard } from './with-mind.board';\nimport { MindTransforms } from '../transforms';\nimport { EXTEND_OFFSET } from '../constants/default';\nimport { ResizeRef, ResizeState, TextManage, WithResizeOptions, getFirstTextManage, withResize } from '@plait/common';\n\ninterface TargetElementRef {\n    minWidth: number;\n    currentWidth: number;\n    path: Path;\n    textManage: TextManage;\n}\n\nexport const withNodeResize = (board: PlaitBoard) => {\n    let targetElementRef: TargetElementRef | null = null;\n    const options: WithResizeOptions<MindElement, null> = {\n        key: 'mind-node',\n        canResize: () => {\n            return true;\n        },\n        hitTest: (point: Point) => {\n            const newTargetElement = getSelectedTarget(board as PlaitMindBoard, point);\n            if (newTargetElement) {\n                return {\n                    element: newTargetElement,\n                    handle: null,\n                    cursorClass: ResizeCursorClass.ew\n                };\n            }\n            return null;\n        },\n        beforeResize: (resizeRef: ResizeRef<MindElement, null>) => {\n            targetElementRef = {\n                minWidth: NodeSpace.getNodeResizableMinWidth(board as PlaitMindBoard, resizeRef.element),\n                currentWidth: NodeSpace.getNodeDynamicWidth(board as PlaitMindBoard, resizeRef.element),\n                path: PlaitBoard.findPath(board, resizeRef.element),\n                textManage: getFirstTextManage(resizeRef.element)\n            };\n        },\n        onResize: (resizeRef: ResizeRef<MindElement, null>, resizeState: ResizeState) => {\n            let resizedWidth = targetElementRef!.currentWidth + Point.getOffsetX(resizeState.startPoint, resizeState.endPoint);\n            if (resizedWidth <= targetElementRef!.minWidth) {\n                resizedWidth = targetElementRef!.minWidth;\n            }\n            const newTarget = PlaitNode.get<MindElement>(board, targetElementRef!.path);\n            if (newTarget && NodeSpace.getNodeTopicMinWidth(board as PlaitMindBoard, newTarget) !== resizedWidth) {\n                targetElementRef!.textManage.updateRectangleWidth(resizedWidth);\n                const { height } = targetElementRef!.textManage.getSize(undefined, resizedWidth);\n                MindTransforms.setNodeManualWidth(board as PlaitMindBoard, newTarget, resizedWidth, height);\n            }\n        },\n        afterResize: (resizeRef: ResizeRef<MindElement, null>) => {\n            targetElementRef = null;\n        }\n    };\n    withResize<MindElement, null>(board, options);\n    return board;\n};\n\nexport const getSelectedTarget = (board: PlaitMindBoard, point: Point) => {\n    const selectedElements = getSelectedElements(board).filter(value => MindElement.isMindElement(board, value)) as MindElement[];\n    if (selectedElements.length > 0) {\n        const target = selectedElements.find(value => {\n            const rectangle = getResizeActiveRectangle(board, value);\n            return distanceBetweenPointAndRectangle(point[0], point[1], rectangle) <= 0;\n        });\n        return target ? target : null;\n    }\n    return null;\n};\n\nexport const getResizeActiveRectangle = (board: PlaitBoard, element: MindElement): RectangleClient => {\n    const node = MindElement.getNode(element);\n    const rectangle = getRectangleByNode(node);\n    return { x: rectangle.x + rectangle.width - EXTEND_OFFSET, y: rectangle.y, width: EXTEND_OFFSET * 2, height: rectangle.height };\n};\n"]}
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of mind
|
|
3
|
-
*/
|
|
4
|
-
export * from './mind.component';
|
|
5
|
-
export * from './mind-node.component';
|
|
6
|
-
export * from './utils';
|
|
7
|
-
export * from './interfaces';
|
|
8
|
-
export * from './plugins/with-mind';
|
|
9
|
-
export * from './plugins/with-mind-extend';
|
|
10
|
-
export * from './constants';
|
|
11
|
-
export * from './queries/index';
|
|
12
|
-
export * from './transforms/index';
|
|
13
|
-
export * from './emoji';
|
|
14
|
-
export * from './plugins/with-mind.board';
|
|
15
|
-
export * from './plugins/with-abstract-resize.board';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsc0NBQXNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG1pbmRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL21pbmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbWluZC1ub2RlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1taW5kJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy93aXRoLW1pbmQtZXh0ZW5kJztcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vcXVlcmllcy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zZm9ybXMvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9lbW9qaSc7XG5leHBvcnQgKiBmcm9tICcuL3BsdWdpbnMvd2l0aC1taW5kLmJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vcGx1Z2lucy93aXRoLWFic3RyYWN0LXJlc2l6ZS5ib2FyZCc7XG4iXX0=
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { MindElement } from '../interfaces';
|
|
2
|
-
import { getAvailableSubLayoutsByLayoutDirections, getBranchDirectionsByLayouts } from '../utils';
|
|
3
|
-
import { MindLayoutType } from '@plait/layouts';
|
|
4
|
-
import { getBranchLayouts } from './get-branch-layouts';
|
|
5
|
-
export const getAvailableSubLayoutsByElement = (board, element) => {
|
|
6
|
-
const parentElement = MindElement.findParent(element);
|
|
7
|
-
if (parentElement) {
|
|
8
|
-
const branchLayouts = getBranchLayouts(board, parentElement);
|
|
9
|
-
if (branchLayouts[0] === MindLayoutType.standard) {
|
|
10
|
-
const node = MindElement.getNode(element);
|
|
11
|
-
branchLayouts[0] = node.left ? MindLayoutType.left : MindLayoutType.right;
|
|
12
|
-
}
|
|
13
|
-
const currentLayoutDirections = getBranchDirectionsByLayouts(branchLayouts);
|
|
14
|
-
let availableSubLayouts = getAvailableSubLayoutsByLayoutDirections(currentLayoutDirections);
|
|
15
|
-
const parentLayout = [branchLayouts[branchLayouts.length - 1]];
|
|
16
|
-
const parentDirections = getBranchDirectionsByLayouts(parentLayout);
|
|
17
|
-
const parentAvailableSubLayouts = getAvailableSubLayoutsByLayoutDirections(parentDirections);
|
|
18
|
-
availableSubLayouts = availableSubLayouts.filter(layout => parentAvailableSubLayouts.some(parentAvailableSubLayout => parentAvailableSubLayout === layout));
|
|
19
|
-
return availableSubLayouts;
|
|
20
|
-
}
|
|
21
|
-
return undefined;
|
|
22
|
-
};
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWF2YWlsYWJsZS1zdWJsYXlvdXRzLWJ5LWVsZW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9xdWVyaWVzL2dldC1hdmFpbGFibGUtc3VibGF5b3V0cy1ieS1lbGVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2xHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd4RCxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxFQUFFO0lBQ3ZGLE1BQU0sYUFBYSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdEQsSUFBSSxhQUFhLEVBQUUsQ0FBQztRQUNoQixNQUFNLGFBQWEsR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDN0QsSUFBSSxhQUFhLENBQUMsQ0FBQyxDQUFDLEtBQUssY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQy9DLE1BQU0sSUFBSSxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDMUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUM7UUFDOUUsQ0FBQztRQUNELE1BQU0sdUJBQXVCLEdBQUcsNEJBQTRCLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDNUUsSUFBSSxtQkFBbUIsR0FBRyx3Q0FBd0MsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1FBQzVGLE1BQU0sWUFBWSxHQUFHLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvRCxNQUFNLGdCQUFnQixHQUFHLDRCQUE0QixDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3BFLE1BQU0seUJBQXlCLEdBQUcsd0NBQXdDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUU3RixtQkFBbUIsR0FBRyxtQkFBbUIsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FDdEQseUJBQXlCLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLEVBQUUsQ0FBQyx3QkFBd0IsS0FBSyxNQUFNLENBQUMsQ0FDbEcsQ0FBQztRQUNGLE9BQU8sbUJBQW1CLENBQUM7SUFDL0IsQ0FBQztJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ3JCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBnZXRBdmFpbGFibGVTdWJMYXlvdXRzQnlMYXlvdXREaXJlY3Rpb25zLCBnZXRCcmFuY2hEaXJlY3Rpb25zQnlMYXlvdXRzIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgTWluZExheW91dFR5cGUgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXRCcmFuY2hMYXlvdXRzIH0gZnJvbSAnLi9nZXQtYnJhbmNoLWxheW91dHMnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcblxuZXhwb3J0IGNvbnN0IGdldEF2YWlsYWJsZVN1YkxheW91dHNCeUVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSA9PiB7XG4gICAgY29uc3QgcGFyZW50RWxlbWVudCA9IE1pbmRFbGVtZW50LmZpbmRQYXJlbnQoZWxlbWVudCk7XG4gICAgaWYgKHBhcmVudEVsZW1lbnQpIHtcbiAgICAgICAgY29uc3QgYnJhbmNoTGF5b3V0cyA9IGdldEJyYW5jaExheW91dHMoYm9hcmQsIHBhcmVudEVsZW1lbnQpO1xuICAgICAgICBpZiAoYnJhbmNoTGF5b3V0c1swXSA9PT0gTWluZExheW91dFR5cGUuc3RhbmRhcmQpIHtcbiAgICAgICAgICAgIGNvbnN0IG5vZGUgPSBNaW5kRWxlbWVudC5nZXROb2RlKGVsZW1lbnQpO1xuICAgICAgICAgICAgYnJhbmNoTGF5b3V0c1swXSA9IG5vZGUubGVmdCA/IE1pbmRMYXlvdXRUeXBlLmxlZnQgOiBNaW5kTGF5b3V0VHlwZS5yaWdodDtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBjdXJyZW50TGF5b3V0RGlyZWN0aW9ucyA9IGdldEJyYW5jaERpcmVjdGlvbnNCeUxheW91dHMoYnJhbmNoTGF5b3V0cyk7XG4gICAgICAgIGxldCBhdmFpbGFibGVTdWJMYXlvdXRzID0gZ2V0QXZhaWxhYmxlU3ViTGF5b3V0c0J5TGF5b3V0RGlyZWN0aW9ucyhjdXJyZW50TGF5b3V0RGlyZWN0aW9ucyk7XG4gICAgICAgIGNvbnN0IHBhcmVudExheW91dCA9IFticmFuY2hMYXlvdXRzW2JyYW5jaExheW91dHMubGVuZ3RoIC0gMV1dO1xuICAgICAgICBjb25zdCBwYXJlbnREaXJlY3Rpb25zID0gZ2V0QnJhbmNoRGlyZWN0aW9uc0J5TGF5b3V0cyhwYXJlbnRMYXlvdXQpO1xuICAgICAgICBjb25zdCBwYXJlbnRBdmFpbGFibGVTdWJMYXlvdXRzID0gZ2V0QXZhaWxhYmxlU3ViTGF5b3V0c0J5TGF5b3V0RGlyZWN0aW9ucyhwYXJlbnREaXJlY3Rpb25zKTtcblxuICAgICAgICBhdmFpbGFibGVTdWJMYXlvdXRzID0gYXZhaWxhYmxlU3ViTGF5b3V0cy5maWx0ZXIobGF5b3V0ID0+XG4gICAgICAgICAgICBwYXJlbnRBdmFpbGFibGVTdWJMYXlvdXRzLnNvbWUocGFyZW50QXZhaWxhYmxlU3ViTGF5b3V0ID0+IHBhcmVudEF2YWlsYWJsZVN1YkxheW91dCA9PT0gbGF5b3V0KVxuICAgICAgICApO1xuICAgICAgICByZXR1cm4gYXZhaWxhYmxlU3ViTGF5b3V0cztcbiAgICB9XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG4iXX0=
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { MindElement } from '../interfaces';
|
|
2
|
-
import { getCorrectLayoutByElement } from './get-correct-layout-by-element';
|
|
3
|
-
export const getBranchLayouts = (board, element) => {
|
|
4
|
-
const layouts = [];
|
|
5
|
-
if (element.layout) {
|
|
6
|
-
// TODO: getCorrectLayoutByElement Contains recursive operations. getBranchLayouts itself also has recursive operations and needs to be optimized.
|
|
7
|
-
layouts.unshift(getCorrectLayoutByElement(board, element));
|
|
8
|
-
}
|
|
9
|
-
let parent = MindElement.findParent(element);
|
|
10
|
-
while (parent) {
|
|
11
|
-
if (parent.layout) {
|
|
12
|
-
layouts.unshift(parent.layout);
|
|
13
|
-
}
|
|
14
|
-
parent = MindElement.findParent(parent);
|
|
15
|
-
}
|
|
16
|
-
return layouts;
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWJyYW5jaC1sYXlvdXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvcXVlcmllcy9nZXQtYnJhbmNoLWxheW91dHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1QyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUc1RSxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxFQUFFO0lBQ3hFLE1BQU0sT0FBTyxHQUFxQixFQUFFLENBQUM7SUFDckMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDakIsa0pBQWtKO1FBQ2xKLE9BQU8sQ0FBQyxPQUFPLENBQUMseUJBQXlCLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUNELElBQUksTUFBTSxHQUFHLFdBQVcsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0MsT0FBTyxNQUFNLEVBQUUsQ0FBQztRQUNaLElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ2hCLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFDRCxNQUFNLEdBQUcsV0FBVyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFDbkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IE1pbmRMYXlvdXRUeXBlIH0gZnJvbSAnQHBsYWl0L2xheW91dHMnO1xuaW1wb3J0IHsgZ2V0Q29ycmVjdExheW91dEJ5RWxlbWVudCB9IGZyb20gJy4vZ2V0LWNvcnJlY3QtbGF5b3V0LWJ5LWVsZW1lbnQnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcblxuZXhwb3J0IGNvbnN0IGdldEJyYW5jaExheW91dHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSA9PiB7XG4gICAgY29uc3QgbGF5b3V0czogTWluZExheW91dFR5cGVbXSA9IFtdO1xuICAgIGlmIChlbGVtZW50LmxheW91dCkge1xuICAgICAgICAvLyBUT0RPOiBnZXRDb3JyZWN0TGF5b3V0QnlFbGVtZW50IENvbnRhaW5zIHJlY3Vyc2l2ZSBvcGVyYXRpb25zLiBnZXRCcmFuY2hMYXlvdXRzIGl0c2VsZiBhbHNvIGhhcyByZWN1cnNpdmUgb3BlcmF0aW9ucyBhbmQgbmVlZHMgdG8gYmUgb3B0aW1pemVkLlxuICAgICAgICBsYXlvdXRzLnVuc2hpZnQoZ2V0Q29ycmVjdExheW91dEJ5RWxlbWVudChib2FyZCwgZWxlbWVudCkpO1xuICAgIH1cbiAgICBsZXQgcGFyZW50ID0gTWluZEVsZW1lbnQuZmluZFBhcmVudChlbGVtZW50KTtcbiAgICB3aGlsZSAocGFyZW50KSB7XG4gICAgICAgIGlmIChwYXJlbnQubGF5b3V0KSB7XG4gICAgICAgICAgICBsYXlvdXRzLnVuc2hpZnQocGFyZW50LmxheW91dCk7XG4gICAgICAgIH1cbiAgICAgICAgcGFyZW50ID0gTWluZEVsZW1lbnQuZmluZFBhcmVudChwYXJlbnQpO1xuICAgIH1cbiAgICByZXR1cm4gbGF5b3V0cztcbn07XG4iXX0=
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import { MindElement, PlaitMind } from '../interfaces';
|
|
2
|
-
import { correctLayoutByDirection, getInCorrectLayoutDirection, getRootLayout } from '../utils';
|
|
3
|
-
import { AbstractNode, MindLayoutType, getAbstractLayout } from '@plait/layouts';
|
|
4
|
-
/**
|
|
5
|
-
* get correctly layout:
|
|
6
|
-
* 1. root is standard -> left or right
|
|
7
|
-
* 2. correct layout by incorrect layout direction
|
|
8
|
-
* @param element
|
|
9
|
-
*/
|
|
10
|
-
export const getCorrectLayoutByElement = (board, element) => {
|
|
11
|
-
const ancestors = MindElement.getAncestors(board, element);
|
|
12
|
-
ancestors.unshift(element);
|
|
13
|
-
const root = ancestors[ancestors.length - 1];
|
|
14
|
-
let rootLayout = getRootLayout(root);
|
|
15
|
-
if (PlaitMind.isMind(element)) {
|
|
16
|
-
return rootLayout;
|
|
17
|
-
}
|
|
18
|
-
const node = MindElement.getNode(element);
|
|
19
|
-
let correctRootLayout = rootLayout;
|
|
20
|
-
if (rootLayout === MindLayoutType.standard) {
|
|
21
|
-
correctRootLayout = node.left ? MindLayoutType.left : MindLayoutType.right;
|
|
22
|
-
}
|
|
23
|
-
let layout = null;
|
|
24
|
-
const elementWithLayout = ancestors.find(value => value.layout || AbstractNode.isAbstract(value));
|
|
25
|
-
if (elementWithLayout) {
|
|
26
|
-
if (AbstractNode.isAbstract(elementWithLayout)) {
|
|
27
|
-
const parent = MindElement.getParent(elementWithLayout);
|
|
28
|
-
const parentLayout = getCorrectLayoutByElement(board, parent);
|
|
29
|
-
layout = getAbstractLayout(parentLayout);
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
layout = elementWithLayout?.layout;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
if (layout === MindLayoutType.standard || !layout) {
|
|
36
|
-
return correctRootLayout;
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
const incorrectDirection = getInCorrectLayoutDirection(correctRootLayout, layout);
|
|
40
|
-
if (incorrectDirection) {
|
|
41
|
-
return correctLayoutByDirection(layout, incorrectDirection);
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
return layout;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWNvcnJlY3QtbGF5b3V0LWJ5LWVsZW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9xdWVyaWVzL2dldC1jb3JyZWN0LWxheW91dC1ieS1lbGVtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDaEcsT0FBTyxFQUFFLFlBQVksRUFBRSxjQUFjLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVqRjs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLENBQUMsS0FBaUIsRUFBRSxPQUFvQixFQUFFLEVBQUU7SUFDakYsTUFBTSxTQUFTLEdBQUcsV0FBVyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFrQixDQUFDO0lBQzVFLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsTUFBTSxJQUFJLEdBQUcsU0FBUyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDN0MsSUFBSSxVQUFVLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBRXJDLElBQUksU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1FBQzVCLE9BQU8sVUFBVSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxNQUFNLElBQUksR0FBRyxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzFDLElBQUksaUJBQWlCLEdBQUcsVUFBVSxDQUFDO0lBQ25DLElBQUksVUFBVSxLQUFLLGNBQWMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN6QyxpQkFBaUIsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDO0lBQy9FLENBQUM7SUFFRCxJQUFJLE1BQU0sR0FBRyxJQUFJLENBQUM7SUFDbEIsTUFBTSxpQkFBaUIsR0FBRyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxZQUFZLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDbEcsSUFBSSxpQkFBaUIsRUFBRSxDQUFDO1FBQ3BCLElBQUksWUFBWSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDN0MsTUFBTSxNQUFNLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1lBQ3hELE1BQU0sWUFBWSxHQUFHLHlCQUF5QixDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztZQUM5RCxNQUFNLEdBQUcsaUJBQWlCLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDN0MsQ0FBQzthQUFNLENBQUM7WUFDSixNQUFNLEdBQUcsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO1FBQ3ZDLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFBSSxNQUFNLEtBQUssY0FBYyxDQUFDLFFBQVEsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hELE9BQU8saUJBQWlCLENBQUM7SUFDN0IsQ0FBQztTQUFNLENBQUM7UUFDSixNQUFNLGtCQUFrQixHQUFHLDJCQUEyQixDQUFDLGlCQUFpQixFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ2xGLElBQUksa0JBQWtCLEVBQUUsQ0FBQztZQUNyQixPQUFPLHdCQUF3QixDQUFDLE1BQU0sRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1FBQ2hFLENBQUM7YUFBTSxDQUFDO1lBQ0osT0FBTyxNQUFNLENBQUM7UUFDbEIsQ0FBQztJQUNMLENBQUM7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgTWluZEVsZW1lbnQsIFBsYWl0TWluZCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgY29ycmVjdExheW91dEJ5RGlyZWN0aW9uLCBnZXRJbkNvcnJlY3RMYXlvdXREaXJlY3Rpb24sIGdldFJvb3RMYXlvdXQgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBBYnN0cmFjdE5vZGUsIE1pbmRMYXlvdXRUeXBlLCBnZXRBYnN0cmFjdExheW91dCB9IGZyb20gJ0BwbGFpdC9sYXlvdXRzJztcblxuLyoqXG4gKiBnZXQgY29ycmVjdGx5IGxheW91dO+8mlxuICogMS4gcm9vdCBpcyBzdGFuZGFyZCAtPiBsZWZ0IG9yIHJpZ2h0XG4gKiAyLiBjb3JyZWN0IGxheW91dCBieSBpbmNvcnJlY3QgbGF5b3V0IGRpcmVjdGlvblxuICogQHBhcmFtIGVsZW1lbnRcbiAqL1xuZXhwb3J0IGNvbnN0IGdldENvcnJlY3RMYXlvdXRCeUVsZW1lbnQgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50KSA9PiB7XG4gICAgY29uc3QgYW5jZXN0b3JzID0gTWluZEVsZW1lbnQuZ2V0QW5jZXN0b3JzKGJvYXJkLCBlbGVtZW50KSBhcyBNaW5kRWxlbWVudFtdO1xuICAgIGFuY2VzdG9ycy51bnNoaWZ0KGVsZW1lbnQpO1xuICAgIGNvbnN0IHJvb3QgPSBhbmNlc3RvcnNbYW5jZXN0b3JzLmxlbmd0aCAtIDFdO1xuICAgIGxldCByb290TGF5b3V0ID0gZ2V0Um9vdExheW91dChyb290KTtcblxuICAgIGlmIChQbGFpdE1pbmQuaXNNaW5kKGVsZW1lbnQpKSB7XG4gICAgICAgIHJldHVybiByb290TGF5b3V0O1xuICAgIH1cblxuICAgIGNvbnN0IG5vZGUgPSBNaW5kRWxlbWVudC5nZXROb2RlKGVsZW1lbnQpO1xuICAgIGxldCBjb3JyZWN0Um9vdExheW91dCA9IHJvb3RMYXlvdXQ7XG4gICAgaWYgKHJvb3RMYXlvdXQgPT09IE1pbmRMYXlvdXRUeXBlLnN0YW5kYXJkKSB7XG4gICAgICAgIGNvcnJlY3RSb290TGF5b3V0ID0gbm9kZS5sZWZ0ID8gTWluZExheW91dFR5cGUubGVmdCA6IE1pbmRMYXlvdXRUeXBlLnJpZ2h0O1xuICAgIH1cblxuICAgIGxldCBsYXlvdXQgPSBudWxsO1xuICAgIGNvbnN0IGVsZW1lbnRXaXRoTGF5b3V0ID0gYW5jZXN0b3JzLmZpbmQodmFsdWUgPT4gdmFsdWUubGF5b3V0IHx8IEFic3RyYWN0Tm9kZS5pc0Fic3RyYWN0KHZhbHVlKSk7XG4gICAgaWYgKGVsZW1lbnRXaXRoTGF5b3V0KSB7XG4gICAgICAgIGlmIChBYnN0cmFjdE5vZGUuaXNBYnN0cmFjdChlbGVtZW50V2l0aExheW91dCkpIHtcbiAgICAgICAgICAgIGNvbnN0IHBhcmVudCA9IE1pbmRFbGVtZW50LmdldFBhcmVudChlbGVtZW50V2l0aExheW91dCk7XG4gICAgICAgICAgICBjb25zdCBwYXJlbnRMYXlvdXQgPSBnZXRDb3JyZWN0TGF5b3V0QnlFbGVtZW50KGJvYXJkLCBwYXJlbnQpO1xuICAgICAgICAgICAgbGF5b3V0ID0gZ2V0QWJzdHJhY3RMYXlvdXQocGFyZW50TGF5b3V0KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGxheW91dCA9IGVsZW1lbnRXaXRoTGF5b3V0Py5sYXlvdXQ7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAobGF5b3V0ID09PSBNaW5kTGF5b3V0VHlwZS5zdGFuZGFyZCB8fCAhbGF5b3V0KSB7XG4gICAgICAgIHJldHVybiBjb3JyZWN0Um9vdExheW91dDtcbiAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBpbmNvcnJlY3REaXJlY3Rpb24gPSBnZXRJbkNvcnJlY3RMYXlvdXREaXJlY3Rpb24oY29ycmVjdFJvb3RMYXlvdXQsIGxheW91dCk7XG4gICAgICAgIGlmIChpbmNvcnJlY3REaXJlY3Rpb24pIHtcbiAgICAgICAgICAgIHJldHVybiBjb3JyZWN0TGF5b3V0QnlEaXJlY3Rpb24obGF5b3V0LCBpbmNvcnJlY3REaXJlY3Rpb24pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIGxheW91dDtcbiAgICAgICAgfVxuICAgIH1cbn07XG4iXX0=
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { MindElement, PlaitMind } from '../interfaces';
|
|
2
|
-
import { AbstractNode, getAbstractLayout } from '@plait/layouts';
|
|
3
|
-
import { getDefaultLayout } from '../utils/layout';
|
|
4
|
-
export const getLayoutByElement = (element) => {
|
|
5
|
-
const layout = element.layout;
|
|
6
|
-
if (layout) {
|
|
7
|
-
return layout;
|
|
8
|
-
}
|
|
9
|
-
const parent = !PlaitMind.isMind(element) && MindElement.getParent(element);
|
|
10
|
-
if (AbstractNode.isAbstract(element) && parent) {
|
|
11
|
-
return getAbstractLayout(getLayoutByElement(parent));
|
|
12
|
-
}
|
|
13
|
-
if (parent) {
|
|
14
|
-
return getLayoutByElement(parent);
|
|
15
|
-
}
|
|
16
|
-
return getDefaultLayout();
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWxheW91dC1ieS1lbGVtZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvcXVlcmllcy9nZXQtbGF5b3V0LWJ5LWVsZW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBa0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLE9BQW9CLEVBQWtCLEVBQUU7SUFDdkUsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUM5QixJQUFJLE1BQU0sRUFBRSxDQUFDO1FBQ1QsT0FBTyxNQUFNLENBQUM7SUFDbEIsQ0FBQztJQUVELE1BQU0sTUFBTSxHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxXQUFXLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRTVFLElBQUksWUFBWSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxNQUFNLEVBQUUsQ0FBQztRQUM3QyxPQUFPLGlCQUFpQixDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELElBQUksTUFBTSxFQUFFLENBQUM7UUFDVCxPQUFPLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxPQUFPLGdCQUFnQixFQUFFLENBQUM7QUFDOUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWluZEVsZW1lbnQsIFBsYWl0TWluZCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQWJzdHJhY3ROb2RlLCBNaW5kTGF5b3V0VHlwZSwgZ2V0QWJzdHJhY3RMYXlvdXQgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXREZWZhdWx0TGF5b3V0IH0gZnJvbSAnLi4vdXRpbHMvbGF5b3V0JztcblxuZXhwb3J0IGNvbnN0IGdldExheW91dEJ5RWxlbWVudCA9IChlbGVtZW50OiBNaW5kRWxlbWVudCk6IE1pbmRMYXlvdXRUeXBlID0+IHtcbiAgICBjb25zdCBsYXlvdXQgPSBlbGVtZW50LmxheW91dDtcbiAgICBpZiAobGF5b3V0KSB7XG4gICAgICAgIHJldHVybiBsYXlvdXQ7XG4gICAgfVxuXG4gICAgY29uc3QgcGFyZW50ID0gIVBsYWl0TWluZC5pc01pbmQoZWxlbWVudCkgJiYgTWluZEVsZW1lbnQuZ2V0UGFyZW50KGVsZW1lbnQpO1xuXG4gICAgaWYgKEFic3RyYWN0Tm9kZS5pc0Fic3RyYWN0KGVsZW1lbnQpICYmIHBhcmVudCkge1xuICAgICAgICByZXR1cm4gZ2V0QWJzdHJhY3RMYXlvdXQoZ2V0TGF5b3V0QnlFbGVtZW50KHBhcmVudCkpO1xuICAgIH1cblxuICAgIGlmIChwYXJlbnQpIHtcbiAgICAgICAgcmV0dXJuIGdldExheW91dEJ5RWxlbWVudChwYXJlbnQpO1xuICAgIH1cblxuICAgIHJldHVybiBnZXREZWZhdWx0TGF5b3V0KCk7XG59O1xuIl19
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { getAvailableSubLayoutsByElement } from './get-available-sublayouts-by-element';
|
|
2
|
-
import { getBranchLayouts } from './get-branch-layouts';
|
|
3
|
-
import { getCorrectLayoutByElement } from './get-correct-layout-by-element';
|
|
4
|
-
import { getLayoutByElement } from './get-layout-by-element';
|
|
5
|
-
export const MindQueries = {
|
|
6
|
-
getAvailableSubLayoutsByElement,
|
|
7
|
-
getBranchLayouts,
|
|
8
|
-
getLayoutByElement,
|
|
9
|
-
getCorrectLayoutByElement
|
|
10
|
-
};
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9xdWVyaWVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRTdELE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRztJQUN2QiwrQkFBK0I7SUFDL0IsZ0JBQWdCO0lBQ2hCLGtCQUFrQjtJQUNsQix5QkFBeUI7Q0FDNUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEF2YWlsYWJsZVN1YkxheW91dHNCeUVsZW1lbnQgfSBmcm9tICcuL2dldC1hdmFpbGFibGUtc3VibGF5b3V0cy1ieS1lbGVtZW50JztcbmltcG9ydCB7IGdldEJyYW5jaExheW91dHMgfSBmcm9tICcuL2dldC1icmFuY2gtbGF5b3V0cyc7XG5pbXBvcnQgeyBnZXRDb3JyZWN0TGF5b3V0QnlFbGVtZW50IH0gZnJvbSAnLi9nZXQtY29ycmVjdC1sYXlvdXQtYnktZWxlbWVudCc7XG5pbXBvcnQgeyBnZXRMYXlvdXRCeUVsZW1lbnQgfSBmcm9tICcuL2dldC1sYXlvdXQtYnktZWxlbWVudCc7XG5cbmV4cG9ydCBjb25zdCBNaW5kUXVlcmllcyA9IHtcbiAgICBnZXRBdmFpbGFibGVTdWJMYXlvdXRzQnlFbGVtZW50LFxuICAgIGdldEJyYW5jaExheW91dHMsXG4gICAgZ2V0TGF5b3V0QnlFbGVtZW50LFxuICAgIGdldENvcnJlY3RMYXlvdXRCeUVsZW1lbnRcbn07XG4iXX0=
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import { Path, PlaitBoard, Transforms, addSelectedElement, clearSelectedElement } from '@plait/core';
|
|
2
|
-
import { AbstractNode, isStandardLayout } from '@plait/layouts';
|
|
3
|
-
import { divideElementByParent, getFirstLevelElement } from '../utils/mind';
|
|
4
|
-
import { MindQueries } from '../queries';
|
|
5
|
-
import { DefaultAbstractNodeStyle } from '../constants/node-style';
|
|
6
|
-
import { createMindElement } from '../utils/node/create-node';
|
|
7
|
-
import { getAbstractNodeText, getTopicSize } from '../utils/common';
|
|
8
|
-
import { buildText } from '@plait/common';
|
|
9
|
-
export const setAbstractsByRefs = (board, abstractRefs) => {
|
|
10
|
-
abstractRefs.forEach((newProperty, element) => {
|
|
11
|
-
const start = element.start + newProperty.start;
|
|
12
|
-
const end = element.end + newProperty.end;
|
|
13
|
-
const path = PlaitBoard.findPath(board, element);
|
|
14
|
-
if (start > end) {
|
|
15
|
-
Transforms.removeNode(board, path);
|
|
16
|
-
}
|
|
17
|
-
else {
|
|
18
|
-
Transforms.setNode(board, { start, end }, path);
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
};
|
|
22
|
-
export const setAbstractByStandardLayout = (board, element) => {
|
|
23
|
-
const rightNodeCount = element.rightNodeCount;
|
|
24
|
-
const abstract = element.children.find((child) => {
|
|
25
|
-
return AbstractNode.isAbstract(child) && child.end >= rightNodeCount && child.start < rightNodeCount;
|
|
26
|
-
});
|
|
27
|
-
if (abstract) {
|
|
28
|
-
const path = PlaitBoard.findPath(board, abstract);
|
|
29
|
-
Transforms.setNode(board, { end: rightNodeCount - 1 }, path);
|
|
30
|
-
}
|
|
31
|
-
};
|
|
32
|
-
export const insertAbstract = (board, elements) => {
|
|
33
|
-
let elementGroup = getFirstLevelElement(elements);
|
|
34
|
-
const { parentElements, abstractIncludedGroups } = divideElementByParent(elementGroup);
|
|
35
|
-
abstractIncludedGroups.forEach((group, index) => {
|
|
36
|
-
const groupParent = parentElements[index];
|
|
37
|
-
setAbstractByElements(board, groupParent, group);
|
|
38
|
-
});
|
|
39
|
-
};
|
|
40
|
-
const setAbstractByElements = (board, groupParent, group) => {
|
|
41
|
-
const indexArray = group.map((child) => groupParent.children.indexOf(child)).sort((a, b) => a - b);
|
|
42
|
-
const rightNodeCount = groupParent?.rightNodeCount;
|
|
43
|
-
const start = indexArray[0], end = indexArray[indexArray.length - 1];
|
|
44
|
-
if (isStandardLayout(MindQueries.getLayoutByElement(groupParent)) &&
|
|
45
|
-
rightNodeCount &&
|
|
46
|
-
start < rightNodeCount &&
|
|
47
|
-
end >= rightNodeCount) {
|
|
48
|
-
const childrenLength = groupParent.children.length;
|
|
49
|
-
const path = [...PlaitBoard.findPath(board, groupParent), childrenLength];
|
|
50
|
-
const leftChildren = indexArray.filter((index) => index >= rightNodeCount);
|
|
51
|
-
const rightChildren = indexArray.filter((index) => index < rightNodeCount);
|
|
52
|
-
insertAbstractNode(board, path, rightChildren[0], rightChildren[rightChildren.length - 1]);
|
|
53
|
-
insertAbstractNode(board, Path.next(path), leftChildren[0], leftChildren[leftChildren.length - 1]);
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
const path = [...PlaitBoard.findPath(board, groupParent), groupParent.children.length];
|
|
57
|
-
insertAbstractNode(board, path, start, end);
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
const insertAbstractNode = (board, path, start, end) => {
|
|
61
|
-
const abstractNodeText = getAbstractNodeText(board);
|
|
62
|
-
const { width, height } = getTopicSize(false, false, buildText(abstractNodeText));
|
|
63
|
-
const mindElement = createMindElement(abstractNodeText, width, height, {
|
|
64
|
-
strokeWidth: DefaultAbstractNodeStyle.branch.width,
|
|
65
|
-
branchWidth: DefaultAbstractNodeStyle.branch.width
|
|
66
|
-
});
|
|
67
|
-
mindElement.start = start;
|
|
68
|
-
mindElement.end = end;
|
|
69
|
-
Transforms.insertNode(board, mindElement, path);
|
|
70
|
-
clearSelectedElement(board);
|
|
71
|
-
addSelectedElement(board, mindElement);
|
|
72
|
-
};
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-node.js","sourceRoot":"","sources":["../../../../packages/mind/src/transforms/abstract-node.ts"],"names":[],"mappings":"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","sourcesContent":["import { Path, PlaitBoard, PlaitElement, Transforms, addSelectedElement, clearSelectedElement } from '@plait/core';\nimport { AbstractRefs } from '../plugins/with-abstract-resize.board';\nimport { MindElement, PlaitMind } from '../interfaces/element';\nimport { AbstractNode, isStandardLayout } from '@plait/layouts';\nimport { divideElementByParent, getFirstLevelElement } from '../utils/mind';\nimport { MindQueries } from '../queries';\nimport { DefaultAbstractNodeStyle } from '../constants/node-style';\nimport { createMindElement } from '../utils/node/create-node';\nimport { getAbstractNodeText, getTopicSize } from '../utils/common';\nimport { buildText } from '@plait/common';\n\nexport const setAbstractsByRefs = (board: PlaitBoard, abstractRefs: AbstractRefs) => {\n    abstractRefs.forEach((newProperty, element) => {\n        const start = element.start! + newProperty.start;\n        const end = element.end! + newProperty.end;\n        const path = PlaitBoard.findPath(board, element as MindElement);\n\n        if (start > end) {\n            Transforms.removeNode(board, path);\n        } else {\n            Transforms.setNode(board, { start, end }, path);\n        }\n    });\n};\n\nexport const setAbstractByStandardLayout = (board: PlaitBoard, element: MindElement) => {\n    const rightNodeCount = element.rightNodeCount!;\n    const abstract = element.children.find((child) => {\n        return AbstractNode.isAbstract(child) && child.end >= rightNodeCount && child.start < rightNodeCount;\n    });\n\n    if (abstract) {\n        const path = PlaitBoard.findPath(board, abstract);\n        Transforms.setNode(board, { end: rightNodeCount - 1 }, path);\n    }\n};\n\nexport const insertAbstract = (board: PlaitBoard, elements: PlaitElement[]) => {\n    let elementGroup = getFirstLevelElement(elements as MindElement[]);\n    const { parentElements, abstractIncludedGroups } = divideElementByParent(elementGroup);\n\n    abstractIncludedGroups.forEach((group, index) => {\n        const groupParent = parentElements[index];\n        setAbstractByElements(board, groupParent, group);\n    });\n};\n\nconst setAbstractByElements = (board: PlaitBoard, groupParent: MindElement, group: MindElement[]) => {\n    const indexArray = group.map((child) => groupParent!.children.indexOf(child)).sort((a, b) => a - b);\n    const rightNodeCount = groupParent?.rightNodeCount;\n    const start = indexArray[0],\n        end = indexArray[indexArray.length - 1];\n\n    if (\n        isStandardLayout(MindQueries.getLayoutByElement(groupParent)) &&\n        rightNodeCount &&\n        start < rightNodeCount &&\n        end >= rightNodeCount\n    ) {\n        const childrenLength = groupParent.children.length;\n        const path = [...PlaitBoard.findPath(board, groupParent), childrenLength];\n        const leftChildren = indexArray.filter((index) => index >= rightNodeCount);\n        const rightChildren = indexArray.filter((index) => index < rightNodeCount);\n        insertAbstractNode(board, path, rightChildren[0], rightChildren[rightChildren.length - 1]);\n        insertAbstractNode(board, Path.next(path), leftChildren[0], leftChildren[leftChildren.length - 1]);\n    } else {\n        const path = [...PlaitBoard.findPath(board, groupParent), groupParent.children.length];\n        insertAbstractNode(board, path, start, end);\n    }\n};\n\nconst insertAbstractNode = (board: PlaitBoard, path: Path, start: number, end: number) => {\n    const abstractNodeText = getAbstractNodeText(board);\n    const { width, height } = getTopicSize(false, false, buildText(abstractNodeText));\n    const mindElement = createMindElement(abstractNodeText, width, height, {\n        strokeWidth: DefaultAbstractNodeStyle.branch.width,\n        branchWidth: DefaultAbstractNodeStyle.branch.width\n    });\n\n    mindElement.start = start;\n    mindElement.end = end;\n\n    Transforms.insertNode(board, mindElement, path);\n\n    clearSelectedElement(board);\n    addSelectedElement(board, mindElement);\n};\n"]}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { MindElement } from '../interfaces/element';
|
|
2
|
-
import { PlaitBoard, Transforms } from '@plait/core';
|
|
3
|
-
export const addEmoji = (board, element, emojiItem) => {
|
|
4
|
-
const emojis = element.data.emojis || [];
|
|
5
|
-
const newEmojis = [...emojis];
|
|
6
|
-
newEmojis.push(emojiItem);
|
|
7
|
-
const newElement = {
|
|
8
|
-
data: { ...element.data, emojis: newEmojis }
|
|
9
|
-
};
|
|
10
|
-
const path = PlaitBoard.findPath(board, element);
|
|
11
|
-
Transforms.setNode(board, newElement, path);
|
|
12
|
-
};
|
|
13
|
-
export const removeEmoji = (board, element, emojiItem) => {
|
|
14
|
-
const emojis = element.data.emojis.filter(value => value !== emojiItem);
|
|
15
|
-
const newElement = {
|
|
16
|
-
data: { topic: element.data.topic }
|
|
17
|
-
};
|
|
18
|
-
if (MindElement.hasImage(element)) {
|
|
19
|
-
newElement.data.image = element.data.image;
|
|
20
|
-
}
|
|
21
|
-
if (emojis.length > 0) {
|
|
22
|
-
newElement.data.emojis = emojis;
|
|
23
|
-
}
|
|
24
|
-
const path = PlaitBoard.findPath(board, element);
|
|
25
|
-
Transforms.setNode(board, newElement, path);
|
|
26
|
-
};
|
|
27
|
-
export const replaceEmoji = (board, element, oldEmoji, newEmoji) => {
|
|
28
|
-
const newElement = {
|
|
29
|
-
data: { ...element.data }
|
|
30
|
-
};
|
|
31
|
-
const newEmojis = element.data.emojis.map(value => {
|
|
32
|
-
if (value === oldEmoji) {
|
|
33
|
-
return newEmoji;
|
|
34
|
-
}
|
|
35
|
-
return value;
|
|
36
|
-
});
|
|
37
|
-
newElement.data.emojis = newEmojis;
|
|
38
|
-
const path = PlaitBoard.findPath(board, element);
|
|
39
|
-
Transforms.setNode(board, newElement, path);
|
|
40
|
-
};
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2Vtb2ppLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUdyRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQW9CLEVBQUUsU0FBb0IsRUFBRSxFQUFFO0lBQ3RGLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQztJQUN6QyxNQUFNLFNBQVMsR0FBRyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUM7SUFDOUIsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQixNQUFNLFVBQVUsR0FBRztRQUNmLElBQUksRUFBRSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFO0tBQ2hDLENBQUM7SUFDakIsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2hELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBK0IsRUFBRSxTQUFvQixFQUFFLEVBQUU7SUFDcEcsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxLQUFLLFNBQVMsQ0FBQyxDQUFDO0lBQ3hFLE1BQU0sVUFBVSxHQUFHO1FBQ2YsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO0tBQ3ZCLENBQUM7SUFFakIsSUFBSSxXQUFXLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7UUFDaEMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNwQixVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDcEMsQ0FBQztJQUNELE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2pELFVBQVUsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNoRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQStCLEVBQUUsUUFBbUIsRUFBRSxRQUFtQixFQUFFLEVBQUU7SUFDekgsTUFBTSxVQUFVLEdBQUc7UUFDZixJQUFJLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLEVBQUU7S0FDYixDQUFDO0lBQ2pCLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUM5QyxJQUFJLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUNyQixPQUFPLFFBQVEsQ0FBQztRQUNwQixDQUFDO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQyxDQUFDLENBQUM7SUFDSCxVQUFVLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUM7SUFDbkMsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2hELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IFBsYWl0Qm9hcmQsIFRyYW5zZm9ybXMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBFbW9qaURhdGEsIEVtb2ppSXRlbSB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudC1kYXRhJztcblxuZXhwb3J0IGNvbnN0IGFkZEVtb2ppID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudCwgZW1vamlJdGVtOiBFbW9qaUl0ZW0pID0+IHtcbiAgICBjb25zdCBlbW9qaXMgPSBlbGVtZW50LmRhdGEuZW1vamlzIHx8IFtdO1xuICAgIGNvbnN0IG5ld0Vtb2ppcyA9IFsuLi5lbW9qaXNdO1xuICAgIG5ld0Vtb2ppcy5wdXNoKGVtb2ppSXRlbSk7XG4gICAgY29uc3QgbmV3RWxlbWVudCA9IHtcbiAgICAgICAgZGF0YTogeyAuLi5lbGVtZW50LmRhdGEsIGVtb2ppczogbmV3RW1vamlzIH1cbiAgICB9IGFzIE1pbmRFbGVtZW50O1xuICAgIGNvbnN0IHBhdGggPSBQbGFpdEJvYXJkLmZpbmRQYXRoKGJvYXJkLCBlbGVtZW50KTtcbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIHBhdGgpO1xufTtcblxuZXhwb3J0IGNvbnN0IHJlbW92ZUVtb2ppID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudDxFbW9qaURhdGE+LCBlbW9qaUl0ZW06IEVtb2ppSXRlbSkgPT4ge1xuICAgIGNvbnN0IGVtb2ppcyA9IGVsZW1lbnQuZGF0YS5lbW9qaXMuZmlsdGVyKHZhbHVlID0+IHZhbHVlICE9PSBlbW9qaUl0ZW0pO1xuICAgIGNvbnN0IG5ld0VsZW1lbnQgPSB7XG4gICAgICAgIGRhdGE6IHsgdG9waWM6IGVsZW1lbnQuZGF0YS50b3BpYyB9XG4gICAgfSBhcyBNaW5kRWxlbWVudDtcblxuICAgIGlmIChNaW5kRWxlbWVudC5oYXNJbWFnZShlbGVtZW50KSkge1xuICAgICAgICBuZXdFbGVtZW50LmRhdGEuaW1hZ2UgPSBlbGVtZW50LmRhdGEuaW1hZ2U7XG4gICAgfVxuXG4gICAgaWYgKGVtb2ppcy5sZW5ndGggPiAwKSB7XG4gICAgICAgIG5ld0VsZW1lbnQuZGF0YS5lbW9qaXMgPSBlbW9qaXM7XG4gICAgfVxuICAgIGNvbnN0IHBhdGggPSBQbGFpdEJvYXJkLmZpbmRQYXRoKGJvYXJkLCBlbGVtZW50KTtcbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIHBhdGgpO1xufTtcblxuZXhwb3J0IGNvbnN0IHJlcGxhY2VFbW9qaSA9IChib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudDogTWluZEVsZW1lbnQ8RW1vamlEYXRhPiwgb2xkRW1vamk6IEVtb2ppSXRlbSwgbmV3RW1vamk6IEVtb2ppSXRlbSkgPT4ge1xuICAgIGNvbnN0IG5ld0VsZW1lbnQgPSB7XG4gICAgICAgIGRhdGE6IHsgLi4uZWxlbWVudC5kYXRhIH1cbiAgICB9IGFzIE1pbmRFbGVtZW50O1xuICAgIGNvbnN0IG5ld0Vtb2ppcyA9IGVsZW1lbnQuZGF0YS5lbW9qaXMubWFwKHZhbHVlID0+IHtcbiAgICAgICAgaWYgKHZhbHVlID09PSBvbGRFbW9qaSkge1xuICAgICAgICAgICAgcmV0dXJuIG5ld0Vtb2ppO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9KTtcbiAgICBuZXdFbGVtZW50LmRhdGEuZW1vamlzID0gbmV3RW1vamlzO1xuICAgIGNvbnN0IHBhdGggPSBQbGFpdEJvYXJkLmZpbmRQYXRoKGJvYXJkLCBlbGVtZW50KTtcbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIHBhdGgpO1xufTtcbiJdfQ==
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, Transforms } from '@plait/core';
|
|
2
|
-
import { removeImageFocus } from '../utils/node/image';
|
|
3
|
-
import { NodeSpace } from '../utils/space/node-space';
|
|
4
|
-
import { getNewNodeHeight } from '../utils/node/dynamic-width';
|
|
5
|
-
export const removeImage = (board, element) => {
|
|
6
|
-
removeImageFocus(board, element);
|
|
7
|
-
const newElement = {
|
|
8
|
-
data: { ...element.data }
|
|
9
|
-
};
|
|
10
|
-
delete newElement.data.image;
|
|
11
|
-
const path = PlaitBoard.findPath(board, element);
|
|
12
|
-
const newDynamicWidth = NodeSpace.getNodeNewDynamicWidth(board, element, 0);
|
|
13
|
-
const newHeight = getNewNodeHeight(board, element, newDynamicWidth);
|
|
14
|
-
if (newHeight) {
|
|
15
|
-
newElement.height = newHeight;
|
|
16
|
-
}
|
|
17
|
-
Transforms.setNode(board, newElement, path);
|
|
18
|
-
};
|
|
19
|
-
export const setImage = (board, element, imageItem) => {
|
|
20
|
-
const newElement = {
|
|
21
|
-
data: { ...element.data, image: imageItem }
|
|
22
|
-
};
|
|
23
|
-
const newDynamicWidth = NodeSpace.getNodeNewDynamicWidth(board, element, imageItem.width);
|
|
24
|
-
const newHeight = getNewNodeHeight(board, element, newDynamicWidth);
|
|
25
|
-
if (newHeight) {
|
|
26
|
-
newElement.height = newHeight;
|
|
27
|
-
}
|
|
28
|
-
const path = PlaitBoard.findPath(board, element);
|
|
29
|
-
Transforms.setNode(board, newElement, path);
|
|
30
|
-
};
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2ltYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXJELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUcvRCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQStCLEVBQUUsRUFBRTtJQUM5RSxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakMsTUFBTSxVQUFVLEdBQUc7UUFDZixJQUFJLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLEVBQUU7S0FDYixDQUFDO0lBQ2pCLE9BQU8sVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDN0IsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsTUFBTSxlQUFlLEdBQUcsU0FBUyxDQUFDLHNCQUFzQixDQUFDLEtBQXVCLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzlGLE1BQU0sU0FBUyxHQUFHLGdCQUFnQixDQUFDLEtBQXVCLEVBQUUsT0FBTyxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3RGLElBQUksU0FBUyxFQUFFLENBQUM7UUFDWixVQUFVLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQztJQUNsQyxDQUFDO0lBQ0QsVUFBVSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2hELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQWlCLEVBQUUsT0FBb0IsRUFBRSxTQUEwQixFQUFFLEVBQUU7SUFDNUYsTUFBTSxVQUFVLEdBQUc7UUFDZixJQUFJLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRTtLQUM5QyxDQUFDO0lBQ0YsTUFBTSxlQUFlLEdBQUcsU0FBUyxDQUFDLHNCQUFzQixDQUFDLEtBQXVCLEVBQUUsT0FBTyxFQUFFLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1RyxNQUFNLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQyxLQUF1QixFQUFFLE9BQU8sRUFBRSxlQUFlLENBQUMsQ0FBQztJQUN0RixJQUFJLFNBQVMsRUFBRSxDQUFDO1FBQ1gsVUFBMEIsQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO0lBQ25ELENBQUM7SUFDRCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNqRCxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDaEQsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgVHJhbnNmb3JtcyB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IEltYWdlRGF0YSwgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IHJlbW92ZUltYWdlRm9jdXMgfSBmcm9tICcuLi91dGlscy9ub2RlL2ltYWdlJztcbmltcG9ydCB7IE5vZGVTcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlL25vZGUtc3BhY2UnO1xuaW1wb3J0IHsgUGxhaXRNaW5kQm9hcmQgfSBmcm9tICcuLi9wbHVnaW5zL3dpdGgtbWluZC5ib2FyZCc7XG5pbXBvcnQgeyBnZXROZXdOb2RlSGVpZ2h0IH0gZnJvbSAnLi4vdXRpbHMvbm9kZS9keW5hbWljLXdpZHRoJztcbmltcG9ydCB7IENvbW1vbkltYWdlSXRlbSB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlSW1hZ2UgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnQ6IE1pbmRFbGVtZW50PEltYWdlRGF0YT4pID0+IHtcbiAgICByZW1vdmVJbWFnZUZvY3VzKGJvYXJkLCBlbGVtZW50KTtcbiAgICBjb25zdCBuZXdFbGVtZW50ID0ge1xuICAgICAgICBkYXRhOiB7IC4uLmVsZW1lbnQuZGF0YSB9XG4gICAgfSBhcyBNaW5kRWxlbWVudDtcbiAgICBkZWxldGUgbmV3RWxlbWVudC5kYXRhLmltYWdlO1xuICAgIGNvbnN0IHBhdGggPSBQbGFpdEJvYXJkLmZpbmRQYXRoKGJvYXJkLCBlbGVtZW50KTtcbiAgICBjb25zdCBuZXdEeW5hbWljV2lkdGggPSBOb2RlU3BhY2UuZ2V0Tm9kZU5ld0R5bmFtaWNXaWR0aChib2FyZCBhcyBQbGFpdE1pbmRCb2FyZCwgZWxlbWVudCwgMCk7XG4gICAgY29uc3QgbmV3SGVpZ2h0ID0gZ2V0TmV3Tm9kZUhlaWdodChib2FyZCBhcyBQbGFpdE1pbmRCb2FyZCwgZWxlbWVudCwgbmV3RHluYW1pY1dpZHRoKTtcbiAgICBpZiAobmV3SGVpZ2h0KSB7XG4gICAgICAgIG5ld0VsZW1lbnQuaGVpZ2h0ID0gbmV3SGVpZ2h0O1xuICAgIH1cbiAgICBUcmFuc2Zvcm1zLnNldE5vZGUoYm9hcmQsIG5ld0VsZW1lbnQsIHBhdGgpO1xufTtcblxuZXhwb3J0IGNvbnN0IHNldEltYWdlID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBNaW5kRWxlbWVudCwgaW1hZ2VJdGVtOiBDb21tb25JbWFnZUl0ZW0pID0+IHtcbiAgICBjb25zdCBuZXdFbGVtZW50ID0ge1xuICAgICAgICBkYXRhOiB7IC4uLmVsZW1lbnQuZGF0YSwgaW1hZ2U6IGltYWdlSXRlbSB9XG4gICAgfTtcbiAgICBjb25zdCBuZXdEeW5hbWljV2lkdGggPSBOb2RlU3BhY2UuZ2V0Tm9kZU5ld0R5bmFtaWNXaWR0aChib2FyZCBhcyBQbGFpdE1pbmRCb2FyZCwgZWxlbWVudCwgaW1hZ2VJdGVtLndpZHRoKTtcbiAgICBjb25zdCBuZXdIZWlnaHQgPSBnZXROZXdOb2RlSGVpZ2h0KGJvYXJkIGFzIFBsYWl0TWluZEJvYXJkLCBlbGVtZW50LCBuZXdEeW5hbWljV2lkdGgpO1xuICAgIGlmIChuZXdIZWlnaHQpIHtcbiAgICAgICAgKG5ld0VsZW1lbnQgYXMgTWluZEVsZW1lbnQpLmhlaWdodCA9IG5ld0hlaWdodDtcbiAgICB9XG4gICAgY29uc3QgcGF0aCA9IFBsYWl0Qm9hcmQuZmluZFBhdGgoYm9hcmQsIGVsZW1lbnQpO1xuICAgIFRyYW5zZm9ybXMuc2V0Tm9kZShib2FyZCwgbmV3RWxlbWVudCwgcGF0aCk7XG59O1xuIl19
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { insertAbstract, setAbstractsByRefs, setAbstractByStandardLayout } from './abstract-node';
|
|
2
|
-
import { setTopic, setTopicSize, insertNodes, insertAbstractNodes, setRightNodeCountByRefs, setNodeManualWidth, insertChildNode, insertSiblingNode, insertMind } from './node';
|
|
3
|
-
import { addEmoji, removeEmoji, replaceEmoji } from './emoji';
|
|
4
|
-
import { removeImage, setImage } from './image';
|
|
5
|
-
import { setShape, setBranchShape, setBranchWidth, setLayout, setBranchColor } from './property';
|
|
6
|
-
export const MindTransforms = {
|
|
7
|
-
setLayout,
|
|
8
|
-
setShape,
|
|
9
|
-
setBranchShape,
|
|
10
|
-
setBranchWidth,
|
|
11
|
-
setBranchColor,
|
|
12
|
-
setTopic,
|
|
13
|
-
setTopicSize,
|
|
14
|
-
setNodeManualWidth,
|
|
15
|
-
addEmoji,
|
|
16
|
-
removeEmoji,
|
|
17
|
-
replaceEmoji,
|
|
18
|
-
insertAbstract,
|
|
19
|
-
setAbstractsByRefs,
|
|
20
|
-
setAbstractByStandardLayout,
|
|
21
|
-
insertNodes,
|
|
22
|
-
insertAbstractNodes,
|
|
23
|
-
setRightNodeCountByRefs,
|
|
24
|
-
removeImage,
|
|
25
|
-
setImage,
|
|
26
|
-
insertChildNode,
|
|
27
|
-
insertSiblingNode,
|
|
28
|
-
insertMind
|
|
29
|
-
};
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy90cmFuc2Zvcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsa0JBQWtCLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRyxPQUFPLEVBQ0gsUUFBUSxFQUNSLFlBQVksRUFDWixXQUFXLEVBQ1gsbUJBQW1CLEVBQ25CLHVCQUF1QixFQUN2QixrQkFBa0IsRUFDbEIsZUFBZSxFQUNmLGlCQUFpQixFQUNqQixVQUFVLEVBQ2IsTUFBTSxRQUFRLENBQUM7QUFDaEIsT0FBTyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ2hELE9BQU8sRUFBRSxRQUFRLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRWpHLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixTQUFTO0lBQ1QsUUFBUTtJQUNSLGNBQWM7SUFDZCxjQUFjO0lBQ2QsY0FBYztJQUNkLFFBQVE7SUFDUixZQUFZO0lBQ1osa0JBQWtCO0lBQ2xCLFFBQVE7SUFDUixXQUFXO0lBQ1gsWUFBWTtJQUNaLGNBQWM7SUFDZCxrQkFBa0I7SUFDbEIsMkJBQTJCO0lBQzNCLFdBQVc7SUFDWCxtQkFBbUI7SUFDbkIsdUJBQXVCO0lBQ3ZCLFdBQVc7SUFDWCxRQUFRO0lBQ1IsZUFBZTtJQUNmLGlCQUFpQjtJQUNqQixVQUFVO0NBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluc2VydEFic3RyYWN0LCBzZXRBYnN0cmFjdHNCeVJlZnMsIHNldEFic3RyYWN0QnlTdGFuZGFyZExheW91dCB9IGZyb20gJy4vYWJzdHJhY3Qtbm9kZSc7XG5pbXBvcnQge1xuICAgIHNldFRvcGljLFxuICAgIHNldFRvcGljU2l6ZSxcbiAgICBpbnNlcnROb2RlcyxcbiAgICBpbnNlcnRBYnN0cmFjdE5vZGVzLFxuICAgIHNldFJpZ2h0Tm9kZUNvdW50QnlSZWZzLFxuICAgIHNldE5vZGVNYW51YWxXaWR0aCxcbiAgICBpbnNlcnRDaGlsZE5vZGUsXG4gICAgaW5zZXJ0U2libGluZ05vZGUsXG4gICAgaW5zZXJ0TWluZFxufSBmcm9tICcuL25vZGUnO1xuaW1wb3J0IHsgYWRkRW1vamksIHJlbW92ZUVtb2ppLCByZXBsYWNlRW1vamkgfSBmcm9tICcuL2Vtb2ppJztcbmltcG9ydCB7IHJlbW92ZUltYWdlLCBzZXRJbWFnZSB9IGZyb20gJy4vaW1hZ2UnO1xuaW1wb3J0IHsgc2V0U2hhcGUsIHNldEJyYW5jaFNoYXBlLCBzZXRCcmFuY2hXaWR0aCwgc2V0TGF5b3V0LCBzZXRCcmFuY2hDb2xvciB9IGZyb20gJy4vcHJvcGVydHknO1xuXG5leHBvcnQgY29uc3QgTWluZFRyYW5zZm9ybXMgPSB7XG4gICAgc2V0TGF5b3V0LFxuICAgIHNldFNoYXBlLFxuICAgIHNldEJyYW5jaFNoYXBlLFxuICAgIHNldEJyYW5jaFdpZHRoLFxuICAgIHNldEJyYW5jaENvbG9yLFxuICAgIHNldFRvcGljLFxuICAgIHNldFRvcGljU2l6ZSxcbiAgICBzZXROb2RlTWFudWFsV2lkdGgsXG4gICAgYWRkRW1vamksXG4gICAgcmVtb3ZlRW1vamksXG4gICAgcmVwbGFjZUVtb2ppLFxuICAgIGluc2VydEFic3RyYWN0LFxuICAgIHNldEFic3RyYWN0c0J5UmVmcyxcbiAgICBzZXRBYnN0cmFjdEJ5U3RhbmRhcmRMYXlvdXQsXG4gICAgaW5zZXJ0Tm9kZXMsXG4gICAgaW5zZXJ0QWJzdHJhY3ROb2RlcyxcbiAgICBzZXRSaWdodE5vZGVDb3VudEJ5UmVmcyxcbiAgICByZW1vdmVJbWFnZSxcbiAgICBzZXRJbWFnZSxcbiAgICBpbnNlcnRDaGlsZE5vZGUsXG4gICAgaW5zZXJ0U2libGluZ05vZGUsXG4gICAgaW5zZXJ0TWluZFxufTtcbiJdfQ==
|