@plait/core 0.32.0 → 0.34.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/esm2022/board/board.component.mjs +3 -12
- package/esm2022/plugins/with-moving.mjs +4 -1
- package/esm2022/utils/math.mjs +52 -1
- package/esm2022/utils/selected-element.mjs +11 -1
- package/esm2022/utils/viewport.mjs +32 -4
- package/fesm2022/plait-core.mjs +220 -137
- package/fesm2022/plait-core.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/math.d.ts +1 -0
- package/utils/selected-element.d.ts +2 -0
- package/utils/viewport.d.ts +1 -0
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { SCROLL_BAR_WIDTH } from '../constants';
|
|
2
|
-
import { PlaitBoard } from '../interfaces';
|
|
2
|
+
import { PlaitBoard, Point } from '../interfaces';
|
|
3
|
+
import { BoardTransforms } from '../transforms/board';
|
|
3
4
|
import { getRectangleByElements } from './element';
|
|
4
5
|
import { BOARD_TO_VIEWPORT_ORIGINATION } from './weak-maps';
|
|
5
6
|
const IS_FROM_SCROLLING = new WeakMap();
|
|
@@ -88,8 +89,9 @@ export function setSVGViewBox(board, viewBox) {
|
|
|
88
89
|
}
|
|
89
90
|
export function updateViewportOffset(board) {
|
|
90
91
|
const origination = getViewportOrigination(board);
|
|
91
|
-
if (!origination)
|
|
92
|
+
if (!origination) {
|
|
92
93
|
return;
|
|
94
|
+
}
|
|
93
95
|
const { zoom } = board.viewport;
|
|
94
96
|
const viewBox = getViewBox(board, zoom);
|
|
95
97
|
const scrollLeft = (origination[0] - viewBox[0]) * zoom;
|
|
@@ -98,11 +100,37 @@ export function updateViewportOffset(board) {
|
|
|
98
100
|
}
|
|
99
101
|
export function updateViewportContainerScroll(board, left, top, isFromViewportChange = true) {
|
|
100
102
|
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
103
|
+
const previousScrollLeft = viewportContainer.scrollLeft;
|
|
104
|
+
const previousScrollTop = viewportContainer.scrollTop;
|
|
101
105
|
if (viewportContainer.scrollLeft !== left || viewportContainer.scrollTop !== top) {
|
|
102
106
|
viewportContainer.scrollLeft = left;
|
|
103
107
|
viewportContainer.scrollTop = top;
|
|
104
|
-
|
|
108
|
+
const offsetWidth = viewportContainer.offsetWidth;
|
|
109
|
+
const offsetHeight = viewportContainer.offsetHeight;
|
|
110
|
+
if (previousScrollLeft === viewportContainer.scrollLeft && previousScrollTop === viewportContainer.scrollTop) {
|
|
111
|
+
// The scroll event cannot be triggered, so the origination is modified directly based on the scroll distance.
|
|
112
|
+
updateViewportByScrolling(board, previousScrollLeft, previousScrollTop);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
const isValidLeftOrTop = left > 0 &&
|
|
116
|
+
top > 0 &&
|
|
117
|
+
left < viewportContainer.scrollWidth - offsetWidth &&
|
|
118
|
+
top < viewportContainer.scrollHeight - offsetHeight;
|
|
119
|
+
if (isFromViewportChange && isValidLeftOrTop) {
|
|
120
|
+
setIsFromViewportChange(board, true);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
export function updateViewportByScrolling(board, scrollLeft, scrollTop) {
|
|
126
|
+
const zoom = board.viewport.zoom;
|
|
127
|
+
const viewBox = getViewBox(board, zoom);
|
|
128
|
+
const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]];
|
|
129
|
+
if (Point.isEquals(origination, board.viewport.origination)) {
|
|
130
|
+
return;
|
|
105
131
|
}
|
|
132
|
+
BoardTransforms.updateViewport(board, origination);
|
|
133
|
+
setIsFromScrolling(board, true);
|
|
106
134
|
}
|
|
107
135
|
export function initializeViewportContainer(board) {
|
|
108
136
|
const { width, height } = getViewportContainerRect(board);
|
|
@@ -157,4 +185,4 @@ export const setIsFromViewportChange = (board, state) => {
|
|
|
157
185
|
IS_FROM_VIEWPORT_CHANGE.set(board, state);
|
|
158
186
|
};
|
|
159
187
|
export function scrollToRectangle(board, client) { }
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/viewport.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard, Point, RectangleClient } from '../interfaces';\nimport { getRectangleByElements } from './element';\nimport { BOARD_TO_VIEWPORT_ORIGINATION } from './weak-maps';\n\nconst IS_FROM_SCROLLING = new WeakMap<PlaitBoard, boolean>();\n\nconst IS_FROM_VIEWPORT_CHANGE = new WeakMap<PlaitBoard, boolean>();\n\nexport function getViewportContainerRect(board: PlaitBoard) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const viewportRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n\n    return {\n        width: viewportRect.width + scrollBarWidth,\n        height: viewportRect.height + scrollBarWidth\n    };\n}\n\nexport function getElementHostBBox(board: PlaitBoard, zoom: number) {\n    const childrenRect = getRectangleByElements(board, board.children, true);\n    const viewportContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const containerWidth = viewportContainerRect.width / zoom;\n    const containerHeight = viewportContainerRect.height / zoom;\n    let left: number;\n    let right: number;\n    let top: number;\n    let bottom: number;\n\n    if (childrenRect.width < containerWidth) {\n        const centerX = childrenRect.x + childrenRect.width / 2;\n        const halfContainerWidth = containerWidth / 2;\n        left = centerX - halfContainerWidth;\n        right = centerX + halfContainerWidth;\n    } else {\n        left = childrenRect.x;\n        right = childrenRect.x + childrenRect.width;\n    }\n    if (childrenRect.height < containerHeight) {\n        const centerY = childrenRect.y + childrenRect.height / 2;\n        const halfContainerHeight = containerHeight / 2;\n        top = centerY - halfContainerHeight;\n        bottom = centerY + halfContainerHeight;\n    } else {\n        top = childrenRect.y;\n        bottom = childrenRect.y + childrenRect.height;\n    }\n    return {\n        left,\n        right,\n        top,\n        bottom\n    };\n}\n\n/**\n * 验证缩放比是否符合限制，如果超出限制，则返回合适的缩放比\n * @param zoom 缩放比\n * @param minZoom 最小缩放比\n * @param maxZoom 最大缩放比\n * @returns 正确的缩放比\n */\nexport function clampZoomLevel(zoom: number, minZoom = 0.2, maxZoom = 4) {\n    return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;\n}\n\nexport function getViewBox(board: PlaitBoard, zoom: number) {\n    const boardContainerRectangle = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBBox = getElementHostBBox(board, zoom);\n\n    const horizontalPadding = boardContainerRectangle.width / 2;\n    const verticalPadding = boardContainerRectangle.height / 2;\n    const viewBox = [\n        elementHostBBox.left - horizontalPadding / zoom,\n        elementHostBBox.top - verticalPadding / zoom,\n        elementHostBBox.right - elementHostBBox.left + (horizontalPadding * 2) / zoom,\n        elementHostBBox.bottom - elementHostBBox.top + (verticalPadding * 2) / zoom\n    ];\n    return viewBox;\n}\n\nexport function getViewBoxCenterPoint(board: PlaitBoard) {\n    const childrenRectangle = getRectangleByElements(board, board.children, true);\n    return [childrenRectangle.x + childrenRectangle.width / 2, childrenRectangle.y + childrenRectangle.height / 2] as Point;\n}\n\nexport function setSVGViewBox(board: PlaitBoard, viewBox: number[]) {\n    const zoom = board.viewport.zoom;\n    const hostElement = PlaitBoard.getHost(board);\n    hostElement.style.display = 'block';\n    hostElement.style.width = `${viewBox[2] * zoom}px`;\n    hostElement.style.height = `${viewBox[3] * zoom}px`;\n\n    if (viewBox && viewBox[2] > 0 && viewBox[3] > 0) {\n        hostElement.setAttribute('viewBox', viewBox.join(' '));\n    }\n}\n\nexport function updateViewportOffset(board: PlaitBoard) {\n    const origination = getViewportOrigination(board);\n    if (!origination) return;\n\n    const { zoom } = board.viewport;\n    const viewBox = getViewBox(board, zoom);\n    const scrollLeft = (origination![0] - viewBox[0]) * zoom;\n    const scrollTop = (origination![1] - viewBox[1]) * zoom;\n    updateViewportContainerScroll(board, scrollLeft, scrollTop);\n}\n\nexport function updateViewportContainerScroll(board: PlaitBoard, left: number, top: number, isFromViewportChange: boolean = true) {\n    const viewportContainer = PlaitBoard.getViewportContainer(board);\n    if (viewportContainer.scrollLeft !== left || viewportContainer.scrollTop !== top) {\n        viewportContainer.scrollLeft = left;\n        viewportContainer.scrollTop = top;\n        isFromViewportChange && setIsFromViewportChange(board, true);\n    }\n}\n\nexport function initializeViewportContainer(board: PlaitBoard) {\n    const { width, height } = getViewportContainerRect(board);\n    const viewportContainer = PlaitBoard.getViewportContainer(board);\n    viewportContainer.style.width = `${width}px`;\n    viewportContainer.style.height = `${height}px`;\n}\n\nexport function initializeViewBox(board: PlaitBoard) {\n    const zoom = board.viewport.zoom;\n    const viewBox = getViewBox(board, zoom);\n    setSVGViewBox(board, viewBox);\n}\n\nexport function initializeViewportOffset(board: PlaitBoard) {\n    if (!board.viewport?.origination) {\n        const zoom = board.viewport.zoom;\n        const viewportContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n        const viewBox = getViewBox(board, zoom);\n        const centerX = viewBox[0] + viewBox[2] / 2;\n        const centerY = viewBox[1] + viewBox[3] / 2;\n        const origination = [centerX - viewportContainerRect.width / 2 / zoom, centerY - viewportContainerRect.height / 2 / zoom] as Point;\n        updateViewportOrigination(board, origination);\n        updateViewportOffset(board);\n        return;\n    }\n    updateViewportOffset(board);\n}\n\nexport const updateViewportOrigination = (board: PlaitBoard, origination: Point) => {\n    BOARD_TO_VIEWPORT_ORIGINATION.set(board, origination);\n};\n\nexport const clearViewportOrigination = (board: PlaitBoard) => {\n    BOARD_TO_VIEWPORT_ORIGINATION.delete(board);\n};\n\nexport const getViewportOrigination = (board: PlaitBoard) => {\n    const origination = BOARD_TO_VIEWPORT_ORIGINATION.get(board);\n    if (origination) {\n        return origination;\n    } else {\n        return board.viewport.origination;\n    }\n};\n\nexport const isFromScrolling = (board: PlaitBoard) => {\n    return !!IS_FROM_SCROLLING.get(board);\n};\n\nexport const setIsFromScrolling = (board: PlaitBoard, state: boolean) => {\n    IS_FROM_SCROLLING.set(board, state);\n};\n\nexport const isFromViewportChange = (board: PlaitBoard) => {\n    return !!IS_FROM_VIEWPORT_CHANGE.get(board);\n};\n\nexport const setIsFromViewportChange = (board: PlaitBoard, state: boolean) => {\n    IS_FROM_VIEWPORT_CHANGE.set(board, state);\n};\n\nexport function scrollToRectangle(board: PlaitBoard, client: RectangleClient) {}\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/viewport.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard, Point, RectangleClient } from '../interfaces';\nimport { BoardTransforms } from '../transforms/board';\nimport { getRectangleByElements } from './element';\nimport { BOARD_TO_VIEWPORT_ORIGINATION } from './weak-maps';\n\nconst IS_FROM_SCROLLING = new WeakMap<PlaitBoard, boolean>();\n\nconst IS_FROM_VIEWPORT_CHANGE = new WeakMap<PlaitBoard, boolean>();\n\nexport function getViewportContainerRect(board: PlaitBoard) {\n    const { hideScrollbar } = board.options;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const viewportRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n\n    return {\n        width: viewportRect.width + scrollBarWidth,\n        height: viewportRect.height + scrollBarWidth\n    };\n}\n\nexport function getElementHostBBox(board: PlaitBoard, zoom: number) {\n    const childrenRect = getRectangleByElements(board, board.children, true);\n    const viewportContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const containerWidth = viewportContainerRect.width / zoom;\n    const containerHeight = viewportContainerRect.height / zoom;\n    let left: number;\n    let right: number;\n    let top: number;\n    let bottom: number;\n\n    if (childrenRect.width < containerWidth) {\n        const centerX = childrenRect.x + childrenRect.width / 2;\n        const halfContainerWidth = containerWidth / 2;\n        left = centerX - halfContainerWidth;\n        right = centerX + halfContainerWidth;\n    } else {\n        left = childrenRect.x;\n        right = childrenRect.x + childrenRect.width;\n    }\n    if (childrenRect.height < containerHeight) {\n        const centerY = childrenRect.y + childrenRect.height / 2;\n        const halfContainerHeight = containerHeight / 2;\n        top = centerY - halfContainerHeight;\n        bottom = centerY + halfContainerHeight;\n    } else {\n        top = childrenRect.y;\n        bottom = childrenRect.y + childrenRect.height;\n    }\n    return {\n        left,\n        right,\n        top,\n        bottom\n    };\n}\n\n/**\n * 验证缩放比是否符合限制，如果超出限制，则返回合适的缩放比\n * @param zoom 缩放比\n * @param minZoom 最小缩放比\n * @param maxZoom 最大缩放比\n * @returns 正确的缩放比\n */\nexport function clampZoomLevel(zoom: number, minZoom = 0.2, maxZoom = 4) {\n    return zoom < minZoom ? minZoom : zoom > maxZoom ? maxZoom : zoom;\n}\n\nexport function getViewBox(board: PlaitBoard, zoom: number) {\n    const boardContainerRectangle = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n    const elementHostBBox = getElementHostBBox(board, zoom);\n\n    const horizontalPadding = boardContainerRectangle.width / 2;\n    const verticalPadding = boardContainerRectangle.height / 2;\n    const viewBox = [\n        elementHostBBox.left - horizontalPadding / zoom,\n        elementHostBBox.top - verticalPadding / zoom,\n        elementHostBBox.right - elementHostBBox.left + (horizontalPadding * 2) / zoom,\n        elementHostBBox.bottom - elementHostBBox.top + (verticalPadding * 2) / zoom\n    ];\n    return viewBox;\n}\n\nexport function getViewBoxCenterPoint(board: PlaitBoard) {\n    const childrenRectangle = getRectangleByElements(board, board.children, true);\n    return [childrenRectangle.x + childrenRectangle.width / 2, childrenRectangle.y + childrenRectangle.height / 2] as Point;\n}\n\nexport function setSVGViewBox(board: PlaitBoard, viewBox: number[]) {\n    const zoom = board.viewport.zoom;\n    const hostElement = PlaitBoard.getHost(board);\n    hostElement.style.display = 'block';\n    hostElement.style.width = `${viewBox[2] * zoom}px`;\n    hostElement.style.height = `${viewBox[3] * zoom}px`;\n\n    if (viewBox && viewBox[2] > 0 && viewBox[3] > 0) {\n        hostElement.setAttribute('viewBox', viewBox.join(' '));\n    }\n}\n\nexport function updateViewportOffset(board: PlaitBoard) {\n    const origination = getViewportOrigination(board);\n    if (!origination) {\n        return;\n    }\n    const { zoom } = board.viewport;\n    const viewBox = getViewBox(board, zoom);\n    const scrollLeft = (origination![0] - viewBox[0]) * zoom;\n    const scrollTop = (origination![1] - viewBox[1]) * zoom;\n    updateViewportContainerScroll(board, scrollLeft, scrollTop);\n}\n\nexport function updateViewportContainerScroll(board: PlaitBoard, left: number, top: number, isFromViewportChange: boolean = true) {\n    const viewportContainer = PlaitBoard.getViewportContainer(board);\n    const previousScrollLeft = viewportContainer.scrollLeft;\n    const previousScrollTop = viewportContainer.scrollTop;\n    if (viewportContainer.scrollLeft !== left || viewportContainer.scrollTop !== top) {\n        viewportContainer.scrollLeft = left;\n        viewportContainer.scrollTop = top;\n        const offsetWidth = viewportContainer.offsetWidth;\n        const offsetHeight = viewportContainer.offsetHeight;\n        if (previousScrollLeft === viewportContainer.scrollLeft && previousScrollTop === viewportContainer.scrollTop) {\n            // The scroll event cannot be triggered, so the origination is modified directly based on the scroll distance.\n            updateViewportByScrolling(board, previousScrollLeft, previousScrollTop);\n        } else {\n            const isValidLeftOrTop =\n                left > 0 &&\n                top > 0 &&\n                left < viewportContainer.scrollWidth - offsetWidth &&\n                top < viewportContainer.scrollHeight - offsetHeight;\n            if (isFromViewportChange && isValidLeftOrTop) {\n                setIsFromViewportChange(board, true);\n            }\n        }\n    }\n}\n\nexport function updateViewportByScrolling(board: PlaitBoard, scrollLeft: number, scrollTop: number) {\n    const zoom = board.viewport.zoom;\n    const viewBox = getViewBox(board, zoom);\n    const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]] as Point;\n    if (Point.isEquals(origination, board.viewport.origination)) {\n        return;\n    }\n    BoardTransforms.updateViewport(board, origination);\n    setIsFromScrolling(board, true);\n}\n\nexport function initializeViewportContainer(board: PlaitBoard) {\n    const { width, height } = getViewportContainerRect(board);\n    const viewportContainer = PlaitBoard.getViewportContainer(board);\n    viewportContainer.style.width = `${width}px`;\n    viewportContainer.style.height = `${height}px`;\n}\n\nexport function initializeViewBox(board: PlaitBoard) {\n    const zoom = board.viewport.zoom;\n    const viewBox = getViewBox(board, zoom);\n    setSVGViewBox(board, viewBox);\n}\n\nexport function initializeViewportOffset(board: PlaitBoard) {\n    if (!board.viewport?.origination) {\n        const zoom = board.viewport.zoom;\n        const viewportContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();\n        const viewBox = getViewBox(board, zoom);\n        const centerX = viewBox[0] + viewBox[2] / 2;\n        const centerY = viewBox[1] + viewBox[3] / 2;\n        const origination = [centerX - viewportContainerRect.width / 2 / zoom, centerY - viewportContainerRect.height / 2 / zoom] as Point;\n        updateViewportOrigination(board, origination);\n        updateViewportOffset(board);\n        return;\n    }\n    updateViewportOffset(board);\n}\n\nexport const updateViewportOrigination = (board: PlaitBoard, origination: Point) => {\n    BOARD_TO_VIEWPORT_ORIGINATION.set(board, origination);\n};\n\nexport const clearViewportOrigination = (board: PlaitBoard) => {\n    BOARD_TO_VIEWPORT_ORIGINATION.delete(board);\n};\n\nexport const getViewportOrigination = (board: PlaitBoard) => {\n    const origination = BOARD_TO_VIEWPORT_ORIGINATION.get(board);\n    if (origination) {\n        return origination;\n    } else {\n        return board.viewport.origination;\n    }\n};\n\nexport const isFromScrolling = (board: PlaitBoard) => {\n    return !!IS_FROM_SCROLLING.get(board);\n};\n\nexport const setIsFromScrolling = (board: PlaitBoard, state: boolean) => {\n    IS_FROM_SCROLLING.set(board, state);\n};\n\nexport const isFromViewportChange = (board: PlaitBoard) => {\n    return !!IS_FROM_VIEWPORT_CHANGE.get(board);\n};\n\nexport const setIsFromViewportChange = (board: PlaitBoard, state: boolean) => {\n    IS_FROM_VIEWPORT_CHANGE.set(board, state);\n};\n\nexport function scrollToRectangle(board: PlaitBoard, client: RectangleClient) {}\n"]}
|
package/fesm2022/plait-core.mjs
CHANGED
|
@@ -142,6 +142,15 @@ const isSelectedElement = (board, element) => {
|
|
|
142
142
|
const selectedElements = getSelectedElements(board);
|
|
143
143
|
return !!selectedElements.find(value => value === element);
|
|
144
144
|
};
|
|
145
|
+
const temporaryDisableSelection = (board) => {
|
|
146
|
+
const currentOptions = board.getPluginOptions(PlaitPluginKey.withSelection);
|
|
147
|
+
board.setPluginOptions(PlaitPluginKey.withSelection, {
|
|
148
|
+
isDisabledSelect: true
|
|
149
|
+
});
|
|
150
|
+
setTimeout(() => {
|
|
151
|
+
board.setPluginOptions(PlaitPluginKey.withSelection, { ...currentOptions });
|
|
152
|
+
}, 0);
|
|
153
|
+
};
|
|
145
154
|
|
|
146
155
|
/**
|
|
147
156
|
* @license
|
|
@@ -724,6 +733,57 @@ const isPointInRoundRectangle = (point, rectangle, radius) => {
|
|
|
724
733
|
const downScale = (number) => {
|
|
725
734
|
return Number(number.toFixed(2));
|
|
726
735
|
};
|
|
736
|
+
// https://gist.github.com/nicholaswmin/c2661eb11cad5671d816
|
|
737
|
+
const catmullRomFitting = function (points) {
|
|
738
|
+
const alpha = 0.5;
|
|
739
|
+
let p0, p1, p2, p3, bp1, bp2, d1, d2, d3, A, B, N, M;
|
|
740
|
+
var d3powA, d2powA, d3pow2A, d2pow2A, d1pow2A, d1powA;
|
|
741
|
+
const result = [];
|
|
742
|
+
result.push([Math.round(points[0][0]), Math.round(points[0][1])]);
|
|
743
|
+
var length = points.length;
|
|
744
|
+
for (var i = 0; i < length - 1; i++) {
|
|
745
|
+
p0 = i == 0 ? points[0] : points[i - 1];
|
|
746
|
+
p1 = points[i];
|
|
747
|
+
p2 = points[i + 1];
|
|
748
|
+
p3 = i + 2 < length ? points[i + 2] : p2;
|
|
749
|
+
d1 = Math.sqrt(Math.pow(p0[0] - p1[0], 2) + Math.pow(p0[1] - p1[1], 2));
|
|
750
|
+
d2 = Math.sqrt(Math.pow(p1[0] - p2[0], 2) + Math.pow(p1[1] - p2[1], 2));
|
|
751
|
+
d3 = Math.sqrt(Math.pow(p2[0] - p3[0], 2) + Math.pow(p2[1] - p3[1], 2));
|
|
752
|
+
// Catmull-Rom to Cubic Bezier conversion matrix
|
|
753
|
+
// A = 2d1^2a + 3d1^a * d2^a + d3^2a
|
|
754
|
+
// B = 2d3^2a + 3d3^a * d2^a + d2^2a
|
|
755
|
+
// [ 0 1 0 0 ]
|
|
756
|
+
// [ -d2^2a /N A/N d1^2a /N 0 ]
|
|
757
|
+
// [ 0 d3^2a /M B/M -d2^2a /M ]
|
|
758
|
+
// [ 0 0 1 0 ]
|
|
759
|
+
d3powA = Math.pow(d3, alpha);
|
|
760
|
+
d3pow2A = Math.pow(d3, 2 * alpha);
|
|
761
|
+
d2powA = Math.pow(d2, alpha);
|
|
762
|
+
d2pow2A = Math.pow(d2, 2 * alpha);
|
|
763
|
+
d1powA = Math.pow(d1, alpha);
|
|
764
|
+
d1pow2A = Math.pow(d1, 2 * alpha);
|
|
765
|
+
A = 2 * d1pow2A + 3 * d1powA * d2powA + d2pow2A;
|
|
766
|
+
B = 2 * d3pow2A + 3 * d3powA * d2powA + d2pow2A;
|
|
767
|
+
N = 3 * d1powA * (d1powA + d2powA);
|
|
768
|
+
if (N > 0) {
|
|
769
|
+
N = 1 / N;
|
|
770
|
+
}
|
|
771
|
+
M = 3 * d3powA * (d3powA + d2powA);
|
|
772
|
+
if (M > 0) {
|
|
773
|
+
M = 1 / M;
|
|
774
|
+
}
|
|
775
|
+
bp1 = [(-d2pow2A * p0[0] + A * p1[0] + d1pow2A * p2[0]) * N, (-d2pow2A * p0[1] + A * p1[1] + d1pow2A * p2[1]) * N];
|
|
776
|
+
bp2 = [(d3pow2A * p1[0] + B * p2[0] - d2pow2A * p3[0]) * M, (d3pow2A * p1[1] + B * p2[1] - d2pow2A * p3[1]) * M];
|
|
777
|
+
if (bp1[0] == 0 && bp1[1] == 0) {
|
|
778
|
+
bp1 = p1;
|
|
779
|
+
}
|
|
780
|
+
if (bp2[0] == 0 && bp2[1] == 0) {
|
|
781
|
+
bp2 = p2;
|
|
782
|
+
}
|
|
783
|
+
result.push(bp1, bp2, p2);
|
|
784
|
+
}
|
|
785
|
+
return result;
|
|
786
|
+
};
|
|
727
787
|
|
|
728
788
|
function transformPoints(board, points) {
|
|
729
789
|
const newPoints = points.map(point => {
|
|
@@ -1082,6 +1142,132 @@ function drawBezierPath(points, options) {
|
|
|
1082
1142
|
return g;
|
|
1083
1143
|
}
|
|
1084
1144
|
|
|
1145
|
+
function setViewport(board, viewport) {
|
|
1146
|
+
const operation = { type: 'set_viewport', properties: board.viewport, newProperties: viewport };
|
|
1147
|
+
board.apply(operation);
|
|
1148
|
+
}
|
|
1149
|
+
const ViewportTransforms$1 = {
|
|
1150
|
+
setViewport
|
|
1151
|
+
};
|
|
1152
|
+
|
|
1153
|
+
function setTheme(board, themeColorMode) {
|
|
1154
|
+
const operation = { type: 'set_theme', properties: board.theme, newProperties: themeColorMode };
|
|
1155
|
+
board.apply(operation);
|
|
1156
|
+
}
|
|
1157
|
+
const ViewportTransforms = {
|
|
1158
|
+
setTheme
|
|
1159
|
+
};
|
|
1160
|
+
|
|
1161
|
+
function updateViewport(board, origination, zoom) {
|
|
1162
|
+
zoom = zoom ?? board.viewport.zoom;
|
|
1163
|
+
setViewport(board, {
|
|
1164
|
+
...board.viewport,
|
|
1165
|
+
zoom,
|
|
1166
|
+
origination
|
|
1167
|
+
});
|
|
1168
|
+
clearViewportOrigination(board);
|
|
1169
|
+
}
|
|
1170
|
+
const updatePointerType = (board, pointer) => {
|
|
1171
|
+
board.pointer = pointer;
|
|
1172
|
+
const boardComponent = BOARD_TO_COMPONENT.get(board);
|
|
1173
|
+
boardComponent?.markForCheck();
|
|
1174
|
+
};
|
|
1175
|
+
function updateZoom(board, newZoom, isCenter = true) {
|
|
1176
|
+
newZoom = clampZoomLevel(newZoom);
|
|
1177
|
+
const mousePoint = PlaitBoard.getMovingPointInBoard(board);
|
|
1178
|
+
const nativeElement = PlaitBoard.getBoardContainer(board);
|
|
1179
|
+
const nativeElementRect = nativeElement.getBoundingClientRect();
|
|
1180
|
+
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
1181
|
+
let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];
|
|
1182
|
+
if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {
|
|
1183
|
+
focusPoint = toPoint(mousePoint[0], mousePoint[1], nativeElement);
|
|
1184
|
+
}
|
|
1185
|
+
const zoom = board.viewport.zoom;
|
|
1186
|
+
const origination = getViewportOrigination(board);
|
|
1187
|
+
const centerX = origination[0] + focusPoint[0] / zoom;
|
|
1188
|
+
const centerY = origination[1] + focusPoint[1] / zoom;
|
|
1189
|
+
const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom];
|
|
1190
|
+
updateViewport(board, newOrigination, newZoom);
|
|
1191
|
+
}
|
|
1192
|
+
function fitViewport(board) {
|
|
1193
|
+
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
1194
|
+
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
1195
|
+
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
1196
|
+
const zoom = board.viewport.zoom;
|
|
1197
|
+
const autoFitPadding = 16;
|
|
1198
|
+
const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;
|
|
1199
|
+
const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;
|
|
1200
|
+
let newZoom = zoom;
|
|
1201
|
+
if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {
|
|
1202
|
+
newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);
|
|
1203
|
+
}
|
|
1204
|
+
else {
|
|
1205
|
+
newZoom = 1;
|
|
1206
|
+
}
|
|
1207
|
+
const centerPoint = getViewBoxCenterPoint(board);
|
|
1208
|
+
const newOrigination = [
|
|
1209
|
+
centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,
|
|
1210
|
+
centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom
|
|
1211
|
+
];
|
|
1212
|
+
updateViewport(board, newOrigination, newZoom);
|
|
1213
|
+
}
|
|
1214
|
+
function fitViewportWidth(board, options) {
|
|
1215
|
+
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
1216
|
+
const boardContainer = PlaitBoard.getBoardContainer(board);
|
|
1217
|
+
const boardContainerRectangle = boardContainer.getBoundingClientRect();
|
|
1218
|
+
let finalWidth = 0;
|
|
1219
|
+
if (options.maxWidth) {
|
|
1220
|
+
finalWidth = options.maxWidth;
|
|
1221
|
+
}
|
|
1222
|
+
else {
|
|
1223
|
+
finalWidth = boardContainerRectangle.width;
|
|
1224
|
+
}
|
|
1225
|
+
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
1226
|
+
const contentWidth = finalWidth - 2 * options.autoFitPadding;
|
|
1227
|
+
let newZoom = 0;
|
|
1228
|
+
if (contentWidth < elementHostBox.width) {
|
|
1229
|
+
newZoom = Math.min(contentWidth / elementHostBox.width);
|
|
1230
|
+
}
|
|
1231
|
+
else {
|
|
1232
|
+
newZoom = 1;
|
|
1233
|
+
}
|
|
1234
|
+
let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;
|
|
1235
|
+
if (finalHeight > options.limitHeight) {
|
|
1236
|
+
const containerEl = boardContainer.closest(`.${options.containerClass}`);
|
|
1237
|
+
containerEl.style.height = `${finalHeight}px`;
|
|
1238
|
+
initializeViewportContainer(board);
|
|
1239
|
+
}
|
|
1240
|
+
else {
|
|
1241
|
+
finalHeight = options.limitHeight;
|
|
1242
|
+
}
|
|
1243
|
+
const centerX = elementHostBox.x + elementHostBox.width / 2;
|
|
1244
|
+
const centerY = elementHostBox.y + elementHostBox.height / 2;
|
|
1245
|
+
const newOrigination = [
|
|
1246
|
+
centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,
|
|
1247
|
+
centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom
|
|
1248
|
+
];
|
|
1249
|
+
updateViewport(board, newOrigination, newZoom);
|
|
1250
|
+
}
|
|
1251
|
+
/**
|
|
1252
|
+
* apply theme to every element (remove element custom properties)
|
|
1253
|
+
* invoke applyThemeColor
|
|
1254
|
+
*/
|
|
1255
|
+
function updateThemeColor(board, mode) {
|
|
1256
|
+
mode = mode ?? board.theme.themeColorMode;
|
|
1257
|
+
setTheme(board, { themeColorMode: mode });
|
|
1258
|
+
depthFirstRecursion(board, element => {
|
|
1259
|
+
board.applyTheme(element);
|
|
1260
|
+
});
|
|
1261
|
+
}
|
|
1262
|
+
const BoardTransforms = {
|
|
1263
|
+
updatePointerType,
|
|
1264
|
+
updateViewport,
|
|
1265
|
+
fitViewport,
|
|
1266
|
+
updateZoom,
|
|
1267
|
+
updateThemeColor,
|
|
1268
|
+
fitViewportWidth
|
|
1269
|
+
};
|
|
1270
|
+
|
|
1085
1271
|
const IS_FROM_SCROLLING = new WeakMap();
|
|
1086
1272
|
const IS_FROM_VIEWPORT_CHANGE = new WeakMap();
|
|
1087
1273
|
function getViewportContainerRect(board) {
|
|
@@ -1168,8 +1354,9 @@ function setSVGViewBox(board, viewBox) {
|
|
|
1168
1354
|
}
|
|
1169
1355
|
function updateViewportOffset(board) {
|
|
1170
1356
|
const origination = getViewportOrigination(board);
|
|
1171
|
-
if (!origination)
|
|
1357
|
+
if (!origination) {
|
|
1172
1358
|
return;
|
|
1359
|
+
}
|
|
1173
1360
|
const { zoom } = board.viewport;
|
|
1174
1361
|
const viewBox = getViewBox(board, zoom);
|
|
1175
1362
|
const scrollLeft = (origination[0] - viewBox[0]) * zoom;
|
|
@@ -1178,12 +1365,38 @@ function updateViewportOffset(board) {
|
|
|
1178
1365
|
}
|
|
1179
1366
|
function updateViewportContainerScroll(board, left, top, isFromViewportChange = true) {
|
|
1180
1367
|
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
1368
|
+
const previousScrollLeft = viewportContainer.scrollLeft;
|
|
1369
|
+
const previousScrollTop = viewportContainer.scrollTop;
|
|
1181
1370
|
if (viewportContainer.scrollLeft !== left || viewportContainer.scrollTop !== top) {
|
|
1182
1371
|
viewportContainer.scrollLeft = left;
|
|
1183
1372
|
viewportContainer.scrollTop = top;
|
|
1184
|
-
|
|
1373
|
+
const offsetWidth = viewportContainer.offsetWidth;
|
|
1374
|
+
const offsetHeight = viewportContainer.offsetHeight;
|
|
1375
|
+
if (previousScrollLeft === viewportContainer.scrollLeft && previousScrollTop === viewportContainer.scrollTop) {
|
|
1376
|
+
// The scroll event cannot be triggered, so the origination is modified directly based on the scroll distance.
|
|
1377
|
+
updateViewportByScrolling(board, previousScrollLeft, previousScrollTop);
|
|
1378
|
+
}
|
|
1379
|
+
else {
|
|
1380
|
+
const isValidLeftOrTop = left > 0 &&
|
|
1381
|
+
top > 0 &&
|
|
1382
|
+
left < viewportContainer.scrollWidth - offsetWidth &&
|
|
1383
|
+
top < viewportContainer.scrollHeight - offsetHeight;
|
|
1384
|
+
if (isFromViewportChange && isValidLeftOrTop) {
|
|
1385
|
+
setIsFromViewportChange(board, true);
|
|
1386
|
+
}
|
|
1387
|
+
}
|
|
1185
1388
|
}
|
|
1186
1389
|
}
|
|
1390
|
+
function updateViewportByScrolling(board, scrollLeft, scrollTop) {
|
|
1391
|
+
const zoom = board.viewport.zoom;
|
|
1392
|
+
const viewBox = getViewBox(board, zoom);
|
|
1393
|
+
const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]];
|
|
1394
|
+
if (Point.isEquals(origination, board.viewport.origination)) {
|
|
1395
|
+
return;
|
|
1396
|
+
}
|
|
1397
|
+
BoardTransforms.updateViewport(board, origination);
|
|
1398
|
+
setIsFromScrolling(board, true);
|
|
1399
|
+
}
|
|
1187
1400
|
function initializeViewportContainer(board) {
|
|
1188
1401
|
const { width, height } = getViewportContainerRect(board);
|
|
1189
1402
|
const viewportContainer = PlaitBoard.getViewportContainer(board);
|
|
@@ -2495,132 +2708,6 @@ function addSelectionWithTemporaryElements(board, elements) {
|
|
|
2495
2708
|
}
|
|
2496
2709
|
}
|
|
2497
2710
|
|
|
2498
|
-
function setViewport(board, viewport) {
|
|
2499
|
-
const operation = { type: 'set_viewport', properties: board.viewport, newProperties: viewport };
|
|
2500
|
-
board.apply(operation);
|
|
2501
|
-
}
|
|
2502
|
-
const ViewportTransforms$1 = {
|
|
2503
|
-
setViewport
|
|
2504
|
-
};
|
|
2505
|
-
|
|
2506
|
-
function setTheme(board, themeColorMode) {
|
|
2507
|
-
const operation = { type: 'set_theme', properties: board.theme, newProperties: themeColorMode };
|
|
2508
|
-
board.apply(operation);
|
|
2509
|
-
}
|
|
2510
|
-
const ViewportTransforms = {
|
|
2511
|
-
setTheme
|
|
2512
|
-
};
|
|
2513
|
-
|
|
2514
|
-
function updateViewport(board, origination, zoom) {
|
|
2515
|
-
zoom = zoom ?? board.viewport.zoom;
|
|
2516
|
-
setViewport(board, {
|
|
2517
|
-
...board.viewport,
|
|
2518
|
-
zoom,
|
|
2519
|
-
origination
|
|
2520
|
-
});
|
|
2521
|
-
clearViewportOrigination(board);
|
|
2522
|
-
}
|
|
2523
|
-
const updatePointerType = (board, pointer) => {
|
|
2524
|
-
board.pointer = pointer;
|
|
2525
|
-
const boardComponent = BOARD_TO_COMPONENT.get(board);
|
|
2526
|
-
boardComponent?.markForCheck();
|
|
2527
|
-
};
|
|
2528
|
-
function updateZoom(board, newZoom, isCenter = true) {
|
|
2529
|
-
newZoom = clampZoomLevel(newZoom);
|
|
2530
|
-
const mousePoint = PlaitBoard.getMovingPointInBoard(board);
|
|
2531
|
-
const nativeElement = PlaitBoard.getBoardContainer(board);
|
|
2532
|
-
const nativeElementRect = nativeElement.getBoundingClientRect();
|
|
2533
|
-
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
2534
|
-
let focusPoint = [boardContainerRect.width / 2, boardContainerRect.height / 2];
|
|
2535
|
-
if (!isCenter && mousePoint && distanceBetweenPointAndRectangle(mousePoint[0], mousePoint[1], nativeElementRect) === 0) {
|
|
2536
|
-
focusPoint = toPoint(mousePoint[0], mousePoint[1], nativeElement);
|
|
2537
|
-
}
|
|
2538
|
-
const zoom = board.viewport.zoom;
|
|
2539
|
-
const origination = getViewportOrigination(board);
|
|
2540
|
-
const centerX = origination[0] + focusPoint[0] / zoom;
|
|
2541
|
-
const centerY = origination[1] + focusPoint[1] / zoom;
|
|
2542
|
-
const newOrigination = [centerX - focusPoint[0] / newZoom, centerY - focusPoint[1] / newZoom];
|
|
2543
|
-
updateViewport(board, newOrigination, newZoom);
|
|
2544
|
-
}
|
|
2545
|
-
function fitViewport(board) {
|
|
2546
|
-
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
2547
|
-
const boardContainerRect = PlaitBoard.getBoardContainer(board).getBoundingClientRect();
|
|
2548
|
-
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
2549
|
-
const zoom = board.viewport.zoom;
|
|
2550
|
-
const autoFitPadding = 16;
|
|
2551
|
-
const viewportWidth = boardContainerRect.width - 2 * autoFitPadding;
|
|
2552
|
-
const viewportHeight = boardContainerRect.height - 2 * autoFitPadding;
|
|
2553
|
-
let newZoom = zoom;
|
|
2554
|
-
if (viewportWidth < elementHostBox.width || viewportHeight < elementHostBox.height) {
|
|
2555
|
-
newZoom = Math.min(viewportWidth / elementHostBox.width, viewportHeight / elementHostBox.height);
|
|
2556
|
-
}
|
|
2557
|
-
else {
|
|
2558
|
-
newZoom = 1;
|
|
2559
|
-
}
|
|
2560
|
-
const centerPoint = getViewBoxCenterPoint(board);
|
|
2561
|
-
const newOrigination = [
|
|
2562
|
-
centerPoint[0] - boardContainerRect.width / 2 / newZoom + scrollBarWidth / 2 / zoom,
|
|
2563
|
-
centerPoint[1] - boardContainerRect.height / 2 / newZoom + scrollBarWidth / 2 / zoom
|
|
2564
|
-
];
|
|
2565
|
-
updateViewport(board, newOrigination, newZoom);
|
|
2566
|
-
}
|
|
2567
|
-
function fitViewportWidth(board, options) {
|
|
2568
|
-
let scrollBarWidth = getRealScrollBarWidth(board);
|
|
2569
|
-
const boardContainer = PlaitBoard.getBoardContainer(board);
|
|
2570
|
-
const boardContainerRectangle = boardContainer.getBoundingClientRect();
|
|
2571
|
-
let finalWidth = 0;
|
|
2572
|
-
if (options.maxWidth) {
|
|
2573
|
-
finalWidth = options.maxWidth;
|
|
2574
|
-
}
|
|
2575
|
-
else {
|
|
2576
|
-
finalWidth = boardContainerRectangle.width;
|
|
2577
|
-
}
|
|
2578
|
-
const elementHostBox = getRectangleByElements(board, board.children, true);
|
|
2579
|
-
const contentWidth = finalWidth - 2 * options.autoFitPadding;
|
|
2580
|
-
let newZoom = 0;
|
|
2581
|
-
if (contentWidth < elementHostBox.width) {
|
|
2582
|
-
newZoom = Math.min(contentWidth / elementHostBox.width);
|
|
2583
|
-
}
|
|
2584
|
-
else {
|
|
2585
|
-
newZoom = 1;
|
|
2586
|
-
}
|
|
2587
|
-
let finalHeight = elementHostBox.height * newZoom + 2 * options.autoFitPadding;
|
|
2588
|
-
if (finalHeight > options.limitHeight) {
|
|
2589
|
-
const containerEl = boardContainer.closest(`.${options.containerClass}`);
|
|
2590
|
-
containerEl.style.height = `${finalHeight}px`;
|
|
2591
|
-
initializeViewportContainer(board);
|
|
2592
|
-
}
|
|
2593
|
-
else {
|
|
2594
|
-
finalHeight = options.limitHeight;
|
|
2595
|
-
}
|
|
2596
|
-
const centerX = elementHostBox.x + elementHostBox.width / 2;
|
|
2597
|
-
const centerY = elementHostBox.y + elementHostBox.height / 2;
|
|
2598
|
-
const newOrigination = [
|
|
2599
|
-
centerX - finalWidth / 2 / newZoom + scrollBarWidth / 2 / newZoom,
|
|
2600
|
-
centerY - finalHeight / 2 / newZoom + scrollBarWidth / 2 / newZoom
|
|
2601
|
-
];
|
|
2602
|
-
updateViewport(board, newOrigination, newZoom);
|
|
2603
|
-
}
|
|
2604
|
-
/**
|
|
2605
|
-
* apply theme to every element (remove element custom properties)
|
|
2606
|
-
* invoke applyThemeColor
|
|
2607
|
-
*/
|
|
2608
|
-
function updateThemeColor(board, mode) {
|
|
2609
|
-
mode = mode ?? board.theme.themeColorMode;
|
|
2610
|
-
setTheme(board, { themeColorMode: mode });
|
|
2611
|
-
depthFirstRecursion(board, element => {
|
|
2612
|
-
board.applyTheme(element);
|
|
2613
|
-
});
|
|
2614
|
-
}
|
|
2615
|
-
const BoardTransforms = {
|
|
2616
|
-
updatePointerType,
|
|
2617
|
-
updateViewport,
|
|
2618
|
-
fitViewport,
|
|
2619
|
-
updateZoom,
|
|
2620
|
-
updateThemeColor,
|
|
2621
|
-
fitViewportWidth
|
|
2622
|
-
};
|
|
2623
|
-
|
|
2624
2711
|
const removeElements = (board, elements) => {
|
|
2625
2712
|
elements
|
|
2626
2713
|
.map(element => {
|
|
@@ -3354,6 +3441,9 @@ function withMoving(board) {
|
|
|
3354
3441
|
const tolerance = 5;
|
|
3355
3442
|
if (Math.abs(offsetX) > tolerance || Math.abs(offsetY) > tolerance || getMovingElements(board).length > 0) {
|
|
3356
3443
|
throttleRAF(() => {
|
|
3444
|
+
if (!activeElementsRectangle) {
|
|
3445
|
+
return;
|
|
3446
|
+
}
|
|
3357
3447
|
const newRectangle = {
|
|
3358
3448
|
...activeElementsRectangle,
|
|
3359
3449
|
x: activeElementsRectangle.x + offsetX,
|
|
@@ -3987,14 +4077,7 @@ class PlaitBoardComponent {
|
|
|
3987
4077
|
}))
|
|
3988
4078
|
.subscribe((event) => {
|
|
3989
4079
|
const { scrollLeft, scrollTop } = event.target;
|
|
3990
|
-
|
|
3991
|
-
const viewBox = getViewBox(this.board, zoom);
|
|
3992
|
-
const origination = [scrollLeft / zoom + viewBox[0], scrollTop / zoom + viewBox[1]];
|
|
3993
|
-
if (Point.isEquals(origination, this.board.viewport.origination)) {
|
|
3994
|
-
return;
|
|
3995
|
-
}
|
|
3996
|
-
BoardTransforms.updateViewport(this.board, origination);
|
|
3997
|
-
setIsFromScrolling(this.board, true);
|
|
4080
|
+
updateViewportByScrolling(this.board, scrollLeft, scrollTop);
|
|
3998
4081
|
});
|
|
3999
4082
|
});
|
|
4000
4083
|
this.ngZone.runOutsideAngular(() => {
|
|
@@ -4283,5 +4366,5 @@ function createModModifierKeys() {
|
|
|
4283
4366
|
* Generated bundle index. Do not edit.
|
|
4284
4367
|
*/
|
|
4285
4368
|
|
|
4286
|
-
export { A, ACTIVE_STROKE_WIDTH, ALT, APOSTROPHE, ATTACHED_ELEMENT_CLASS_NAME, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_TOUCH_REF, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, CoreTransforms, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, Direction, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, HOST_CLASS_NAME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRESS_AND_MOVE_BUFFER, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElementComponent, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, ResizeCursorClass, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SELECTION_RECTANGLE_CLASS_NAME, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createMask, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createRect, createSVG, createSelectionRectangleG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downScale, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRectangle, drawRoundRectangle, fakeNodeWeakMap, findElements, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementById, getElementHostBBox, getHitElementByPoint, getHitElementsBySelection, getIsRecursionFunc, getMovingElements, getNearestPointBetweenPointAndSegment, getNearestPointBetweenPointAndSegments, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getTemporaryRef, getTextFromClipboard, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, handleTouchTarget, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isInPlaitBoard, isLineHitLine, isMainPointer, isNullOrUndefined, isPointInEllipse, isPointInPolygon, isPointInRoundRectangle, isPolylineHitRectangle, isPreventTouchMove, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, preventTouchMove, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setClipboardData, setClipboardDataByMedia, setClipboardDataByText, setIsFromScrolling, setIsFromViewportChange, setPathStrokeLinecap, setSVGViewBox, setSelectionMoving, setStrokeLinecap, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateForeignObjectWidth, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
4369
|
+
export { A, ACTIVE_STROKE_WIDTH, ALT, APOSTROPHE, ATTACHED_ELEMENT_CLASS_NAME, AT_SIGN, B, BACKSLASH, BACKSPACE, BOARD_TO_COMPONENT, BOARD_TO_ELEMENT_HOST, BOARD_TO_HOST, BOARD_TO_IS_SELECTION_MOVING, BOARD_TO_MOVING_ELEMENT, BOARD_TO_MOVING_POINT, BOARD_TO_MOVING_POINT_IN_BOARD, BOARD_TO_ON_CHANGE, BOARD_TO_ROUGH_SVG, BOARD_TO_SELECTED_ELEMENT, BOARD_TO_TEMPORARY_ELEMENTS, BOARD_TO_TOUCH_REF, BOARD_TO_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, CoreTransforms, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, Direction, E, EIGHT, ELEMENT_TO_COMPONENT, END, ENTER, EQUALS, ESCAPE, F, F1, F10, F11, F12, F2, F3, F4, F5, F6, F7, F8, F9, FF_EQUALS, FF_MINUS, FF_MUTE, FF_SEMICOLON, FF_VOLUME_DOWN, FF_VOLUME_UP, FIRST_MEDIA, FIVE, FLUSHING, FOUR, G, H, HOME, HOST_CLASS_NAME, I, INSERT, IS_APPLE, IS_BOARD_CACHE, IS_CHROME, IS_CHROME_LEGACY, IS_EDGE_LEGACY, IS_FIREFOX, IS_IOS, IS_MAC, IS_SAFARI, IS_TEXT_EDITABLE, J, K, L, LAST_MEDIA, LEFT_ARROW, M, MAC_ENTER, MAC_META, MAC_WK_CMD_LEFT, MAC_WK_CMD_RIGHT, MAX_RADIUS, MERGING, META, MUTE, N, NINE, NODE_TO_INDEX, NODE_TO_PARENT, NS, NUMPAD_DIVIDE, NUMPAD_EIGHT, NUMPAD_FIVE, NUMPAD_FOUR, NUMPAD_MINUS, NUMPAD_MULTIPLY, NUMPAD_NINE, NUMPAD_ONE, NUMPAD_PERIOD, NUMPAD_PLUS, NUMPAD_SEVEN, NUMPAD_SIX, NUMPAD_THREE, NUMPAD_TWO, NUMPAD_ZERO, NUM_CENTER, NUM_LOCK, O, ONE, OPEN_SQUARE_BRACKET, P, PAGE_DOWN, PAGE_UP, PATH_REFS, PAUSE, PERIOD, PLUS_SIGN, POINTER_BUTTON, PRESS_AND_MOVE_BUFFER, PRINT_SCREEN, Path, PlaitBoard, PlaitBoardComponent, PlaitChildrenElementComponent, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitNode, PlaitOperation, PlaitPluginElementComponent, PlaitPluginKey, PlaitPointerType, Point, Q, QUESTION_MARK, R, RIGHT_ARROW, RectangleClient, ResizeCursorClass, RetroThemeColor, S, SAVING, SCROLL_BAR_WIDTH, SCROLL_LOCK, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SELECTION_RECTANGLE_CLASS_NAME, SEMICOLON, SEVEN, SHIFT, SINGLE_QUOTE, SIX, SLASH, SPACE, Selection, SoftThemeColor, StarryThemeColor, T, TAB, THREE, TILDE, TWO, ThemeColorMode, ThemeColors, Transforms, U, UP_ARROW, V, VOLUME_DOWN, VOLUME_UP, Viewport, W, X, Y, Z, ZERO, addMovingElements, addSelectedElement, arrowPoints, cacheMovingElements, cacheSelectedElements, catmullRomFitting, clampZoomLevel, clearNodeWeakMap, clearSelectedElement, clearSelectionMoving, clearViewportOrigination, createFakeEvent, createForeignObject, createG, createKeyboardEvent, createMask, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createRect, createSVG, createSelectionRectangleG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downScale, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRectangle, drawRoundRectangle, fakeNodeWeakMap, findElements, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementById, getElementHostBBox, getHitElementByPoint, getHitElementsBySelection, getIsRecursionFunc, getMovingElements, getNearestPointBetweenPointAndSegment, getNearestPointBetweenPointAndSegments, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getTemporaryRef, getTextFromClipboard, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, handleTouchTarget, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isInPlaitBoard, isLineHitLine, isMainPointer, isNullOrUndefined, isPointInEllipse, isPointInPolygon, isPointInRoundRectangle, isPolylineHitRectangle, isPreventTouchMove, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, preventTouchMove, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setClipboardData, setClipboardDataByMedia, setClipboardDataByText, setIsFromScrolling, setIsFromViewportChange, setPathStrokeLinecap, setSVGViewBox, setSelectionMoving, setStrokeLinecap, shouldClear, shouldMerge, shouldSave, temporaryDisableSelection, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateForeignObjectWidth, updateViewportByScrolling, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
4287
4370
|
//# sourceMappingURL=plait-core.mjs.map
|