@plait/draw 0.63.0 → 0.64.1

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 (57) hide show
  1. package/arrow-line.component.d.ts +3 -3
  2. package/constants/pointer.d.ts +3 -2
  3. package/esm2022/arrow-line.component.mjs +6 -5
  4. package/esm2022/constants/pointer.mjs +5 -2
  5. package/esm2022/generators/arrow-line.generator.mjs +3 -3
  6. package/esm2022/generators/index.mjs +2 -2
  7. package/esm2022/generators/line-active.generator.mjs +81 -0
  8. package/esm2022/generators/vector-line-generator.mjs +13 -0
  9. package/esm2022/interfaces/index.mjs +8 -5
  10. package/esm2022/interfaces/line.mjs +2 -0
  11. package/esm2022/interfaces/vector-line.mjs +5 -1
  12. package/esm2022/plugins/with-arrow-line-bound-reaction.mjs +3 -3
  13. package/esm2022/plugins/with-arrow-line-resize.mjs +9 -9
  14. package/esm2022/plugins/with-draw-fragment.mjs +7 -5
  15. package/esm2022/plugins/with-draw.mjs +17 -2
  16. package/esm2022/plugins/with-vector-line-resize.mjs +61 -0
  17. package/esm2022/plugins/with-vector-pen-create.mjs +124 -0
  18. package/esm2022/public-api.mjs +2 -1
  19. package/esm2022/transforms/index.mjs +3 -1
  20. package/esm2022/transforms/vector-line.mjs +13 -0
  21. package/esm2022/utils/arrow-line/arrow-line-basic.mjs +5 -58
  22. package/esm2022/utils/common.mjs +5 -1
  23. package/esm2022/utils/hit.mjs +24 -4
  24. package/esm2022/utils/index.mjs +3 -1
  25. package/esm2022/utils/line.mjs +64 -0
  26. package/esm2022/utils/position/arrow-line.mjs +3 -50
  27. package/esm2022/utils/position/line.mjs +51 -0
  28. package/esm2022/utils/selected.mjs +5 -1
  29. package/esm2022/utils/vector-line.mjs +75 -0
  30. package/esm2022/vector-line.component.mjs +50 -0
  31. package/fesm2022/plait-draw.mjs +510 -146
  32. package/fesm2022/plait-draw.mjs.map +1 -1
  33. package/generators/arrow-line.generator.d.ts +3 -5
  34. package/generators/index.d.ts +1 -1
  35. package/generators/line-active.generator.d.ts +13 -0
  36. package/generators/vector-line-generator.d.ts +6 -0
  37. package/interfaces/index.d.ts +3 -0
  38. package/interfaces/line.d.ts +3 -0
  39. package/interfaces/vector-line.d.ts +10 -1
  40. package/package.json +1 -1
  41. package/plugins/with-vector-line-resize.d.ts +2 -0
  42. package/plugins/with-vector-pen-create.d.ts +2 -0
  43. package/public-api.d.ts +1 -0
  44. package/styles/styles.scss +2 -2
  45. package/transforms/index.d.ts +1 -0
  46. package/transforms/vector-line.d.ts +3 -0
  47. package/utils/arrow-line/arrow-line-basic.d.ts +0 -1
  48. package/utils/hit.d.ts +3 -2
  49. package/utils/index.d.ts +2 -0
  50. package/utils/line.d.ts +3 -0
  51. package/utils/position/arrow-line.d.ts +0 -13
  52. package/utils/position/line.d.ts +15 -0
  53. package/utils/selected.d.ts +2 -1
  54. package/utils/vector-line.d.ts +7 -0
  55. package/vector-line.component.d.ts +14 -0
  56. package/esm2022/generators/arrow-line-active.generator.mjs +0 -81
  57. package/generators/arrow-line-active.generator.d.ts +0 -13
@@ -1,8 +1,6 @@
1
1
  import { PlaitArrowLine } from '../interfaces';
2
2
  import { Generator } from '@plait/common';
3
- export interface ShapeData {
4
- }
5
- export declare class ArrowLineShapeGenerator extends Generator<PlaitArrowLine, ShapeData> {
6
- canDraw(element: PlaitArrowLine, data: ShapeData): boolean;
7
- draw(element: PlaitArrowLine, data: ShapeData): SVGGElement;
3
+ export declare class ArrowLineShapeGenerator extends Generator<PlaitArrowLine> {
4
+ canDraw(element: PlaitArrowLine): boolean;
5
+ draw(element: PlaitArrowLine): SVGGElement;
8
6
  }
@@ -1,5 +1,5 @@
1
1
  export * from './geometry-shape.generator';
2
- export * from './arrow-line-active.generator';
2
+ export * from './line-active.generator';
3
3
  export * from './arrow-line-auto-complete.generator';
4
4
  export * from './single-text.generator';
5
5
  export * from './text.generator';
@@ -0,0 +1,13 @@
1
+ import { Point } from '@plait/core';
2
+ import { Generator } from '@plait/common';
3
+ import { PlaitLine } from '../interfaces/line';
4
+ export interface ActiveData {
5
+ selected: boolean;
6
+ linePoints: Point[];
7
+ }
8
+ export declare class LineActiveGenerator extends Generator<PlaitLine, ActiveData> {
9
+ onlySelectedCurrentLine: boolean;
10
+ canDraw(element: PlaitLine, data: ActiveData): boolean;
11
+ draw(element: PlaitLine, data: ActiveData): SVGGElement;
12
+ needUpdate(): boolean;
13
+ }
@@ -0,0 +1,6 @@
1
+ import { PlaitVectorLine } from '../interfaces';
2
+ import { Generator } from '@plait/common';
3
+ export declare class VectorLineShapeGenerator extends Generator<PlaitVectorLine> {
4
+ canDraw(element: PlaitVectorLine): boolean;
5
+ draw(element: PlaitVectorLine): SVGGElement;
6
+ }
@@ -5,6 +5,7 @@ import { PlaitSwimlane, SwimlaneSymbols } from './swimlane';
5
5
  import { PlaitBaseTable, PlaitTable, TableSymbols } from './table';
6
6
  import { PlaitText } from './text';
7
7
  import { PlaitVectorLine } from './vector-line';
8
+ import { PlaitLine } from './line';
8
9
  export * from './arrow-line';
9
10
  export * from './geometry';
10
11
  export * from './text';
@@ -19,6 +20,8 @@ export type DrawShapes = GeometryShapes | TableSymbols | SwimlaneSymbols;
19
20
  export declare const PlaitDrawElement: {
20
21
  isGeometry: (value: any) => value is PlaitGeometry;
21
22
  isArrowLine: (value: any) => value is PlaitArrowLine;
23
+ isVectorLine: (value: any) => value is PlaitVectorLine;
24
+ isLine: (value: any) => value is PlaitLine;
22
25
  isText: (value: any) => value is PlaitText;
23
26
  isImage: (value: any) => value is PlaitImage;
24
27
  isTable: (value: any) => value is PlaitTable;
@@ -0,0 +1,3 @@
1
+ import { PlaitArrowLine } from './arrow-line';
2
+ import { PlaitVectorLine } from './vector-line';
3
+ export type PlaitLine = PlaitArrowLine | PlaitVectorLine;
@@ -1,9 +1,18 @@
1
- import { PlaitElement, Point } from '@plait/core';
1
+ import { Path, PlaitElement, Point } from '@plait/core';
2
2
  import { StrokeStyle } from './element';
3
+ export declare enum VectorPenPointerType {
4
+ vectorPen = "vectorPen"
5
+ }
3
6
  export declare enum VectorLineShape {
4
7
  straight = "straight",
5
8
  curve = "curve"
6
9
  }
10
+ export interface VectorPenRef {
11
+ start?: Point;
12
+ element?: PlaitVectorLine;
13
+ path?: Path;
14
+ shape: VectorLineShape;
15
+ }
7
16
  export interface PlaitVectorLine extends PlaitElement {
8
17
  type: 'vector-line';
9
18
  shape: VectorLineShape;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@plait/draw",
3
- "version": "0.63.0",
3
+ "version": "0.64.1",
4
4
  "peerDependencies": {},
5
5
  "dependencies": {
6
6
  "tslib": "^2.3.0"
@@ -0,0 +1,2 @@
1
+ import { PlaitBoard } from '@plait/core';
2
+ export declare const withVectorLineResize: (board: PlaitBoard) => PlaitBoard;
@@ -0,0 +1,2 @@
1
+ import { PlaitBoard } from '@plait/core';
2
+ export declare const withVectorPenCreateByDraw: (board: PlaitBoard) => PlaitBoard;
package/public-api.d.ts CHANGED
@@ -5,5 +5,6 @@ export * from './constants';
5
5
  export * from './utils';
6
6
  export * from './geometry.component';
7
7
  export * from './arrow-line.component';
8
+ export * from './vector-line.component';
8
9
  export * from './transforms';
9
10
  export * from './generators/index';
@@ -4,7 +4,7 @@
4
4
  cursor: default;
5
5
  }
6
6
  }
7
- &:not(.pointer-text):not(.pointer-selection):not(.pointer-hand) {
7
+ &:not(.pointer-text):not(.pointer-selection):not(.pointer-hand):not(.pointer-vectorPen) {
8
8
  .board-host-svg {
9
9
  cursor: crosshair;
10
10
  }
@@ -12,7 +12,7 @@
12
12
  &.draw-line-resizing .element-active-host .line-handle {
13
13
  display: none;
14
14
  }
15
- &.line-text-resizing ,
15
+ &.line-text-resizing,
16
16
  &.line-text-resizing .slate-editable-container {
17
17
  cursor: move;
18
18
  }
@@ -10,6 +10,7 @@ export declare const DrawTransforms: {
10
10
  removeArrowLineText: (board: import("@plait/core").PlaitBoard, element: import("@plait/draw").PlaitArrowLine, index: number) => void;
11
11
  setArrowLineMark: (board: import("@plait/core").PlaitBoard, handleKey: import("@plait/draw").ArrowLineHandleKey, marker: import("@plait/draw").ArrowLineMarkerType) => void;
12
12
  setArrowLineShape: (board: import("@plait/core").PlaitBoard, newProperties: Partial<import("@plait/draw").PlaitArrowLine>) => void;
13
+ setVectorLineShape: (board: import("@plait/core").PlaitBoard, newProperties: Partial<import("@plait/draw").PlaitVectorLine>) => void;
13
14
  insertImage: (board: import("@plait/core").PlaitBoard, imageItem: import("@plait/common").CommonImageItem, startPoint?: import("@plait/core").Point | undefined) => void;
14
15
  connectArrowLineToDraw: (board: import("@plait/core").PlaitBoard, lineElement: import("@plait/draw").PlaitArrowLine, handle: import("@plait/draw").ArrowLineHandleKey, geometryElement: import("@plait/draw").PlaitShapeElement) => void;
15
16
  switchGeometryShape: (board: import("@plait/core").PlaitBoard, shape: import("@plait/draw").GeometryShapes) => void;
@@ -0,0 +1,3 @@
1
+ import { PlaitBoard } from '@plait/core';
2
+ import { PlaitVectorLine } from '../interfaces';
3
+ export declare const setVectorLineShape: (board: PlaitBoard, newProperties: Partial<PlaitVectorLine>) => void;
@@ -3,7 +3,6 @@ import { ArrowLineHandle, ArrowLineShape, ArrowLineText, PlaitArrowLine, PlaitSh
3
3
  export declare const createArrowLineElement: (shape: ArrowLineShape, points: [Point, Point], source: ArrowLineHandle, target: ArrowLineHandle, texts?: ArrowLineText[], options?: Pick<PlaitArrowLine, 'strokeColor' | 'strokeWidth'>) => PlaitArrowLine;
4
4
  export declare const getArrowLinePoints: (board: PlaitBoard, element: PlaitArrowLine) => Point[];
5
5
  export declare const getCurvePoints: (board: PlaitBoard, element: PlaitArrowLine) => Point[];
6
- export declare function getMiddlePoints(board: PlaitBoard, element: PlaitArrowLine): Point[];
7
6
  export declare const drawArrowLine: (board: PlaitBoard, element: PlaitArrowLine) => SVGGElement;
8
7
  export declare const getHitConnection: (board: PlaitBoard, point: Point, hitElement: PlaitShapeElement) => Point;
9
8
  export declare const getHitConnectorPoint: (point: Point, hitElement: PlaitShapeElement) => Point | undefined;
package/utils/hit.d.ts CHANGED
@@ -1,15 +1,16 @@
1
1
  import { PlaitElement, RectangleClient, Selection, PlaitBoard, Point } from '@plait/core';
2
- import { PlaitArrowLine, PlaitCommonGeometry, PlaitDrawElement, PlaitGeometry, PlaitShapeElement } from '../interfaces';
2
+ import { PlaitArrowLine, PlaitCommonGeometry, PlaitDrawElement, PlaitGeometry, PlaitShapeElement, PlaitVectorLine } from '../interfaces';
3
3
  export declare const isTextExceedingBounds: (geometry: PlaitGeometry) => boolean;
4
4
  export declare const isHitArrowLineText: (board: PlaitBoard, element: PlaitArrowLine, point: Point) => boolean;
5
5
  export declare const isHitPolyLine: (pathPoints: Point[], point: Point) => boolean;
6
6
  export declare const isHitArrowLine: (board: PlaitBoard, element: PlaitArrowLine, point: Point) => boolean;
7
+ export declare const isHitVectorLine: (board: PlaitBoard, element: PlaitVectorLine, point: Point) => boolean;
7
8
  export declare const isRectangleHitElementText: (element: PlaitCommonGeometry, rectangle: RectangleClient) => boolean;
8
9
  export declare const isHitElementText: (element: PlaitCommonGeometry, point: Point) => boolean;
9
10
  export declare const isRectangleHitDrawElement: (board: PlaitBoard, element: PlaitElement, selection: Selection) => boolean | null;
10
11
  export declare const getDrawHitElement: (board: PlaitBoard, elements: PlaitDrawElement[]) => PlaitElement;
11
12
  export declare const getFirstFilledDrawElement: (board: PlaitBoard, elements: PlaitDrawElement[]) => PlaitGeometry | null;
12
- export declare const getFirstTextOrLineElement: (elements: PlaitDrawElement[]) => PlaitGeometry | import("../interfaces").PlaitBaseTable | import("../interfaces/image").PlaitImage | PlaitArrowLine | import("../interfaces").PlaitVectorLine | null;
13
+ export declare const getFirstTextOrLineElement: (elements: PlaitDrawElement[]) => PlaitGeometry | import("../interfaces").PlaitBaseTable | import("../interfaces/image").PlaitImage | PlaitArrowLine | PlaitVectorLine | null;
13
14
  export declare const isHitDrawElement: (board: PlaitBoard, element: PlaitElement, point: Point) => boolean | null;
14
15
  export declare const isHitEdgeOfShape: (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => boolean;
15
16
  export declare const isInsideOfShape: (board: PlaitBoard, element: PlaitShapeElement, point: Point, hitDistanceBuffer: number) => boolean;
package/utils/index.d.ts CHANGED
@@ -11,3 +11,5 @@ export * from './snap-resizing';
11
11
  export * from './table';
12
12
  export * from './table-selected';
13
13
  export * from './swimlane';
14
+ export * from './line';
15
+ export * from './vector-line';
@@ -0,0 +1,3 @@
1
+ import { PlaitBoard, Point } from '@plait/core';
2
+ import { PlaitLine } from '../interfaces/line';
3
+ export declare function getMiddlePoints(board: PlaitBoard, element: PlaitLine): Point[];
@@ -1,16 +1,3 @@
1
1
  import { PlaitBoard, Point } from '@plait/core';
2
2
  import { PlaitArrowLine } from '../../interfaces';
3
- export declare enum ArrowLineResizeHandle {
4
- 'source' = "source",
5
- 'target' = "target",
6
- 'addHandle' = "addHandle"
7
- }
8
- export declare const getHitArrowLineResizeHandleRef: (board: PlaitBoard, element: PlaitArrowLine, point: Point) => {
9
- handle: ArrowLineResizeHandle;
10
- handleIndex: number;
11
- } | {
12
- handleIndex: number;
13
- handle?: undefined;
14
- } | undefined;
15
- export declare function getHitPointIndex(points: Point[], movingPoint: Point): number;
16
3
  export declare const getHitArrowLineTextIndex: (board: PlaitBoard, element: PlaitArrowLine, point: Point) => number;
@@ -0,0 +1,15 @@
1
+ import { PlaitBoard, Point } from '@plait/core';
2
+ import { PlaitLine } from '../../interfaces/line';
3
+ export declare enum LineResizeHandle {
4
+ 'source' = "source",
5
+ 'target' = "target",
6
+ 'addHandle' = "addHandle"
7
+ }
8
+ export declare const getHitLineResizeHandleRef: (board: PlaitBoard, element: PlaitLine, point: Point) => {
9
+ handle: LineResizeHandle;
10
+ handleIndex: number;
11
+ } | {
12
+ handleIndex: number;
13
+ handle?: undefined;
14
+ } | undefined;
15
+ export declare function getHitPointIndex(points: Point[], movingPoint: Point): number;
@@ -1,9 +1,10 @@
1
1
  import { PlaitBoard, PlaitElement } from '@plait/core';
2
- import { PlaitArrowLine, PlaitDrawElement, PlaitGeometry, PlaitSwimlane } from '../interfaces';
2
+ import { PlaitArrowLine, PlaitDrawElement, PlaitGeometry, PlaitSwimlane, PlaitVectorLine } from '../interfaces';
3
3
  import { PlaitImage } from '../interfaces/image';
4
4
  export declare const getSelectedDrawElements: (board: PlaitBoard, elements?: PlaitElement[]) => PlaitDrawElement[];
5
5
  export declare const getSelectedGeometryElements: (board: PlaitBoard) => PlaitGeometry[];
6
6
  export declare const getSelectedArrowLineElements: (board: PlaitBoard) => PlaitArrowLine[];
7
+ export declare const getSelectedVectorLineElements: (board: PlaitBoard) => PlaitVectorLine[];
7
8
  export declare const getSelectedImageElements: (board: PlaitBoard) => PlaitImage[];
8
9
  export declare const isSingleSelectSwimlane: (board: PlaitBoard) => boolean;
9
10
  export declare const getSelectedSwimlane: (board: PlaitBoard) => PlaitSwimlane;
@@ -0,0 +1,7 @@
1
+ import { PlaitBoard, Point } from '@plait/core';
2
+ import { PlaitVectorLine, VectorLineShape } from '../interfaces';
3
+ export declare const isClosedVectorLine: (vectorLine: PlaitVectorLine) => boolean;
4
+ export declare const getVectorLinePoints: (board: PlaitBoard, element: PlaitVectorLine) => Point[] | null;
5
+ export declare const createVectorLineElement: (shape: VectorLineShape, points: Point[], options?: Pick<PlaitVectorLine, 'strokeColor' | 'strokeWidth' | 'fill'>) => PlaitVectorLine;
6
+ export declare const vectorLineCreating: (board: PlaitBoard, lineShape: VectorLineShape, points: Point[], movingPoint: Point, lineShapeG: SVGGElement) => PlaitVectorLine;
7
+ export declare const drawVectorLine: (board: PlaitBoard, element: PlaitVectorLine) => SVGGElement;
@@ -0,0 +1,14 @@
1
+ import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';
2
+ import { PlaitVectorLine } from './interfaces';
3
+ import { LineActiveGenerator } from './generators/line-active.generator';
4
+ import { CommonElementFlavour } from '@plait/common';
5
+ import { VectorLineShapeGenerator } from './generators/vector-line-generator';
6
+ export declare class VectorLineComponent extends CommonElementFlavour<PlaitVectorLine, PlaitBoard> implements OnContextChanged<PlaitVectorLine, PlaitBoard> {
7
+ shapeGenerator: VectorLineShapeGenerator;
8
+ activeGenerator: LineActiveGenerator;
9
+ constructor();
10
+ initializeGenerator(): void;
11
+ initialize(): void;
12
+ onContextChanged(value: PlaitPluginElementContext<PlaitVectorLine, PlaitBoard>, previous: PlaitPluginElementContext<PlaitVectorLine, PlaitBoard>): void;
13
+ destroy(): void;
14
+ }
@@ -1,81 +0,0 @@
1
- import { PlaitBoard, createG, drawRectangle, getSelectedElements } from '@plait/core';
2
- import { ArrowLineShape, PlaitArrowLine } from '../interfaces';
3
- import { Generator, PRIMARY_COLOR, drawFillPrimaryHandle, drawPrimaryHandle } from '@plait/common';
4
- import { getMiddlePoints } from '../utils/arrow-line/arrow-line-basic';
5
- import { getNextRenderPoints } from '../utils/arrow-line/elbow';
6
- import { isUpdatedHandleIndex } from '../utils/arrow-line';
7
- import { getHitPointIndex } from '../utils/position/arrow-line';
8
- import { DefaultDrawActiveStyle } from '../constants';
9
- export class ArrowLineActiveGenerator extends Generator {
10
- constructor() {
11
- super(...arguments);
12
- this.onlySelectedCurrentLine = false;
13
- }
14
- canDraw(element, data) {
15
- if (data.selected) {
16
- return true;
17
- }
18
- else {
19
- return false;
20
- }
21
- }
22
- draw(element, data) {
23
- const activeG = createG();
24
- const selectedElements = getSelectedElements(this.board);
25
- this.onlySelectedCurrentLine = selectedElements.length === 1;
26
- if (this.onlySelectedCurrentLine) {
27
- activeG.classList.add('active');
28
- activeG.classList.add('line-handle');
29
- const points = PlaitArrowLine.getPoints(this.board, element);
30
- let updatePoints = [...points];
31
- let elbowNextRenderPoints = [];
32
- if (element.shape === ArrowLineShape.elbow) {
33
- updatePoints = points.slice(0, 1).concat(points.slice(-1));
34
- elbowNextRenderPoints = getNextRenderPoints(this.board, element, data.linePoints);
35
- }
36
- updatePoints.forEach(point => {
37
- const updateHandle = drawPrimaryHandle(this.board, point);
38
- activeG.appendChild(updateHandle);
39
- });
40
- const middlePoints = getMiddlePoints(this.board, element);
41
- if (!PlaitBoard.hasBeenTextEditing(this.board)) {
42
- for (let i = 0; i < middlePoints.length; i++) {
43
- const point = middlePoints[i];
44
- if (element.shape === ArrowLineShape.elbow && elbowNextRenderPoints.length) {
45
- const handleIndex = getHitPointIndex(middlePoints, point);
46
- const isUpdateHandleIndex = isUpdatedHandleIndex(this.board, element, [...points], elbowNextRenderPoints, handleIndex);
47
- if (isUpdateHandleIndex) {
48
- const updateHandle = drawPrimaryHandle(this.board, point);
49
- activeG.appendChild(updateHandle);
50
- continue;
51
- }
52
- }
53
- const circle = drawFillPrimaryHandle(this.board, point);
54
- activeG.appendChild(circle);
55
- }
56
- }
57
- }
58
- else {
59
- const activeRectangle = this.board.getRectangle(element);
60
- if (activeRectangle) {
61
- let opacity = '0.5';
62
- if (activeRectangle.height === 0 || activeRectangle.width === 0) {
63
- opacity = '0.8';
64
- }
65
- const strokeG = drawRectangle(this.board, activeRectangle, {
66
- stroke: PRIMARY_COLOR,
67
- strokeWidth: DefaultDrawActiveStyle.selectionStrokeWidth
68
- });
69
- strokeG.style.opacity = opacity;
70
- activeG.appendChild(strokeG);
71
- }
72
- }
73
- return activeG;
74
- }
75
- needUpdate() {
76
- const selectedElements = getSelectedElements(this.board);
77
- const onlySelectedCurrentLine = selectedElements.length === 1;
78
- return onlySelectedCurrentLine !== this.onlySelectedCurrentLine;
79
- }
80
- }
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arrow-line-active.generator.js","sourceRoot":"","sources":["../../../../packages/draw/src/generators/arrow-line-active.generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, Point, createG, drawRectangle, getSelectedElements } from '@plait/core';\nimport { ArrowLineShape, PlaitArrowLine } from '../interfaces';\nimport { Generator, PRIMARY_COLOR, drawFillPrimaryHandle, drawPrimaryHandle } from '@plait/common';\nimport { getMiddlePoints } from '../utils/arrow-line/arrow-line-basic';\nimport { getNextRenderPoints } from '../utils/arrow-line/elbow';\nimport { isUpdatedHandleIndex } from '../utils/arrow-line';\nimport { getHitPointIndex } from '../utils/position/arrow-line';\nimport { DefaultDrawActiveStyle } from '../constants';\n\nexport interface ActiveData {\n    selected: boolean;\n    linePoints: Point[];\n}\n\nexport class ArrowLineActiveGenerator extends Generator<PlaitArrowLine, ActiveData> {\n    onlySelectedCurrentLine = false;\n\n    canDraw(element: PlaitArrowLine, data: ActiveData): boolean {\n        if (data.selected) {\n            return true;\n        } else {\n            return false;\n        }\n    }\n\n    draw(element: PlaitArrowLine, data: ActiveData): SVGGElement {\n        const activeG = createG();\n        const selectedElements = getSelectedElements(this.board);\n        this.onlySelectedCurrentLine = selectedElements.length === 1;\n        if (this.onlySelectedCurrentLine) {\n            activeG.classList.add('active');\n            activeG.classList.add('line-handle');\n            const points = PlaitArrowLine.getPoints(this.board, element);\n            let updatePoints = [...points];\n            let elbowNextRenderPoints: Point[] = [];\n            if (element.shape === ArrowLineShape.elbow) {\n                updatePoints = points.slice(0, 1).concat(points.slice(-1));\n                elbowNextRenderPoints = getNextRenderPoints(this.board, element, data.linePoints);\n            }\n            updatePoints.forEach(point => {\n                const updateHandle = drawPrimaryHandle(this.board, point);\n                activeG.appendChild(updateHandle);\n            });\n            const middlePoints = getMiddlePoints(this.board, element);\n            if (!PlaitBoard.hasBeenTextEditing(this.board)) {\n                for (let i = 0; i < middlePoints.length; i++) {\n                    const point = middlePoints[i];\n                    if (element.shape === ArrowLineShape.elbow && elbowNextRenderPoints.length) {\n                        const handleIndex = getHitPointIndex(middlePoints, point);\n                        const isUpdateHandleIndex = isUpdatedHandleIndex(\n                            this.board,\n                            element,\n                            [...points],\n                            elbowNextRenderPoints,\n                            handleIndex\n                        );\n                        if (isUpdateHandleIndex) {\n                            const updateHandle = drawPrimaryHandle(this.board, point);\n                            activeG.appendChild(updateHandle);\n                            continue;\n                        }\n                    }\n                    const circle = drawFillPrimaryHandle(this.board, point);\n                    activeG.appendChild(circle);\n                }\n            }\n        } else {\n            const activeRectangle = this.board.getRectangle(element);\n            if (activeRectangle) {\n                let opacity = '0.5';\n                if (activeRectangle.height === 0 || activeRectangle.width === 0) {\n                    opacity = '0.8';\n                }\n                const strokeG = drawRectangle(this.board, activeRectangle, {\n                    stroke: PRIMARY_COLOR,\n                    strokeWidth: DefaultDrawActiveStyle.selectionStrokeWidth\n                });\n                strokeG.style.opacity = opacity;\n                activeG.appendChild(strokeG);\n            }\n        }\n        return activeG;\n    }\n\n    needUpdate() {\n        const selectedElements = getSelectedElements(this.board);\n        const onlySelectedCurrentLine = selectedElements.length === 1;\n        return onlySelectedCurrentLine !== this.onlySelectedCurrentLine;\n    }\n}\n"]}
@@ -1,13 +0,0 @@
1
- import { Point } from '@plait/core';
2
- import { PlaitArrowLine } from '../interfaces';
3
- import { Generator } from '@plait/common';
4
- export interface ActiveData {
5
- selected: boolean;
6
- linePoints: Point[];
7
- }
8
- export declare class ArrowLineActiveGenerator extends Generator<PlaitArrowLine, ActiveData> {
9
- onlySelectedCurrentLine: boolean;
10
- canDraw(element: PlaitArrowLine, data: ActiveData): boolean;
11
- draw(element: PlaitArrowLine, data: ActiveData): SVGGElement;
12
- needUpdate(): boolean;
13
- }