@plait/draw 0.1.0-next.10 → 0.1.0-next.12

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.
Files changed (84) hide show
  1. package/constants/pointer.d.ts +5 -1
  2. package/esm2022/constants/pointer.mjs +27 -0
  3. package/esm2022/generators/line-active.generator.mjs +51 -0
  4. package/{esm2020 → esm2022}/geometry.component.mjs +4 -4
  5. package/esm2022/interfaces/geometry.mjs +27 -0
  6. package/esm2022/interfaces/line.mjs +56 -0
  7. package/esm2022/line.component.mjs +160 -0
  8. package/esm2022/plugins/with-draw-fragment.mjs +61 -0
  9. package/{esm2020 → esm2022}/plugins/with-draw.mjs +4 -5
  10. package/{esm2020 → esm2022}/utils/clipboard.mjs +2 -1
  11. package/esm2022/utils/engine/diamond.mjs +30 -0
  12. package/esm2022/utils/engine/ellipse.mjs +92 -0
  13. package/esm2022/utils/engine/index.mjs +26 -0
  14. package/esm2022/utils/engine/left-arrow.mjs +45 -0
  15. package/esm2022/utils/engine/parallelogram.mjs +39 -0
  16. package/esm2022/utils/engine/rectangle.mjs +26 -0
  17. package/esm2022/utils/engine/right-arrow.mjs +45 -0
  18. package/esm2022/utils/engine/round-rectangle.mjs +59 -0
  19. package/esm2022/utils/engine/trapezoid.mjs +40 -0
  20. package/esm2022/utils/engine/triangle.mjs +40 -0
  21. package/esm2022/utils/geometry.mjs +95 -0
  22. package/esm2022/utils/line.mjs +205 -0
  23. package/esm2022/utils/position/line.mjs +33 -0
  24. package/{fesm2020 → fesm2022}/plait-draw.mjs +416 -88
  25. package/fesm2022/plait-draw.mjs.map +1 -0
  26. package/generators/line-active.generator.d.ts +1 -0
  27. package/interfaces/geometry.d.ts +9 -2
  28. package/interfaces/line.d.ts +9 -2
  29. package/line.component.d.ts +1 -0
  30. package/package.json +7 -12
  31. package/plugins/with-draw-fragment.d.ts +2 -0
  32. package/styles/styles.scss +2 -2
  33. package/utils/engine/left-arrow.d.ts +4 -0
  34. package/utils/engine/parallelogram.d.ts +1 -1
  35. package/utils/engine/right-arrow.d.ts +4 -0
  36. package/utils/engine/trapezoid.d.ts +4 -0
  37. package/utils/engine/triangle.d.ts +4 -0
  38. package/utils/geometry.d.ts +1 -0
  39. package/utils/line.d.ts +10 -6
  40. package/esm2020/constants/pointer.mjs +0 -19
  41. package/esm2020/generators/line-active.generator.mjs +0 -36
  42. package/esm2020/interfaces/geometry.mjs +0 -23
  43. package/esm2020/interfaces/line.mjs +0 -48
  44. package/esm2020/line.component.mjs +0 -152
  45. package/esm2020/plugins/with-draw-fragment.mjs +0 -52
  46. package/esm2020/utils/engine/diamond.mjs +0 -22
  47. package/esm2020/utils/engine/ellipse.mjs +0 -55
  48. package/esm2020/utils/engine/index.mjs +0 -18
  49. package/esm2020/utils/engine/parallelogram.mjs +0 -32
  50. package/esm2020/utils/engine/rectangle.mjs +0 -18
  51. package/esm2020/utils/engine/round-rectangle.mjs +0 -49
  52. package/esm2020/utils/geometry.mjs +0 -84
  53. package/esm2020/utils/line.mjs +0 -169
  54. package/esm2020/utils/position/line.mjs +0 -34
  55. package/fesm2015/plait-draw.mjs +0 -1765
  56. package/fesm2015/plait-draw.mjs.map +0 -1
  57. package/fesm2020/plait-draw.mjs.map +0 -1
  58. /package/{esm2020 → esm2022}/constants/geometry.mjs +0 -0
  59. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  60. /package/{esm2020 → esm2022}/constants/line.mjs +0 -0
  61. /package/{esm2020 → esm2022}/generators/geometry-shape.generator.mjs +0 -0
  62. /package/{esm2020 → esm2022}/generators/line.generator.mjs +0 -0
  63. /package/{esm2020 → esm2022}/interfaces/element.mjs +0 -0
  64. /package/{esm2020 → esm2022}/interfaces/index.mjs +0 -0
  65. /package/{esm2020 → esm2022}/interfaces/text.mjs +0 -0
  66. /package/{esm2020 → esm2022}/plait-draw.mjs +0 -0
  67. /package/{esm2020 → esm2022}/plugins/with-draw-hotkey.mjs +0 -0
  68. /package/{esm2020 → esm2022}/plugins/with-geometry-create.mjs +0 -0
  69. /package/{esm2020 → esm2022}/plugins/with-geometry-resize.mjs +0 -0
  70. /package/{esm2020 → esm2022}/plugins/with-line-bound-reaction.mjs +0 -0
  71. /package/{esm2020 → esm2022}/plugins/with-line-create.mjs +0 -0
  72. /package/{esm2020 → esm2022}/plugins/with-line-resize.mjs +0 -0
  73. /package/{esm2020 → esm2022}/plugins/with-line-text.mjs +0 -0
  74. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  75. /package/{esm2020 → esm2022}/transforms/geometry-text.mjs +0 -0
  76. /package/{esm2020 → esm2022}/transforms/geometry.mjs +0 -0
  77. /package/{esm2020 → esm2022}/transforms/index.mjs +0 -0
  78. /package/{esm2020 → esm2022}/transforms/line.mjs +0 -0
  79. /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
  80. /package/{esm2020 → esm2022}/utils/line-arrow.mjs +0 -0
  81. /package/{esm2020 → esm2022}/utils/position/geometry.mjs +0 -0
  82. /package/{esm2020 → esm2022}/utils/selected.mjs +0 -0
  83. /package/{esm2020 → esm2022}/utils/style/index.mjs +0 -0
  84. /package/{esm2020 → esm2022}/utils/style/stroke.mjs +0 -0
@@ -0,0 +1,40 @@
1
+ import { PlaitBoard, RectangleClient, getNearestPointBetweenPointAndSegments, isPointInPolygon, setStrokeLinecap } from '@plait/core';
2
+ import { getCenterPointsOnPolygon, getEdgeOnPolygonByPoint } from '../geometry';
3
+ export const TrapezoidEngine = {
4
+ draw(board, rectangle, options) {
5
+ const points = getTrapezoidPoints(rectangle);
6
+ const rs = PlaitBoard.getRoughSVG(board);
7
+ const polygon = rs.polygon(points, { ...options, fillStyle: 'solid' });
8
+ setStrokeLinecap(polygon, 'round');
9
+ return polygon;
10
+ },
11
+ isHit(rectangle, point) {
12
+ const points = getTrapezoidPoints(rectangle);
13
+ return isPointInPolygon(point, points);
14
+ },
15
+ getNearestPoint(rectangle, point) {
16
+ const cornerPoints = getTrapezoidPoints(rectangle);
17
+ return getNearestPointBetweenPointAndSegments(point, cornerPoints);
18
+ },
19
+ getConnectorPoints(rectangle) {
20
+ const points = getTrapezoidPoints(rectangle);
21
+ return getCenterPointsOnPolygon(points);
22
+ },
23
+ getEdgeByConnectionPoint(rectangle, pointOfRectangle) {
24
+ const corners = getTrapezoidPoints(rectangle);
25
+ const point = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);
26
+ return getEdgeOnPolygonByPoint(corners, point);
27
+ },
28
+ getCornerPoints(rectangle) {
29
+ return getTrapezoidPoints(rectangle);
30
+ }
31
+ };
32
+ export const getTrapezoidPoints = (rectangle) => {
33
+ return [
34
+ [rectangle.x + rectangle.width * 0.15, rectangle.y],
35
+ [rectangle.x + rectangle.width * 0.85, rectangle.y],
36
+ [rectangle.x + rectangle.width, rectangle.y + rectangle.height],
37
+ [rectangle.x, rectangle.y + rectangle.height]
38
+ ];
39
+ };
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhcGV6b2lkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvdXRpbHMvZW5naW5lL3RyYXBlem9pZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsVUFBVSxFQUdWLGVBQWUsRUFDZixzQ0FBc0MsRUFDdEMsZ0JBQWdCLEVBQ2hCLGdCQUFnQixFQUNuQixNQUFNLGFBQWEsQ0FBQztBQUdyQixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFaEYsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFnQjtJQUN4QyxJQUFJLENBQUMsS0FBaUIsRUFBRSxTQUEwQixFQUFFLE9BQWdCO1FBQ2hFLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sRUFBRSxHQUFHLFVBQVUsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRSxHQUFHLE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUN2RSxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDbkMsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQztJQUNELEtBQUssQ0FBQyxTQUEwQixFQUFFLEtBQVk7UUFDMUMsTUFBTSxNQUFNLEdBQUcsa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDN0MsT0FBTyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUNELGVBQWUsQ0FBQyxTQUEwQixFQUFFLEtBQVk7UUFDcEQsTUFBTSxZQUFZLEdBQUcsa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDbkQsT0FBTyxzQ0FBc0MsQ0FBQyxLQUFLLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUNELGtCQUFrQixDQUFDLFNBQTBCO1FBQ3pDLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzdDLE9BQU8sd0JBQXdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUNELHdCQUF3QixDQUFDLFNBQTBCLEVBQUUsZ0JBQWtDO1FBQ25GLE1BQU0sT0FBTyxHQUFHLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzlDLE1BQU0sS0FBSyxHQUFHLGVBQWUsQ0FBQyxrQkFBa0IsQ0FBQyxTQUFTLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztRQUM5RSxPQUFPLHVCQUF1QixDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBQ0QsZUFBZSxDQUFDLFNBQTBCO1FBQ3RDLE9BQU8sa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDekMsQ0FBQztDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLFNBQTBCLEVBQVcsRUFBRTtJQUN0RSxPQUFPO1FBQ0gsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDbkQsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDbkQsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUMsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDO1FBQy9ELENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7S0FDaEQsQ0FBQztBQUNOLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgUGxhaXRCb2FyZCxcbiAgICBQb2ludCxcbiAgICBQb2ludE9mUmVjdGFuZ2xlLFxuICAgIFJlY3RhbmdsZUNsaWVudCxcbiAgICBnZXROZWFyZXN0UG9pbnRCZXR3ZWVuUG9pbnRBbmRTZWdtZW50cyxcbiAgICBpc1BvaW50SW5Qb2x5Z29uLFxuICAgIHNldFN0cm9rZUxpbmVjYXBcbn0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgU2hhcGVFbmdpbmUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IE9wdGlvbnMgfSBmcm9tICdyb3VnaGpzL2Jpbi9jb3JlJztcbmltcG9ydCB7IGdldENlbnRlclBvaW50c09uUG9seWdvbiwgZ2V0RWRnZU9uUG9seWdvbkJ5UG9pbnQgfSBmcm9tICcuLi9nZW9tZXRyeSc7XG5cbmV4cG9ydCBjb25zdCBUcmFwZXpvaWRFbmdpbmU6IFNoYXBlRW5naW5lID0ge1xuICAgIGRyYXcoYm9hcmQ6IFBsYWl0Qm9hcmQsIHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBvcHRpb25zOiBPcHRpb25zKSB7XG4gICAgICAgIGNvbnN0IHBvaW50cyA9IGdldFRyYXBlem9pZFBvaW50cyhyZWN0YW5nbGUpO1xuICAgICAgICBjb25zdCBycyA9IFBsYWl0Qm9hcmQuZ2V0Um91Z2hTVkcoYm9hcmQpO1xuICAgICAgICBjb25zdCBwb2x5Z29uID0gcnMucG9seWdvbihwb2ludHMsIHsgLi4ub3B0aW9ucywgZmlsbFN0eWxlOiAnc29saWQnIH0pO1xuICAgICAgICBzZXRTdHJva2VMaW5lY2FwKHBvbHlnb24sICdyb3VuZCcpO1xuICAgICAgICByZXR1cm4gcG9seWdvbjtcbiAgICB9LFxuICAgIGlzSGl0KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludDogUG9pbnQpIHtcbiAgICAgICAgY29uc3QgcG9pbnRzID0gZ2V0VHJhcGV6b2lkUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgICAgIHJldHVybiBpc1BvaW50SW5Qb2x5Z29uKHBvaW50LCBwb2ludHMpO1xuICAgIH0sXG4gICAgZ2V0TmVhcmVzdFBvaW50KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludDogUG9pbnQpIHtcbiAgICAgICAgY29uc3QgY29ybmVyUG9pbnRzID0gZ2V0VHJhcGV6b2lkUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgICAgIHJldHVybiBnZXROZWFyZXN0UG9pbnRCZXR3ZWVuUG9pbnRBbmRTZWdtZW50cyhwb2ludCwgY29ybmVyUG9pbnRzKTtcbiAgICB9LFxuICAgIGdldENvbm5lY3RvclBvaW50cyhyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCkge1xuICAgICAgICBjb25zdCBwb2ludHMgPSBnZXRUcmFwZXpvaWRQb2ludHMocmVjdGFuZ2xlKTtcbiAgICAgICAgcmV0dXJuIGdldENlbnRlclBvaW50c09uUG9seWdvbihwb2ludHMpO1xuICAgIH0sXG4gICAgZ2V0RWRnZUJ5Q29ubmVjdGlvblBvaW50KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludE9mUmVjdGFuZ2xlOiBQb2ludE9mUmVjdGFuZ2xlKTogW1BvaW50LCBQb2ludF0gfCBudWxsIHtcbiAgICAgICAgY29uc3QgY29ybmVycyA9IGdldFRyYXBlem9pZFBvaW50cyhyZWN0YW5nbGUpO1xuICAgICAgICBjb25zdCBwb2ludCA9IFJlY3RhbmdsZUNsaWVudC5nZXRDb25uZWN0aW9uUG9pbnQocmVjdGFuZ2xlLCBwb2ludE9mUmVjdGFuZ2xlKTtcbiAgICAgICAgcmV0dXJuIGdldEVkZ2VPblBvbHlnb25CeVBvaW50KGNvcm5lcnMsIHBvaW50KTtcbiAgICB9LFxuICAgIGdldENvcm5lclBvaW50cyhyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCkge1xuICAgICAgICByZXR1cm4gZ2V0VHJhcGV6b2lkUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgfVxufTtcblxuZXhwb3J0IGNvbnN0IGdldFRyYXBlem9pZFBvaW50cyA9IChyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCk6IFBvaW50W10gPT4ge1xuICAgIHJldHVybiBbXG4gICAgICAgIFtyZWN0YW5nbGUueCArIHJlY3RhbmdsZS53aWR0aCAqIDAuMTUsIHJlY3RhbmdsZS55XSxcbiAgICAgICAgW3JlY3RhbmdsZS54ICsgcmVjdGFuZ2xlLndpZHRoICogMC44NSwgcmVjdGFuZ2xlLnldLFxuICAgICAgICBbcmVjdGFuZ2xlLnggKyByZWN0YW5nbGUud2lkdGgsIHJlY3RhbmdsZS55ICsgcmVjdGFuZ2xlLmhlaWdodF0sXG4gICAgICAgIFtyZWN0YW5nbGUueCwgcmVjdGFuZ2xlLnkgKyByZWN0YW5nbGUuaGVpZ2h0XVxuICAgIF07XG59O1xuIl19
@@ -0,0 +1,40 @@
1
+ import { PlaitBoard, RectangleClient, getNearestPointBetweenPointAndSegments, isPointInPolygon, setStrokeLinecap } from '@plait/core';
2
+ import { getCenterPointsOnPolygon, getEdgeOnPolygonByPoint } from '../geometry';
3
+ export const TriangleEngine = {
4
+ draw(board, rectangle, options) {
5
+ const points = getTrianglePoints(rectangle);
6
+ const rs = PlaitBoard.getRoughSVG(board);
7
+ const polygon = rs.polygon(points, { ...options, fillStyle: 'solid' });
8
+ setStrokeLinecap(polygon, 'round');
9
+ return polygon;
10
+ },
11
+ isHit(rectangle, point) {
12
+ const points = getTrianglePoints(rectangle);
13
+ return isPointInPolygon(point, points);
14
+ },
15
+ getNearestPoint(rectangle, point) {
16
+ const cornerPoints = getTrianglePoints(rectangle);
17
+ return getNearestPointBetweenPointAndSegments(point, cornerPoints);
18
+ },
19
+ getConnectorPoints(rectangle) {
20
+ const cornerPoints = getTrianglePoints(rectangle);
21
+ const lineCenterPoints = getCenterPointsOnPolygon(cornerPoints);
22
+ return [...lineCenterPoints, ...cornerPoints];
23
+ },
24
+ getEdgeByConnectionPoint(rectangle, pointOfRectangle) {
25
+ const corners = getTrianglePoints(rectangle);
26
+ const point = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);
27
+ return getEdgeOnPolygonByPoint(corners, point);
28
+ },
29
+ getCornerPoints(rectangle) {
30
+ return getTrianglePoints(rectangle);
31
+ }
32
+ };
33
+ export const getTrianglePoints = (rectangle) => {
34
+ return [
35
+ [rectangle.x + rectangle.width / 2, rectangle.y],
36
+ [rectangle.x + rectangle.width, rectangle.y + rectangle.height],
37
+ [rectangle.x, rectangle.y + rectangle.height]
38
+ ];
39
+ };
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJpYW5nbGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy91dGlscy9lbmdpbmUvdHJpYW5nbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFVBQVUsRUFHVixlQUFlLEVBQ2Ysc0NBQXNDLEVBQ3RDLGdCQUFnQixFQUNoQixnQkFBZ0IsRUFDbkIsTUFBTSxhQUFhLENBQUM7QUFHckIsT0FBTyxFQUFFLHdCQUF3QixFQUFFLHVCQUF1QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRWhGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBZ0I7SUFDdkMsSUFBSSxDQUFDLEtBQWlCLEVBQUUsU0FBMEIsRUFBRSxPQUFnQjtRQUNoRSxNQUFNLE1BQU0sR0FBRyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUM1QyxNQUFNLEVBQUUsR0FBRyxVQUFVLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pDLE1BQU0sT0FBTyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLEVBQUUsR0FBRyxPQUFPLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDdkUsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ25DLE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUM7SUFDRCxLQUFLLENBQUMsU0FBMEIsRUFBRSxLQUFZO1FBQzFDLE1BQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVDLE9BQU8sZ0JBQWdCLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFDRCxlQUFlLENBQUMsU0FBMEIsRUFBRSxLQUFZO1FBQ3BELE1BQU0sWUFBWSxHQUFHLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ2xELE9BQU8sc0NBQXNDLENBQUMsS0FBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFDRCxrQkFBa0IsQ0FBQyxTQUEwQjtRQUN6QyxNQUFNLFlBQVksR0FBRyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNsRCxNQUFNLGdCQUFnQixHQUFHLHdCQUF3QixDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2hFLE9BQU8sQ0FBQyxHQUFHLGdCQUFnQixFQUFFLEdBQUcsWUFBWSxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUNELHdCQUF3QixDQUFDLFNBQTBCLEVBQUUsZ0JBQWtDO1FBQ25GLE1BQU0sT0FBTyxHQUFHLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzdDLE1BQU0sS0FBSyxHQUFHLGVBQWUsQ0FBQyxrQkFBa0IsQ0FBQyxTQUFTLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztRQUM5RSxPQUFPLHVCQUF1QixDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBQ0QsZUFBZSxDQUFDLFNBQTBCO1FBQ3RDLE9BQU8saUJBQWlCLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDeEMsQ0FBQztDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLFNBQTBCLEVBQVcsRUFBRTtJQUNyRSxPQUFPO1FBQ0gsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDaEQsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUMsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDO1FBQy9ELENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7S0FDaEQsQ0FBQztBQUNOLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgUGxhaXRCb2FyZCxcbiAgICBQb2ludCxcbiAgICBQb2ludE9mUmVjdGFuZ2xlLFxuICAgIFJlY3RhbmdsZUNsaWVudCxcbiAgICBnZXROZWFyZXN0UG9pbnRCZXR3ZWVuUG9pbnRBbmRTZWdtZW50cyxcbiAgICBpc1BvaW50SW5Qb2x5Z29uLFxuICAgIHNldFN0cm9rZUxpbmVjYXBcbn0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgU2hhcGVFbmdpbmUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IE9wdGlvbnMgfSBmcm9tICdyb3VnaGpzL2Jpbi9jb3JlJztcbmltcG9ydCB7IGdldENlbnRlclBvaW50c09uUG9seWdvbiwgZ2V0RWRnZU9uUG9seWdvbkJ5UG9pbnQgfSBmcm9tICcuLi9nZW9tZXRyeSc7XG5cbmV4cG9ydCBjb25zdCBUcmlhbmdsZUVuZ2luZTogU2hhcGVFbmdpbmUgPSB7XG4gICAgZHJhdyhib2FyZDogUGxhaXRCb2FyZCwgcmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQsIG9wdGlvbnM6IE9wdGlvbnMpIHtcbiAgICAgICAgY29uc3QgcG9pbnRzID0gZ2V0VHJpYW5nbGVQb2ludHMocmVjdGFuZ2xlKTtcbiAgICAgICAgY29uc3QgcnMgPSBQbGFpdEJvYXJkLmdldFJvdWdoU1ZHKGJvYXJkKTtcbiAgICAgICAgY29uc3QgcG9seWdvbiA9IHJzLnBvbHlnb24ocG9pbnRzLCB7IC4uLm9wdGlvbnMsIGZpbGxTdHlsZTogJ3NvbGlkJyB9KTtcbiAgICAgICAgc2V0U3Ryb2tlTGluZWNhcChwb2x5Z29uLCAncm91bmQnKTtcbiAgICAgICAgcmV0dXJuIHBvbHlnb247XG4gICAgfSxcbiAgICBpc0hpdChyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCwgcG9pbnQ6IFBvaW50KSB7XG4gICAgICAgIGNvbnN0IHBvaW50cyA9IGdldFRyaWFuZ2xlUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgICAgIHJldHVybiBpc1BvaW50SW5Qb2x5Z29uKHBvaW50LCBwb2ludHMpO1xuICAgIH0sXG4gICAgZ2V0TmVhcmVzdFBvaW50KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludDogUG9pbnQpIHtcbiAgICAgICAgY29uc3QgY29ybmVyUG9pbnRzID0gZ2V0VHJpYW5nbGVQb2ludHMocmVjdGFuZ2xlKTtcbiAgICAgICAgcmV0dXJuIGdldE5lYXJlc3RQb2ludEJldHdlZW5Qb2ludEFuZFNlZ21lbnRzKHBvaW50LCBjb3JuZXJQb2ludHMpO1xuICAgIH0sXG4gICAgZ2V0Q29ubmVjdG9yUG9pbnRzKHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50KSB7XG4gICAgICAgIGNvbnN0IGNvcm5lclBvaW50cyA9IGdldFRyaWFuZ2xlUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgICAgIGNvbnN0IGxpbmVDZW50ZXJQb2ludHMgPSBnZXRDZW50ZXJQb2ludHNPblBvbHlnb24oY29ybmVyUG9pbnRzKTtcbiAgICAgICAgcmV0dXJuIFsuLi5saW5lQ2VudGVyUG9pbnRzLCAuLi5jb3JuZXJQb2ludHNdO1xuICAgIH0sXG4gICAgZ2V0RWRnZUJ5Q29ubmVjdGlvblBvaW50KHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludE9mUmVjdGFuZ2xlOiBQb2ludE9mUmVjdGFuZ2xlKTogW1BvaW50LCBQb2ludF0gfCBudWxsIHtcbiAgICAgICAgY29uc3QgY29ybmVycyA9IGdldFRyaWFuZ2xlUG9pbnRzKHJlY3RhbmdsZSk7XG4gICAgICAgIGNvbnN0IHBvaW50ID0gUmVjdGFuZ2xlQ2xpZW50LmdldENvbm5lY3Rpb25Qb2ludChyZWN0YW5nbGUsIHBvaW50T2ZSZWN0YW5nbGUpO1xuICAgICAgICByZXR1cm4gZ2V0RWRnZU9uUG9seWdvbkJ5UG9pbnQoY29ybmVycywgcG9pbnQpO1xuICAgIH0sXG4gICAgZ2V0Q29ybmVyUG9pbnRzKHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50KSB7XG4gICAgICAgIHJldHVybiBnZXRUcmlhbmdsZVBvaW50cyhyZWN0YW5nbGUpO1xuICAgIH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUcmlhbmdsZVBvaW50cyA9IChyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCk6IFBvaW50W10gPT4ge1xuICAgIHJldHVybiBbXG4gICAgICAgIFtyZWN0YW5nbGUueCArIHJlY3RhbmdsZS53aWR0aCAvIDIsIHJlY3RhbmdsZS55XSxcbiAgICAgICAgW3JlY3RhbmdsZS54ICsgcmVjdGFuZ2xlLndpZHRoLCByZWN0YW5nbGUueSArIHJlY3RhbmdsZS5oZWlnaHRdLFxuICAgICAgICBbcmVjdGFuZ2xlLngsIHJlY3RhbmdsZS55ICsgcmVjdGFuZ2xlLmhlaWdodF1cbiAgICBdO1xufTtcbiJdfQ==
@@ -0,0 +1,95 @@
1
+ import { ACTIVE_STROKE_WIDTH, PlaitBoard, RectangleClient, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, createG, distanceBetweenPointAndSegment, drawCircle, idCreator } from '@plait/core';
2
+ import { GeometryShape } from '../interfaces/geometry';
3
+ import { Alignment, buildText } from '@plait/text';
4
+ import { DefaultTextProperty, ShapeDefaultSpace } from '../constants';
5
+ import { getRectangleByPoints } from '@plait/common';
6
+ import { getStrokeWidthByElement } from './style/stroke';
7
+ import { getEngine } from './engine';
8
+ export const createGeometryElement = (shape, points, text, options) => {
9
+ let textOptions = {};
10
+ let alignment = Alignment.center;
11
+ if (shape === GeometryShape.text) {
12
+ textOptions = { autoSize: true };
13
+ alignment = undefined;
14
+ }
15
+ return {
16
+ id: idCreator(),
17
+ type: 'geometry',
18
+ shape,
19
+ angle: 0,
20
+ opacity: 1,
21
+ textHeight: DefaultTextProperty.height,
22
+ text: buildText(text, alignment),
23
+ points,
24
+ ...textOptions,
25
+ ...options
26
+ };
27
+ };
28
+ export const getPointsByCenterPoint = (point, width, height) => {
29
+ const leftTopPoint = [point[0] - width / 2, point[1] - height / 2];
30
+ const rightBottomPoint = [point[0] + width / 2, point[1] + height / 2];
31
+ return [leftTopPoint, rightBottomPoint];
32
+ };
33
+ export const getTextRectangle = (element) => {
34
+ const elementRectangle = getRectangleByPoints(element.points);
35
+ const strokeWidth = getStrokeWidthByElement(element);
36
+ const height = element.textHeight;
37
+ const width = elementRectangle.width - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;
38
+ return {
39
+ height,
40
+ width: width > 0 ? width : 0,
41
+ x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth,
42
+ y: elementRectangle.y + (elementRectangle.height - height) / 2
43
+ };
44
+ };
45
+ export const drawBoundMask = (board, element) => {
46
+ const G = createG();
47
+ const rectangle = getRectangleByPoints(element.points);
48
+ const activeRectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);
49
+ const maskG = drawGeometry(board, activeRectangle, element.shape, {
50
+ stroke: SELECTION_BORDER_COLOR,
51
+ strokeWidth: 1,
52
+ fill: SELECTION_FILL_COLOR,
53
+ fillStyle: 'solid'
54
+ });
55
+ G.appendChild(maskG);
56
+ const connectorPoints = getEngine(element.shape).getConnectorPoints(activeRectangle);
57
+ connectorPoints.forEach(point => {
58
+ const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 6, {
59
+ stroke: '#999999',
60
+ strokeWidth: 1,
61
+ fill: '#FFF',
62
+ fillStyle: 'solid'
63
+ });
64
+ G.appendChild(circleG);
65
+ });
66
+ return G;
67
+ };
68
+ export const drawGeometry = (board, outerRectangle, shape, options) => {
69
+ return getEngine(shape).draw(board, outerRectangle, options);
70
+ };
71
+ export const getNearestPoint = (element, point, inflateDelta = 0) => {
72
+ const rectangle = getRectangleByPoints(element.points);
73
+ const activeRectangle = RectangleClient.inflate(rectangle, inflateDelta);
74
+ return getEngine(element.shape).getNearestPoint(activeRectangle, point);
75
+ };
76
+ export const getCenterPointsOnPolygon = (points) => {
77
+ const centerPoint = [];
78
+ for (let i = 0; i < points.length; i++) {
79
+ let j = i == points.length - 1 ? 0 : i + 1;
80
+ centerPoint.push([(points[i][0] + points[j][0]) / 2, (points[i][1] + points[j][1]) / 2]);
81
+ }
82
+ return centerPoint;
83
+ };
84
+ export const getEdgeOnPolygonByPoint = (corners, point) => {
85
+ for (let index = 1; index <= corners.length; index++) {
86
+ let start = corners[index - 1];
87
+ let end = index === corners.length ? corners[0] : corners[index];
88
+ const distance = distanceBetweenPointAndSegment(point[0], point[1], start[0], start[1], end[0], end[1]);
89
+ if (distance < 1) {
90
+ return [start, end];
91
+ }
92
+ }
93
+ return null;
94
+ };
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/geometry.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,mBAAmB,EACnB,UAAU,EAEV,eAAe,EACf,sBAAsB,EACtB,oBAAoB,EACpB,OAAO,EACP,8BAA8B,EAC9B,UAAU,EACV,SAAS,EACZ,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,aAAa,EAAiB,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEnD,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AAEzD,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AAErC,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACjC,KAAoB,EACpB,MAAsB,EACtB,IAAsB,EACtB,OAAqE,EACxD,EAAE;IACf,IAAI,WAAW,GAAG,EAAE,CAAC;IACrB,IAAI,SAAS,GAA0B,SAAS,CAAC,MAAM,CAAC;IACxD,IAAI,KAAK,KAAK,aAAa,CAAC,IAAI,EAAE;QAC9B,WAAW,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QACjC,SAAS,GAAG,SAAS,CAAC;KACzB;IAED,OAAO;QACH,EAAE,EAAE,SAAS,EAAE;QACf,IAAI,EAAE,UAAU;QAChB,KAAK;QACL,KAAK,EAAE,CAAC;QACR,OAAO,EAAE,CAAC;QACV,UAAU,EAAE,mBAAmB,CAAC,MAAM;QACtC,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC;QAChC,MAAM;QACN,GAAG,WAAW;QACd,GAAG,OAAO;KACb,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,KAAY,EAAE,KAAa,EAAE,MAAc,EAAkB,EAAE;IAClG,MAAM,YAAY,GAAU,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC;IAC1E,MAAM,gBAAgB,GAAU,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC;IAE9E,OAAO,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;AAC5C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,OAAsB,EAAE,EAAE;IACvD,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,OAAO,CAAC,MAAO,CAAC,CAAC;IAC/D,MAAM,WAAW,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;IACrD,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAClC,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,GAAG,iBAAiB,CAAC,gBAAgB,GAAG,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;IAChG,OAAO;QACH,MAAM;QACN,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC,EAAE,gBAAgB,CAAC,CAAC,GAAG,iBAAiB,CAAC,gBAAgB,GAAG,WAAW;QACxE,CAAC,EAAE,gBAAgB,CAAC,CAAC,GAAG,CAAC,gBAAgB,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC;KACjE,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAAiB,EAAE,OAAsB,EAAE,EAAE;IACvE,MAAM,CAAC,GAAG,OAAO,EAAE,CAAC;IACpB,MAAM,SAAS,GAAG,oBAAoB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACvD,MAAM,eAAe,GAAG,eAAe,CAAC,OAAO,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;IAChF,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,EAAE,eAAe,EAAE,OAAO,CAAC,KAAK,EAAE;QAC9D,MAAM,EAAE,sBAAsB;QAC9B,WAAW,EAAE,CAAC;QACd,IAAI,EAAE,oBAAoB;QAC1B,SAAS,EAAE,OAAO;KACrB,CAAC,CAAC;IACH,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAErB,MAAM,eAAe,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IACrF,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QAC5B,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;YAChE,MAAM,EAAE,SAAS;YACjB,WAAW,EAAE,CAAC;YACd,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,OAAO;SACrB,CAAC,CAAC;QACH,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,CAAC;AACb,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAiB,EAAE,cAA+B,EAAE,KAAoB,EAAE,OAAgB,EAAE,EAAE;IACvH,OAAO,SAAS,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;AACjE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAsB,EAAE,KAAY,EAAE,YAAY,GAAG,CAAC,EAAE,EAAE;IACtF,MAAM,SAAS,GAAG,oBAAoB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACvD,MAAM,eAAe,GAAG,eAAe,CAAC,OAAO,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;IACzE,OAAO,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;AAC5E,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,MAAe,EAAE,EAAE;IACxD,MAAM,WAAW,GAAY,EAAE,CAAC;IAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACpC,IAAI,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC3C,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;KAC5F;IACD,OAAO,WAAW,CAAC;AACvB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,OAAgB,EAAE,KAAY,EAAE,EAAE;IACtE,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,IAAI,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;QAClD,IAAI,KAAK,GAAG,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC/B,IAAI,GAAG,GAAG,KAAK,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACjE,MAAM,QAAQ,GAAG,8BAA8B,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACxG,IAAI,QAAQ,GAAG,CAAC,EAAE;YACd,OAAO,CAAC,KAAK,EAAE,GAAG,CAAmB,CAAC;SACzC;KACJ;IACD,OAAO,IAAI,CAAC;AAChB,CAAC,CAAC","sourcesContent":["import {\n    ACTIVE_STROKE_WIDTH,\n    PlaitBoard,\n    Point,\n    RectangleClient,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    createG,\n    distanceBetweenPointAndSegment,\n    drawCircle,\n    idCreator\n} from '@plait/core';\nimport { GeometryShape, PlaitGeometry } from '../interfaces/geometry';\nimport { Alignment, buildText } from '@plait/text';\nimport { Element } from 'slate';\nimport { DefaultTextProperty, ShapeDefaultSpace } from '../constants';\nimport { getRectangleByPoints } from '@plait/common';\nimport { getStrokeWidthByElement } from './style/stroke';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from './engine';\n\nexport const createGeometryElement = (\n    shape: GeometryShape,\n    points: [Point, Point],\n    text: string | Element,\n    options?: Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    if (shape === GeometryShape.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight: DefaultTextProperty.height,\n        text: buildText(text, alignment),\n        points,\n        ...textOptions,\n        ...options\n    };\n};\n\nexport const getPointsByCenterPoint = (point: Point, width: number, height: number): [Point, Point] => {\n    const leftTopPoint: Point = [point[0] - width / 2, point[1] - height / 2];\n    const rightBottomPoint: Point = [point[0] + width / 2, point[1] + height / 2];\n\n    return [leftTopPoint, rightBottomPoint];\n};\n\nexport const getTextRectangle = (element: PlaitGeometry) => {\n    const elementRectangle = getRectangleByPoints(element.points!);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const height = element.textHeight;\n    const width = elementRectangle.width - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;\n    return {\n        height,\n        width: width > 0 ? width : 0,\n        x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth,\n        y: elementRectangle.y + (elementRectangle.height - height) / 2\n    };\n};\n\nexport const drawBoundMask = (board: PlaitBoard, element: PlaitGeometry) => {\n    const G = createG();\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);\n    const maskG = drawGeometry(board, activeRectangle, element.shape, {\n        stroke: SELECTION_BORDER_COLOR,\n        strokeWidth: 1,\n        fill: SELECTION_FILL_COLOR,\n        fillStyle: 'solid'\n    });\n    G.appendChild(maskG);\n\n    const connectorPoints = getEngine(element.shape).getConnectorPoints(activeRectangle);\n    connectorPoints.forEach(point => {\n        const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 6, {\n            stroke: '#999999',\n            strokeWidth: 1,\n            fill: '#FFF',\n            fillStyle: 'solid'\n        });\n        G.appendChild(circleG);\n    });\n\n    return G;\n};\n\nexport const drawGeometry = (board: PlaitBoard, outerRectangle: RectangleClient, shape: GeometryShape, options: Options) => {\n    return getEngine(shape).draw(board, outerRectangle, options);\n};\n\nexport const getNearestPoint = (element: PlaitGeometry, point: Point, inflateDelta = 0) => {\n    const rectangle = getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, inflateDelta);\n    return getEngine(element.shape).getNearestPoint(activeRectangle, point);\n};\n\nexport const getCenterPointsOnPolygon = (points: Point[]) => {\n    const centerPoint: Point[] = [];\n    for (let i = 0; i < points.length; i++) {\n        let j = i == points.length - 1 ? 0 : i + 1;\n        centerPoint.push([(points[i][0] + points[j][0]) / 2, (points[i][1] + points[j][1]) / 2]);\n    }\n    return centerPoint;\n};\n\nexport const getEdgeOnPolygonByPoint = (corners: Point[], point: Point) => {\n    for (let index = 1; index <= corners.length; index++) {\n        let start = corners[index - 1];\n        let end = index === corners.length ? corners[0] : corners[index];\n        const distance = distanceBetweenPointAndSegment(point[0], point[1], start[0], start[1], end[0], end[1]);\n        if (distance < 1) {\n            return [start, end] as [Point, Point];\n        }\n    }\n    return null;\n};\n"]}
@@ -0,0 +1,205 @@
1
+ import { idCreator, distanceBetweenPointAndSegments, createG, getElementById, RectangleClient, findElements, drawLinearPath, createMask, createRect, ACTIVE_STROKE_WIDTH, Direction } from '@plait/core';
2
+ import { getPoints, getRectangleByPoints, getPointOnPolyline, getDirectionFactor, rotateVector90, getDirectionByVector, getDirectionByPointOfRectangle } from '@plait/common';
3
+ import { LineHandleKey, LineMarkerType, LineShape, PlaitDrawElement, PlaitLine } from '../interfaces';
4
+ import { getPointsByCenterPoint, getNearestPoint } from './geometry';
5
+ import { getLineDashByElement, getStrokeColorByElement, getStrokeWidthByElement } from './style/stroke';
6
+ import { getEngine } from './engine';
7
+ import { drawLineArrow } from './line-arrow';
8
+ export const createLineElement = (shape, points, source, target, options) => {
9
+ return {
10
+ id: idCreator(),
11
+ type: 'line',
12
+ shape,
13
+ source,
14
+ texts: [],
15
+ target,
16
+ opacity: 1,
17
+ points,
18
+ ...options
19
+ };
20
+ };
21
+ export const getLinePoints = (board, element) => {
22
+ return element.shape === LineShape.elbow ? getElbowPoints(board, element) : getStraightPoints(board, element);
23
+ };
24
+ export const getStraightPoints = (board, element) => {
25
+ return getLineHandlePoints(board, element);
26
+ };
27
+ export const getLineHandlePoints = (board, element) => {
28
+ const handleRefPair = getLineHandleRefPair(board, element);
29
+ return [handleRefPair.source.point, handleRefPair.target.point];
30
+ };
31
+ export const getLineHandleRefPair = (board, element) => {
32
+ const strokeWidth = getStrokeWidthByElement(element);
33
+ const sourceBoundElement = element.source.boundId ? getElementById(board, element.source.boundId) : undefined;
34
+ const targetBoundElement = element.target.boundId ? getElementById(board, element.target.boundId) : undefined;
35
+ let sourcePoint = sourceBoundElement ? getConnectionPoint(sourceBoundElement, element.source.connection) : element.points[0];
36
+ let targetPoint = targetBoundElement
37
+ ? getConnectionPoint(targetBoundElement, element.target.connection)
38
+ : element.points[element.points.length - 1];
39
+ let sourceDirection = sourcePoint[0] < targetPoint[0] ? Direction.right : Direction.left;
40
+ let targetDirection = sourcePoint[0] < targetPoint[0] ? Direction.left : Direction.right;
41
+ const sourceHandleRef = { key: LineHandleKey.source, point: sourcePoint, direction: sourceDirection };
42
+ const targetHandleRef = { key: LineHandleKey.target, point: targetPoint, direction: targetDirection };
43
+ if (sourceBoundElement) {
44
+ const connectionOffset = PlaitLine.isSourceMarkOrTargetMark(element, LineMarkerType.none, LineHandleKey.source) ? 0 : strokeWidth;
45
+ const direction = getDirectionByBoundElementAndConnection(board, sourceBoundElement, element.source.connection);
46
+ sourceDirection = direction ? direction : sourceDirection;
47
+ sourcePoint = getConnectionPoint(sourceBoundElement, element.source.connection, sourceDirection, connectionOffset);
48
+ sourceHandleRef.boundElement = sourceBoundElement;
49
+ sourceHandleRef.direction = sourceDirection;
50
+ sourceHandleRef.point = sourcePoint;
51
+ }
52
+ if (targetBoundElement) {
53
+ const connectionOffset = PlaitLine.isSourceMarkOrTargetMark(element, LineMarkerType.none, LineHandleKey.target) ? 0 : strokeWidth;
54
+ const direction = getDirectionByBoundElementAndConnection(board, targetBoundElement, element.target.connection);
55
+ targetDirection = direction ? direction : targetDirection;
56
+ targetPoint = getConnectionPoint(targetBoundElement, element.target.connection, targetDirection, connectionOffset);
57
+ targetHandleRef.boundElement = sourceBoundElement;
58
+ targetHandleRef.direction = targetDirection;
59
+ targetHandleRef.point = targetPoint;
60
+ }
61
+ return { source: sourceHandleRef, target: targetHandleRef };
62
+ };
63
+ export const getElbowPoints = (board, element) => {
64
+ if (element.points.length === 2) {
65
+ const handleRefPair = getLineHandleRefPair(board, element);
66
+ const points = getPoints(handleRefPair.source.point, handleRefPair.source.direction, handleRefPair.target.point, handleRefPair.target.direction, 30);
67
+ return points;
68
+ }
69
+ return element.points;
70
+ };
71
+ export const isHitPolyLine = (pathPoints, point, strokeWidth, expand = 0) => {
72
+ const distance = distanceBetweenPointAndSegments(pathPoints, point);
73
+ return distance <= strokeWidth + expand;
74
+ };
75
+ export const getHitLineTextIndex = (board, element, point) => {
76
+ const texts = element.texts;
77
+ if (!texts.length)
78
+ return -1;
79
+ const points = getElbowPoints(board, element);
80
+ return texts.findIndex(text => {
81
+ const center = getPointOnPolyline(points, text.position);
82
+ const rectangle = {
83
+ x: center[0] - text.width / 2,
84
+ y: center[1] - text.height / 2,
85
+ width: text.width,
86
+ height: text.height
87
+ };
88
+ return RectangleClient.isHit(rectangle, RectangleClient.toRectangleClient([point, point]));
89
+ });
90
+ };
91
+ export const isHitLineText = (board, element, point) => {
92
+ return getHitLineTextIndex(board, element, point) !== -1;
93
+ };
94
+ export const drawLine = (board, element) => {
95
+ const strokeWidth = getStrokeWidthByElement(element);
96
+ const strokeColor = getStrokeColorByElement(element);
97
+ const strokeLineDash = getLineDashByElement(element);
98
+ const options = { stroke: strokeColor, strokeWidth, strokeLineDash };
99
+ const lineG = createG();
100
+ const points = getLinePoints(board, element);
101
+ const line = drawLinearPath(points, options);
102
+ const id = idCreator();
103
+ line.setAttribute('mask', `url(#${id})`);
104
+ lineG.appendChild(line);
105
+ const { mask, maskTargetFillRect } = drawMask(board, element, id);
106
+ lineG.appendChild(mask);
107
+ line.appendChild(maskTargetFillRect);
108
+ const arrow = drawLineArrow(element, points, { stroke: strokeColor, strokeWidth });
109
+ arrow && lineG.appendChild(arrow);
110
+ return lineG;
111
+ };
112
+ function drawMask(board, element, id) {
113
+ const mask = createMask();
114
+ mask.setAttribute('id', id);
115
+ const points = getLinePoints(board, element);
116
+ let rectangle = getRectangleByPoints(points);
117
+ rectangle = RectangleClient.getOutlineRectangle(rectangle, -30);
118
+ const maskFillRect = createRect(rectangle, {
119
+ fill: 'white'
120
+ });
121
+ mask.appendChild(maskFillRect);
122
+ const texts = element.texts;
123
+ texts.forEach((text, index) => {
124
+ const textRectangle = getLineTextRectangle(board, element, index);
125
+ const rect = createRect(textRectangle, {
126
+ fill: 'black'
127
+ });
128
+ mask.appendChild(rect);
129
+ });
130
+ //撑开 line
131
+ const maskTargetFillRect = createRect(rectangle);
132
+ maskTargetFillRect.setAttribute('opacity', '0');
133
+ return { mask, maskTargetFillRect };
134
+ }
135
+ export const getDirectionByBoundElementAndConnection = (board, boundElement, connection) => {
136
+ const rectangle = getRectangleByPoints(boundElement.points);
137
+ const engine = getEngine(boundElement.shape);
138
+ const direction = getDirectionByPointOfRectangle(connection);
139
+ if (direction) {
140
+ return direction;
141
+ }
142
+ if (engine.getEdgeByConnectionPoint) {
143
+ const edge = engine.getEdgeByConnectionPoint(rectangle, connection);
144
+ if (edge) {
145
+ const vector = [edge[1][0] - edge[0][0], edge[1][1] - edge[0][1]];
146
+ const vector90 = rotateVector90(vector);
147
+ const direction = getDirectionByVector(vector90);
148
+ return direction;
149
+ }
150
+ }
151
+ if (engine.getTangentVectorByConnectionPoint) {
152
+ const vector = engine.getTangentVectorByConnectionPoint(rectangle, connection);
153
+ if (vector) {
154
+ const vector90 = rotateVector90(vector);
155
+ const direction = getDirectionByVector(vector90);
156
+ return direction;
157
+ }
158
+ }
159
+ return null;
160
+ };
161
+ export const getConnectionPoint = (geometry, connection, direction, delta) => {
162
+ const rectangle = getRectangleByPoints(geometry.points);
163
+ if (direction && delta) {
164
+ const directionFactor = getDirectionFactor(direction);
165
+ const point = RectangleClient.getConnectionPoint(rectangle, connection);
166
+ return [point[0] + directionFactor.x * delta, point[1] + directionFactor.y * delta];
167
+ }
168
+ else {
169
+ return RectangleClient.getConnectionPoint(rectangle, connection);
170
+ }
171
+ };
172
+ export const transformPointToConnection = (board, point, hitElement) => {
173
+ let rectangle = getRectangleByPoints(hitElement.points);
174
+ rectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);
175
+ let nearestPoint = getNearestPoint(hitElement, point, ACTIVE_STROKE_WIDTH);
176
+ const hitConnector = getHitConnectorPoint(nearestPoint, hitElement, rectangle);
177
+ nearestPoint = hitConnector ? hitConnector : nearestPoint;
178
+ return [(nearestPoint[0] - rectangle.x) / rectangle.width, (nearestPoint[1] - rectangle.y) / rectangle.height];
179
+ };
180
+ export const getHitConnectorPoint = (movingPoint, hitElement, rectangle) => {
181
+ const connector = getEngine(hitElement.shape).getConnectorPoints(rectangle);
182
+ const points = getPointsByCenterPoint(movingPoint, 5, 5);
183
+ const pointRectangle = getRectangleByPoints(points);
184
+ return connector.find(point => {
185
+ return RectangleClient.isHit(pointRectangle, RectangleClient.toRectangleClient([point, point]));
186
+ });
187
+ };
188
+ export const getLineTextRectangle = (board, element, index) => {
189
+ const text = element.texts[index];
190
+ const elbowPoints = getLinePoints(board, element);
191
+ const point = getPointOnPolyline(elbowPoints, text.position);
192
+ return {
193
+ x: point[0] - text.width / 2,
194
+ y: point[1] - text.height / 2,
195
+ width: text.width,
196
+ height: text.height
197
+ };
198
+ };
199
+ export const getBoardLines = (board) => {
200
+ return findElements(board, {
201
+ match: (element) => PlaitDrawElement.isLine(element),
202
+ recursion: (element) => PlaitDrawElement.isDrawElement(element)
203
+ });
204
+ };
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/line.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Point,\n    idCreator,\n    distanceBetweenPointAndSegments,\n    PlaitBoard,\n    createG,\n    getElementById,\n    RectangleClient,\n    findElements,\n    PlaitElement,\n    drawLinearPath,\n    createMask,\n    createRect,\n    ACTIVE_STROKE_WIDTH,\n    PointOfRectangle,\n    Direction,\n    Vector\n} from '@plait/core';\nimport {\n    getPoints,\n    getRectangleByPoints,\n    getPointOnPolyline,\n    getDirectionFactor,\n    rotateVector90,\n    getDirectionByVector,\n    getDirectionByPointOfRectangle\n} from '@plait/common';\nimport {\n    LineHandle,\n    LineHandleKey,\n    LineHandleRef,\n    LineMarkerType,\n    LineShape,\n    PlaitDrawElement,\n    PlaitGeometry,\n    PlaitLine\n} from '../interfaces';\nimport { getPointsByCenterPoint, getNearestPoint } from './geometry';\nimport { getLineDashByElement, getStrokeColorByElement, getStrokeWidthByElement } from './style/stroke';\nimport { getEngine } from './engine';\nimport { drawLineArrow } from './line-arrow';\n\nexport const createLineElement = (\n    shape: LineShape,\n    points: [Point, Point],\n    source: LineHandle,\n    target: LineHandle,\n    options?: Pick<PlaitLine, 'strokeColor' | 'strokeWidth'>\n): PlaitLine => {\n    return {\n        id: idCreator(),\n        type: 'line',\n        shape,\n        source,\n        texts: [],\n        target,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const getLinePoints = (board: PlaitBoard, element: PlaitLine) => {\n    return element.shape === LineShape.elbow ? getElbowPoints(board, element) : getStraightPoints(board, element);\n};\n\nexport const getStraightPoints = (board: PlaitBoard, element: PlaitLine) => {\n    return getLineHandlePoints(board, element);\n};\n\nexport const getLineHandlePoints = (board: PlaitBoard, element: PlaitLine) => {\n    const handleRefPair = getLineHandleRefPair(board, element);\n    return [handleRefPair.source.point, handleRefPair.target.point];\n};\n\nexport const getLineHandleRefPair = (board: PlaitBoard, element: PlaitLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const sourceBoundElement = element.source.boundId ? getElementById<PlaitGeometry>(board, element.source.boundId) : undefined;\n    const targetBoundElement = element.target.boundId ? getElementById<PlaitGeometry>(board, element.target.boundId) : undefined;\n    let sourcePoint = sourceBoundElement ? getConnectionPoint(sourceBoundElement, element.source.connection!) : element.points[0];\n    let targetPoint = targetBoundElement\n        ? getConnectionPoint(targetBoundElement, element.target.connection!)\n        : element.points[element.points.length - 1];\n    let sourceDirection = sourcePoint[0] < targetPoint[0] ? Direction.right : Direction.left;\n    let targetDirection = sourcePoint[0] < targetPoint[0] ? Direction.left : Direction.right;\n    const sourceHandleRef: LineHandleRef = { key: LineHandleKey.source, point: sourcePoint, direction: sourceDirection };\n    const targetHandleRef: LineHandleRef = { key: LineHandleKey.target, point: targetPoint, direction: targetDirection };\n    if (sourceBoundElement) {\n        const connectionOffset = PlaitLine.isSourceMarkOrTargetMark(element, LineMarkerType.none, LineHandleKey.source) ? 0 : strokeWidth;\n        const direction = getDirectionByBoundElementAndConnection(board, sourceBoundElement, element.source.connection!);\n        sourceDirection = direction ? direction : sourceDirection;\n        sourcePoint = getConnectionPoint(sourceBoundElement, element.source.connection!, sourceDirection, connectionOffset);\n        sourceHandleRef.boundElement = sourceBoundElement;\n        sourceHandleRef.direction = sourceDirection;\n        sourceHandleRef.point = sourcePoint;\n    }\n    if (targetBoundElement) {\n        const connectionOffset = PlaitLine.isSourceMarkOrTargetMark(element, LineMarkerType.none, LineHandleKey.target) ? 0 : strokeWidth;\n        const direction = getDirectionByBoundElementAndConnection(board, targetBoundElement, element.target.connection!);\n        targetDirection = direction ? direction : targetDirection;\n        targetPoint = getConnectionPoint(targetBoundElement, element.target.connection!, targetDirection, connectionOffset);\n        targetHandleRef.boundElement = sourceBoundElement;\n        targetHandleRef.direction = targetDirection;\n        targetHandleRef.point = targetPoint;\n    }\n    return { source: sourceHandleRef, target: targetHandleRef };\n};\n\nexport const getElbowPoints = (board: PlaitBoard, element: PlaitLine) => {\n    if (element.points.length === 2) {\n        const handleRefPair = getLineHandleRefPair(board, element);\n        const points: Point[] = getPoints(\n            handleRefPair.source.point,\n            handleRefPair.source.direction,\n            handleRefPair.target.point,\n            handleRefPair.target.direction,\n            30\n        );\n        return points;\n    }\n    return element.points;\n};\n\nexport const isHitPolyLine = (pathPoints: Point[], point: Point, strokeWidth: number, expand: number = 0) => {\n    const distance = distanceBetweenPointAndSegments(pathPoints, point);\n    return distance <= strokeWidth + expand;\n};\n\nexport const getHitLineTextIndex = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    const texts = element.texts;\n    if (!texts.length) return -1;\n\n    const points = getElbowPoints(board, element);\n    return texts.findIndex(text => {\n        const center = getPointOnPolyline(points, text.position);\n        const rectangle = {\n            x: center[0] - text.width! / 2,\n            y: center[1] - text.height! / 2,\n            width: text.width!,\n            height: text.height!\n        };\n        return RectangleClient.isHit(rectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const isHitLineText = (board: PlaitBoard, element: PlaitLine, point: Point) => {\n    return getHitLineTextIndex(board, element, point) !== -1;\n};\n\nexport const drawLine = (board: PlaitBoard, element: PlaitLine) => {\n    const strokeWidth = getStrokeWidthByElement(element);\n    const strokeColor = getStrokeColorByElement(element);\n    const strokeLineDash = getLineDashByElement(element);\n    const options = { stroke: strokeColor, strokeWidth, strokeLineDash };\n    const lineG = createG();\n    const points = getLinePoints(board, element);\n    const line = drawLinearPath(points, options);\n    const id = idCreator();\n    line.setAttribute('mask', `url(#${id})`);\n    lineG.appendChild(line);\n    const { mask, maskTargetFillRect } = drawMask(board, element, id);\n    lineG.appendChild(mask);\n    line.appendChild(maskTargetFillRect);\n    const arrow = drawLineArrow(element, points, { stroke: strokeColor, strokeWidth });\n    arrow && lineG.appendChild(arrow);\n    return lineG;\n};\n\nfunction drawMask(board: PlaitBoard, element: PlaitLine, id: string) {\n    const mask = createMask();\n    mask.setAttribute('id', id);\n    const points = getLinePoints(board, element);\n    let rectangle = getRectangleByPoints(points);\n    rectangle = RectangleClient.getOutlineRectangle(rectangle, -30);\n    const maskFillRect = createRect(rectangle, {\n        fill: 'white'\n    });\n    mask.appendChild(maskFillRect);\n\n    const texts = element.texts;\n    texts.forEach((text, index) => {\n        const textRectangle = getLineTextRectangle(board, element, index);\n        const rect = createRect(textRectangle, {\n            fill: 'black'\n        });\n        mask.appendChild(rect);\n    });\n    //撑开 line\n    const maskTargetFillRect = createRect(rectangle);\n    maskTargetFillRect.setAttribute('opacity', '0');\n    return { mask, maskTargetFillRect };\n}\n\nexport const getDirectionByBoundElementAndConnection = (board: PlaitBoard, boundElement: PlaitGeometry, connection: PointOfRectangle) => {\n    const rectangle = getRectangleByPoints(boundElement.points);\n    const engine = getEngine(boundElement.shape);\n    const direction = getDirectionByPointOfRectangle(connection);\n    if (direction) {\n        return direction;\n    }\n    if (engine.getEdgeByConnectionPoint) {\n        const edge = engine.getEdgeByConnectionPoint(rectangle, connection);\n        if (edge) {\n            const vector = [edge[1][0] - edge[0][0], edge[1][1] - edge[0][1]] as Vector;\n            const vector90 = rotateVector90(vector);\n            const direction = getDirectionByVector(vector90);\n            return direction;\n        }\n    }\n    if (engine.getTangentVectorByConnectionPoint) {\n        const vector = engine.getTangentVectorByConnectionPoint(rectangle, connection);\n        if (vector) {\n            const vector90 = rotateVector90(vector);\n            const direction = getDirectionByVector(vector90);\n            return direction;\n        }\n    }\n    return null;\n};\n\nexport const getConnectionPoint = (geometry: PlaitGeometry, connection: Point, direction?: Direction, delta?: number): Point => {\n    const rectangle = getRectangleByPoints(geometry.points);\n    if (direction && delta) {\n        const directionFactor = getDirectionFactor(direction);\n        const point = RectangleClient.getConnectionPoint(rectangle, connection);\n        return [point[0] + directionFactor.x * delta, point[1] + directionFactor.y * delta];\n    } else {\n        return RectangleClient.getConnectionPoint(rectangle, connection);\n    }\n};\n\nexport const transformPointToConnection = (board: PlaitBoard, point: Point, hitElement: PlaitGeometry): Point => {\n    let rectangle = getRectangleByPoints(hitElement.points);\n    rectangle = RectangleClient.inflate(rectangle, ACTIVE_STROKE_WIDTH);\n    let nearestPoint = getNearestPoint(hitElement, point, ACTIVE_STROKE_WIDTH);\n    const hitConnector = getHitConnectorPoint(nearestPoint, hitElement, rectangle);\n    nearestPoint = hitConnector ? hitConnector : nearestPoint;\n    return [(nearestPoint[0] - rectangle.x) / rectangle.width, (nearestPoint[1] - rectangle.y) / rectangle.height];\n};\n\nexport const getHitConnectorPoint = (movingPoint: Point, hitElement: PlaitGeometry, rectangle: RectangleClient) => {\n    const connector = getEngine(hitElement.shape).getConnectorPoints(rectangle);\n    const points = getPointsByCenterPoint(movingPoint, 5, 5);\n    const pointRectangle = getRectangleByPoints(points);\n    return connector.find(point => {\n        return RectangleClient.isHit(pointRectangle, RectangleClient.toRectangleClient([point, point]));\n    });\n};\n\nexport const getLineTextRectangle = (board: PlaitBoard, element: PlaitLine, index: number): RectangleClient => {\n    const text = element.texts[index];\n    const elbowPoints = getLinePoints(board, element);\n    const point = getPointOnPolyline(elbowPoints, text.position);\n    return {\n        x: point[0] - text.width! / 2,\n        y: point[1] - text.height! / 2,\n        width: text.width!,\n        height: text.height!\n    };\n};\n\nexport const getBoardLines = (board: PlaitBoard) => {\n    return findElements(board, {\n        match: (element: PlaitElement) => PlaitDrawElement.isLine(element),\n        recursion: (element: PlaitElement) => PlaitDrawElement.isDrawElement(element)\n    }) as PlaitLine[];\n};\n"]}
@@ -0,0 +1,33 @@
1
+ import { RectangleClient } from '@plait/core';
2
+ import { RESIZE_HANDLE_DIAMETER } from '@plait/common';
3
+ import { getLineHandlePoints } from '../line';
4
+ export var LineResizeHandle;
5
+ (function (LineResizeHandle) {
6
+ LineResizeHandle["source"] = "source";
7
+ LineResizeHandle["target"] = "target";
8
+ })(LineResizeHandle || (LineResizeHandle = {}));
9
+ export const getHitLineResizeHandleRef = (board, element, point) => {
10
+ const [sourcePoint, targetPoint] = getLineHandlePoints(board, element);
11
+ const sourceRectangle = {
12
+ x: sourcePoint[0] - RESIZE_HANDLE_DIAMETER / 2,
13
+ y: sourcePoint[1] - RESIZE_HANDLE_DIAMETER / 2,
14
+ width: RESIZE_HANDLE_DIAMETER,
15
+ height: RESIZE_HANDLE_DIAMETER
16
+ };
17
+ const targetRectangle = {
18
+ x: targetPoint[0] - RESIZE_HANDLE_DIAMETER / 2,
19
+ y: targetPoint[1] - RESIZE_HANDLE_DIAMETER / 2,
20
+ width: RESIZE_HANDLE_DIAMETER,
21
+ height: RESIZE_HANDLE_DIAMETER
22
+ };
23
+ const isHitSourceRectangle = RectangleClient.isHit(RectangleClient.toRectangleClient([point, point]), sourceRectangle);
24
+ const isHitTargetRectangle = RectangleClient.isHit(RectangleClient.toRectangleClient([point, point]), targetRectangle);
25
+ if (isHitSourceRectangle) {
26
+ return { rectangle: sourceRectangle, handle: LineResizeHandle.source };
27
+ }
28
+ if (isHitTargetRectangle) {
29
+ return { rectangle: targetRectangle, handle: LineResizeHandle.target };
30
+ }
31
+ return undefined;
32
+ };
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3V0aWxzL3Bvc2l0aW9uL2xpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFakUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUU5QyxNQUFNLENBQU4sSUFBWSxnQkFHWDtBQUhELFdBQVksZ0JBQWdCO0lBQ3hCLHFDQUFtQixDQUFBO0lBQ25CLHFDQUFtQixDQUFBO0FBQ3ZCLENBQUMsRUFIVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBRzNCO0FBRUQsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLE9BQWtCLEVBQUUsS0FBWSxFQUFFLEVBQUU7SUFDN0YsTUFBTSxDQUFDLFdBQVcsRUFBRSxXQUFXLENBQUMsR0FBRyxtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdkUsTUFBTSxlQUFlLEdBQW9CO1FBQ3JDLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsc0JBQXNCLEdBQUcsQ0FBQztRQUM5QyxDQUFDLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxHQUFHLHNCQUFzQixHQUFHLENBQUM7UUFDOUMsS0FBSyxFQUFFLHNCQUFzQjtRQUM3QixNQUFNLEVBQUUsc0JBQXNCO0tBQ2pDLENBQUM7SUFDRixNQUFNLGVBQWUsR0FBb0I7UUFDckMsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsR0FBRyxzQkFBc0IsR0FBRyxDQUFDO1FBQzlDLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsc0JBQXNCLEdBQUcsQ0FBQztRQUM5QyxLQUFLLEVBQUUsc0JBQXNCO1FBQzdCLE1BQU0sRUFBRSxzQkFBc0I7S0FDakMsQ0FBQztJQUNGLE1BQU0sb0JBQW9CLEdBQUcsZUFBZSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUN2SCxNQUFNLG9CQUFvQixHQUFHLGVBQWUsQ0FBQyxLQUFLLENBQUMsZUFBZSxDQUFDLGlCQUFpQixDQUFDLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDdkgsSUFBSSxvQkFBb0IsRUFBRTtRQUN0QixPQUFPLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLENBQUM7S0FDMUU7SUFDRCxJQUFJLG9CQUFvQixFQUFFO1FBQ3RCLE9BQU8sRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQztLQUMxRTtJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ3JCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0Qm9hcmQsIFBvaW50LCBSZWN0YW5nbGVDbGllbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBQbGFpdExpbmUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFJFU0laRV9IQU5ETEVfRElBTUVURVIgfSBmcm9tICdAcGxhaXQvY29tbW9uJztcbmltcG9ydCB7IGdldExpbmVIYW5kbGVQb2ludHMgfSBmcm9tICcuLi9saW5lJztcblxuZXhwb3J0IGVudW0gTGluZVJlc2l6ZUhhbmRsZSB7XG4gICAgJ3NvdXJjZScgPSAnc291cmNlJyxcbiAgICAndGFyZ2V0JyA9ICd0YXJnZXQnXG59XG5cbmV4cG9ydCBjb25zdCBnZXRIaXRMaW5lUmVzaXplSGFuZGxlUmVmID0gKGJvYXJkOiBQbGFpdEJvYXJkLCBlbGVtZW50OiBQbGFpdExpbmUsIHBvaW50OiBQb2ludCkgPT4ge1xuICAgIGNvbnN0IFtzb3VyY2VQb2ludCwgdGFyZ2V0UG9pbnRdID0gZ2V0TGluZUhhbmRsZVBvaW50cyhib2FyZCwgZWxlbWVudCk7XG4gICAgY29uc3Qgc291cmNlUmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQgPSB7XG4gICAgICAgIHg6IHNvdXJjZVBvaW50WzBdIC0gUkVTSVpFX0hBTkRMRV9ESUFNRVRFUiAvIDIsXG4gICAgICAgIHk6IHNvdXJjZVBvaW50WzFdIC0gUkVTSVpFX0hBTkRMRV9ESUFNRVRFUiAvIDIsXG4gICAgICAgIHdpZHRoOiBSRVNJWkVfSEFORExFX0RJQU1FVEVSLFxuICAgICAgICBoZWlnaHQ6IFJFU0laRV9IQU5ETEVfRElBTUVURVJcbiAgICB9O1xuICAgIGNvbnN0IHRhcmdldFJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50ID0ge1xuICAgICAgICB4OiB0YXJnZXRQb2ludFswXSAtIFJFU0laRV9IQU5ETEVfRElBTUVURVIgLyAyLFxuICAgICAgICB5OiB0YXJnZXRQb2ludFsxXSAtIFJFU0laRV9IQU5ETEVfRElBTUVURVIgLyAyLFxuICAgICAgICB3aWR0aDogUkVTSVpFX0hBTkRMRV9ESUFNRVRFUixcbiAgICAgICAgaGVpZ2h0OiBSRVNJWkVfSEFORExFX0RJQU1FVEVSXG4gICAgfTtcbiAgICBjb25zdCBpc0hpdFNvdXJjZVJlY3RhbmdsZSA9IFJlY3RhbmdsZUNsaWVudC5pc0hpdChSZWN0YW5nbGVDbGllbnQudG9SZWN0YW5nbGVDbGllbnQoW3BvaW50LCBwb2ludF0pLCBzb3VyY2VSZWN0YW5nbGUpO1xuICAgIGNvbnN0IGlzSGl0VGFyZ2V0UmVjdGFuZ2xlID0gUmVjdGFuZ2xlQ2xpZW50LmlzSGl0KFJlY3RhbmdsZUNsaWVudC50b1JlY3RhbmdsZUNsaWVudChbcG9pbnQsIHBvaW50XSksIHRhcmdldFJlY3RhbmdsZSk7XG4gICAgaWYgKGlzSGl0U291cmNlUmVjdGFuZ2xlKSB7XG4gICAgICAgIHJldHVybiB7IHJlY3RhbmdsZTogc291cmNlUmVjdGFuZ2xlLCBoYW5kbGU6IExpbmVSZXNpemVIYW5kbGUuc291cmNlIH07XG4gICAgfVxuICAgIGlmIChpc0hpdFRhcmdldFJlY3RhbmdsZSkge1xuICAgICAgICByZXR1cm4geyByZWN0YW5nbGU6IHRhcmdldFJlY3RhbmdsZSwgaGFuZGxlOiBMaW5lUmVzaXplSGFuZGxlLnRhcmdldCB9O1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xufTtcbiJdfQ==