@plait/draw 0.56.2 → 0.58.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/draw.d.ts +1 -0
- package/constants/geometry.d.ts +82 -2
- package/constants/index.d.ts +1 -0
- package/constants/pointer.d.ts +4 -2
- package/engines/flowchart/display.d.ts +4 -0
- package/engines/index.d.ts +3 -3
- package/engines/table/table.d.ts +16 -0
- package/engines/uml/actor.d.ts +2 -0
- package/engines/uml/combined-fragment.d.ts +3 -0
- package/engines/uml/container.d.ts +2 -0
- package/engines/uml/package.d.ts +3 -0
- package/esm2022/constants/draw.mjs +2 -0
- package/esm2022/constants/geometry.mjs +71 -5
- package/esm2022/constants/index.mjs +2 -1
- package/esm2022/constants/pointer.mjs +9 -3
- package/esm2022/engines/basic-shapes/cloud.mjs +1 -1
- package/esm2022/engines/basic-shapes/comment.mjs +1 -1
- package/esm2022/engines/basic-shapes/diamond.mjs +2 -2
- package/esm2022/engines/basic-shapes/parallelogram.mjs +2 -2
- package/esm2022/engines/basic-shapes/pentagon.mjs +1 -1
- package/esm2022/engines/basic-shapes/round-comment.mjs +2 -2
- package/esm2022/engines/basic-shapes/star.mjs +1 -1
- package/esm2022/engines/basic-shapes/trapezoid.mjs +2 -2
- package/esm2022/engines/basic-shapes/triangle.mjs +2 -2
- package/esm2022/engines/flowchart/database.mjs +2 -2
- package/esm2022/engines/flowchart/display.mjs +74 -0
- package/esm2022/engines/flowchart/document.mjs +1 -1
- package/esm2022/engines/flowchart/hard-disk.mjs +2 -2
- package/esm2022/engines/flowchart/internal-storage.mjs +2 -2
- package/esm2022/engines/flowchart/manual-input.mjs +2 -2
- package/esm2022/engines/flowchart/manual-loop.mjs +2 -2
- package/esm2022/engines/flowchart/merge.mjs +1 -1
- package/esm2022/engines/flowchart/multi-document.mjs +1 -1
- package/esm2022/engines/flowchart/note-curly-left.mjs +2 -2
- package/esm2022/engines/flowchart/note-curly-right.mjs +2 -2
- package/esm2022/engines/flowchart/note-square.mjs +1 -1
- package/esm2022/engines/flowchart/off-page.mjs +2 -2
- package/esm2022/engines/flowchart/or.mjs +1 -8
- package/esm2022/engines/flowchart/predefined-process.mjs +1 -1
- package/esm2022/engines/flowchart/summing-junction.mjs +1 -8
- package/esm2022/engines/index.mjs +20 -5
- package/esm2022/engines/table/table.mjs +72 -0
- package/esm2022/engines/uml/actor.mjs +102 -0
- package/esm2022/engines/uml/combined-fragment.mjs +66 -0
- package/esm2022/engines/uml/container.mjs +44 -0
- package/esm2022/engines/uml/package.mjs +75 -0
- package/esm2022/generators/geometry-shape.generator.mjs +3 -3
- package/esm2022/generators/index.mjs +7 -0
- package/esm2022/generators/line-active.generator.mjs +3 -3
- package/esm2022/generators/line-auto-complete.generator.mjs +1 -1
- package/esm2022/generators/single-text.generator.mjs +16 -0
- package/esm2022/generators/table.generator.mjs +20 -0
- package/esm2022/generators/text.generator.mjs +134 -0
- package/esm2022/geometry.component.mjs +64 -77
- package/esm2022/image.component.mjs +11 -28
- package/esm2022/interfaces/element.mjs +2 -1
- package/esm2022/interfaces/engine.mjs +2 -0
- package/esm2022/interfaces/geometry.mjs +24 -1
- package/esm2022/interfaces/image.mjs +1 -1
- package/esm2022/interfaces/index.mjs +27 -4
- package/esm2022/interfaces/line.mjs +1 -1
- package/esm2022/interfaces/table.mjs +9 -0
- package/esm2022/line.component.mjs +9 -26
- package/esm2022/plugins/with-draw-fragment.mjs +3 -1
- package/esm2022/plugins/with-draw-hotkey.mjs +12 -3
- package/esm2022/plugins/with-draw-resize.mjs +1 -1
- package/esm2022/plugins/with-draw.mjs +7 -2
- package/esm2022/plugins/with-geometry-create.mjs +2 -1
- package/esm2022/plugins/with-geometry-resize.mjs +1 -1
- package/esm2022/plugins/with-line-auto-complete-reaction.mjs +2 -2
- package/esm2022/plugins/with-line-bound-reaction.mjs +3 -4
- package/esm2022/plugins/with-line-create.mjs +3 -3
- package/esm2022/plugins/with-line-resize.mjs +3 -3
- package/esm2022/plugins/with-swimlane-create.mjs +132 -0
- package/esm2022/plugins/with-swimlane.mjs +21 -0
- package/esm2022/plugins/with-table-resize.mjs +130 -0
- package/esm2022/plugins/with-table.mjs +60 -0
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/table.component.mjs +136 -0
- package/esm2022/transforms/geometry-text.mjs +6 -3
- package/esm2022/transforms/geometry.mjs +3 -2
- package/esm2022/transforms/index.mjs +11 -2
- package/esm2022/transforms/multi-text-geometry-text.mjs +15 -0
- package/esm2022/transforms/swimlane.mjs +97 -0
- package/esm2022/transforms/table-text.mjs +44 -0
- package/esm2022/utils/clipboard.mjs +15 -2
- package/esm2022/utils/common.mjs +130 -0
- package/esm2022/utils/geometry.mjs +49 -63
- package/esm2022/utils/hit.mjs +47 -18
- package/esm2022/utils/index.mjs +4 -1
- package/esm2022/utils/line/elbow.mjs +2 -2
- package/esm2022/utils/line/line-arrow.mjs +2 -2
- package/esm2022/utils/line/line-basic.mjs +4 -4
- package/esm2022/utils/line/line-common.mjs +2 -2
- package/esm2022/utils/memorize.mjs +7 -1
- package/esm2022/utils/multi-text-geometry.mjs +61 -0
- package/esm2022/utils/position/geometry.mjs +2 -40
- package/esm2022/utils/selected.mjs +14 -1
- package/esm2022/utils/shape.mjs +5 -2
- package/esm2022/utils/snap-resizing.mjs +7 -7
- package/esm2022/utils/style/stroke.mjs +4 -10
- package/esm2022/utils/swimlane.mjs +120 -0
- package/esm2022/utils/table.mjs +124 -0
- package/fesm2022/plait-draw.mjs +4556 -2877
- package/fesm2022/plait-draw.mjs.map +1 -1
- package/generators/index.d.ts +6 -0
- package/generators/line-auto-complete.generator.d.ts +2 -2
- package/generators/single-text.generator.d.ts +11 -0
- package/generators/table.generator.d.ts +9 -0
- package/generators/text.generator.d.ts +43 -0
- package/geometry.component.d.ts +12 -17
- package/image.component.d.ts +6 -11
- package/interfaces/element.d.ts +2 -1
- package/interfaces/engine.d.ts +16 -0
- package/interfaces/geometry.d.ts +42 -18
- package/interfaces/image.d.ts +4 -2
- package/interfaces/index.d.ts +12 -3
- package/interfaces/line.d.ts +4 -5
- package/interfaces/table.d.ts +40 -0
- package/line.component.d.ts +5 -10
- package/package.json +1 -1
- package/plugins/with-swimlane-create.d.ts +8 -0
- package/plugins/with-swimlane.d.ts +2 -0
- package/plugins/with-table-resize.d.ts +2 -0
- package/plugins/with-table.d.ts +6 -0
- package/public-api.d.ts +1 -0
- package/table.component.d.ts +21 -0
- package/transforms/geometry.d.ts +2 -2
- package/transforms/index.d.ts +8 -2
- package/transforms/multi-text-geometry-text.d.ts +4 -0
- package/transforms/swimlane.d.ts +6 -0
- package/transforms/table-text.d.ts +4 -0
- package/utils/clipboard.d.ts +2 -0
- package/utils/common.d.ts +27 -0
- package/utils/geometry.d.ts +34 -15
- package/utils/hit.d.ts +4 -2
- package/utils/index.d.ts +3 -0
- package/utils/line/line-common.d.ts +3 -3
- package/utils/memorize.d.ts +3 -1
- package/utils/multi-text-geometry.d.ts +14 -0
- package/utils/position/geometry.d.ts +8 -21
- package/utils/selected.d.ts +4 -0
- package/utils/shape.d.ts +2 -2
- package/utils/style/stroke.d.ts +4 -5
- package/utils/swimlane.d.ts +52 -0
- package/utils/table.d.ts +26 -0
|
@@ -1,17 +1,13 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
1
|
import { PlaitBoard } from '@plait/core';
|
|
3
|
-
import {
|
|
4
|
-
import { CommonPluginElement, ImageGenerator } from '@plait/common';
|
|
2
|
+
import { CommonElementFlavour, ImageGenerator } from '@plait/common';
|
|
5
3
|
import { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';
|
|
6
|
-
|
|
7
|
-
export class ImageComponent extends CommonPluginElement {
|
|
8
|
-
constructor() {
|
|
9
|
-
super(...arguments);
|
|
10
|
-
this.destroy$ = new Subject();
|
|
11
|
-
}
|
|
4
|
+
export class ImageComponent extends CommonElementFlavour {
|
|
12
5
|
get activeGenerator() {
|
|
13
6
|
return this.imageGenerator.componentRef.instance.activeGenerator;
|
|
14
7
|
}
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
}
|
|
15
11
|
initializeGenerator() {
|
|
16
12
|
this.imageGenerator = new ImageGenerator(this.board, {
|
|
17
13
|
getRectangle: (element) => {
|
|
@@ -33,10 +29,10 @@ export class ImageComponent extends CommonPluginElement {
|
|
|
33
29
|
this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);
|
|
34
30
|
this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);
|
|
35
31
|
}
|
|
36
|
-
|
|
37
|
-
super.
|
|
32
|
+
initialize() {
|
|
33
|
+
super.initialize();
|
|
38
34
|
this.initializeGenerator();
|
|
39
|
-
this.imageGenerator.processDrawing(this.element, this.getElementG(), this.
|
|
35
|
+
this.imageGenerator.processDrawing(this.element, this.getElementG(), PlaitBoard.getViewContainerRef(this.board));
|
|
40
36
|
this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {
|
|
41
37
|
selected: this.selected
|
|
42
38
|
});
|
|
@@ -60,23 +56,10 @@ export class ImageComponent extends CommonPluginElement {
|
|
|
60
56
|
}
|
|
61
57
|
}
|
|
62
58
|
}
|
|
63
|
-
|
|
64
|
-
super.
|
|
65
|
-
this.destroy$.next();
|
|
66
|
-
this.destroy$.complete();
|
|
59
|
+
destroy() {
|
|
60
|
+
super.destroy();
|
|
67
61
|
this.imageGenerator.destroy();
|
|
68
62
|
this.lineAutoCompleteGenerator.destroy();
|
|
69
63
|
}
|
|
70
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: ImageComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: ImageComponent, isStandalone: true, selector: "plait-draw-geometry", usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
72
64
|
}
|
|
73
|
-
|
|
74
|
-
type: Component,
|
|
75
|
-
args: [{
|
|
76
|
-
selector: 'plait-draw-geometry',
|
|
77
|
-
template: ``,
|
|
78
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
79
|
-
standalone: true
|
|
80
|
-
}]
|
|
81
|
-
}] });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../packages/draw/src/image.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { PlaitBoard, PlaitPluginElementContext, OnContextChanged, isSelectionMoving, getSelectedElements } from '@plait/core';\nimport { Subject } from 'rxjs';\nimport { CommonPluginElement, ImageGenerator } from '@plait/common';\nimport { PlaitImage } from './interfaces/image';\nimport { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';\n\n@Component({\n    selector: 'plait-draw-geometry',\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true\n})\nexport class ImageComponent extends CommonPluginElement<PlaitImage, PlaitBoard>\n    implements OnInit, OnDestroy, OnContextChanged<PlaitImage, PlaitBoard> {\n    destroy$ = new Subject<void>();\n\n    get activeGenerator() {\n        return this.imageGenerator.componentRef.instance.activeGenerator;\n    }\n\n    imageGenerator!: ImageGenerator<PlaitImage>;\n\n    lineAutoCompleteGenerator!: LineAutoCompleteGenerator;\n\n    initializeGenerator() {\n        this.imageGenerator = new ImageGenerator<PlaitImage>(this.board, {\n            getRectangle: (element: PlaitImage) => {\n                return {\n                    x: element.points[0][0],\n                    y: element.points[0][1],\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            },\n            getImageItem: element => {\n                return {\n                    url: element.url,\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            }\n        });\n        this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);\n        this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.initializeGenerator();\n        this.imageGenerator.processDrawing(this.element, this.getElementG(), this.viewContainerRef);\n        this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitImage, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitImage, PlaitBoard>\n    ) {\n        if (value.element !== previous.element) {\n            this.imageGenerator.updateImage(this.getElementG(), previous.element, value.element);\n            this.imageGenerator.componentRef.instance.isFocus = this.selected;\n            this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState = this.activeGenerator.options.hasResizeHandle() === this.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.imageGenerator.componentRef.instance.isFocus = this.selected;\n                this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.imageGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n    }\n}\n"]}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../packages/draw/src/image.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitBoard, PlaitPluginElementContext, OnContextChanged } from '@plait/core';\nimport { Subject } from 'rxjs';\nimport { CommonElementFlavour, ImageGenerator } from '@plait/common';\nimport { PlaitImage } from './interfaces/image';\nimport { LineAutoCompleteGenerator } from './generators/line-auto-complete.generator';\n\nexport class ImageComponent extends CommonElementFlavour<PlaitImage, PlaitBoard> implements OnContextChanged<PlaitImage, PlaitBoard> {\n    get activeGenerator() {\n        return this.imageGenerator.componentRef.instance.activeGenerator;\n    }\n\n    imageGenerator!: ImageGenerator<PlaitImage>;\n\n    lineAutoCompleteGenerator!: LineAutoCompleteGenerator<PlaitImage>;\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.imageGenerator = new ImageGenerator<PlaitImage>(this.board, {\n            getRectangle: (element: PlaitImage) => {\n                return {\n                    x: element.points[0][0],\n                    y: element.points[0][1],\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            },\n            getImageItem: element => {\n                return {\n                    url: element.url,\n                    width: element.points[1][0] - element.points[0][0],\n                    height: element.points[1][1] - element.points[0][1]\n                };\n            }\n        });\n        this.lineAutoCompleteGenerator = new LineAutoCompleteGenerator(this.board);\n        this.getRef().addGenerator(LineAutoCompleteGenerator.key, this.lineAutoCompleteGenerator);\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\n        this.imageGenerator.processDrawing(this.element, this.getElementG(), PlaitBoard.getViewContainerRef(this.board));\n        this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected\n        });\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<PlaitImage, PlaitBoard>,\n        previous: PlaitPluginElementContext<PlaitImage, PlaitBoard>\n    ) {\n        if (value.element !== previous.element) {\n            this.imageGenerator.updateImage(this.getElementG(), previous.element, value.element);\n            this.imageGenerator.componentRef.instance.isFocus = this.selected;\n            this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected\n            });\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameHandleState = this.activeGenerator.options.hasResizeHandle() === this.activeGenerator.hasResizeHandle;\n            if (!hasSameSelected || !hasSameHandleState) {\n                this.imageGenerator.componentRef.instance.isFocus = this.selected;\n                this.lineAutoCompleteGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n        }\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.imageGenerator.destroy();\n        this.lineAutoCompleteGenerator.destroy();\n    }\n}\n"]}
|
|
@@ -10,5 +10,6 @@ export var MemorizeKey;
|
|
|
10
10
|
MemorizeKey["flowchart"] = "flowchart";
|
|
11
11
|
MemorizeKey["text"] = "text";
|
|
12
12
|
MemorizeKey["line"] = "line";
|
|
13
|
+
MemorizeKey["UML"] = "UML";
|
|
13
14
|
})(MemorizeKey || (MemorizeKey = {}));
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL2ludGVyZmFjZXMvZWxlbWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxXQUlYO0FBSkQsV0FBWSxXQUFXO0lBQ25CLDhCQUFlLENBQUE7SUFDZixnQ0FBaUIsQ0FBQTtJQUNqQixnQ0FBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsV0FBVyxLQUFYLFdBQVcsUUFJdEI7QUFFRCxNQUFNLENBQU4sSUFBWSxXQU1YO0FBTkQsV0FBWSxXQUFXO0lBQ25CLHdDQUF5QixDQUFBO0lBQ3pCLHNDQUF1QixDQUFBO0lBQ3ZCLDRCQUFhLENBQUE7SUFDYiw0QkFBYSxDQUFBO0lBQ2IsMEJBQVcsQ0FBQTtBQUNmLENBQUMsRUFOVyxXQUFXLEtBQVgsV0FBVyxRQU10QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFN0cm9rZVN0eWxlIHtcbiAgICBzb2xpZCA9ICdzb2xpZCcsXG4gICAgZGFzaGVkID0gJ2Rhc2hlZCcsXG4gICAgZG90dGVkID0gJ2RvdHRlZCdcbn1cblxuZXhwb3J0IGVudW0gTWVtb3JpemVLZXkge1xuICAgIGJhc2ljU2hhcGUgPSAnYmFzaWNTaGFwZScsXG4gICAgZmxvd2NoYXJ0ID0gJ2Zsb3djaGFydCcsXG4gICAgdGV4dCA9ICd0ZXh0JyxcbiAgICBsaW5lID0gJ2xpbmUnLFxuICAgIFVNTCA9ICdVTUwnXG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvaW50ZXJmYWNlcy9lbmdpbmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlY3RhbmdsZUNsaWVudCwgUG9pbnRPZlJlY3RhbmdsZSwgVmVjdG9yLCBQbGFpdEJvYXJkLCBQb2ludCwgUGxhaXRFbGVtZW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgT3B0aW9ucyB9IGZyb20gJ3JvdWdoanMvYmluL2NvcmUnO1xuaW1wb3J0IHsgUGxhaXRHZW9tZXRyeSB9IGZyb20gJy4vZ2VvbWV0cnknO1xuXG5leHBvcnQgaW50ZXJmYWNlIEVuZ2luZUV4dHJhRGF0YSB7fVxuXG5leHBvcnQgaW50ZXJmYWNlIFNoYXBlRW5naW5lPFxuICAgIFQgZXh0ZW5kcyBQbGFpdEVsZW1lbnQgPSBQbGFpdEdlb21ldHJ5LFxuICAgIFAgZXh0ZW5kcyBFbmdpbmVFeHRyYURhdGEgPSBFbmdpbmVFeHRyYURhdGEsXG4gICAgSyBleHRlbmRzIEVuZ2luZUV4dHJhRGF0YSA9IEVuZ2luZUV4dHJhRGF0YVxuPiB7XG4gICAgaXNJbnNpZGVQb2ludDogKHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludDogUG9pbnQpID0+IGJvb2xlYW47XG4gICAgZ2V0TmVhcmVzdFBvaW50OiAocmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQsIHBvaW50OiBQb2ludCkgPT4gUG9pbnQ7XG4gICAgZ2V0TmVhcmVzdENyb3NzaW5nUG9pbnQ/OiAocmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQsIHBvaW50OiBQb2ludCkgPT4gUG9pbnQ7XG4gICAgZ2V0Q29ubmVjdG9yUG9pbnRzOiAocmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQpID0+IFBvaW50W107XG4gICAgZ2V0Q29ybmVyUG9pbnRzOiAocmVjdGFuZ2xlOiBSZWN0YW5nbGVDbGllbnQpID0+IFBvaW50W107XG4gICAgZ2V0RWRnZUJ5Q29ubmVjdGlvblBvaW50PzogKHJlY3RhbmdsZTogUmVjdGFuZ2xlQ2xpZW50LCBwb2ludDogUG9pbnRPZlJlY3RhbmdsZSkgPT4gW1BvaW50LCBQb2ludF0gfCBudWxsO1xuICAgIGdldFRhbmdlbnRWZWN0b3JCeUNvbm5lY3Rpb25Qb2ludD86IChyZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCwgcG9pbnQ6IFBvaW50T2ZSZWN0YW5nbGUpID0+IFZlY3RvciB8IG51bGw7XG4gICAgZHJhdzogKGJvYXJkOiBQbGFpdEJvYXJkLCByZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCwgcm91Z2hPcHRpb25zOiBPcHRpb25zLCBvcHRpb25zPzogUCkgPT4gU1ZHR0VsZW1lbnQ7XG4gICAgZ2V0VGV4dFJlY3RhbmdsZT86IChlbGVtZW50OiBULCBvcHRpb25zPzogSykgPT4gUmVjdGFuZ2xlQ2xpZW50O1xufVxuIl19
|
|
@@ -47,6 +47,29 @@ export var FlowchartSymbols;
|
|
|
47
47
|
FlowchartSymbols["noteCurlyRight"] = "noteCurlyRight";
|
|
48
48
|
FlowchartSymbols["noteCurlyLeft"] = "noteCurlyLeft";
|
|
49
49
|
FlowchartSymbols["noteSquare"] = "noteSquare";
|
|
50
|
+
FlowchartSymbols["display"] = "display";
|
|
50
51
|
})(FlowchartSymbols || (FlowchartSymbols = {}));
|
|
52
|
+
export var TableSymbols;
|
|
53
|
+
(function (TableSymbols) {
|
|
54
|
+
TableSymbols["table"] = "table";
|
|
55
|
+
})(TableSymbols || (TableSymbols = {}));
|
|
56
|
+
export var SwimlaneSymbols;
|
|
57
|
+
(function (SwimlaneSymbols) {
|
|
58
|
+
SwimlaneSymbols["swimlaneVertical"] = "swimlaneVertical";
|
|
59
|
+
SwimlaneSymbols["swimlaneHorizontal"] = "swimlaneHorizontal";
|
|
60
|
+
})(SwimlaneSymbols || (SwimlaneSymbols = {}));
|
|
61
|
+
export var UMLSymbols;
|
|
62
|
+
(function (UMLSymbols) {
|
|
63
|
+
UMLSymbols["actor"] = "actor";
|
|
64
|
+
UMLSymbols["useCase"] = "useCase";
|
|
65
|
+
UMLSymbols["container"] = "container";
|
|
66
|
+
UMLSymbols["package"] = "package";
|
|
67
|
+
UMLSymbols["combinedFragment"] = "combinedFragment";
|
|
68
|
+
})(UMLSymbols || (UMLSymbols = {}));
|
|
69
|
+
export var MultipleTextGeometryCommonTextKeys;
|
|
70
|
+
(function (MultipleTextGeometryCommonTextKeys) {
|
|
71
|
+
MultipleTextGeometryCommonTextKeys["name"] = "name";
|
|
72
|
+
MultipleTextGeometryCommonTextKeys["content"] = "content";
|
|
73
|
+
})(MultipleTextGeometryCommonTextKeys || (MultipleTextGeometryCommonTextKeys = {}));
|
|
51
74
|
export const PlaitGeometry = {};
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvbWV0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9pbnRlcmZhY2VzL2dlb21ldHJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1BLE1BQU0sQ0FBTixJQUFZLFdBc0JYO0FBdEJELFdBQVksV0FBVztJQUNuQixzQ0FBdUIsQ0FBQTtJQUN2QixrQ0FBbUIsQ0FBQTtJQUNuQixrQ0FBbUIsQ0FBQTtJQUNuQixnREFBaUMsQ0FBQTtJQUNqQyw4Q0FBK0IsQ0FBQTtJQUMvQiw0QkFBYSxDQUFBO0lBQ2Isb0NBQXFCLENBQUE7SUFDckIsc0NBQXVCLENBQUE7SUFDdkIsc0NBQXVCLENBQUE7SUFDdkIsd0NBQXlCLENBQUE7SUFDekIsOEJBQWUsQ0FBQTtJQUNmLDRCQUFhLENBQUE7SUFDYixvQ0FBcUIsQ0FBQTtJQUNyQixrQ0FBbUIsQ0FBQTtJQUNuQixrQ0FBbUIsQ0FBQTtJQUNuQiw4Q0FBK0IsQ0FBQTtJQUMvQiw0Q0FBNkIsQ0FBQTtJQUM3QiwwQ0FBMkIsQ0FBQTtJQUMzQixrQ0FBbUIsQ0FBQTtJQUNuQiw0Q0FBNkIsQ0FBQTtJQUM3Qiw4QkFBZSxDQUFBO0FBQ25CLENBQUMsRUF0QlcsV0FBVyxLQUFYLFdBQVcsUUFzQnRCO0FBRUQsTUFBTSxDQUFOLElBQVksZ0JBeUJYO0FBekJELFdBQVksZ0JBQWdCO0lBQ3hCLHVDQUFtQixDQUFBO0lBQ25CLHlDQUFxQixDQUFBO0lBQ3JCLGlDQUFhLENBQUE7SUFDYiwyQ0FBdUIsQ0FBQTtJQUN2Qix5Q0FBcUIsQ0FBQTtJQUNyQiwrQ0FBMkIsQ0FBQTtJQUMzQiwrQ0FBMkIsQ0FBQTtJQUMzQiw2Q0FBeUIsQ0FBQTtJQUN6QixtQ0FBZSxDQUFBO0lBQ2YsbUNBQWUsQ0FBQTtJQUNmLDZDQUF5QixDQUFBO0lBQ3pCLDZCQUFTLENBQUE7SUFDVCx1REFBbUMsQ0FBQTtJQUNuQywyREFBdUMsQ0FBQTtJQUN2Qyx1Q0FBbUIsQ0FBQTtJQUNuQix5Q0FBcUIsQ0FBQTtJQUNyQixtREFBK0IsQ0FBQTtJQUMvQix5Q0FBcUIsQ0FBQTtJQUNyQix5Q0FBcUIsQ0FBQTtJQUNyQix1REFBbUMsQ0FBQTtJQUNuQyxxREFBaUMsQ0FBQTtJQUNqQyxtREFBK0IsQ0FBQTtJQUMvQiw2Q0FBeUIsQ0FBQTtJQUN6Qix1Q0FBbUIsQ0FBQTtBQUN2QixDQUFDLEVBekJXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUF5QjNCO0FBRUQsTUFBTSxDQUFOLElBQVksWUFFWDtBQUZELFdBQVksWUFBWTtJQUNwQiwrQkFBZSxDQUFBO0FBQ25CLENBQUMsRUFGVyxZQUFZLEtBQVosWUFBWSxRQUV2QjtBQUVELE1BQU0sQ0FBTixJQUFZLGVBR1g7QUFIRCxXQUFZLGVBQWU7SUFDdkIsd0RBQXFDLENBQUE7SUFDckMsNERBQXlDLENBQUE7QUFDN0MsQ0FBQyxFQUhXLGVBQWUsS0FBZixlQUFlLFFBRzFCO0FBRUQsTUFBTSxDQUFOLElBQVksVUFNWDtBQU5ELFdBQVksVUFBVTtJQUNsQiw2QkFBZSxDQUFBO0lBQ2YsaUNBQW1CLENBQUE7SUFDbkIscUNBQXVCLENBQUE7SUFDdkIsaUNBQW1CLENBQUE7SUFDbkIsbURBQXFDLENBQUE7QUFDekMsQ0FBQyxFQU5XLFVBQVUsS0FBVixVQUFVLFFBTXJCO0FBRUQsTUFBTSxDQUFOLElBQVksa0NBR1g7QUFIRCxXQUFZLGtDQUFrQztJQUMxQyxtREFBYSxDQUFBO0lBQ2IseURBQW1CLENBQUE7QUFDdkIsQ0FBQyxFQUhXLGtDQUFrQyxLQUFsQyxrQ0FBa0MsUUFHN0M7QUFzREQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0RWxlbWVudCwgUG9pbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBQYXJhZ3JhcGhFbGVtZW50IH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuaW1wb3J0IHsgU3Ryb2tlU3R5bGUgfSBmcm9tICcuL2VsZW1lbnQnO1xuaW1wb3J0IHsgUGxhaXRUYWJsZSB9IGZyb20gJy4vdGFibGUnO1xuaW1wb3J0IHsgUGxhaXREcmF3U2hhcGVUZXh0IH0gZnJvbSAnLi4vZ2VuZXJhdG9ycy90ZXh0LmdlbmVyYXRvcic7XG5cbmV4cG9ydCBlbnVtIEJhc2ljU2hhcGVzIHtcbiAgICByZWN0YW5nbGUgPSAncmVjdGFuZ2xlJyxcbiAgICBlbGxpcHNlID0gJ2VsbGlwc2UnLFxuICAgIGRpYW1vbmQgPSAnZGlhbW9uZCcsXG4gICAgcm91bmRSZWN0YW5nbGUgPSAncm91bmRSZWN0YW5nbGUnLFxuICAgIHBhcmFsbGVsb2dyYW0gPSAncGFyYWxsZWxvZ3JhbScsXG4gICAgdGV4dCA9ICd0ZXh0JyxcbiAgICB0cmlhbmdsZSA9ICd0cmlhbmdsZScsXG4gICAgbGVmdEFycm93ID0gJ2xlZnRBcnJvdycsXG4gICAgdHJhcGV6b2lkID0gJ3RyYXBlem9pZCcsXG4gICAgcmlnaHRBcnJvdyA9ICdyaWdodEFycm93JyxcbiAgICBjcm9zcyA9ICdjcm9zcycsXG4gICAgc3RhciA9ICdzdGFyJyxcbiAgICBwZW50YWdvbiA9ICdwZW50YWdvbicsXG4gICAgaGV4YWdvbiA9ICdoZXhhZ29uJyxcbiAgICBvY3RhZ29uID0gJ29jdGFnb24nLFxuICAgIHBlbnRhZ29uQXJyb3cgPSAncGVudGFnb25BcnJvdycsXG4gICAgcHJvY2Vzc0Fycm93ID0gJ3Byb2Nlc3NBcnJvdycsXG4gICAgdHdvV2F5QXJyb3cgPSAndHdvV2F5QXJyb3cnLFxuICAgIGNvbW1lbnQgPSAnY29tbWVudCcsXG4gICAgcm91bmRDb21tZW50ID0gJ3JvdW5kQ29tbWVudCcsXG4gICAgY2xvdWQgPSAnY2xvdWQnXG59XG5cbmV4cG9ydCBlbnVtIEZsb3djaGFydFN5bWJvbHMge1xuICAgIHByb2Nlc3MgPSAncHJvY2VzcycsXG4gICAgZGVjaXNpb24gPSAnZGVjaXNpb24nLFxuICAgIGRhdGEgPSAnZGF0YScsXG4gICAgY29ubmVjdG9yID0gJ2Nvbm5lY3RvcicsXG4gICAgdGVybWluYWwgPSAndGVybWluYWwnLFxuICAgIG1hbnVhbElucHV0ID0gJ21hbnVhbElucHV0JyxcbiAgICBwcmVwYXJhdGlvbiA9ICdwcmVwYXJhdGlvbicsXG4gICAgbWFudWFsTG9vcCA9ICdtYW51YWxMb29wJyxcbiAgICBtZXJnZSA9ICdtZXJnZScsXG4gICAgZGVsYXkgPSAnZGVsYXknLFxuICAgIHN0b3JlZERhdGEgPSAnc3RvcmVkRGF0YScsXG4gICAgb3IgPSAnb3InLFxuICAgIHN1bW1pbmdKdW5jdGlvbiA9ICdzdW1taW5nSnVuY3Rpb24nLFxuICAgIHByZWRlZmluZWRQcm9jZXNzID0gJ3ByZWRlZmluZWRQcm9jZXNzJyxcbiAgICBvZmZQYWdlID0gJ29mZlBhZ2UnLFxuICAgIGRvY3VtZW50ID0gJ2RvY3VtZW50JyxcbiAgICBtdWx0aURvY3VtZW50ID0gJ211bHRpRG9jdW1lbnQnLFxuICAgIGRhdGFiYXNlID0gJ2RhdGFiYXNlJyxcbiAgICBoYXJkRGlzayA9ICdoYXJkRGlzaycsXG4gICAgaW50ZXJuYWxTdG9yYWdlID0gJ2ludGVybmFsU3RvcmFnZScsXG4gICAgbm90ZUN1cmx5UmlnaHQgPSAnbm90ZUN1cmx5UmlnaHQnLFxuICAgIG5vdGVDdXJseUxlZnQgPSAnbm90ZUN1cmx5TGVmdCcsXG4gICAgbm90ZVNxdWFyZSA9ICdub3RlU3F1YXJlJyxcbiAgICBkaXNwbGF5ID0gJ2Rpc3BsYXknXG59XG5cbmV4cG9ydCBlbnVtIFRhYmxlU3ltYm9scyB7XG4gICAgdGFibGUgPSAndGFibGUnXG59XG5cbmV4cG9ydCBlbnVtIFN3aW1sYW5lU3ltYm9scyB7XG4gICAgc3dpbWxhbmVWZXJ0aWNhbCA9ICdzd2ltbGFuZVZlcnRpY2FsJyxcbiAgICBzd2ltbGFuZUhvcml6b250YWwgPSAnc3dpbWxhbmVIb3Jpem9udGFsJ1xufVxuXG5leHBvcnQgZW51bSBVTUxTeW1ib2xzIHtcbiAgICBhY3RvciA9ICdhY3RvcicsXG4gICAgdXNlQ2FzZSA9ICd1c2VDYXNlJyxcbiAgICBjb250YWluZXIgPSAnY29udGFpbmVyJyxcbiAgICBwYWNrYWdlID0gJ3BhY2thZ2UnLFxuICAgIGNvbWJpbmVkRnJhZ21lbnQgPSAnY29tYmluZWRGcmFnbWVudCdcbn1cblxuZXhwb3J0IGVudW0gTXVsdGlwbGVUZXh0R2VvbWV0cnlDb21tb25UZXh0S2V5cyB7XG4gICAgbmFtZSA9ICduYW1lJyxcbiAgICBjb250ZW50ID0gJ2NvbnRlbnQnXG59XG5cbmV4cG9ydCB0eXBlIEdlb21ldHJ5U2hhcGVzID0gQmFzaWNTaGFwZXMgfCBGbG93Y2hhcnRTeW1ib2xzIHwgU3dpbWxhbmVTeW1ib2xzIHwgVU1MU3ltYm9scztcblxuZXhwb3J0IHR5cGUgU3dpbWxhbmVEaXJlY3Rpb24gPSAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0Q29tbW9uR2VvbWV0cnkgZXh0ZW5kcyBQbGFpdEVsZW1lbnQge1xuICAgIHBvaW50czogW1BvaW50LCBQb2ludF07XG4gICAgdHlwZTogJ2dlb21ldHJ5JztcbiAgICBzaGFwZTogR2VvbWV0cnlTaGFwZXM7XG5cbiAgICAvLyBub2RlIHN0eWxlIGF0dHJpYnV0ZXNcbiAgICBmaWxsPzogc3RyaW5nO1xuICAgIHN0cm9rZUNvbG9yPzogc3RyaW5nO1xuICAgIHN0cm9rZVdpZHRoPzogbnVtYmVyO1xuICAgIHN0cm9rZVN0eWxlPzogU3Ryb2tlU3R5bGU7XG4gICAgXG4gICAgYW5nbGU6IG51bWJlcjtcbiAgICBvcGFjaXR5OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRNdWx0aXBsZVRleHRHZW9tZXRyeSBleHRlbmRzIFBsYWl0Q29tbW9uR2VvbWV0cnkge1xuICAgIHRleHRzOiBQbGFpdERyYXdTaGFwZVRleHRbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdEdlb21ldHJ5IGV4dGVuZHMgUGxhaXRDb21tb25HZW9tZXRyeSB7XG4gICAgdGV4dD86IFBhcmFncmFwaEVsZW1lbnQ7XG4gICAgdGV4dEhlaWdodD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdFJlY3RhbmdsZSBleHRlbmRzIFBsYWl0R2VvbWV0cnkge1xuICAgIHNoYXBlOiBCYXNpY1NoYXBlcy5yZWN0YW5nbGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRFbGxpcHNlIGV4dGVuZHMgUGxhaXRHZW9tZXRyeSB7XG4gICAgc2hhcGU6IEJhc2ljU2hhcGVzLmVsbGlwc2U7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXREaWFtb25kIGV4dGVuZHMgUGxhaXRHZW9tZXRyeSB7XG4gICAgc2hhcGU6IEJhc2ljU2hhcGVzLmRpYW1vbmQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRTd2ltbGFuZSBleHRlbmRzIFBsYWl0VGFibGUge1xuICAgIHNoYXBlOiBTd2ltbGFuZVN5bWJvbHM7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRTd2ltbGFuZVZlcnRpY2FsIGV4dGVuZHMgUGxhaXRTd2ltbGFuZSB7XG4gICAgc2hhcGU6IFN3aW1sYW5lU3ltYm9scy5zd2ltbGFuZVZlcnRpY2FsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0U3dpbWxhbmVIb3Jpem9udGFsIGV4dGVuZHMgUGxhaXRTd2ltbGFuZSB7XG4gICAgc2hhcGU6IFN3aW1sYW5lU3ltYm9scy5zd2ltbGFuZUhvcml6b250YWw7XG59XG5cbmV4cG9ydCBjb25zdCBQbGFpdEdlb21ldHJ5ID0ge307XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9pbnRlcmZhY2VzL2ltYWdlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdEVsZW1lbnQsIFBvaW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0Q29tbW9uSW1hZ2UgZXh0ZW5kcyBQbGFpdEVsZW1lbnQge1xuICAgIHBvaW50czogW1BvaW50LCBQb2ludF07XG4gICAgdHlwZTogJ2ltYWdlJztcbiAgICBhbmdsZTogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0SW1hZ2UgZXh0ZW5kcyBQbGFpdENvbW1vbkltYWdlIHtcbiAgICB1cmw6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
import { BasicShapes, FlowchartSymbols } from './geometry';
|
|
1
|
+
import { BasicShapes, FlowchartSymbols, SwimlaneSymbols, UMLSymbols } from './geometry';
|
|
2
|
+
import { PlaitTableElement } from './table';
|
|
2
3
|
export * from './line';
|
|
3
4
|
export * from './geometry';
|
|
4
5
|
export * from './text';
|
|
5
6
|
export * from './element';
|
|
7
|
+
export * from './engine';
|
|
6
8
|
export const PlaitDrawElement = {
|
|
7
9
|
isGeometry: (value) => {
|
|
8
10
|
return value.type === 'geometry';
|
|
@@ -16,8 +18,14 @@ export const PlaitDrawElement = {
|
|
|
16
18
|
isImage: (value) => {
|
|
17
19
|
return value.type === 'image';
|
|
18
20
|
},
|
|
21
|
+
isTable: (value) => {
|
|
22
|
+
return PlaitTableElement.isTable(value);
|
|
23
|
+
},
|
|
19
24
|
isDrawElement: (value) => {
|
|
20
|
-
if (PlaitDrawElement.isGeometry(value) ||
|
|
25
|
+
if (PlaitDrawElement.isGeometry(value) ||
|
|
26
|
+
PlaitDrawElement.isLine(value) ||
|
|
27
|
+
PlaitDrawElement.isImage(value) ||
|
|
28
|
+
PlaitTableElement.isTable(value)) {
|
|
21
29
|
return true;
|
|
22
30
|
}
|
|
23
31
|
else {
|
|
@@ -25,13 +33,28 @@ export const PlaitDrawElement = {
|
|
|
25
33
|
}
|
|
26
34
|
},
|
|
27
35
|
isShapeElement: (value) => {
|
|
28
|
-
return PlaitDrawElement.isImage(value) || PlaitDrawElement.isGeometry(value);
|
|
36
|
+
return PlaitDrawElement.isImage(value) || PlaitDrawElement.isGeometry(value) || PlaitDrawElement.isTable(value);
|
|
29
37
|
},
|
|
30
38
|
isBasicShape: (value) => {
|
|
31
39
|
return Object.keys(BasicShapes).includes(value.shape);
|
|
32
40
|
},
|
|
33
41
|
isFlowchart: (value) => {
|
|
34
42
|
return Object.keys(FlowchartSymbols).includes(value.shape);
|
|
43
|
+
},
|
|
44
|
+
isUML: (value) => {
|
|
45
|
+
return Object.keys(UMLSymbols).includes(value.shape);
|
|
46
|
+
},
|
|
47
|
+
isSwimlane: (value) => {
|
|
48
|
+
return Object.keys(SwimlaneSymbols).includes(value.shape);
|
|
49
|
+
},
|
|
50
|
+
isVerticalSwimlane: (value) => {
|
|
51
|
+
return Object.keys(SwimlaneSymbols).includes(value.shape) && value.shape === SwimlaneSymbols.swimlaneVertical;
|
|
52
|
+
},
|
|
53
|
+
isHorizontalSwimlane: (value) => {
|
|
54
|
+
return Object.keys(SwimlaneSymbols).includes(value.shape) && value.shape === SwimlaneSymbols.swimlaneHorizontal;
|
|
55
|
+
},
|
|
56
|
+
isUMLClassOrInterface: (value) => {
|
|
57
|
+
return false;
|
|
35
58
|
}
|
|
36
59
|
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQWlDLGVBQWUsRUFBZ0IsVUFBVSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBR3JJLE9BQU8sRUFBYyxpQkFBaUIsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUd4RCxjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFVBQVUsQ0FBQztBQVF6QixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRztJQUM1QixVQUFVLEVBQUUsQ0FBQyxLQUFVLEVBQTBCLEVBQUU7UUFDL0MsT0FBTyxLQUFLLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQztJQUNyQyxDQUFDO0lBQ0QsTUFBTSxFQUFFLENBQUMsS0FBVSxFQUFzQixFQUFFO1FBQ3ZDLE9BQU8sS0FBSyxDQUFDLElBQUksS0FBSyxNQUFNLENBQUM7SUFDakMsQ0FBQztJQUNELE1BQU0sRUFBRSxDQUFDLEtBQVUsRUFBc0IsRUFBRTtRQUN2QyxPQUFPLEtBQUssQ0FBQyxJQUFJLEtBQUssVUFBVSxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssV0FBVyxDQUFDLElBQUksQ0FBQztJQUN6RSxDQUFDO0lBQ0QsT0FBTyxFQUFFLENBQUMsS0FBVSxFQUF1QixFQUFFO1FBQ3pDLE9BQU8sS0FBSyxDQUFDLElBQUksS0FBSyxPQUFPLENBQUM7SUFDbEMsQ0FBQztJQUNELE9BQU8sRUFBRSxDQUFDLEtBQVUsRUFBdUIsRUFBRTtRQUN6QyxPQUFPLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBQ0QsYUFBYSxFQUFFLENBQUMsS0FBVSxFQUE2QixFQUFFO1FBQ3JELElBQ0ksZ0JBQWdCLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQztZQUNsQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO1lBQzlCLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUM7WUFDL0IsaUJBQWlCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUNsQyxDQUFDO1lBQ0MsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQzthQUFNLENBQUM7WUFDSixPQUFPLEtBQUssQ0FBQztRQUNqQixDQUFDO0lBQ0wsQ0FBQztJQUNELGNBQWMsRUFBRSxDQUFDLEtBQVUsRUFBOEIsRUFBRTtRQUN2RCxPQUFPLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3BILENBQUM7SUFDRCxZQUFZLEVBQUUsQ0FBQyxLQUFVLEVBQUUsRUFBRTtRQUN6QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBQ0QsV0FBVyxFQUFFLENBQUMsS0FBVSxFQUFFLEVBQUU7UUFDeEIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBQ0QsS0FBSyxFQUFFLENBQUMsS0FBVSxFQUFFLEVBQUU7UUFDbEIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUNELFVBQVUsRUFBRSxDQUFDLEtBQVUsRUFBRSxFQUFFO1FBQ3ZCLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFDRCxrQkFBa0IsRUFBRSxDQUFDLEtBQVUsRUFBRSxFQUFFO1FBQy9CLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssZUFBZSxDQUFDLGdCQUFnQixDQUFDO0lBQ2xILENBQUM7SUFDRCxvQkFBb0IsRUFBRSxDQUFDLEtBQVUsRUFBRSxFQUFFO1FBQ2pDLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssZUFBZSxDQUFDLGtCQUFrQixDQUFDO0lBQ3BILENBQUM7SUFDRCxxQkFBcUIsRUFBRSxDQUFDLEtBQVUsRUFBRSxFQUFFO1FBQ2xDLE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzaWNTaGFwZXMsIEZsb3djaGFydFN5bWJvbHMsIEdlb21ldHJ5U2hhcGVzLCBQbGFpdEdlb21ldHJ5LCBTd2ltbGFuZVN5bWJvbHMsIFRhYmxlU3ltYm9scywgVU1MU3ltYm9scyB9IGZyb20gJy4vZ2VvbWV0cnknO1xuaW1wb3J0IHsgUGxhaXRJbWFnZSB9IGZyb20gJy4vaW1hZ2UnO1xuaW1wb3J0IHsgUGxhaXRMaW5lIH0gZnJvbSAnLi9saW5lJztcbmltcG9ydCB7IFBsYWl0VGFibGUsIFBsYWl0VGFibGVFbGVtZW50IH0gZnJvbSAnLi90YWJsZSc7XG5pbXBvcnQgeyBQbGFpdFRleHQgfSBmcm9tICcuL3RleHQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9nZW9tZXRyeSc7XG5leHBvcnQgKiBmcm9tICcuL3RleHQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGVtZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZW5naW5lJztcblxuZXhwb3J0IHR5cGUgUGxhaXREcmF3RWxlbWVudCA9IFBsYWl0R2VvbWV0cnkgfCBQbGFpdExpbmUgfCBQbGFpdEltYWdlIHwgUGxhaXRUYWJsZTtcblxuZXhwb3J0IHR5cGUgUGxhaXRTaGFwZUVsZW1lbnQgPSBQbGFpdEdlb21ldHJ5IHwgUGxhaXRJbWFnZSB8IFBsYWl0VGFibGU7XG5cbmV4cG9ydCB0eXBlIERyYXdTaGFwZXMgPSBHZW9tZXRyeVNoYXBlcyB8IFRhYmxlU3ltYm9scztcblxuZXhwb3J0IGNvbnN0IFBsYWl0RHJhd0VsZW1lbnQgPSB7XG4gICAgaXNHZW9tZXRyeTogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdEdlb21ldHJ5ID0+IHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnR5cGUgPT09ICdnZW9tZXRyeSc7XG4gICAgfSxcbiAgICBpc0xpbmU6ICh2YWx1ZTogYW55KTogdmFsdWUgaXMgUGxhaXRMaW5lID0+IHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnR5cGUgPT09ICdsaW5lJztcbiAgICB9LFxuICAgIGlzVGV4dDogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdFRleHQgPT4ge1xuICAgICAgICByZXR1cm4gdmFsdWUudHlwZSA9PT0gJ2dlb21ldHJ5JyAmJiB2YWx1ZS5zaGFwZSA9PT0gQmFzaWNTaGFwZXMudGV4dDtcbiAgICB9LFxuICAgIGlzSW1hZ2U6ICh2YWx1ZTogYW55KTogdmFsdWUgaXMgUGxhaXRJbWFnZSA9PiB7XG4gICAgICAgIHJldHVybiB2YWx1ZS50eXBlID09PSAnaW1hZ2UnO1xuICAgIH0sXG4gICAgaXNUYWJsZTogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdFRhYmxlID0+IHtcbiAgICAgICAgcmV0dXJuIFBsYWl0VGFibGVFbGVtZW50LmlzVGFibGUodmFsdWUpO1xuICAgIH0sXG4gICAgaXNEcmF3RWxlbWVudDogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdERyYXdFbGVtZW50ID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICAgUGxhaXREcmF3RWxlbWVudC5pc0dlb21ldHJ5KHZhbHVlKSB8fFxuICAgICAgICAgICAgUGxhaXREcmF3RWxlbWVudC5pc0xpbmUodmFsdWUpIHx8XG4gICAgICAgICAgICBQbGFpdERyYXdFbGVtZW50LmlzSW1hZ2UodmFsdWUpIHx8XG4gICAgICAgICAgICBQbGFpdFRhYmxlRWxlbWVudC5pc1RhYmxlKHZhbHVlKVxuICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgfSxcbiAgICBpc1NoYXBlRWxlbWVudDogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdFNoYXBlRWxlbWVudCA9PiB7XG4gICAgICAgIHJldHVybiBQbGFpdERyYXdFbGVtZW50LmlzSW1hZ2UodmFsdWUpIHx8IFBsYWl0RHJhd0VsZW1lbnQuaXNHZW9tZXRyeSh2YWx1ZSkgfHwgUGxhaXREcmF3RWxlbWVudC5pc1RhYmxlKHZhbHVlKTtcbiAgICB9LFxuICAgIGlzQmFzaWNTaGFwZTogKHZhbHVlOiBhbnkpID0+IHtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKEJhc2ljU2hhcGVzKS5pbmNsdWRlcyh2YWx1ZS5zaGFwZSk7XG4gICAgfSxcbiAgICBpc0Zsb3djaGFydDogKHZhbHVlOiBhbnkpID0+IHtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKEZsb3djaGFydFN5bWJvbHMpLmluY2x1ZGVzKHZhbHVlLnNoYXBlKTtcbiAgICB9LFxuICAgIGlzVU1MOiAodmFsdWU6IGFueSkgPT4ge1xuICAgICAgICByZXR1cm4gT2JqZWN0LmtleXMoVU1MU3ltYm9scykuaW5jbHVkZXModmFsdWUuc2hhcGUpO1xuICAgIH0sXG4gICAgaXNTd2ltbGFuZTogKHZhbHVlOiBhbnkpID0+IHtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKFN3aW1sYW5lU3ltYm9scykuaW5jbHVkZXModmFsdWUuc2hhcGUpO1xuICAgIH0sXG4gICAgaXNWZXJ0aWNhbFN3aW1sYW5lOiAodmFsdWU6IGFueSkgPT4ge1xuICAgICAgICByZXR1cm4gT2JqZWN0LmtleXMoU3dpbWxhbmVTeW1ib2xzKS5pbmNsdWRlcyh2YWx1ZS5zaGFwZSkgJiYgdmFsdWUuc2hhcGUgPT09IFN3aW1sYW5lU3ltYm9scy5zd2ltbGFuZVZlcnRpY2FsO1xuICAgIH0sXG4gICAgaXNIb3Jpem9udGFsU3dpbWxhbmU6ICh2YWx1ZTogYW55KSA9PiB7XG4gICAgICAgIHJldHVybiBPYmplY3Qua2V5cyhTd2ltbGFuZVN5bWJvbHMpLmluY2x1ZGVzKHZhbHVlLnNoYXBlKSAmJiB2YWx1ZS5zaGFwZSA9PT0gU3dpbWxhbmVTeW1ib2xzLnN3aW1sYW5lSG9yaXpvbnRhbDtcbiAgICB9LFxuICAgIGlzVU1MQ2xhc3NPckludGVyZmFjZTogKHZhbHVlOiBhbnkpID0+IHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXX0=
|
|
@@ -67,4 +67,4 @@ export const PlaitLine = {
|
|
|
67
67
|
return [sourcePoint, ...restPoints, targetPoint];
|
|
68
68
|
}
|
|
69
69
|
};
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.js","sourceRoot":"","sources":["../../../../packages/draw/src/interfaces/line.ts"],"names":[],"mappings":"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","sourcesContent":["import { Direction, PlaitBoard, PlaitElement, Point, PointOfRectangle, Vector, getElementById, rotatePointsByElement } from '@plait/core';\nimport { Element } from 'slate';\nimport { PlaitGeometry } from './geometry';\nimport { StrokeStyle } from './element';\nimport { getConnectionPoint } from '../utils/line/line-common';\nimport { PlaitShapeElement } from '.';\n\nexport enum LineMarkerType {\n    arrow = 'arrow',\n    none = 'none',\n    openTriangle = 'open-triangle',\n    solidTriangle = 'solid-triangle',\n    sharpArrow = 'sharp-arrow',\n    oneSideUp = 'one-side-up',\n    oneSideDown = 'one-side-down',\n    hollowTriangle = 'hollow-triangle',\n    singleSlash = 'single-slash'\n}\n\nexport enum LineShape {\n    straight = 'straight',\n    curve = 'curve',\n    elbow = 'elbow'\n}\n\nexport enum LineHandleKey {\n    source = 'source',\n    target = 'target'\n}\n\nexport interface LineText {\n    text: Element;\n    // Percentage of positioning based on line length\n    position: number;\n    width: number;\n    height: number;\n}\n\nexport interface LineHandle {\n    // The id of the bounded element\n    boundId?: string;\n    connection?: PointOfRectangle;\n    marker: LineMarkerType;\n}\n\nexport interface LineHandleRef {\n    key: LineHandleKey;\n    direction: Direction;\n    point: PointOfRectangle;\n    vector: Vector;\n    boundElement?: PlaitShapeElement;\n}\n\nexport interface LineHandleRefPair {\n    source: LineHandleRef;\n    target: LineHandleRef;\n}\n\nexport interface PlaitLine extends PlaitElement {\n    type: 'line';\n    shape: LineShape;\n    points: Point[];\n\n    source: LineHandle;\n    target: LineHandle;\n\n    texts: LineText[];\n\n    // node style attributes\n    strokeColor?: string;\n    strokeWidth?: number;\n    strokeStyle?: StrokeStyle;\n\n    opacity: number;\n}\n\nexport interface PlaitStraightLine extends PlaitLine {\n    shape: LineShape.straight;\n}\n\nexport interface PlaitCurveLine extends PlaitLine {\n    shape: LineShape.curve;\n}\n\nexport interface PlaitElbowLine extends PlaitLine {\n    shape: LineShape.elbow;\n}\n\nexport const PlaitLine = {\n    isSourceMarkOrTargetMark(line: PlaitLine, markType: LineMarkerType, handleKey: LineHandleKey) {\n        if (handleKey === LineHandleKey.source) {\n            return line.source.marker === markType;\n        } else {\n            return line.target.marker === markType;\n        }\n    },\n    isSourceMark(line: PlaitLine, markType: LineMarkerType) {\n        return PlaitLine.isSourceMarkOrTargetMark(line, markType, LineHandleKey.source);\n    },\n    isTargetMark(line: PlaitLine, markType: LineMarkerType) {\n        return PlaitLine.isSourceMarkOrTargetMark(line, markType, LineHandleKey.target);\n    },\n    isBoundElementOfSource(line: PlaitLine, element: PlaitShapeElement) {\n        return line.source.boundId === element.id;\n    },\n    isBoundElementOfTarget(line: PlaitLine, element: PlaitShapeElement) {\n        return line.target.boundId === element.id;\n    },\n    getPoints(board: PlaitBoard, line: PlaitLine) {\n        let sourcePoint;\n        if (line.source.boundId) {\n            const sourceElement = getElementById<PlaitShapeElement>(board, line.source.boundId)!;\n            const sourceConnectionPoint = getConnectionPoint(sourceElement, line.source.connection!);\n            sourcePoint = rotatePointsByElement(sourceConnectionPoint, sourceElement) || sourceConnectionPoint;\n        } else {\n            sourcePoint = line.points[0];\n        }\n\n        let targetPoint;\n        if (line.target.boundId) {\n            const targetElement = getElementById<PlaitShapeElement>(board, line.target.boundId)!;\n            const targetConnectionPoint = getConnectionPoint(targetElement, line.target.connection!);\n            targetPoint = rotatePointsByElement(targetConnectionPoint, targetElement) || targetConnectionPoint;\n        } else {\n            targetPoint = line.points[line.points.length - 1];\n        }\n        const restPoints = line.points.length > 2 ? line.points.slice(1, line.points.length - 1) : [];\n        return [sourcePoint, ...restPoints, targetPoint];\n    }\n};\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export const PlaitTableElement = {
|
|
2
|
+
isTable: (value) => {
|
|
3
|
+
return value.type === 'table';
|
|
4
|
+
},
|
|
5
|
+
isVerticalText: (value) => {
|
|
6
|
+
return value.text?.direction === 'vertical';
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9kcmF3L3NyYy9pbnRlcmZhY2VzL3RhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBDQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRztJQUM3QixPQUFPLEVBQUUsQ0FBQyxLQUFVLEVBQXVCLEVBQUU7UUFDekMsT0FBTyxLQUFLLENBQUMsSUFBSSxLQUFLLE9BQU8sQ0FBQztJQUNsQyxDQUFDO0lBQ0QsY0FBYyxFQUFFLENBQUMsS0FBcUIsRUFBMkIsRUFBRTtRQUMvRCxPQUFPLEtBQUssQ0FBQyxJQUFJLEVBQUUsU0FBUyxLQUFLLFVBQVUsQ0FBQztJQUNoRCxDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0RWxlbWVudCwgUG9pbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBFbmdpbmVFeHRyYURhdGEgfSBmcm9tICcuL2VuZ2luZSc7XG5pbXBvcnQgeyBQYXJhZ3JhcGhFbGVtZW50IH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0VGFibGUgZXh0ZW5kcyBQbGFpdEVsZW1lbnQge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgcG9pbnRzOiBQb2ludFtdO1xuICAgIHR5cGU6ICd0YWJsZSc7XG4gICAgcm93czoge1xuICAgICAgICBpZDogc3RyaW5nO1xuICAgICAgICBoZWlnaHQ/OiBudW1iZXI7XG4gICAgfVtdO1xuICAgIGNvbHVtbnM6IHtcbiAgICAgICAgaWQ6IHN0cmluZztcbiAgICAgICAgd2lkdGg/OiBudW1iZXI7XG4gICAgfVtdO1xuICAgIGNlbGxzOiBQbGFpdFRhYmxlQ2VsbFtdO1xuICAgIGdyb3VwSWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRUYWJsZUNlbGwge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgcm93SWQ6IHN0cmluZztcbiAgICBjb2x1bW5JZDogc3RyaW5nO1xuICAgIGNvbHNwYW4/OiBudW1iZXI7XG4gICAgcm93c3Bhbj86IG51bWJlcjtcbiAgICB0ZXh0PzogUGxhaXRUYWJsZUNlbGxQYXJhZ3JhcGg7XG4gICAgdGV4dEhlaWdodD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdFRhYmxlRHJhd09wdGlvbnMgZXh0ZW5kcyBFbmdpbmVFeHRyYURhdGEge1xuICAgIGVsZW1lbnQ6IFBsYWl0VGFibGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRUYWJsZUNlbGxXaXRoUG9pbnRzIGV4dGVuZHMgUGxhaXRUYWJsZUNlbGwge1xuICAgIHBvaW50czogW1BvaW50LCBQb2ludF07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGxhaXRUYWJsZUNlbGxQYXJhZ3JhcGggZXh0ZW5kcyBQYXJhZ3JhcGhFbGVtZW50IHtcbiAgICBkaXJlY3Rpb24/OiAndmVydGljYWwnIHwgJ2hvcml6b250YWwnO1xufVxuXG5leHBvcnQgY29uc3QgUGxhaXRUYWJsZUVsZW1lbnQgPSB7XG4gICAgaXNUYWJsZTogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBQbGFpdFRhYmxlID0+IHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnR5cGUgPT09ICd0YWJsZSc7XG4gICAgfSxcbiAgICBpc1ZlcnRpY2FsVGV4dDogKHZhbHVlOiBQbGFpdFRhYmxlQ2VsbCk6IHZhbHVlIGlzIFBsYWl0VGFibGVDZWxsID0+IHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnRleHQ/LmRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJztcbiAgICB9XG59O1xuIl19
|
|
@@ -1,21 +1,17 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
1
|
import { PlaitBoard, getElementById, createDebugGenerator } from '@plait/core';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
2
|
import { TextManage } from '@plait/text';
|
|
5
3
|
import { LineShapeGenerator } from './generators/line.generator';
|
|
6
4
|
import { LineActiveGenerator } from './generators/line-active.generator';
|
|
7
5
|
import { DrawTransforms } from './transforms';
|
|
8
6
|
import { GeometryThreshold } from './constants';
|
|
9
|
-
import {
|
|
7
|
+
import { CommonElementFlavour } from '@plait/common';
|
|
10
8
|
import { getLinePoints, getLineTextRectangle } from './utils/line/line-basic';
|
|
11
9
|
import { memorizeLatestText } from './utils/memorize';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
10
|
const debugKey = 'debug:plait:line-turning';
|
|
14
11
|
const debugGenerator = createDebugGenerator(debugKey);
|
|
15
|
-
export class LineComponent extends
|
|
12
|
+
export class LineComponent extends CommonElementFlavour {
|
|
16
13
|
constructor() {
|
|
17
|
-
super(
|
|
18
|
-
this.destroy$ = new Subject();
|
|
14
|
+
super();
|
|
19
15
|
this.boundedElements = {};
|
|
20
16
|
}
|
|
21
17
|
initializeGenerator() {
|
|
@@ -23,7 +19,7 @@ export class LineComponent extends CommonPluginElement {
|
|
|
23
19
|
this.activeGenerator = new LineActiveGenerator(this.board);
|
|
24
20
|
this.initializeTextManagesByElement();
|
|
25
21
|
}
|
|
26
|
-
|
|
22
|
+
initialize() {
|
|
27
23
|
this.initializeGenerator();
|
|
28
24
|
this.shapeGenerator.processDrawing(this.element, this.getElementG());
|
|
29
25
|
const linePoints = getLinePoints(this.board, this.element);
|
|
@@ -31,7 +27,7 @@ export class LineComponent extends CommonPluginElement {
|
|
|
31
27
|
selected: this.selected,
|
|
32
28
|
linePoints
|
|
33
29
|
});
|
|
34
|
-
super.
|
|
30
|
+
super.initialize();
|
|
35
31
|
this.boundedElements = this.getBoundedElements();
|
|
36
32
|
this.drawText();
|
|
37
33
|
debugGenerator.isDebug() && debugGenerator.drawCircles(this.board, this.element.points.slice(1, -1), 4, true);
|
|
@@ -106,7 +102,7 @@ export class LineComponent extends CommonPluginElement {
|
|
|
106
102
|
}
|
|
107
103
|
}
|
|
108
104
|
createTextManage(text, index) {
|
|
109
|
-
return new TextManage(this.board, this.
|
|
105
|
+
return new TextManage(this.board, PlaitBoard.getViewContainerRef(this.board), {
|
|
110
106
|
getRectangle: () => {
|
|
111
107
|
return getLineTextRectangle(this.board, this.element, index);
|
|
112
108
|
},
|
|
@@ -151,23 +147,10 @@ export class LineComponent extends CommonPluginElement {
|
|
|
151
147
|
manage.updateRectangle();
|
|
152
148
|
});
|
|
153
149
|
}
|
|
154
|
-
|
|
155
|
-
super.
|
|
150
|
+
destroy() {
|
|
151
|
+
super.destroy();
|
|
156
152
|
this.activeGenerator.destroy();
|
|
157
|
-
this.destroy$.next();
|
|
158
|
-
this.destroy$.complete();
|
|
159
153
|
this.destroyTextManages();
|
|
160
154
|
}
|
|
161
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: LineComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
162
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: LineComponent, isStandalone: true, selector: "plait-draw-line", usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
163
155
|
}
|
|
164
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: LineComponent, decorators: [{
|
|
165
|
-
type: Component,
|
|
166
|
-
args: [{
|
|
167
|
-
selector: 'plait-draw-line',
|
|
168
|
-
template: ``,
|
|
169
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
170
|
-
standalone: true
|
|
171
|
-
}]
|
|
172
|
-
}] });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.component.js","sourceRoot":"","sources":["../../../packages/draw/src/line.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { PlaitBoard, PlaitPluginElementContext, OnContextChanged, getElementById, createDebugGenerator } from '@plait/core';\nimport { Subject } from 'rxjs';\nimport { LineText, PlaitGeometry, PlaitLine } from './interfaces';\nimport { TextManage, TextManageRef } from '@plait/text';\nimport { LineShapeGenerator } from './generators/line.generator';\nimport { LineActiveGenerator } from './generators/line-active.generator';\nimport { DrawTransforms } from './transforms';\nimport { GeometryThreshold } from './constants';\nimport { CommonPluginElement } from '@plait/common';\nimport { getLinePoints, getLineTextRectangle } from './utils/line/line-basic';\nimport { memorizeLatestText } from './utils/memorize';\n\ninterface BoundedElements {\n    source?: PlaitGeometry;\n    target?: PlaitGeometry;\n}\n\nconst debugKey = 'debug:plait:line-turning';\nconst debugGenerator = createDebugGenerator(debugKey);\n\n@Component({\n    selector: 'plait-draw-line',\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true\n})\nexport class LineComponent extends CommonPluginElement<PlaitLine, PlaitBoard>\n    implements OnInit, OnDestroy, OnContextChanged<PlaitLine, PlaitBoard> {\n    destroy$ = new Subject<void>();\n\n    shapeGenerator!: LineShapeGenerator;\n\n    activeGenerator!: LineActiveGenerator;\n\n    boundedElements: BoundedElements = {};\n\n    initializeGenerator() {\n        this.shapeGenerator = new LineShapeGenerator(this.board);\n        this.activeGenerator = new LineActiveGenerator(this.board);\n        this.initializeTextManagesByElement();\n    }\n\n    ngOnInit(): void {\n        this.initializeGenerator();\n        this.shapeGenerator.processDrawing(this.element, this.getElementG());\n        const linePoints = getLinePoints(this.board, this.element);\n        this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected,\n            linePoints\n        });\n        super.ngOnInit();\n        this.boundedElements = this.getBoundedElements();\n        this.drawText();\n\n        debugGenerator.isDebug() && debugGenerator.drawCircles(this.board, this.element.points.slice(1, -1), 4, true);\n    }\n\n    getBoundedElements() {\n        const boundedElements: BoundedElements = {};\n        if (this.element.source.boundId) {\n            const boundElement = getElementById<PlaitGeometry>(this.board, this.element.source.boundId);\n            if (boundElement) {\n                boundedElements.source = boundElement;\n            }\n        }\n        if (this.element.target.boundId) {\n            const boundElement = getElementById<PlaitGeometry>(this.board, this.element.target.boundId);\n            if (boundElement) {\n                boundedElements.target = boundElement;\n            }\n        }\n        return boundedElements;\n    }\n\n    onContextChanged(value: PlaitPluginElementContext<PlaitLine, PlaitBoard>, previous: PlaitPluginElementContext<PlaitLine, PlaitBoard>) {\n        this.initializeWeakMap();\n        const boundedElements = this.getBoundedElements();\n        const isBoundedElementsChanged =\n            boundedElements.source !== this.boundedElements.source || boundedElements.target !== this.boundedElements.target;\n        this.boundedElements = boundedElements;\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n        const linePoints = getLinePoints(this.board, this.element);\n        if (value.element !== previous.element || isChangeTheme) {\n            this.shapeGenerator.processDrawing(this.element, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected,\n                linePoints\n            });\n            this.updateText(previous.element.texts, value.element.texts);\n            this.updateTextRectangle();\n        } else {\n            const needUpdate = value.selected !== previous.selected || this.activeGenerator.needUpdate();\n            if (needUpdate) {\n                this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected,\n                    linePoints\n                });\n            }\n        }\n        if (isBoundedElementsChanged) {\n            this.shapeGenerator.processDrawing(this.element, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected,\n                linePoints\n            });\n            this.updateTextRectangle();\n            return;\n        }\n    }\n\n    initializeTextManagesByElement() {\n        if (this.element.texts?.length) {\n            const textManages: TextManage[] = [];\n            this.element.texts.forEach((text, index) => {\n                const manage = this.createTextManage(text, index);\n                textManages.push(manage);\n            });\n            this.initializeTextManages(textManages);\n        }\n    }\n\n    drawText() {\n        if (this.element.texts?.length) {\n            this.getTextManages().forEach((manage, index) => {\n                manage.draw(this.element.texts![index].text);\n                this.getElementG().append(manage.g);\n            });\n        }\n    }\n\n    createTextManage(text: LineText, index: number) {\n        return new TextManage(this.board, this.viewContainerRef, {\n            getRectangle: () => {\n                return getLineTextRectangle(this.board, this.element, index);\n            },\n            onValueChangeHandle: (textManageRef: TextManageRef) => {\n                const height = textManageRef.height / this.board.viewport.zoom;\n                const width = textManageRef.width / this.board.viewport.zoom;\n                const texts = [...this.element.texts];\n                texts.splice(index, 1, {\n                    text: textManageRef.newValue ? textManageRef.newValue : this.element.texts[index].text,\n                    position: this.element.texts[index].position,\n                    width,\n                    height\n                });\n                DrawTransforms.setLineTexts(this.board, this.element, texts);\n                textManageRef.operations && memorizeLatestText(this.element, textManageRef.operations);\n            },\n            getMaxWidth: () => GeometryThreshold.defaultTextMaxWidth\n        });\n    }\n\n    updateText(previousTexts: LineText[], currentTexts: LineText[]) {\n        if (previousTexts === currentTexts) return;\n        const previousTextsLength = previousTexts.length;\n        const currentTextsLength = currentTexts.length;\n        const textManages = this.getTextManages();\n        if (currentTextsLength === previousTextsLength) {\n            for (let i = 0; i < previousTextsLength; i++) {\n                if (previousTexts[i].text !== currentTexts[i].text) {\n                    textManages[i].updateText(currentTexts[i].text);\n                }\n            }\n        } else {\n            this.destroyTextManages();\n            this.initializeTextManagesByElement();\n            this.drawText();\n        }\n    }\n\n    updateTextRectangle() {\n        const textManages = this.getTextManages();\n        textManages.forEach(manage => {\n            manage.updateRectangle();\n        });\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.activeGenerator.destroy();\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.destroyTextManages();\n    }\n}\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.component.js","sourceRoot":"","sources":["../../../packages/draw/src/line.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { PlaitBoard, PlaitPluginElementContext, OnContextChanged, getElementById, createDebugGenerator } from '@plait/core';\nimport { Subject } from 'rxjs';\nimport { LineText, PlaitGeometry, PlaitLine } from './interfaces';\nimport { TextManage, TextManageRef } from '@plait/text';\nimport { LineShapeGenerator } from './generators/line.generator';\nimport { LineActiveGenerator } from './generators/line-active.generator';\nimport { DrawTransforms } from './transforms';\nimport { GeometryThreshold } from './constants';\nimport { CommonElementFlavour } from '@plait/common';\nimport { getLinePoints, getLineTextRectangle } from './utils/line/line-basic';\nimport { memorizeLatestText } from './utils/memorize';\n\ninterface BoundedElements {\n    source?: PlaitGeometry;\n    target?: PlaitGeometry;\n}\n\nconst debugKey = 'debug:plait:line-turning';\nconst debugGenerator = createDebugGenerator(debugKey);\n\nexport class LineComponent extends CommonElementFlavour<PlaitLine, PlaitBoard> implements OnContextChanged<PlaitLine, PlaitBoard> {\n    shapeGenerator!: LineShapeGenerator;\n\n    activeGenerator!: LineActiveGenerator;\n\n    boundedElements: BoundedElements = {};\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.shapeGenerator = new LineShapeGenerator(this.board);\n        this.activeGenerator = new LineActiveGenerator(this.board);\n        this.initializeTextManagesByElement();\n    }\n\n    initialize(): void {\n        this.initializeGenerator();\n        this.shapeGenerator.processDrawing(this.element, this.getElementG());\n        const linePoints = getLinePoints(this.board, this.element);\n        this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n            selected: this.selected,\n            linePoints\n        });\n        super.initialize();\n        this.boundedElements = this.getBoundedElements();\n        this.drawText();\n\n        debugGenerator.isDebug() && debugGenerator.drawCircles(this.board, this.element.points.slice(1, -1), 4, true);\n    }\n\n    getBoundedElements() {\n        const boundedElements: BoundedElements = {};\n        if (this.element.source.boundId) {\n            const boundElement = getElementById<PlaitGeometry>(this.board, this.element.source.boundId);\n            if (boundElement) {\n                boundedElements.source = boundElement;\n            }\n        }\n        if (this.element.target.boundId) {\n            const boundElement = getElementById<PlaitGeometry>(this.board, this.element.target.boundId);\n            if (boundElement) {\n                boundedElements.target = boundElement;\n            }\n        }\n        return boundedElements;\n    }\n\n    onContextChanged(value: PlaitPluginElementContext<PlaitLine, PlaitBoard>, previous: PlaitPluginElementContext<PlaitLine, PlaitBoard>) {\n        this.initializeWeakMap();\n        const boundedElements = this.getBoundedElements();\n        const isBoundedElementsChanged =\n            boundedElements.source !== this.boundedElements.source || boundedElements.target !== this.boundedElements.target;\n        this.boundedElements = boundedElements;\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n        const linePoints = getLinePoints(this.board, this.element);\n        if (value.element !== previous.element || isChangeTheme) {\n            this.shapeGenerator.processDrawing(this.element, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected,\n                linePoints\n            });\n            this.updateText(previous.element.texts, value.element.texts);\n            this.updateTextRectangle();\n        } else {\n            const needUpdate = value.selected !== previous.selected || this.activeGenerator.needUpdate();\n            if (needUpdate) {\n                this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                    selected: this.selected,\n                    linePoints\n                });\n            }\n        }\n        if (isBoundedElementsChanged) {\n            this.shapeGenerator.processDrawing(this.element, this.getElementG());\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getElementActiveHost(this.board), {\n                selected: this.selected,\n                linePoints\n            });\n            this.updateTextRectangle();\n            return;\n        }\n    }\n\n    initializeTextManagesByElement() {\n        if (this.element.texts?.length) {\n            const textManages: TextManage[] = [];\n            this.element.texts.forEach((text, index) => {\n                const manage = this.createTextManage(text, index);\n                textManages.push(manage);\n            });\n            this.initializeTextManages(textManages);\n        }\n    }\n\n    drawText() {\n        if (this.element.texts?.length) {\n            this.getTextManages().forEach((manage, index) => {\n                manage.draw(this.element.texts![index].text);\n                this.getElementG().append(manage.g);\n            });\n        }\n    }\n\n    createTextManage(text: LineText, index: number) {\n        return new TextManage(this.board, PlaitBoard.getViewContainerRef(this.board), {\n            getRectangle: () => {\n                return getLineTextRectangle(this.board, this.element, index);\n            },\n            onValueChangeHandle: (textManageRef: TextManageRef) => {\n                const height = textManageRef.height / this.board.viewport.zoom;\n                const width = textManageRef.width / this.board.viewport.zoom;\n                const texts = [...this.element.texts];\n                texts.splice(index, 1, {\n                    text: textManageRef.newValue ? textManageRef.newValue : this.element.texts[index].text,\n                    position: this.element.texts[index].position,\n                    width,\n                    height\n                });\n                DrawTransforms.setLineTexts(this.board, this.element, texts);\n                textManageRef.operations && memorizeLatestText(this.element, textManageRef.operations);\n            },\n            getMaxWidth: () => GeometryThreshold.defaultTextMaxWidth\n        });\n    }\n\n    updateText(previousTexts: LineText[], currentTexts: LineText[]) {\n        if (previousTexts === currentTexts) return;\n        const previousTextsLength = previousTexts.length;\n        const currentTextsLength = currentTexts.length;\n        const textManages = this.getTextManages();\n        if (currentTextsLength === previousTextsLength) {\n            for (let i = 0; i < previousTextsLength; i++) {\n                if (previousTexts[i].text !== currentTexts[i].text) {\n                    textManages[i].updateText(currentTexts[i].text);\n                }\n            }\n        } else {\n            this.destroyTextManages();\n            this.initializeTextManagesByElement();\n            this.drawText();\n        }\n    }\n\n    updateTextRectangle() {\n        const textManages = this.getTextManages();\n        textManages.forEach(manage => {\n            manage.updateRectangle();\n        });\n    }\n\n    destroy(): void {\n        super.destroy();\n        this.activeGenerator.destroy();\n        this.destroyTextManages();\n    }\n}\n"]}
|
|
@@ -15,6 +15,7 @@ export const withDrawFragment = (baseBoard) => {
|
|
|
15
15
|
const geometryElements = drawElements.filter(value => PlaitDrawElement.isGeometry(value));
|
|
16
16
|
const lineElements = drawElements.filter(value => PlaitDrawElement.isLine(value));
|
|
17
17
|
const imageElements = drawElements.filter(value => PlaitDrawElement.isImage(value));
|
|
18
|
+
const tableElements = drawElements.filter(value => PlaitDrawElement.isTable(value));
|
|
18
19
|
const boundLineElements = [
|
|
19
20
|
...getBoundedLineElements(board, geometryElements),
|
|
20
21
|
...getBoundedLineElements(board, imageElements)
|
|
@@ -23,6 +24,7 @@ export const withDrawFragment = (baseBoard) => {
|
|
|
23
24
|
...geometryElements,
|
|
24
25
|
...lineElements,
|
|
25
26
|
...imageElements,
|
|
27
|
+
...tableElements,
|
|
26
28
|
...boundLineElements.filter(line => !lineElements.includes(line))
|
|
27
29
|
]);
|
|
28
30
|
}
|
|
@@ -91,4 +93,4 @@ export const getBoundedLineElements = (board, plaitShapes) => {
|
|
|
91
93
|
const lines = getLines(board);
|
|
92
94
|
return lines.filter(line => plaitShapes.find(shape => PlaitLine.isBoundElementOfSource(line, shape) || PlaitLine.isBoundElementOfTarget(line, shape)));
|
|
93
95
|
};
|
|
94
|
-
//# 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 {\n    ClipboardData,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    RectangleClient,\n    WritableClipboardContext,\n    WritableClipboardOperationType,\n    WritableClipboardType,\n    addClipboardContext,\n    createClipboardContext,\n    getSelectedElements\n} from '@plait/core';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { PlaitDrawElement, PlaitGeometry, PlaitLine, PlaitShapeElement } from '../interfaces';\nimport { buildClipboardData, insertClipboardData } from '../utils/clipboard';\nimport { DrawTransforms } from '../transforms';\nimport { getLines } from '../utils/line/line-basic';\nimport { PlaitImage } from '../interfaces/image';\nimport { acceptImageTypes, buildImage, getElementOfFocusedImage, getElementsText } from '@plait/common';\nimport { DEFAULT_IMAGE_WIDTH } from '../constants';\n\nexport const withDrawFragment = (baseBoard: PlaitBoard) => {\n    const board = baseBoard as PlaitBoard;\n    const { getDeletedFragment, buildFragment, 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.buildFragment = (\n        clipboardContext: WritableClipboardContext | null,\n        rectangle: RectangleClient | null,\n        operationType: WritableClipboardOperationType,\n        originData?: PlaitElement[]\n    ) => {\n        const targetDrawElements = getSelectedDrawElements(board, originData);\n        let boundLineElements: PlaitLine[] = [];\n        if (targetDrawElements.length) {\n            if (operationType === WritableClipboardOperationType.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 selectedElements = [...targetDrawElements, ...boundLineElements];\n            const elements = buildClipboardData(board, selectedElements, rectangle ? [rectangle.x, rectangle.y] : [0, 0]);\n            const text = getElementsText(selectedElements);\n            if (!clipboardContext) {\n                clipboardContext = createClipboardContext(WritableClipboardType.elements, elements, text);\n            } else {\n                clipboardContext = addClipboardContext(clipboardContext, {\n                    text,\n                    type: WritableClipboardType.elements,\n                    elements\n                });\n            }\n        }\n        return buildFragment(clipboardContext, rectangle, operationType, originData);\n    };\n\n    board.insertFragment = (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {\n        const selectedElements = getSelectedElements(board);\n        if (clipboardData?.files?.length) {\n            const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);\n            const canInsertionImage =\n                !getElementOfFocusedImage(board) && !(selectedElements.length === 1 && board.isImageBindingAllowed(selectedElements[0]));\n            if (acceptImageArray.includes(clipboardData.files[0].type) && canInsertionImage) {\n                const imageFile = clipboardData.files[0];\n                buildImage(board, imageFile, DEFAULT_IMAGE_WIDTH, imageItem => {\n                    DrawTransforms.insertImage(board, imageItem, targetPoint);\n                });\n                return;\n            }\n        }\n\n        if (clipboardData?.elements?.length) {\n            const drawElements = clipboardData.elements?.filter(value => PlaitDrawElement.isDrawElement(value)) as PlaitDrawElement[];\n            if (clipboardData.elements && clipboardData.elements.length > 0 && drawElements.length > 0) {\n                insertClipboardData(board, drawElements, targetPoint);\n            }\n        }\n\n        if (clipboardData?.text) {\n            if (!clipboardData.elements || clipboardData.elements.length === 0) {\n                // (*￣︶￣)\n                const insertAsChildren = selectedElements.length === 1 && selectedElements[0].children;\n                const insertAsFreeText = !insertAsChildren;\n                if (insertAsFreeText) {\n                    DrawTransforms.insertText(board, targetPoint, clipboardData.text);\n                    return;\n                }\n            }\n        }\n\n        insertFragment(clipboardData, targetPoint, operationType);\n    };\n\n    return board;\n};\n\nexport const getBoundedLineElements = (board: PlaitBoard, plaitShapes: PlaitShapeElement[]) => {\n    const lines = getLines(board);\n    return lines.filter(line =>\n        plaitShapes.find(shape => PlaitLine.isBoundElementOfSource(line, shape) || PlaitLine.isBoundElementOfTarget(line, shape))\n    );\n};\n"]}
|
|
96
|
+
//# 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 {\n    ClipboardData,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    RectangleClient,\n    WritableClipboardContext,\n    WritableClipboardOperationType,\n    WritableClipboardType,\n    addClipboardContext,\n    createClipboardContext,\n    getSelectedElements\n} from '@plait/core';\nimport { getSelectedDrawElements } from '../utils/selected';\nimport { PlaitDrawElement, PlaitGeometry, PlaitLine, PlaitShapeElement } from '../interfaces';\nimport { buildClipboardData, insertClipboardData } from '../utils/clipboard';\nimport { DrawTransforms } from '../transforms';\nimport { getLines } from '../utils/line/line-basic';\nimport { PlaitImage } from '../interfaces/image';\nimport { acceptImageTypes, buildImage, getElementOfFocusedImage, getElementsText } from '@plait/common';\nimport { DEFAULT_IMAGE_WIDTH } from '../constants';\nimport { PlaitTable } from '../interfaces/table';\n\nexport const withDrawFragment = (baseBoard: PlaitBoard) => {\n    const board = baseBoard as PlaitBoard;\n    const { getDeletedFragment, buildFragment, 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            const tableElements = drawElements.filter(value => PlaitDrawElement.isTable(value)) as PlaitTable[];\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                    ...tableElements,\n                    ...boundLineElements.filter(line => !lineElements.includes(line))\n                ]\n            );\n        }\n        return getDeletedFragment(data);\n    };\n\n    board.buildFragment = (\n        clipboardContext: WritableClipboardContext | null,\n        rectangle: RectangleClient | null,\n        operationType: WritableClipboardOperationType,\n        originData?: PlaitElement[]\n    ) => {\n        const targetDrawElements = getSelectedDrawElements(board, originData);\n        let boundLineElements: PlaitLine[] = [];\n        if (targetDrawElements.length) {\n            if (operationType === WritableClipboardOperationType.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 selectedElements = [...targetDrawElements, ...boundLineElements];\n            const elements = buildClipboardData(board, selectedElements, rectangle ? [rectangle.x, rectangle.y] : [0, 0]);\n            const text = getElementsText(selectedElements);\n            if (!clipboardContext) {\n                clipboardContext = createClipboardContext(WritableClipboardType.elements, elements, text);\n            } else {\n                clipboardContext = addClipboardContext(clipboardContext, {\n                    text,\n                    type: WritableClipboardType.elements,\n                    elements\n                });\n            }\n        }\n        return buildFragment(clipboardContext, rectangle, operationType, originData);\n    };\n\n    board.insertFragment = (clipboardData: ClipboardData | null, targetPoint: Point, operationType?: WritableClipboardOperationType) => {\n        const selectedElements = getSelectedElements(board);\n        if (clipboardData?.files?.length) {\n            const acceptImageArray = acceptImageTypes.map(type => 'image/' + type);\n            const canInsertionImage =\n                !getElementOfFocusedImage(board) && !(selectedElements.length === 1 && board.isImageBindingAllowed(selectedElements[0]));\n            if (acceptImageArray.includes(clipboardData.files[0].type) && canInsertionImage) {\n                const imageFile = clipboardData.files[0];\n                buildImage(board, imageFile, DEFAULT_IMAGE_WIDTH, imageItem => {\n                    DrawTransforms.insertImage(board, imageItem, targetPoint);\n                });\n                return;\n            }\n        }\n\n        if (clipboardData?.elements?.length) {\n            const drawElements = clipboardData.elements?.filter(value => PlaitDrawElement.isDrawElement(value)) as PlaitDrawElement[];\n            if (clipboardData.elements && clipboardData.elements.length > 0 && drawElements.length > 0) {\n                insertClipboardData(board, drawElements, targetPoint);\n            }\n        }\n\n        if (clipboardData?.text) {\n            if (!clipboardData.elements || clipboardData.elements.length === 0) {\n                // (*￣︶￣)\n                const insertAsChildren = selectedElements.length === 1 && selectedElements[0].children;\n                const insertAsFreeText = !insertAsChildren;\n                if (insertAsFreeText) {\n                    DrawTransforms.insertText(board, targetPoint, clipboardData.text);\n                    return;\n                }\n            }\n        }\n\n        insertFragment(clipboardData, targetPoint, operationType);\n    };\n\n    return board;\n};\n\nexport const getBoundedLineElements = (board: PlaitBoard, plaitShapes: PlaitShapeElement[]) => {\n    const lines = getLines(board);\n    return lines.filter(line =>\n        plaitShapes.find(shape => PlaitLine.isBoundElementOfSource(line, shape) || PlaitLine.isBoundElementOfTarget(line, shape))\n    );\n};\n"]}
|