@plait/draw 0.77.2 → 0.78.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/fesm2022/plait-draw.mjs +21 -14
  2. package/fesm2022/plait-draw.mjs.map +1 -1
  3. package/package.json +1 -3
  4. package/transforms/image.d.ts +6 -0
  5. package/utils/hit.d.ts +1 -1
  6. package/esm2022/arrow-line.component.mjs +0 -165
  7. package/esm2022/constants/default.mjs +0 -7
  8. package/esm2022/constants/geometry.mjs +0 -272
  9. package/esm2022/constants/image.mjs +0 -2
  10. package/esm2022/constants/index.mjs +0 -9
  11. package/esm2022/constants/line.mjs +0 -12
  12. package/esm2022/constants/pointer.mjs +0 -23
  13. package/esm2022/constants/swimlane.mjs +0 -25
  14. package/esm2022/constants/text.mjs +0 -2
  15. package/esm2022/constants/theme.mjs +0 -28
  16. package/esm2022/engines/basic-shapes/cloud.mjs +0 -146
  17. package/esm2022/engines/basic-shapes/comment.mjs +0 -56
  18. package/esm2022/engines/basic-shapes/cross.mjs +0 -33
  19. package/esm2022/engines/basic-shapes/diamond.mjs +0 -16
  20. package/esm2022/engines/basic-shapes/ellipse.mjs +0 -53
  21. package/esm2022/engines/basic-shapes/hexagon.mjs +0 -27
  22. package/esm2022/engines/basic-shapes/left-arrow.mjs +0 -30
  23. package/esm2022/engines/basic-shapes/octagon.mjs +0 -29
  24. package/esm2022/engines/basic-shapes/parallelogram.mjs +0 -26
  25. package/esm2022/engines/basic-shapes/pentagon-arrow.mjs +0 -27
  26. package/esm2022/engines/basic-shapes/pentagon.mjs +0 -30
  27. package/esm2022/engines/basic-shapes/polygon.mjs +0 -56
  28. package/esm2022/engines/basic-shapes/process-arrow.mjs +0 -26
  29. package/esm2022/engines/basic-shapes/rectangle.mjs +0 -26
  30. package/esm2022/engines/basic-shapes/right-arrow.mjs +0 -28
  31. package/esm2022/engines/basic-shapes/round-comment.mjs +0 -82
  32. package/esm2022/engines/basic-shapes/round-rectangle.mjs +0 -58
  33. package/esm2022/engines/basic-shapes/star.mjs +0 -39
  34. package/esm2022/engines/basic-shapes/trapezoid.mjs +0 -26
  35. package/esm2022/engines/basic-shapes/triangle.mjs +0 -34
  36. package/esm2022/engines/basic-shapes/two-way-arrow.mjs +0 -25
  37. package/esm2022/engines/flowchart/database.mjs +0 -84
  38. package/esm2022/engines/flowchart/delay.mjs +0 -44
  39. package/esm2022/engines/flowchart/display.mjs +0 -74
  40. package/esm2022/engines/flowchart/document.mjs +0 -81
  41. package/esm2022/engines/flowchart/hard-disk.mjs +0 -84
  42. package/esm2022/engines/flowchart/internal-storage.mjs +0 -47
  43. package/esm2022/engines/flowchart/manual-input.mjs +0 -33
  44. package/esm2022/engines/flowchart/manual-loop.mjs +0 -26
  45. package/esm2022/engines/flowchart/merge.mjs +0 -34
  46. package/esm2022/engines/flowchart/multi-document.mjs +0 -143
  47. package/esm2022/engines/flowchart/note-curly-left.mjs +0 -86
  48. package/esm2022/engines/flowchart/note-curly-right.mjs +0 -89
  49. package/esm2022/engines/flowchart/note-square.mjs +0 -46
  50. package/esm2022/engines/flowchart/off-page.mjs +0 -32
  51. package/esm2022/engines/flowchart/or.mjs +0 -20
  52. package/esm2022/engines/flowchart/predefined-process.mjs +0 -47
  53. package/esm2022/engines/flowchart/preparation.mjs +0 -27
  54. package/esm2022/engines/flowchart/stored-data.mjs +0 -79
  55. package/esm2022/engines/flowchart/summing-junction.mjs +0 -23
  56. package/esm2022/engines/flowchart/terminal.mjs +0 -68
  57. package/esm2022/engines/index.mjs +0 -130
  58. package/esm2022/engines/table/table.mjs +0 -101
  59. package/esm2022/engines/uml/activity-class.mjs +0 -47
  60. package/esm2022/engines/uml/actor.mjs +0 -119
  61. package/esm2022/engines/uml/assembly.mjs +0 -105
  62. package/esm2022/engines/uml/combined-fragment.mjs +0 -66
  63. package/esm2022/engines/uml/component-box.mjs +0 -61
  64. package/esm2022/engines/uml/component.mjs +0 -117
  65. package/esm2022/engines/uml/container.mjs +0 -44
  66. package/esm2022/engines/uml/deletion.mjs +0 -54
  67. package/esm2022/engines/uml/note.mjs +0 -58
  68. package/esm2022/engines/uml/package.mjs +0 -105
  69. package/esm2022/engines/uml/provided-interface.mjs +0 -92
  70. package/esm2022/engines/uml/required-interface.mjs +0 -81
  71. package/esm2022/engines/uml/template.mjs +0 -47
  72. package/esm2022/generators/arrow-line-auto-complete.generator.mjs +0 -46
  73. package/esm2022/generators/arrow-line.generator.mjs +0 -13
  74. package/esm2022/generators/geometry-shape.generator.mjs +0 -29
  75. package/esm2022/generators/index.mjs +0 -7
  76. package/esm2022/generators/line-active.generator.mjs +0 -84
  77. package/esm2022/generators/single-text.generator.mjs +0 -16
  78. package/esm2022/generators/table.generator.mjs +0 -25
  79. package/esm2022/generators/text.generator.mjs +0 -131
  80. package/esm2022/generators/vector-line-generator.mjs +0 -13
  81. package/esm2022/geometry.component.mjs +0 -145
  82. package/esm2022/image.component.mjs +0 -67
  83. package/esm2022/interfaces/arrow-line.mjs +0 -70
  84. package/esm2022/interfaces/element.mjs +0 -9
  85. package/esm2022/interfaces/engine.mjs +0 -2
  86. package/esm2022/interfaces/geometry.mjs +0 -82
  87. package/esm2022/interfaces/image.mjs +0 -2
  88. package/esm2022/interfaces/index.mjs +0 -92
  89. package/esm2022/interfaces/line.mjs +0 -2
  90. package/esm2022/interfaces/options.mjs +0 -2
  91. package/esm2022/interfaces/swimlane.mjs +0 -13
  92. package/esm2022/interfaces/table.mjs +0 -13
  93. package/esm2022/interfaces/text.mjs +0 -2
  94. package/esm2022/interfaces/vector-line.mjs +0 -10
  95. package/esm2022/plait-draw.mjs +0 -5
  96. package/esm2022/plugins/with-arrow-line-auto-complete-reaction.mjs +0 -43
  97. package/esm2022/plugins/with-arrow-line-auto-complete.mjs +0 -76
  98. package/esm2022/plugins/with-arrow-line-bound-reaction.mjs +0 -53
  99. package/esm2022/plugins/with-arrow-line-create.mjs +0 -51
  100. package/esm2022/plugins/with-arrow-line-resize.mjs +0 -158
  101. package/esm2022/plugins/with-arrow-line-text-move.mjs +0 -53
  102. package/esm2022/plugins/with-arrow-line-text.mjs +0 -73
  103. package/esm2022/plugins/with-draw-fragment.mjs +0 -98
  104. package/esm2022/plugins/with-draw-hotkey.mjs +0 -45
  105. package/esm2022/plugins/with-draw-resize.mjs +0 -269
  106. package/esm2022/plugins/with-draw-rotate.mjs +0 -132
  107. package/esm2022/plugins/with-draw.mjs +0 -144
  108. package/esm2022/plugins/with-geometry-create.mjs +0 -182
  109. package/esm2022/plugins/with-swimlane-create.mjs +0 -127
  110. package/esm2022/plugins/with-swimlane.mjs +0 -21
  111. package/esm2022/plugins/with-table-resize.mjs +0 -135
  112. package/esm2022/plugins/with-table.mjs +0 -109
  113. package/esm2022/plugins/with-vector-line-create.mjs +0 -85
  114. package/esm2022/plugins/with-vector-line-resize.mjs +0 -61
  115. package/esm2022/public-api.mjs +0 -11
  116. package/esm2022/table.component.mjs +0 -162
  117. package/esm2022/transforms/arrow-line.mjs +0 -66
  118. package/esm2022/transforms/common.mjs +0 -36
  119. package/esm2022/transforms/geometry-text.mjs +0 -59
  120. package/esm2022/transforms/geometry.mjs +0 -43
  121. package/esm2022/transforms/image.mjs +0 -22
  122. package/esm2022/transforms/index.mjs +0 -36
  123. package/esm2022/transforms/multi-text-geometry-text.mjs +0 -15
  124. package/esm2022/transforms/swimlane.mjs +0 -164
  125. package/esm2022/transforms/table-text.mjs +0 -44
  126. package/esm2022/transforms/table.mjs +0 -36
  127. package/esm2022/transforms/vector-line.mjs +0 -13
  128. package/esm2022/utils/arrow-line/arrow-line-arrow.mjs +0 -123
  129. package/esm2022/utils/arrow-line/arrow-line-basic.mjs +0 -205
  130. package/esm2022/utils/arrow-line/arrow-line-common.mjs +0 -162
  131. package/esm2022/utils/arrow-line/arrow-line-resize.mjs +0 -309
  132. package/esm2022/utils/arrow-line/elbow.mjs +0 -114
  133. package/esm2022/utils/arrow-line/index.mjs +0 -6
  134. package/esm2022/utils/clipboard.mjs +0 -55
  135. package/esm2022/utils/common.mjs +0 -184
  136. package/esm2022/utils/geometry.mjs +0 -178
  137. package/esm2022/utils/hit.mjs +0 -242
  138. package/esm2022/utils/index.mjs +0 -17
  139. package/esm2022/utils/line.mjs +0 -64
  140. package/esm2022/utils/memorize.mjs +0 -93
  141. package/esm2022/utils/multi-text-geometry.mjs +0 -61
  142. package/esm2022/utils/polygon.mjs +0 -30
  143. package/esm2022/utils/position/arrow-line.mjs +0 -20
  144. package/esm2022/utils/position/geometry.mjs +0 -30
  145. package/esm2022/utils/position/line.mjs +0 -51
  146. package/esm2022/utils/selected.mjs +0 -39
  147. package/esm2022/utils/shape.mjs +0 -11
  148. package/esm2022/utils/snap-resizing.mjs +0 -185
  149. package/esm2022/utils/style/index.mjs +0 -2
  150. package/esm2022/utils/style/stroke.mjs +0 -21
  151. package/esm2022/utils/swimlane.mjs +0 -124
  152. package/esm2022/utils/table-selected.mjs +0 -21
  153. package/esm2022/utils/table.mjs +0 -172
  154. package/esm2022/utils/uml.mjs +0 -90
  155. package/esm2022/utils/vector-line.mjs +0 -71
  156. package/esm2022/vector-line.component.mjs +0 -55
@@ -1,184 +0,0 @@
1
- import { ACTIVE_STROKE_WIDTH, addSelectedElement, BoardTransforms, clearSelectedElement, createG, depthFirstRecursion, drawCircle, getI18nValue, getIsRecursionFunc, PlaitBoard, PlaitPointerType, RectangleClient, rotateAntiPointsByElement, SELECTION_BORDER_COLOR, SELECTION_FILL_COLOR, SNAPPING_STROKE_WIDTH, Transforms } from '@plait/core';
2
- import { DefaultDrawStyle, DefaultTextProperty, DrawI18nKey, LINE_HIT_GEOMETRY_BUFFER, LINE_SNAPPING_BUFFER, ShapeDefaultSpace } from '../constants';
3
- import { GeometryCommonTextKeys, PlaitDrawElement } from '../interfaces';
4
- import { Alignment, getTextEditorsByElement } from '@plait/common';
5
- import { isCellIncludeText } from './table';
6
- import { getEngine } from '../engines';
7
- import { getElementShape } from './shape';
8
- import { memorizeLatestShape } from './memorize';
9
- import { isHitEdgeOfShape, isInsideOfShape } from './hit';
10
- import { getHitConnectorPoint } from './arrow-line';
11
- import { getNearestPoint, isGeometryClosed, isGeometryIncludeText, isSingleTextGeometry } from './geometry';
12
- import { isMultipleTextGeometry } from './multi-text-geometry';
13
- export const getTextRectangle = (element) => {
14
- const elementRectangle = RectangleClient.getRectangleByPoints(element.points);
15
- const strokeWidth = getStrokeWidthByElement(element);
16
- const height = element.textHeight;
17
- const width = elementRectangle.width - ShapeDefaultSpace.rectangleAndText * 2 - strokeWidth * 2;
18
- return {
19
- height,
20
- width: width > 0 ? width : 0,
21
- x: elementRectangle.x + ShapeDefaultSpace.rectangleAndText + strokeWidth,
22
- y: elementRectangle.y + (elementRectangle.height - height) / 2
23
- };
24
- };
25
- export const getStrokeWidthByElement = (element) => {
26
- if (PlaitDrawElement.isText(element)) {
27
- return 0;
28
- }
29
- const strokeWidth = element.strokeWidth || DefaultDrawStyle.strokeWidth;
30
- return strokeWidth;
31
- };
32
- export const insertElement = (board, element) => {
33
- memorizeLatestShape(board, element.shape);
34
- Transforms.insertNode(board, element, [board.children.length]);
35
- clearSelectedElement(board);
36
- addSelectedElement(board, element);
37
- BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
38
- };
39
- export const isDrawElementIncludeText = (element) => {
40
- if (PlaitDrawElement.isText(element)) {
41
- return true;
42
- }
43
- if (PlaitDrawElement.isImage(element)) {
44
- return false;
45
- }
46
- if (PlaitDrawElement.isGeometry(element)) {
47
- return isGeometryIncludeText(element);
48
- }
49
- if (PlaitDrawElement.isArrowLine(element)) {
50
- const editors = getTextEditorsByElement(element);
51
- return editors.length > 0;
52
- }
53
- if (PlaitDrawElement.isElementByTable(element)) {
54
- return element.cells.some((cell) => isCellIncludeText(cell));
55
- }
56
- return true;
57
- };
58
- export const isDrawElementsIncludeText = (elements) => {
59
- return elements.some((item) => {
60
- return isDrawElementIncludeText(item);
61
- });
62
- };
63
- export const isClosedDrawElement = (element) => {
64
- if (PlaitDrawElement.isDrawElement(element)) {
65
- if (PlaitDrawElement.isText(element) || PlaitDrawElement.isArrowLine(element) || PlaitDrawElement.isImage(element)) {
66
- return false;
67
- }
68
- if (PlaitDrawElement.isVectorLine(element)) {
69
- return isClosedPoints(element.points);
70
- }
71
- if (PlaitDrawElement.isGeometry(element)) {
72
- return isGeometryClosed(element);
73
- }
74
- return true;
75
- }
76
- return false;
77
- };
78
- export const isClosedCustomGeometry = (board, value) => {
79
- return PlaitDrawElement.isCustomGeometryElement(board, value) && isClosedPoints(value.points);
80
- };
81
- export const getSnappingShape = (board, point) => {
82
- let hitElement = getHitShape(board, point);
83
- if (hitElement) {
84
- const ref = getSnappingRef(board, hitElement, point);
85
- if (ref.isHitConnector || ref.isHitEdge) {
86
- return hitElement;
87
- }
88
- }
89
- return null;
90
- };
91
- export const getSnappingRef = (board, hitElement, point) => {
92
- const rotatedPoint = rotateAntiPointsByElement(board, point, hitElement) || point;
93
- const connectorPoint = getHitConnectorPoint(rotatedPoint, hitElement);
94
- const edgePoint = getNearestPoint(hitElement, rotatedPoint);
95
- const isHitEdge = isHitEdgeOfShape(board, hitElement, rotatedPoint, LINE_SNAPPING_BUFFER);
96
- return { isHitEdge, isHitConnector: !!connectorPoint, connectorPoint, edgePoint };
97
- };
98
- export const getHitShape = (board, point, offset = LINE_HIT_GEOMETRY_BUFFER) => {
99
- let hitShape = null;
100
- traverseDrawShapes(board, (element) => {
101
- if (hitShape === null && isInsideOfShape(board, element, rotateAntiPointsByElement(board, point, element) || point, offset * 2)) {
102
- hitShape = element;
103
- }
104
- });
105
- return hitShape;
106
- };
107
- export const traverseDrawShapes = (board, callback) => {
108
- depthFirstRecursion(board, (node) => {
109
- if (!PlaitBoard.isBoard(node) && PlaitDrawElement.isShapeElement(node)) {
110
- callback(node);
111
- }
112
- }, getIsRecursionFunc(board), true);
113
- };
114
- export const drawShape = (board, outerRectangle, shape, roughOptions, drawOptions) => {
115
- return getEngine(shape).draw(board, outerRectangle, roughOptions, drawOptions);
116
- };
117
- export const drawBoundReaction = (board, element, roughOptions = { hasMask: true, hasConnector: true }) => {
118
- const g = createG();
119
- const rectangle = RectangleClient.getRectangleByPoints(element.points);
120
- const activeRectangle = RectangleClient.inflate(rectangle, SNAPPING_STROKE_WIDTH);
121
- const shape = getElementShape(element);
122
- let drawOptions;
123
- if (PlaitDrawElement.isElementByTable(element)) {
124
- drawOptions = { element };
125
- }
126
- const strokeG = drawShape(board, activeRectangle, shape, {
127
- stroke: SELECTION_BORDER_COLOR,
128
- strokeWidth: SNAPPING_STROKE_WIDTH
129
- }, drawOptions);
130
- g.appendChild(strokeG);
131
- if (roughOptions.hasMask) {
132
- const maskG = drawShape(board, activeRectangle, shape, {
133
- stroke: SELECTION_BORDER_COLOR,
134
- strokeWidth: 0,
135
- fill: isClosedDrawElement(element) ? SELECTION_FILL_COLOR : DefaultDrawStyle.fill,
136
- fillStyle: 'solid'
137
- }, drawOptions);
138
- g.appendChild(maskG);
139
- }
140
- if (roughOptions.hasConnector) {
141
- const connectorPoints = getEngine(shape).getConnectorPoints(rectangle);
142
- connectorPoints.forEach((point) => {
143
- const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 8, {
144
- stroke: SELECTION_BORDER_COLOR,
145
- strokeWidth: ACTIVE_STROKE_WIDTH,
146
- fill: '#FFF',
147
- fillStyle: 'solid'
148
- });
149
- g.appendChild(circleG);
150
- });
151
- }
152
- return g;
153
- };
154
- export const getTextKey = (element, text) => {
155
- if (element && isMultipleTextGeometry(element)) {
156
- return `${element.id}-${text.id}`;
157
- }
158
- else {
159
- return text.id;
160
- }
161
- };
162
- export const getGeometryAlign = (board, element) => {
163
- if (isMultipleTextGeometry(element)) {
164
- const drawShapeText = element.texts.find((item) => item.id.includes(GeometryCommonTextKeys.content));
165
- return drawShapeText?.text.align || Alignment.center;
166
- }
167
- if (isSingleTextGeometry(element)) {
168
- return element.text?.align || Alignment.center;
169
- }
170
- if (PlaitDrawElement.isElementByTable(element)) {
171
- const firstTextCell = element.cells.find((item) => item.text);
172
- return firstTextCell?.text?.align || Alignment.center;
173
- }
174
- return Alignment.center;
175
- };
176
- export const isClosedPoints = (points) => {
177
- const startPoint = points[0];
178
- const endPoint = points[points.length - 1];
179
- return startPoint[0] === endPoint[0] && startPoint[1] === endPoint[1];
180
- };
181
- export const getDefaultGeometryText = (board) => {
182
- return getI18nValue(board, DrawI18nKey.geometryText, DefaultTextProperty.text);
183
- };
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/common.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ACTIVE_STROKE_WIDTH,\n    addSelectedElement,\n    Ancestor,\n    BoardTransforms,\n    clearSelectedElement,\n    createG,\n    depthFirstRecursion,\n    drawCircle,\n    getI18nValue,\n    getIsRecursionFunc,\n    PlaitBoard,\n    PlaitElement,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    rotateAntiPointsByElement,\n    SELECTION_BORDER_COLOR,\n    SELECTION_FILL_COLOR,\n    SNAPPING_STROKE_WIDTH,\n    Transforms\n} from '@plait/core';\nimport {\n    DefaultDrawStyle,\n    DefaultTextProperty,\n    DrawI18nKey,\n    LINE_HIT_GEOMETRY_BUFFER,\n    LINE_SNAPPING_BUFFER,\n    ShapeDefaultSpace\n} from '../constants';\nimport {\n    DrawOptions,\n    DrawShapes,\n    GeometryCommonTextKeys,\n    PlaitBaseGeometry,\n    PlaitCommonGeometry,\n    PlaitCustomGeometry,\n    PlaitDrawElement,\n    PlaitGeometry,\n    PlaitShapeElement\n} from '../interfaces';\nimport { Alignment, getTextEditorsByElement } from '@plait/common';\nimport { isCellIncludeText } from './table';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { Options } from 'roughjs/bin/core';\nimport { PlaitBaseTable } from '../interfaces/table';\nimport { memorizeLatestShape } from './memorize';\nimport { isHitEdgeOfShape, isInsideOfShape } from './hit';\nimport { getHitConnectorPoint } from './arrow-line';\nimport { getNearestPoint, isGeometryClosed, isGeometryIncludeText, isSingleTextGeometry } from './geometry';\nimport { isMultipleTextGeometry } from './multi-text-geometry';\nimport { DrawTextInfo } from '../generators/text.generator';\n\nexport const getTextRectangle = <T extends PlaitElement = PlaitGeometry>(element: T) => {\n    const elementRectangle = RectangleClient.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 getStrokeWidthByElement = (element: PlaitElement) => {\n    if (PlaitDrawElement.isText(element)) {\n        return 0;\n    }\n    const strokeWidth = element.strokeWidth || DefaultDrawStyle.strokeWidth;\n    return strokeWidth;\n};\n\nexport const insertElement = (board: PlaitBoard, element: PlaitBaseGeometry | PlaitBaseTable) => {\n    memorizeLatestShape(board, element.shape);\n    Transforms.insertNode(board, element, [board.children.length]);\n    clearSelectedElement(board);\n    addSelectedElement(board, element);\n    BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n};\n\nexport const isDrawElementIncludeText = (element: PlaitDrawElement) => {\n    if (PlaitDrawElement.isText(element)) {\n        return true;\n    }\n    if (PlaitDrawElement.isImage(element)) {\n        return false;\n    }\n    if (PlaitDrawElement.isGeometry(element)) {\n        return isGeometryIncludeText(element);\n    }\n    if (PlaitDrawElement.isArrowLine(element)) {\n        const editors = getTextEditorsByElement(element);\n        return editors.length > 0;\n    }\n    if (PlaitDrawElement.isElementByTable(element)) {\n        return element.cells.some((cell) => isCellIncludeText(cell));\n    }\n    return true;\n};\n\nexport const isDrawElementsIncludeText = (elements: PlaitDrawElement[]) => {\n    return elements.some((item) => {\n        return isDrawElementIncludeText(item);\n    });\n};\n\nexport const isClosedDrawElement = (element: PlaitElement) => {\n    if (PlaitDrawElement.isDrawElement(element)) {\n        if (PlaitDrawElement.isText(element) || PlaitDrawElement.isArrowLine(element) || PlaitDrawElement.isImage(element)) {\n            return false;\n        }\n        if (PlaitDrawElement.isVectorLine(element)) {\n            return isClosedPoints(element.points);\n        }\n        if (PlaitDrawElement.isGeometry(element)) {\n            return isGeometryClosed(element);\n        }\n        return true;\n    }\n    return false;\n};\n\nexport const isClosedCustomGeometry = (board: PlaitBoard, value: PlaitElement): value is PlaitCustomGeometry => {\n    return PlaitDrawElement.isCustomGeometryElement(board, value) && isClosedPoints(value.points);\n};\n\nexport const getSnappingShape = (board: PlaitBoard, point: Point): PlaitShapeElement | null => {\n    let hitElement: PlaitShapeElement | null = getHitShape(board, point);\n    if (hitElement) {\n        const ref = getSnappingRef(board, hitElement, point);\n        if (ref.isHitConnector || ref.isHitEdge) {\n            return hitElement;\n        }\n    }\n    return null;\n};\n\nexport const getSnappingRef = (board: PlaitBoard, hitElement: PlaitShapeElement, point: Point) => {\n    const rotatedPoint = rotateAntiPointsByElement(board, point, hitElement) || point;\n    const connectorPoint = getHitConnectorPoint(rotatedPoint, hitElement);\n    const edgePoint = getNearestPoint(hitElement, rotatedPoint);\n    const isHitEdge = isHitEdgeOfShape(board, hitElement, rotatedPoint, LINE_SNAPPING_BUFFER);\n    return { isHitEdge, isHitConnector: !!connectorPoint, connectorPoint, edgePoint };\n};\n\nexport const getHitShape = (board: PlaitBoard, point: Point, offset = LINE_HIT_GEOMETRY_BUFFER): PlaitShapeElement | null => {\n    let hitShape: PlaitShapeElement | null = null;\n    traverseDrawShapes(board, (element: PlaitShapeElement) => {\n        if (hitShape === null && isInsideOfShape(board, element, rotateAntiPointsByElement(board, point, element) || point, offset * 2)) {\n            hitShape = element;\n        }\n    });\n    return hitShape;\n};\n\nexport const traverseDrawShapes = (board: PlaitBoard, callback: (element: PlaitShapeElement) => void) => {\n    depthFirstRecursion<Ancestor>(\n        board,\n        (node) => {\n            if (!PlaitBoard.isBoard(node) && PlaitDrawElement.isShapeElement(node)) {\n                callback(node);\n            }\n        },\n        getIsRecursionFunc(board),\n        true\n    );\n};\n\nexport const drawShape = (\n    board: PlaitBoard,\n    outerRectangle: RectangleClient,\n    shape: DrawShapes,\n    roughOptions: Options,\n    drawOptions?: DrawOptions\n) => {\n    return getEngine(shape).draw(board, outerRectangle, roughOptions, drawOptions);\n};\n\nexport const drawBoundReaction = (\n    board: PlaitBoard,\n    element: PlaitShapeElement,\n    roughOptions: { hasMask: boolean; hasConnector: boolean } = { hasMask: true, hasConnector: true }\n) => {\n    const g = createG();\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const activeRectangle = RectangleClient.inflate(rectangle, SNAPPING_STROKE_WIDTH);\n    const shape = getElementShape(element);\n    let drawOptions: DrawOptions | undefined;\n    if (PlaitDrawElement.isElementByTable(element)) {\n        drawOptions = { element };\n    }\n    const strokeG = drawShape(\n        board,\n        activeRectangle,\n        shape,\n        {\n            stroke: SELECTION_BORDER_COLOR,\n            strokeWidth: SNAPPING_STROKE_WIDTH\n        },\n        drawOptions\n    );\n    g.appendChild(strokeG);\n\n    if (roughOptions.hasMask) {\n        const maskG = drawShape(\n            board,\n            activeRectangle,\n            shape,\n            {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: 0,\n                fill: isClosedDrawElement(element) ? SELECTION_FILL_COLOR : DefaultDrawStyle.fill,\n                fillStyle: 'solid'\n            },\n            drawOptions\n        );\n        g.appendChild(maskG);\n    }\n    if (roughOptions.hasConnector) {\n        const connectorPoints = getEngine(shape).getConnectorPoints(rectangle);\n        connectorPoints.forEach((point) => {\n            const circleG = drawCircle(PlaitBoard.getRoughSVG(board), point, 8, {\n                stroke: SELECTION_BORDER_COLOR,\n                strokeWidth: ACTIVE_STROKE_WIDTH,\n                fill: '#FFF',\n                fillStyle: 'solid'\n            });\n            g.appendChild(circleG);\n        });\n    }\n    return g;\n};\n\nexport const getTextKey = (element: PlaitElement | undefined, text: Pick<DrawTextInfo, 'id'>) => {\n    if (element && isMultipleTextGeometry(element)) {\n        return `${element.id}-${text.id}`;\n    } else {\n        return text.id;\n    }\n};\n\nexport const getGeometryAlign = (board: PlaitBoard, element: PlaitCommonGeometry | PlaitBaseTable) => {\n    if (isMultipleTextGeometry(element)) {\n        const drawShapeText = element.texts.find((item) => item.id.includes(GeometryCommonTextKeys.content));\n        return drawShapeText?.text.align || Alignment.center;\n    }\n    if (isSingleTextGeometry(element as PlaitCommonGeometry)) {\n        return (element as PlaitGeometry).text?.align || Alignment.center;\n    }\n\n    if (PlaitDrawElement.isElementByTable(element)) {\n        const firstTextCell = element.cells.find((item) => item.text);\n        return firstTextCell?.text?.align || Alignment.center;\n    }\n    return Alignment.center;\n};\n\nexport const isClosedPoints = (points: Point[]) => {\n    const startPoint = points[0];\n    const endPoint = points[points.length - 1];\n    return startPoint[0] === endPoint[0] && startPoint[1] === endPoint[1];\n};\n\nexport const getDefaultGeometryText = (board: PlaitBoard) => {\n    return getI18nValue(board, DrawI18nKey.geometryText, DefaultTextProperty.text);\n};\n"]}
@@ -1,178 +0,0 @@
1
- import { RectangleClient, idCreator, toActiveRectangleFromViewBoxRectangle } from '@plait/core';
2
- import { BasicShapes } from '../interfaces/geometry';
3
- import { DefaultBasicShapeProperty, DefaultBasicShapePropertyMap, DefaultFlowchartPropertyMap, DefaultTextProperty, DefaultUMLPropertyMap, DrawThemeColors, GEOMETRY_NOT_CLOSED, GEOMETRY_WITHOUT_TEXT, ShapeDefaultSpace, getFlowchartPointers, getUMLPointers } from '../constants';
4
- import { Alignment, DEFAULT_FONT_FAMILY, RESIZE_HANDLE_DIAMETER, buildText, getFirstTextManage, measureElement } from '@plait/common';
5
- import { getEngine } from '../engines';
6
- import { getElementShape } from './shape';
7
- import { PlaitDrawElement } from '../interfaces';
8
- import { getMemorizedLatestByPointer } from './memorize';
9
- import { getTextManage } from '../generators/text.generator';
10
- import { createUMLClassOrInterfaceGeometryElement } from './uml';
11
- import { createMultipleTextGeometryElement, isMultipleTextGeometry, isMultipleTextShape } from './multi-text-geometry';
12
- import { DEFAULT_FONT_SIZE } from '@plait/text-plugins';
13
- export const createGeometryElement = (shape, points, text, options = {}, textProperties = {}) => {
14
- if (GEOMETRY_WITHOUT_TEXT.includes(shape)) {
15
- return createGeometryElementWithoutText(shape, points, options);
16
- }
17
- else {
18
- return createGeometryElementWithText(shape, points, text, options, textProperties);
19
- }
20
- };
21
- export const createGeometryElementWithText = (shape, points, text, options = {}, textProperties = {}) => {
22
- let textOptions = {};
23
- let alignment = Alignment.center;
24
- let textHeight = DefaultTextProperty.height;
25
- if (shape === BasicShapes.text) {
26
- textOptions = { autoSize: true };
27
- alignment = undefined;
28
- }
29
- textProperties = { ...textProperties };
30
- textProperties?.align && (alignment = textProperties?.align);
31
- textProperties?.textHeight && (textHeight = textProperties?.textHeight);
32
- delete textProperties?.align;
33
- delete textProperties?.textHeight;
34
- return {
35
- id: idCreator(),
36
- type: 'geometry',
37
- shape,
38
- angle: 0,
39
- opacity: 1,
40
- textHeight,
41
- text: buildText(text, alignment, textProperties),
42
- points,
43
- ...textOptions,
44
- ...options
45
- };
46
- };
47
- export const createGeometryElementWithoutText = (shape, points, options = {}) => {
48
- return {
49
- id: idCreator(),
50
- type: 'geometry',
51
- shape,
52
- angle: 0,
53
- opacity: 1,
54
- points,
55
- ...options
56
- };
57
- };
58
- export const drawGeometry = (board, outerRectangle, shape, roughOptions) => {
59
- return getEngine(shape).draw(board, outerRectangle, roughOptions);
60
- };
61
- export const getNearestPoint = (element, point) => {
62
- const rectangle = RectangleClient.getRectangleByPoints(element.points);
63
- const shape = getElementShape(element);
64
- return getEngine(shape).getNearestPoint(rectangle, point);
65
- };
66
- export const getCenterPointsOnPolygon = (points) => {
67
- const centerPoint = [];
68
- for (let i = 0; i < points.length; i++) {
69
- let j = i == points.length - 1 ? 0 : i + 1;
70
- centerPoint.push([(points[i][0] + points[j][0]) / 2, (points[i][1] + points[j][1]) / 2]);
71
- }
72
- return centerPoint;
73
- };
74
- export const getDefaultFlowchartProperty = (symbol) => {
75
- return DefaultFlowchartPropertyMap[symbol];
76
- };
77
- export const getDefaultBasicShapeProperty = (shape) => {
78
- return DefaultBasicShapePropertyMap[shape] || DefaultBasicShapeProperty;
79
- };
80
- export const getDefaultUMLProperty = (shape) => {
81
- return DefaultUMLPropertyMap[shape];
82
- };
83
- export const getAutoCompletePoints = (board, element, isToActive = false) => {
84
- const AutoCompleteMargin = (12 + RESIZE_HANDLE_DIAMETER / 2) * 2;
85
- const rectangle = RectangleClient.getRectangleByPoints(element.points);
86
- const activeRectangle = toActiveRectangleFromViewBoxRectangle(board, rectangle);
87
- const targetRectangle = isToActive ? activeRectangle : rectangle;
88
- return RectangleClient.getEdgeCenterPoints(RectangleClient.inflate(targetRectangle, AutoCompleteMargin));
89
- };
90
- export const getHitIndexOfAutoCompletePoint = (movingPoint, points) => {
91
- return points.findIndex((point) => {
92
- const movingRectangle = RectangleClient.getRectangleByPoints([movingPoint]);
93
- let rectangle = RectangleClient.getRectangleByPoints([point]);
94
- rectangle = RectangleClient.inflate(rectangle, RESIZE_HANDLE_DIAMETER);
95
- return RectangleClient.isHit(movingRectangle, rectangle);
96
- });
97
- };
98
- export const getDrawDefaultStrokeColor = (theme) => {
99
- return DrawThemeColors[theme].strokeColor;
100
- };
101
- export const getFlowchartDefaultFill = (theme) => {
102
- return DrawThemeColors[theme].fill;
103
- };
104
- export const getTextShapeProperty = (board, text, fontSize) => {
105
- fontSize = fontSize ? Number(fontSize) : DEFAULT_FONT_SIZE;
106
- const textSize = measureElement(buildText(text), { fontSize, fontFamily: DEFAULT_FONT_FAMILY });
107
- return {
108
- width: textSize.width + ShapeDefaultSpace.rectangleAndText * 2,
109
- height: textSize.height
110
- };
111
- };
112
- export const getDefaultGeometryPoints = (pointer, centerPoint) => {
113
- const property = getDefaultGeometryProperty(pointer);
114
- return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));
115
- };
116
- export const getDefaultGeometryProperty = (pointer) => {
117
- const isFlowChart = getFlowchartPointers().includes(pointer);
118
- const isUML = getUMLPointers().includes(pointer);
119
- if (isFlowChart) {
120
- return getDefaultFlowchartProperty(pointer);
121
- }
122
- else if (isUML) {
123
- return getDefaultUMLProperty(pointer);
124
- }
125
- else {
126
- return getDefaultBasicShapeProperty(pointer);
127
- }
128
- };
129
- export const getDefaultTextPoints = (board, centerPoint, fontSize) => {
130
- const property = getTextShapeProperty(board, DefaultTextProperty.text, fontSize);
131
- return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));
132
- };
133
- export const createTextElement = (board, points, text, textHeight) => {
134
- const memorizedLatest = getMemorizedLatestByPointer(BasicShapes.text);
135
- textHeight = textHeight ? textHeight : RectangleClient.getRectangleByPoints(points).height;
136
- return createGeometryElement(BasicShapes.text, points, text, memorizedLatest.geometryProperties, {
137
- ...memorizedLatest.textProperties,
138
- textHeight
139
- });
140
- };
141
- export const createDefaultGeometry = (board, points, shape) => {
142
- const memorizedLatest = getMemorizedLatestByPointer(shape);
143
- const textHeight = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']).height;
144
- if (PlaitDrawElement.isUMLClassOrInterface({ shape })) {
145
- return createUMLClassOrInterfaceGeometryElement(board, shape, points);
146
- }
147
- if (isMultipleTextShape(shape)) {
148
- return createMultipleTextGeometryElement(shape, points, {
149
- strokeWidth: DefaultBasicShapeProperty.strokeWidth,
150
- ...memorizedLatest.geometryProperties
151
- });
152
- }
153
- else {
154
- return createGeometryElement(shape, points, '', {
155
- strokeWidth: DefaultBasicShapeProperty.strokeWidth,
156
- ...memorizedLatest.geometryProperties
157
- }, { ...memorizedLatest.textProperties, textHeight });
158
- }
159
- };
160
- export const editText = (board, element, text) => {
161
- const textManage = text ? getTextManage(board, element, text) : getFirstTextManage(element);
162
- if (textManage) {
163
- textManage.edit(() => { });
164
- }
165
- };
166
- export const isGeometryIncludeText = (element) => {
167
- return isSingleTextGeometry(element) || isMultipleTextGeometry(element);
168
- };
169
- export const isSingleTextShape = (shape) => {
170
- return !GEOMETRY_WITHOUT_TEXT.includes(shape) && !isMultipleTextShape(shape);
171
- };
172
- export const isSingleTextGeometry = (element) => {
173
- return PlaitDrawElement.isGeometry(element) && isSingleTextShape(element.shape);
174
- };
175
- export const isGeometryClosed = (element) => {
176
- return !GEOMETRY_NOT_CLOSED.includes(element.shape);
177
- };
178
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geometry.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/geometry.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    RectangleClient,\n    ThemeColorMode,\n    getSelectedElements,\n    idCreator,\n    toActiveRectangleFromViewBoxRectangle\n} from '@plait/core';\nimport { GeometryShapes, BasicShapes, PlaitGeometry, FlowchartSymbols, UMLSymbols } from '../interfaces/geometry';\nimport { Element } from 'slate';\nimport {\n    DefaultBasicShapeProperty,\n    DefaultBasicShapePropertyMap,\n    DefaultFlowchartPropertyMap,\n    DefaultTextProperty,\n    DefaultUMLPropertyMap,\n    DrawPointerType,\n    DrawThemeColors,\n    GEOMETRY_NOT_CLOSED,\n    GEOMETRY_WITHOUT_TEXT,\n    ShapeDefaultSpace,\n    getFlowchartPointers,\n    getUMLPointers\n} from '../constants';\nimport {\n    ActiveGenerator,\n    Alignment,\n    CustomText,\n    DEFAULT_FONT_FAMILY,\n    PlaitCommonElementRef,\n    RESIZE_HANDLE_DIAMETER,\n    buildText,\n    getFirstTextManage,\n    measureElement\n} from '@plait/common';\nimport { Options } from 'roughjs/bin/core';\nimport { getEngine } from '../engines';\nimport { getElementShape } from './shape';\nimport { PlaitDrawElement, PlaitShapeElement } from '../interfaces';\nimport { getMemorizedLatestByPointer } from './memorize';\nimport { DrawTextInfo, getTextManage } from '../generators/text.generator';\nimport { createUMLClassOrInterfaceGeometryElement } from './uml';\nimport { createMultipleTextGeometryElement, isMultipleTextGeometry, isMultipleTextShape } from './multi-text-geometry';\nimport { DEFAULT_FONT_SIZE } from '@plait/text-plugins';\n\nexport type GeometryStyleOptions = Pick<PlaitGeometry, 'fill' | 'strokeColor' | 'strokeWidth'>;\n\nexport type TextProperties = Partial<CustomText> & { align?: Alignment; textHeight?: number };\n\nexport const createGeometryElement = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options: GeometryStyleOptions = {},\n    textProperties: TextProperties = {}\n): PlaitGeometry => {\n    if (GEOMETRY_WITHOUT_TEXT.includes(shape)) {\n        return createGeometryElementWithoutText(shape, points, options);\n    } else {\n        return createGeometryElementWithText(shape, points, text, options, textProperties);\n    }\n};\n\nexport const createGeometryElementWithText = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    text: string | Element,\n    options: GeometryStyleOptions = {},\n    textProperties: TextProperties = {}\n): PlaitGeometry => {\n    let textOptions = {};\n    let alignment: undefined | Alignment = Alignment.center;\n    let textHeight = DefaultTextProperty.height;\n    if (shape === BasicShapes.text) {\n        textOptions = { autoSize: true };\n        alignment = undefined;\n    }\n    textProperties = { ...textProperties };\n    textProperties?.align && (alignment = textProperties?.align);\n    textProperties?.textHeight && (textHeight = textProperties?.textHeight);\n    delete textProperties?.align;\n    delete textProperties?.textHeight;\n\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        textHeight,\n        text: buildText(text, alignment, textProperties),\n        points,\n        ...textOptions,\n        ...options\n    };\n};\n\nexport const createGeometryElementWithoutText = (\n    shape: GeometryShapes,\n    points: [Point, Point],\n    options: GeometryStyleOptions = {}\n): PlaitGeometry => {\n    return {\n        id: idCreator(),\n        type: 'geometry',\n        shape,\n        angle: 0,\n        opacity: 1,\n        points,\n        ...options\n    };\n};\n\nexport const drawGeometry = (board: PlaitBoard, outerRectangle: RectangleClient, shape: GeometryShapes, roughOptions: Options) => {\n    return getEngine(shape).draw(board, outerRectangle, roughOptions);\n};\n\nexport const getNearestPoint = (element: PlaitShapeElement, point: Point) => {\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const shape = getElementShape(element);\n    return getEngine(shape).getNearestPoint(rectangle, 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 getDefaultFlowchartProperty = (symbol: FlowchartSymbols) => {\n    return DefaultFlowchartPropertyMap[symbol];\n};\n\nexport const getDefaultBasicShapeProperty = (shape: BasicShapes) => {\n    return DefaultBasicShapePropertyMap[shape] || DefaultBasicShapeProperty;\n};\n\nexport const getDefaultUMLProperty = (shape: UMLSymbols) => {\n    return DefaultUMLPropertyMap[shape];\n};\n\nexport const getAutoCompletePoints = (board: PlaitBoard, element: PlaitShapeElement, isToActive = false) => {\n    const AutoCompleteMargin = (12 + RESIZE_HANDLE_DIAMETER / 2) * 2;\n    const rectangle = RectangleClient.getRectangleByPoints(element.points);\n    const activeRectangle = toActiveRectangleFromViewBoxRectangle(board, rectangle);\n    const targetRectangle = isToActive ? activeRectangle : rectangle;\n    return RectangleClient.getEdgeCenterPoints(RectangleClient.inflate(targetRectangle, AutoCompleteMargin));\n};\n\nexport const getHitIndexOfAutoCompletePoint = (movingPoint: Point, points: Point[]) => {\n    return points.findIndex((point) => {\n        const movingRectangle = RectangleClient.getRectangleByPoints([movingPoint]);\n        let rectangle = RectangleClient.getRectangleByPoints([point]);\n        rectangle = RectangleClient.inflate(rectangle, RESIZE_HANDLE_DIAMETER);\n        return RectangleClient.isHit(movingRectangle, rectangle);\n    });\n};\n\nexport const getDrawDefaultStrokeColor = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].strokeColor;\n};\n\nexport const getFlowchartDefaultFill = (theme: ThemeColorMode) => {\n    return DrawThemeColors[theme].fill;\n};\n\nexport const getTextShapeProperty = (board: PlaitBoard, text: string | Element, fontSize?: number | string) => {\n    fontSize = fontSize ? Number(fontSize) : DEFAULT_FONT_SIZE;\n    const textSize = measureElement(buildText(text), { fontSize, fontFamily: DEFAULT_FONT_FAMILY });\n    return {\n        width: textSize.width + ShapeDefaultSpace.rectangleAndText * 2,\n        height: textSize.height\n    };\n};\n\nexport const getDefaultGeometryPoints = (pointer: DrawPointerType, centerPoint: Point) => {\n    const property = getDefaultGeometryProperty(pointer);\n    return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));\n};\n\nexport const getDefaultGeometryProperty = (pointer: DrawPointerType) => {\n    const isFlowChart = getFlowchartPointers().includes(pointer);\n    const isUML = getUMLPointers().includes(pointer);\n    if (isFlowChart) {\n        return getDefaultFlowchartProperty(pointer as FlowchartSymbols);\n    } else if (isUML) {\n        return getDefaultUMLProperty(pointer as UMLSymbols);\n    } else {\n        return getDefaultBasicShapeProperty(pointer as BasicShapes);\n    }\n};\n\nexport const getDefaultTextPoints = (board: PlaitBoard, centerPoint: Point, fontSize?: number | string) => {\n    const property = getTextShapeProperty(board, DefaultTextProperty.text, fontSize);\n    return RectangleClient.getPoints(RectangleClient.getRectangleByCenterPoint(centerPoint, property.width, property.height));\n};\n\nexport const createTextElement = (board: PlaitBoard, points: [Point, Point], text: string | Element, textHeight?: number) => {\n    const memorizedLatest = getMemorizedLatestByPointer(BasicShapes.text);\n    textHeight = textHeight ? textHeight : RectangleClient.getRectangleByPoints(points).height;\n    return createGeometryElement(BasicShapes.text, points, text, memorizedLatest.geometryProperties as GeometryStyleOptions, {\n        ...memorizedLatest.textProperties,\n        textHeight\n    });\n};\n\nexport const createDefaultGeometry = (board: PlaitBoard, points: [Point, Point], shape: GeometryShapes) => {\n    const memorizedLatest = getMemorizedLatestByPointer(shape);\n    const textHeight = getTextShapeProperty(board, DefaultTextProperty.text, memorizedLatest.textProperties['font-size']).height;\n    if (PlaitDrawElement.isUMLClassOrInterface({ shape })) {\n        return createUMLClassOrInterfaceGeometryElement(board, shape, points);\n    }\n    if (isMultipleTextShape(shape)) {\n        return createMultipleTextGeometryElement(shape, points, {\n            strokeWidth: DefaultBasicShapeProperty.strokeWidth,\n            ...(memorizedLatest.geometryProperties as GeometryStyleOptions)\n        });\n    } else {\n        return createGeometryElement(\n            shape,\n            points,\n            '',\n            {\n                strokeWidth: DefaultBasicShapeProperty.strokeWidth,\n                ...(memorizedLatest.geometryProperties as GeometryStyleOptions)\n            },\n            { ...memorizedLatest.textProperties, textHeight }\n        );\n    }\n};\n\nexport const editText = (board: PlaitBoard, element: PlaitGeometry, text?: DrawTextInfo) => {\n    const textManage = text ? getTextManage(board, element, text) : getFirstTextManage(element);\n    if (textManage) {\n        textManage.edit(() => {});\n    }\n};\n\nexport const isGeometryIncludeText = (element: PlaitGeometry) => {\n    return isSingleTextGeometry(element) || isMultipleTextGeometry(element);\n};\n\nexport const isSingleTextShape = (shape: GeometryShapes) => {\n    return !GEOMETRY_WITHOUT_TEXT.includes(shape) && !isMultipleTextShape(shape);\n};\n\nexport const isSingleTextGeometry = (element: PlaitGeometry) => {\n    return PlaitDrawElement.isGeometry(element) && isSingleTextShape(element.shape);\n};\n\nexport const isGeometryClosed = (element: PlaitGeometry) => {\n    return !GEOMETRY_NOT_CLOSED.includes(element.shape);\n};\n"]}