@plait/draw 0.1.0-next.9 → 0.28.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 (106) hide show
  1. package/constants/image.d.ts +1 -0
  2. package/constants/index.d.ts +1 -0
  3. package/constants/pointer.d.ts +4 -10
  4. package/engines/comment.d.ts +4 -0
  5. package/engines/cross.d.ts +4 -0
  6. package/{utils/engine → engines}/diamond.d.ts +1 -1
  7. package/{utils/engine → engines}/ellipse.d.ts +1 -1
  8. package/engines/hexagon.d.ts +4 -0
  9. package/{utils/engine → engines}/index.d.ts +1 -1
  10. package/engines/left-arrow.d.ts +4 -0
  11. package/engines/octagon.d.ts +4 -0
  12. package/engines/parallelogram.d.ts +4 -0
  13. package/engines/pentagon-arrow.d.ts +4 -0
  14. package/engines/pentagon.d.ts +4 -0
  15. package/engines/process-arrow.d.ts +4 -0
  16. package/{utils/engine → engines}/rectangle.d.ts +1 -1
  17. package/engines/right-arrow.d.ts +4 -0
  18. package/engines/round-comment.d.ts +4 -0
  19. package/{utils/engine → engines}/round-rectangle.d.ts +1 -1
  20. package/engines/star.d.ts +4 -0
  21. package/engines/trapezoid.d.ts +4 -0
  22. package/engines/triangle.d.ts +4 -0
  23. package/engines/two-way-arrow.d.ts +4 -0
  24. package/esm2022/constants/geometry.mjs +3 -3
  25. package/esm2022/constants/image.mjs +2 -0
  26. package/esm2022/constants/index.mjs +2 -1
  27. package/esm2022/constants/pointer.mjs +8 -19
  28. package/esm2022/engines/comment.mjs +57 -0
  29. package/esm2022/engines/cross.mjs +46 -0
  30. package/esm2022/engines/diamond.mjs +30 -0
  31. package/esm2022/engines/ellipse.mjs +92 -0
  32. package/esm2022/engines/hexagon.mjs +40 -0
  33. package/esm2022/engines/index.mjs +46 -0
  34. package/esm2022/engines/left-arrow.mjs +45 -0
  35. package/esm2022/engines/octagon.mjs +42 -0
  36. package/esm2022/engines/parallelogram.mjs +39 -0
  37. package/esm2022/engines/pentagon-arrow.mjs +39 -0
  38. package/esm2022/engines/pentagon.mjs +39 -0
  39. package/esm2022/engines/process-arrow.mjs +41 -0
  40. package/esm2022/engines/rectangle.mjs +26 -0
  41. package/esm2022/engines/right-arrow.mjs +45 -0
  42. package/esm2022/engines/round-comment.mjs +81 -0
  43. package/esm2022/engines/round-rectangle.mjs +59 -0
  44. package/esm2022/engines/star.mjs +45 -0
  45. package/esm2022/engines/trapezoid.mjs +40 -0
  46. package/esm2022/engines/triangle.mjs +40 -0
  47. package/esm2022/engines/two-way-arrow.mjs +48 -0
  48. package/esm2022/generators/geometry-shape.generator.mjs +7 -2
  49. package/esm2022/generators/line-active.generator.mjs +71 -22
  50. package/esm2022/generators/line.generator.mjs +2 -11
  51. package/esm2022/geometry.component.mjs +13 -7
  52. package/esm2022/image.component.mjs +70 -0
  53. package/esm2022/interfaces/geometry.mjs +15 -1
  54. package/esm2022/interfaces/image.mjs +2 -0
  55. package/esm2022/interfaces/index.mjs +8 -2
  56. package/esm2022/interfaces/line.mjs +27 -4
  57. package/esm2022/line.component.mjs +15 -6
  58. package/esm2022/plugins/with-draw-fragment.mjs +37 -7
  59. package/esm2022/plugins/with-draw.mjs +38 -10
  60. package/esm2022/plugins/with-geometry-create.mjs +15 -12
  61. package/esm2022/plugins/with-geometry-resize.mjs +28 -20
  62. package/esm2022/plugins/with-line-bound-reaction.mjs +10 -5
  63. package/esm2022/plugins/with-line-create.mjs +7 -5
  64. package/esm2022/plugins/with-line-resize.mjs +12 -4
  65. package/esm2022/transforms/geometry-text.mjs +1 -1
  66. package/esm2022/transforms/image.mjs +23 -0
  67. package/esm2022/transforms/index.mjs +4 -2
  68. package/esm2022/utils/clipboard.mjs +4 -3
  69. package/esm2022/utils/geometry.mjs +20 -6
  70. package/esm2022/utils/index.mjs +1 -1
  71. package/esm2022/utils/line-arrow.mjs +43 -18
  72. package/esm2022/utils/line.mjs +202 -51
  73. package/esm2022/utils/position/geometry.mjs +5 -4
  74. package/esm2022/utils/position/line.mjs +32 -22
  75. package/esm2022/utils/selected.mjs +5 -1
  76. package/esm2022/utils/shape.mjs +8 -0
  77. package/fesm2022/plait-draw.mjs +1439 -280
  78. package/fesm2022/plait-draw.mjs.map +1 -1
  79. package/generators/line-active.generator.d.ts +3 -0
  80. package/generators/line.generator.d.ts +1 -1
  81. package/geometry.component.d.ts +1 -1
  82. package/image.component.d.ts +20 -0
  83. package/interfaces/geometry.d.ts +20 -2
  84. package/interfaces/image.d.ts +7 -0
  85. package/interfaces/index.d.ts +5 -1
  86. package/interfaces/line.d.ts +19 -5
  87. package/line.component.d.ts +2 -1
  88. package/package.json +3 -2
  89. package/plugins/with-draw-fragment.d.ts +2 -0
  90. package/plugins/with-geometry-create.d.ts +1 -1
  91. package/styles/styles.scss +2 -2
  92. package/transforms/image.d.ts +3 -0
  93. package/transforms/index.d.ts +1 -0
  94. package/utils/geometry.d.ts +1 -0
  95. package/utils/line.d.ts +14 -6
  96. package/utils/position/geometry.d.ts +2 -1
  97. package/utils/position/line.d.ts +7 -3
  98. package/utils/selected.d.ts +2 -0
  99. package/utils/shape.d.ts +2 -0
  100. package/esm2022/utils/engine/diamond.mjs +0 -22
  101. package/esm2022/utils/engine/ellipse.mjs +0 -55
  102. package/esm2022/utils/engine/index.mjs +0 -18
  103. package/esm2022/utils/engine/parallelogram.mjs +0 -32
  104. package/esm2022/utils/engine/rectangle.mjs +0 -18
  105. package/esm2022/utils/engine/round-rectangle.mjs +0 -49
  106. package/utils/engine/parallelogram.d.ts +0 -4
@@ -5,27 +5,43 @@ import { getTextFromClipboard, getTextSize } from '@plait/text';
5
5
  import { buildClipboardData, insertClipboardData } from '../utils/clipboard';
6
6
  import { DrawTransforms } from '../transforms';
7
7
  import { getBoardLines } from '../utils/line';
8
+ import { acceptImageTypes, buildImage } from '@plait/common';
9
+ import { DEFAULT_IMAGE_WIDTH } from '../constants';
8
10
  export const withDrawFragment = (baseBoard) => {
9
11
  const board = baseBoard;
10
12
  const { getDeletedFragment, setFragment, insertFragment } = board;
11
13
  board.getDeletedFragment = (data) => {
12
14
  const drawElements = getSelectedDrawElements(board);
13
15
  if (drawElements.length) {
14
- const lines = getBoardLines(board);
15
16
  const geometryElements = drawElements.filter(value => PlaitDrawElement.isGeometry(value));
16
17
  const lineElements = drawElements.filter(value => PlaitDrawElement.isLine(value));
17
- const boundLineElements = lines.filter(line => geometryElements.find(geometry => PlaitLine.isBoundElementOfSource(line, geometry) || PlaitLine.isBoundElementOfTarget(line, geometry)));
18
- data.push(...[...geometryElements, ...lineElements, ...boundLineElements.filter(line => !lineElements.includes(line))]);
18
+ const imageElements = drawElements.filter(value => PlaitDrawElement.isImage(value));
19
+ const boundLineElements = [
20
+ ...getBoundedLineElements(board, geometryElements),
21
+ ...getBoundedLineElements(board, imageElements)
22
+ ].filter(line => !lineElements.includes(line));
23
+ data.push(...[
24
+ ...geometryElements,
25
+ ...lineElements,
26
+ ...imageElements,
27
+ ...boundLineElements.filter(line => !lineElements.includes(line))
28
+ ]);
19
29
  }
20
30
  return getDeletedFragment(data);
21
31
  };
22
- board.setFragment = (data, rectangle) => {
32
+ board.setFragment = (data, rectangle, type) => {
23
33
  const targetDrawElements = getSelectedDrawElements(board);
34
+ let boundLineElements = [];
24
35
  if (targetDrawElements.length) {
25
- const elements = buildClipboardData(board, targetDrawElements, rectangle ? [rectangle.x, rectangle.y] : [0, 0]);
36
+ if (type === 'cut') {
37
+ const geometryElements = targetDrawElements.filter(value => PlaitDrawElement.isGeometry(value));
38
+ const lineElements = targetDrawElements.filter(value => PlaitDrawElement.isLine(value));
39
+ boundLineElements = getBoundedLineElements(board, geometryElements).filter(line => !lineElements.includes(line));
40
+ }
41
+ const elements = buildClipboardData(board, [...targetDrawElements, ...boundLineElements], rectangle ? [rectangle.x, rectangle.y] : [0, 0]);
26
42
  setClipboardData(data, elements);
27
43
  }
28
- setFragment(data, rectangle);
44
+ setFragment(data, rectangle, type);
29
45
  };
30
46
  board.insertFragment = (data, targetPoint) => {
31
47
  const elements = getDataFromClipboard(data);
@@ -45,8 +61,22 @@ export const withDrawFragment = (baseBoard) => {
45
61
  return;
46
62
  }
47
63
  }
64
+ if (data?.files.length) {
65
+ const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);
66
+ if (acceptImageArray.includes(data?.files[0].type)) {
67
+ const imageFile = data.files[0];
68
+ buildImage(board, imageFile, DEFAULT_IMAGE_WIDTH, imageItem => {
69
+ DrawTransforms.insertImage(board, imageItem, targetPoint);
70
+ });
71
+ return;
72
+ }
73
+ }
48
74
  insertFragment(data, targetPoint);
49
75
  };
50
76
  return board;
51
77
  };
52
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-draw-fragment.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-draw-fragment.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient, getDataFromClipboard, getSelectedElements, setClipboardData } from '@plait/core';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { PlaitDrawElement, PlaitGeometry, PlaitLine } from '../interfaces';\nimport { getTextFromClipboard, getTextSize } from '@plait/text';\nimport { buildClipboardData, insertClipboardData } from '../utils/clipboard';\nimport { DrawTransforms } from '../transforms';\nimport { getBoardLines } from '../utils/line';\n\nexport const withDrawFragment = (baseBoard: PlaitBoard) => {\n    const board = baseBoard as PlaitBoard;\n    const { getDeletedFragment, setFragment, insertFragment } = board;\n\n    board.getDeletedFragment = (data: PlaitElement[]) => {\n        const drawElements = getSelectedDrawElements(board);\n        if (drawElements.length) {\n            const lines = getBoardLines(board);\n            const geometryElements = drawElements.filter(value => PlaitDrawElement.isGeometry(value)) as PlaitGeometry[];\n            const lineElements = drawElements.filter(value => PlaitDrawElement.isLine(value)) as PlaitLine[];\n            const boundLineElements = lines.filter(line =>\n                geometryElements.find(\n                    geometry => PlaitLine.isBoundElementOfSource(line, geometry) || PlaitLine.isBoundElementOfTarget(line, geometry)\n                )\n            );\n            data.push(...[...geometryElements, ...lineElements, ...boundLineElements.filter(line => !lineElements.includes(line))]);\n        }\n        return getDeletedFragment(data);\n    };\n\n    board.setFragment = (data: DataTransfer | null, rectangle: RectangleClient | null) => {\n        const targetDrawElements = getSelectedDrawElements(board);\n        if (targetDrawElements.length) {\n            const elements = buildClipboardData(board, targetDrawElements, rectangle ? [rectangle.x, rectangle.y] : [0, 0]);\n            setClipboardData(data, elements);\n        }\n        setFragment(data, rectangle);\n    };\n\n    board.insertFragment = (data: DataTransfer | null, targetPoint: Point) => {\n        const elements = getDataFromClipboard(data);\n        const drawElements = elements.filter(value => PlaitDrawElement.isDrawElement(value)) as PlaitDrawElement[];\n        if (elements.length > 0 && drawElements.length > 0) {\n            insertClipboardData(board, drawElements, targetPoint);\n        } else if (elements.length === 0) {\n            const text = getTextFromClipboard(data);\n            const selectedElements = getSelectedElements(board);\n            // (*￣︶￣)\n            const insertAsChildren = selectedElements.length === 1 && selectedElements[0].children;\n            const insertAsFreeText = !insertAsChildren;\n            if (text && insertAsFreeText) {\n                const { width, height } = getTextSize(board, text);\n                DrawTransforms.insertText(board, [targetPoint, [targetPoint[0] + width, targetPoint[1] + height]], text);\n                return;\n            }\n        }\n        insertFragment(data, targetPoint);\n    };\n\n    return board;\n};\n"]}
78
+ export const getBoundedLineElements = (board, plaitShapes) => {
79
+ const lines = getBoardLines(board);
80
+ return lines.filter(line => plaitShapes.find(shape => PlaitLine.isBoundElementOfSource(line, shape) || PlaitLine.isBoundElementOfTarget(line, shape)));
81
+ };
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-draw-fragment.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-draw-fragment.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, RectangleClient, getDataFromClipboard, getSelectedElements, setClipboardData } from '@plait/core';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { PlaitDrawElement, PlaitGeometry, PlaitLine, PlaitShape } from '../interfaces';\nimport { getTextFromClipboard, getTextSize } from '@plait/text';\nimport { buildClipboardData, insertClipboardData } from '../utils/clipboard';\nimport { DrawTransforms } from '../transforms';\nimport { getBoardLines } from '../utils/line';\nimport { PlaitImage } from '../interfaces/image';\nimport { acceptImageTypes, buildImage } from '@plait/common';\nimport { DEFAULT_IMAGE_WIDTH } from '../constants';\n\nexport const withDrawFragment = (baseBoard: PlaitBoard) => {\n    const board = baseBoard as PlaitBoard;\n    const { getDeletedFragment, setFragment, insertFragment } = board;\n\n    board.getDeletedFragment = (data: PlaitElement[]) => {\n        const drawElements = getSelectedDrawElements(board);\n        if (drawElements.length) {\n            const geometryElements = drawElements.filter(value => PlaitDrawElement.isGeometry(value)) as PlaitGeometry[];\n            const lineElements = drawElements.filter(value => PlaitDrawElement.isLine(value)) as PlaitLine[];\n            const imageElements = drawElements.filter(value => PlaitDrawElement.isImage(value)) as PlaitImage[];\n\n            const boundLineElements = [\n                ...getBoundedLineElements(board, geometryElements),\n                ...getBoundedLineElements(board, imageElements)\n            ].filter(line => !lineElements.includes(line));\n            data.push(\n                ...[\n                    ...geometryElements,\n                    ...lineElements,\n                    ...imageElements,\n                    ...boundLineElements.filter(line => !lineElements.includes(line))\n                ]\n            );\n        }\n        return getDeletedFragment(data);\n    };\n\n    board.setFragment = (data: DataTransfer | null, rectangle: RectangleClient | null, type: 'copy' | 'cut') => {\n        const targetDrawElements = getSelectedDrawElements(board);\n        let boundLineElements: PlaitLine[] = [];\n        if (targetDrawElements.length) {\n            if (type === 'cut') {\n                const geometryElements = targetDrawElements.filter(value => PlaitDrawElement.isGeometry(value)) as PlaitGeometry[];\n                const lineElements = targetDrawElements.filter(value => PlaitDrawElement.isLine(value)) as PlaitLine[];\n                boundLineElements = getBoundedLineElements(board, geometryElements).filter(line => !lineElements.includes(line));\n            }\n            const elements = buildClipboardData(\n                board,\n                [...targetDrawElements, ...boundLineElements],\n                rectangle ? [rectangle.x, rectangle.y] : [0, 0]\n            );\n            setClipboardData(data, elements);\n        }\n        setFragment(data, rectangle, type);\n    };\n\n    board.insertFragment = (data: DataTransfer | null, targetPoint: Point) => {\n        const elements = getDataFromClipboard(data);\n        const drawElements = elements.filter(value => PlaitDrawElement.isDrawElement(value)) as PlaitDrawElement[];\n        if (elements.length > 0 && drawElements.length > 0) {\n            insertClipboardData(board, drawElements, targetPoint);\n        } else if (elements.length === 0) {\n            const text = getTextFromClipboard(data);\n            const selectedElements = getSelectedElements(board);\n            // (*￣︶￣)\n            const insertAsChildren = selectedElements.length === 1 && selectedElements[0].children;\n            const insertAsFreeText = !insertAsChildren;\n            if (text && insertAsFreeText) {\n                const { width, height } = getTextSize(board, text);\n                DrawTransforms.insertText(board, [targetPoint, [targetPoint[0] + width, targetPoint[1] + height]], text);\n                return;\n            }\n        }\n\n        if (data?.files.length) {\n            const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);\n            if (acceptImageArray.includes(data?.files[0].type)) {\n                const imageFile = data.files[0];\n                buildImage(board, imageFile, DEFAULT_IMAGE_WIDTH, imageItem => {\n                    DrawTransforms.insertImage(board, imageItem, targetPoint);\n                });\n                return;\n            }\n        }\n\n        insertFragment(data, targetPoint);\n    };\n\n    return board;\n};\n\nexport const getBoundedLineElements = (board: PlaitBoard, plaitShapes: PlaitShape[]) => {\n    const lines = getBoardLines(board);\n    return lines.filter(line =>\n        plaitShapes.find(shape => PlaitLine.isBoundElementOfSource(line, shape) || PlaitLine.isBoundElementOfTarget(line, shape))\n    );\n};\n"]}
@@ -1,20 +1,21 @@
1
- import { RectangleClient, isPolylineHitRectangle } from '@plait/core';
1
+ import { RectangleClient, getSelectedElements, isPolylineHitRectangle } from '@plait/core';
2
2
  import { GeometryComponent } from '../geometry.component';
3
3
  import { LineComponent } from '../line.component';
4
4
  import { PlaitDrawElement } from '../interfaces';
5
5
  import { getRectangleByPoints } from '@plait/common';
6
6
  import { withDrawHotkey } from './with-draw-hotkey';
7
- import { withGeometryCreateByDraw, withGeometryCreateByDrag } from './with-geometry-create';
7
+ import { withGeometryCreateByDrawing, withGeometryCreateByDrag } from './with-geometry-create';
8
8
  import { withDrawFragment } from './with-draw-fragment';
9
- import { getTextRectangle, isHitPolyLine, isHitLineText, getTargetPoint, getSourcePoint, getLinePoints } from '../utils';
9
+ import { getTextRectangle, isHitPolyLine, isHitLineText, getLinePoints } from '../utils';
10
10
  import { getStrokeWidthByElement } from '../utils/style/stroke';
11
11
  import { withLineCreateByDraw } from './with-line-create';
12
12
  import { withGeometryResize } from './with-geometry-resize';
13
13
  import { withLineResize } from './with-line-resize';
14
14
  import { withLineBoundReaction } from './with-line-bound-reaction';
15
15
  import { withLineText } from './with-line-text';
16
+ import { ImageComponent } from '../image.component';
16
17
  export const withDraw = (board) => {
17
- const { drawElement, getRectangle, isHitSelection, isMovable, dblclick } = board;
18
+ const { drawElement, getRectangle, isHitSelection, isMovable, isAlign } = board;
18
19
  board.drawElement = (context) => {
19
20
  if (PlaitDrawElement.isGeometry(context.element)) {
20
21
  return GeometryComponent;
@@ -22,6 +23,9 @@ export const withDraw = (board) => {
22
23
  else if (PlaitDrawElement.isLine(context.element)) {
23
24
  return LineComponent;
24
25
  }
26
+ else if (PlaitDrawElement.isImage(context.element)) {
27
+ return ImageComponent;
28
+ }
25
29
  return drawElement(context);
26
30
  };
27
31
  board.getRectangle = (element) => {
@@ -29,9 +33,11 @@ export const withDraw = (board) => {
29
33
  return getRectangleByPoints(element.points);
30
34
  }
31
35
  if (PlaitDrawElement.isLine(element)) {
32
- const source = getSourcePoint(board, element);
33
- const target = getTargetPoint(board, element);
34
- return getRectangleByPoints([source, target]);
36
+ const points = getLinePoints(board, element);
37
+ return getRectangleByPoints(points);
38
+ }
39
+ if (PlaitDrawElement.isImage(element)) {
40
+ return getRectangleByPoints(element.points);
35
41
  }
36
42
  return getRectangle(element);
37
43
  };
@@ -45,6 +51,11 @@ export const withDraw = (board) => {
45
51
  }
46
52
  return RectangleClient.isHit(rangeRectangle, client);
47
53
  }
54
+ if (PlaitDrawElement.isImage(element)) {
55
+ const client = getRectangleByPoints(element.points);
56
+ const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);
57
+ return RectangleClient.isHit(rangeRectangle, client);
58
+ }
48
59
  if (PlaitDrawElement.isLine(element)) {
49
60
  const points = getLinePoints(board, element);
50
61
  const strokeWidth = getStrokeWidthByElement(element);
@@ -63,11 +74,28 @@ export const withDraw = (board) => {
63
74
  if (PlaitDrawElement.isGeometry(element)) {
64
75
  return true;
65
76
  }
77
+ if (PlaitDrawElement.isImage(element)) {
78
+ return true;
79
+ }
66
80
  if (PlaitDrawElement.isLine(element)) {
67
- return !element.source.boundId && !element.target.boundId;
81
+ const selectedElements = getSelectedElements(board);
82
+ const isSelected = (boundId) => {
83
+ return !!selectedElements.find(value => value.id === boundId);
84
+ };
85
+ if ((element.source.boundId && !isSelected(element.source.boundId)) ||
86
+ (element.target.boundId && !isSelected(element.target.boundId))) {
87
+ return false;
88
+ }
89
+ return true;
68
90
  }
69
91
  return isMovable(element);
70
92
  };
71
- return withLineText(withLineBoundReaction(withLineResize(withGeometryResize(withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDraw(withDrawFragment(withDrawHotkey(board)))))))));
93
+ board.isAlign = (element) => {
94
+ if (PlaitDrawElement.isGeometry(element) || PlaitDrawElement.isImage(element)) {
95
+ return true;
96
+ }
97
+ return isAlign(element);
98
+ };
99
+ return withLineText(withLineBoundReaction(withLineResize(withGeometryResize(withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDrawing(withDrawFragment(withDrawHotkey(board)))))))));
72
100
  };
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-draw.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-draw.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, PlaitPluginElementContext, Range, RectangleClient, isPolylineHitRectangle } from '@plait/core';\nimport { GeometryComponent } from '../geometry.component';\nimport { LineComponent } from '../line.component';\nimport { PlaitDrawElement } from '../interfaces';\nimport { getRectangleByPoints } from '@plait/common';\nimport { withDrawHotkey } from './with-draw-hotkey';\nimport { withGeometryCreateByDraw, withGeometryCreateByDrag } from './with-geometry-create';\nimport { withDrawFragment } from './with-draw-fragment';\nimport { getTextRectangle, isHitPolyLine, isHitLineText, getTargetPoint, getSourcePoint, getLinePoints } from '../utils';\nimport { getStrokeWidthByElement } from '../utils/style/stroke';\nimport { withLineCreateByDraw } from './with-line-create';\nimport { withGeometryResize } from './with-geometry-resize';\nimport { withLineResize } from './with-line-resize';\nimport { withLineBoundReaction } from './with-line-bound-reaction';\nimport { withLineText } from './with-line-text';\n\nexport const withDraw = (board: PlaitBoard) => {\n    const { drawElement, getRectangle, isHitSelection, isMovable, dblclick } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitDrawElement.isGeometry(context.element)) {\n            return GeometryComponent;\n        } else if (PlaitDrawElement.isLine(context.element)) {\n            return LineComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.getRectangle = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return getRectangleByPoints(element.points);\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const source = getSourcePoint(board, element);\n            const target = getTargetPoint(board, element);\n            return getRectangleByPoints([source, target]);\n        }\n        return getRectangle(element);\n    };\n\n    board.isHitSelection = (element: PlaitElement, range: Range) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            const client = getRectangleByPoints(element.points);\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            if (element.textHeight > client.height) {\n                const textClient = getTextRectangle(element);\n                return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);\n            }\n            return RectangleClient.isHit(rangeRectangle, client);\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const points = getLinePoints(board, element);\n            const strokeWidth = getStrokeWidthByElement(element);\n            const isHitText = isHitLineText(board, element, range.focus);\n            const isHit = isHitPolyLine(points, range.focus, strokeWidth, 3) || isHitText;\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            const isContainPolyLinePoint = points.some(point => {\n                return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));\n            });\n            const isIntersect = range.anchor === range.focus ? isHit : isPolylineHitRectangle(points, rangeRectangle);\n            return isContainPolyLinePoint || isIntersect;\n        }\n\n        return isHitSelection(element, range);\n    };\n\n    board.isMovable = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return true;\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            return !element.source.boundId && !element.target.boundId;\n        }\n        return isMovable(element);\n    };\n\n    return withLineText(\n        withLineBoundReaction(\n            withLineResize(\n                withGeometryResize(\n                    withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDraw(withDrawFragment(withDrawHotkey(board)))))\n                )\n            )\n        )\n    );\n};\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-draw.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-draw.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitElement,\n    PlaitPluginElementContext,\n    Range,\n    RectangleClient,\n    getSelectedElements,\n    isPolylineHitRectangle\n} from '@plait/core';\nimport { GeometryComponent } from '../geometry.component';\nimport { LineComponent } from '../line.component';\nimport { PlaitDrawElement } from '../interfaces';\nimport { getRectangleByPoints } from '@plait/common';\nimport { withDrawHotkey } from './with-draw-hotkey';\nimport { withGeometryCreateByDrawing, withGeometryCreateByDrag } from './with-geometry-create';\nimport { withDrawFragment } from './with-draw-fragment';\nimport { getTextRectangle, isHitPolyLine, isHitLineText, getLinePoints } from '../utils';\nimport { getStrokeWidthByElement } from '../utils/style/stroke';\nimport { withLineCreateByDraw } from './with-line-create';\nimport { withGeometryResize } from './with-geometry-resize';\nimport { withLineResize } from './with-line-resize';\nimport { withLineBoundReaction } from './with-line-bound-reaction';\nimport { withLineText } from './with-line-text';\nimport { ImageComponent } from '../image.component';\n\nexport const withDraw = (board: PlaitBoard) => {\n    const { drawElement, getRectangle, isHitSelection, isMovable, isAlign } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitDrawElement.isGeometry(context.element)) {\n            return GeometryComponent;\n        } else if (PlaitDrawElement.isLine(context.element)) {\n            return LineComponent;\n        } else if (PlaitDrawElement.isImage(context.element)) {\n            return ImageComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.getRectangle = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return getRectangleByPoints(element.points);\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const points = getLinePoints(board, element);\n            return getRectangleByPoints(points);\n        }\n        if (PlaitDrawElement.isImage(element)) {\n            return getRectangleByPoints(element.points);\n        }\n        return getRectangle(element);\n    };\n\n    board.isHitSelection = (element: PlaitElement, range: Range) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            const client = getRectangleByPoints(element.points);\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            if (element.textHeight > client.height) {\n                const textClient = getTextRectangle(element);\n                return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);\n            }\n            return RectangleClient.isHit(rangeRectangle, client);\n        }\n        if (PlaitDrawElement.isImage(element)) {\n            const client = getRectangleByPoints(element.points);\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            return RectangleClient.isHit(rangeRectangle, client);\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const points = getLinePoints(board, element);\n            const strokeWidth = getStrokeWidthByElement(element);\n            const isHitText = isHitLineText(board, element, range.focus);\n            const isHit = isHitPolyLine(points, range.focus, strokeWidth, 3) || isHitText;\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            const isContainPolyLinePoint = points.some(point => {\n                return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));\n            });\n            const isIntersect = range.anchor === range.focus ? isHit : isPolylineHitRectangle(points, rangeRectangle);\n            return isContainPolyLinePoint || isIntersect;\n        }\n\n        return isHitSelection(element, range);\n    };\n\n    board.isMovable = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return true;\n        }\n        if (PlaitDrawElement.isImage(element)) {\n            return true;\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const selectedElements = getSelectedElements(board);\n            const isSelected = (boundId: string) => {\n                return !!selectedElements.find(value => value.id === boundId);\n            };\n            if (\n                (element.source.boundId && !isSelected(element.source.boundId)) ||\n                (element.target.boundId && !isSelected(element.target.boundId))\n            ) {\n                return false;\n            }\n            return true;\n        }\n        return isMovable(element);\n    };\n\n    board.isAlign = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element) || PlaitDrawElement.isImage(element)) {\n            return true;\n        }\n        return isAlign(element);\n    };\n\n    return withLineText(\n        withLineBoundReaction(\n            withLineResize(\n                withGeometryResize(\n                    withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDrawing(withDrawFragment(withDrawHotkey(board)))))\n                )\n            )\n        )\n    );\n};\n"]}
@@ -2,7 +2,7 @@ import { BoardTransforms, PlaitBoard, PlaitPointerType, RectangleClient, Transfo
2
2
  import { GeometryShape } from '../interfaces';
3
3
  import { GeometryShapeGenerator } from '../generators/geometry-shape.generator';
4
4
  import { createGeometryElement, getPointsByCenterPoint } from '../utils';
5
- import { DefaultGeometryProperty, DefaultTextProperty, DrawPointerType, GeometryPointer, ShapeDefaultSpace } from '../constants';
5
+ import { DefaultGeometryProperty, DefaultTextProperty, getGeometryPointers, ShapeDefaultSpace } from '../constants';
6
6
  import { normalizeShapePoints, isDndMode, isDrawingMode } from '@plait/common';
7
7
  import { DrawTransforms } from '../transforms';
8
8
  import { DEFAULT_FONT_SIZE } from '@plait/text';
@@ -14,13 +14,14 @@ export const withGeometryCreateByDrag = (board) => {
14
14
  geometryShapeG?.remove();
15
15
  geometryShapeG = createG();
16
16
  const geometryGenerator = new GeometryShapeGenerator(board);
17
- const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
17
+ const geometryPointers = getGeometryPointers();
18
+ const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);
18
19
  const dragMode = isGeometryPointer && isDndMode(board);
19
20
  const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
20
21
  const pointer = PlaitBoard.getPointer(board);
21
22
  if (dragMode) {
22
23
  const points = getDefaultGeometryPoints(pointer, movingPoint);
23
- if (pointer === DrawPointerType.text) {
24
+ if (pointer === GeometryShape.text) {
24
25
  const textG = getTemporaryTextG(movingPoint);
25
26
  geometryShapeG.appendChild(textG);
26
27
  PlaitBoard.getElementActiveHost(board).append(geometryShapeG);
@@ -38,12 +39,13 @@ export const withGeometryCreateByDrag = (board) => {
38
39
  };
39
40
  board.pointerUp = (event) => {
40
41
  const pointer = PlaitBoard.getPointer(board);
41
- const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
42
+ const geometryPointers = getGeometryPointers();
43
+ const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);
42
44
  const dragMode = isGeometryPointer && isDndMode(board);
43
45
  if (dragMode) {
44
46
  const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
45
47
  const points = getDefaultGeometryPoints(pointer, targetPoint);
46
- if (pointer === DrawPointerType.text) {
48
+ if (pointer === GeometryShape.text) {
47
49
  DrawTransforms.insertText(board, points);
48
50
  }
49
51
  else {
@@ -58,7 +60,7 @@ export const withGeometryCreateByDrag = (board) => {
58
60
  };
59
61
  return board;
60
62
  };
61
- export const withGeometryCreateByDraw = (board) => {
63
+ export const withGeometryCreateByDrawing = (board) => {
62
64
  const { pointerDown, pointerMove, pointerUp, keydown, keyup } = board;
63
65
  let start = null;
64
66
  let geometryShapeG = null;
@@ -73,13 +75,14 @@ export const withGeometryCreateByDraw = (board) => {
73
75
  keyup(event);
74
76
  };
75
77
  board.pointerDown = (event) => {
76
- const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
78
+ const geometryPointers = getGeometryPointers();
79
+ const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);
77
80
  if (isGeometryPointer && isDrawingMode(board)) {
78
81
  const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
79
82
  start = point;
80
83
  const pointer = PlaitBoard.getPointer(board);
81
84
  preventTouchMove(board, event, true);
82
- if (pointer === DrawPointerType.text) {
85
+ if (pointer === GeometryShape.text) {
83
86
  const points = getDefaultGeometryPoints(pointer, point);
84
87
  const textElement = createGeometryElement(GeometryShape.text, points, DefaultTextProperty.text);
85
88
  Transforms.insertNode(board, textElement, [board.children.length]);
@@ -98,7 +101,7 @@ export const withGeometryCreateByDraw = (board) => {
98
101
  const drawMode = !!start;
99
102
  const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
100
103
  const pointer = PlaitBoard.getPointer(board);
101
- if (drawMode && pointer !== DrawPointerType.text) {
104
+ if (drawMode && pointer !== GeometryShape.text) {
102
105
  const points = normalizeShapePoints([start, movingPoint], isShift);
103
106
  temporaryElement = createGeometryElement(pointer, points, '', {
104
107
  strokeColor: DefaultGeometryProperty.strokeColor,
@@ -117,7 +120,7 @@ export const withGeometryCreateByDraw = (board) => {
117
120
  if (Math.hypot(width, height) === 0) {
118
121
  const pointer = PlaitBoard.getPointer(board);
119
122
  const points = getDefaultGeometryPoints(pointer, targetPoint);
120
- if (pointer !== DrawPointerType.text) {
123
+ if (pointer !== GeometryShape.text) {
121
124
  temporaryElement = createGeometryElement(pointer, points, '', {
122
125
  strokeColor: DefaultGeometryProperty.strokeColor,
123
126
  strokeWidth: DefaultGeometryProperty.strokeWidth
@@ -141,7 +144,7 @@ export const withGeometryCreateByDraw = (board) => {
141
144
  return board;
142
145
  };
143
146
  const getDefaultGeometryPoints = (pointer, targetPoint) => {
144
- return pointer === DrawPointerType.text
147
+ return pointer === GeometryShape.text
145
148
  ? getPointsByCenterPoint(targetPoint, DefaultTextProperty.width, DefaultTextProperty.height)
146
149
  : getPointsByCenterPoint(targetPoint, DefaultGeometryProperty.width, DefaultGeometryProperty.height);
147
150
  };
@@ -157,4 +160,4 @@ const getTemporaryTextG = (movingPoint) => {
157
160
  textG.appendChild(foreignObject);
158
161
  return textG;
159
162
  };
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-create.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createForeignObject,\n    createG,\n    preventTouchMove,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { GeometryShape, PlaitGeometry } from '../interfaces';\nimport { GeometryShapeGenerator } from '../generators/geometry-shape.generator';\nimport { createGeometryElement, getPointsByCenterPoint } from '../utils';\nimport { DefaultGeometryProperty, DefaultTextProperty, DrawPointerType, GeometryPointer, ShapeDefaultSpace } from '../constants';\nimport { normalizeShapePoints, isDndMode, isDrawingMode } from '@plait/common';\nimport { DrawTransforms } from '../transforms';\nimport { DEFAULT_FONT_SIZE } from '@plait/text';\nimport { isKeyHotkey } from 'is-hotkey';\n\nexport const withGeometryCreateByDrag = (board: PlaitBoard) => {\n    const { pointerMove, pointerUp } = board;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        const dragMode = isGeometryPointer && isDndMode(board);\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (dragMode) {\n            const points = getDefaultGeometryPoints(pointer, movingPoint);\n            if (pointer === DrawPointerType.text) {\n                const textG = getTemporaryTextG(movingPoint);\n                geometryShapeG.appendChild(textG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            } else {\n                const temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                    strokeColor: DefaultGeometryProperty.strokeColor,\n                    strokeWidth: DefaultGeometryProperty.strokeWidth\n                });\n                geometryGenerator.draw(temporaryElement, geometryShapeG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        const dragMode = isGeometryPointer && isDndMode(board);\n\n        if (dragMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const points = getDefaultGeometryPoints(pointer, targetPoint);\n            if (pointer === DrawPointerType.text) {\n                DrawTransforms.insertText(board, points);\n            } else {\n                DrawTransforms.insertGeometry(board, points, (pointer as unknown) as GeometryShape);\n            }\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        preventTouchMove(board, event, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nexport const withGeometryCreateByDraw = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, pointerUp, keydown, keyup } = board;\n    let start: Point | null = null;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        isShift = false;\n        keyup(event);\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        if (isGeometryPointer && isDrawingMode(board)) {\n            const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            start = point;\n            const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n            preventTouchMove(board, event, true);\n            if (pointer === DrawPointerType.text) {\n                const points = getDefaultGeometryPoints(pointer, point);\n                const textElement = createGeometryElement(GeometryShape.text, points, DefaultTextProperty.text);\n                Transforms.insertNode(board, textElement, [board.children.length]);\n                clearSelectedElement(board);\n                addSelectedElement(board, textElement);\n                BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n                start = null;\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const drawMode = !!start;\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        if (drawMode && pointer !== DrawPointerType.text) {\n            const points = normalizeShapePoints([start!, movingPoint], isShift);\n            temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                strokeColor: DefaultGeometryProperty.strokeColor,\n                strokeWidth: DefaultGeometryProperty.strokeWidth\n            });\n            geometryGenerator.draw(temporaryElement, geometryShapeG);\n            PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const isDrawMode = !!start;\n        if (isDrawMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { width, height } = RectangleClient.toRectangleClient([start!, targetPoint]);\n            if (Math.hypot(width, height) === 0) {\n                const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n                const points = getDefaultGeometryPoints(pointer, targetPoint);\n                if (pointer !== DrawPointerType.text) {\n                    temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                        strokeColor: DefaultGeometryProperty.strokeColor,\n                        strokeWidth: DefaultGeometryProperty.strokeWidth\n                    });\n                }\n            }\n        }\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        start = null;\n        temporaryElement = null;\n        preventTouchMove(board, event, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nconst getDefaultGeometryPoints = (pointer: DrawPointerType, targetPoint: Point) => {\n    return pointer === DrawPointerType.text\n        ? getPointsByCenterPoint(targetPoint, DefaultTextProperty.width, DefaultTextProperty.height)\n        : getPointsByCenterPoint(targetPoint, DefaultGeometryProperty.width, DefaultGeometryProperty.height);\n};\n\nconst getTemporaryTextG = (movingPoint: Point) => {\n    const textG = createG();\n    const width = DefaultTextProperty.width - ShapeDefaultSpace.rectangleAndText * 2;\n    const foreignObject = createForeignObject(\n        movingPoint[0] - width / 2,\n        movingPoint[1] - DefaultTextProperty.height / 2,\n        width,\n        DefaultTextProperty.height\n    );\n\n    const richtext = document.createElement('div');\n    richtext.textContent = DefaultTextProperty.text;\n    richtext.style.fontSize = `${DEFAULT_FONT_SIZE}px`;\n    richtext.style.cursor = 'default';\n    foreignObject.appendChild(richtext);\n    textG.appendChild(foreignObject);\n\n    return textG;\n};\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-create.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createForeignObject,\n    createG,\n    preventTouchMove,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { GeometryShape, PlaitGeometry } from '../interfaces';\nimport { GeometryShapeGenerator } from '../generators/geometry-shape.generator';\nimport { createGeometryElement, getPointsByCenterPoint } from '../utils';\nimport { DefaultGeometryProperty, DefaultTextProperty, DrawPointerType, getGeometryPointers, ShapeDefaultSpace } from '../constants';\nimport { normalizeShapePoints, isDndMode, isDrawingMode } from '@plait/common';\nimport { DrawTransforms } from '../transforms';\nimport { DEFAULT_FONT_SIZE } from '@plait/text';\nimport { isKeyHotkey } from 'is-hotkey';\n\nexport const withGeometryCreateByDrag = (board: PlaitBoard) => {\n    const { pointerMove, pointerUp } = board;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (dragMode) {\n            const points = getDefaultGeometryPoints(pointer, movingPoint);\n            if (pointer === GeometryShape.text) {\n                const textG = getTemporaryTextG(movingPoint);\n                geometryShapeG.appendChild(textG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            } else {\n                const temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                    strokeColor: DefaultGeometryProperty.strokeColor,\n                    strokeWidth: DefaultGeometryProperty.strokeWidth\n                });\n                geometryGenerator.draw(temporaryElement, geometryShapeG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        const dragMode = isGeometryPointer && isDndMode(board);\n\n        if (dragMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const points = getDefaultGeometryPoints(pointer, targetPoint);\n            if (pointer === GeometryShape.text) {\n                DrawTransforms.insertText(board, points);\n            } else {\n                DrawTransforms.insertGeometry(board, points, (pointer as unknown) as GeometryShape);\n            }\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        preventTouchMove(board, event, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nexport const withGeometryCreateByDrawing = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, pointerUp, keydown, keyup } = board;\n    let start: Point | null = null;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        isShift = false;\n        keyup(event);\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const geometryPointers = getGeometryPointers();\n        const isGeometryPointer = PlaitBoard.isInPointer(board, geometryPointers);\n        if (isGeometryPointer && isDrawingMode(board)) {\n            const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            start = point;\n            const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n            preventTouchMove(board, event, true);\n            if (pointer === GeometryShape.text) {\n                const points = getDefaultGeometryPoints(pointer, point);\n                const textElement = createGeometryElement(GeometryShape.text, points, DefaultTextProperty.text);\n                Transforms.insertNode(board, textElement, [board.children.length]);\n                clearSelectedElement(board);\n                addSelectedElement(board, textElement);\n                BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n                start = null;\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const drawMode = !!start;\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        if (drawMode && pointer !== GeometryShape.text) {\n            const points = normalizeShapePoints([start!, movingPoint], isShift);\n            temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                strokeColor: DefaultGeometryProperty.strokeColor,\n                strokeWidth: DefaultGeometryProperty.strokeWidth\n            });\n            geometryGenerator.draw(temporaryElement, geometryShapeG);\n            PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const isDrawMode = !!start;\n        if (isDrawMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { width, height } = RectangleClient.toRectangleClient([start!, targetPoint]);\n            if (Math.hypot(width, height) === 0) {\n                const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n                const points = getDefaultGeometryPoints(pointer, targetPoint);\n                if (pointer !== GeometryShape.text) {\n                    temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                        strokeColor: DefaultGeometryProperty.strokeColor,\n                        strokeWidth: DefaultGeometryProperty.strokeWidth\n                    });\n                }\n            }\n        }\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        start = null;\n        temporaryElement = null;\n        preventTouchMove(board, event, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nconst getDefaultGeometryPoints = (pointer: DrawPointerType, targetPoint: Point) => {\n    return pointer === GeometryShape.text\n        ? getPointsByCenterPoint(targetPoint, DefaultTextProperty.width, DefaultTextProperty.height)\n        : getPointsByCenterPoint(targetPoint, DefaultGeometryProperty.width, DefaultGeometryProperty.height);\n};\n\nconst getTemporaryTextG = (movingPoint: Point) => {\n    const textG = createG();\n    const width = DefaultTextProperty.width - ShapeDefaultSpace.rectangleAndText * 2;\n    const foreignObject = createForeignObject(\n        movingPoint[0] - width / 2,\n        movingPoint[1] - DefaultTextProperty.height / 2,\n        width,\n        DefaultTextProperty.height\n    );\n\n    const richtext = document.createElement('div');\n    richtext.textContent = DefaultTextProperty.text;\n    richtext.style.fontSize = `${DEFAULT_FONT_SIZE}px`;\n    richtext.style.cursor = 'default';\n    foreignObject.appendChild(richtext);\n    textG.appendChild(foreignObject);\n\n    return textG;\n};\n"]}
@@ -1,10 +1,11 @@
1
- import { PlaitElement, getSelectedElements } from '@plait/core';
1
+ import { PlaitElement, Transforms, getSelectedElements } from '@plait/core';
2
2
  import { PlaitGeometry } from '../interfaces/geometry';
3
- import { ResizeHandle, normalizeShapePoints, withResize } from '@plait/common';
4
- import { getSelectedGeometryElements } from '../utils/selected';
3
+ import { ResizeHandle, getRectangleByPoints, normalizeShapePoints, withResize } from '@plait/common';
4
+ import { getSelectedGeometryElements, getSelectedImageElements } from '../utils/selected';
5
5
  import { getHitGeometryResizeHandleRef } from '../utils/position/geometry';
6
6
  import { DrawTransforms } from '../transforms';
7
7
  import { isKeyHotkey } from 'is-hotkey';
8
+ import { PlaitDrawElement } from '../interfaces';
8
9
  export const withGeometryResize = (board) => {
9
10
  const { keydown, keyup } = board;
10
11
  let isShift = false;
@@ -22,12 +23,12 @@ export const withGeometryResize = (board) => {
22
23
  return true;
23
24
  },
24
25
  detect: (point) => {
25
- const selectedGeometryElements = getSelectedGeometryElements(board);
26
- if (selectedGeometryElements.length !== 1 || getSelectedElements(board).length !== 1) {
26
+ const selectedElements = [...getSelectedGeometryElements(board), ...getSelectedImageElements(board)];
27
+ if (selectedElements.length !== 1 || getSelectedElements(board).length !== 1) {
27
28
  return null;
28
29
  }
29
- const target = selectedGeometryElements[0];
30
- const targetComponent = PlaitElement.getComponent(selectedGeometryElements[0]);
30
+ const target = selectedElements[0];
31
+ const targetComponent = PlaitElement.getComponent(selectedElements[0]);
31
32
  if (targetComponent.activeGenerator.hasResizeHandle) {
32
33
  const handleRef = getHitGeometryResizeHandleRef(board, target, point);
33
34
  if (handleRef) {
@@ -42,30 +43,37 @@ export const withGeometryResize = (board) => {
42
43
  },
43
44
  onResize: (resizeRef, resizeState) => {
44
45
  let points = [...resizeRef.element.points];
46
+ const rectangle = getRectangleByPoints(resizeRef.element.points);
47
+ const ratio = rectangle.height / rectangle.width;
45
48
  if (resizeRef.handle === ResizeHandle.nw) {
46
49
  points = [resizeState.endTransformPoint, resizeRef.element.points[1]];
47
50
  }
48
51
  if (resizeRef.handle === ResizeHandle.ne) {
49
- points = [
50
- [resizeRef.element.points[0][0], resizeState.endTransformPoint[1]],
51
- [resizeState.endTransformPoint[0], resizeRef.element.points[1][1]]
52
- ];
52
+ points = [resizeState.endTransformPoint, [resizeRef.element.points[0][0], resizeRef.element.points[1][1]]];
53
53
  }
54
54
  if (resizeRef.handle === ResizeHandle.se) {
55
- points = [resizeRef.element.points[0], resizeState.endTransformPoint];
55
+ points = [resizeState.endTransformPoint, resizeRef.element.points[0]];
56
56
  }
57
57
  if (resizeRef.handle === ResizeHandle.sw) {
58
- points = [
59
- [resizeState.endTransformPoint[0], resizeRef.element.points[0][1]],
60
- [resizeRef.element.points[1][0], resizeState.endTransformPoint[1]]
61
- ];
58
+ points = [resizeState.endTransformPoint, [resizeRef.element.points[1][0], resizeRef.element.points[0][1]]];
59
+ }
60
+ if (isShift || PlaitDrawElement.isImage(resizeRef.element)) {
61
+ const rectangle = getRectangleByPoints(points);
62
+ const factor = points[0][1] > points[1][1] ? 1 : -1;
63
+ const height = rectangle.width * ratio * factor;
64
+ points = [[resizeState.endTransformPoint[0], points[1][1] + height], points[1]];
65
+ }
66
+ if (PlaitDrawElement.isGeometry(resizeRef.element)) {
67
+ const { height: textHeight } = PlaitGeometry.getTextManage(resizeRef.element).getSize();
68
+ DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);
69
+ }
70
+ else {
71
+ points = normalizeShapePoints(points);
72
+ Transforms.setNode(board, { points }, resizeRef.path);
62
73
  }
63
- points = normalizeShapePoints(points, isShift);
64
- const { height: textHeight } = PlaitGeometry.getTextManage(resizeRef.element).getSize();
65
- DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);
66
74
  }
67
75
  };
68
76
  withResize(board, options);
69
77
  return board;
70
78
  };
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-resize.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, getSelectedElements } from '@plait/core';\nimport { PlaitGeometry } from '../interfaces/geometry';\nimport { ResizeHandle, ResizeRef, ResizeState, WithResizeOptions, normalizeShapePoints, withResize } from '@plait/common';\nimport { getSelectedGeometryElements } from '../utils/selected';\nimport { getHitGeometryResizeHandleRef } from '../utils/position/geometry';\nimport { DrawTransforms } from '../transforms';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { GeometryComponent } from '../geometry.component';\n\nexport const withGeometryResize = (board: PlaitBoard) => {\n    const { keydown, keyup } = board;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        isShift = false;\n        keyup(event);\n    };\n\n    const options: WithResizeOptions<PlaitGeometry> = {\n        key: 'draw-geometry',\n        canResize: () => {\n            return true;\n        },\n        detect: (point: Point) => {\n            const selectedGeometryElements = getSelectedGeometryElements(board);\n            if (selectedGeometryElements.length !== 1 || getSelectedElements(board).length !== 1) {\n                return null;\n            }\n            const target = selectedGeometryElements[0];\n            const targetComponent = PlaitElement.getComponent(selectedGeometryElements[0]) as GeometryComponent;\n            if (targetComponent.activeGenerator.hasResizeHandle) {\n                const handleRef = getHitGeometryResizeHandleRef(board, target, point);\n                if (handleRef) {\n                    return {\n                        element: target,\n                        handle: handleRef.handle,\n                        cursorClass: handleRef.cursorClass\n                    };\n                }\n            }\n            return null;\n        },\n        onResize: (resizeRef: ResizeRef<PlaitGeometry>, resizeState: ResizeState) => {\n            let points: [Point, Point] = [...resizeRef.element.points];\n            if (resizeRef.handle === ResizeHandle.nw) {\n                points = [resizeState.endTransformPoint, resizeRef.element.points[1]];\n            }\n            if (resizeRef.handle === ResizeHandle.ne) {\n                points = [\n                    [resizeRef.element.points[0][0], resizeState.endTransformPoint[1]],\n                    [resizeState.endTransformPoint[0], resizeRef.element.points[1][1]]\n                ];\n            }\n            if (resizeRef.handle === ResizeHandle.se) {\n                points = [resizeRef.element.points[0], resizeState.endTransformPoint];\n            }\n            if (resizeRef.handle === ResizeHandle.sw) {\n                points = [\n                    [resizeState.endTransformPoint[0], resizeRef.element.points[0][1]],\n                    [resizeRef.element.points[1][0], resizeState.endTransformPoint[1]]\n                ];\n            }\n            points = normalizeShapePoints(points, isShift);\n            const { height: textHeight } = PlaitGeometry.getTextManage(resizeRef.element).getSize();\n            DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);\n        }\n    };\n\n    withResize<PlaitGeometry>(board, options);\n\n    return board;\n};\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-resize.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-resize.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitElement, Point, Transforms, getSelectedElements } from '@plait/core';\nimport { PlaitGeometry } from '../interfaces/geometry';\nimport {\n    ResizeHandle,\n    ResizeRef,\n    ResizeState,\n    WithResizeOptions,\n    getRectangleByPoints,\n    normalizeShapePoints,\n    withResize\n} from '@plait/common';\nimport { getSelectedGeometryElements, getSelectedImageElements } from '../utils/selected';\nimport { getHitGeometryResizeHandleRef } from '../utils/position/geometry';\nimport { DrawTransforms } from '../transforms';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { GeometryComponent } from '../geometry.component';\nimport { PlaitImage } from '../interfaces/image';\nimport { PlaitDrawElement } from '../interfaces';\n\nexport const withGeometryResize = (board: PlaitBoard) => {\n    const { keydown, keyup } = board;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        isShift = false;\n        keyup(event);\n    };\n\n    const options: WithResizeOptions<PlaitGeometry | PlaitImage> = {\n        key: 'draw-geometry',\n        canResize: () => {\n            return true;\n        },\n        detect: (point: Point) => {\n            const selectedElements = [...getSelectedGeometryElements(board), ...getSelectedImageElements(board)];\n            if (selectedElements.length !== 1 || getSelectedElements(board).length !== 1) {\n                return null;\n            }\n            const target = selectedElements[0];\n            const targetComponent = PlaitElement.getComponent(selectedElements[0]) as GeometryComponent;\n            if (targetComponent.activeGenerator.hasResizeHandle) {\n                const handleRef = getHitGeometryResizeHandleRef(board, target, point);\n                if (handleRef) {\n                    return {\n                        element: target,\n                        handle: handleRef.handle,\n                        cursorClass: handleRef.cursorClass\n                    };\n                }\n            }\n            return null;\n        },\n        onResize: (resizeRef: ResizeRef<PlaitGeometry | PlaitImage>, resizeState: ResizeState) => {\n            let points: [Point, Point] = [...resizeRef.element.points];\n            const rectangle = getRectangleByPoints(resizeRef.element.points);\n            const ratio = rectangle.height / rectangle.width;\n            if (resizeRef.handle === ResizeHandle.nw) {\n                points = [resizeState.endTransformPoint, resizeRef.element.points[1]];\n            }\n            if (resizeRef.handle === ResizeHandle.ne) {\n                points = [resizeState.endTransformPoint, [resizeRef.element.points[0][0], resizeRef.element.points[1][1]]];\n            }\n            if (resizeRef.handle === ResizeHandle.se) {\n                points = [resizeState.endTransformPoint, resizeRef.element.points[0]];\n            }\n            if (resizeRef.handle === ResizeHandle.sw) {\n                points = [resizeState.endTransformPoint, [resizeRef.element.points[1][0], resizeRef.element.points[0][1]]];\n            }\n            if (isShift || PlaitDrawElement.isImage(resizeRef.element)) {\n                const rectangle = getRectangleByPoints(points);\n                const factor = points[0][1] > points[1][1] ? 1 : -1;\n                const height = rectangle.width * ratio * factor;\n                points = [[resizeState.endTransformPoint[0], points[1][1] + height], points[1]];\n            }\n            if (PlaitDrawElement.isGeometry(resizeRef.element)) {\n                const { height: textHeight } = PlaitGeometry.getTextManage(resizeRef.element).getSize();\n                DrawTransforms.resizeGeometry(board, points, textHeight, resizeRef.path);\n            } else {\n                points = normalizeShapePoints(points);\n                Transforms.setNode(board, { points }, resizeRef.path);\n            }\n        }\n    };\n\n    withResize<PlaitGeometry | PlaitImage>(board, options);\n\n    return board;\n};\n"]}