@plait/core 0.77.3 → 0.78.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-core.mjs.map +1 -1
- package/package.json +1 -3
- package/esm2022/constants/cursor.mjs +0 -13
- package/esm2022/constants/index.mjs +0 -20
- package/esm2022/constants/keycodes.mjs +0 -127
- package/esm2022/constants/selection.mjs +0 -6
- package/esm2022/constants/zoom.mjs +0 -4
- package/esm2022/context.mjs +0 -23
- package/esm2022/core/element/context-change.mjs +0 -13
- package/esm2022/core/element/context.mjs +0 -2
- package/esm2022/core/element/element-flavour.mjs +0 -140
- package/esm2022/core/element/element-ref.mjs +0 -2
- package/esm2022/core/list-render.mjs +0 -217
- package/esm2022/differs/default_iterable_differ.mjs +0 -614
- package/esm2022/differs/iterable_differs.mjs +0 -9
- package/esm2022/interfaces/board.mjs +0 -108
- package/esm2022/interfaces/custom-types.mjs +0 -5
- package/esm2022/interfaces/direction.mjs +0 -8
- package/esm2022/interfaces/element.mjs +0 -43
- package/esm2022/interfaces/group.mjs +0 -6
- package/esm2022/interfaces/history.mjs +0 -5
- package/esm2022/interfaces/index.mjs +0 -19
- package/esm2022/interfaces/node.mjs +0 -57
- package/esm2022/interfaces/operation.mjs +0 -96
- package/esm2022/interfaces/path-ref.mjs +0 -15
- package/esm2022/interfaces/path.mjs +0 -183
- package/esm2022/interfaces/plugin.mjs +0 -6
- package/esm2022/interfaces/point.mjs +0 -27
- package/esm2022/interfaces/pointer.mjs +0 -6
- package/esm2022/interfaces/rectangle-client.mjs +0 -171
- package/esm2022/interfaces/selection.mjs +0 -13
- package/esm2022/interfaces/svg-arc-command.mjs +0 -2
- package/esm2022/interfaces/theme.mjs +0 -49
- package/esm2022/interfaces/viewport.mjs +0 -7
- package/esm2022/plait-core.mjs +0 -5
- package/esm2022/plugins/create-board.mjs +0 -122
- package/esm2022/plugins/index.mjs +0 -11
- package/esm2022/plugins/with-board.mjs +0 -20
- package/esm2022/plugins/with-hand.mjs +0 -113
- package/esm2022/plugins/with-history.mjs +0 -91
- package/esm2022/plugins/with-hotkey.mjs +0 -96
- package/esm2022/plugins/with-i18n.mjs +0 -13
- package/esm2022/plugins/with-moving.mjs +0 -282
- package/esm2022/plugins/with-options.mjs +0 -13
- package/esm2022/plugins/with-related-fragment.mjs +0 -23
- package/esm2022/plugins/with-selection.mjs +0 -230
- package/esm2022/public-api.mjs +0 -16
- package/esm2022/testing/core/create-board.mjs +0 -15
- package/esm2022/testing/core/fake-weak-map.mjs +0 -18
- package/esm2022/testing/core/index.mjs +0 -3
- package/esm2022/testing/fake-events/event-objects.mjs +0 -131
- package/esm2022/testing/fake-events/index.mjs +0 -2
- package/esm2022/testing/index.mjs +0 -3
- package/esm2022/testing/test-element.mjs +0 -9
- package/esm2022/transforms/board.mjs +0 -137
- package/esm2022/transforms/element.mjs +0 -22
- package/esm2022/transforms/general.mjs +0 -146
- package/esm2022/transforms/group.mjs +0 -64
- package/esm2022/transforms/index.mjs +0 -17
- package/esm2022/transforms/node.mjs +0 -37
- package/esm2022/transforms/selection.mjs +0 -26
- package/esm2022/transforms/theme.mjs +0 -8
- package/esm2022/transforms/viewport.mjs +0 -8
- package/esm2022/transforms/z-index.mjs +0 -20
- package/esm2022/utils/angle.mjs +0 -164
- package/esm2022/utils/board.mjs +0 -18
- package/esm2022/utils/clipboard/clipboard.mjs +0 -40
- package/esm2022/utils/clipboard/common.mjs +0 -82
- package/esm2022/utils/clipboard/data-transfer.mjs +0 -33
- package/esm2022/utils/clipboard/index.mjs +0 -3
- package/esm2022/utils/clipboard/navigator-clipboard.mjs +0 -71
- package/esm2022/utils/clipboard/types.mjs +0 -13
- package/esm2022/utils/common.mjs +0 -79
- package/esm2022/utils/debug.mjs +0 -91
- package/esm2022/utils/dnd.mjs +0 -8
- package/esm2022/utils/dom/common.mjs +0 -75
- package/esm2022/utils/dom/environment.mjs +0 -2
- package/esm2022/utils/dom/foreign.mjs +0 -26
- package/esm2022/utils/dom/index.mjs +0 -4
- package/esm2022/utils/drawing/arrow.mjs +0 -23
- package/esm2022/utils/drawing/circle.mjs +0 -4
- package/esm2022/utils/drawing/line.mjs +0 -47
- package/esm2022/utils/drawing/rectangle.mjs +0 -36
- package/esm2022/utils/element.mjs +0 -90
- package/esm2022/utils/environment.mjs +0 -14
- package/esm2022/utils/fragment.mjs +0 -27
- package/esm2022/utils/group.mjs +0 -239
- package/esm2022/utils/helper.mjs +0 -68
- package/esm2022/utils/history.mjs +0 -96
- package/esm2022/utils/hotkeys.mjs +0 -109
- package/esm2022/utils/id-creator.mjs +0 -11
- package/esm2022/utils/index.mjs +0 -35
- package/esm2022/utils/iterable.mjs +0 -32
- package/esm2022/utils/math.mjs +0 -480
- package/esm2022/utils/mobile.mjs +0 -6
- package/esm2022/utils/moving-element.mjs +0 -17
- package/esm2022/utils/pointer.mjs +0 -13
- package/esm2022/utils/position.mjs +0 -9
- package/esm2022/utils/selected-element.mjs +0 -145
- package/esm2022/utils/selection.mjs +0 -151
- package/esm2022/utils/snap/snap-moving.mjs +0 -199
- package/esm2022/utils/snap/snap.mjs +0 -211
- package/esm2022/utils/to-image.mjs +0 -204
- package/esm2022/utils/to-point.mjs +0 -74
- package/esm2022/utils/tree.mjs +0 -22
- package/esm2022/utils/viewport.mjs +0 -227
- package/esm2022/utils/weak-maps.mjs +0 -27
- package/esm2022/utils/z-index.mjs +0 -166
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '../interfaces/board';
|
|
2
|
-
import { getRectangleByElements } from '../utils/element';
|
|
3
|
-
import { distanceBetweenPointAndRectangle } from '../utils/math';
|
|
4
|
-
import { clampZoomLevel, clearViewportOrigination, getViewBoxCenterPoint, getViewportOrigination, initializeViewportContainer } from '../utils/viewport';
|
|
5
|
-
import { setViewport } from './viewport';
|
|
6
|
-
import { depthFirstRecursion, getRealScrollBarWidth, getSelectedElements } from '../utils';
|
|
7
|
-
import { setTheme } from './theme';
|
|
8
|
-
function updateViewport(board, origination, zoom) {
|
|
9
|
-
zoom = zoom ?? board.viewport.zoom;
|
|
10
|
-
setViewport(board, {
|
|
11
|
-
...board.viewport,
|
|
12
|
-
zoom,
|
|
13
|
-
origination
|
|
14
|
-
});
|
|
15
|
-
clearViewportOrigination(board);
|
|
16
|
-
}
|
|
17
|
-
function updateZoom(board, newZoom, center) {
|
|
18
|
-
newZoom = clampZoomLevel(newZoom);
|
|
19
|
-
const nativeElement = PlaitBoard.getBoardContainer(board);
|
|
20
|
-
const nativeElementRect = nativeElement.getBoundingClientRect();
|
|
21
|
-
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
22
|
-
let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];
|
|
23
|
-
if (center && distanceBetweenPointAndRectangle(center[0], center[1], nativeElementRect) === 0) {
|
|
24
|
-
focusPoint = [center[0] - nativeElementRect.x, center[1] - nativeElementRect.y];
|
|
25
|
-
}
|
|
26
|
-
const zoom = board.viewport.zoom;
|
|
27
|
-
const origination = getViewportOrigination(board);
|
|
28
|
-
const centerX = origination[0] + focusPoint[0] / zoom;
|
|
29
|
-
const centerY = origination[1] + focusPoint[1] / zoom;
|
|
30
|
-
const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom];
|
|
31
|
-
updateViewport(board, newOrigination, newZoom);
|
|
32
|
-
}
|
|
33
|
-
function fitViewport(board) {
|
|
34
|
-
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
35
|
-
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
36
|
-
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
37
|
-
const zoom = board.viewport.zoom;
|
|
38
|
-
const autoFitPadding = 16;
|
|
39
|
-
const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;
|
|
40
|
-
const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;
|
|
41
|
-
let newZoom = zoom;
|
|
42
|
-
if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {
|
|
43
|
-
newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
newZoom = 1;
|
|
47
|
-
}
|
|
48
|
-
const centerPoint = getViewBoxCenterPoint(board);
|
|
49
|
-
const newOrigination = [
|
|
50
|
-
centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,
|
|
51
|
-
centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom
|
|
52
|
-
];
|
|
53
|
-
updateViewport(board, newOrigination, newZoom);
|
|
54
|
-
}
|
|
55
|
-
function fitViewportWidth(board, options) {
|
|
56
|
-
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
57
|
-
const boardContainer = PlaitBoard.getBoardContainer(board);
|
|
58
|
-
const boardContainerRectangle = boardContainer.getBoundingClientRect();
|
|
59
|
-
let finalWidth = 0;
|
|
60
|
-
if (options.maxWidth) {
|
|
61
|
-
finalWidth = options.maxWidth;
|
|
62
|
-
}
|
|
63
|
-
else {
|
|
64
|
-
finalWidth = boardContainerRectangle.width;
|
|
65
|
-
}
|
|
66
|
-
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
67
|
-
const contentWidth = finalWidth - 2 * options.autoFitPadding;
|
|
68
|
-
let newZoom = 0;
|
|
69
|
-
if (contentWidth < elementHostBox.width) {
|
|
70
|
-
newZoom = Math.min(contentWidth / elementHostBox.width);
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
newZoom = 1;
|
|
74
|
-
}
|
|
75
|
-
let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;
|
|
76
|
-
if (finalHeight > options.limitHeight) {
|
|
77
|
-
const containerEl = boardContainer.closest(`.${options.containerClass}`);
|
|
78
|
-
containerEl.style.height = `${finalHeight}px`;
|
|
79
|
-
initializeViewportContainer(board);
|
|
80
|
-
}
|
|
81
|
-
else {
|
|
82
|
-
finalHeight = options.limitHeight;
|
|
83
|
-
}
|
|
84
|
-
const centerX = elementHostBox.x + elementHostBox.width / 2;
|
|
85
|
-
const centerY = elementHostBox.y + elementHostBox.height / 2;
|
|
86
|
-
const newOrigination = [
|
|
87
|
-
centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,
|
|
88
|
-
centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom
|
|
89
|
-
];
|
|
90
|
-
updateViewport(board, newOrigination, newZoom);
|
|
91
|
-
}
|
|
92
|
-
/**
|
|
93
|
-
* apply theme to every element (remove element custom properties)
|
|
94
|
-
* invoke applyThemeColor
|
|
95
|
-
*/
|
|
96
|
-
function updateThemeColor(board, mode) {
|
|
97
|
-
mode = mode ?? board.theme.themeColorMode;
|
|
98
|
-
setTheme(board, { themeColorMode: mode });
|
|
99
|
-
depthFirstRecursion(board, element => {
|
|
100
|
-
board.applyTheme(element);
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
const updatePointerType = (board, pointer) => {
|
|
104
|
-
if (board.pointer === pointer)
|
|
105
|
-
return;
|
|
106
|
-
board.pointer = pointer;
|
|
107
|
-
};
|
|
108
|
-
function moveToCenter(board, centerPoint) {
|
|
109
|
-
const plaitElement = getSelectedElements(board)?.[0];
|
|
110
|
-
if (plaitElement) {
|
|
111
|
-
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
112
|
-
const scrollBarWidth = getRealScrollBarWidth(board);
|
|
113
|
-
const oldCenterPoint = getViewBoxCenterPoint(board);
|
|
114
|
-
const left = centerPoint[0] - oldCenterPoint[0];
|
|
115
|
-
const top = centerPoint[1] - oldCenterPoint[1];
|
|
116
|
-
const zoom = board.viewport.zoom;
|
|
117
|
-
const origination = [
|
|
118
|
-
left - boardContainerRect.width / 2 / zoom + scrollBarWidth / 2 / zoom,
|
|
119
|
-
top - boardContainerRect.height / 2 / zoom + scrollBarWidth / 2 / zoom
|
|
120
|
-
];
|
|
121
|
-
setViewport(board, {
|
|
122
|
-
...board.viewport,
|
|
123
|
-
origination
|
|
124
|
-
});
|
|
125
|
-
clearViewportOrigination(board);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
export const BoardTransforms = {
|
|
129
|
-
updatePointerType,
|
|
130
|
-
updateViewport,
|
|
131
|
-
fitViewport,
|
|
132
|
-
updateZoom,
|
|
133
|
-
updateThemeColor,
|
|
134
|
-
fitViewportWidth,
|
|
135
|
-
moveToCenter
|
|
136
|
-
};
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/board.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThemeColorMode } from '../interfaces/theme';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\nimport { getRectangleByElements } from '../utils/element';\nimport { distanceBetweenPointAndRectangle } from '../utils/math';\nimport {\n    clampZoomLevel,\n    clearViewportOrigination,\n    getViewBoxCenterPoint,\n    getViewportOrigination,\n    initializeViewportContainer\n} from '../utils/viewport';\nimport { setViewport } from './viewport';\nimport { depthFirstRecursion, getRealScrollBarWidth, getSelectedElements } from '../utils';\nimport { PlaitElement } from '../interfaces/element';\nimport { setTheme } from './theme';\nimport { FitViewportOptions } from '../interfaces/viewport';\nimport { PlaitPointerType } from '../interfaces/pointer';\n\nfunction updateViewport(board: PlaitBoard, origination: Point, zoom?: number) {\n    zoom = zoom ?? board.viewport.zoom;\n    setViewport(board, {\n        ...board.viewport,\n        zoom,\n        origination\n    });\n    clearViewportOrigination(board);\n}\n\nfunction updateZoom(board: PlaitBoard, newZoom: number, center?: Point) {\n    newZoom = clampZoomLevel(newZoom);\n\n    const nativeElement = PlaitBoard.getBoardContainer(board);\n    const nativeElementRect = nativeElement.getBoundingClientRect();\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];\n\n    if (center && distanceBetweenPointAndRectangle(center[0], center[1], nativeElementRect) === 0) {\n        focusPoint = [center[0] - nativeElementRect.x, center[1] - nativeElementRect.y];\n    }\n\n    const zoom = board.viewport.zoom;\n    const origination = getViewportOrigination(board);\n    const centerX = origination![0] + focusPoint[0] / zoom;\n    const centerY = origination![1] + focusPoint[1] / zoom;\n    const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewport(board: PlaitBoard) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const zoom = board.viewport.zoom;\n    const autoFitPadding = 16;\n    const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;\n    const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;\n\n    let newZoom = zoom;\n    if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {\n        newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);\n    } else {\n        newZoom = 1;\n    }\n\n    const centerPoint = getViewBoxCenterPoint(board);\n    const newOrigination = [\n        centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,\n        centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\nfunction fitViewportWidth(board: PlaitBoard, options: FitViewportOptions) {\n    let scrollBarWidth = getRealScrollBarWidth(board);\n\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const boardContainerRectangle = boardContainer.getBoundingClientRect();\n\n    let finalWidth = 0;\n    if (options.maxWidth) {\n        finalWidth = options.maxWidth;\n    } else {\n        finalWidth = boardContainerRectangle.width;\n    }\n\n    const elementHostBox = getRectangleByElements(board, board.children, true);\n    const contentWidth = finalWidth - 2 * options.autoFitPadding;\n    let newZoom = 0;\n    if (contentWidth < elementHostBox.width) {\n        newZoom = Math.min(contentWidth / elementHostBox.width);\n    } else {\n        newZoom = 1;\n    }\n\n    let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;\n    if (finalHeight > options.limitHeight) {\n        const containerEl = boardContainer.closest(`.${options.containerClass}`) as HTMLElement;\n        containerEl.style.height = `${finalHeight}px`;\n        initializeViewportContainer(board);\n    } else {\n        finalHeight = options.limitHeight;\n    }\n\n    const centerX = elementHostBox.x + elementHostBox.width / 2;\n    const centerY = elementHostBox.y + elementHostBox.height / 2;\n    const newOrigination = [\n        centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,\n        centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom\n    ] as Point;\n    updateViewport(board, newOrigination, newZoom);\n}\n\n/**\n * apply theme to every element (remove element custom properties)\n * invoke applyThemeColor\n */\nfunction updateThemeColor(board: PlaitBoard, mode: ThemeColorMode) {\n    mode = mode ?? board.theme.themeColorMode;\n    setTheme(board, { themeColorMode: mode });\n\n    depthFirstRecursion((board as unknown) as PlaitElement, element => {\n        board.applyTheme(element);\n    });\n}\n\nconst updatePointerType = <T extends string = PlaitPointerType>(board: PlaitBoard, pointer: T) => {\n    if (board.pointer === pointer) return;\n    board.pointer = pointer;\n};\n\nfunction moveToCenter(board: PlaitBoard, centerPoint: Point) {\n    const plaitElement = getSelectedElements(board)?.[0];\n    if (plaitElement) {\n        const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n        const scrollBarWidth = getRealScrollBarWidth(board);\n        const oldCenterPoint = getViewBoxCenterPoint(board);\n        const left = centerPoint[0] - oldCenterPoint[0];\n        const top = centerPoint[1] - oldCenterPoint[1];\n        const zoom = board.viewport.zoom;\n\n        const origination = [\n            left - boardContainerRect.width / 2 / zoom + scrollBarWidth / 2 / zoom,\n            top - boardContainerRect.height / 2 / zoom + scrollBarWidth / 2 / zoom\n        ] as Point;\n\n        setViewport(board, {\n            ...board.viewport,\n            origination\n        });\n        clearViewportOrigination(board);\n    }\n}\n\nexport const BoardTransforms = {\n    updatePointerType,\n    updateViewport,\n    fitViewport,\n    updateZoom,\n    updateThemeColor,\n    fitViewportWidth,\n    moveToCenter\n};\n"]}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '../interfaces/board';
|
|
2
|
-
import { removeSelectedElement } from '../utils/selected-element';
|
|
3
|
-
import { removeNode } from './node';
|
|
4
|
-
export const removeElements = (board, elements) => {
|
|
5
|
-
elements
|
|
6
|
-
.map(element => {
|
|
7
|
-
const path = PlaitBoard.findPath(board, element);
|
|
8
|
-
const ref = board.pathRef(path);
|
|
9
|
-
return () => {
|
|
10
|
-
ref.current && removeNode(board, ref.current);
|
|
11
|
-
ref.unref();
|
|
12
|
-
removeSelectedElement(board, element, true);
|
|
13
|
-
};
|
|
14
|
-
})
|
|
15
|
-
.forEach(action => {
|
|
16
|
-
action();
|
|
17
|
-
});
|
|
18
|
-
};
|
|
19
|
-
export const CoreTransforms = {
|
|
20
|
-
removeElements
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3RyYW5zZm9ybXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFakQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUVwQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxLQUFpQixFQUFFLFFBQXdCLEVBQUUsRUFBRTtJQUMxRSxRQUFRO1NBQ0gsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ1gsTUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDakQsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQyxPQUFPLEdBQUcsRUFBRTtZQUNSLEdBQUcsQ0FBQyxPQUFPLElBQUksVUFBVSxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDOUMsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1oscUJBQXFCLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNoRCxDQUFDLENBQUM7SUFDTixDQUFDLENBQUM7U0FDRCxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDZCxNQUFNLEVBQUUsQ0FBQztJQUNiLENBQUMsQ0FBQyxDQUFDO0FBQ1gsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzFCLGNBQWM7Q0FDakIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyByZW1vdmVTZWxlY3RlZEVsZW1lbnQgfSBmcm9tICcuLi91dGlscy9zZWxlY3RlZC1lbGVtZW50JztcbmltcG9ydCB7IHJlbW92ZU5vZGUgfSBmcm9tICcuL25vZGUnO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlRWxlbWVudHMgPSAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSkgPT4ge1xuICAgIGVsZW1lbnRzXG4gICAgICAgIC5tYXAoZWxlbWVudCA9PiB7XG4gICAgICAgICAgICBjb25zdCBwYXRoID0gUGxhaXRCb2FyZC5maW5kUGF0aChib2FyZCwgZWxlbWVudCk7XG4gICAgICAgICAgICBjb25zdCByZWYgPSBib2FyZC5wYXRoUmVmKHBhdGgpO1xuICAgICAgICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgICAgICAgICByZWYuY3VycmVudCAmJiByZW1vdmVOb2RlKGJvYXJkLCByZWYuY3VycmVudCk7XG4gICAgICAgICAgICAgICAgcmVmLnVucmVmKCk7XG4gICAgICAgICAgICAgICAgcmVtb3ZlU2VsZWN0ZWRFbGVtZW50KGJvYXJkLCBlbGVtZW50LCB0cnVlKTtcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0pXG4gICAgICAgIC5mb3JFYWNoKGFjdGlvbiA9PiB7XG4gICAgICAgICAgICBhY3Rpb24oKTtcbiAgICAgICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgQ29yZVRyYW5zZm9ybXMgPSB7XG4gICAgcmVtb3ZlRWxlbWVudHNcbn07XG4iXX0=
|
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { createDraft, finishDraft, isDraft } from 'immer';
|
|
2
|
-
import { Viewport } from '../interfaces/viewport';
|
|
3
|
-
import { PlaitNode } from '../interfaces/node';
|
|
4
|
-
import { Path } from '../interfaces/path';
|
|
5
|
-
const applyToDraft = (board, selection, viewport, theme, op) => {
|
|
6
|
-
switch (op.type) {
|
|
7
|
-
case 'insert_node': {
|
|
8
|
-
const { path, node } = op;
|
|
9
|
-
const parent = PlaitNode.parent(board, path);
|
|
10
|
-
const index = path[path.length - 1];
|
|
11
|
-
if (!parent.children || index > parent.children.length) {
|
|
12
|
-
throw new Error(`Cannot apply an "insert_node" operation at path [${path}] because the destination is past the end of the node.`);
|
|
13
|
-
}
|
|
14
|
-
parent.children.splice(index, 0, node);
|
|
15
|
-
break;
|
|
16
|
-
}
|
|
17
|
-
case 'remove_node': {
|
|
18
|
-
const { path } = op;
|
|
19
|
-
const parent = PlaitNode.parent(board, path);
|
|
20
|
-
const index = path[path.length - 1];
|
|
21
|
-
if (!parent.children || index > parent.children.length) {
|
|
22
|
-
throw new Error(`Cannot apply an "insert_node" operation at path [${path}] because the destination is past the end of the node.`);
|
|
23
|
-
}
|
|
24
|
-
parent.children.splice(index, 1);
|
|
25
|
-
break;
|
|
26
|
-
}
|
|
27
|
-
case 'move_node': {
|
|
28
|
-
const { path, newPath } = op;
|
|
29
|
-
if (Path.isAncestor(path, newPath)) {
|
|
30
|
-
throw new Error(`Cannot move a path [${path}] to new path [${newPath}] because the destination is inside itself.`);
|
|
31
|
-
}
|
|
32
|
-
const node = PlaitNode.get(board, path);
|
|
33
|
-
const parent = PlaitNode.parent(board, path);
|
|
34
|
-
const index = path[path.length - 1];
|
|
35
|
-
// This is tricky, but since the `path` and `newPath` both refer to
|
|
36
|
-
// the same snapshot in time, there's a mismatch. After either
|
|
37
|
-
// removing the original position, the second step's path can be out
|
|
38
|
-
// of date. So instead of using the `op.newPath` directly, we
|
|
39
|
-
// transform `op.path` to ascertain what the `newPath` would be after
|
|
40
|
-
// the operation was applied.
|
|
41
|
-
parent.children?.splice(index, 1);
|
|
42
|
-
const truePath = Path.transform(path, op);
|
|
43
|
-
const newParent = PlaitNode.get(board, Path.parent(truePath));
|
|
44
|
-
const newIndex = truePath[truePath.length - 1];
|
|
45
|
-
newParent.children?.splice(newIndex, 0, node);
|
|
46
|
-
break;
|
|
47
|
-
}
|
|
48
|
-
case 'set_node': {
|
|
49
|
-
const { path, properties, newProperties } = op;
|
|
50
|
-
if (path.length === 0) {
|
|
51
|
-
throw new Error(`Cannot set properties on the root node!`);
|
|
52
|
-
}
|
|
53
|
-
const node = PlaitNode.get(board, path);
|
|
54
|
-
for (const key in newProperties) {
|
|
55
|
-
const value = newProperties[key];
|
|
56
|
-
if (value == null) {
|
|
57
|
-
delete node[key];
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
node[key] = value;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
// properties that were previously defined, but are now missing, must be deleted
|
|
64
|
-
for (const key in properties) {
|
|
65
|
-
if (!newProperties.hasOwnProperty(key)) {
|
|
66
|
-
delete node[key];
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
break;
|
|
70
|
-
}
|
|
71
|
-
case 'set_viewport': {
|
|
72
|
-
const { newProperties } = op;
|
|
73
|
-
if (newProperties == null) {
|
|
74
|
-
viewport = newProperties;
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
if (viewport == null) {
|
|
78
|
-
if (!Viewport.isViewport(newProperties)) {
|
|
79
|
-
throw new Error(`Cannot apply an incomplete "set_viewport" operation properties ${JSON.stringify(newProperties)} when there is no current viewport.`);
|
|
80
|
-
}
|
|
81
|
-
viewport = { ...newProperties };
|
|
82
|
-
}
|
|
83
|
-
for (const key in newProperties) {
|
|
84
|
-
const value = newProperties[key];
|
|
85
|
-
if (value == null) {
|
|
86
|
-
delete viewport[key];
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
viewport[key] = value;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
break;
|
|
94
|
-
}
|
|
95
|
-
case 'set_selection': {
|
|
96
|
-
const { newProperties } = op;
|
|
97
|
-
if (newProperties == null) {
|
|
98
|
-
selection = newProperties;
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
if (selection === null) {
|
|
102
|
-
selection = op.newProperties;
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
selection = newProperties;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
break;
|
|
109
|
-
}
|
|
110
|
-
case 'set_theme': {
|
|
111
|
-
const { newProperties } = op;
|
|
112
|
-
theme = newProperties;
|
|
113
|
-
break;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
return { selection, viewport, theme };
|
|
117
|
-
};
|
|
118
|
-
export const GeneralTransforms = {
|
|
119
|
-
/**
|
|
120
|
-
* Transform the board by an operation.
|
|
121
|
-
*/
|
|
122
|
-
transform(board, op) {
|
|
123
|
-
board.children = createDraft(board.children);
|
|
124
|
-
let viewport = board.viewport && createDraft(board.viewport);
|
|
125
|
-
let selection = board.selection && createDraft(board.selection);
|
|
126
|
-
let theme = board.theme && createDraft(board.theme);
|
|
127
|
-
try {
|
|
128
|
-
const state = applyToDraft(board, selection, viewport, theme, op);
|
|
129
|
-
viewport = state.viewport;
|
|
130
|
-
selection = state.selection;
|
|
131
|
-
theme = state.theme;
|
|
132
|
-
}
|
|
133
|
-
finally {
|
|
134
|
-
board.children = finishDraft(board.children);
|
|
135
|
-
if (selection) {
|
|
136
|
-
board.selection = isDraft(selection) ? finishDraft(selection) : selection;
|
|
137
|
-
}
|
|
138
|
-
else {
|
|
139
|
-
board.selection = null;
|
|
140
|
-
}
|
|
141
|
-
board.viewport = isDraft(viewport) ? finishDraft(viewport) : viewport;
|
|
142
|
-
board.theme = isDraft(theme) ? finishDraft(theme) : theme;
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/general.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitOperation } from '../interfaces/operation';\nimport { PlaitBoard } from '../interfaces/board';\nimport { createDraft, finishDraft, isDraft } from 'immer';\nimport { Viewport } from '../interfaces/viewport';\nimport { Selection } from '../interfaces/selection';\nimport { Ancestor, PlaitNode } from '../interfaces/node';\nimport { Path } from '../interfaces/path';\nimport { PlaitTheme } from '../interfaces/theme';\n\nexport interface GeneralTransforms {\n    transform: (board: PlaitBoard, op: PlaitOperation) => void;\n}\n\nconst applyToDraft = (board: PlaitBoard, selection: Selection | null, viewport: Viewport, theme: PlaitTheme, op: PlaitOperation) => {\n    switch (op.type) {\n        case 'insert_node': {\n            const { path, node } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n\n            parent.children.splice(index, 0, node);\n            break;\n        }\n        case 'remove_node': {\n            const { path } = op;\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            if (!parent.children || index > parent.children.length) {\n                throw new Error(\n                    `Cannot apply an \"insert_node\" operation at path [${path}] because the destination is past the end of the node.`\n                );\n            }\n            parent.children.splice(index, 1);\n            break;\n        }\n        case 'move_node': {\n            const { path, newPath } = op;\n\n            if (Path.isAncestor(path, newPath)) {\n                throw new Error(`Cannot move a path [${path}] to new path [${newPath}] because the destination is inside itself.`);\n            }\n\n            const node = PlaitNode.get(board, path);\n            const parent = PlaitNode.parent(board, path);\n            const index = path[path.length - 1];\n\n            // This is tricky, but since the `path` and `newPath` both refer to\n            // the same snapshot in time, there's a mismatch. After either\n            // removing the original position, the second step's path can be out\n            // of date. So instead of using the `op.newPath` directly, we\n            // transform `op.path` to ascertain what the `newPath` would be after\n            // the operation was applied.\n            parent.children?.splice(index, 1);\n            const truePath = Path.transform(path, op)!;\n            const newParent = PlaitNode.get(board, Path.parent(truePath)) as Ancestor;\n            const newIndex = truePath[truePath.length - 1];\n\n            newParent.children?.splice(newIndex, 0, node);\n            break;\n        }\n        case 'set_node': {\n            const { path, properties, newProperties } = op;\n\n            if (path.length === 0) {\n                throw new Error(`Cannot set properties on the root node!`);\n            }\n\n            const node = PlaitNode.get(board, path);\n\n            for (const key in newProperties) {\n                const value = newProperties[key];\n\n                if (value == null) {\n                    delete node[key];\n                } else {\n                    node[key] = value;\n                }\n            }\n\n            // properties that were previously defined, but are now missing, must be deleted\n            for (const key in properties) {\n                if (!newProperties.hasOwnProperty(key)) {\n                    delete node[key];\n                }\n            }\n\n            break;\n        }\n        case 'set_viewport': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                viewport = newProperties;\n            } else {\n                if (viewport == null) {\n                    if (!Viewport.isViewport(newProperties)) {\n                        throw new Error(\n                            `Cannot apply an incomplete \"set_viewport\" operation properties ${JSON.stringify(\n                                newProperties\n                            )} when there is no current viewport.`\n                        );\n                    }\n                    viewport = { ...newProperties };\n                }\n\n                for (const key in newProperties) {\n                    const value = newProperties[key];\n\n                    if (value == null) {\n                        delete viewport[key];\n                    } else {\n                        viewport[key] = value;\n                    }\n                }\n            }\n            break;\n        }\n        case 'set_selection': {\n            const { newProperties } = op;\n            if (newProperties == null) {\n                selection = newProperties;\n            } else {\n                if (selection === null) {\n                    selection = op.newProperties;\n                } else {\n                    selection = newProperties;\n                }\n            }\n            break;\n        }\n        case 'set_theme': {\n            const { newProperties } = op;\n            theme = newProperties as PlaitTheme;\n            break;\n        }\n    }\n    return { selection, viewport, theme };\n};\n\nexport const GeneralTransforms: GeneralTransforms = {\n    /**\n     * Transform the board by an operation.\n     */\n    transform(board: PlaitBoard, op: PlaitOperation): void {\n        board.children = createDraft(board.children);\n        let viewport = board.viewport && createDraft(board.viewport);\n        let selection = board.selection && createDraft(board.selection);\n        let theme = board.theme && createDraft(board.theme);\n\n        try {\n            const state = applyToDraft(board, selection, viewport, theme, op);\n            viewport = state.viewport;\n            selection = state.selection;\n            theme = state.theme;\n        } finally {\n            board.children = finishDraft(board.children);\n\n            if (selection) {\n                board.selection = isDraft(selection) ? (finishDraft(selection) as Selection) : selection;\n            } else {\n                board.selection = null;\n            }\n\n            board.viewport = isDraft(viewport) ? (finishDraft(viewport) as Viewport) : viewport;\n            board.theme = isDraft(theme) ? finishDraft(theme) : theme;\n        }\n    }\n};\n"]}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '../interfaces';
|
|
2
|
-
import { getHighestSelectedGroups, getSelectedIsolatedElementsCanAddToGroup, createGroup, canAddGroup, hasSelectedElementsInSameGroup, canRemoveGroup, findElements, getElementsIndices, isIndicesContinuous, getSelectedElements, getHighestIndexOfElement, moveElementsToNewPathAfterAddGroup } from '../utils';
|
|
3
|
-
import { NodeTransforms } from './node';
|
|
4
|
-
export const addGroup = (board, elements) => {
|
|
5
|
-
const selectedGroups = getHighestSelectedGroups(board, elements);
|
|
6
|
-
const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);
|
|
7
|
-
const highestSelectedElements = [...selectedGroups, ...selectedIsolatedElements];
|
|
8
|
-
const group = createGroup();
|
|
9
|
-
if (canAddGroup(board)) {
|
|
10
|
-
highestSelectedElements.forEach(item => {
|
|
11
|
-
const path = PlaitBoard.findPath(board, item);
|
|
12
|
-
NodeTransforms.setNode(board, { groupId: group.id }, path);
|
|
13
|
-
});
|
|
14
|
-
const selectedElements = getSelectedElements(board);
|
|
15
|
-
const highestIndexOfSelectedElement = getHighestIndexOfElement(board, selectedElements);
|
|
16
|
-
const indices = getElementsIndices(board, highestSelectedElements);
|
|
17
|
-
const isContinuous = isIndicesContinuous(indices);
|
|
18
|
-
if (!isContinuous) {
|
|
19
|
-
moveElementsToNewPathAfterAddGroup(board, selectedElements, [highestIndexOfSelectedElement - 1]);
|
|
20
|
-
}
|
|
21
|
-
if (hasSelectedElementsInSameGroup(highestSelectedElements)) {
|
|
22
|
-
const newGroupId = selectedIsolatedElements[0].groupId;
|
|
23
|
-
NodeTransforms.insertNode(board, {
|
|
24
|
-
...group,
|
|
25
|
-
groupId: newGroupId
|
|
26
|
-
}, [board.children.length]);
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
NodeTransforms.insertNode(board, group, [board.children.length]);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
export const removeGroup = (board, elements) => {
|
|
34
|
-
const selectedGroups = getHighestSelectedGroups(board, elements);
|
|
35
|
-
if (canRemoveGroup(board)) {
|
|
36
|
-
selectedGroups.forEach(group => {
|
|
37
|
-
const elementsInGroup = findElements(board, {
|
|
38
|
-
match: item => item.groupId === group.id,
|
|
39
|
-
recursion: () => false
|
|
40
|
-
});
|
|
41
|
-
elementsInGroup.forEach(element => {
|
|
42
|
-
const path = PlaitBoard.findPath(board, element);
|
|
43
|
-
NodeTransforms.setNode(board, { groupId: group.groupId || undefined }, path);
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
selectedGroups
|
|
47
|
-
.map(group => {
|
|
48
|
-
const groupPath = PlaitBoard.findPath(board, group);
|
|
49
|
-
const groupRef = board.pathRef(groupPath);
|
|
50
|
-
return () => {
|
|
51
|
-
groupRef.current && NodeTransforms.removeNode(board, groupRef.current);
|
|
52
|
-
groupRef.unref();
|
|
53
|
-
};
|
|
54
|
-
})
|
|
55
|
-
.forEach(action => {
|
|
56
|
-
action();
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
export const GroupTransforms = {
|
|
61
|
-
addGroup,
|
|
62
|
-
removeGroup
|
|
63
|
-
};
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group.js","sourceRoot":"","sources":["../../../../packages/core/src/transforms/group.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement } from '../interfaces';\nimport {\n    getHighestSelectedGroups,\n    getSelectedIsolatedElementsCanAddToGroup,\n    createGroup,\n    canAddGroup,\n    hasSelectedElementsInSameGroup,\n    canRemoveGroup,\n    findElements,\n    getElementsIndices,\n    isIndicesContinuous,\n    getSelectedElements,\n    getHighestIndexOfElement,\n    moveElementsToNewPathAfterAddGroup\n} from '../utils';\nimport { NodeTransforms } from './node';\n\nexport const addGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedGroups = getHighestSelectedGroups(board, elements);\n    const selectedIsolatedElements = getSelectedIsolatedElementsCanAddToGroup(board);\n    const highestSelectedElements = [...selectedGroups, ...selectedIsolatedElements];\n    const group = createGroup();\n    if (canAddGroup(board)) {\n        highestSelectedElements.forEach(item => {\n            const path = PlaitBoard.findPath(board, item);\n            NodeTransforms.setNode(board, { groupId: group.id }, path);\n        });\n        const selectedElements = getSelectedElements(board);\n        const highestIndexOfSelectedElement = getHighestIndexOfElement(board, selectedElements);\n        const indices = getElementsIndices(board, highestSelectedElements);\n        const isContinuous = isIndicesContinuous(indices);\n        if (!isContinuous) {\n            moveElementsToNewPathAfterAddGroup(board, selectedElements, [highestIndexOfSelectedElement - 1]);\n        }\n        if (hasSelectedElementsInSameGroup(highestSelectedElements)) {\n            const newGroupId = selectedIsolatedElements[0].groupId;\n            NodeTransforms.insertNode(\n                board,\n                {\n                    ...group,\n                    groupId: newGroupId\n                },\n                [board.children.length]\n            );\n        } else {\n            NodeTransforms.insertNode(board, group, [board.children.length]);\n        }\n    }\n};\n\nexport const removeGroup = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedGroups = getHighestSelectedGroups(board, elements);\n    if (canRemoveGroup(board)) {\n        selectedGroups.forEach(group => {\n            const elementsInGroup = findElements(board, {\n                match: item => item.groupId === group.id,\n                recursion: () => false\n            });\n            elementsInGroup.forEach(element => {\n                const path = PlaitBoard.findPath(board, element);\n                NodeTransforms.setNode(board, { groupId: group.groupId || undefined }, path);\n            });\n        });\n        selectedGroups\n            .map(group => {\n                const groupPath = PlaitBoard.findPath(board, group);\n                const groupRef = board.pathRef(groupPath);\n                return () => {\n                    groupRef.current && NodeTransforms.removeNode(board, groupRef.current);\n                    groupRef.unref();\n                };\n            })\n            .forEach(action => {\n                action();\n            });\n    }\n};\n\nexport interface GroupTransforms {\n    addGroup: (board: PlaitBoard, elements?: PlaitElement[]) => void;\n    removeGroup: (board: PlaitBoard, elements?: PlaitElement[]) => void;\n}\n\nexport const GroupTransforms = {\n    addGroup,\n    removeGroup\n};\n"]}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { GeneralTransforms } from './general';
|
|
2
|
-
import { GroupTransforms } from './group';
|
|
3
|
-
import { NodeTransforms } from './node';
|
|
4
|
-
import { SelectionTransforms } from './selection';
|
|
5
|
-
import { ViewportTransforms } from './viewport';
|
|
6
|
-
import { ZIndexTransforms } from './z-index';
|
|
7
|
-
export { BoardTransforms } from './board';
|
|
8
|
-
export { CoreTransforms } from './element';
|
|
9
|
-
export const Transforms = {
|
|
10
|
-
...GeneralTransforms,
|
|
11
|
-
...ViewportTransforms,
|
|
12
|
-
...SelectionTransforms,
|
|
13
|
-
...NodeTransforms,
|
|
14
|
-
...GroupTransforms,
|
|
15
|
-
...ZIndexTransforms
|
|
16
|
-
};
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90cmFuc2Zvcm1zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM5QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDeEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUNoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFN0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUMxQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRTNDLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FLQTtJQUNuQixHQUFHLGlCQUFpQjtJQUNwQixHQUFHLGtCQUFrQjtJQUNyQixHQUFHLG1CQUFtQjtJQUN0QixHQUFHLGNBQWM7SUFDakIsR0FBRyxlQUFlO0lBQ2xCLEdBQUcsZ0JBQWdCO0NBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHZW5lcmFsVHJhbnNmb3JtcyB9IGZyb20gJy4vZ2VuZXJhbCc7XG5pbXBvcnQgeyBHcm91cFRyYW5zZm9ybXMgfSBmcm9tICcuL2dyb3VwJztcbmltcG9ydCB7IE5vZGVUcmFuc2Zvcm1zIH0gZnJvbSAnLi9ub2RlJztcbmltcG9ydCB7IFNlbGVjdGlvblRyYW5zZm9ybXMgfSBmcm9tICcuL3NlbGVjdGlvbic7XG5pbXBvcnQgeyBWaWV3cG9ydFRyYW5zZm9ybXMgfSBmcm9tICcuL3ZpZXdwb3J0JztcbmltcG9ydCB7IFpJbmRleFRyYW5zZm9ybXMgfSBmcm9tICcuL3otaW5kZXgnO1xuXG5leHBvcnQgeyBCb2FyZFRyYW5zZm9ybXMgfSBmcm9tICcuL2JvYXJkJztcbmV4cG9ydCB7IENvcmVUcmFuc2Zvcm1zIH0gZnJvbSAnLi9lbGVtZW50JztcblxuZXhwb3J0IGNvbnN0IFRyYW5zZm9ybXM6IEdlbmVyYWxUcmFuc2Zvcm1zICZcbiAgICBWaWV3cG9ydFRyYW5zZm9ybXMgJlxuICAgIFNlbGVjdGlvblRyYW5zZm9ybXMgJlxuICAgIE5vZGVUcmFuc2Zvcm1zICZcbiAgICBHcm91cFRyYW5zZm9ybXMgJlxuICAgIFpJbmRleFRyYW5zZm9ybXMgPSB7XG4gICAgLi4uR2VuZXJhbFRyYW5zZm9ybXMsXG4gICAgLi4uVmlld3BvcnRUcmFuc2Zvcm1zLFxuICAgIC4uLlNlbGVjdGlvblRyYW5zZm9ybXMsXG4gICAgLi4uTm9kZVRyYW5zZm9ybXMsXG4gICAgLi4uR3JvdXBUcmFuc2Zvcm1zLFxuICAgIC4uLlpJbmRleFRyYW5zZm9ybXNcbn07XG4iXX0=
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { PlaitNode } from '../interfaces/node';
|
|
2
|
-
export function insertNode(board, node, path) {
|
|
3
|
-
const operation = { type: 'insert_node', node, path };
|
|
4
|
-
board.apply(operation);
|
|
5
|
-
}
|
|
6
|
-
export function setNode(board, props, path) {
|
|
7
|
-
const properties = {};
|
|
8
|
-
const newProperties = {};
|
|
9
|
-
const node = PlaitNode.get(board, path);
|
|
10
|
-
for (const k in props) {
|
|
11
|
-
if (node[k] !== props[k]) {
|
|
12
|
-
if (node.hasOwnProperty(k)) {
|
|
13
|
-
properties[k] = node[k];
|
|
14
|
-
}
|
|
15
|
-
if (props[k] != null)
|
|
16
|
-
newProperties[k] = props[k];
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
const operation = { type: 'set_node', properties, newProperties, path };
|
|
20
|
-
board.apply(operation);
|
|
21
|
-
}
|
|
22
|
-
export function removeNode(board, path) {
|
|
23
|
-
const node = PlaitNode.get(board, path);
|
|
24
|
-
const operation = { type: 'remove_node', path, node };
|
|
25
|
-
board.apply(operation);
|
|
26
|
-
}
|
|
27
|
-
export function moveNode(board, path, newPath) {
|
|
28
|
-
const operation = { type: 'move_node', path, newPath };
|
|
29
|
-
board.apply(operation);
|
|
30
|
-
}
|
|
31
|
-
export const NodeTransforms = {
|
|
32
|
-
insertNode,
|
|
33
|
-
setNode,
|
|
34
|
-
removeNode,
|
|
35
|
-
moveNode
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3RyYW5zZm9ybXMvbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHL0MsTUFBTSxVQUFVLFVBQVUsQ0FBQyxLQUFpQixFQUFFLElBQWUsRUFBRSxJQUFVO0lBQ3JFLE1BQU0sU0FBUyxHQUF3QixFQUFFLElBQUksRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzNFLEtBQUssQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDM0IsQ0FBQztBQUVELE1BQU0sVUFBVSxPQUFPLENBQUMsS0FBaUIsRUFBRSxLQUF5QixFQUFFLElBQVU7SUFDNUUsTUFBTSxVQUFVLEdBQXVCLEVBQUUsQ0FBQztJQUMxQyxNQUFNLGFBQWEsR0FBdUIsRUFBRSxDQUFDO0lBQzdDLE1BQU0sSUFBSSxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3hDLEtBQUssTUFBTSxDQUFDLElBQUksS0FBSyxFQUFFLENBQUM7UUFDcEIsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDdkIsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ3pCLFVBQVUsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUIsQ0FBQztZQUNELElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUk7Z0JBQUUsYUFBYSxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO0lBQ0wsQ0FBQztJQUNELE1BQU0sU0FBUyxHQUFxQixFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUMxRixLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLEtBQWlCLEVBQUUsSUFBVTtJQUNwRCxNQUFNLElBQUksR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN4QyxNQUFNLFNBQVMsR0FBd0IsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUMzRSxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLEtBQWlCLEVBQUUsSUFBVSxFQUFFLE9BQWE7SUFDakUsTUFBTSxTQUFTLEdBQXNCLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7SUFDMUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBU0QsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFtQjtJQUMxQyxVQUFVO0lBQ1YsT0FBTztJQUNQLFVBQVU7SUFDVixRQUFRO0NBQ1gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluc2VydE5vZGVPcGVyYXRpb24sIE1vdmVOb2RlT3BlcmF0aW9uLCBSZW1vdmVOb2RlT3BlcmF0aW9uLCBTZXROb2RlT3BlcmF0aW9uIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9vcGVyYXRpb24nO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgUGxhaXROb2RlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IFBhdGggfSBmcm9tICcuLi9pbnRlcmZhY2VzL3BhdGgnO1xuXG5leHBvcnQgZnVuY3Rpb24gaW5zZXJ0Tm9kZShib2FyZDogUGxhaXRCb2FyZCwgbm9kZTogUGxhaXROb2RlLCBwYXRoOiBQYXRoKSB7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBJbnNlcnROb2RlT3BlcmF0aW9uID0geyB0eXBlOiAnaW5zZXJ0X25vZGUnLCBub2RlLCBwYXRoIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNldE5vZGUoYm9hcmQ6IFBsYWl0Qm9hcmQsIHByb3BzOiBQYXJ0aWFsPFBsYWl0Tm9kZT4sIHBhdGg6IFBhdGgpIHtcbiAgICBjb25zdCBwcm9wZXJ0aWVzOiBQYXJ0aWFsPFBsYWl0Tm9kZT4gPSB7fTtcbiAgICBjb25zdCBuZXdQcm9wZXJ0aWVzOiBQYXJ0aWFsPFBsYWl0Tm9kZT4gPSB7fTtcbiAgICBjb25zdCBub2RlID0gUGxhaXROb2RlLmdldChib2FyZCwgcGF0aCk7XG4gICAgZm9yIChjb25zdCBrIGluIHByb3BzKSB7XG4gICAgICAgIGlmIChub2RlW2tdICE9PSBwcm9wc1trXSkge1xuICAgICAgICAgICAgaWYgKG5vZGUuaGFzT3duUHJvcGVydHkoaykpIHtcbiAgICAgICAgICAgICAgICBwcm9wZXJ0aWVzW2tdID0gbm9kZVtrXTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmIChwcm9wc1trXSAhPSBudWxsKSBuZXdQcm9wZXJ0aWVzW2tdID0gcHJvcHNba107XG4gICAgICAgIH1cbiAgICB9XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBTZXROb2RlT3BlcmF0aW9uID0geyB0eXBlOiAnc2V0X25vZGUnLCBwcm9wZXJ0aWVzLCBuZXdQcm9wZXJ0aWVzLCBwYXRoIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlbW92ZU5vZGUoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgpIHtcbiAgICBjb25zdCBub2RlID0gUGxhaXROb2RlLmdldChib2FyZCwgcGF0aCk7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBSZW1vdmVOb2RlT3BlcmF0aW9uID0geyB0eXBlOiAncmVtb3ZlX25vZGUnLCBwYXRoLCBub2RlIH07XG4gICAgYm9hcmQuYXBwbHkob3BlcmF0aW9uKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1vdmVOb2RlKGJvYXJkOiBQbGFpdEJvYXJkLCBwYXRoOiBQYXRoLCBuZXdQYXRoOiBQYXRoKSB7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBNb3ZlTm9kZU9wZXJhdGlvbiA9IHsgdHlwZTogJ21vdmVfbm9kZScsIHBhdGgsIG5ld1BhdGggfTtcbiAgICBib2FyZC5hcHBseShvcGVyYXRpb24pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vZGVUcmFuc2Zvcm1zIHtcbiAgICBpbnNlcnROb2RlOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIG5vZGU6IFBsYWl0Tm9kZSwgcGF0aDogUGF0aCkgPT4gdm9pZDtcbiAgICBzZXROb2RlOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIG5vZGU6IFBhcnRpYWw8UGxhaXROb2RlPiwgcGF0aDogUGF0aCkgPT4gdm9pZDtcbiAgICByZW1vdmVOb2RlOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIHBhdGg6IFBhdGgpID0+IHZvaWQ7XG4gICAgbW92ZU5vZGU6IChib2FyZDogUGxhaXRCb2FyZCwgcGF0aDogUGF0aCwgbmV3UGF0aDogUGF0aCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGNvbnN0IE5vZGVUcmFuc2Zvcm1zOiBOb2RlVHJhbnNmb3JtcyA9IHtcbiAgICBpbnNlcnROb2RlLFxuICAgIHNldE5vZGUsXG4gICAgcmVtb3ZlTm9kZSxcbiAgICBtb3ZlTm9kZVxufTtcbiJdfQ==
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { BOARD_TO_TEMPORARY_ELEMENTS } from '../utils/weak-maps';
|
|
2
|
-
import { getTemporaryRef } from '../utils';
|
|
3
|
-
export function setSelection(board, selection) {
|
|
4
|
-
const operation = { type: 'set_selection', properties: board.selection, newProperties: selection };
|
|
5
|
-
board.apply(operation);
|
|
6
|
-
}
|
|
7
|
-
export const SelectionTransforms = {
|
|
8
|
-
setSelection,
|
|
9
|
-
addSelectionWithTemporaryElements
|
|
10
|
-
};
|
|
11
|
-
export function addSelectionWithTemporaryElements(board, elements) {
|
|
12
|
-
const timeoutId = setTimeout(() => {
|
|
13
|
-
setSelection(board, { anchor: [0, 0], focus: [0, 0] });
|
|
14
|
-
}, 0);
|
|
15
|
-
let ref = getTemporaryRef(board);
|
|
16
|
-
if (ref) {
|
|
17
|
-
clearTimeout(ref.timeoutId);
|
|
18
|
-
const currentElements = ref.elements;
|
|
19
|
-
ref.elements.push(...elements.filter(element => !currentElements.includes(element)));
|
|
20
|
-
ref.timeoutId = timeoutId;
|
|
21
|
-
}
|
|
22
|
-
else {
|
|
23
|
-
BOARD_TO_TEMPORARY_ELEMENTS.set(board, { timeoutId, elements });
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvdHJhbnNmb3Jtcy9zZWxlY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUUzQyxNQUFNLFVBQVUsWUFBWSxDQUFDLEtBQWlCLEVBQUUsU0FBMkI7SUFDdkUsTUFBTSxTQUFTLEdBQTBCLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxVQUFVLEVBQUUsS0FBSyxDQUFDLFNBQVMsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLENBQUM7SUFDMUgsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUMzQixDQUFDO0FBT0QsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXdCO0lBQ3BELFlBQVk7SUFDWixpQ0FBaUM7Q0FDcEMsQ0FBQztBQUVGLE1BQU0sVUFBVSxpQ0FBaUMsQ0FBQyxLQUFpQixFQUFFLFFBQXdCO0lBQ3pGLE1BQU0sU0FBUyxHQUFHLFVBQVUsQ0FBQyxHQUFHLEVBQUU7UUFDOUIsWUFBWSxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzNELENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNOLElBQUksR0FBRyxHQUFHLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ04sWUFBWSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUM1QixNQUFNLGVBQWUsR0FBRyxHQUFHLENBQUMsUUFBUSxDQUFDO1FBQ3JDLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDckYsR0FBRyxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDOUIsQ0FBQztTQUFNLENBQUM7UUFDSiwyQkFBMkIsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDcEUsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXRTZWxlY3Rpb25PcGVyYXRpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL29wZXJhdGlvbic7XG5pbXBvcnQgeyBQbGFpdEJvYXJkIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9ib2FyZCc7XG5pbXBvcnQgeyBTZWxlY3Rpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL3NlbGVjdGlvbic7XG5pbXBvcnQgeyBCT0FSRF9UT19URU1QT1JBUllfRUxFTUVOVFMgfSBmcm9tICcuLi91dGlscy93ZWFrLW1hcHMnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IGdldFRlbXBvcmFyeVJlZiB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHNldFNlbGVjdGlvbihib2FyZDogUGxhaXRCb2FyZCwgc2VsZWN0aW9uOiBTZWxlY3Rpb24gfCBudWxsKSB7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBTZXRTZWxlY3Rpb25PcGVyYXRpb24gPSB7IHR5cGU6ICdzZXRfc2VsZWN0aW9uJywgcHJvcGVydGllczogYm9hcmQuc2VsZWN0aW9uLCBuZXdQcm9wZXJ0aWVzOiBzZWxlY3Rpb24gfTtcbiAgICBib2FyZC5hcHBseShvcGVyYXRpb24pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlbGVjdGlvblRyYW5zZm9ybXMge1xuICAgIHNldFNlbGVjdGlvbjogKGJvYXJkOiBQbGFpdEJvYXJkLCBzZWxlY3Rpb246IFNlbGVjdGlvbiB8IG51bGwpID0+IHZvaWQ7XG4gICAgYWRkU2VsZWN0aW9uV2l0aFRlbXBvcmFyeUVsZW1lbnRzOiAoYm9hcmQ6IFBsYWl0Qm9hcmQsIGVsZW1lbnRzOiBQbGFpdEVsZW1lbnRbXSkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGNvbnN0IFNlbGVjdGlvblRyYW5zZm9ybXM6IFNlbGVjdGlvblRyYW5zZm9ybXMgPSB7XG4gICAgc2V0U2VsZWN0aW9uLFxuICAgIGFkZFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50c1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZFNlbGVjdGlvbldpdGhUZW1wb3JhcnlFbGVtZW50cyhib2FyZDogUGxhaXRCb2FyZCwgZWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSB7XG4gICAgY29uc3QgdGltZW91dElkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHNldFNlbGVjdGlvbihib2FyZCwgeyBhbmNob3I6IFswLCAwXSwgZm9jdXM6IFswLCAwXSB9KTtcbiAgICB9LCAwKTtcbiAgICBsZXQgcmVmID0gZ2V0VGVtcG9yYXJ5UmVmKGJvYXJkKTtcbiAgICBpZiAocmVmKSB7XG4gICAgICAgIGNsZWFyVGltZW91dChyZWYudGltZW91dElkKTtcbiAgICAgICAgY29uc3QgY3VycmVudEVsZW1lbnRzID0gcmVmLmVsZW1lbnRzO1xuICAgICAgICByZWYuZWxlbWVudHMucHVzaCguLi5lbGVtZW50cy5maWx0ZXIoZWxlbWVudCA9PiAhY3VycmVudEVsZW1lbnRzLmluY2x1ZGVzKGVsZW1lbnQpKSk7XG4gICAgICAgIHJlZi50aW1lb3V0SWQgPSB0aW1lb3V0SWQ7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgQk9BUkRfVE9fVEVNUE9SQVJZX0VMRU1FTlRTLnNldChib2FyZCwgeyB0aW1lb3V0SWQsIGVsZW1lbnRzIH0pO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export function setTheme(board, themeColorMode) {
|
|
2
|
-
const operation = { type: 'set_theme', properties: board.theme, newProperties: themeColorMode };
|
|
3
|
-
board.apply(operation);
|
|
4
|
-
}
|
|
5
|
-
export const ViewportTransforms = {
|
|
6
|
-
setTheme
|
|
7
|
-
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90cmFuc2Zvcm1zL3RoZW1lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sVUFBVSxRQUFRLENBQUMsS0FBaUIsRUFBRSxjQUEwQjtJQUNsRSxNQUFNLFNBQVMsR0FBc0IsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxLQUFLLENBQUMsS0FBSyxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsQ0FBQztJQUNuSCxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFNRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBb0I7SUFDL0MsUUFBUTtDQUNYLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXRUaGVtZU9wZXJhdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3BlcmF0aW9uJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFBsYWl0VGhlbWUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHNldFRoZW1lKGJvYXJkOiBQbGFpdEJvYXJkLCB0aGVtZUNvbG9yTW9kZTogUGxhaXRUaGVtZSkge1xuICAgIGNvbnN0IG9wZXJhdGlvbjogU2V0VGhlbWVPcGVyYXRpb24gPSB7IHR5cGU6ICdzZXRfdGhlbWUnLCBwcm9wZXJ0aWVzOiBib2FyZC50aGVtZSwgbmV3UHJvcGVydGllczogdGhlbWVDb2xvck1vZGUgfTtcbiAgICBib2FyZC5hcHBseShvcGVyYXRpb24pO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lVHJhbnNmb3JtcyB7XG4gICAgc2V0VGhlbWU6IChib2FyZDogUGxhaXRCb2FyZCwgdGhlbWVDb2xvck1vZGU6IFBsYWl0VGhlbWUpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBWaWV3cG9ydFRyYW5zZm9ybXM6IFRoZW1lVHJhbnNmb3JtcyA9IHtcbiAgICBzZXRUaGVtZVxufTtcbiJdfQ==
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export function setViewport(board, viewport) {
|
|
2
|
-
const operation = { type: 'set_viewport', properties: board.viewport, newProperties: viewport };
|
|
3
|
-
board.apply(operation);
|
|
4
|
-
}
|
|
5
|
-
export const ViewportTransforms = {
|
|
6
|
-
setViewport
|
|
7
|
-
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy90cmFuc2Zvcm1zL3ZpZXdwb3J0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBaUIsRUFBRSxRQUFrQjtJQUM3RCxNQUFNLFNBQVMsR0FBeUIsRUFBRSxJQUFJLEVBQUUsY0FBYyxFQUFFLFVBQVUsRUFBRSxLQUFLLENBQUMsUUFBUSxFQUFFLGFBQWEsRUFBRSxRQUFRLEVBQUUsQ0FBQztJQUN0SCxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzNCLENBQUM7QUFNRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBdUI7SUFDbEQsV0FBVztDQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXRWaWV3cG9ydE9wZXJhdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3BlcmF0aW9uJztcbmltcG9ydCB7IFBsYWl0Qm9hcmQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2JvYXJkJztcbmltcG9ydCB7IFZpZXdwb3J0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy92aWV3cG9ydCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXRWaWV3cG9ydChib2FyZDogUGxhaXRCb2FyZCwgdmlld3BvcnQ6IFZpZXdwb3J0KSB7XG4gICAgY29uc3Qgb3BlcmF0aW9uOiBTZXRWaWV3cG9ydE9wZXJhdGlvbiA9IHsgdHlwZTogJ3NldF92aWV3cG9ydCcsIHByb3BlcnRpZXM6IGJvYXJkLnZpZXdwb3J0LCBuZXdQcm9wZXJ0aWVzOiB2aWV3cG9ydCB9O1xuICAgIGJvYXJkLmFwcGx5KG9wZXJhdGlvbik7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmlld3BvcnRUcmFuc2Zvcm1zIHtcbiAgICBzZXRWaWV3cG9ydDogKGJvYXJkOiBQbGFpdEJvYXJkLCB2aWV3cG9ydDogVmlld3BvcnQpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBWaWV3cG9ydFRyYW5zZm9ybXM6IFZpZXdwb3J0VHJhbnNmb3JtcyA9IHtcbiAgICBzZXRWaWV3cG9ydFxufTtcbiJdfQ==
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { moveElementsToNewPath } from '../utils';
|
|
2
|
-
import { getAllMoveOptions, getOneMoveOptions } from '../utils/z-index';
|
|
3
|
-
const moveToTop = (board) => {
|
|
4
|
-
const moveOptions = getAllMoveOptions(board, 'up');
|
|
5
|
-
moveElementsToNewPath(board, moveOptions);
|
|
6
|
-
};
|
|
7
|
-
const moveToBottom = (board) => {
|
|
8
|
-
const moveOptions = getAllMoveOptions(board, 'down');
|
|
9
|
-
moveElementsToNewPath(board, moveOptions);
|
|
10
|
-
};
|
|
11
|
-
const moveUp = (board) => {
|
|
12
|
-
const moveOptions = getOneMoveOptions(board, 'up');
|
|
13
|
-
moveElementsToNewPath(board, moveOptions);
|
|
14
|
-
};
|
|
15
|
-
const moveDown = (board) => {
|
|
16
|
-
const moveOptions = getOneMoveOptions(board, 'down');
|
|
17
|
-
moveElementsToNewPath(board, moveOptions);
|
|
18
|
-
};
|
|
19
|
-
export const ZIndexTransforms = { moveUp, moveDown, moveToTop, moveToBottom };
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiei1pbmRleC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3RyYW5zZm9ybXMvei1pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDakQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEUsTUFBTSxTQUFTLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDcEMsTUFBTSxXQUFXLEdBQUcsaUJBQWlCLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ25ELHFCQUFxQixDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztBQUM5QyxDQUFDLENBQUM7QUFFRixNQUFNLFlBQVksR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUN2QyxNQUFNLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDckQscUJBQXFCLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQzlDLENBQUMsQ0FBQztBQUVGLE1BQU0sTUFBTSxHQUFHLENBQUMsS0FBaUIsRUFBRSxFQUFFO0lBQ2pDLE1BQU0sV0FBVyxHQUFHLGlCQUFpQixDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNuRCxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUM7QUFDOUMsQ0FBQyxDQUFDO0FBRUYsTUFBTSxRQUFRLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDbkMsTUFBTSxXQUFXLEdBQUcsaUJBQWlCLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3JELHFCQUFxQixDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztBQUM5QyxDQUFDLENBQUM7QUFTRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgbW92ZUVsZW1lbnRzVG9OZXdQYXRoIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgZ2V0QWxsTW92ZU9wdGlvbnMsIGdldE9uZU1vdmVPcHRpb25zIH0gZnJvbSAnLi4vdXRpbHMvei1pbmRleCc7XG5cbmNvbnN0IG1vdmVUb1RvcCA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IG1vdmVPcHRpb25zID0gZ2V0QWxsTW92ZU9wdGlvbnMoYm9hcmQsICd1cCcpO1xuICAgIG1vdmVFbGVtZW50c1RvTmV3UGF0aChib2FyZCwgbW92ZU9wdGlvbnMpO1xufTtcblxuY29uc3QgbW92ZVRvQm90dG9tID0gKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB7XG4gICAgY29uc3QgbW92ZU9wdGlvbnMgPSBnZXRBbGxNb3ZlT3B0aW9ucyhib2FyZCwgJ2Rvd24nKTtcbiAgICBtb3ZlRWxlbWVudHNUb05ld1BhdGgoYm9hcmQsIG1vdmVPcHRpb25zKTtcbn07XG5cbmNvbnN0IG1vdmVVcCA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IG1vdmVPcHRpb25zID0gZ2V0T25lTW92ZU9wdGlvbnMoYm9hcmQsICd1cCcpO1xuICAgIG1vdmVFbGVtZW50c1RvTmV3UGF0aChib2FyZCwgbW92ZU9wdGlvbnMpO1xufTtcblxuY29uc3QgbW92ZURvd24gPSAoYm9hcmQ6IFBsYWl0Qm9hcmQpID0+IHtcbiAgICBjb25zdCBtb3ZlT3B0aW9ucyA9IGdldE9uZU1vdmVPcHRpb25zKGJvYXJkLCAnZG93bicpO1xuICAgIG1vdmVFbGVtZW50c1RvTmV3UGF0aChib2FyZCwgbW92ZU9wdGlvbnMpO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBaSW5kZXhUcmFuc2Zvcm1zIHtcbiAgICBtb3ZlVXA6IChib2FyZDogUGxhaXRCb2FyZCkgPT4gdm9pZDtcbiAgICBtb3ZlRG93bjogKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB2b2lkO1xuICAgIG1vdmVUb1RvcDogKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB2b2lkO1xuICAgIG1vdmVUb0JvdHRvbTogKGJvYXJkOiBQbGFpdEJvYXJkKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgY29uc3QgWkluZGV4VHJhbnNmb3JtcyA9IHsgbW92ZVVwLCBtb3ZlRG93biwgbW92ZVRvVG9wLCBtb3ZlVG9Cb3R0b20gfTtcbiJdfQ==
|