@plait/draw 0.50.1 → 0.51.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 (84) hide show
  1. package/README.md +13 -1
  2. package/constants/line.d.ts +1 -0
  3. package/engines/basic-shapes/ellipse.d.ts +1 -10
  4. package/engines/flowchart/terminal.d.ts +1 -0
  5. package/esm2022/constants/line.mjs +2 -1
  6. package/esm2022/engines/basic-shapes/comment.mjs +4 -5
  7. package/esm2022/engines/basic-shapes/ellipse.mjs +5 -29
  8. package/esm2022/engines/basic-shapes/parallelogram.mjs +3 -2
  9. package/esm2022/engines/basic-shapes/pentagon.mjs +3 -3
  10. package/esm2022/engines/basic-shapes/polygon.mjs +20 -4
  11. package/esm2022/engines/basic-shapes/process-arrow.mjs +3 -3
  12. package/esm2022/engines/basic-shapes/rectangle.mjs +4 -4
  13. package/esm2022/engines/basic-shapes/round-comment.mjs +4 -5
  14. package/esm2022/engines/basic-shapes/round-rectangle.mjs +3 -3
  15. package/esm2022/engines/basic-shapes/star.mjs +3 -3
  16. package/esm2022/engines/basic-shapes/trapezoid.mjs +3 -2
  17. package/esm2022/engines/basic-shapes/triangle.mjs +5 -4
  18. package/esm2022/engines/flowchart/delay.mjs +6 -6
  19. package/esm2022/engines/flowchart/manual-input.mjs +5 -4
  20. package/esm2022/engines/flowchart/manual-loop.mjs +3 -2
  21. package/esm2022/engines/flowchart/merge.mjs +4 -4
  22. package/esm2022/engines/flowchart/stored-data.mjs +16 -10
  23. package/esm2022/engines/flowchart/terminal.mjs +37 -27
  24. package/esm2022/generators/geometry-shape.generator.mjs +3 -3
  25. package/esm2022/generators/line-active.generator.mjs +52 -68
  26. package/esm2022/generators/line.generator.mjs +2 -2
  27. package/esm2022/geometry.component.mjs +7 -7
  28. package/esm2022/image.component.mjs +4 -4
  29. package/esm2022/interfaces/geometry.mjs +1 -1
  30. package/esm2022/interfaces/line.mjs +2 -2
  31. package/esm2022/line.component.mjs +42 -12
  32. package/esm2022/plugins/with-draw-fragment.mjs +3 -3
  33. package/esm2022/plugins/with-draw-hotkey.mjs +6 -6
  34. package/esm2022/plugins/with-draw-resize.mjs +149 -0
  35. package/esm2022/plugins/with-draw.mjs +14 -8
  36. package/esm2022/plugins/with-geometry-create.mjs +10 -10
  37. package/esm2022/plugins/with-geometry-resize.mjs +27 -74
  38. package/esm2022/plugins/with-line-auto-complete.mjs +17 -5
  39. package/esm2022/plugins/with-line-bound-reaction.mjs +6 -5
  40. package/esm2022/plugins/with-line-create.mjs +2 -2
  41. package/esm2022/plugins/with-line-resize.mjs +105 -19
  42. package/esm2022/plugins/with-line-text-move.mjs +5 -4
  43. package/esm2022/plugins/with-line-text.mjs +7 -5
  44. package/esm2022/transforms/geometry.mjs +4 -4
  45. package/esm2022/transforms/line.mjs +6 -8
  46. package/esm2022/utils/clipboard.mjs +2 -2
  47. package/esm2022/utils/geometry.mjs +16 -33
  48. package/esm2022/utils/hit.mjs +18 -10
  49. package/esm2022/utils/index.mjs +2 -2
  50. package/esm2022/utils/line/elbow.mjs +101 -0
  51. package/esm2022/utils/line/index.mjs +6 -0
  52. package/esm2022/utils/line/line-arrow.mjs +123 -0
  53. package/esm2022/utils/line/line-basic.mjs +258 -0
  54. package/esm2022/utils/line/line-common.mjs +111 -0
  55. package/esm2022/utils/line/line-resize.mjs +313 -0
  56. package/esm2022/utils/polygon.mjs +30 -0
  57. package/esm2022/utils/position/geometry.mjs +5 -6
  58. package/esm2022/utils/position/line.mjs +38 -15
  59. package/esm2022/utils/resize-align-reaction.mjs +316 -0
  60. package/esm2022/utils/resize-align.mjs +37 -0
  61. package/fesm2022/plait-draw.mjs +2117 -1152
  62. package/fesm2022/plait-draw.mjs.map +1 -1
  63. package/generators/line-active.generator.d.ts +4 -2
  64. package/interfaces/geometry.d.ts +1 -0
  65. package/interfaces/line.d.ts +4 -0
  66. package/package.json +1 -1
  67. package/plugins/with-draw-resize.d.ts +13 -0
  68. package/utils/geometry.d.ts +1 -3
  69. package/utils/hit.d.ts +3 -1
  70. package/utils/index.d.ts +1 -1
  71. package/utils/line/elbow.d.ts +19 -0
  72. package/utils/line/index.d.ts +5 -0
  73. package/utils/{line-arrow.d.ts → line/line-arrow.d.ts} +1 -1
  74. package/utils/line/line-basic.d.ts +13 -0
  75. package/utils/line/line-common.d.ts +35 -0
  76. package/utils/line/line-resize.d.ts +23 -0
  77. package/utils/polygon.d.ts +4 -0
  78. package/utils/position/geometry.d.ts +2 -3
  79. package/utils/position/line.d.ts +4 -2
  80. package/utils/resize-align-reaction.d.ts +42 -0
  81. package/utils/resize-align.d.ts +8 -0
  82. package/esm2022/utils/line-arrow.mjs +0 -123
  83. package/esm2022/utils/line.mjs +0 -392
  84. package/utils/line.d.ts +0 -25
@@ -1,11 +1,13 @@
1
- import { PlaitBoard, Point } from '@plait/core';
1
+ import { Point } from '@plait/core';
2
2
  import { PlaitLine } from '../interfaces';
3
3
  import { Generator } from '@plait/common';
4
4
  export interface ActiveData {
5
5
  selected: boolean;
6
+ linePoints: Point[];
6
7
  }
7
8
  export declare class LineActiveGenerator extends Generator<PlaitLine, ActiveData> {
9
+ onlySelectedCurrentLine: boolean;
8
10
  canDraw(element: PlaitLine, data: ActiveData): boolean;
9
11
  draw(element: PlaitLine, data: ActiveData): SVGGElement;
12
+ needUpdate(): boolean;
10
13
  }
11
- export declare function getMiddlePoints(board: PlaitBoard, element: PlaitLine): Point[];
@@ -64,6 +64,7 @@ export declare const PlaitGeometry: {};
64
64
  export interface ShapeEngine {
65
65
  isHit: (rectangle: RectangleClient, point: Point) => boolean;
66
66
  getNearestPoint: (rectangle: RectangleClient, point: Point) => Point;
67
+ getNearestCrossingPoint?: (rectangle: RectangleClient, point: Point) => Point;
67
68
  getConnectorPoints: (rectangle: RectangleClient) => Point[];
68
69
  getCornerPoints: (rectangle: RectangleClient) => Point[];
69
70
  getEdgeByConnectionPoint?: (rectangle: RectangleClient, point: PointOfRectangle) => [Point, Point] | null;
@@ -41,6 +41,10 @@ export interface LineHandleRef {
41
41
  vector: Vector;
42
42
  boundElement?: PlaitGeometry;
43
43
  }
44
+ export interface LineHandleRefPair {
45
+ source: LineHandleRef;
46
+ target: LineHandleRef;
47
+ }
44
48
  export interface PlaitLine extends PlaitElement {
45
49
  type: 'line';
46
50
  shape: LineShape;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@plait/draw",
3
- "version": "0.50.1",
3
+ "version": "0.51.1",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^16.0.0",
6
6
  "@angular/core": "^16.0.0",
@@ -0,0 +1,13 @@
1
+ import { ResizeRef, ResizeState } from '@plait/common';
2
+ import { PlaitBoard, Point } from '@plait/core';
3
+ import { PlaitDrawElement } from '../interfaces';
4
+ export declare function withDrawResize(board: PlaitBoard): PlaitBoard;
5
+ export declare const getResizeOriginPointAndHandlePoint: (board: PlaitBoard, resizeRef: ResizeRef<PlaitDrawElement | PlaitDrawElement[]>) => {
6
+ originPoint: Point;
7
+ handlePoint: Point;
8
+ };
9
+ export declare const getResizeZoom: (resizeState: ResizeState, resizeOriginPoint: Point, resizeHandlePoint: Point, isFromCorner: boolean, isAspectRatio: boolean) => {
10
+ xZoom: number;
11
+ yZoom: number;
12
+ };
13
+ export declare const movePointByZoomAndOriginPoint: (p: Point, resizeOriginPoint: Point, xZoom: number, yZoom: number) => Point;
@@ -11,7 +11,6 @@ export type TextProperties = Partial<CustomText> & {
11
11
  textHeight?: number;
12
12
  };
13
13
  export declare const createGeometryElement: (shape: GeometryShapes, points: [Point, Point], text: string | Element, options?: GeometryStyleOptions, textProperties?: TextProperties) => PlaitGeometry;
14
- export declare const getPointsByCenterPoint: (point: Point, width: number, height: number) => [Point, Point];
15
14
  export declare const getTextRectangle: (element: PlaitGeometry) => {
16
15
  height: number;
17
16
  width: number;
@@ -20,9 +19,8 @@ export declare const getTextRectangle: (element: PlaitGeometry) => {
20
19
  };
21
20
  export declare const drawBoundMask: (board: PlaitBoard, element: PlaitGeometry) => SVGGElement;
22
21
  export declare const drawGeometry: (board: PlaitBoard, outerRectangle: RectangleClient, shape: GeometryShapes, options: Options) => SVGGElement;
23
- export declare const getNearestPoint: (element: PlaitShape, point: Point, inflateDelta?: number) => Point;
22
+ export declare const getNearestPoint: (element: PlaitShape, point: Point) => Point;
24
23
  export declare const getCenterPointsOnPolygon: (points: Point[]) => Point[];
25
- export declare const getEdgeOnPolygonByPoint: (corners: Point[], point: Point) => [Point, Point] | null;
26
24
  export declare const getDefaultFlowchartProperty: (symbol: FlowchartSymbols) => {
27
25
  width: number;
28
26
  height: number;
package/utils/hit.d.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  import { PlaitElement, Selection, PlaitBoard, Point } from '@plait/core';
2
- import { PlaitGeometry } from '../interfaces';
2
+ import { PlaitGeometry, PlaitLine } from '../interfaces';
3
3
  export declare const isTextExceedingBounds: (geometry: PlaitGeometry) => boolean;
4
+ export declare const isHitLineText: (board: PlaitBoard, element: PlaitLine, point: Point) => boolean;
5
+ export declare const isHitPolyLine: (pathPoints: Point[], point: Point, strokeWidth: number, expand?: number) => boolean;
4
6
  export declare const isRectangleHitDrawElement: (board: PlaitBoard, element: PlaitElement, selection: Selection) => boolean | null;
5
7
  export declare const isHitDrawElement: (board: PlaitBoard, element: PlaitElement, point: Point) => boolean | null;
package/utils/index.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- export * from './line';
1
+ export * from './line/index';
2
2
  export * from './geometry';
3
3
  export * from './selected';
4
4
  export * from './style';
@@ -0,0 +1,19 @@
1
+ import { Point, PlaitBoard } from '@plait/core';
2
+ import { LineHandleRefPair, PlaitLine } from '../../interfaces';
3
+ export declare const getElbowPoints: (board: PlaitBoard, element: PlaitLine) => Point[];
4
+ export declare const getNextSourceAndTargetPoints: (board: PlaitBoard, element: PlaitLine) => Point[];
5
+ export declare const getSourceAndTargetRectangle: (board: PlaitBoard, element: PlaitLine, handleRefPair: LineHandleRefPair) => {
6
+ sourceRectangle: {
7
+ x: number;
8
+ y: number;
9
+ width: number;
10
+ height: number;
11
+ };
12
+ targetRectangle: {
13
+ x: number;
14
+ y: number;
15
+ width: number;
16
+ height: number;
17
+ };
18
+ };
19
+ export declare function getNextRenderPoints(board: PlaitBoard, element: PlaitLine, renderPoints?: Point[]): Point[];
@@ -0,0 +1,5 @@
1
+ export * from './elbow';
2
+ export * from './line-arrow';
3
+ export * from './line-basic';
4
+ export * from './line-common';
5
+ export * from './line-resize';
@@ -1,4 +1,4 @@
1
1
  import { Point } from '@plait/core';
2
- import { PlaitLine } from '../interfaces';
2
+ import { PlaitLine } from '../../interfaces';
3
3
  import { Options } from 'roughjs/bin/core';
4
4
  export declare const drawLineArrow: (element: PlaitLine, points: Point[], options: Options) => SVGGElement | null;
@@ -0,0 +1,13 @@
1
+ import { Point, PlaitBoard, RectangleClient } from '@plait/core';
2
+ import { LineHandle, LineShape, LineText, PlaitLine, PlaitShape } from '../../interfaces';
3
+ export declare const createLineElement: (shape: LineShape, points: [Point, Point], source: LineHandle, target: LineHandle, texts?: LineText[], options?: Pick<PlaitLine, 'strokeColor' | 'strokeWidth'>) => PlaitLine;
4
+ export declare const getLinePoints: (board: PlaitBoard, element: PlaitLine) => Point[];
5
+ export declare const getCurvePoints: (board: PlaitBoard, element: PlaitLine) => Point[];
6
+ export declare function getMiddlePoints(board: PlaitBoard, element: PlaitLine): Point[];
7
+ export declare const drawLine: (board: PlaitBoard, element: PlaitLine) => SVGGElement;
8
+ export declare const getConnectionByNearestPoint: (board: PlaitBoard, point: Point, hitElement: PlaitShape) => Point;
9
+ export declare const getHitConnectorPoint: (point: Point, hitElement: PlaitShape, rectangle: RectangleClient) => Point | undefined;
10
+ export declare const getLineTextRectangle: (board: PlaitBoard, element: PlaitLine, index: number) => RectangleClient;
11
+ export declare const getLines: (board: PlaitBoard) => PlaitLine[];
12
+ export declare const Q2C: (points: Point[]) => Point[];
13
+ export declare const handleLineCreating: (board: PlaitBoard, lineShape: LineShape, sourcePoint: Point, movingPoint: Point, sourceElement: PlaitShape | null, lineShapeG: SVGGElement) => PlaitLine;
@@ -0,0 +1,35 @@
1
+ import { Point, PlaitBoard, PointOfRectangle, Direction, Vector } from '@plait/core';
2
+ import { LineHandleRefPair, PlaitGeometry, PlaitLine } from '../../interfaces';
3
+ export declare const getLineHandleRefPair: (board: PlaitBoard, element: PlaitLine) => LineHandleRefPair;
4
+ export declare const getConnectionPoint: (geometry: PlaitGeometry, connection: Point, direction?: Direction, delta?: number) => Point;
5
+ export declare const getVectorByConnection: (boundElement: PlaitGeometry, connection: PointOfRectangle) => Vector;
6
+ export declare const getElbowLineRouteOptions: (board: PlaitBoard, element: PlaitLine, handleRefPair?: LineHandleRefPair) => {
7
+ sourcePoint: PointOfRectangle;
8
+ nextSourcePoint: Point;
9
+ sourceRectangle: {
10
+ x: number;
11
+ y: number;
12
+ width: number;
13
+ height: number;
14
+ };
15
+ sourceOuterRectangle: {
16
+ x: number;
17
+ y: number;
18
+ width: number;
19
+ height: number;
20
+ };
21
+ targetPoint: PointOfRectangle;
22
+ nextTargetPoint: Point;
23
+ targetRectangle: {
24
+ x: number;
25
+ y: number;
26
+ width: number;
27
+ height: number;
28
+ };
29
+ targetOuterRectangle: {
30
+ x: number;
31
+ y: number;
32
+ width: number;
33
+ height: number;
34
+ };
35
+ };
@@ -0,0 +1,23 @@
1
+ import { ElbowLineRouteOptions, ResizeState } from '@plait/common';
2
+ import { PlaitBoard, Point } from '@plait/core';
3
+ import { PlaitLine } from '../../interfaces';
4
+ export declare const alignPoints: (basePoint: Point, movingPoint: Point) => Point;
5
+ export declare function getResizedPreviousAndNextPoint(nextRenderPoints: Point[], sourcePoint: Point, targetPoint: Point, handleIndex: number): {
6
+ previous: Point | null;
7
+ next: Point | null;
8
+ };
9
+ export declare function alignElbowSegment(startKeyPoint: Point, endKeyPoint: Point, resizeState: ResizeState, resizedPreviousAndNextPoint: {
10
+ previous: Point | null;
11
+ next: Point | null;
12
+ }): Point[];
13
+ export declare function getIndexAndDeleteCountByKeyPoint(board: PlaitBoard, element: PlaitLine, dataPoints: Point[], nextRenderPoints: Point[], handleIndex: number): {
14
+ index: null;
15
+ deleteCount: null;
16
+ } | {
17
+ index: number;
18
+ deleteCount: number | null;
19
+ };
20
+ export declare function getMirrorDataPoints(board: PlaitBoard, nextDataPoints: Point[], nextKeyPoints: Point[], params: ElbowLineRouteOptions): Point[];
21
+ export declare function isUpdatedHandleIndex(board: PlaitBoard, element: PlaitLine, dataPoints: Point[], nextRenderPoints: Point[], handleIndex: number): boolean;
22
+ export declare function getMidKeyPoints(simplifiedNextKeyPoints: Point[], startPoint: Point, endPoint: Point): Point[];
23
+ export declare const hasIllegalElbowPoint: (midDataPoints: Point[]) => boolean;
@@ -0,0 +1,4 @@
1
+ import { Point } from '@plait/core';
2
+ export declare const getCenterPointsOnPolygon: (points: Point[]) => Point[];
3
+ export declare const getCrossingPointBetweenPointAndPolygon: (corners: Point[], point: Point) => Point[];
4
+ export declare const getPolygonEdgeByConnectionPoint: (corners: Point[], point: Point) => [Point, Point] | null;
@@ -1,8 +1,7 @@
1
- import { PlaitBoard, Point } from '@plait/core';
1
+ import { PlaitBoard, Point, RectangleClient } from '@plait/core';
2
2
  import { PlaitGeometry } from '../../interfaces';
3
3
  import { ResizeHandle } from '@plait/common';
4
- import { PlaitImage } from '../../interfaces/image';
5
- export declare const getHitGeometryResizeHandleRef: (board: PlaitBoard, element: PlaitGeometry | PlaitImage, point: Point) => {
4
+ export declare const getHitRectangleResizeHandleRef: (board: PlaitBoard, rectangle: RectangleClient, point: Point) => {
6
5
  rectangle: {
7
6
  x: number;
8
7
  y: number;
@@ -7,8 +7,10 @@ export declare enum LineResizeHandle {
7
7
  }
8
8
  export declare const getHitLineResizeHandleRef: (board: PlaitBoard, element: PlaitLine, point: Point) => {
9
9
  handle: LineResizeHandle;
10
- index: number;
10
+ handleIndex: number;
11
11
  } | {
12
- index: number;
12
+ handleIndex: number;
13
13
  handle?: undefined;
14
14
  } | undefined;
15
+ export declare function getHitPointIndex(points: Point[], movingPoint: Point): number;
16
+ export declare const getHitLineTextIndex: (board: PlaitBoard, element: PlaitLine, point: Point) => number;
@@ -0,0 +1,42 @@
1
+ import { ResizeState } from '@plait/common';
2
+ import { DirectionFactors, PlaitBoard, PlaitElement, Point, RectangleClient } from '@plait/core';
3
+ export interface ResizeAlignDelta {
4
+ deltaX: number;
5
+ deltaY: number;
6
+ }
7
+ export interface AlignLineRef extends ResizeAlignDelta {
8
+ xZoom: number;
9
+ yZoom: number;
10
+ activePoints: Point[];
11
+ }
12
+ export interface ResizeAlignRef extends AlignLineRef {
13
+ alignG: SVGGElement;
14
+ }
15
+ export interface ResizeAlignOptions {
16
+ resizeState: ResizeState;
17
+ resizeOriginPoints: Point[];
18
+ activeRectangle: RectangleClient;
19
+ directionFactors: DirectionFactors;
20
+ originPoint: Point;
21
+ handlePoint: Point;
22
+ isFromCorner: boolean;
23
+ isAspectRatio: boolean;
24
+ }
25
+ type TripleAlignAxis = [number, number, number];
26
+ export declare class ResizeAlignReaction {
27
+ private board;
28
+ private activeElements;
29
+ alignRectangles: RectangleClient[];
30
+ constructor(board: PlaitBoard, activeElements: PlaitElement[]);
31
+ getAlignRectangle(): RectangleClient[];
32
+ getAlignLineRef(resizeAlignDelta: ResizeAlignDelta, resizeAlignOptions: ResizeAlignOptions): AlignLineRef;
33
+ getEqualLineDelta(resizeAlignOptions: ResizeAlignOptions): ResizeAlignDelta;
34
+ drawEqualLines(activePoints: Point[], resizeAlignOptions: ResizeAlignOptions): SVGGElement;
35
+ getAlignLineDelta(resizeAlignOptions: ResizeAlignOptions): ResizeAlignDelta;
36
+ drawAlignLines(activePoints: Point[], resizeAlignOptions: ResizeAlignOptions): SVGGElement;
37
+ handleResizeAlign(resizeAlignOptions: ResizeAlignOptions): ResizeAlignRef;
38
+ }
39
+ export declare const getTripleAlignAxis: (rectangle: RectangleClient, isHorizontal: boolean) => TripleAlignAxis;
40
+ export declare const isAlign: (axis: number, rectangle: RectangleClient, isHorizontal: boolean) => boolean;
41
+ export declare const getClosestDelta: (axis: number, rectangle: RectangleClient, isHorizontal: boolean) => number;
42
+ export {};
@@ -0,0 +1,8 @@
1
+ import { PlaitBoard, Point } from '@plait/core';
2
+ import { ResizeRef, ResizeState } from '@plait/common';
3
+ import { PlaitDrawElement } from '../interfaces';
4
+ import { ResizeAlignRef } from './resize-align-reaction';
5
+ export declare function getResizeAlignRef(board: PlaitBoard, resizeRef: ResizeRef<PlaitDrawElement | PlaitDrawElement[]>, resizeState: ResizeState, resizeOriginPointAndHandlePoint: {
6
+ originPoint: Point;
7
+ handlePoint: Point;
8
+ }, isAspectRatio: boolean, isFromCorner: boolean): ResizeAlignRef;
@@ -1,123 +0,0 @@
1
- import { arrowPoints, createG, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate } from '@plait/core';
2
- import { LineMarkerType, PlaitLine } from '../interfaces';
3
- import { getFactorByPoints, getExtendPoint } from '@plait/common';
4
- import { getStrokeWidthByElement } from './style';
5
- const ARROW_LENGTH = 20;
6
- export const drawLineArrow = (element, points, options) => {
7
- const arrowG = createG();
8
- if (PlaitLine.isSourceMark(element, LineMarkerType.none) && PlaitLine.isTargetMark(element, LineMarkerType.none)) {
9
- return null;
10
- }
11
- const strokeWidth = getStrokeWidthByElement(element);
12
- const offset = (strokeWidth * strokeWidth) / 3;
13
- if (points.length === 1) {
14
- points = [points[0], [points[0][0] + 0.1, points[0][1]]];
15
- }
16
- if (!PlaitLine.isSourceMark(element, LineMarkerType.none)) {
17
- const source = getExtendPoint(points[0], points[1], ARROW_LENGTH + offset);
18
- const sourceArrow = getArrow(element, { marker: element.source.marker, source, target: points[0], isSource: true }, options);
19
- sourceArrow && arrowG.appendChild(sourceArrow);
20
- }
21
- if (!PlaitLine.isTargetMark(element, LineMarkerType.none)) {
22
- const source = getExtendPoint(points[points.length - 1], points[points.length - 2], ARROW_LENGTH + offset);
23
- const arrow = getArrow(element, { marker: element.target.marker, source, target: points[points.length - 1], isSource: false }, options);
24
- arrow && arrowG.appendChild(arrow);
25
- }
26
- return arrowG;
27
- };
28
- const getArrow = (element, arrowOptions, options) => {
29
- const { marker, target, source, isSource } = arrowOptions;
30
- let targetArrow;
31
- switch (marker) {
32
- case LineMarkerType.openTriangle: {
33
- targetArrow = drawOpenTriangle(element, source, target, options);
34
- break;
35
- }
36
- case LineMarkerType.solidTriangle: {
37
- targetArrow = drawSolidTriangle(source, target, options);
38
- break;
39
- }
40
- case LineMarkerType.arrow: {
41
- targetArrow = drawArrow(element, source, target, options);
42
- break;
43
- }
44
- case LineMarkerType.sharpArrow: {
45
- targetArrow = drawSharpArrow(source, target, options);
46
- break;
47
- }
48
- case LineMarkerType.oneSideUp: {
49
- targetArrow = drawOneSideArrow(source, target, isSource ? 'down' : 'up', options);
50
- break;
51
- }
52
- case LineMarkerType.oneSideDown: {
53
- targetArrow = drawOneSideArrow(source, target, isSource ? 'up' : 'down', options);
54
- break;
55
- }
56
- case LineMarkerType.hollowTriangle: {
57
- targetArrow = drawHollowTriangleArrow(source, target, options);
58
- break;
59
- }
60
- case LineMarkerType.singleSlash: {
61
- targetArrow = drawSingleSlash(source, target, isSource, options);
62
- break;
63
- }
64
- }
65
- return targetArrow;
66
- };
67
- const drawSharpArrow = (source, target, options) => {
68
- const startPoint = target;
69
- const { pointLeft, pointRight } = arrowPoints(source, target, 20);
70
- const g = createG();
71
- const path = createPath();
72
- let polylinePath = `M${pointRight[0]},${pointRight[1]}A25,25,20,0,1,${pointLeft[0]},${pointLeft[1]}L${startPoint[0]},${startPoint[1]}Z`;
73
- path.setAttribute('d', polylinePath);
74
- path.setAttribute('stroke', `${options?.stroke}`);
75
- path.setAttribute('stroke-width', `${options?.strokeWidth}`);
76
- path.setAttribute('fill', `${options?.stroke}`);
77
- g.appendChild(path);
78
- return g;
79
- };
80
- const drawArrow = (element, source, target, options) => {
81
- const directionFactor = getFactorByPoints(source, target);
82
- const strokeWidth = getStrokeWidthByElement(element);
83
- const endPoint = [target[0] + (strokeWidth * directionFactor.x) / 2, target[1] + (strokeWidth * directionFactor.y) / 2];
84
- const distance = distanceBetweenPointAndPoint(...source, ...endPoint);
85
- const middlePoint = [
86
- endPoint[0] - (((distance * 3) / 5 + strokeWidth) / 2) * directionFactor.x,
87
- endPoint[1] - (((distance * 3) / 5 + strokeWidth) / 2) * directionFactor.y
88
- ];
89
- const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);
90
- const arrowG = drawLinearPath([pointLeft, endPoint, pointRight, middlePoint], { ...options, fill: options.stroke }, true);
91
- const path = arrowG.querySelector('path');
92
- path.setAttribute('stroke-linejoin', 'round');
93
- return arrowG;
94
- };
95
- const drawSolidTriangle = (source, target, options) => {
96
- const endPoint = target;
97
- const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);
98
- return drawLinearPath([pointLeft, endPoint, pointRight], { ...options, fill: options.stroke }, true);
99
- };
100
- const drawOpenTriangle = (element, source, target, options) => {
101
- const directionFactor = getFactorByPoints(source, target);
102
- const strokeWidth = getStrokeWidthByElement(element);
103
- const endPoint = [target[0] + (strokeWidth * directionFactor.x) / 2, target[1] + (strokeWidth * directionFactor.y) / 2];
104
- const { pointLeft, pointRight } = arrowPoints(source, endPoint, 40);
105
- return drawLinearPath([pointLeft, endPoint, pointRight], options);
106
- };
107
- const drawOneSideArrow = (source, target, side, options) => {
108
- const { pointLeft, pointRight } = arrowPoints(source, target, 40);
109
- return drawLinearPath([side === 'up' ? pointRight : pointLeft, target], options);
110
- };
111
- const drawSingleSlash = (source, target, isSource, options) => {
112
- const length = distanceBetweenPointAndPoint(...source, ...target);
113
- const middlePoint = getExtendPoint(target, source, length / 2);
114
- const angle = isSource ? 120 : 60;
115
- const start = rotate(...source, ...middlePoint, (angle * Math.PI) / 180);
116
- const end = rotate(...target, ...middlePoint, (angle * Math.PI) / 180);
117
- return drawLinearPath([start, end], options);
118
- };
119
- const drawHollowTriangleArrow = (source, target, options) => {
120
- const { pointLeft, pointRight } = arrowPoints(source, target, 30);
121
- return drawLinearPath([pointLeft, pointRight, target], { ...options, fill: 'white' }, true);
122
- };
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-arrow.js","sourceRoot":"","sources":["../../../../packages/draw/src/utils/line-arrow.ts"],"names":[],"mappings":"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","sourcesContent":["import { Point, arrowPoints, createG, createPath, distanceBetweenPointAndPoint, drawLinearPath, rotate } from '@plait/core';\nimport { LineMarkerType, PlaitLine } from '../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getFactorByPoints, getExtendPoint } from '@plait/common';\nimport { getStrokeWidthByElement } from './style';\n\ninterface ArrowOptions {\n    marker: LineMarkerType;\n    source: Point;\n    target: Point;\n    isSource: boolean;\n}\nconst ARROW_LENGTH = 20;\n\nexport const drawLineArrow = (element: PlaitLine, points: Point[], options: Options) => {\n    const arrowG = createG();\n    if (PlaitLine.isSourceMark(element, LineMarkerType.none) && PlaitLine.isTargetMark(element, LineMarkerType.none)) {\n        return null;\n    }\n    const strokeWidth = getStrokeWidthByElement(element);\n    const offset = (strokeWidth * strokeWidth) / 3;\n    if (points.length === 1) {\n        points = [points[0], [points[0][0] + 0.1, points[0][1]]];\n    }\n\n    if (!PlaitLine.isSourceMark(element, LineMarkerType.none)) {\n        const source = getExtendPoint(points[0], points[1], ARROW_LENGTH + offset);\n        const sourceArrow = getArrow(element, { marker: element.source.marker, source, target: points[0], isSource: true }, options);\n        sourceArrow && arrowG.appendChild(sourceArrow);\n    }\n    if (!PlaitLine.isTargetMark(element, LineMarkerType.none)) {\n        const source = getExtendPoint(points[points.length - 1], points[points.length - 2], ARROW_LENGTH + offset);\n        const arrow = getArrow(\n            element,\n            { marker: element.target.marker, source, target: points[points.length - 1], isSource: false },\n            options\n        );\n\n        arrow && arrowG.appendChild(arrow);\n    }\n    return arrowG;\n};\n\nconst getArrow = (element: PlaitLine, arrowOptions: ArrowOptions, options: Options) => {\n    const { marker, target, source, isSource } = arrowOptions;\n    let targetArrow;\n    switch (marker) {\n        case LineMarkerType.openTriangle: {\n            targetArrow = drawOpenTriangle(element, source, target, options);\n            break;\n        }\n        case LineMarkerType.solidTriangle: {\n            targetArrow = drawSolidTriangle(source, target, options);\n            break;\n        }\n        case LineMarkerType.arrow: {\n            targetArrow = drawArrow(element, source, target, options);\n            break;\n        }\n        case LineMarkerType.sharpArrow: {\n            targetArrow = drawSharpArrow(source, target, options);\n            break;\n        }\n        case LineMarkerType.oneSideUp: {\n            targetArrow = drawOneSideArrow(source, target, isSource ? 'down' : 'up', options);\n            break;\n        }\n        case LineMarkerType.oneSideDown: {\n            targetArrow = drawOneSideArrow(source, target, isSource ? 'up' : 'down', options);\n            break;\n        }\n        case LineMarkerType.hollowTriangle: {\n            targetArrow = drawHollowTriangleArrow(source, target, options);\n            break;\n        }\n        case LineMarkerType.singleSlash: {\n            targetArrow = drawSingleSlash(source, target, isSource, options);\n            break;\n        }\n    }\n    return targetArrow;\n};\n\nconst drawSharpArrow = (source: Point, target: Point, options: Options) => {\n    const startPoint: Point = target;\n    const { pointLeft, pointRight } = arrowPoints(source, target, 20);\n    const g = createG();\n    const path = createPath();\n    let polylinePath = `M${pointRight[0]},${pointRight[1]}A25,25,20,0,1,${pointLeft[0]},${pointLeft[1]}L${startPoint[0]},${startPoint[1]}Z`;\n    path.setAttribute('d', polylinePath);\n    path.setAttribute('stroke', `${options?.stroke}`);\n    path.setAttribute('stroke-width', `${options?.strokeWidth}`);\n    path.setAttribute('fill', `${options?.stroke}`);\n    g.appendChild(path);\n    return g;\n};\n\nconst drawArrow = (element: PlaitLine, source: Point, target: Point, options: Options) => {\n    const directionFactor = getFactorByPoints(source, target);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const endPoint: Point = [target[0] + (strokeWidth * directionFactor.x) / 2, target[1] + (strokeWidth * directionFactor.y) / 2];\n    const distance = distanceBetweenPointAndPoint(...source, ...endPoint);\n    const middlePoint: Point = [\n        endPoint[0] - (((distance * 3) / 5 + strokeWidth) / 2) * directionFactor.x,\n        endPoint[1] - (((distance * 3) / 5 + strokeWidth) / 2) * directionFactor.y\n    ];\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);\n    const arrowG = drawLinearPath([pointLeft, endPoint, pointRight, middlePoint], { ...options, fill: options.stroke }, true);\n    const path = arrowG.querySelector('path');\n    path!.setAttribute('stroke-linejoin', 'round');\n    return arrowG;\n};\n\nconst drawSolidTriangle = (source: Point, target: Point, options: Options) => {\n    const endPoint: Point = target;\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 30);\n    return drawLinearPath([pointLeft, endPoint, pointRight], { ...options, fill: options.stroke }, true);\n};\n\nconst drawOpenTriangle = (element: PlaitLine, source: Point, target: Point, options: Options) => {\n    const directionFactor = getFactorByPoints(source, target);\n    const strokeWidth = getStrokeWidthByElement(element);\n    const endPoint: Point = [target[0] + (strokeWidth * directionFactor.x) / 2, target[1] + (strokeWidth * directionFactor.y) / 2];\n    const { pointLeft, pointRight } = arrowPoints(source, endPoint, 40);\n    return drawLinearPath([pointLeft, endPoint, pointRight], options);\n};\n\nconst drawOneSideArrow = (source: Point, target: Point, side: string, options: Options) => {\n    const { pointLeft, pointRight } = arrowPoints(source, target, 40);\n    return drawLinearPath([side === 'up' ? pointRight : pointLeft, target], options);\n};\n\nconst drawSingleSlash = (source: Point, target: Point, isSource: boolean, options: Options) => {\n    const length = distanceBetweenPointAndPoint(...source, ...target);\n    const middlePoint = getExtendPoint(target, source, length / 2);\n    const angle = isSource ? 120 : 60;\n    const start = rotate(...source, ...middlePoint, (angle * Math.PI) / 180) as Point;\n    const end = rotate(...target, ...middlePoint, (angle * Math.PI) / 180) as Point;\n    return drawLinearPath([start, end], options);\n};\n\nconst drawHollowTriangleArrow = (source: Point, target: Point, options: Options) => {\n    const { pointLeft, pointRight } = arrowPoints(source, target, 30);\n    return drawLinearPath([pointLeft, pointRight, target], { ...options, fill: 'white' }, true);\n};\n"]}