@plait/draw 0.62.0-next.6 → 0.62.0-next.7

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 (137) hide show
  1. package/arrow-line.component.d.ts +26 -0
  2. package/constants/pointer.d.ts +3 -3
  3. package/esm2022/arrow-line.component.mjs +157 -0
  4. package/esm2022/constants/geometry.mjs +3 -3
  5. package/esm2022/constants/pointer.mjs +4 -4
  6. package/esm2022/engines/flowchart/note-curly-left.mjs +2 -2
  7. package/esm2022/engines/flowchart/note-curly-right.mjs +7 -7
  8. package/esm2022/engines/flowchart/note-square.mjs +2 -2
  9. package/esm2022/engines/uml/required-interface.mjs +3 -2
  10. package/esm2022/generators/arrow-line-active.generator.mjs +81 -0
  11. package/esm2022/generators/arrow-line-auto-complete.generator.mjs +46 -0
  12. package/esm2022/generators/arrow-line.generator.mjs +13 -0
  13. package/esm2022/generators/index.mjs +3 -3
  14. package/esm2022/geometry.component.mjs +4 -4
  15. package/esm2022/image.component.mjs +4 -4
  16. package/esm2022/interfaces/arrow-line.mjs +70 -0
  17. package/esm2022/interfaces/element.mjs +2 -2
  18. package/esm2022/interfaces/index.mjs +14 -7
  19. package/esm2022/interfaces/vector-line.mjs +6 -0
  20. package/esm2022/plugins/with-arrow-line-auto-complete-reaction.mjs +41 -0
  21. package/esm2022/plugins/with-arrow-line-auto-complete.mjs +74 -0
  22. package/esm2022/plugins/with-arrow-line-bound-reaction.mjs +53 -0
  23. package/esm2022/plugins/with-arrow-line-create.mjs +53 -0
  24. package/esm2022/plugins/with-arrow-line-resize.mjs +158 -0
  25. package/esm2022/plugins/with-arrow-line-text-move.mjs +53 -0
  26. package/esm2022/plugins/with-arrow-line-text.mjs +63 -0
  27. package/esm2022/plugins/with-draw-fragment.mjs +13 -13
  28. package/esm2022/plugins/with-draw-resize.mjs +12 -5
  29. package/esm2022/plugins/with-draw.mjs +27 -20
  30. package/esm2022/plugins/with-geometry-resize.mjs +1 -1
  31. package/esm2022/plugins/with-swimlane.mjs +1 -20
  32. package/esm2022/plugins/with-table.mjs +21 -3
  33. package/esm2022/public-api.mjs +3 -3
  34. package/esm2022/table.component.mjs +6 -6
  35. package/esm2022/transforms/arrow-line.mjs +100 -0
  36. package/esm2022/transforms/geometry.mjs +4 -4
  37. package/esm2022/transforms/index.mjs +12 -11
  38. package/esm2022/transforms/swimlane.mjs +1 -29
  39. package/esm2022/transforms/table-text.mjs +5 -5
  40. package/esm2022/transforms/table.mjs +30 -0
  41. package/esm2022/utils/arrow-line/arrow-line-arrow.mjs +123 -0
  42. package/esm2022/utils/arrow-line/arrow-line-basic.mjs +257 -0
  43. package/esm2022/utils/arrow-line/arrow-line-common.mjs +127 -0
  44. package/esm2022/utils/arrow-line/arrow-line-resize.mjs +309 -0
  45. package/esm2022/utils/arrow-line/elbow.mjs +114 -0
  46. package/esm2022/utils/arrow-line/index.mjs +6 -0
  47. package/esm2022/utils/clipboard.mjs +10 -10
  48. package/esm2022/utils/common.mjs +3 -3
  49. package/esm2022/utils/geometry.mjs +13 -13
  50. package/esm2022/utils/hit.mjs +67 -44
  51. package/esm2022/utils/index.mjs +2 -2
  52. package/esm2022/utils/memorize.mjs +4 -5
  53. package/esm2022/utils/position/arrow-line.mjs +67 -0
  54. package/esm2022/utils/position/geometry.mjs +1 -1
  55. package/esm2022/utils/selected.mjs +3 -3
  56. package/esm2022/utils/swimlane.mjs +11 -5
  57. package/esm2022/utils/table-selected.mjs +3 -4
  58. package/esm2022/utils/table.mjs +16 -1
  59. package/fesm2022/plait-draw.mjs +448 -372
  60. package/fesm2022/plait-draw.mjs.map +1 -1
  61. package/generators/arrow-line-active.generator.d.ts +13 -0
  62. package/generators/{line-auto-complete.generator.d.ts → arrow-line-auto-complete.generator.d.ts} +1 -1
  63. package/generators/arrow-line.generator.d.ts +8 -0
  64. package/generators/index.d.ts +2 -2
  65. package/geometry.component.d.ts +2 -2
  66. package/image.component.d.ts +2 -2
  67. package/interfaces/arrow-line.d.ts +75 -0
  68. package/interfaces/element.d.ts +1 -1
  69. package/interfaces/index.d.ts +6 -4
  70. package/interfaces/vector-line.d.ts +16 -0
  71. package/package.json +1 -1
  72. package/plugins/with-arrow-line-auto-complete-reaction.d.ts +2 -0
  73. package/plugins/with-arrow-line-auto-complete.d.ts +7 -0
  74. package/plugins/with-arrow-line-bound-reaction.d.ts +2 -0
  75. package/plugins/with-arrow-line-create.d.ts +2 -0
  76. package/plugins/with-arrow-line-resize.d.ts +2 -0
  77. package/plugins/with-arrow-line-text-move.d.ts +2 -0
  78. package/plugins/with-arrow-line-text.d.ts +2 -0
  79. package/plugins/with-draw-fragment.d.ts +2 -2
  80. package/plugins/with-swimlane.d.ts +1 -2
  81. package/public-api.d.ts +2 -2
  82. package/table.component.d.ts +2 -2
  83. package/transforms/arrow-line.d.ts +12 -0
  84. package/transforms/index.d.ts +8 -8
  85. package/transforms/swimlane.d.ts +1 -3
  86. package/transforms/table-text.d.ts +2 -3
  87. package/transforms/table.d.ts +3 -0
  88. package/utils/arrow-line/arrow-line-arrow.d.ts +4 -0
  89. package/utils/arrow-line/arrow-line-basic.d.ts +13 -0
  90. package/utils/{line/line-common.d.ts → arrow-line/arrow-line-common.d.ts} +3 -3
  91. package/utils/{line/line-resize.d.ts → arrow-line/arrow-line-resize.d.ts} +3 -3
  92. package/utils/{line → arrow-line}/elbow.d.ts +7 -7
  93. package/utils/arrow-line/index.d.ts +5 -0
  94. package/utils/clipboard.d.ts +4 -4
  95. package/utils/geometry.d.ts +17 -17
  96. package/utils/hit.d.ts +7 -4
  97. package/utils/index.d.ts +1 -1
  98. package/utils/position/arrow-line.d.ts +16 -0
  99. package/utils/selected.d.ts +2 -2
  100. package/utils/swimlane.d.ts +1 -1
  101. package/utils/table.d.ts +2 -0
  102. package/esm2022/generators/line-active.generator.mjs +0 -81
  103. package/esm2022/generators/line-auto-complete.generator.mjs +0 -46
  104. package/esm2022/generators/line.generator.mjs +0 -13
  105. package/esm2022/interfaces/line.mjs +0 -70
  106. package/esm2022/line.component.mjs +0 -155
  107. package/esm2022/plugins/with-line-auto-complete-reaction.mjs +0 -41
  108. package/esm2022/plugins/with-line-auto-complete.mjs +0 -75
  109. package/esm2022/plugins/with-line-bound-reaction.mjs +0 -53
  110. package/esm2022/plugins/with-line-create.mjs +0 -53
  111. package/esm2022/plugins/with-line-resize.mjs +0 -158
  112. package/esm2022/plugins/with-line-text-move.mjs +0 -53
  113. package/esm2022/plugins/with-line-text.mjs +0 -62
  114. package/esm2022/transforms/line.mjs +0 -100
  115. package/esm2022/utils/line/elbow.mjs +0 -114
  116. package/esm2022/utils/line/index.mjs +0 -6
  117. package/esm2022/utils/line/line-arrow.mjs +0 -123
  118. package/esm2022/utils/line/line-basic.mjs +0 -257
  119. package/esm2022/utils/line/line-common.mjs +0 -123
  120. package/esm2022/utils/line/line-resize.mjs +0 -309
  121. package/esm2022/utils/position/line.mjs +0 -67
  122. package/generators/line-active.generator.d.ts +0 -13
  123. package/generators/line.generator.d.ts +0 -8
  124. package/interfaces/line.d.ts +0 -75
  125. package/line.component.d.ts +0 -26
  126. package/plugins/with-line-auto-complete-reaction.d.ts +0 -2
  127. package/plugins/with-line-auto-complete.d.ts +0 -7
  128. package/plugins/with-line-bound-reaction.d.ts +0 -2
  129. package/plugins/with-line-create.d.ts +0 -2
  130. package/plugins/with-line-resize.d.ts +0 -2
  131. package/plugins/with-line-text-move.d.ts +0 -2
  132. package/plugins/with-line-text.d.ts +0 -2
  133. package/transforms/line.d.ts +0 -12
  134. package/utils/line/index.d.ts +0 -5
  135. package/utils/line/line-arrow.d.ts +0 -4
  136. package/utils/line/line-basic.d.ts +0 -13
  137. package/utils/position/line.d.ts +0 -16
@@ -0,0 +1,81 @@
1
+ import { PlaitBoard, createG, drawRectangle, getSelectedElements } from '@plait/core';
2
+ import { ArrowLineShape, PlaitArrowLine } from '../interfaces';
3
+ import { Generator, PRIMARY_COLOR, drawFillPrimaryHandle, drawPrimaryHandle } from '@plait/common';
4
+ import { getMiddlePoints } from '../utils/arrow-line/arrow-line-basic';
5
+ import { getNextRenderPoints } from '../utils/arrow-line/elbow';
6
+ import { isUpdatedHandleIndex } from '../utils/arrow-line';
7
+ import { getHitPointIndex } from '../utils/position/arrow-line';
8
+ import { DefaultDrawActiveStyle } from '../constants';
9
+ export class ArrowLineActiveGenerator extends Generator {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.onlySelectedCurrentLine = false;
13
+ }
14
+ canDraw(element, data) {
15
+ if (data.selected) {
16
+ return true;
17
+ }
18
+ else {
19
+ return false;
20
+ }
21
+ }
22
+ draw(element, data) {
23
+ const activeG = createG();
24
+ const selectedElements = getSelectedElements(this.board);
25
+ this.onlySelectedCurrentLine = selectedElements.length === 1;
26
+ if (this.onlySelectedCurrentLine) {
27
+ activeG.classList.add('active');
28
+ activeG.classList.add('line-handle');
29
+ const points = PlaitArrowLine.getPoints(this.board, element);
30
+ let updatePoints = [...points];
31
+ let elbowNextRenderPoints = [];
32
+ if (element.shape === ArrowLineShape.elbow) {
33
+ updatePoints = points.slice(0, 1).concat(points.slice(-1));
34
+ elbowNextRenderPoints = getNextRenderPoints(this.board, element, data.linePoints);
35
+ }
36
+ updatePoints.forEach(point => {
37
+ const updateHandle = drawPrimaryHandle(this.board, point);
38
+ activeG.appendChild(updateHandle);
39
+ });
40
+ const middlePoints = getMiddlePoints(this.board, element);
41
+ if (!PlaitBoard.hasBeenTextEditing(this.board)) {
42
+ for (let i = 0; i < middlePoints.length; i++) {
43
+ const point = middlePoints[i];
44
+ if (element.shape === ArrowLineShape.elbow && elbowNextRenderPoints.length) {
45
+ const handleIndex = getHitPointIndex(middlePoints, point);
46
+ const isUpdateHandleIndex = isUpdatedHandleIndex(this.board, element, [...points], elbowNextRenderPoints, handleIndex);
47
+ if (isUpdateHandleIndex) {
48
+ const updateHandle = drawPrimaryHandle(this.board, point);
49
+ activeG.appendChild(updateHandle);
50
+ continue;
51
+ }
52
+ }
53
+ const circle = drawFillPrimaryHandle(this.board, point);
54
+ activeG.appendChild(circle);
55
+ }
56
+ }
57
+ }
58
+ else {
59
+ const activeRectangle = this.board.getRectangle(element);
60
+ if (activeRectangle) {
61
+ let opacity = '0.5';
62
+ if (activeRectangle.height === 0 || activeRectangle.width === 0) {
63
+ opacity = '0.8';
64
+ }
65
+ const strokeG = drawRectangle(this.board, activeRectangle, {
66
+ stroke: PRIMARY_COLOR,
67
+ strokeWidth: DefaultDrawActiveStyle.selectionStrokeWidth
68
+ });
69
+ strokeG.style.opacity = opacity;
70
+ activeG.appendChild(strokeG);
71
+ }
72
+ }
73
+ return activeG;
74
+ }
75
+ needUpdate() {
76
+ const selectedElements = getSelectedElements(this.board);
77
+ const onlySelectedCurrentLine = selectedElements.length === 1;
78
+ return onlySelectedCurrentLine !== this.onlySelectedCurrentLine;
79
+ }
80
+ }
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arrow-line-active.generator.js","sourceRoot":"","sources":["../../../../packages/draw/src/generators/arrow-line-active.generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, createG, drawRectangle, getSelectedElements } from '@plait/core';\nimport { ArrowLineShape, PlaitArrowLine } from '../interfaces';\nimport { Generator, PRIMARY_COLOR, drawFillPrimaryHandle, drawPrimaryHandle } from '@plait/common';\nimport { getMiddlePoints } from '../utils/arrow-line/arrow-line-basic';\nimport { getNextRenderPoints } from '../utils/arrow-line/elbow';\nimport { isUpdatedHandleIndex } from '../utils/arrow-line';\nimport { getHitPointIndex } from '../utils/position/arrow-line';\nimport { DefaultDrawActiveStyle } from '../constants';\n\nexport interface ActiveData {\n    selected: boolean;\n    linePoints: Point[];\n}\n\nexport class ArrowLineActiveGenerator extends Generator<PlaitArrowLine, ActiveData> {\n    onlySelectedCurrentLine = false;\n\n    canDraw(element: PlaitArrowLine, data: ActiveData): boolean {\n        if (data.selected) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    draw(element: PlaitArrowLine, data: ActiveData): SVGGElement {\n        const activeG = createG();\n        const selectedElements = getSelectedElements(this.board);\n        this.onlySelectedCurrentLine = selectedElements.length === 1;\n        if (this.onlySelectedCurrentLine) {\n            activeG.classList.add('active');\n            activeG.classList.add('line-handle');\n            const points = PlaitArrowLine.getPoints(this.board, element);\n            let updatePoints = [...points];\n            let elbowNextRenderPoints: Point[] = [];\n            if (element.shape === ArrowLineShape.elbow) {\n                updatePoints = points.slice(0, 1).concat(points.slice(-1));\n                elbowNextRenderPoints = getNextRenderPoints(this.board, element, data.linePoints);\n            }\n            updatePoints.forEach(point => {\n                const updateHandle = drawPrimaryHandle(this.board, point);\n                activeG.appendChild(updateHandle);\n            });\n            const middlePoints = getMiddlePoints(this.board, element);\n            if (!PlaitBoard.hasBeenTextEditing(this.board)) {\n                for (let i = 0; i < middlePoints.length; i++) {\n                    const point = middlePoints[i];\n                    if (element.shape === ArrowLineShape.elbow && elbowNextRenderPoints.length) {\n                        const handleIndex = getHitPointIndex(middlePoints, point);\n                        const isUpdateHandleIndex = isUpdatedHandleIndex(\n                            this.board,\n                            element,\n                            [...points],\n                            elbowNextRenderPoints,\n                            handleIndex\n                        );\n                        if (isUpdateHandleIndex) {\n                            const updateHandle = drawPrimaryHandle(this.board, point);\n                            activeG.appendChild(updateHandle);\n                            continue;\n                        }\n                    }\n                    const circle = drawFillPrimaryHandle(this.board, point);\n                    activeG.appendChild(circle);\n                }\n            }\n        } else {\n            const activeRectangle = this.board.getRectangle(element);\n            if (activeRectangle) {\n                let opacity = '0.5';\n                if (activeRectangle.height === 0 || activeRectangle.width === 0) {\n                    opacity = '0.8';\n                }\n                const strokeG = drawRectangle(this.board, activeRectangle, {\n                    stroke: PRIMARY_COLOR,\n                    strokeWidth: DefaultDrawActiveStyle.selectionStrokeWidth\n                });\n                strokeG.style.opacity = opacity;\n                activeG.appendChild(strokeG);\n            }\n        }\n        return activeG;\n    }\n\n    needUpdate() {\n        const selectedElements = getSelectedElements(this.board);\n        const onlySelectedCurrentLine = selectedElements.length === 1;\n        return onlySelectedCurrentLine !== this.onlySelectedCurrentLine;\n    }\n}\n"]}
@@ -0,0 +1,46 @@
1
+ import { PlaitBoard, RgbaToHEX, createG, drawCircle, getSelectedElements, isSelectionMoving } from '@plait/core';
2
+ import { Generator, PRIMARY_COLOR } from '@plait/common';
3
+ import { getAutoCompletePoints } from '../utils';
4
+ import { LINE_AUTO_COMPLETE_DIAMETER, LINE_AUTO_COMPLETE_OPACITY } from '../constants/line';
5
+ export class ArrowLineAutoCompleteGenerator extends Generator {
6
+ static { this.key = 'line-auto-complete-generator'; }
7
+ constructor(board) {
8
+ super(board);
9
+ this.board = board;
10
+ this.hoverElement = null;
11
+ }
12
+ canDraw(element, data) {
13
+ const selectedElements = getSelectedElements(this.board);
14
+ if (data.selected && selectedElements.length === 1 && !isSelectionMoving(this.board)) {
15
+ return true;
16
+ }
17
+ else {
18
+ return false;
19
+ }
20
+ }
21
+ draw(element, data) {
22
+ this.autoCompleteG = createG();
23
+ const middlePoints = getAutoCompletePoints(element);
24
+ middlePoints.forEach((point, index) => {
25
+ const circle = drawCircle(PlaitBoard.getRoughSVG(this.board), point, LINE_AUTO_COMPLETE_DIAMETER, {
26
+ stroke: 'none',
27
+ fill: RgbaToHEX(PRIMARY_COLOR, LINE_AUTO_COMPLETE_OPACITY),
28
+ fillStyle: 'solid'
29
+ });
30
+ circle.classList.add(`line-auto-complete-${index}`);
31
+ this.autoCompleteG.appendChild(circle);
32
+ });
33
+ return this.autoCompleteG;
34
+ }
35
+ removeAutoCompleteG(index) {
36
+ this.hoverElement = this.autoCompleteG.querySelector(`.line-auto-complete-${index}`);
37
+ this.hoverElement.style.visibility = 'hidden';
38
+ }
39
+ recoverAutoCompleteG() {
40
+ if (this.hoverElement) {
41
+ this.hoverElement.style.visibility = 'visible';
42
+ this.hoverElement = null;
43
+ }
44
+ }
45
+ }
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3ctbGluZS1hdXRvLWNvbXBsZXRlLmdlbmVyYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL2dlbmVyYXRvcnMvYXJyb3ctbGluZS1hdXRvLWNvbXBsZXRlLmdlbmVyYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRWpILE9BQU8sRUFBNEIsU0FBUyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDakQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLDBCQUEwQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFNUYsTUFBTSxPQUFPLDhCQUE0RSxTQUFRLFNBQXNDO2FBQzVILFFBQUcsR0FBRyw4QkFBOEIsQUFBakMsQ0FBa0M7SUFLNUMsWUFBbUIsS0FBaUI7UUFDaEMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBREUsVUFBSyxHQUFMLEtBQUssQ0FBWTtRQUZwQyxpQkFBWSxHQUF1QixJQUFJLENBQUM7SUFJeEMsQ0FBQztJQUVELE9BQU8sQ0FBQyxPQUEwQixFQUFFLElBQThCO1FBQzlELE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3pELElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDbkYsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQzthQUFNLENBQUM7WUFDSixPQUFPLEtBQUssQ0FBQztRQUNqQixDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksQ0FBQyxPQUFVLEVBQUUsSUFBOEI7UUFDM0MsSUFBSSxDQUFDLGFBQWEsR0FBRyxPQUFPLEVBQUUsQ0FBQztRQUMvQixNQUFNLFlBQVksR0FBRyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRCxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQ2xDLE1BQU0sTUFBTSxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLEVBQUUsMkJBQTJCLEVBQUU7Z0JBQzlGLE1BQU0sRUFBRSxNQUFNO2dCQUNkLElBQUksRUFBRSxTQUFTLENBQUMsYUFBYSxFQUFFLDBCQUEwQixDQUFDO2dCQUMxRCxTQUFTLEVBQUUsT0FBTzthQUNyQixDQUFDLENBQUM7WUFDSCxNQUFNLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxzQkFBc0IsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNwRCxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMzQyxDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM5QixDQUFDO0lBRUQsbUJBQW1CLENBQUMsS0FBYTtRQUM3QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLHVCQUF1QixLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ3JGLElBQUksQ0FBQyxZQUFhLENBQUMsS0FBSyxDQUFDLFVBQVUsR0FBRyxRQUFRLENBQUM7SUFDbkQsQ0FBQztJQUVELG9CQUFvQjtRQUNoQixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO1lBQy9DLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDO1FBQzdCLENBQUM7SUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUmdiYVRvSEVYLCBjcmVhdGVHLCBkcmF3Q2lyY2xlLCBnZXRTZWxlY3RlZEVsZW1lbnRzLCBpc1NlbGVjdGlvbk1vdmluZyB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFBsYWl0R2VvbWV0cnksIFBsYWl0U2hhcGVFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBBY3RpdmVHZW5lcmF0b3JFeHRyYURhdGEsIEdlbmVyYXRvciwgUFJJTUFSWV9DT0xPUiB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZ2V0QXV0b0NvbXBsZXRlUG9pbnRzIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgTElORV9BVVRPX0NPTVBMRVRFX0RJQU1FVEVSLCBMSU5FX0FVVE9fQ09NUExFVEVfT1BBQ0lUWSB9IGZyb20gJy4uL2NvbnN0YW50cy9saW5lJztcblxuZXhwb3J0IGNsYXNzIEFycm93TGluZUF1dG9Db21wbGV0ZUdlbmVyYXRvcjxUIGV4dGVuZHMgUGxhaXRTaGFwZUVsZW1lbnQgPSBQbGFpdEdlb21ldHJ5PiBleHRlbmRzIEdlbmVyYXRvcjxULCBBY3RpdmVHZW5lcmF0b3JFeHRyYURhdGE+IHtcbiAgICBzdGF0aWMga2V5ID0gJ2xpbmUtYXV0by1jb21wbGV0ZS1nZW5lcmF0b3InO1xuXG4gICAgYXV0b0NvbXBsZXRlRyE6IFNWR0dFbGVtZW50O1xuICAgIGhvdmVyRWxlbWVudDogU1ZHR0VsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBib2FyZDogUGxhaXRCb2FyZCkge1xuICAgICAgICBzdXBlcihib2FyZCk7XG4gICAgfVxuXG4gICAgY2FuRHJhdyhlbGVtZW50OiBQbGFpdFNoYXBlRWxlbWVudCwgZGF0YTogQWN0aXZlR2VuZXJhdG9yRXh0cmFEYXRhKTogYm9vbGVhbiB7XG4gICAgICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKHRoaXMuYm9hcmQpO1xuICAgICAgICBpZiAoZGF0YS5zZWxlY3RlZCAmJiBzZWxlY3RlZEVsZW1lbnRzLmxlbmd0aCA9PT0gMSAmJiAhaXNTZWxlY3Rpb25Nb3ZpbmcodGhpcy5ib2FyZCkpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgZHJhdyhlbGVtZW50OiBULCBkYXRhOiBBY3RpdmVHZW5lcmF0b3JFeHRyYURhdGEpOiBTVkdHRWxlbWVudCB7XG4gICAgICAgIHRoaXMuYXV0b0NvbXBsZXRlRyA9IGNyZWF0ZUcoKTtcbiAgICAgICAgY29uc3QgbWlkZGxlUG9pbnRzID0gZ2V0QXV0b0NvbXBsZXRlUG9pbnRzKGVsZW1lbnQpO1xuICAgICAgICBtaWRkbGVQb2ludHMuZm9yRWFjaCgocG9pbnQsIGluZGV4KSA9PiB7XG4gICAgICAgICAgICBjb25zdCBjaXJjbGUgPSBkcmF3Q2lyY2xlKFBsYWl0Qm9hcmQuZ2V0Um91Z2hTVkcodGhpcy5ib2FyZCksIHBvaW50LCBMSU5FX0FVVE9fQ09NUExFVEVfRElBTUVURVIsIHtcbiAgICAgICAgICAgICAgICBzdHJva2U6ICdub25lJyxcbiAgICAgICAgICAgICAgICBmaWxsOiBSZ2JhVG9IRVgoUFJJTUFSWV9DT0xPUiwgTElORV9BVVRPX0NPTVBMRVRFX09QQUNJVFkpLFxuICAgICAgICAgICAgICAgIGZpbGxTdHlsZTogJ3NvbGlkJ1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBjaXJjbGUuY2xhc3NMaXN0LmFkZChgbGluZS1hdXRvLWNvbXBsZXRlLSR7aW5kZXh9YCk7XG4gICAgICAgICAgICB0aGlzLmF1dG9Db21wbGV0ZUcuYXBwZW5kQ2hpbGQoY2lyY2xlKTtcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiB0aGlzLmF1dG9Db21wbGV0ZUc7XG4gICAgfVxuXG4gICAgcmVtb3ZlQXV0b0NvbXBsZXRlRyhpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuaG92ZXJFbGVtZW50ID0gdGhpcy5hdXRvQ29tcGxldGVHLnF1ZXJ5U2VsZWN0b3IoYC5saW5lLWF1dG8tY29tcGxldGUtJHtpbmRleH1gKTtcbiAgICAgICAgdGhpcy5ob3ZlckVsZW1lbnQhLnN0eWxlLnZpc2liaWxpdHkgPSAnaGlkZGVuJztcbiAgICB9XG5cbiAgICByZWNvdmVyQXV0b0NvbXBsZXRlRygpIHtcbiAgICAgICAgaWYgKHRoaXMuaG92ZXJFbGVtZW50KSB7XG4gICAgICAgICAgICB0aGlzLmhvdmVyRWxlbWVudC5zdHlsZS52aXNpYmlsaXR5ID0gJ3Zpc2libGUnO1xuICAgICAgICAgICAgdGhpcy5ob3ZlckVsZW1lbnQgPSBudWxsO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -0,0 +1,13 @@
1
+ import { Generator } from '@plait/common';
2
+ import { drawArrowLine } from '../utils/arrow-line/arrow-line-basic';
3
+ export class ArrowLineShapeGenerator extends Generator {
4
+ canDraw(element, data) {
5
+ return true;
6
+ }
7
+ draw(element, data) {
8
+ let lineG;
9
+ lineG = drawArrowLine(this.board, element);
10
+ return lineG;
11
+ }
12
+ }
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3ctbGluZS5nZW5lcmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9nZW5lcmF0b3JzL2Fycm93LWxpbmUuZ2VuZXJhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBSXJFLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxTQUFvQztJQUM3RSxPQUFPLENBQUMsT0FBdUIsRUFBRSxJQUFlO1FBQzVDLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxJQUFJLENBQUMsT0FBdUIsRUFBRSxJQUFlO1FBQ3pDLElBQUksS0FBOEIsQ0FBQztRQUNuQyxLQUFLLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDM0MsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRBcnJvd0xpbmUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEdlbmVyYXRvciB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZHJhd0Fycm93TGluZSB9IGZyb20gJy4uL3V0aWxzL2Fycm93LWxpbmUvYXJyb3ctbGluZS1iYXNpYyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2hhcGVEYXRhIHt9XG5cbmV4cG9ydCBjbGFzcyBBcnJvd0xpbmVTaGFwZUdlbmVyYXRvciBleHRlbmRzIEdlbmVyYXRvcjxQbGFpdEFycm93TGluZSwgU2hhcGVEYXRhPiB7XG4gICAgY2FuRHJhdyhlbGVtZW50OiBQbGFpdEFycm93TGluZSwgZGF0YTogU2hhcGVEYXRhKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cblxuICAgIGRyYXcoZWxlbWVudDogUGxhaXRBcnJvd0xpbmUsIGRhdGE6IFNoYXBlRGF0YSkge1xuICAgICAgICBsZXQgbGluZUc6IFNWR0dFbGVtZW50IHwgdW5kZWZpbmVkO1xuICAgICAgICBsaW5lRyA9IGRyYXdBcnJvd0xpbmUodGhpcy5ib2FyZCwgZWxlbWVudCk7XG4gICAgICAgIHJldHVybiBsaW5lRztcbiAgICB9XG59XG4iXX0=
@@ -1,7 +1,7 @@
1
1
  export * from './geometry-shape.generator';
2
- export * from './line-active.generator';
3
- export * from './line-auto-complete.generator';
2
+ export * from './arrow-line-active.generator';
3
+ export * from './arrow-line-auto-complete.generator';
4
4
  export * from './single-text.generator';
5
5
  export * from './text.generator';
6
6
  export * from './table.generator';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9nZW5lcmF0b3JzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9nZW9tZXRyeS1zaGFwZS5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lLWFjdGl2ZS5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lLWF1dG8tY29tcGxldGUuZ2VuZXJhdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vc2luZ2xlLXRleHQuZ2VuZXJhdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5nZW5lcmF0b3InO1xuIl19
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9nZW5lcmF0b3JzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9nZW9tZXRyeS1zaGFwZS5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9hcnJvdy1saW5lLWFjdGl2ZS5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9hcnJvdy1saW5lLWF1dG8tY29tcGxldGUuZ2VuZXJhdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vc2luZ2xlLXRleHQuZ2VuZXJhdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5nZW5lcmF0b3InO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5nZW5lcmF0b3InO1xuIl19
@@ -2,7 +2,7 @@ import { PlaitBoard, isSelectionMoving, getSelectedElements, ACTIVE_STROKE_WIDTH
2
2
  import { GeometryShapeGenerator } from './generators/geometry-shape.generator';
3
3
  import { DrawTransforms } from './transforms';
4
4
  import { ActiveGenerator, CommonElementFlavour, canResize } from '@plait/common';
5
- import { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';
5
+ import { ArrowLineAutoCompleteGenerator } from './generators/arrow-line-auto-complete.generator';
6
6
  import { getTextRectangle, isGeometryIncludeText, isMultipleTextGeometry, memorizeLatestText } from './utils';
7
7
  import { TextGenerator } from './generators/text.generator';
8
8
  import { SingleTextGenerator } from './generators/single-text.generator';
@@ -39,12 +39,12 @@ export class GeometryComponent extends CommonElementFlavour {
39
39
  return canResize(this.board, this.element);
40
40
  }
41
41
  });
42
- this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);
42
+ this.lineAutoCompleteGenerator = new ArrowLineAutoCompleteGenerator(this.board);
43
43
  this.shapeGenerator = new GeometryShapeGenerator(this.board);
44
44
  if (isGeometryIncludeText(this.element)) {
45
45
  this.initializeTextManage();
46
46
  }
47
- this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
47
+ this.getRef().addGenerator(ArrowLineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
48
48
  this.getRef().addGenerator(ActiveGenerator.key, this.activeGenerator);
49
49
  }
50
50
  initialize() {
@@ -134,4 +134,4 @@ export class GeometryComponent extends CommonElementFlavour {
134
134
  this.textGenerator?.destroy();
135
135
  }
136
136
  }
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.component.js","sourceRoot":"","sources":["../../../packages/draw/src/geometry.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    isSelectionMoving,\n    getSelectedElements,\n    ACTIVE_STROKE_WIDTH,\n    RectangleClient\n} from '@plait/core';\nimport { PlaitCommonGeometry, PlaitGeometry, PlaitMultipleTextGeometry } from './interfaces/geometry';\nimport { GeometryShapeGenerator } from './generators/geometry-shape.generator';\nimport { DrawTransforms } from './transforms';\nimport { ActiveGenerator, CommonElementFlavour, TextManageChangeData, canResize } from '@plait/common';\nimport { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';\nimport { getTextRectangle, isGeometryIncludeText, isMultipleTextGeometry, memorizeLatestText } from './utils';\nimport { PlaitDrawShapeText, TextGenerator } from './generators/text.generator';\nimport { SingleTextGenerator } from './generators/single-text.generator';\nimport { PlaitText } from './interfaces';\nimport { GeometryThreshold } from './constants';\nimport { getEngine } from './engines';\n\nexport class GeometryComponent extends CommonElementFlavour<PlaitCommonGeometry, PlaitBoard>\n    implements OnContextChanged<PlaitCommonGeometry, PlaitBoard> {\n    activeGenerator!: ActiveGenerator<PlaitCommonGeometry>;\n\n    lineAutoCompleteGenerator!: LineAutoCompleteGenerator;\n\n    shapeGenerator!: GeometryShapeGenerator;\n\n    textGenerator!: TextGenerator<PlaitMultipleTextGeometry> | SingleTextGenerator;\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.activeGenerator = new ActiveGenerator<PlaitCommonGeometry>(this.board, {\n            getStrokeWidth: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if (selectedElements.length === 1 && !isSelectionMoving(this.board)) {\n                    return ACTIVE_STROKE_WIDTH;\n                } else {\n                    return ACTIVE_STROKE_WIDTH;\n                }\n            },\n            getStrokeOpacity: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if (selectedElements.length === 1 && !isSelectionMoving(this.board)) {\n                    return 1;\n                } else {\n                    return 0.5;\n                }\n            },\n            getRectangle: (element: PlaitCommonGeometry) => {\n                return RectangleClient.getRectangleByPoints(element.points);\n            },\n            hasResizeHandle: () => {\n                return canResize(this.board, this.element);\n            }\n        });\n        this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);\n        this.shapeGenerator = new GeometryShapeGenerator(this.board);\n        if (isGeometryIncludeText(this.element)) {\n            this.initializeTextManage();\n        }\n        this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n        this.getRef().addGenerator(ActiveGenerator.key, this.activeGenerator);\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\n        this.shapeGenerator.processDrawing(this.element as PlaitGeometry, this.getElementG());\n        this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n        this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n        this.textGenerator && this.textGenerator.draw(this.getElementG());\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitCommonGeometry, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitCommonGeometry, PlaitBoard>\n    ) {\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n        if (value.element !== previous.element || isChangeTheme) {\n            this.shapeGenerator.processDrawing(this.element as PlaitGeometry, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n            this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n            this.textGenerator && this.updateText(previous.element, value.element);\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState = this.activeGenerator.options.hasResizeHandle() === this.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n                this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    updateText(previousElement: PlaitCommonGeometry, currentElement: PlaitCommonGeometry) {\n        if (isMultipleTextGeometry(this.element)) {\n            (this.textGenerator as TextGenerator<PlaitMultipleTextGeometry>).update(\n                this.element,\n                previousElement.texts,\n                currentElement.texts,\n                this.getElementG()\n            );\n        } else {\n            (this.textGenerator as SingleTextGenerator).update(\n                this.element as PlaitGeometry,\n                previousElement.text,\n                currentElement.text,\n                this.getElementG()\n            );\n        }\n    }\n\n    initializeTextManage() {\n        const onTextChange = (element: PlaitCommonGeometry, textManageChangeData: TextManageChangeData, text: PlaitDrawShapeText) => {\n            if (textManageChangeData.newText) {\n                if (isMultipleTextGeometry(element)) {\n                    DrawTransforms.setDrawShapeText(this.board, element, {\n                        key: text.key,\n                        text: textManageChangeData.newText,\n                        textHeight: textManageChangeData.height\n                    });\n                } else {\n                    DrawTransforms.setText(\n                        this.board,\n                        element as PlaitGeometry,\n                        textManageChangeData.newText,\n                        textManageChangeData.width,\n                        textManageChangeData.height\n                    );\n                }\n            } else {\n                DrawTransforms.setTextSize(this.board, element as PlaitGeometry, textManageChangeData.width, textManageChangeData.height);\n            }\n            textManageChangeData.operations && memorizeLatestText(element, textManageChangeData.operations);\n        };\n\n        if (isMultipleTextGeometry(this.element)) {\n            this.textGenerator = new TextGenerator<PlaitMultipleTextGeometry>(\n                this.board,\n                this.element as PlaitMultipleTextGeometry,\n                this.element.texts!,\n                {\n                    onChange: onTextChange\n                }\n            );\n        } else {\n            this.textGenerator = new SingleTextGenerator(this.board, this.element as PlaitGeometry, this.element.text, {\n                onChange: onTextChange,\n                getMaxWidth: () => {\n                    let width = getTextRectangle(this.element).width;\n                    const getRectangle = getEngine(this.element.shape).getTextRectangle;\n                    if (getRectangle) {\n                        width = getRectangle(this.element as PlaitGeometry).width;\n                    }\n                    return (this.element as PlaitText)?.autoSize ? GeometryThreshold.defaultTextMaxWidth : width;\n                }\n            });\n        }\n        this.textGenerator.initialize();\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.activeGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n        this.textGenerator?.destroy();\n    }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.component.js","sourceRoot":"","sources":["../../../packages/draw/src/geometry.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    isSelectionMoving,\n    getSelectedElements,\n    ACTIVE_STROKE_WIDTH,\n    RectangleClient\n} from '@plait/core';\nimport { PlaitCommonGeometry, PlaitGeometry, PlaitMultipleTextGeometry } from './interfaces/geometry';\nimport { GeometryShapeGenerator } from './generators/geometry-shape.generator';\nimport { DrawTransforms } from './transforms';\nimport { ActiveGenerator, CommonElementFlavour, TextManageChangeData, canResize } from '@plait/common';\nimport { ArrowLineAutoCompleteGenerator } from './generators/arrow-line-auto-complete.generator';\nimport { getTextRectangle, isGeometryIncludeText, isMultipleTextGeometry, memorizeLatestText } from './utils';\nimport { PlaitDrawShapeText, TextGenerator } from './generators/text.generator';\nimport { SingleTextGenerator } from './generators/single-text.generator';\nimport { PlaitText } from './interfaces';\nimport { GeometryThreshold } from './constants';\nimport { getEngine } from './engines';\n\nexport class GeometryComponent extends CommonElementFlavour<PlaitCommonGeometry, PlaitBoard>\n    implements OnContextChanged<PlaitCommonGeometry, PlaitBoard> {\n    activeGenerator!: ActiveGenerator<PlaitCommonGeometry>;\n\n    lineAutoCompleteGenerator!: ArrowLineAutoCompleteGenerator;\n\n    shapeGenerator!: GeometryShapeGenerator;\n\n    textGenerator!: TextGenerator<PlaitMultipleTextGeometry> | SingleTextGenerator;\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.activeGenerator = new ActiveGenerator<PlaitCommonGeometry>(this.board, {\n            getStrokeWidth: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if (selectedElements.length === 1 && !isSelectionMoving(this.board)) {\n                    return ACTIVE_STROKE_WIDTH;\n                } else {\n                    return ACTIVE_STROKE_WIDTH;\n                }\n            },\n            getStrokeOpacity: () => {\n                const selectedElements = getSelectedElements(this.board);\n                if (selectedElements.length === 1 && !isSelectionMoving(this.board)) {\n                    return 1;\n                } else {\n                    return 0.5;\n                }\n            },\n            getRectangle: (element: PlaitCommonGeometry) => {\n                return RectangleClient.getRectangleByPoints(element.points);\n            },\n            hasResizeHandle: () => {\n                return canResize(this.board, this.element);\n            }\n        });\n        this.lineAutoCompleteGenerator = new ArrowLineAutoCompleteGenerator(this.board);\n        this.shapeGenerator = new GeometryShapeGenerator(this.board);\n        if (isGeometryIncludeText(this.element)) {\n            this.initializeTextManage();\n        }\n        this.getRef().addGenerator(ArrowLineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n        this.getRef().addGenerator(ActiveGenerator.key, this.activeGenerator);\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\n        this.shapeGenerator.processDrawing(this.element as PlaitGeometry, this.getElementG());\n        this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n        this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n        this.textGenerator && this.textGenerator.draw(this.getElementG());\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitCommonGeometry, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitCommonGeometry, PlaitBoard>\n    ) {\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n        if (value.element !== previous.element || isChangeTheme) {\n            this.shapeGenerator.processDrawing(this.element as PlaitGeometry, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n            this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n            this.textGenerator && this.updateText(previous.element, value.element);\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState = this.activeGenerator.options.hasResizeHandle() === this.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n                this.lineAutoCompleteGenerator.processDrawing(this.element as PlaitGeometry, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    updateText(previousElement: PlaitCommonGeometry, currentElement: PlaitCommonGeometry) {\n        if (isMultipleTextGeometry(this.element)) {\n            (this.textGenerator as TextGenerator<PlaitMultipleTextGeometry>).update(\n                this.element,\n                previousElement.texts,\n                currentElement.texts,\n                this.getElementG()\n            );\n        } else {\n            (this.textGenerator as SingleTextGenerator).update(\n                this.element as PlaitGeometry,\n                previousElement.text,\n                currentElement.text,\n                this.getElementG()\n            );\n        }\n    }\n\n    initializeTextManage() {\n        const onTextChange = (element: PlaitCommonGeometry, textManageChangeData: TextManageChangeData, text: PlaitDrawShapeText) => {\n            if (textManageChangeData.newText) {\n                if (isMultipleTextGeometry(element)) {\n                    DrawTransforms.setDrawShapeText(this.board, element, {\n                        key: text.key,\n                        text: textManageChangeData.newText,\n                        textHeight: textManageChangeData.height\n                    });\n                } else {\n                    DrawTransforms.setText(\n                        this.board,\n                        element as PlaitGeometry,\n                        textManageChangeData.newText,\n                        textManageChangeData.width,\n                        textManageChangeData.height\n                    );\n                }\n            } else {\n                DrawTransforms.setTextSize(this.board, element as PlaitGeometry, textManageChangeData.width, textManageChangeData.height);\n            }\n            textManageChangeData.operations && memorizeLatestText(element, textManageChangeData.operations);\n        };\n\n        if (isMultipleTextGeometry(this.element)) {\n            this.textGenerator = new TextGenerator<PlaitMultipleTextGeometry>(\n                this.board,\n                this.element as PlaitMultipleTextGeometry,\n                this.element.texts!,\n                {\n                    onChange: onTextChange\n                }\n            );\n        } else {\n            this.textGenerator = new SingleTextGenerator(this.board, this.element as PlaitGeometry, this.element.text, {\n                onChange: onTextChange,\n                getMaxWidth: () => {\n                    let width = getTextRectangle(this.element).width;\n                    const getRectangle = getEngine(this.element.shape).getTextRectangle;\n                    if (getRectangle) {\n                        width = getRectangle(this.element as PlaitGeometry).width;\n                    }\n                    return (this.element as PlaitText)?.autoSize ? GeometryThreshold.defaultTextMaxWidth : width;\n                }\n            });\n        }\n        this.textGenerator.initialize();\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.activeGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n        this.textGenerator?.destroy();\n    }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { PlaitBoard } from '@plait/core';
2
2
  import { CommonElementFlavour, ImageGenerator } from '@plait/common';
3
- import { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';
3
+ import { ArrowLineAutoCompleteGenerator } from './generators/arrow-line-auto-complete.generator';
4
4
  export class ImageComponent extends CommonElementFlavour {
5
5
  constructor() {
6
6
  super();
@@ -23,8 +23,8 @@ export class ImageComponent extends CommonElementFlavour {
23
23
  };
24
24
  }
25
25
  });
26
- this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);
27
- this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
26
+ this.lineAutoCompleteGenerator = new ArrowLineAutoCompleteGenerator(this.board);
27
+ this.getRef().addGenerator(ArrowLineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
28
28
  }
29
29
  initialize() {
30
30
  super.initialize();
@@ -60,4 +60,4 @@ export class ImageComponent extends CommonElementFlavour {
60
60
  this.lineAutoCompleteGenerator.destroy();
61
61
  }
62
62
  }
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../packages/draw/src/image.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';\nimport { CommonElementFlavour, ImageGenerator } from '@plait/common';\nimport { PlaitImage } from './interfaces/image';\nimport { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';\n\nexport class ImageComponent extends CommonElementFlavour<PlaitImage, PlaitBoard> implements OnContextChanged<PlaitImage, PlaitBoard> {\n    imageGenerator!: ImageGenerator<PlaitImage>;\n\n    lineAutoCompleteGenerator!: LineAutoCompleteGenerator<PlaitImage>;\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.imageGenerator = new ImageGenerator<PlaitImage>(this.board, {\n            getRectangle: (element: PlaitImage) => {\n                return {\n                    x: element.points[0][0],\n                    y: element.points[0][1],\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            },\n            getImageItem: element => {\n                return {\n                    url: element.url,\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            }\n        });\n        this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);\n        this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\n        this.imageGenerator.processDrawing(this.element, this.getElementG());\n        this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitImage, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitImage, PlaitBoard>\n    ) {\n        if (value.element !== previous.element) {\n            this.imageGenerator.updateImage(this.getElementG(), previous.element, value.element);\n            this.imageGenerator.setFocus(this.element, this.selected);\n            this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState =\n                this.imageGenerator.activeGenerator &&\n                this.imageGenerator.activeGenerator.options.hasResizeHandle() === this.imageGenerator.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.imageGenerator.setFocus(this.element, this.selected);\n                this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.imageGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n    }\n}\n"]}
63
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../packages/draw/src/image.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAA+C,MAAM,aAAa,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAErE,OAAO,EAAE,8BAA8B,EAAE,MAAM,iDAAiD,CAAC;AAEjG,MAAM,OAAO,cAAe,SAAQ,oBAA4C;IAK5E;QACI,KAAK,EAAE,CAAC;IACZ,CAAC;IAED,mBAAmB;QACf,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAa,IAAI,CAAC,KAAK,EAAE;YAC7D,YAAY,EAAE,CAAC,OAAmB,EAAE,EAAE;gBAClC,OAAO;oBACH,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACvB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACvB,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAClD,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBACtD,CAAC;YACN,CAAC;YACD,YAAY,EAAE,OAAO,CAAC,EAAE;gBACpB,OAAO;oBACH,GAAG,EAAE,OAAO,CAAC,GAAG;oBAChB,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAClD,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBACtD,CAAC;YACN,CAAC;SACJ,CAAC,CAAC;QACH,IAAI,CAAC,yBAAyB,GAAG,IAAI,8BAA8B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChF,IAAI,CAAC,MAAM,EAAE,CAAC,YAAY,CAAC,8BAA8B,CAAC,GAAG,EAAE,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACnG,CAAC;IAED,UAAU;QACN,KAAK,CAAC,UAAU,EAAE,CAAC;QACnB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACrE,IAAI,CAAC,yBAAyB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACrG,QAAQ,EAAE,IAAI,CAAC,QAAQ;SAC1B,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB,CACZ,KAAwD,EACxD,QAA2D;QAE3D,IAAI,KAAK,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO,EAAE,CAAC;YACrC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YACrF,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC1D,IAAI,CAAC,yBAAyB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBACrG,QAAQ,EAAE,IAAI,CAAC,QAAQ;aAC1B,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACJ,MAAM,eAAe,GAAG,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,QAAQ,CAAC;YAC7D,MAAM,kBAAkB,GACpB,IAAI,CAAC,cAAc,CAAC,eAAe;gBACnC,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,OAAO,CAAC,eAAe,EAAE,KAAK,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,eAAe,CAAC;YAC1H,IAAI,CAAC,eAAe,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1C,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC1D,IAAI,CAAC,yBAAyB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;oBACrG,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBAC1B,CAAC,CAAC;YACP,CAAC;QACL,CAAC;IACL,CAAC;IAED,OAAO;QACH,KAAK,CAAC,OAAO,EAAE,CAAC;QAChB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,yBAAyB,CAAC,OAAO,EAAE,CAAC;IAC7C,CAAC;CACJ","sourcesContent":["import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';\nimport { CommonElementFlavour, ImageGenerator } from '@plait/common';\nimport { PlaitImage } from './interfaces/image';\nimport { ArrowLineAutoCompleteGenerator } from './generators/arrow-line-auto-complete.generator';\n\nexport class ImageComponent extends CommonElementFlavour<PlaitImage, PlaitBoard> implements OnContextChanged<PlaitImage, PlaitBoard> {\n    imageGenerator!: ImageGenerator<PlaitImage>;\n\n    lineAutoCompleteGenerator!: ArrowLineAutoCompleteGenerator<PlaitImage>;\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.imageGenerator = new ImageGenerator<PlaitImage>(this.board, {\n            getRectangle: (element: PlaitImage) => {\n                return {\n                    x: element.points[0][0],\n                    y: element.points[0][1],\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            },\n            getImageItem: element => {\n                return {\n                    url: element.url,\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            }\n        });\n        this.lineAutoCompleteGenerator = new ArrowLineAutoCompleteGenerator(this.board);\n        this.getRef().addGenerator(ArrowLineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\n        this.imageGenerator.processDrawing(this.element, this.getElementG());\n        this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitImage, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitImage, PlaitBoard>\n    ) {\n        if (value.element !== previous.element) {\n            this.imageGenerator.updateImage(this.getElementG(), previous.element, value.element);\n            this.imageGenerator.setFocus(this.element, this.selected);\n            this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState =\n                this.imageGenerator.activeGenerator &&\n                this.imageGenerator.activeGenerator.options.hasResizeHandle() === this.imageGenerator.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.imageGenerator.setFocus(this.element, this.selected);\n                this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.imageGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n    }\n}\n"]}
@@ -0,0 +1,70 @@
1
+ import { getElementById, rotatePointsByElement } from '@plait/core';
2
+ import { getConnectionPoint } from '../utils/arrow-line/arrow-line-common';
3
+ export var ArrowLineMarkerType;
4
+ (function (ArrowLineMarkerType) {
5
+ ArrowLineMarkerType["arrow"] = "arrow";
6
+ ArrowLineMarkerType["none"] = "none";
7
+ ArrowLineMarkerType["openTriangle"] = "open-triangle";
8
+ ArrowLineMarkerType["solidTriangle"] = "solid-triangle";
9
+ ArrowLineMarkerType["sharpArrow"] = "sharp-arrow";
10
+ ArrowLineMarkerType["oneSideUp"] = "one-side-up";
11
+ ArrowLineMarkerType["oneSideDown"] = "one-side-down";
12
+ ArrowLineMarkerType["hollowTriangle"] = "hollow-triangle";
13
+ ArrowLineMarkerType["singleSlash"] = "single-slash";
14
+ })(ArrowLineMarkerType || (ArrowLineMarkerType = {}));
15
+ export var ArrowLineShape;
16
+ (function (ArrowLineShape) {
17
+ ArrowLineShape["straight"] = "straight";
18
+ ArrowLineShape["curve"] = "curve";
19
+ ArrowLineShape["elbow"] = "elbow";
20
+ })(ArrowLineShape || (ArrowLineShape = {}));
21
+ export var ArrowLineHandleKey;
22
+ (function (ArrowLineHandleKey) {
23
+ ArrowLineHandleKey["source"] = "source";
24
+ ArrowLineHandleKey["target"] = "target";
25
+ })(ArrowLineHandleKey || (ArrowLineHandleKey = {}));
26
+ export const PlaitArrowLine = {
27
+ isSourceMarkOrTargetMark(line, markType, handleKey) {
28
+ if (handleKey === ArrowLineHandleKey.source) {
29
+ return line.source.marker === markType;
30
+ }
31
+ else {
32
+ return line.target.marker === markType;
33
+ }
34
+ },
35
+ isSourceMark(line, markType) {
36
+ return PlaitArrowLine.isSourceMarkOrTargetMark(line, markType, ArrowLineHandleKey.source);
37
+ },
38
+ isTargetMark(line, markType) {
39
+ return PlaitArrowLine.isSourceMarkOrTargetMark(line, markType, ArrowLineHandleKey.target);
40
+ },
41
+ isBoundElementOfSource(line, element) {
42
+ return line.source.boundId === element.id;
43
+ },
44
+ isBoundElementOfTarget(line, element) {
45
+ return line.target.boundId === element.id;
46
+ },
47
+ getPoints(board, line) {
48
+ let sourcePoint;
49
+ if (line.source.boundId) {
50
+ const sourceElement = getElementById(board, line.source.boundId);
51
+ const sourceConnectionPoint = getConnectionPoint(sourceElement, line.source.connection);
52
+ sourcePoint = rotatePointsByElement(sourceConnectionPoint, sourceElement) || sourceConnectionPoint;
53
+ }
54
+ else {
55
+ sourcePoint = line.points[0];
56
+ }
57
+ let targetPoint;
58
+ if (line.target.boundId) {
59
+ const targetElement = getElementById(board, line.target.boundId);
60
+ const targetConnectionPoint = getConnectionPoint(targetElement, line.target.connection);
61
+ targetPoint = rotatePointsByElement(targetConnectionPoint, targetElement) || targetConnectionPoint;
62
+ }
63
+ else {
64
+ targetPoint = line.points[line.points.length - 1];
65
+ }
66
+ const restPoints = line.points.length > 2 ? line.points.slice(1, line.points.length - 1) : [];
67
+ return [sourcePoint, ...restPoints, targetPoint];
68
+ }
69
+ };
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arrow-line.js","sourceRoot":"","sources":["../../../../packages/draw/src/interfaces/arrow-line.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwE,cAAc,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAG1I,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAG3E,MAAM,CAAN,IAAY,mBAUX;AAVD,WAAY,mBAAmB;IAC3B,sCAAe,CAAA;IACf,oCAAa,CAAA;IACb,qDAA8B,CAAA;IAC9B,uDAAgC,CAAA;IAChC,iDAA0B,CAAA;IAC1B,gDAAyB,CAAA;IACzB,oDAA6B,CAAA;IAC7B,yDAAkC,CAAA;IAClC,mDAA4B,CAAA;AAChC,CAAC,EAVW,mBAAmB,KAAnB,mBAAmB,QAU9B;AAED,MAAM,CAAN,IAAY,cAIX;AAJD,WAAY,cAAc;IACtB,uCAAqB,CAAA;IACrB,iCAAe,CAAA;IACf,iCAAe,CAAA;AACnB,CAAC,EAJW,cAAc,KAAd,cAAc,QAIzB;AAED,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC1B,uCAAiB,CAAA;IACjB,uCAAiB,CAAA;AACrB,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B;AA4DD,MAAM,CAAC,MAAM,cAAc,GAAG;IAC1B,wBAAwB,CAAC,IAAoB,EAAE,QAA6B,EAAE,SAA6B;QACvG,IAAI,SAAS,KAAK,kBAAkB,CAAC,MAAM,EAAE,CAAC;YAC1C,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,CAAC;QAC3C,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,QAAQ,CAAC;QAC3C,CAAC;IACL,CAAC;IACD,YAAY,CAAC,IAAoB,EAAE,QAA6B;QAC5D,OAAO,cAAc,CAAC,wBAAwB,CAAC,IAAI,EAAE,QAAQ,EAAE,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAC9F,CAAC;IACD,YAAY,CAAC,IAAoB,EAAE,QAA6B;QAC5D,OAAO,cAAc,CAAC,wBAAwB,CAAC,IAAI,EAAE,QAAQ,EAAE,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAC9F,CAAC;IACD,sBAAsB,CAAC,IAAoB,EAAE,OAA0B;QACnE,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,OAAO,CAAC,EAAE,CAAC;IAC9C,CAAC;IACD,sBAAsB,CAAC,IAAoB,EAAE,OAA0B;QACnE,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,OAAO,CAAC,EAAE,CAAC;IAC9C,CAAC;IACD,SAAS,CAAC,KAAiB,EAAE,IAAoB;QAC7C,IAAI,WAAW,CAAC;QAChB,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACtB,MAAM,aAAa,GAAG,cAAc,CAAoB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAE,CAAC;YACrF,MAAM,qBAAqB,GAAG,kBAAkB,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,UAAW,CAAC,CAAC;YACzF,WAAW,GAAG,qBAAqB,CAAC,qBAAqB,EAAE,aAAa,CAAC,IAAI,qBAAqB,CAAC;QACvG,CAAC;aAAM,CAAC;YACJ,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC;QAED,IAAI,WAAW,CAAC;QAChB,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACtB,MAAM,aAAa,GAAG,cAAc,CAAoB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAE,CAAC;YACrF,MAAM,qBAAqB,GAAG,kBAAkB,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,UAAW,CAAC,CAAC;YACzF,WAAW,GAAG,qBAAqB,CAAC,qBAAqB,EAAE,aAAa,CAAC,IAAI,qBAAqB,CAAC;QACvG,CAAC;aAAM,CAAC;YACJ,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACtD,CAAC;QACD,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9F,OAAO,CAAC,WAAW,EAAE,GAAG,UAAU,EAAE,WAAW,CAAC,CAAC;IACrD,CAAC;CACJ,CAAC","sourcesContent":["import { Direction, PlaitBoard, PlaitElement, Point, PointOfRectangle, Vector, getElementById, rotatePointsByElement } from '@plait/core';\nimport { Element } from 'slate';\nimport { StrokeStyle } from './element';\nimport { getConnectionPoint } from '../utils/arrow-line/arrow-line-common';\nimport { PlaitShapeElement } from '.';\n\nexport enum ArrowLineMarkerType {\n    arrow = 'arrow',\n    none = 'none',\n    openTriangle = 'open-triangle',\n    solidTriangle = 'solid-triangle',\n    sharpArrow = 'sharp-arrow',\n    oneSideUp = 'one-side-up',\n    oneSideDown = 'one-side-down',\n    hollowTriangle = 'hollow-triangle',\n    singleSlash = 'single-slash'\n}\n\nexport enum ArrowLineShape {\n    straight = 'straight',\n    curve = 'curve',\n    elbow = 'elbow'\n}\n\nexport enum ArrowLineHandleKey {\n    source = 'source',\n    target = 'target'\n}\n\nexport interface ArrowLineText {\n    text: Element;\n    // Percentage of positioning based on line length\n    position: number;\n    width: number;\n    height: number;\n}\n\nexport interface ArrowLineHandle {\n    // The id of the bounded element\n    boundId?: string;\n    connection?: PointOfRectangle;\n    marker: ArrowLineMarkerType;\n}\n\nexport interface ArrowLineHandleRef {\n    key: ArrowLineHandleKey;\n    direction: Direction;\n    point: PointOfRectangle;\n    vector: Vector;\n    boundElement?: PlaitShapeElement;\n}\n\nexport interface ArrowLineHandleRefPair {\n    source: ArrowLineHandleRef;\n    target: ArrowLineHandleRef;\n}\n\nexport interface PlaitArrowLine extends PlaitElement {\n    type: 'arrow-line';\n    shape: ArrowLineShape;\n    points: Point[];\n\n    source: ArrowLineHandle;\n    target: ArrowLineHandle;\n\n    texts: ArrowLineText[];\n\n    // node style attributes\n    strokeColor?: string;\n    strokeWidth?: number;\n    strokeStyle?: StrokeStyle;\n\n    opacity: number;\n}\n\nexport interface PlaitStraightArrowLine extends PlaitArrowLine {\n    shape: ArrowLineShape.straight;\n}\n\nexport interface PlaitCurveArrowLine extends PlaitArrowLine {\n    shape: ArrowLineShape.curve;\n}\n\nexport interface PlaitElbowArrowLine extends PlaitArrowLine {\n    shape: ArrowLineShape.elbow;\n}\n\nexport const PlaitArrowLine = {\n    isSourceMarkOrTargetMark(line: PlaitArrowLine, markType: ArrowLineMarkerType, handleKey: ArrowLineHandleKey) {\n        if (handleKey === ArrowLineHandleKey.source) {\n            return line.source.marker === markType;\n        } else {\n            return line.target.marker === markType;\n        }\n    },\n    isSourceMark(line: PlaitArrowLine, markType: ArrowLineMarkerType) {\n        return PlaitArrowLine.isSourceMarkOrTargetMark(line, markType, ArrowLineHandleKey.source);\n    },\n    isTargetMark(line: PlaitArrowLine, markType: ArrowLineMarkerType) {\n        return PlaitArrowLine.isSourceMarkOrTargetMark(line, markType, ArrowLineHandleKey.target);\n    },\n    isBoundElementOfSource(line: PlaitArrowLine, element: PlaitShapeElement) {\n        return line.source.boundId === element.id;\n    },\n    isBoundElementOfTarget(line: PlaitArrowLine, element: PlaitShapeElement) {\n        return line.target.boundId === element.id;\n    },\n    getPoints(board: PlaitBoard, line: PlaitArrowLine) {\n        let sourcePoint;\n        if (line.source.boundId) {\n            const sourceElement = getElementById<PlaitShapeElement>(board, line.source.boundId)!;\n            const sourceConnectionPoint = getConnectionPoint(sourceElement, line.source.connection!);\n            sourcePoint = rotatePointsByElement(sourceConnectionPoint, sourceElement) || sourceConnectionPoint;\n        } else {\n            sourcePoint = line.points[0];\n        }\n\n        let targetPoint;\n        if (line.target.boundId) {\n            const targetElement = getElementById<PlaitShapeElement>(board, line.target.boundId)!;\n            const targetConnectionPoint = getConnectionPoint(targetElement, line.target.connection!);\n            targetPoint = rotatePointsByElement(targetConnectionPoint, targetElement) || targetConnectionPoint;\n        } else {\n            targetPoint = line.points[line.points.length - 1];\n        }\n        const restPoints = line.points.length > 2 ? line.points.slice(1, line.points.length - 1) : [];\n        return [sourcePoint, ...restPoints, targetPoint];\n    }\n};\n"]}
@@ -9,7 +9,7 @@ export var MemorizeKey;
9
9
  MemorizeKey["basicShape"] = "basicShape";
10
10
  MemorizeKey["flowchart"] = "flowchart";
11
11
  MemorizeKey["text"] = "text";
12
- MemorizeKey["line"] = "line";
12
+ MemorizeKey["arrowLine"] = "arrow-line";
13
13
  MemorizeKey["UML"] = "UML";
14
14
  })(MemorizeKey || (MemorizeKey = {}));
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL2ludGVyZmFjZXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxXQUlYO0FBSkQsV0FBWSxXQUFXO0lBQ25CLDhCQUFlLENBQUE7SUFDZixnQ0FBaUIsQ0FBQTtJQUNqQixnQ0FBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsV0FBVyxLQUFYLFdBQVcsUUFJdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxXQU1YO0FBTkQsV0FBWSxXQUFXO0lBQ25CLHdDQUF5QixDQUFBO0lBQ3pCLHNDQUF1QixDQUFBO0lBQ3ZCLDRCQUFhLENBQUE7SUFDYiw0QkFBYSxDQUFBO0lBQ2IsMEJBQVcsQ0FBQTtBQUNmLENBQUMsRUFOVyxXQUFXLEtBQVgsV0FBVyxRQU10QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFN0cm9rZVN0eWxlIHtcbiAgICBzb2xpZCA9ICdzb2xpZCcsXG4gICAgZGFzaGVkID0gJ2Rhc2hlZCcsXG4gICAgZG90dGVkID0gJ2RvdHRlZCdcbn1cblxuZXhwb3J0IGVudW0gTWVtb3JpemVLZXkge1xuICAgIGJhc2ljU2hhcGUgPSAnYmFzaWNTaGFwZScsXG4gICAgZmxvd2NoYXJ0ID0gJ2Zsb3djaGFydCcsXG4gICAgdGV4dCA9ICd0ZXh0JyxcbiAgICBsaW5lID0gJ2xpbmUnLFxuICAgIFVNTCA9ICdVTUwnXG59XG4iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL2ludGVyZmFjZXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxXQUlYO0FBSkQsV0FBWSxXQUFXO0lBQ25CLDhCQUFlLENBQUE7SUFDZixnQ0FBaUIsQ0FBQTtJQUNqQixnQ0FBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsV0FBVyxLQUFYLFdBQVcsUUFJdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxXQU1YO0FBTkQsV0FBWSxXQUFXO0lBQ25CLHdDQUF5QixDQUFBO0lBQ3pCLHNDQUF1QixDQUFBO0lBQ3ZCLDRCQUFhLENBQUE7SUFDYix1Q0FBd0IsQ0FBQTtJQUN4QiwwQkFBVyxDQUFBO0FBQ2YsQ0FBQyxFQU5XLFdBQVcsS0FBWCxXQUFXLFFBTXRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gU3Ryb2tlU3R5bGUge1xuICAgIHNvbGlkID0gJ3NvbGlkJyxcbiAgICBkYXNoZWQgPSAnZGFzaGVkJyxcbiAgICBkb3R0ZWQgPSAnZG90dGVkJ1xufVxuXG5leHBvcnQgZW51bSBNZW1vcml6ZUtleSB7XG4gICAgYmFzaWNTaGFwZSA9ICdiYXNpY1NoYXBlJyxcbiAgICBmbG93Y2hhcnQgPSAnZmxvd2NoYXJ0JyxcbiAgICB0ZXh0ID0gJ3RleHQnLFxuICAgIGFycm93TGluZSA9ICdhcnJvdy1saW5lJyxcbiAgICBVTUwgPSAnVU1MJ1xufVxuIl19
@@ -1,19 +1,23 @@
1
1
  import { BasicShapes, FlowchartSymbols, UMLSymbols } from './geometry';
2
2
  import { SwimlaneSymbols } from './swimlane';
3
3
  import { PlaitTableElement } from './table';
4
- export * from './line';
4
+ export * from './arrow-line';
5
5
  export * from './geometry';
6
6
  export * from './text';
7
7
  export * from './element';
8
8
  export * from './engine';
9
9
  export * from './swimlane';
10
10
  export * from './table';
11
+ export * from './vector-line';
11
12
  export const PlaitDrawElement = {
12
13
  isGeometry: (value) => {
13
14
  return value.type === 'geometry';
14
15
  },
15
- isLine: (value) => {
16
- return value.type === 'line';
16
+ // isLine: (value: any): value is PlaitArrowLine => {
17
+ // return value.type === 'arrow-line' || value.type === 'line' || value.type === 'vector-line';
18
+ // },
19
+ isArrowLine: (value) => {
20
+ return value.type === 'arrow-line' || value.type === 'line';
17
21
  },
18
22
  isText: (value) => {
19
23
  return value.type === 'geometry' && value.shape === BasicShapes.text;
@@ -26,7 +30,7 @@ export const PlaitDrawElement = {
26
30
  },
27
31
  isDrawElement: (value) => {
28
32
  if (PlaitDrawElement.isGeometry(value) ||
29
- PlaitDrawElement.isLine(value) ||
33
+ PlaitDrawElement.isArrowLine(value) ||
30
34
  PlaitDrawElement.isImage(value) ||
31
35
  PlaitDrawElement.isTable(value) ||
32
36
  PlaitDrawElement.isSwimlane(value)) {
@@ -37,7 +41,10 @@ export const PlaitDrawElement = {
37
41
  }
38
42
  },
39
43
  isShapeElement: (value) => {
40
- return PlaitDrawElement.isImage(value) || PlaitDrawElement.isGeometry(value) || PlaitDrawElement.isTable(value) || PlaitDrawElement.isSwimlane(value);
44
+ return (PlaitDrawElement.isImage(value) ||
45
+ PlaitDrawElement.isGeometry(value) ||
46
+ PlaitDrawElement.isTable(value) ||
47
+ PlaitDrawElement.isSwimlane(value));
41
48
  },
42
49
  isBasicShape: (value) => {
43
50
  return Object.keys(BasicShapes).includes(value.shape);
@@ -65,6 +72,6 @@ export const PlaitDrawElement = {
65
72
  },
66
73
  isElementByTable: (value) => {
67
74
  return PlaitDrawElement.isTable(value) || PlaitDrawElement.isSwimlane(value) || PlaitDrawElement.isGeometryByTable(value);
68
- },
75
+ }
69
76
  };
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/draw/src/interfaces/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { BasicShapes, FlowchartSymbols, GeometryShapes, PlaitBaseGeometry, PlaitGeometry, UMLSymbols } from './geometry';\nimport { PlaitImage } from './image';\nimport { PlaitLine } from './line';\nimport { PlaitSwimlane, SwimlaneSymbols } from './swimlane';\nimport { PlaitBaseTable, PlaitTable, PlaitTableElement, TableSymbols } from './table';\nimport { PlaitText } from './text';\n\nexport * from './line';\nexport * from './geometry';\nexport * from './text';\nexport * from './element';\nexport * from './engine';\nexport * from './swimlane';\nexport * from './table';\n\nexport type PlaitDrawElement = PlaitGeometry | PlaitLine | PlaitImage | PlaitBaseTable | PlaitSwimlane;\n\nexport type PlaitShapeElement = PlaitGeometry | PlaitImage | PlaitTable | PlaitSwimlane;\n\nexport type DrawShapes = GeometryShapes | TableSymbols | SwimlaneSymbols;\n\nexport const PlaitDrawElement = {\n    isGeometry: (value: any): value is PlaitGeometry => {\n        return value.type === 'geometry';\n    },\n    isLine: (value: any): value is PlaitLine => {\n        return value.type === 'line';\n    },\n    isText: (value: any): value is PlaitText => {\n        return value.type === 'geometry' && value.shape === BasicShapes.text;\n    },\n    isImage: (value: any): value is PlaitImage => {\n        return value.type === 'image';\n    },\n    isTable: (value: any): value is PlaitTable => {\n        return PlaitTableElement.isTable(value);\n    },\n    isDrawElement: (value: any): value is PlaitDrawElement => {\n        if (\n            PlaitDrawElement.isGeometry(value) ||\n            PlaitDrawElement.isLine(value) ||\n            PlaitDrawElement.isImage(value) ||\n            PlaitDrawElement.isTable(value) ||\n            PlaitDrawElement.isSwimlane(value)\n        ) {\n            return true;\n        } else {\n            return false;\n        }\n    },\n    isShapeElement: (value: any): value is PlaitShapeElement => {\n        return PlaitDrawElement.isImage(value) || PlaitDrawElement.isGeometry(value) || PlaitDrawElement.isTable(value) || PlaitDrawElement.isSwimlane(value);\n    },\n    isBasicShape: (value: any) => {\n        return Object.keys(BasicShapes).includes(value.shape);\n    },\n    isFlowchart: (value: any) => {\n        return Object.keys(FlowchartSymbols).includes(value.shape);\n    },\n    isUML: (value: any) => {\n        return Object.keys(UMLSymbols).includes(value.shape);\n    },\n    isSwimlane: (value: any): value is PlaitSwimlane => {\n        return value.type === 'swimlane';\n    },\n    isVerticalSwimlane: (value: any) => {\n        return PlaitDrawElement.isSwimlane(value) && value.shape === SwimlaneSymbols.swimlaneVertical;\n    },\n    isHorizontalSwimlane: (value: any) => {\n        return PlaitDrawElement.isSwimlane(value) && value.shape === SwimlaneSymbols.swimlaneHorizontal;\n    },\n    isUMLClassOrInterface: (value: any) => {\n        return Object.keys(UMLSymbols).includes(value.shape) && [UMLSymbols.class, UMLSymbols.interface].includes(value.shape);\n    },\n    isGeometryByTable: (value: any): value is PlaitBaseTable => {\n        return PlaitDrawElement.isUMLClassOrInterface(value);\n    },\n    isElementByTable: (value: any): value is PlaitBaseTable => {\n        return PlaitDrawElement.isTable(value) || PlaitDrawElement.isSwimlane(value) || PlaitDrawElement.isGeometryByTable(value);\n    },\n};\n"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/draw/src/interfaces/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { BasicShapes, FlowchartSymbols, GeometryShapes, PlaitBaseGeometry, PlaitGeometry, UMLSymbols } from './geometry';\nimport { PlaitImage } from './image';\nimport { PlaitArrowLine } from './arrow-line';\nimport { PlaitSwimlane, SwimlaneSymbols } from './swimlane';\nimport { PlaitBaseTable, PlaitTable, PlaitTableElement, TableSymbols } from './table';\nimport { PlaitText } from './text';\nimport { PlaitVectorLine } from './vector-line';\n\nexport * from './arrow-line';\nexport * from './geometry';\nexport * from './text';\nexport * from './element';\nexport * from './engine';\nexport * from './swimlane';\nexport * from './table';\nexport * from './vector-line';\n\nexport type PlaitDrawElement = PlaitGeometry | PlaitArrowLine | PlaitVectorLine | PlaitImage | PlaitBaseTable | PlaitSwimlane;\n\nexport type PlaitShapeElement = PlaitGeometry | PlaitImage | PlaitTable | PlaitSwimlane;\n\nexport type DrawShapes = GeometryShapes | TableSymbols | SwimlaneSymbols;\n\nexport const PlaitDrawElement = {\n    isGeometry: (value: any): value is PlaitGeometry => {\n        return value.type === 'geometry';\n    },\n    // isLine: (value: any): value is PlaitArrowLine => {\n    //     return value.type === 'arrow-line' || value.type === 'line' || value.type === 'vector-line';\n    // },\n    isArrowLine: (value: any): value is PlaitArrowLine => {\n        return value.type === 'arrow-line' || value.type === 'line';\n    },\n    isText: (value: any): value is PlaitText => {\n        return value.type === 'geometry' && value.shape === BasicShapes.text;\n    },\n    isImage: (value: any): value is PlaitImage => {\n        return value.type === 'image';\n    },\n    isTable: (value: any): value is PlaitTable => {\n        return PlaitTableElement.isTable(value);\n    },\n    isDrawElement: (value: any): value is PlaitDrawElement => {\n        if (\n            PlaitDrawElement.isGeometry(value) ||\n            PlaitDrawElement.isArrowLine(value) ||\n            PlaitDrawElement.isImage(value) ||\n            PlaitDrawElement.isTable(value) ||\n            PlaitDrawElement.isSwimlane(value)\n        ) {\n            return true;\n        } else {\n            return false;\n        }\n    },\n    isShapeElement: (value: any): value is PlaitShapeElement => {\n        return (\n            PlaitDrawElement.isImage(value) ||\n            PlaitDrawElement.isGeometry(value) ||\n            PlaitDrawElement.isTable(value) ||\n            PlaitDrawElement.isSwimlane(value)\n        );\n    },\n    isBasicShape: (value: any) => {\n        return Object.keys(BasicShapes).includes(value.shape);\n    },\n    isFlowchart: (value: any) => {\n        return Object.keys(FlowchartSymbols).includes(value.shape);\n    },\n    isUML: (value: any) => {\n        return Object.keys(UMLSymbols).includes(value.shape);\n    },\n    isSwimlane: (value: any): value is PlaitSwimlane => {\n        return value.type === 'swimlane';\n    },\n    isVerticalSwimlane: (value: any) => {\n        return PlaitDrawElement.isSwimlane(value) && value.shape === SwimlaneSymbols.swimlaneVertical;\n    },\n    isHorizontalSwimlane: (value: any) => {\n        return PlaitDrawElement.isSwimlane(value) && value.shape === SwimlaneSymbols.swimlaneHorizontal;\n    },\n    isUMLClassOrInterface: (value: any) => {\n        return Object.keys(UMLSymbols).includes(value.shape) && [UMLSymbols.class, UMLSymbols.interface].includes(value.shape);\n    },\n    isGeometryByTable: (value: any): value is PlaitBaseTable => {\n        return PlaitDrawElement.isUMLClassOrInterface(value);\n    },\n    isElementByTable: (value: any): value is PlaitBaseTable => {\n        return PlaitDrawElement.isTable(value) || PlaitDrawElement.isSwimlane(value) || PlaitDrawElement.isGeometryByTable(value);\n    }\n};\n"]}
@@ -0,0 +1,6 @@
1
+ export var VectorLineShape;
2
+ (function (VectorLineShape) {
3
+ VectorLineShape["straight"] = "straight";
4
+ VectorLineShape["curve"] = "curve";
5
+ })(VectorLineShape || (VectorLineShape = {}));
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVjdG9yLWxpbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9pbnRlcmZhY2VzL3ZlY3Rvci1saW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sQ0FBTixJQUFZLGVBR1g7QUFIRCxXQUFZLGVBQWU7SUFDdkIsd0NBQWtDLENBQUE7SUFDbEMsa0NBQTRCLENBQUE7QUFDaEMsQ0FBQyxFQUhXLGVBQWUsS0FBZixlQUFlLFFBRzFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRFbGVtZW50LCBQb2ludCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IFN0cm9rZVN0eWxlIH0gZnJvbSAnLi9lbGVtZW50JztcbmltcG9ydCB7IEFycm93TGluZVNoYXBlIH0gZnJvbSAnLi9hcnJvdy1saW5lJztcblxuZXhwb3J0IGVudW0gVmVjdG9yTGluZVNoYXBlIHtcbiAgICBzdHJhaWdodCA9IEFycm93TGluZVNoYXBlLnN0cmFpZ2h0LFxuICAgIGN1cnZlID0gQXJyb3dMaW5lU2hhcGUuY3VydmVcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdFZlY3RvckxpbmUgZXh0ZW5kcyBQbGFpdEVsZW1lbnQge1xuICAgIHR5cGU6ICd2ZWN0b3ItbGluZSc7XG4gICAgc2hhcGU6IFZlY3RvckxpbmVTaGFwZTtcbiAgICBwb2ludHM6IFBvaW50W107XG4gICAgc3Ryb2tlQ29sb3I/OiBzdHJpbmc7XG4gICAgc3Ryb2tlV2lkdGg/OiBudW1iZXI7XG4gICAgc3Ryb2tlU3R5bGU/OiBTdHJva2VTdHlsZTtcbiAgICBmaWxsPzogc3RyaW5nO1xuICAgIG9wYWNpdHk6IG51bWJlcjtcbn1cbiJdfQ==