@plait/draw 0.55.1 → 0.56.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.
- package/constants/geometry.d.ts +52 -0
- package/engines/basic-shapes/ellipse.d.ts +8 -3
- package/engines/flowchart/database.d.ts +2 -0
- package/engines/flowchart/document.d.ts +2 -0
- package/engines/flowchart/hard-disk.d.ts +2 -0
- package/engines/flowchart/internal-storage.d.ts +2 -0
- package/engines/flowchart/multi-document.d.ts +4 -0
- package/engines/flowchart/note-curly-left.d.ts +2 -0
- package/engines/flowchart/note-curly-right.d.ts +2 -0
- package/engines/flowchart/note-square.d.ts +2 -0
- package/esm2022/constants/geometry.mjs +30 -2
- package/esm2022/engines/basic-shapes/ellipse.mjs +49 -36
- package/esm2022/engines/basic-shapes/round-rectangle.mjs +2 -3
- package/esm2022/engines/flowchart/database.mjs +84 -0
- package/esm2022/engines/flowchart/delay.mjs +2 -3
- package/esm2022/engines/flowchart/document.mjs +81 -0
- package/esm2022/engines/flowchart/hard-disk.mjs +84 -0
- package/esm2022/engines/flowchart/internal-storage.mjs +47 -0
- package/esm2022/engines/flowchart/multi-document.mjs +143 -0
- package/esm2022/engines/flowchart/note-curly-left.mjs +50 -0
- package/esm2022/engines/flowchart/note-curly-right.mjs +50 -0
- package/esm2022/engines/flowchart/note-square.mjs +46 -0
- package/esm2022/engines/flowchart/or.mjs +2 -2
- package/esm2022/engines/flowchart/stored-data.mjs +2 -3
- package/esm2022/engines/flowchart/summing-junction.mjs +2 -2
- package/esm2022/engines/flowchart/terminal.mjs +2 -3
- package/esm2022/engines/index.mjs +18 -2
- package/esm2022/generators/line-active.generator.mjs +15 -13
- package/esm2022/generators/line-auto-complete.generator.mjs +2 -1
- package/esm2022/geometry.component.mjs +12 -20
- package/esm2022/image.component.mjs +8 -8
- package/esm2022/interfaces/geometry.mjs +9 -1
- package/esm2022/line.component.mjs +6 -6
- package/esm2022/plugins/with-draw-fragment.mjs +4 -4
- package/esm2022/plugins/with-draw-hotkey.mjs +5 -5
- package/esm2022/plugins/with-draw-rotate.mjs +6 -7
- package/esm2022/plugins/with-draw.mjs +3 -3
- package/esm2022/plugins/with-geometry-create.mjs +35 -22
- package/esm2022/plugins/with-geometry-resize.mjs +4 -5
- package/esm2022/plugins/with-line-auto-complete-reaction.mjs +6 -4
- package/esm2022/plugins/with-line-text-move.mjs +5 -5
- package/esm2022/plugins/with-line-text.mjs +11 -7
- package/esm2022/utils/geometry.mjs +7 -3
- package/esm2022/utils/selected.mjs +4 -4
- package/fesm2022/plait-draw.mjs +699 -131
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/line-auto-complete.generator.d.ts +1 -0
- package/geometry.component.d.ts +1 -4
- package/image.component.d.ts +1 -3
- package/interfaces/geometry.d.ts +9 -1
- package/line.component.d.ts +1 -3
- package/package.json +1 -1
- package/utils/geometry.d.ts +16 -0
- package/utils/selected.d.ts +2 -2
- package/engines/basic-shapes/circle.d.ts +0 -8
- package/esm2022/engines/basic-shapes/circle.mjs +0 -51
|
@@ -3,6 +3,7 @@ import { PlaitGeometry, PlaitShapeElement } from '../interfaces';
|
|
|
3
3
|
import { ActiveGeneratorExtraData, Generator } from '@plait/common';
|
|
4
4
|
export declare class LineAutoCompleteGenerator extends Generator<PlaitShapeElement, ActiveGeneratorExtraData> {
|
|
5
5
|
board: PlaitBoard;
|
|
6
|
+
static key: string;
|
|
6
7
|
autoCompleteG: SVGGElement;
|
|
7
8
|
hoverElement: SVGGElement | null;
|
|
8
9
|
constructor(board: PlaitBoard);
|
package/geometry.component.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { PlaitGeometry } from './interfaces/geometry';
|
|
@@ -8,17 +8,14 @@ import { ActiveGenerator, CommonPluginElement } from '@plait/common';
|
|
|
8
8
|
import { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
export declare class GeometryComponent extends CommonPluginElement<PlaitGeometry, PlaitBoard> implements OnInit, OnDestroy, OnContextChanged<PlaitGeometry, PlaitBoard> {
|
|
11
|
-
protected cdr: ChangeDetectorRef;
|
|
12
11
|
destroy$: Subject<void>;
|
|
13
12
|
activeGenerator: ActiveGenerator<PlaitGeometry>;
|
|
14
13
|
lineAutoCompleteGenerator: LineAutoCompleteGenerator;
|
|
15
14
|
shapeGenerator: GeometryShapeGenerator;
|
|
16
15
|
get textManage(): TextManage;
|
|
17
|
-
constructor(cdr: ChangeDetectorRef);
|
|
18
16
|
initializeGenerator(): void;
|
|
19
17
|
ngOnInit(): void;
|
|
20
18
|
onContextChanged(value: PlaitPluginElementContext<PlaitGeometry, PlaitBoard>, previous: PlaitPluginElementContext<PlaitGeometry, PlaitBoard>): void;
|
|
21
|
-
editText(): void;
|
|
22
19
|
drawText(): void;
|
|
23
20
|
updateText(): void;
|
|
24
21
|
initializeTextManage(): void;
|
package/image.component.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { CommonPluginElement, ImageGenerator } from '@plait/common';
|
|
@@ -6,12 +6,10 @@ import { PlaitImage } from './interfaces/image';
|
|
|
6
6
|
import { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class ImageComponent extends CommonPluginElement<PlaitImage, PlaitBoard> implements OnInit, OnDestroy, OnContextChanged<PlaitImage, PlaitBoard> {
|
|
9
|
-
protected cdr: ChangeDetectorRef;
|
|
10
9
|
destroy$: Subject<void>;
|
|
11
10
|
get activeGenerator(): import("@plait/common").ActiveGenerator<import("@plait/core").PlaitElement>;
|
|
12
11
|
imageGenerator: ImageGenerator<PlaitImage>;
|
|
13
12
|
lineAutoCompleteGenerator: LineAutoCompleteGenerator;
|
|
14
|
-
constructor(cdr: ChangeDetectorRef);
|
|
15
13
|
initializeGenerator(): void;
|
|
16
14
|
ngOnInit(): void;
|
|
17
15
|
onContextChanged(value: PlaitPluginElementContext<PlaitImage, PlaitBoard>, previous: PlaitPluginElementContext<PlaitImage, PlaitBoard>): void;
|
package/interfaces/geometry.d.ts
CHANGED
|
@@ -40,7 +40,15 @@ export declare enum FlowchartSymbols {
|
|
|
40
40
|
or = "or",
|
|
41
41
|
summingJunction = "summingJunction",
|
|
42
42
|
predefinedProcess = "predefinedProcess",
|
|
43
|
-
offPage = "offPage"
|
|
43
|
+
offPage = "offPage",
|
|
44
|
+
document = "document",
|
|
45
|
+
multiDocument = "multiDocument",
|
|
46
|
+
database = "database",
|
|
47
|
+
hardDisk = "hardDisk",
|
|
48
|
+
internalStorage = "internalStorage",
|
|
49
|
+
noteCurlyRight = "noteCurlyRight",
|
|
50
|
+
noteCurlyLeft = "noteCurlyLeft",
|
|
51
|
+
noteSquare = "noteSquare"
|
|
44
52
|
}
|
|
45
53
|
export type GeometryShapes = BasicShapes | FlowchartSymbols;
|
|
46
54
|
export interface PlaitGeometry extends PlaitElement {
|
package/line.component.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
4
|
import { LineText, PlaitGeometry, PlaitLine } from './interfaces';
|
|
@@ -12,12 +12,10 @@ interface BoundedElements {
|
|
|
12
12
|
target?: PlaitGeometry;
|
|
13
13
|
}
|
|
14
14
|
export declare class LineComponent extends CommonPluginElement<PlaitLine, PlaitBoard> implements OnInit, OnDestroy, OnContextChanged<PlaitLine, PlaitBoard> {
|
|
15
|
-
protected cdr: ChangeDetectorRef;
|
|
16
15
|
destroy$: Subject<void>;
|
|
17
16
|
shapeGenerator: LineShapeGenerator;
|
|
18
17
|
activeGenerator: LineActiveGenerator;
|
|
19
18
|
boundedElements: BoundedElements;
|
|
20
|
-
constructor(cdr: ChangeDetectorRef);
|
|
21
19
|
initializeGenerator(): void;
|
|
22
20
|
ngOnInit(): void;
|
|
23
21
|
getBoundedElements(): BoundedElements;
|
package/package.json
CHANGED
package/utils/geometry.d.ts
CHANGED
|
@@ -42,6 +42,21 @@ export declare const getDefaultFlowchartProperty: (symbol: FlowchartSymbols) =>
|
|
|
42
42
|
} | {
|
|
43
43
|
width: number;
|
|
44
44
|
height: number;
|
|
45
|
+
} | {
|
|
46
|
+
width: number;
|
|
47
|
+
height: number;
|
|
48
|
+
} | {
|
|
49
|
+
width: number;
|
|
50
|
+
height: number;
|
|
51
|
+
} | {
|
|
52
|
+
width: number;
|
|
53
|
+
height: number;
|
|
54
|
+
} | {
|
|
55
|
+
width: number;
|
|
56
|
+
height: number;
|
|
57
|
+
} | {
|
|
58
|
+
width: number;
|
|
59
|
+
height: number;
|
|
45
60
|
};
|
|
46
61
|
export declare const createDefaultFlowchart: (point: Point) => (PlaitGeometry | import("../interfaces").PlaitLine)[];
|
|
47
62
|
export declare const getAutoCompletePoints: (element: PlaitShapeElement) => [Point, Point, Point, Point];
|
|
@@ -61,3 +76,4 @@ export declare const getDefaultTextPoints: (board: PlaitBoard, centerPoint: Poin
|
|
|
61
76
|
export declare const insertElement: (board: PlaitBoard, element: PlaitGeometry) => void;
|
|
62
77
|
export declare const createTextElement: (board: PlaitBoard, points: [Point, Point], text?: string | Element, textHeight?: number) => PlaitGeometry;
|
|
63
78
|
export declare const createDefaultGeometry: (board: PlaitBoard, points: [Point, Point], shape: GeometryShapes) => PlaitGeometry;
|
|
79
|
+
export declare const editText: (element: PlaitGeometry) => void;
|
package/utils/selected.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { PlaitBoard } from '@plait/core';
|
|
1
|
+
import { PlaitBoard, PlaitElement } from '@plait/core';
|
|
2
2
|
import { PlaitDrawElement, PlaitGeometry, PlaitLine } from '../interfaces';
|
|
3
3
|
import { PlaitImage } from '../interfaces/image';
|
|
4
|
-
export declare const getSelectedDrawElements: (board: PlaitBoard) => PlaitDrawElement[];
|
|
4
|
+
export declare const getSelectedDrawElements: (board: PlaitBoard, elements?: PlaitElement[]) => PlaitDrawElement[];
|
|
5
5
|
export declare const getSelectedGeometryElements: (board: PlaitBoard) => PlaitGeometry[];
|
|
6
6
|
export declare const getSelectedLineElements: (board: PlaitBoard) => PlaitLine[];
|
|
7
7
|
export declare const getSelectedImageElements: (board: PlaitBoard) => PlaitImage[];
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient } from '@plait/core';
|
|
2
|
-
import { PlaitGeometry, ShapeEngine } from '../../interfaces';
|
|
3
|
-
import { Options } from 'roughjs/bin/core';
|
|
4
|
-
export interface CreateCircleOptions {
|
|
5
|
-
draw?: (board: PlaitBoard, rectangle: RectangleClient, options: Options) => SVGGElement;
|
|
6
|
-
getTextRectangle?: (element: PlaitGeometry) => RectangleClient;
|
|
7
|
-
}
|
|
8
|
-
export declare function createEllipseEngine(createOptions?: CreateCircleOptions): ShapeEngine;
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { PlaitBoard, RectangleClient, getEllipseTangentSlope, getVectorFromPointAndSlope, isPointInEllipse } from '@plait/core';
|
|
2
|
-
import { getTextRectangle } from '../../utils';
|
|
3
|
-
import { getNearestPointBetweenPointAndEllipse } from './ellipse';
|
|
4
|
-
export function createEllipseEngine(createOptions) {
|
|
5
|
-
const engine = {
|
|
6
|
-
draw(board, rectangle, options) {
|
|
7
|
-
const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];
|
|
8
|
-
const rs = PlaitBoard.getRoughSVG(board);
|
|
9
|
-
return rs.ellipse(centerPoint[0], centerPoint[1], rectangle.width, rectangle.height, { ...options, fillStyle: 'solid' });
|
|
10
|
-
},
|
|
11
|
-
isInsidePoint(rectangle, point) {
|
|
12
|
-
const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];
|
|
13
|
-
return isPointInEllipse(point, centerPoint, rectangle.width / 2, rectangle.height / 2);
|
|
14
|
-
},
|
|
15
|
-
getCornerPoints(rectangle) {
|
|
16
|
-
return RectangleClient.getEdgeCenterPoints(rectangle);
|
|
17
|
-
},
|
|
18
|
-
getNearestPoint(rectangle, point) {
|
|
19
|
-
const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];
|
|
20
|
-
return getNearestPointBetweenPointAndEllipse(point, centerPoint, rectangle.width / 2, rectangle.height / 2);
|
|
21
|
-
},
|
|
22
|
-
getTangentVectorByConnectionPoint(rectangle, pointOfRectangle) {
|
|
23
|
-
const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);
|
|
24
|
-
const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];
|
|
25
|
-
const point = [connectionPoint[0] - centerPoint[0], -(connectionPoint[1] - centerPoint[1])];
|
|
26
|
-
const a = rectangle.width / 2;
|
|
27
|
-
const b = rectangle.height / 2;
|
|
28
|
-
const slope = getEllipseTangentSlope(point[0], point[1], a, b);
|
|
29
|
-
const vector = getVectorFromPointAndSlope(point[0], point[1], slope);
|
|
30
|
-
return vector;
|
|
31
|
-
},
|
|
32
|
-
getConnectorPoints(rectangle) {
|
|
33
|
-
return RectangleClient.getEdgeCenterPoints(rectangle);
|
|
34
|
-
},
|
|
35
|
-
getTextRectangle(element) {
|
|
36
|
-
const rectangle = getTextRectangle(element);
|
|
37
|
-
const width = rectangle.width;
|
|
38
|
-
rectangle.width = (rectangle.width * 3) / 4;
|
|
39
|
-
rectangle.x += width / 8;
|
|
40
|
-
return rectangle;
|
|
41
|
-
}
|
|
42
|
-
};
|
|
43
|
-
if (createOptions?.draw) {
|
|
44
|
-
engine.draw = createOptions.draw;
|
|
45
|
-
}
|
|
46
|
-
if (createOptions?.getTextRectangle) {
|
|
47
|
-
engine.getTextRectangle = createOptions.getTextRectangle;
|
|
48
|
-
}
|
|
49
|
-
return engine;
|
|
50
|
-
}
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"circle.js","sourceRoot":"","sources":["../../../../../packages/draw/src/engines/basic-shapes/circle.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    Point,\n    PointOfRectangle,\n    RectangleClient,\n    getEllipseTangentSlope,\n    getVectorFromPointAndSlope,\n    isPointInEllipse\n} from '@plait/core';\nimport { PlaitGeometry, ShapeEngine } from '../../interfaces';\nimport { Options } from 'roughjs/bin/core';\nimport { getTextRectangle } from '../../utils';\nimport { getNearestPointBetweenPointAndEllipse } from './ellipse';\n\nexport interface CreateCircleOptions {\n    draw?: (board: PlaitBoard, rectangle: RectangleClient, options: Options) => SVGGElement;\n    getTextRectangle?: (element: PlaitGeometry) => RectangleClient;\n}\n\nexport function createEllipseEngine(createOptions?: CreateCircleOptions): ShapeEngine {\n    const engine: ShapeEngine = {\n        draw(board: PlaitBoard, rectangle: RectangleClient, options: Options) {\n            const centerPoint = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];\n            const rs = PlaitBoard.getRoughSVG(board);\n            return rs.ellipse(centerPoint[0], centerPoint[1], rectangle.width, rectangle.height, { ...options, fillStyle: 'solid' });\n        },\n        isInsidePoint(rectangle: RectangleClient, point: Point) {\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];\n            return isPointInEllipse(point, centerPoint, rectangle.width / 2, rectangle.height / 2);\n        },\n        getCornerPoints(rectangle: RectangleClient) {\n            return RectangleClient.getEdgeCenterPoints(rectangle);\n        },\n        getNearestPoint(rectangle: RectangleClient, point: Point) {\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];\n            return getNearestPointBetweenPointAndEllipse(point, centerPoint, rectangle.width / 2, rectangle.height / 2);\n        },\n        getTangentVectorByConnectionPoint(rectangle: RectangleClient, pointOfRectangle: PointOfRectangle) {\n            const connectionPoint = RectangleClient.getConnectionPoint(rectangle, pointOfRectangle);\n            const centerPoint: Point = [rectangle.x + rectangle.width / 2, rectangle.y + rectangle.height / 2];\n            const point = [connectionPoint[0] - centerPoint[0], -(connectionPoint[1] - centerPoint[1])];\n            const a = rectangle.width / 2;\n            const b = rectangle.height / 2;\n            const slope = getEllipseTangentSlope(point[0], point[1], a, b) as any;\n            const vector = getVectorFromPointAndSlope(point[0], point[1], slope);\n            return vector;\n        },\n        getConnectorPoints(rectangle: RectangleClient) {\n            return RectangleClient.getEdgeCenterPoints(rectangle);\n        },\n        getTextRectangle(element: PlaitGeometry) {\n            const rectangle = getTextRectangle(element);\n            const width = rectangle.width;\n            rectangle.width = (rectangle.width * 3) / 4;\n            rectangle.x += width / 8;\n            return rectangle;\n        }\n    };\n\n    if (createOptions?.draw) {\n        engine.draw = createOptions.draw;\n    }\n    if (createOptions?.getTextRectangle) {\n        engine.getTextRectangle = createOptions.getTextRectangle;\n    }\n\n    return engine;\n}\n"]}
|