@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,211 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient, SELECTION_BORDER_COLOR } from '../../interfaces';
|
|
2
|
-
import { getRectangleByAngle } from '../angle';
|
|
3
|
-
import { createG } from '../dom';
|
|
4
|
-
import { findElements } from '../element';
|
|
5
|
-
export const SNAP_TOLERANCE = 2;
|
|
6
|
-
const SNAP_SPACING = 24;
|
|
7
|
-
export function getSnapRectangles(board, activeElements) {
|
|
8
|
-
const elements = findElements(board, {
|
|
9
|
-
match: element => board.isAlign(element) && !activeElements.some(item => item.id === element.id),
|
|
10
|
-
recursion: () => true,
|
|
11
|
-
isReverse: false
|
|
12
|
-
});
|
|
13
|
-
return elements.map(item => {
|
|
14
|
-
const rectangle = board.getRectangle(item);
|
|
15
|
-
return getRectangleByAngle(rectangle, item.angle || 0);
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
export function getBarPoint(point, isHorizontal) {
|
|
19
|
-
return isHorizontal
|
|
20
|
-
? [
|
|
21
|
-
[point[0], point[1] - 4],
|
|
22
|
-
[point[0], point[1] + 4]
|
|
23
|
-
]
|
|
24
|
-
: [
|
|
25
|
-
[point[0] - 4, point[1]],
|
|
26
|
-
[point[0] + 4, point[1]]
|
|
27
|
-
];
|
|
28
|
-
}
|
|
29
|
-
export function getMinPointDelta(pointRectangles, axis, isHorizontal) {
|
|
30
|
-
let delta = SNAP_TOLERANCE;
|
|
31
|
-
pointRectangles.forEach(item => {
|
|
32
|
-
const distance = getNearestDelta(axis, item, isHorizontal);
|
|
33
|
-
if (Math.abs(distance) < Math.abs(delta)) {
|
|
34
|
-
delta = distance;
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
return delta;
|
|
38
|
-
}
|
|
39
|
-
export const getNearestDelta = (axis, rectangle, isHorizontal) => {
|
|
40
|
-
const pointAxis = getTripleAxis(rectangle, isHorizontal);
|
|
41
|
-
const deltas = pointAxis.map(item => item - axis);
|
|
42
|
-
const absDeltas = deltas.map(item => Math.abs(item));
|
|
43
|
-
const index = absDeltas.indexOf(Math.min(...absDeltas));
|
|
44
|
-
return deltas[index];
|
|
45
|
-
};
|
|
46
|
-
export const getTripleAxis = (rectangle, isHorizontal) => {
|
|
47
|
-
const axis = isHorizontal ? 'x' : 'y';
|
|
48
|
-
const side = isHorizontal ? 'width' : 'height';
|
|
49
|
-
return [rectangle[axis], rectangle[axis] + rectangle[side] / 2, rectangle[axis] + rectangle[side]];
|
|
50
|
-
};
|
|
51
|
-
export function getNearestPointRectangle(snapRectangles, activeRectangle) {
|
|
52
|
-
let minDistance = Infinity;
|
|
53
|
-
let nearestRectangle = snapRectangles[0];
|
|
54
|
-
snapRectangles.forEach(item => {
|
|
55
|
-
const distance = Math.sqrt(Math.pow(activeRectangle.x - item.x, 2) + Math.pow(activeRectangle.y - item.y, 2));
|
|
56
|
-
if (distance < minDistance) {
|
|
57
|
-
minDistance = distance;
|
|
58
|
-
nearestRectangle = item;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
return nearestRectangle;
|
|
62
|
-
}
|
|
63
|
-
export const isSnapPoint = (axis, rectangle, isHorizontal) => {
|
|
64
|
-
const pointAxis = getTripleAxis(rectangle, isHorizontal);
|
|
65
|
-
return pointAxis.includes(axis);
|
|
66
|
-
};
|
|
67
|
-
export function drawPointSnapLines(board, activeRectangle, snapRectangles, drawHorizontal = true, drawVertical = true, snapMiddle = false) {
|
|
68
|
-
let pointLinePoints = [];
|
|
69
|
-
const pointAxisX = getTripleAxis(activeRectangle, true);
|
|
70
|
-
const pointAxisY = getTripleAxis(activeRectangle, false);
|
|
71
|
-
const pointLineRefs = [
|
|
72
|
-
{
|
|
73
|
-
axis: pointAxisX[0],
|
|
74
|
-
isHorizontal: true,
|
|
75
|
-
pointRectangles: []
|
|
76
|
-
},
|
|
77
|
-
{
|
|
78
|
-
axis: pointAxisX[1],
|
|
79
|
-
isHorizontal: true,
|
|
80
|
-
pointRectangles: []
|
|
81
|
-
},
|
|
82
|
-
{
|
|
83
|
-
axis: pointAxisX[2],
|
|
84
|
-
isHorizontal: true,
|
|
85
|
-
pointRectangles: []
|
|
86
|
-
},
|
|
87
|
-
{
|
|
88
|
-
axis: pointAxisY[0],
|
|
89
|
-
isHorizontal: false,
|
|
90
|
-
pointRectangles: []
|
|
91
|
-
},
|
|
92
|
-
{
|
|
93
|
-
axis: pointAxisY[1],
|
|
94
|
-
isHorizontal: false,
|
|
95
|
-
pointRectangles: []
|
|
96
|
-
},
|
|
97
|
-
{
|
|
98
|
-
axis: pointAxisY[2],
|
|
99
|
-
isHorizontal: false,
|
|
100
|
-
pointRectangles: []
|
|
101
|
-
}
|
|
102
|
-
];
|
|
103
|
-
for (let index = 0; index < snapRectangles.length; index++) {
|
|
104
|
-
const element = snapRectangles[index];
|
|
105
|
-
if (isSnapPoint(pointLineRefs[0].axis, element, pointLineRefs[0].isHorizontal)) {
|
|
106
|
-
pointLineRefs[0].pointRectangles.push(element);
|
|
107
|
-
}
|
|
108
|
-
if (isSnapPoint(pointLineRefs[1].axis, element, pointLineRefs[1].isHorizontal)) {
|
|
109
|
-
pointLineRefs[1].pointRectangles.push(element);
|
|
110
|
-
}
|
|
111
|
-
if (isSnapPoint(pointLineRefs[2].axis, element, pointLineRefs[2].isHorizontal)) {
|
|
112
|
-
pointLineRefs[2].pointRectangles.push(element);
|
|
113
|
-
}
|
|
114
|
-
if (isSnapPoint(pointLineRefs[3].axis, element, pointLineRefs[3].isHorizontal)) {
|
|
115
|
-
pointLineRefs[3].pointRectangles.push(element);
|
|
116
|
-
}
|
|
117
|
-
if (isSnapPoint(pointLineRefs[4].axis, element, pointLineRefs[4].isHorizontal)) {
|
|
118
|
-
pointLineRefs[4].pointRectangles.push(element);
|
|
119
|
-
}
|
|
120
|
-
if (isSnapPoint(pointLineRefs[5].axis, element, pointLineRefs[5].isHorizontal)) {
|
|
121
|
-
pointLineRefs[5].pointRectangles.push(element);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
const setResizePointSnapLine = (axis, pointRectangle, isHorizontal) => {
|
|
125
|
-
const boundingRectangle = RectangleClient.inflate(RectangleClient.getBoundingRectangle([activeRectangle, pointRectangle]), SNAP_SPACING);
|
|
126
|
-
if (isHorizontal) {
|
|
127
|
-
const pointStart = [axis, boundingRectangle.y];
|
|
128
|
-
const pointEnd = [axis, boundingRectangle.y + boundingRectangle.height];
|
|
129
|
-
pointLinePoints.push([pointStart, pointEnd]);
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
const pointStart = [boundingRectangle.x, axis];
|
|
133
|
-
const pointEnd = [boundingRectangle.x + boundingRectangle.width, axis];
|
|
134
|
-
pointLinePoints.push([pointStart, pointEnd]);
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
if (drawHorizontal && pointLineRefs[0].pointRectangles.length) {
|
|
138
|
-
const leftRectangle = pointLineRefs[0].pointRectangles.length === 1
|
|
139
|
-
? pointLineRefs[0].pointRectangles[0]
|
|
140
|
-
: getNearestPointRectangle(pointLineRefs[0].pointRectangles, activeRectangle);
|
|
141
|
-
setResizePointSnapLine(pointLineRefs[0].axis, leftRectangle, pointLineRefs[0].isHorizontal);
|
|
142
|
-
}
|
|
143
|
-
if (drawHorizontal && snapMiddle && pointLineRefs[1].pointRectangles.length) {
|
|
144
|
-
const middleRectangle = pointLineRefs[1].pointRectangles.length === 1
|
|
145
|
-
? pointLineRefs[1].pointRectangles[0]
|
|
146
|
-
: getNearestPointRectangle(pointLineRefs[1].pointRectangles, activeRectangle);
|
|
147
|
-
setResizePointSnapLine(pointLineRefs[1].axis, middleRectangle, pointLineRefs[1].isHorizontal);
|
|
148
|
-
}
|
|
149
|
-
if (drawHorizontal && pointLineRefs[2].pointRectangles.length) {
|
|
150
|
-
const rightRectangle = pointLineRefs[2].pointRectangles.length === 1
|
|
151
|
-
? pointLineRefs[2].pointRectangles[0]
|
|
152
|
-
: getNearestPointRectangle(pointLineRefs[2].pointRectangles, activeRectangle);
|
|
153
|
-
setResizePointSnapLine(pointLineRefs[2].axis, rightRectangle, pointLineRefs[2].isHorizontal);
|
|
154
|
-
}
|
|
155
|
-
if (drawVertical && pointLineRefs[3].pointRectangles.length) {
|
|
156
|
-
const topRectangle = pointLineRefs[3].pointRectangles.length === 1
|
|
157
|
-
? pointLineRefs[3].pointRectangles[0]
|
|
158
|
-
: getNearestPointRectangle(pointLineRefs[3].pointRectangles, activeRectangle);
|
|
159
|
-
setResizePointSnapLine(pointLineRefs[3].axis, topRectangle, pointLineRefs[3].isHorizontal);
|
|
160
|
-
}
|
|
161
|
-
if (drawVertical && snapMiddle && pointLineRefs[4].pointRectangles.length) {
|
|
162
|
-
const middleRectangle = pointLineRefs[4].pointRectangles.length === 1
|
|
163
|
-
? pointLineRefs[4].pointRectangles[0]
|
|
164
|
-
: getNearestPointRectangle(pointLineRefs[4].pointRectangles, activeRectangle);
|
|
165
|
-
setResizePointSnapLine(pointLineRefs[4].axis, middleRectangle, pointLineRefs[4].isHorizontal);
|
|
166
|
-
}
|
|
167
|
-
if (drawVertical && pointLineRefs[5].pointRectangles.length) {
|
|
168
|
-
const rightRectangle = pointLineRefs[5].pointRectangles.length === 1
|
|
169
|
-
? pointLineRefs[5].pointRectangles[0]
|
|
170
|
-
: getNearestPointRectangle(pointLineRefs[5].pointRectangles, activeRectangle);
|
|
171
|
-
setResizePointSnapLine(pointLineRefs[5].axis, rightRectangle, pointLineRefs[5].isHorizontal);
|
|
172
|
-
}
|
|
173
|
-
return drawDashedLines(board, pointLinePoints);
|
|
174
|
-
}
|
|
175
|
-
export function drawDashedLines(board, lines) {
|
|
176
|
-
const g = createG();
|
|
177
|
-
lines.forEach(points => {
|
|
178
|
-
if (!points.length)
|
|
179
|
-
return;
|
|
180
|
-
const line = PlaitBoard.getRoughSVG(board).line(points[0][0], points[0][1], points[1][0], points[1][1], {
|
|
181
|
-
stroke: SELECTION_BORDER_COLOR,
|
|
182
|
-
strokeWidth: 1,
|
|
183
|
-
strokeLineDash: [4, 4]
|
|
184
|
-
});
|
|
185
|
-
g.appendChild(line);
|
|
186
|
-
});
|
|
187
|
-
return g;
|
|
188
|
-
}
|
|
189
|
-
export function drawSolidLines(board, lines) {
|
|
190
|
-
const g = createG();
|
|
191
|
-
lines.forEach(points => {
|
|
192
|
-
if (!points.length)
|
|
193
|
-
return;
|
|
194
|
-
let isHorizontal = points[0][1] === points[1][1];
|
|
195
|
-
const line = PlaitBoard.getRoughSVG(board).line(points[0][0], points[0][1], points[1][0], points[1][1], {
|
|
196
|
-
stroke: SELECTION_BORDER_COLOR,
|
|
197
|
-
strokeWidth: 1
|
|
198
|
-
});
|
|
199
|
-
g.appendChild(line);
|
|
200
|
-
points.forEach(point => {
|
|
201
|
-
const barPoint = getBarPoint(point, isHorizontal);
|
|
202
|
-
const bar = PlaitBoard.getRoughSVG(board).line(barPoint[0][0], barPoint[0][1], barPoint[1][0], barPoint[1][1], {
|
|
203
|
-
stroke: SELECTION_BORDER_COLOR,
|
|
204
|
-
strokeWidth: 1
|
|
205
|
-
});
|
|
206
|
-
g.appendChild(bar);
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
return g;
|
|
210
|
-
}
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"snap.js","sourceRoot":"","sources":["../../../../../packages/core/src/utils/snap/snap.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient, SELECTION_BORDER_COLOR } from '../../interfaces';\nimport { getRectangleByAngle } from '../angle';\nimport { createG } from '../dom';\nimport { findElements } from '../element';\n\nexport interface SnapDelta {\n    deltaX: number;\n    deltaY: number;\n}\n\nexport interface SnapRef extends SnapDelta {\n    snapG: SVGGElement;\n}\n\nexport interface GapSnapRef {\n    before: { distance: number; index: number }[];\n    after: { distance: number; index: number }[];\n}\n\ntype PointSnapLineRef = {\n    axis: number;\n    isHorizontal: boolean;\n    pointRectangles: RectangleClient[];\n};\n\ntype TripleSnapAxis = [number, number, number];\n\nexport const SNAP_TOLERANCE = 2;\n\nconst SNAP_SPACING = 24;\n\nexport function getSnapRectangles(board: PlaitBoard, activeElements: PlaitElement[]) {\n    const elements = findElements(board, {\n        match: element => board.isAlign(element) && !activeElements.some(item => item.id === element.id),\n        recursion: () => true,\n        isReverse: false\n    });\n    return elements.map(item => {\n        const rectangle = board.getRectangle(item)!;\n        return getRectangleByAngle(rectangle, item.angle || 0);\n    });\n}\n\nexport function getBarPoint(point: Point, isHorizontal: boolean) {\n    return isHorizontal\n        ? [\n              [point[0], point[1] - 4],\n              [point[0], point[1] + 4]\n          ]\n        : [\n              [point[0] - 4, point[1]],\n              [point[0] + 4, point[1]]\n          ];\n}\n\nexport function getMinPointDelta(pointRectangles: RectangleClient[], axis: number, isHorizontal: boolean) {\n    let delta = SNAP_TOLERANCE;\n    pointRectangles.forEach(item => {\n        const distance = getNearestDelta(axis, item, isHorizontal);\n        if (Math.abs(distance) < Math.abs(delta)) {\n            delta = distance;\n        }\n    });\n    return delta;\n}\n\nexport const getNearestDelta = (axis: number, rectangle: RectangleClient, isHorizontal: boolean) => {\n    const pointAxis = getTripleAxis(rectangle, isHorizontal);\n    const deltas = pointAxis.map(item => item - axis);\n    const absDeltas = deltas.map(item => Math.abs(item));\n    const index = absDeltas.indexOf(Math.min(...absDeltas));\n    return deltas[index];\n};\n\nexport const getTripleAxis = (rectangle: RectangleClient, isHorizontal: boolean): TripleSnapAxis => {\n    const axis = isHorizontal ? 'x' : 'y';\n    const side = isHorizontal ? 'width' : 'height';\n    return [rectangle[axis], rectangle[axis] + rectangle[side] / 2, rectangle[axis] + rectangle[side]];\n};\n\nexport function getNearestPointRectangle(snapRectangles: RectangleClient[], activeRectangle: RectangleClient) {\n    let minDistance = Infinity;\n    let nearestRectangle = snapRectangles[0];\n\n    snapRectangles.forEach(item => {\n        const distance = Math.sqrt(Math.pow(activeRectangle.x - item.x, 2) + Math.pow(activeRectangle.y - item.y, 2));\n        if (distance < minDistance) {\n            minDistance = distance;\n            nearestRectangle = item;\n        }\n    });\n    return nearestRectangle;\n}\n\nexport const isSnapPoint = (axis: number, rectangle: RectangleClient, isHorizontal: boolean) => {\n    const pointAxis = getTripleAxis(rectangle, isHorizontal);\n    return pointAxis.includes(axis);\n};\n\nexport function drawPointSnapLines(\n    board: PlaitBoard,\n    activeRectangle: RectangleClient,\n    snapRectangles: RectangleClient[],\n    drawHorizontal = true,\n    drawVertical = true,\n    snapMiddle = false\n) {\n    let pointLinePoints: [Point, Point][] = [];\n    const pointAxisX = getTripleAxis(activeRectangle, true);\n    const pointAxisY = getTripleAxis(activeRectangle, false);\n    const pointLineRefs: PointSnapLineRef[] = [\n        {\n            axis: pointAxisX[0],\n            isHorizontal: true,\n            pointRectangles: []\n        },\n        {\n            axis: pointAxisX[1],\n            isHorizontal: true,\n            pointRectangles: []\n        },\n        {\n            axis: pointAxisX[2],\n            isHorizontal: true,\n            pointRectangles: []\n        },\n        {\n            axis: pointAxisY[0],\n            isHorizontal: false,\n            pointRectangles: []\n        },\n        {\n            axis: pointAxisY[1],\n            isHorizontal: false,\n            pointRectangles: []\n        },\n        {\n            axis: pointAxisY[2],\n            isHorizontal: false,\n            pointRectangles: []\n        }\n    ];\n    for (let index = 0; index < snapRectangles.length; index++) {\n        const element = snapRectangles[index];\n        if (isSnapPoint(pointLineRefs[0].axis, element, pointLineRefs[0].isHorizontal)) {\n            pointLineRefs[0].pointRectangles.push(element);\n        }\n        if (isSnapPoint(pointLineRefs[1].axis, element, pointLineRefs[1].isHorizontal)) {\n            pointLineRefs[1].pointRectangles.push(element);\n        }\n        if (isSnapPoint(pointLineRefs[2].axis, element, pointLineRefs[2].isHorizontal)) {\n            pointLineRefs[2].pointRectangles.push(element);\n        }\n        if (isSnapPoint(pointLineRefs[3].axis, element, pointLineRefs[3].isHorizontal)) {\n            pointLineRefs[3].pointRectangles.push(element);\n        }\n        if (isSnapPoint(pointLineRefs[4].axis, element, pointLineRefs[4].isHorizontal)) {\n            pointLineRefs[4].pointRectangles.push(element);\n        }\n        if (isSnapPoint(pointLineRefs[5].axis, element, pointLineRefs[5].isHorizontal)) {\n            pointLineRefs[5].pointRectangles.push(element);\n        }\n    }\n\n    const setResizePointSnapLine = (axis: number, pointRectangle: RectangleClient, isHorizontal: boolean) => {\n        const boundingRectangle = RectangleClient.inflate(\n            RectangleClient.getBoundingRectangle([activeRectangle, pointRectangle]),\n            SNAP_SPACING\n        );\n        if (isHorizontal) {\n            const pointStart = [axis, boundingRectangle.y] as Point;\n            const pointEnd = [axis, boundingRectangle.y + boundingRectangle.height] as Point;\n            pointLinePoints.push([pointStart, pointEnd]);\n        } else {\n            const pointStart = [boundingRectangle.x, axis] as Point;\n            const pointEnd = [boundingRectangle.x + boundingRectangle.width, axis] as Point;\n            pointLinePoints.push([pointStart, pointEnd]);\n        }\n    };\n    if (drawHorizontal && pointLineRefs[0].pointRectangles.length) {\n        const leftRectangle =\n            pointLineRefs[0].pointRectangles.length === 1\n                ? pointLineRefs[0].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[0].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[0].axis, leftRectangle, pointLineRefs[0].isHorizontal);\n    }\n    if (drawHorizontal && snapMiddle && pointLineRefs[1].pointRectangles.length) {\n        const middleRectangle =\n            pointLineRefs[1].pointRectangles.length === 1\n                ? pointLineRefs[1].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[1].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[1].axis, middleRectangle, pointLineRefs[1].isHorizontal);\n    }\n\n    if (drawHorizontal && pointLineRefs[2].pointRectangles.length) {\n        const rightRectangle =\n            pointLineRefs[2].pointRectangles.length === 1\n                ? pointLineRefs[2].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[2].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[2].axis, rightRectangle, pointLineRefs[2].isHorizontal);\n    }\n\n    if (drawVertical && pointLineRefs[3].pointRectangles.length) {\n        const topRectangle =\n            pointLineRefs[3].pointRectangles.length === 1\n                ? pointLineRefs[3].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[3].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[3].axis, topRectangle, pointLineRefs[3].isHorizontal);\n    }\n\n    if (drawVertical && snapMiddle && pointLineRefs[4].pointRectangles.length) {\n        const middleRectangle =\n            pointLineRefs[4].pointRectangles.length === 1\n                ? pointLineRefs[4].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[4].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[4].axis, middleRectangle, pointLineRefs[4].isHorizontal);\n    }\n\n    if (drawVertical && pointLineRefs[5].pointRectangles.length) {\n        const rightRectangle =\n            pointLineRefs[5].pointRectangles.length === 1\n                ? pointLineRefs[5].pointRectangles[0]\n                : getNearestPointRectangle(pointLineRefs[5].pointRectangles, activeRectangle);\n        setResizePointSnapLine(pointLineRefs[5].axis, rightRectangle, pointLineRefs[5].isHorizontal);\n    }\n\n    return drawDashedLines(board, pointLinePoints);\n}\n\nexport function drawDashedLines(board: PlaitBoard, lines: [Point, Point][]) {\n    const g = createG();\n    lines.forEach(points => {\n        if (!points.length) return;\n        const line = PlaitBoard.getRoughSVG(board).line(points[0][0], points[0][1], points[1][0], points[1][1], {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: 1,\n            strokeLineDash: [4, 4]\n        });\n        g.appendChild(line);\n    });\n    return g;\n}\n\nexport function drawSolidLines(board: PlaitBoard, lines: Point[][]) {\n    const g = createG();\n    lines.forEach(points => {\n        if (!points.length) return;\n        let isHorizontal = points[0][1] === points[1][1];\n        const line = PlaitBoard.getRoughSVG(board).line(points[0][0], points[0][1], points[1][0], points[1][1], {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: 1\n        });\n        g.appendChild(line);\n\n        points.forEach(point => {\n            const barPoint = getBarPoint(point, isHorizontal);\n            const bar = PlaitBoard.getRoughSVG(board).line(barPoint[0][0], barPoint[0][1], barPoint[1][0], barPoint[1][1], {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: 1\n            });\n            g.appendChild(bar);\n        });\n    });\n    return g;\n}\n"]}
|
|
@@ -1,204 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, PlaitElement } from '../interfaces';
|
|
2
|
-
import { findElements, getRectangleByElements } from './element';
|
|
3
|
-
const FOREIGN_OBJECT_EXPRESSION = `foreignObject[class^='foreign-object']`;
|
|
4
|
-
/**
|
|
5
|
-
* Is element node
|
|
6
|
-
* @param node
|
|
7
|
-
* @returns
|
|
8
|
-
*/
|
|
9
|
-
function isElementNode(node) {
|
|
10
|
-
return node.nodeType === Node.ELEMENT_NODE;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* load image resources
|
|
14
|
-
* @param url image url
|
|
15
|
-
* @returns image element
|
|
16
|
-
*/
|
|
17
|
-
function loadImage(src) {
|
|
18
|
-
return new Promise((resolve, reject) => {
|
|
19
|
-
const img = new Image();
|
|
20
|
-
img.crossOrigin = 'Anonymous';
|
|
21
|
-
img.onload = () => resolve(img);
|
|
22
|
-
img.onerror = () => reject(new Error('Failed to load image'));
|
|
23
|
-
img.src = src;
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* create and return canvas and context
|
|
28
|
-
* @param width canvas width
|
|
29
|
-
* @param height canvas height
|
|
30
|
-
* @param fillStyle fill style
|
|
31
|
-
* @returns canvas and context
|
|
32
|
-
*/
|
|
33
|
-
function createCanvas(width, height, fillStyle = 'transparent') {
|
|
34
|
-
const canvas = document.createElement('canvas');
|
|
35
|
-
const ctx = canvas.getContext('2d');
|
|
36
|
-
canvas.width = width;
|
|
37
|
-
canvas.height = height;
|
|
38
|
-
canvas.style.width = `${width}px`;
|
|
39
|
-
canvas.style.height = `${height}px`;
|
|
40
|
-
ctx.strokeStyle = '#ffffff';
|
|
41
|
-
ctx.fillStyle = fillStyle;
|
|
42
|
-
ctx.fillRect(0, 0, width, height);
|
|
43
|
-
return {
|
|
44
|
-
canvas,
|
|
45
|
-
ctx
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* convert image to base64
|
|
50
|
-
* @param url image url
|
|
51
|
-
* @returns image base64
|
|
52
|
-
*/
|
|
53
|
-
async function convertImageToBase64(url) {
|
|
54
|
-
const response = await fetch(url);
|
|
55
|
-
const blob = await response.blob();
|
|
56
|
-
return new Promise((resolve, reject) => {
|
|
57
|
-
const reader = new FileReader();
|
|
58
|
-
reader.onloadend = () => resolve(reader.result);
|
|
59
|
-
reader.onerror = reject;
|
|
60
|
-
reader.readAsDataURL(blob);
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* clone node style
|
|
65
|
-
* @param nativeNode source node
|
|
66
|
-
* @param clonedNode clone node
|
|
67
|
-
*/
|
|
68
|
-
function cloneCSSStyle(nativeNode, clonedNode) {
|
|
69
|
-
const targetStyle = clonedNode?.style;
|
|
70
|
-
if (!targetStyle) {
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
const sourceStyle = window.getComputedStyle(nativeNode);
|
|
74
|
-
if (sourceStyle.cssText) {
|
|
75
|
-
targetStyle.cssText = sourceStyle.cssText;
|
|
76
|
-
targetStyle.transformOrigin = sourceStyle.transformOrigin;
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
Array.from(sourceStyle).forEach(name => {
|
|
80
|
-
let value = sourceStyle.getPropertyValue(name);
|
|
81
|
-
targetStyle.setProperty(name, value, sourceStyle.getPropertyPriority(name));
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
/**
|
|
86
|
-
* batch clone target styles
|
|
87
|
-
* @param sourceNode
|
|
88
|
-
* @param cloneNode
|
|
89
|
-
* @param inlineStyleClassNames
|
|
90
|
-
*/
|
|
91
|
-
function batchCloneCSSStyle(sourceNode, cloneNode, inlineStyleClassNames) {
|
|
92
|
-
if (inlineStyleClassNames) {
|
|
93
|
-
const classNames = inlineStyleClassNames + `, ${FOREIGN_OBJECT_EXPRESSION}`;
|
|
94
|
-
const sourceNodes = Array.from(sourceNode.querySelectorAll(classNames));
|
|
95
|
-
const cloneNodes = Array.from(cloneNode.querySelectorAll(classNames));
|
|
96
|
-
sourceNodes.forEach((node, index) => {
|
|
97
|
-
const childElements = Array.from(node.querySelectorAll('*')).filter(isElementNode);
|
|
98
|
-
const cloneChildElements = Array.from(cloneNodes[index].querySelectorAll('*')).filter(isElementNode);
|
|
99
|
-
sourceNodes.push(...childElements);
|
|
100
|
-
cloneNodes.push(...cloneChildElements);
|
|
101
|
-
});
|
|
102
|
-
// processing styles
|
|
103
|
-
sourceNodes.map((node, index) => {
|
|
104
|
-
cloneCSSStyle(node, cloneNodes[index]);
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
/**
|
|
109
|
-
* convert images in target nodes in batches
|
|
110
|
-
* @param sourceNode
|
|
111
|
-
* @param cloneNode
|
|
112
|
-
*/
|
|
113
|
-
async function batchConvertImage(sourceNode, cloneNode) {
|
|
114
|
-
const sourceImageNodes = Array.from(sourceNode.querySelectorAll(`${FOREIGN_OBJECT_EXPRESSION}`));
|
|
115
|
-
const cloneImageNodes = Array.from(cloneNode.querySelectorAll(`${FOREIGN_OBJECT_EXPRESSION}`));
|
|
116
|
-
await Promise.all(sourceImageNodes.map((_, index) => {
|
|
117
|
-
return new Promise(resolve => {
|
|
118
|
-
const cloneImageNode = cloneImageNodes[index];
|
|
119
|
-
// processing image
|
|
120
|
-
const image = cloneImageNode.querySelector('img');
|
|
121
|
-
const url = image?.getAttribute('src');
|
|
122
|
-
if (!url) {
|
|
123
|
-
return resolve(true);
|
|
124
|
-
}
|
|
125
|
-
convertImageToBase64(url).then(base64Image => {
|
|
126
|
-
image?.setAttribute('src', base64Image);
|
|
127
|
-
resolve(true);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
}));
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* clone svg element
|
|
134
|
-
* @param board board
|
|
135
|
-
* @param options parameter configuration
|
|
136
|
-
* @returns clone svg element
|
|
137
|
-
*/
|
|
138
|
-
async function cloneSvg(board, elements, rectangle, options) {
|
|
139
|
-
const { width, height, x, y } = rectangle;
|
|
140
|
-
const { padding = 4, inlineStyleClassNames } = options;
|
|
141
|
-
const sourceSvg = PlaitBoard.getHost(board);
|
|
142
|
-
const selectedGElements = elements.map(value => PlaitElement.getElementG(value));
|
|
143
|
-
const cloneSvgElement = sourceSvg.cloneNode();
|
|
144
|
-
const newHostElement = PlaitBoard.getElementHost(board).cloneNode();
|
|
145
|
-
cloneSvgElement.style.width = `${width}px`;
|
|
146
|
-
cloneSvgElement.style.height = `${height}px`;
|
|
147
|
-
cloneSvgElement.style.backgroundColor = '';
|
|
148
|
-
cloneSvgElement.setAttribute('width', `${width}`);
|
|
149
|
-
cloneSvgElement.setAttribute('height', `${height}`);
|
|
150
|
-
cloneSvgElement.setAttribute('viewBox', [x - padding, y - padding, width + 2 * padding, height + 2 * padding].join(','));
|
|
151
|
-
const promiseArray = new Array(selectedGElements.length);
|
|
152
|
-
await Promise.all(selectedGElements.map(async (child, i) => {
|
|
153
|
-
const cloneChild = child.cloneNode(true);
|
|
154
|
-
batchCloneCSSStyle(child, cloneChild, inlineStyleClassNames);
|
|
155
|
-
await batchConvertImage(child, cloneChild);
|
|
156
|
-
promiseArray[i] = cloneChild;
|
|
157
|
-
}));
|
|
158
|
-
newHostElement.append(...promiseArray);
|
|
159
|
-
cloneSvgElement.appendChild(newHostElement);
|
|
160
|
-
return cloneSvgElement;
|
|
161
|
-
}
|
|
162
|
-
/**
|
|
163
|
-
* current board transfer pictures
|
|
164
|
-
* @param board board
|
|
165
|
-
* @param options parameter configuration
|
|
166
|
-
* @returns images in the specified format base64
|
|
167
|
-
*/
|
|
168
|
-
export async function toImage(board, options) {
|
|
169
|
-
if (!board) {
|
|
170
|
-
return undefined;
|
|
171
|
-
}
|
|
172
|
-
const elements = options.elements || findElements(board, { match: () => true, recursion: () => true, isReverse: false });
|
|
173
|
-
const targetRectangle = getRectangleByElements(board, elements, false);
|
|
174
|
-
const { ratio = 2, fillStyle = 'transparent' } = options;
|
|
175
|
-
const { width, height } = targetRectangle;
|
|
176
|
-
const ratioWidth = width * ratio;
|
|
177
|
-
const ratioHeight = height * ratio;
|
|
178
|
-
const cloneSvgElement = await cloneSvg(board, elements, targetRectangle, options);
|
|
179
|
-
const { canvas, ctx } = createCanvas(ratioWidth, ratioHeight, fillStyle);
|
|
180
|
-
const svgStr = new XMLSerializer().serializeToString(cloneSvgElement);
|
|
181
|
-
const imgSrc = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgStr)}`;
|
|
182
|
-
try {
|
|
183
|
-
const img = await loadImage(imgSrc);
|
|
184
|
-
ctx.drawImage(img, 0, 0, ratioWidth, ratioHeight);
|
|
185
|
-
return canvas.toDataURL('image/png');
|
|
186
|
-
}
|
|
187
|
-
catch (error) {
|
|
188
|
-
console.error('Error converting SVG to image:', error);
|
|
189
|
-
return undefined;
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
/**
|
|
193
|
-
* download the file with the specified name
|
|
194
|
-
* @param url download url
|
|
195
|
-
* @param name file name
|
|
196
|
-
*/
|
|
197
|
-
export function downloadImage(url, name) {
|
|
198
|
-
const a = document.createElement('a');
|
|
199
|
-
a.href = url;
|
|
200
|
-
a.download = name;
|
|
201
|
-
a.click();
|
|
202
|
-
a.remove();
|
|
203
|
-
}
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"to-image.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/to-image.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, RectangleClient } from '../interfaces';\nimport { findElements, getRectangleByElements } from './element';\n\nconst FOREIGN_OBJECT_EXPRESSION = `foreignObject[class^='foreign-object']`;\n\nexport interface ToImageOptions {\n    elements?: PlaitElement[];\n    name?: string;\n    ratio?: number;\n    padding?: number;\n    fillStyle?: string;\n    // List of class names. The list must be in the form class1,class2,...\n    inlineStyleClassNames?: string;\n}\n\n/**\n * Is element node\n * @param node\n * @returns\n */\nfunction isElementNode(node: Node): node is HTMLElement {\n    return node.nodeType === Node.ELEMENT_NODE;\n}\n\n/**\n * load image resources\n * @param url image url\n * @returns image element\n */\nfunction loadImage(src: string): Promise<HTMLImageElement> {\n    return new Promise((resolve, reject) => {\n        const img = new Image();\n        img.crossOrigin = 'Anonymous';\n        img.onload = () => resolve(img);\n        img.onerror = () => reject(new Error('Failed to load image'));\n        img.src = src;\n    });\n}\n\n/**\n * create and return canvas and context\n * @param width canvas width\n * @param height canvas height\n * @param fillStyle fill style\n * @returns canvas and context\n */\nfunction createCanvas(width: number, height: number, fillStyle = 'transparent') {\n    const canvas = document.createElement('canvas');\n    const ctx = canvas.getContext('2d')!;\n\n    canvas.width = width;\n    canvas.height = height;\n    canvas.style.width = `${width}px`;\n    canvas.style.height = `${height}px`;\n    ctx.strokeStyle = '#ffffff';\n    ctx.fillStyle = fillStyle;\n    ctx.fillRect(0, 0, width, height);\n\n    return {\n        canvas,\n        ctx\n    };\n}\n\n/**\n * convert image to base64\n * @param url image url\n * @returns image base64\n */\nasync function convertImageToBase64(url: string): Promise<string> {\n    const response = await fetch(url);\n    const blob = await response.blob();\n    return new Promise((resolve, reject) => {\n        const reader = new FileReader();\n        reader.onloadend = () => resolve(reader.result as string);\n        reader.onerror = reject;\n        reader.readAsDataURL(blob);\n    });\n}\n\n/**\n * clone node style\n * @param nativeNode source node\n * @param clonedNode clone node\n */\nfunction cloneCSSStyle<T extends HTMLElement>(nativeNode: T, clonedNode: T) {\n    const targetStyle = clonedNode?.style;\n    if (!targetStyle) {\n        return;\n    }\n\n    const sourceStyle = window.getComputedStyle(nativeNode);\n    if (sourceStyle.cssText) {\n        targetStyle.cssText = sourceStyle.cssText;\n        targetStyle.transformOrigin = sourceStyle.transformOrigin;\n    } else {\n        Array.from(sourceStyle).forEach(name => {\n            let value = sourceStyle.getPropertyValue(name);\n            targetStyle.setProperty(name, value, sourceStyle.getPropertyPriority(name));\n        });\n    }\n}\n\n/**\n * batch clone target styles\n * @param sourceNode\n * @param cloneNode\n * @param inlineStyleClassNames\n */\nfunction batchCloneCSSStyle(sourceNode: SVGGElement, cloneNode: SVGGElement, inlineStyleClassNames: string) {\n    if (inlineStyleClassNames) {\n        const classNames = inlineStyleClassNames + `, ${FOREIGN_OBJECT_EXPRESSION}`;\n        const sourceNodes = Array.from(sourceNode.querySelectorAll(classNames));\n        const cloneNodes = Array.from(cloneNode.querySelectorAll(classNames));\n\n        sourceNodes.forEach((node, index) => {\n            const childElements = Array.from(node.querySelectorAll('*')).filter(isElementNode) as HTMLElement[];\n            const cloneChildElements = Array.from(cloneNodes[index].querySelectorAll('*')).filter(isElementNode) as HTMLElement[];\n            sourceNodes.push(...childElements);\n            cloneNodes.push(...cloneChildElements);\n        });\n\n        // processing styles\n        sourceNodes.map((node, index) => {\n            cloneCSSStyle(node as HTMLElement, cloneNodes[index] as HTMLElement);\n        });\n    }\n}\n\n/**\n * convert images in target nodes in batches\n * @param sourceNode\n * @param cloneNode\n */\nasync function batchConvertImage(sourceNode: SVGGElement, cloneNode: SVGGElement) {\n    const sourceImageNodes = Array.from(sourceNode.querySelectorAll(`${FOREIGN_OBJECT_EXPRESSION}`));\n    const cloneImageNodes = Array.from(cloneNode.querySelectorAll(`${FOREIGN_OBJECT_EXPRESSION}`));\n    await Promise.all(\n        sourceImageNodes.map((_, index) => {\n            return new Promise(resolve => {\n                const cloneImageNode = cloneImageNodes[index];\n                // processing image\n                const image = (cloneImageNode as HTMLElement).querySelector('img');\n                const url = image?.getAttribute('src');\n                if (!url) {\n                    return resolve(true);\n                }\n                convertImageToBase64(url).then(base64Image => {\n                    image?.setAttribute('src', base64Image);\n                    resolve(true);\n                });\n            });\n        })\n    );\n}\n\n/**\n * clone svg element\n * @param board board\n * @param options parameter configuration\n * @returns clone svg element\n */\nasync function cloneSvg(board: PlaitBoard, elements: PlaitElement[], rectangle: RectangleClient, options: ToImageOptions) {\n    const { width, height, x, y } = rectangle;\n    const { padding = 4, inlineStyleClassNames } = options;\n    const sourceSvg = PlaitBoard.getHost(board);\n    const selectedGElements = elements.map(value => PlaitElement.getElementG(value));\n    const cloneSvgElement = sourceSvg.cloneNode() as SVGElement;\n    const newHostElement = PlaitBoard.getElementHost(board).cloneNode() as SVGGElement;\n\n    cloneSvgElement.style.width = `${width}px`;\n    cloneSvgElement.style.height = `${height}px`;\n    cloneSvgElement.style.backgroundColor = '';\n    cloneSvgElement.setAttribute('width', `${width}`);\n    cloneSvgElement.setAttribute('height', `${height}`);\n    cloneSvgElement.setAttribute('viewBox', [x - padding, y - padding, width + 2 * padding, height + 2 * padding].join(','));\n\n    const promiseArray = new Array(selectedGElements.length);\n    await Promise.all(\n        selectedGElements.map(async (child, i) => {\n            const cloneChild = child.cloneNode(true) as SVGGElement;\n            batchCloneCSSStyle(child, cloneChild, inlineStyleClassNames as string);\n            await batchConvertImage(child, cloneChild);\n            promiseArray[i] = cloneChild;\n        })\n    );\n    newHostElement.append(...promiseArray);\n    cloneSvgElement.appendChild(newHostElement);\n    return cloneSvgElement;\n}\n\n/**\n * current board transfer pictures\n * @param board board\n * @param options parameter configuration\n * @returns images in the specified format base64\n */\nexport async function toImage(board: PlaitBoard, options: ToImageOptions) {\n    if (!board) {\n        return undefined;\n    }\n    const elements = options.elements || findElements(board, { match: () => true, recursion: () => true, isReverse: false });\n    const targetRectangle = getRectangleByElements(board, elements, false);\n    const { ratio = 2, fillStyle = 'transparent' } = options;\n    const { width, height } = targetRectangle;\n    const ratioWidth = width * ratio;\n    const ratioHeight = height * ratio;\n\n    const cloneSvgElement = await cloneSvg(board, elements, targetRectangle, options);\n    const { canvas, ctx } = createCanvas(ratioWidth, ratioHeight, fillStyle);\n\n    const svgStr = new XMLSerializer().serializeToString(cloneSvgElement);\n    const imgSrc = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgStr)}`;\n\n    try {\n        const img = await loadImage(imgSrc);\n        ctx.drawImage(img, 0, 0, ratioWidth, ratioHeight);\n        return canvas.toDataURL('image/png');\n    } catch (error) {\n        console.error('Error converting SVG to image:', error);\n        return undefined;\n    }\n}\n\n/**\n * download the file with the specified name\n * @param url download url\n * @param name file name\n */\nexport function downloadImage(url: string, name: string) {\n    const a = document.createElement('a');\n    a.href = url;\n    a.download = name;\n    a.click();\n    a.remove();\n}\n"]}
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import { RectangleClient } from '../interfaces';
|
|
2
|
-
import { PlaitBoard } from '../interfaces/board';
|
|
3
|
-
export const getViewBox = (board) => {
|
|
4
|
-
return PlaitBoard.getHost(board).viewBox.baseVal;
|
|
5
|
-
};
|
|
6
|
-
/**
|
|
7
|
-
* Get the screen point starting from the upper left corner of the svg element (based on the svg screen coordinate system)
|
|
8
|
-
*/
|
|
9
|
-
export function toHostPoint(board, x, y) {
|
|
10
|
-
const host = PlaitBoard.getHost(board);
|
|
11
|
-
const rect = host.getBoundingClientRect();
|
|
12
|
-
return [x - rect.x, y - rect.y];
|
|
13
|
-
}
|
|
14
|
-
export function toActiveRectangleFromViewBoxRectangle(board, rectangle) {
|
|
15
|
-
const leftTop = [rectangle.x, rectangle.y];
|
|
16
|
-
const rightBottom = [rectangle.x + rectangle.width, rectangle.y + rectangle.height];
|
|
17
|
-
const leftTopOfActive = toActivePointFromViewBoxPoint(board, leftTop);
|
|
18
|
-
const rightBottomOfActive = toActivePointFromViewBoxPoint(board, rightBottom);
|
|
19
|
-
return RectangleClient.getRectangleByPoints([leftTopOfActive, rightBottomOfActive]);
|
|
20
|
-
}
|
|
21
|
-
export function toActivePointFromViewBoxPoint(board, point) {
|
|
22
|
-
const screenPoint = toScreenPointFromHostPoint(board, toHostPointFromViewBoxPoint(board, point));
|
|
23
|
-
return toActivePoint(board, screenPoint[0], screenPoint[1]);
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Get the screen point starting from the upper left corner of the svg element (based on the svg screen coordinate system)
|
|
27
|
-
*/
|
|
28
|
-
export function toActivePoint(board, x, y) {
|
|
29
|
-
const boardContainer = PlaitBoard.getBoardContainer(board);
|
|
30
|
-
const rect = boardContainer.getBoundingClientRect();
|
|
31
|
-
return [x - rect.x, y - rect.y];
|
|
32
|
-
}
|
|
33
|
-
export function toScreenPointFromActivePoint(board, activePoint) {
|
|
34
|
-
const boardContainer = PlaitBoard.getBoardContainer(board);
|
|
35
|
-
const rect = boardContainer.getBoundingClientRect();
|
|
36
|
-
return [rect.x + activePoint[0], rect.y + activePoint[1]];
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Get the point in the coordinate system of the svg viewBox
|
|
40
|
-
*/
|
|
41
|
-
export function toViewBoxPoint(board, hostPoint) {
|
|
42
|
-
const viewBox = getViewBox(board);
|
|
43
|
-
const { zoom } = board.viewport;
|
|
44
|
-
const x = hostPoint[0] / zoom + viewBox.x;
|
|
45
|
-
const y = hostPoint[1] / zoom + viewBox.y;
|
|
46
|
-
const newPoint = [x, y];
|
|
47
|
-
return newPoint;
|
|
48
|
-
}
|
|
49
|
-
export function toViewBoxPoints(board, hostPoints) {
|
|
50
|
-
const newPoints = hostPoints.map((point) => {
|
|
51
|
-
return toViewBoxPoint(board, point);
|
|
52
|
-
});
|
|
53
|
-
return newPoints;
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* `toHostPoint` reverse processing
|
|
57
|
-
* Get the screen point starting from the upper left corner of the browser window or the viewport (based on the screen coordinate system)
|
|
58
|
-
*/
|
|
59
|
-
export function toScreenPointFromHostPoint(board, hostPoint) {
|
|
60
|
-
const host = PlaitBoard.getHost(board);
|
|
61
|
-
const rect = host.getBoundingClientRect();
|
|
62
|
-
return [hostPoint[0] + rect.x, hostPoint[1] + rect.y];
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* `toViewBoxPoint` reverse processing
|
|
66
|
-
*/
|
|
67
|
-
export function toHostPointFromViewBoxPoint(board, viewBoxPoint) {
|
|
68
|
-
const { zoom } = board.viewport;
|
|
69
|
-
const viewBox = getViewBox(board);
|
|
70
|
-
const x = (viewBoxPoint[0] - viewBox.x) * zoom;
|
|
71
|
-
const y = (viewBoxPoint[1] - viewBox.y) * zoom;
|
|
72
|
-
return [x, y];
|
|
73
|
-
}
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"to-point.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/to-point.ts"],"names":[],"mappings":"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","sourcesContent":["import { RectangleClient } from '../interfaces';\nimport { PlaitBoard } from '../interfaces/board';\nimport { Point } from '../interfaces/point';\n\nexport const getViewBox = (board: PlaitBoard) => {\n    return PlaitBoard.getHost(board).viewBox.baseVal;\n};\n\n/**\n * Get the screen point starting from the upper left corner of the svg element (based on the svg screen coordinate system)\n */\nexport function toHostPoint(board: PlaitBoard, x: number, y: number): Point {\n    const host = PlaitBoard.getHost(board);\n    const rect = host.getBoundingClientRect();\n    return [x - rect.x, y - rect.y];\n}\n\nexport function toActiveRectangleFromViewBoxRectangle(board: PlaitBoard, rectangle: RectangleClient) {\n    const leftTop = [rectangle.x, rectangle.y] as Point;\n    const rightBottom = [rectangle.x + rectangle.width, rectangle.y + rectangle.height] as Point;\n    const leftTopOfActive = toActivePointFromViewBoxPoint(board, leftTop);\n    const rightBottomOfActive = toActivePointFromViewBoxPoint(board, rightBottom);\n    return RectangleClient.getRectangleByPoints([leftTopOfActive, rightBottomOfActive]);\n}\n\nexport function toActivePointFromViewBoxPoint(board: PlaitBoard, point: Point) {\n    const screenPoint = toScreenPointFromHostPoint(board, toHostPointFromViewBoxPoint(board, point));\n    return toActivePoint(board, screenPoint[0], screenPoint[1]);\n}\n\n/**\n * Get the screen point starting from the upper left corner of the svg element (based on the svg screen coordinate system)\n */\nexport function toActivePoint(board: PlaitBoard, x: number, y: number): Point {\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const rect = boardContainer.getBoundingClientRect();\n    return [x - rect.x, y - rect.y];\n}\n\nexport function toScreenPointFromActivePoint(board: PlaitBoard, activePoint: Point): Point {\n    const boardContainer = PlaitBoard.getBoardContainer(board);\n    const rect = boardContainer.getBoundingClientRect();\n    return [rect.x + activePoint[0], rect.y + activePoint[1]];\n}\n\n/**\n * Get the point in the coordinate system of the svg viewBox\n */\nexport function toViewBoxPoint(board: PlaitBoard, hostPoint: Point) {\n    const viewBox = getViewBox(board);\n    const { zoom } = board.viewport;\n    const x = hostPoint[0] / zoom + viewBox.x;\n    const y = hostPoint[1] / zoom + viewBox.y;\n    const newPoint = [x, y] as Point;\n    return newPoint;\n}\n\nexport function toViewBoxPoints(board: PlaitBoard, hostPoints: Point[]) {\n    const newPoints = hostPoints.map((point) => {\n        return toViewBoxPoint(board, point);\n    });\n    return newPoints;\n}\n\n/**\n * `toHostPoint` reverse processing\n * Get the screen point starting from the upper left corner of the browser window or the viewport (based on the screen coordinate system)\n */\nexport function toScreenPointFromHostPoint(board: PlaitBoard, hostPoint: Point) {\n    const host = PlaitBoard.getHost(board);\n    const rect = host.getBoundingClientRect();\n    return [hostPoint[0] + rect.x, hostPoint[1] + rect.y] as Point;\n}\n\n/**\n * `toViewBoxPoint` reverse processing\n */\nexport function toHostPointFromViewBoxPoint(board: PlaitBoard, viewBoxPoint: Point) {\n    const { zoom } = board.viewport;\n    const viewBox = getViewBox(board);\n    const x = (viewBoxPoint[0] - viewBox.x) * zoom;\n    const y = (viewBoxPoint[1] - viewBox.y) * zoom;\n    return [x, y] as Point;\n}\n"]}
|
package/esm2022/utils/tree.mjs
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard } from '../interfaces/board';
|
|
2
|
-
export function depthFirstRecursion(node, callback, recursion, isReverse) {
|
|
3
|
-
if (node.children && (!recursion || recursion(node))) {
|
|
4
|
-
let children = [...node.children];
|
|
5
|
-
children = isReverse ? children.reverse() : children;
|
|
6
|
-
children.forEach(child => {
|
|
7
|
-
depthFirstRecursion(child, callback, recursion);
|
|
8
|
-
});
|
|
9
|
-
}
|
|
10
|
-
callback(node);
|
|
11
|
-
}
|
|
12
|
-
export const getIsRecursionFunc = (board) => {
|
|
13
|
-
return (element) => {
|
|
14
|
-
if (PlaitBoard.isBoard(element) || board.isRecursion(element)) {
|
|
15
|
-
return true;
|
|
16
|
-
}
|
|
17
|
-
else {
|
|
18
|
-
return false;
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3V0aWxzL3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBR2pELE1BQU0sVUFBVSxtQkFBbUIsQ0FDL0IsSUFBTyxFQUNQLFFBQTJCLEVBQzNCLFNBQWdDLEVBQ2hDLFNBQW1CO0lBRW5CLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLENBQUMsU0FBUyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDbkQsSUFBSSxRQUFRLEdBQWUsQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM5QyxRQUFRLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztRQUNyRCxRQUFRLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3JCLG1CQUFtQixDQUFDLEtBQVUsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDekQsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQ25CLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLEtBQWlCLEVBQUUsRUFBRTtJQUNwRCxPQUFPLENBQUMsT0FBa0MsRUFBRSxFQUFFO1FBQzFDLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDNUQsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQzthQUFNLENBQUM7WUFDSixPQUFPLEtBQUssQ0FBQztRQUNqQixDQUFDO0lBQ0wsQ0FBQyxDQUFDO0FBQ04sQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgUGxhaXRFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlcHRoRmlyc3RSZWN1cnNpb248VCBleHRlbmRzIFRyZWVOb2RlID0gVHJlZU5vZGU+KFxuICAgIG5vZGU6IFQsXG4gICAgY2FsbGJhY2s6IChub2RlOiBUKSA9PiB2b2lkLFxuICAgIHJlY3Vyc2lvbj86IChub2RlOiBUKSA9PiBib29sZWFuLFxuICAgIGlzUmV2ZXJzZT86IGJvb2xlYW5cbikge1xuICAgIGlmIChub2RlLmNoaWxkcmVuICYmICghcmVjdXJzaW9uIHx8IHJlY3Vyc2lvbihub2RlKSkpIHtcbiAgICAgICAgbGV0IGNoaWxkcmVuOiBUcmVlTm9kZVtdID0gWy4uLm5vZGUuY2hpbGRyZW5dO1xuICAgICAgICBjaGlsZHJlbiA9IGlzUmV2ZXJzZSA/IGNoaWxkcmVuLnJldmVyc2UoKSA6IGNoaWxkcmVuO1xuICAgICAgICBjaGlsZHJlbi5mb3JFYWNoKGNoaWxkID0+IHtcbiAgICAgICAgICAgIGRlcHRoRmlyc3RSZWN1cnNpb24oY2hpbGQgYXMgVCwgY2FsbGJhY2ssIHJlY3Vyc2lvbik7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBjYWxsYmFjayhub2RlKTtcbn1cblxuZXhwb3J0IGNvbnN0IGdldElzUmVjdXJzaW9uRnVuYyA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIHJldHVybiAoZWxlbWVudDogUGxhaXRFbGVtZW50IHwgUGxhaXRCb2FyZCkgPT4ge1xuICAgICAgICBpZiAoUGxhaXRCb2FyZC5pc0JvYXJkKGVsZW1lbnQpIHx8IGJvYXJkLmlzUmVjdXJzaW9uKGVsZW1lbnQpKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH07XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFRyZWVOb2RlIHtcbiAgICBjaGlsZHJlbj86IFRyZWVOb2RlW107XG59XG4iXX0=
|