@plait/core 0.24.0-next.2 → 0.24.0-next.4
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/board/board.component.d.ts +1 -1
- package/core/children/children.component.d.ts +1 -1
- package/core/element/element.component.d.ts +1 -1
- package/core/element/plugin-element.d.ts +1 -1
- package/core/island/island-base.component.d.ts +1 -1
- package/{esm2020 → esm2022}/board/board.component.mjs +6 -6
- package/{esm2020 → esm2022}/core/children/children.component.mjs +6 -6
- package/{esm2020 → esm2022}/core/element/element.component.mjs +4 -4
- package/{esm2020 → esm2022}/core/element/plugin-element.mjs +4 -4
- package/{esm2020 → esm2022}/core/island/island-base.component.mjs +7 -7
- package/{esm2020 → esm2022}/interfaces/rectangle-client.mjs +11 -3
- package/{esm2020 → esm2022}/plait.module.mjs +5 -5
- package/esm2022/plugins/with-moving.mjs +98 -0
- package/esm2022/plugins/with-selection.mjs +181 -0
- package/{esm2020 → esm2022}/services/image-context.service.mjs +4 -4
- package/esm2022/utils/dom/common.mjs +68 -0
- package/esm2022/utils/dom/foreign.mjs +25 -0
- package/esm2022/utils/draw/rectangle.mjs +36 -0
- package/esm2022/utils/element.mjs +53 -0
- package/esm2022/utils/math.mjs +176 -0
- package/{fesm2020 → fesm2022}/plait-core.mjs +178 -42
- package/fesm2022/plait-core.mjs.map +1 -0
- package/interfaces/rectangle-client.d.ts +1 -0
- package/package.json +14 -14
- package/utils/dom/common.d.ts +4 -0
- package/utils/dom/foreign.d.ts +2 -1
- package/utils/draw/rectangle.d.ts +3 -0
- package/utils/element.d.ts +1 -0
- package/utils/math.d.ts +5 -0
- package/esm2020/plugins/with-moving.mjs +0 -97
- package/esm2020/plugins/with-selection.mjs +0 -183
- package/esm2020/utils/dom/common.mjs +0 -53
- package/esm2020/utils/dom/foreign.mjs +0 -19
- package/esm2020/utils/draw/rectangle.mjs +0 -26
- package/esm2020/utils/element.mjs +0 -44
- package/esm2020/utils/math.mjs +0 -85
- package/fesm2015/plait-core.mjs +0 -3498
- package/fesm2015/plait-core.mjs.map +0 -1
- package/fesm2020/plait-core.mjs.map +0 -1
- /package/{esm2020 → esm2022}/board/board.component.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/keycodes.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/resize.mjs +0 -0
- /package/{esm2020 → esm2022}/constants/selection.mjs +0 -0
- /package/{esm2020 → esm2022}/core/children/effect.mjs +0 -0
- /package/{esm2020 → esm2022}/core/element/context-change.mjs +0 -0
- /package/{esm2020 → esm2022}/core/element/context.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/board.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/custom-types.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/element.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/history.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/index.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/operation.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/path-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/path.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/plugin-key.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/plugin.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/point.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/selection.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/theme.mjs +0 -0
- /package/{esm2020 → esm2022}/interfaces/viewport.mjs +0 -0
- /package/{esm2020 → esm2022}/plait-core.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/create-board.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-board.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-hand.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-history.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-hotkey.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-options.mjs +0 -0
- /package/{esm2020 → esm2022}/plugins/with-viewport.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/core/create-board.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/core/fake-weak-map.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/core/index.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/fake-events/event-objects.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/fake-events/index.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/index.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/test-element.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/board.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/general.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/index.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/node.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/selection.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/theme.mjs +0 -0
- /package/{esm2020 → esm2022}/transforms/viewport.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/board.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/clipboard.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/common.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/dom/environment.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/dom/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/arrow.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/circle.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/draw/line.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/environment.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/helper.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/history.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/hotkeys.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/id-creator.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/moving-element.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/selected-element.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/to-image.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/touch.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/tree.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/viewport.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/weak-maps.mjs +0 -0
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { RectangleClient } from '../interfaces/rectangle-client';
|
|
2
|
+
// https://stackoverflow.com/a/6853926/232122
|
|
3
|
+
export function distanceBetweenPointAndSegment(x, y, x1, y1, x2, y2) {
|
|
4
|
+
const A = x - x1;
|
|
5
|
+
const B = y - y1;
|
|
6
|
+
const C = x2 - x1;
|
|
7
|
+
const D = y2 - y1;
|
|
8
|
+
const dot = A * C + B * D;
|
|
9
|
+
const lenSquare = C * C + D * D;
|
|
10
|
+
let param = -1;
|
|
11
|
+
if (lenSquare !== 0) {
|
|
12
|
+
// in case of 0 length line
|
|
13
|
+
param = dot / lenSquare;
|
|
14
|
+
}
|
|
15
|
+
let xx, yy;
|
|
16
|
+
if (param < 0) {
|
|
17
|
+
xx = x1;
|
|
18
|
+
yy = y1;
|
|
19
|
+
}
|
|
20
|
+
else if (param > 1) {
|
|
21
|
+
xx = x2;
|
|
22
|
+
yy = y2;
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
xx = x1 + param * C;
|
|
26
|
+
yy = y1 + param * D;
|
|
27
|
+
}
|
|
28
|
+
const dx = x - xx;
|
|
29
|
+
const dy = y - yy;
|
|
30
|
+
return Math.hypot(dx, dy);
|
|
31
|
+
}
|
|
32
|
+
export function getNearestPointBetweenPointAndSegment(point, linePoints) {
|
|
33
|
+
const x = point[0], y = point[1], x1 = linePoints[0][0], y1 = linePoints[0][1], x2 = linePoints[1][0], y2 = linePoints[1][1];
|
|
34
|
+
const A = x - x1;
|
|
35
|
+
const B = y - y1;
|
|
36
|
+
const C = x2 - x1;
|
|
37
|
+
const D = y2 - y1;
|
|
38
|
+
const dot = A * C + B * D;
|
|
39
|
+
const lenSquare = C * C + D * D;
|
|
40
|
+
let param = -1;
|
|
41
|
+
if (lenSquare !== 0) {
|
|
42
|
+
// in case of 0 length line
|
|
43
|
+
param = dot / lenSquare;
|
|
44
|
+
}
|
|
45
|
+
let xx, yy;
|
|
46
|
+
if (param < 0) {
|
|
47
|
+
xx = x1;
|
|
48
|
+
yy = y1;
|
|
49
|
+
}
|
|
50
|
+
else if (param > 1) {
|
|
51
|
+
xx = x2;
|
|
52
|
+
yy = y2;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
xx = x1 + param * C;
|
|
56
|
+
yy = y1 + param * D;
|
|
57
|
+
}
|
|
58
|
+
return [xx, yy];
|
|
59
|
+
}
|
|
60
|
+
export function distanceBetweenPointAndSegments(points, point) {
|
|
61
|
+
const len = points.length;
|
|
62
|
+
let distance = Infinity;
|
|
63
|
+
for (let i = 0; i < len - 1; i++) {
|
|
64
|
+
const p = points[i];
|
|
65
|
+
const p2 = points[i + 1];
|
|
66
|
+
const currentDistance = distanceBetweenPointAndSegment(point[0], point[1], p[0], p[1], p2[0], p2[1]);
|
|
67
|
+
if (currentDistance < distance) {
|
|
68
|
+
distance = currentDistance;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return distance;
|
|
72
|
+
}
|
|
73
|
+
export function getNearestPointBetweenPointAndSegments(point, points) {
|
|
74
|
+
const len = points.length;
|
|
75
|
+
let distance = Infinity;
|
|
76
|
+
let result = point;
|
|
77
|
+
for (let i = 0; i < len; i++) {
|
|
78
|
+
const p = points[i];
|
|
79
|
+
const p2 = i === len - 1 ? points[0] : points[i + 1];
|
|
80
|
+
const currentDistance = distanceBetweenPointAndSegment(point[0], point[1], p[0], p[1], p2[0], p2[1]);
|
|
81
|
+
if (currentDistance < distance) {
|
|
82
|
+
distance = currentDistance;
|
|
83
|
+
result = getNearestPointBetweenPointAndSegment(point, [p, p2]);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
88
|
+
export function rotate(x1, y1, x2, y2, angle) {
|
|
89
|
+
// 𝑎′𝑥=(𝑎𝑥−𝑐𝑥)cos𝜃−(𝑎𝑦−𝑐𝑦)sin𝜃+𝑐𝑥
|
|
90
|
+
// 𝑎′𝑦=(𝑎𝑥−𝑐𝑥)sin𝜃+(𝑎𝑦−𝑐𝑦)cos𝜃+𝑐𝑦.
|
|
91
|
+
// https://math.stackexchange.com/questions/2204520/how-do-i-rotate-a-line-segment-in-a-specific-point-on-the-line
|
|
92
|
+
return [(x1 - x2) * Math.cos(angle) - (y1 - y2) * Math.sin(angle) + x2, (x1 - x2) * Math.sin(angle) + (y1 - y2) * Math.cos(angle) + y2];
|
|
93
|
+
}
|
|
94
|
+
export function distanceBetweenPointAndPoint(x1, y1, x2, y2) {
|
|
95
|
+
const dx = x1 - x2;
|
|
96
|
+
const dy = y1 - y2;
|
|
97
|
+
return Math.hypot(dx, dy);
|
|
98
|
+
}
|
|
99
|
+
// https://stackoverflow.com/questions/5254838/calculating-distance-between-a-point-and-a-rectangular-box-nearest-point
|
|
100
|
+
export function distanceBetweenPointAndRectangle(x, y, rect) {
|
|
101
|
+
var dx = Math.max(rect.x - x, 0, x - (rect.x + rect.width));
|
|
102
|
+
var dy = Math.max(rect.y - y, 0, y - (rect.y + rect.height));
|
|
103
|
+
return Math.sqrt(dx * dx + dy * dy);
|
|
104
|
+
}
|
|
105
|
+
export const isLineHitLine = (a, b, c, d) => {
|
|
106
|
+
const crossProduct = (v1, v2) => v1[0] * v2[1] - v1[1] * v2[0];
|
|
107
|
+
const ab = [b[0] - a[0], b[1] - a[1]];
|
|
108
|
+
const ac = [c[0] - a[0], c[1] - a[1]];
|
|
109
|
+
const ad = [d[0] - a[0], d[1] - a[1]];
|
|
110
|
+
const ca = [a[0] - c[0], a[1] - c[1]];
|
|
111
|
+
const cb = [b[0] - c[0], b[1] - c[1]];
|
|
112
|
+
const cd = [d[0] - c[0], d[1] - c[1]];
|
|
113
|
+
return crossProduct(ab, ac) * crossProduct(ab, ad) <= 0 && crossProduct(cd, ca) * crossProduct(cd, cb) <= 0;
|
|
114
|
+
};
|
|
115
|
+
export const isPolylineHitRectangle = (points, rectangle) => {
|
|
116
|
+
const rectanglePoints = RectangleClient.getCornerPoints(rectangle);
|
|
117
|
+
for (let i = 1; i < points.length; i++) {
|
|
118
|
+
const isIntersect = isLineHitLine(points[i], points[i - 1], rectanglePoints[0], rectanglePoints[1]) ||
|
|
119
|
+
isLineHitLine(points[i], points[i - 1], rectanglePoints[1], rectanglePoints[2]) ||
|
|
120
|
+
isLineHitLine(points[i], points[i - 1], rectanglePoints[2], rectanglePoints[3]) ||
|
|
121
|
+
isLineHitLine(points[i], points[i - 1], rectanglePoints[3], rectanglePoints[0]);
|
|
122
|
+
if (isIntersect) {
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
return false;
|
|
127
|
+
};
|
|
128
|
+
//https://stackoverflow.com/questions/22521982/check-if-point-is-inside-a-polygon
|
|
129
|
+
export const isPointInPolygon = (point, points) => {
|
|
130
|
+
// ray-casting algorithm based on
|
|
131
|
+
// https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html
|
|
132
|
+
const x = point[0], y = point[1];
|
|
133
|
+
let inside = false;
|
|
134
|
+
for (var i = 0, j = points.length - 1; i < points.length; j = i++) {
|
|
135
|
+
let xi = points[i][0], yi = points[i][1];
|
|
136
|
+
let xj = points[j][0], yj = points[j][1];
|
|
137
|
+
let intersect = yi > y != yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi;
|
|
138
|
+
if (intersect)
|
|
139
|
+
inside = !inside;
|
|
140
|
+
}
|
|
141
|
+
return inside;
|
|
142
|
+
};
|
|
143
|
+
export const isPointInEllipse = (point, center, rx, ry, rotation = 0) => {
|
|
144
|
+
const cosAngle = Math.cos(rotation);
|
|
145
|
+
const sinAngle = Math.sin(rotation);
|
|
146
|
+
const x1 = (point[0] - center[0]) * cosAngle + (point[1] - center[1]) * sinAngle;
|
|
147
|
+
const y1 = (point[1] - center[1]) * cosAngle - (point[0] - center[0]) * sinAngle;
|
|
148
|
+
return (x1 * x1) / (rx * rx) + (y1 * y1) / (ry * ry) <= 1;
|
|
149
|
+
};
|
|
150
|
+
export const isPointInRoundRectangle = (point, rectangle, radius) => {
|
|
151
|
+
const { x: rectX, y: rectY, width, height } = rectangle;
|
|
152
|
+
const isInRectangle = point[0] >= rectX && point[0] <= rectX + width && point[1] >= rectY && point[1] <= rectY + height;
|
|
153
|
+
const handleLeftTop = point[0] >= rectX &&
|
|
154
|
+
point[0] <= rectX + radius &&
|
|
155
|
+
point[1] >= rectY &&
|
|
156
|
+
point[1] <= rectY + radius &&
|
|
157
|
+
Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + radius)) > radius;
|
|
158
|
+
const handleLeftBottom = point[0] >= rectX &&
|
|
159
|
+
point[0] <= rectX + radius &&
|
|
160
|
+
point[1] >= rectY + height &&
|
|
161
|
+
point[1] <= rectY + height - radius &&
|
|
162
|
+
Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + height - radius)) > radius;
|
|
163
|
+
const handleRightTop = point[0] >= rectX + width - radius &&
|
|
164
|
+
point[0] <= rectX + width &&
|
|
165
|
+
point[1] >= rectY &&
|
|
166
|
+
point[1] <= rectY + radius &&
|
|
167
|
+
Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + radius)) > radius;
|
|
168
|
+
const handleRightBottom = point[0] >= rectX + width - radius &&
|
|
169
|
+
point[0] <= rectX + width &&
|
|
170
|
+
point[1] >= rectY + height - radius &&
|
|
171
|
+
point[1] <= rectY + height &&
|
|
172
|
+
Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + height - radius)) > radius;
|
|
173
|
+
const isInCorner = handleLeftTop || handleLeftBottom || handleRightTop || handleRightBottom;
|
|
174
|
+
return isInRectangle && !isInCorner;
|
|
175
|
+
};
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"math.js","sourceRoot":"","sources":["../../../../packages/core/src/utils/math.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point } from '../interfaces';\nimport { RectangleClient } from '../interfaces/rectangle-client';\n\n// https://stackoverflow.com/a/6853926/232122\nexport function distanceBetweenPointAndSegment(x: number, y: number, x1: number, y1: number, x2: number, y2: number) {\n    const A = x - x1;\n    const B = y - y1;\n    const C = x2 - x1;\n    const D = y2 - y1;\n\n    const dot = A * C + B * D;\n    const lenSquare = C * C + D * D;\n    let param = -1;\n    if (lenSquare !== 0) {\n        // in case of 0 length line\n        param = dot / lenSquare;\n    }\n\n    let xx, yy;\n    if (param < 0) {\n        xx = x1;\n        yy = y1;\n    } else if (param > 1) {\n        xx = x2;\n        yy = y2;\n    } else {\n        xx = x1 + param * C;\n        yy = y1 + param * D;\n    }\n\n    const dx = x - xx;\n    const dy = y - yy;\n    return Math.hypot(dx, dy);\n}\n\nexport function getNearestPointBetweenPointAndSegment(point: Point, linePoints: [Point, Point]) {\n    const x = point[0],\n        y = point[1],\n        x1 = linePoints[0][0],\n        y1 = linePoints[0][1],\n        x2 = linePoints[1][0],\n        y2 = linePoints[1][1];\n    const A = x - x1;\n    const B = y - y1;\n    const C = x2 - x1;\n    const D = y2 - y1;\n\n    const dot = A * C + B * D;\n    const lenSquare = C * C + D * D;\n    let param = -1;\n    if (lenSquare !== 0) {\n        // in case of 0 length line\n        param = dot / lenSquare;\n    }\n\n    let xx, yy;\n    if (param < 0) {\n        xx = x1;\n        yy = y1;\n    } else if (param > 1) {\n        xx = x2;\n        yy = y2;\n    } else {\n        xx = x1 + param * C;\n        yy = y1 + param * D;\n    }\n\n    return [xx, yy] as Point;\n}\n\nexport function distanceBetweenPointAndSegments(points: Point[], point: Point) {\n    const len = points.length;\n    let distance = Infinity;\n    for (let i = 0; i < len - 1; i++) {\n        const p = points[i];\n        const p2 = points[i + 1];\n        const currentDistance = distanceBetweenPointAndSegment(point[0], point[1], p[0], p[1], p2[0], p2[1]);\n        if (currentDistance < distance) {\n            distance = currentDistance;\n        }\n    }\n    return distance;\n}\n\nexport function getNearestPointBetweenPointAndSegments(point: Point, points: Point[]) {\n    const len = points.length;\n    let distance = Infinity;\n    let result: Point = point;\n\n    for (let i = 0; i < len; i++) {\n        const p = points[i];\n        const p2 = i === len - 1 ? points[0] : points[i + 1];\n        const currentDistance = distanceBetweenPointAndSegment(point[0], point[1], p[0], p[1], p2[0], p2[1]);\n        if (currentDistance < distance) {\n            distance = currentDistance;\n            result = getNearestPointBetweenPointAndSegment(point, [p, p2]);\n        }\n    }\n    return result;\n}\n\nexport function rotate(x1: number, y1: number, x2: number, y2: number, angle: number) {\n    // 𝑎′𝑥=(𝑎𝑥−𝑐𝑥)cos𝜃−(𝑎𝑦−𝑐𝑦)sin𝜃+𝑐𝑥\n    // 𝑎′𝑦=(𝑎𝑥−𝑐𝑥)sin𝜃+(𝑎𝑦−𝑐𝑦)cos𝜃+𝑐𝑦.\n    // https://math.stackexchange.com/questions/2204520/how-do-i-rotate-a-line-segment-in-a-specific-point-on-the-line\n    return [(x1 - x2) * Math.cos(angle) - (y1 - y2) * Math.sin(angle) + x2, (x1 - x2) * Math.sin(angle) + (y1 - y2) * Math.cos(angle) + y2];\n}\n\nexport function distanceBetweenPointAndPoint(x1: number, y1: number, x2: number, y2: number) {\n    const dx = x1 - x2;\n    const dy = y1 - y2;\n    return Math.hypot(dx, dy);\n}\n\n// https://stackoverflow.com/questions/5254838/calculating-distance-between-a-point-and-a-rectangular-box-nearest-point\nexport function distanceBetweenPointAndRectangle(x: number, y: number, rect: RectangleClient) {\n    var dx = Math.max(rect.x - x, 0, x - (rect.x + rect.width));\n    var dy = Math.max(rect.y - y, 0, y - (rect.y + rect.height));\n    return Math.sqrt(dx * dx + dy * dy);\n}\n\nexport const isLineHitLine = (a: Point, b: Point, c: Point, d: Point): boolean => {\n    const crossProduct = (v1: Point, v2: Point) => v1[0] * v2[1] - v1[1] * v2[0];\n\n    const ab: Point = [b[0] - a[0], b[1] - a[1]];\n    const ac: Point = [c[0] - a[0], c[1] - a[1]];\n    const ad: Point = [d[0] - a[0], d[1] - a[1]];\n\n    const ca: Point = [a[0] - c[0], a[1] - c[1]];\n    const cb: Point = [b[0] - c[0], b[1] - c[1]];\n    const cd: Point = [d[0] - c[0], d[1] - c[1]];\n\n    return crossProduct(ab, ac) * crossProduct(ab, ad) <= 0 && crossProduct(cd, ca) * crossProduct(cd, cb) <= 0;\n};\n\nexport const isPolylineHitRectangle = (points: Point[], rectangle: RectangleClient) => {\n    const rectanglePoints = RectangleClient.getCornerPoints(rectangle);\n\n    for (let i = 1; i < points.length; i++) {\n        const isIntersect =\n            isLineHitLine(points[i], points[i - 1], rectanglePoints[0], rectanglePoints[1]) ||\n            isLineHitLine(points[i], points[i - 1], rectanglePoints[1], rectanglePoints[2]) ||\n            isLineHitLine(points[i], points[i - 1], rectanglePoints[2], rectanglePoints[3]) ||\n            isLineHitLine(points[i], points[i - 1], rectanglePoints[3], rectanglePoints[0]);\n        if (isIntersect) {\n            return true;\n        }\n    }\n\n    return false;\n};\n\n//https://stackoverflow.com/questions/22521982/check-if-point-is-inside-a-polygon\nexport const isPointInPolygon = (point: Point, points: Point[]) => {\n    // ray-casting algorithm based on\n    // https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html\n\n    const x = point[0],\n        y = point[1];\n\n    let inside = false;\n    for (var i = 0, j = points.length - 1; i < points.length; j = i++) {\n        let xi = points[i][0],\n            yi = points[i][1];\n        let xj = points[j][0],\n            yj = points[j][1];\n\n        let intersect = yi > y != yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi;\n        if (intersect) inside = !inside;\n    }\n    return inside;\n};\n\nexport const isPointInEllipse = (point: Point, center: Point, rx: number, ry: number, rotation = 0) => {\n    const cosAngle = Math.cos(rotation);\n    const sinAngle = Math.sin(rotation);\n    const x1 = (point[0] - center[0]) * cosAngle + (point[1] - center[1]) * sinAngle;\n    const y1 = (point[1] - center[1]) * cosAngle - (point[0] - center[0]) * sinAngle;\n\n    return (x1 * x1) / (rx * rx) + (y1 * y1) / (ry * ry) <= 1;\n};\n\nexport const isPointInRoundRectangle = (point: Point, rectangle: RectangleClient, radius: number) => {\n    const { x: rectX, y: rectY, width, height } = rectangle;\n    const isInRectangle = point[0] >= rectX && point[0] <= rectX + width && point[1] >= rectY && point[1] <= rectY + height;\n    const handleLeftTop =\n        point[0] >= rectX &&\n        point[0] <= rectX + radius &&\n        point[1] >= rectY &&\n        point[1] <= rectY + radius &&\n        Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + radius)) > radius;\n    const handleLeftBottom =\n        point[0] >= rectX &&\n        point[0] <= rectX + radius &&\n        point[1] >= rectY + height &&\n        point[1] <= rectY + height - radius &&\n        Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + height - radius)) > radius;\n    const handleRightTop =\n        point[0] >= rectX + width - radius &&\n        point[0] <= rectX + width &&\n        point[1] >= rectY &&\n        point[1] <= rectY + radius &&\n        Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + radius)) > radius;\n    const handleRightBottom =\n        point[0] >= rectX + width - radius &&\n        point[0] <= rectX + width &&\n        point[1] >= rectY + height - radius &&\n        point[1] <= rectY + height &&\n        Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + height - radius)) > radius;\n    const isInCorner = handleLeftTop || handleLeftBottom || handleRightTop || handleRightBottom;\n\n    return isInRectangle && !isInCorner;\n};\n"]}
|
|
@@ -96,6 +96,15 @@ function getRectangleByElements(board, elements, recursion) {
|
|
|
96
96
|
function getBoardRectangle(board) {
|
|
97
97
|
return getRectangleByElements(board, board.children, true);
|
|
98
98
|
}
|
|
99
|
+
function getElementById(board, id) {
|
|
100
|
+
let element = null;
|
|
101
|
+
depthFirstRecursion(board, node => {
|
|
102
|
+
if (id === node.id) {
|
|
103
|
+
element = node;
|
|
104
|
+
}
|
|
105
|
+
}, getIsRecursionFunc(board), true);
|
|
106
|
+
return element;
|
|
107
|
+
}
|
|
99
108
|
|
|
100
109
|
var ThemeColorMode;
|
|
101
110
|
(function (ThemeColorMode) {
|
|
@@ -173,8 +182,8 @@ const RectangleClient = {
|
|
|
173
182
|
return {
|
|
174
183
|
x: rectangle.x + offset,
|
|
175
184
|
y: rectangle.y + offset,
|
|
176
|
-
width: rectangle.width
|
|
177
|
-
height: rectangle.height
|
|
185
|
+
width: rectangle.width - offset * 2,
|
|
186
|
+
height: rectangle.height - offset * 2
|
|
178
187
|
};
|
|
179
188
|
},
|
|
180
189
|
isEqual: (rectangle, otherRectangle) => {
|
|
@@ -190,6 +199,14 @@ const RectangleClient = {
|
|
|
190
199
|
[rectangle.x + rectangle.width, rectangle.y + rectangle.height],
|
|
191
200
|
[rectangle.x, rectangle.y + rectangle.height]
|
|
192
201
|
];
|
|
202
|
+
},
|
|
203
|
+
getEdgeCenterPoints: (rectangle) => {
|
|
204
|
+
return [
|
|
205
|
+
[rectangle.x + rectangle.width / 2, rectangle.y],
|
|
206
|
+
[rectangle.x + rectangle.width, rectangle.y + rectangle.height / 2],
|
|
207
|
+
[rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height],
|
|
208
|
+
[rectangle.x, rectangle.y + rectangle.height / 2]
|
|
209
|
+
];
|
|
193
210
|
}
|
|
194
211
|
};
|
|
195
212
|
|
|
@@ -223,6 +240,34 @@ function distanceBetweenPointAndSegment(x, y, x1, y1, x2, y2) {
|
|
|
223
240
|
const dy = y - yy;
|
|
224
241
|
return Math.hypot(dx, dy);
|
|
225
242
|
}
|
|
243
|
+
function getNearestPointBetweenPointAndSegment(point, linePoints) {
|
|
244
|
+
const x = point[0], y = point[1], x1 = linePoints[0][0], y1 = linePoints[0][1], x2 = linePoints[1][0], y2 = linePoints[1][1];
|
|
245
|
+
const A = x - x1;
|
|
246
|
+
const B = y - y1;
|
|
247
|
+
const C = x2 - x1;
|
|
248
|
+
const D = y2 - y1;
|
|
249
|
+
const dot = A * C + B * D;
|
|
250
|
+
const lenSquare = C * C + D * D;
|
|
251
|
+
let param = -1;
|
|
252
|
+
if (lenSquare !== 0) {
|
|
253
|
+
// in case of 0 length line
|
|
254
|
+
param = dot / lenSquare;
|
|
255
|
+
}
|
|
256
|
+
let xx, yy;
|
|
257
|
+
if (param < 0) {
|
|
258
|
+
xx = x1;
|
|
259
|
+
yy = y1;
|
|
260
|
+
}
|
|
261
|
+
else if (param > 1) {
|
|
262
|
+
xx = x2;
|
|
263
|
+
yy = y2;
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
xx = x1 + param * C;
|
|
267
|
+
yy = y1 + param * D;
|
|
268
|
+
}
|
|
269
|
+
return [xx, yy];
|
|
270
|
+
}
|
|
226
271
|
function distanceBetweenPointAndSegments(points, point) {
|
|
227
272
|
const len = points.length;
|
|
228
273
|
let distance = Infinity;
|
|
@@ -236,6 +281,21 @@ function distanceBetweenPointAndSegments(points, point) {
|
|
|
236
281
|
}
|
|
237
282
|
return distance;
|
|
238
283
|
}
|
|
284
|
+
function getNearestPointBetweenPointAndSegments(point, points) {
|
|
285
|
+
const len = points.length;
|
|
286
|
+
let distance = Infinity;
|
|
287
|
+
let result = point;
|
|
288
|
+
for (let i = 0; i < len; i++) {
|
|
289
|
+
const p = points[i];
|
|
290
|
+
const p2 = i === len - 1 ? points[0] : points[i + 1];
|
|
291
|
+
const currentDistance = distanceBetweenPointAndSegment(point[0], point[1], p[0], p[1], p2[0], p2[1]);
|
|
292
|
+
if (currentDistance < distance) {
|
|
293
|
+
distance = currentDistance;
|
|
294
|
+
result = getNearestPointBetweenPointAndSegment(point, [p, p2]);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
return result;
|
|
298
|
+
}
|
|
239
299
|
function rotate(x1, y1, x2, y2, angle) {
|
|
240
300
|
// 𝑎′𝑥=(𝑎𝑥−𝑐𝑥)cos𝜃−(𝑎𝑦−𝑐𝑦)sin𝜃+𝑐𝑥
|
|
241
301
|
// 𝑎′𝑦=(𝑎𝑥−𝑐𝑥)sin𝜃+(𝑎𝑦−𝑐𝑦)cos𝜃+𝑐𝑦.
|
|
@@ -276,6 +336,54 @@ const isPolylineHitRectangle = (points, rectangle) => {
|
|
|
276
336
|
}
|
|
277
337
|
return false;
|
|
278
338
|
};
|
|
339
|
+
//https://stackoverflow.com/questions/22521982/check-if-point-is-inside-a-polygon
|
|
340
|
+
const isPointInPolygon = (point, points) => {
|
|
341
|
+
// ray-casting algorithm based on
|
|
342
|
+
// https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html
|
|
343
|
+
const x = point[0], y = point[1];
|
|
344
|
+
let inside = false;
|
|
345
|
+
for (var i = 0, j = points.length - 1; i < points.length; j = i++) {
|
|
346
|
+
let xi = points[i][0], yi = points[i][1];
|
|
347
|
+
let xj = points[j][0], yj = points[j][1];
|
|
348
|
+
let intersect = yi > y != yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi;
|
|
349
|
+
if (intersect)
|
|
350
|
+
inside = !inside;
|
|
351
|
+
}
|
|
352
|
+
return inside;
|
|
353
|
+
};
|
|
354
|
+
const isPointInEllipse = (point, center, rx, ry, rotation = 0) => {
|
|
355
|
+
const cosAngle = Math.cos(rotation);
|
|
356
|
+
const sinAngle = Math.sin(rotation);
|
|
357
|
+
const x1 = (point[0] - center[0]) * cosAngle + (point[1] - center[1]) * sinAngle;
|
|
358
|
+
const y1 = (point[1] - center[1]) * cosAngle - (point[0] - center[0]) * sinAngle;
|
|
359
|
+
return (x1 * x1) / (rx * rx) + (y1 * y1) / (ry * ry) <= 1;
|
|
360
|
+
};
|
|
361
|
+
const isPointInRoundRectangle = (point, rectangle, radius) => {
|
|
362
|
+
const { x: rectX, y: rectY, width, height } = rectangle;
|
|
363
|
+
const isInRectangle = point[0] >= rectX && point[0] <= rectX + width && point[1] >= rectY && point[1] <= rectY + height;
|
|
364
|
+
const handleLeftTop = point[0] >= rectX &&
|
|
365
|
+
point[0] <= rectX + radius &&
|
|
366
|
+
point[1] >= rectY &&
|
|
367
|
+
point[1] <= rectY + radius &&
|
|
368
|
+
Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + radius)) > radius;
|
|
369
|
+
const handleLeftBottom = point[0] >= rectX &&
|
|
370
|
+
point[0] <= rectX + radius &&
|
|
371
|
+
point[1] >= rectY + height &&
|
|
372
|
+
point[1] <= rectY + height - radius &&
|
|
373
|
+
Math.hypot(point[0] - (rectX + radius), point[1] - (rectY + height - radius)) > radius;
|
|
374
|
+
const handleRightTop = point[0] >= rectX + width - radius &&
|
|
375
|
+
point[0] <= rectX + width &&
|
|
376
|
+
point[1] >= rectY &&
|
|
377
|
+
point[1] <= rectY + radius &&
|
|
378
|
+
Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + radius)) > radius;
|
|
379
|
+
const handleRightBottom = point[0] >= rectX + width - radius &&
|
|
380
|
+
point[0] <= rectX + width &&
|
|
381
|
+
point[1] >= rectY + height - radius &&
|
|
382
|
+
point[1] <= rectY + height &&
|
|
383
|
+
Math.hypot(point[0] - (rectX + width - radius), point[1] - (rectY + height - radius)) > radius;
|
|
384
|
+
const isInCorner = handleLeftTop || handleLeftBottom || handleRightTop || handleRightBottom;
|
|
385
|
+
return isInRectangle && !isInCorner;
|
|
386
|
+
};
|
|
279
387
|
|
|
280
388
|
const PlaitBoard = {
|
|
281
389
|
isBoard(value) {
|
|
@@ -982,6 +1090,21 @@ function createPath() {
|
|
|
982
1090
|
const newG = document.createElementNS(NS, 'path');
|
|
983
1091
|
return newG;
|
|
984
1092
|
}
|
|
1093
|
+
function createRect(rectangle, options) {
|
|
1094
|
+
const rect = document.createElementNS(NS, 'rect');
|
|
1095
|
+
rect.setAttribute('x', `${rectangle.x}`);
|
|
1096
|
+
rect.setAttribute('y', `${rectangle.y}`);
|
|
1097
|
+
rect.setAttribute('width', `${rectangle.width}`);
|
|
1098
|
+
rect.setAttribute('height', `${rectangle.height}`);
|
|
1099
|
+
for (let key in options) {
|
|
1100
|
+
const optionKey = key;
|
|
1101
|
+
rect.setAttribute(key, `${options[optionKey]}`);
|
|
1102
|
+
}
|
|
1103
|
+
return rect;
|
|
1104
|
+
}
|
|
1105
|
+
function createMask() {
|
|
1106
|
+
return document.createElementNS(NS, 'mask');
|
|
1107
|
+
}
|
|
985
1108
|
function createSVG() {
|
|
986
1109
|
const svg = document.createElementNS(NS, 'svg');
|
|
987
1110
|
return svg;
|
|
@@ -1171,10 +1294,10 @@ class PlaitPluginElementComponent {
|
|
|
1171
1294
|
removeSelectedElement(this.board, this.element);
|
|
1172
1295
|
(this.rootG || this.g).remove();
|
|
1173
1296
|
}
|
|
1297
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitPluginElementComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
1298
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: PlaitPluginElementComponent, inputs: { context: "context" }, ngImport: i0 }); }
|
|
1174
1299
|
}
|
|
1175
|
-
|
|
1176
|
-
PlaitPluginElementComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitPluginElementComponent, inputs: { context: "context" }, ngImport: i0 });
|
|
1177
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitPluginElementComponent, decorators: [{
|
|
1300
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitPluginElementComponent, decorators: [{
|
|
1178
1301
|
type: Directive
|
|
1179
1302
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { context: [{
|
|
1180
1303
|
type: Input
|
|
@@ -1219,8 +1342,8 @@ function createForeignObject(x, y, width, height) {
|
|
|
1219
1342
|
newForeignObject.setAttribute('height', `${height}`);
|
|
1220
1343
|
return newForeignObject;
|
|
1221
1344
|
}
|
|
1222
|
-
function updateForeignObject(
|
|
1223
|
-
const foreignObject =
|
|
1345
|
+
function updateForeignObject(target, width, height, x, y) {
|
|
1346
|
+
const foreignObject = target instanceof SVGForeignObjectElement ? target : target.querySelector('foreignObject');
|
|
1224
1347
|
if (foreignObject) {
|
|
1225
1348
|
foreignObject.setAttribute('width', `${width}`);
|
|
1226
1349
|
foreignObject.setAttribute('height', `${height}`);
|
|
@@ -1228,6 +1351,12 @@ function updateForeignObject(g, width, height, x, y) {
|
|
|
1228
1351
|
foreignObject.setAttribute('y', `${y}`);
|
|
1229
1352
|
}
|
|
1230
1353
|
}
|
|
1354
|
+
function updateForeignObjectWidth(target, width) {
|
|
1355
|
+
const foreignObject = target instanceof SVGForeignObjectElement ? target : target.querySelector('foreignObject');
|
|
1356
|
+
if (foreignObject) {
|
|
1357
|
+
foreignObject.setAttribute('width', `${width}`);
|
|
1358
|
+
}
|
|
1359
|
+
}
|
|
1231
1360
|
|
|
1232
1361
|
const IS_MAC = typeof window != 'undefined' && /Mac|iPod|iPhone|iPad/.test(window.navigator.platform);
|
|
1233
1362
|
|
|
@@ -1436,6 +1565,15 @@ function drawRoundRectangle(rs, x1, y1, x2, y2, options, outline = false, border
|
|
|
1436
1565
|
const point8 = [x1, y1 + radius];
|
|
1437
1566
|
return rs.path(`M${point2[0]} ${point2[1]} A ${radius} ${radius}, 0, 0, 1, ${point3[0]} ${point3[1]} L ${point4[0]} ${point4[1]} A ${radius} ${radius}, 0, 0, 1, ${point5[0]} ${point5[1]} L ${point6[0]} ${point6[1]} A ${radius} ${radius}, 0, 0, 1, ${point7[0]} ${point7[1]} L ${point8[0]} ${point8[1]} A ${radius} ${radius}, 0, 0, 1, ${point1[0]} ${point1[1]} Z`, options);
|
|
1438
1567
|
}
|
|
1568
|
+
const drawRectangle = (board, rectangle, options) => {
|
|
1569
|
+
const roughSVG = PlaitBoard.getRoughSVG(board);
|
|
1570
|
+
const rectangleG = roughSVG.rectangle(rectangle.x, rectangle.y, rectangle.width, rectangle.height, options);
|
|
1571
|
+
const paths = rectangleG.querySelectorAll('path');
|
|
1572
|
+
paths.forEach(path => {
|
|
1573
|
+
path.setAttribute('stroke-linecap', 'square');
|
|
1574
|
+
});
|
|
1575
|
+
return rectangleG;
|
|
1576
|
+
};
|
|
1439
1577
|
|
|
1440
1578
|
function arrowPoints(start, end, maxHypotenuseLength = 10, degree = 40) {
|
|
1441
1579
|
const width = Math.abs(start[0] - end[0]);
|
|
@@ -2407,9 +2545,9 @@ function withSelection(board) {
|
|
|
2407
2545
|
}
|
|
2408
2546
|
if (start) {
|
|
2409
2547
|
const movedTarget = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
2410
|
-
const
|
|
2548
|
+
const rectangle = RectangleClient.toRectangleClient([start, movedTarget]);
|
|
2411
2549
|
selectionMovingG?.remove();
|
|
2412
|
-
if (Math.hypot(width, height) > 5) {
|
|
2550
|
+
if (Math.hypot(rectangle.width, rectangle.height) > 5) {
|
|
2413
2551
|
end = movedTarget;
|
|
2414
2552
|
throttleRAF(() => {
|
|
2415
2553
|
if (start && end) {
|
|
@@ -2417,8 +2555,7 @@ function withSelection(board) {
|
|
|
2417
2555
|
}
|
|
2418
2556
|
});
|
|
2419
2557
|
setSelectionMoving(board);
|
|
2420
|
-
|
|
2421
|
-
selectionMovingG = rough.rectangle(x, y, width, height, {
|
|
2558
|
+
selectionMovingG = drawRectangle(board, rectangle, {
|
|
2422
2559
|
stroke: SELECTION_BORDER_COLOR,
|
|
2423
2560
|
strokeWidth: 1,
|
|
2424
2561
|
fill: SELECTION_FILL_COLOR,
|
|
@@ -2526,9 +2663,8 @@ function clearSelectionMoving(board) {
|
|
|
2526
2663
|
BOARD_TO_IS_SELECTION_MOVING.delete(board);
|
|
2527
2664
|
}
|
|
2528
2665
|
function createSelectionOuterG(board, selectElements) {
|
|
2529
|
-
const
|
|
2530
|
-
|
|
2531
|
-
return rough.rectangle(x - 2.5, y - 2.5, width + 5, height + 5, {
|
|
2666
|
+
const rectangle = getRectangleByElements(board, selectElements, false);
|
|
2667
|
+
return drawRectangle(board, RectangleClient.getOutlineRectangle(rectangle, -2.5), {
|
|
2532
2668
|
stroke: SELECTION_BORDER_COLOR,
|
|
2533
2669
|
strokeWidth: 1,
|
|
2534
2670
|
fillStyle: 'solid'
|
|
@@ -2575,7 +2711,7 @@ function withMoving(board) {
|
|
|
2575
2711
|
const point = transformPoint(board, toPoint(event.x, event.y, host));
|
|
2576
2712
|
const range = { anchor: point, focus: point };
|
|
2577
2713
|
let movableElements = board.children.filter(item => board.isMovable(item));
|
|
2578
|
-
if (movableElements.length) {
|
|
2714
|
+
if (movableElements.length && !isPreventTouchMove(board)) {
|
|
2579
2715
|
startPoint = point;
|
|
2580
2716
|
const selectedRootElements = getSelectedElements(board).filter(item => movableElements.includes(item));
|
|
2581
2717
|
const hitElement = getHitElementOfRoot(board, movableElements, range);
|
|
@@ -2674,10 +2810,10 @@ class PlaitIslandBaseComponent {
|
|
|
2674
2810
|
markForCheck() {
|
|
2675
2811
|
this.cdr.markForCheck();
|
|
2676
2812
|
}
|
|
2813
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitIslandBaseComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
2814
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: PlaitIslandBaseComponent, host: { classAttribute: "plait-island-container" }, ngImport: i0 }); }
|
|
2677
2815
|
}
|
|
2678
|
-
|
|
2679
|
-
PlaitIslandBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitIslandBaseComponent, host: { classAttribute: "plait-island-container" }, ngImport: i0 });
|
|
2680
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandBaseComponent, decorators: [{
|
|
2816
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitIslandBaseComponent, decorators: [{
|
|
2681
2817
|
type: Directive,
|
|
2682
2818
|
args: [{
|
|
2683
2819
|
host: {
|
|
@@ -2708,10 +2844,10 @@ class PlaitIslandPopoverBaseComponent {
|
|
|
2708
2844
|
this.board.onChange = this.onChange;
|
|
2709
2845
|
this.islandOnDestroy();
|
|
2710
2846
|
}
|
|
2847
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitIslandPopoverBaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
2848
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: PlaitIslandPopoverBaseComponent, inputs: { board: "board" }, host: { classAttribute: "plait-island-popover-container" }, ngImport: i0 }); }
|
|
2711
2849
|
}
|
|
2712
|
-
|
|
2713
|
-
PlaitIslandPopoverBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: PlaitIslandPopoverBaseComponent, inputs: { board: "board" }, host: { classAttribute: "plait-island-popover-container" }, ngImport: i0 });
|
|
2714
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitIslandPopoverBaseComponent, decorators: [{
|
|
2850
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitIslandPopoverBaseComponent, decorators: [{
|
|
2715
2851
|
type: Directive,
|
|
2716
2852
|
args: [{
|
|
2717
2853
|
host: {
|
|
@@ -2796,10 +2932,10 @@ class PlaitContextService {
|
|
|
2796
2932
|
removeUploadingFile(fileEntry) {
|
|
2797
2933
|
this.uploadingFiles = this.uploadingFiles.filter(file => file.url !== fileEntry.url);
|
|
2798
2934
|
}
|
|
2935
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitContextService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
2936
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitContextService }); }
|
|
2799
2937
|
}
|
|
2800
|
-
|
|
2801
|
-
PlaitContextService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitContextService });
|
|
2802
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitContextService, decorators: [{
|
|
2938
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitContextService, decorators: [{
|
|
2803
2939
|
type: Injectable
|
|
2804
2940
|
}] });
|
|
2805
2941
|
|
|
@@ -2876,10 +3012,10 @@ class PlaitElementComponent {
|
|
|
2876
3012
|
ngOnDestroy() {
|
|
2877
3013
|
this.board.destroyElement(this.getContext());
|
|
2878
3014
|
}
|
|
3015
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitElementComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3016
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: PlaitElementComponent, selector: "plait-element", inputs: { index: "index", element: "element", parent: "parent", board: "board", effect: "effect", parentG: "parentG" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2879
3017
|
}
|
|
2880
|
-
|
|
2881
|
-
PlaitElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitElementComponent, selector: "plait-element", inputs: { index: "index", element: "element", parent: "parent", board: "board", effect: "effect", parentG: "parentG" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2882
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitElementComponent, decorators: [{
|
|
3018
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitElementComponent, decorators: [{
|
|
2883
3019
|
type: Component,
|
|
2884
3020
|
args: [{
|
|
2885
3021
|
selector: 'plait-element',
|
|
@@ -2914,9 +3050,8 @@ class PlaitChildrenElement {
|
|
|
2914
3050
|
this.parentG = PlaitBoard.getElementHost(this.board);
|
|
2915
3051
|
}
|
|
2916
3052
|
}
|
|
2917
|
-
}
|
|
2918
|
-
|
|
2919
|
-
PlaitChildrenElement.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitChildrenElement, selector: "plait-children", inputs: { board: "board", parent: "parent", effect: "effect", parentG: "parentG" }, ngImport: i0, template: `
|
|
3053
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitChildrenElement, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3054
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: PlaitChildrenElement, selector: "plait-children", inputs: { board: "board", parent: "parent", effect: "effect", parentG: "parentG" }, ngImport: i0, template: `
|
|
2920
3055
|
<plait-element
|
|
2921
3056
|
*ngFor="let item of parent.children; let index = index; trackBy: trackBy"
|
|
2922
3057
|
[index]="index"
|
|
@@ -2926,8 +3061,9 @@ PlaitChildrenElement.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", v
|
|
|
2926
3061
|
[effect]="effect"
|
|
2927
3062
|
[parentG]="parentG"
|
|
2928
3063
|
></plait-element>
|
|
2929
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: PlaitElementComponent, selector: "plait-element", inputs: ["index", "element", "parent", "board", "effect", "parentG"] }] });
|
|
2930
|
-
|
|
3064
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: PlaitElementComponent, selector: "plait-element", inputs: ["index", "element", "parent", "board", "effect", "parentG"] }] }); }
|
|
3065
|
+
}
|
|
3066
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitChildrenElement, decorators: [{
|
|
2931
3067
|
type: Component,
|
|
2932
3068
|
args: [{
|
|
2933
3069
|
selector: 'plait-children',
|
|
@@ -3266,9 +3402,8 @@ class PlaitBoardComponent {
|
|
|
3266
3402
|
this.updateIslands();
|
|
3267
3403
|
});
|
|
3268
3404
|
}
|
|
3269
|
-
}
|
|
3270
|
-
|
|
3271
|
-
PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitOptions: "plaitOptions", plaitTheme: "plaitTheme" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass", "class.readonly": "this.readonly", "class.focused": "this.isFocused", "class.disabled-scroll": "this.disabledScrollOnNonFocus" } }, providers: [PlaitContextService], queries: [{ propertyName: "islands", predicate: PlaitIslandBaseComponent, descendants: true }], viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }, { propertyName: "viewportContainer", first: true, predicate: ["viewportContainer"], descendants: true, read: ElementRef, static: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
3405
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitBoardComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3406
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: PlaitBoardComponent, selector: "plait-board", inputs: { plaitValue: "plaitValue", plaitViewport: "plaitViewport", plaitPlugins: "plaitPlugins", plaitOptions: "plaitOptions", plaitTheme: "plaitTheme" }, outputs: { plaitChange: "plaitChange", plaitBoardInitialized: "plaitBoardInitialized" }, host: { properties: { "class": "this.hostClass", "class.readonly": "this.readonly", "class.focused": "this.isFocused", "class.disabled-scroll": "this.disabledScrollOnNonFocus" } }, providers: [PlaitContextService], queries: [{ propertyName: "islands", predicate: PlaitIslandBaseComponent, descendants: true }], viewQueries: [{ propertyName: "svg", first: true, predicate: ["svg"], descendants: true, static: true }, { propertyName: "viewportContainer", first: true, predicate: ["viewportContainer"], descendants: true, read: ElementRef, static: true }], usesOnChanges: true, ngImport: i0, template: `
|
|
3272
3407
|
<div class="viewport-container" #viewportContainer>
|
|
3273
3408
|
<svg #svg width="100%" height="100%" style="position: relative;" class="board-host-svg">
|
|
3274
3409
|
<g class="element-host"></g>
|
|
@@ -3278,8 +3413,9 @@ PlaitBoardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ve
|
|
|
3278
3413
|
<plait-children [board]="board" [effect]="effect"></plait-children>
|
|
3279
3414
|
</div>
|
|
3280
3415
|
<ng-content></ng-content>
|
|
3281
|
-
`, isInline: true, dependencies: [{ kind: "component", type: PlaitChildrenElement, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
3282
|
-
|
|
3416
|
+
`, isInline: true, dependencies: [{ kind: "component", type: PlaitChildrenElement, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
3417
|
+
}
|
|
3418
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitBoardComponent, decorators: [{
|
|
3283
3419
|
type: Component,
|
|
3284
3420
|
args: [{
|
|
3285
3421
|
selector: 'plait-board',
|
|
@@ -3336,11 +3472,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
3336
3472
|
|
|
3337
3473
|
const COMPONENTS = [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent];
|
|
3338
3474
|
class PlaitModule {
|
|
3475
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
3476
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: PlaitModule, declarations: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent], imports: [CommonModule], exports: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent] }); }
|
|
3477
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitModule, imports: [CommonModule] }); }
|
|
3339
3478
|
}
|
|
3340
|
-
|
|
3341
|
-
PlaitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, declarations: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent], imports: [CommonModule], exports: [PlaitBoardComponent, PlaitChildrenElement, PlaitElementComponent] });
|
|
3342
|
-
PlaitModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, imports: [CommonModule] });
|
|
3343
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: PlaitModule, decorators: [{
|
|
3479
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: PlaitModule, decorators: [{
|
|
3344
3480
|
type: NgModule,
|
|
3345
3481
|
args: [{
|
|
3346
3482
|
declarations: [...COMPONENTS],
|
|
@@ -3517,5 +3653,5 @@ function createModModifierKeys() {
|
|
|
3517
3653
|
* Generated bundle index. Do not edit.
|
|
3518
3654
|
*/
|
|
3519
3655
|
|
|
3520
|
-
export { A, 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_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, 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_PREVENT_TOUCH_MOVE, 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, PlaitChildrenElement, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitModule, 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, 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, createModModifierKeys, createMouseEvent, createPath, createPointerEvent, createSVG, createSelectionOuterG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRoundRectangle, fakeNodeWeakMap, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementHostBBox, getHitElementOfRoot, getHitElements, getIsRecursionFunc, getMovingElements, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getTextFromClipboard, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isHitElements, isInPlaitBoard, isLineHitLine, isMainPointer, isNullOrUndefined, isPolylineHitRectangle, isPreventTouchMove, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, preventTouchMove, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setClipboardData, setClipboardDataByMedia, setClipboardDataByText, setIsFromScrolling, setIsFromViewportChange, setSVGViewBox, setSelectionMoving, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
3656
|
+
export { A, 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_VIEWPORT_ORIGINATION, BoardTransforms, C, CAPS_LOCK, CLIP_BOARD_FORMAT_KEY, CLOSE_SQUARE_BRACKET, COMMA, CONTEXT_MENU, CONTROL, ColorfulThemeColor, D, DASH, DELETE, DOWN_ARROW, DarkThemeColor, DefaultThemeColor, 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_PREVENT_TOUCH_MOVE, 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, PlaitChildrenElement, PlaitContextService, PlaitElement, PlaitElementComponent, PlaitHistoryBoard, PlaitIslandBaseComponent, PlaitIslandPopoverBaseComponent, PlaitModule, 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, 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, createSelectionOuterG, createTestingBoard, createText, createTouchEvent, debounce, deleteTemporaryElements, depthFirstRecursion, distanceBetweenPointAndPoint, distanceBetweenPointAndRectangle, distanceBetweenPointAndSegment, distanceBetweenPointAndSegments, downloadImage, drawArrow, drawBezierPath, drawCircle, drawLine, drawLinearPath, drawRectangle, drawRoundRectangle, fakeNodeWeakMap, getBoardRectangle, getClipboardByKey, getClipboardDataByMedia, getDataFromClipboard, getElementById, getElementHostBBox, getHitElementOfRoot, getHitElements, getIsRecursionFunc, getMovingElements, getNearestPointBetweenPointAndSegment, getNearestPointBetweenPointAndSegments, getRealScrollBarWidth, getRectangleByElements, getSelectedElements, getTemporaryElements, getTextFromClipboard, getViewBox, getViewBoxCenterPoint, getViewportContainerRect, getViewportOrigination, hasBeforeContextChange, hasInputOrTextareaTarget, hasOnBoardChange, hasOnContextChanged, hotkeys, idCreator, initializeViewBox, initializeViewportContainer, initializeViewportOffset, inverse, isDOMElement, isDOMNode, isFromScrolling, isFromViewportChange, isHitElements, isInPlaitBoard, isLineHitLine, isMainPointer, isNullOrUndefined, isPointInEllipse, isPointInPolygon, isPointInRoundRectangle, isPolylineHitRectangle, isPreventTouchMove, isSecondaryPointer, isSelectedElement, isSelectionMoving, isSetViewportOperation, normalizePoint, preventTouchMove, removeMovingElements, removeSelectedElement, rotate, scrollToRectangle, setClipboardData, setClipboardDataByMedia, setClipboardDataByText, setIsFromScrolling, setIsFromViewportChange, setSVGViewBox, setSelectionMoving, shouldClear, shouldMerge, shouldSave, throttleRAF, toImage, toPoint, transformPoint, transformPoints, updateForeignObject, updateForeignObjectWidth, updateViewportContainerScroll, updateViewportOffset, updateViewportOrigination, withMoving, withOptions, withSelection };
|
|
3521
3657
|
//# sourceMappingURL=plait-core.mjs.map
|