@plait/draw 0.1.0-next.3
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/README.md +3 -0
- package/constants/geometry.d.ts +27 -0
- package/constants/index.d.ts +2 -0
- package/constants/line.d.ts +4 -0
- package/constants/pointer.d.ts +10 -0
- package/esm2022/constants/geometry.mjs +28 -0
- package/esm2022/constants/index.mjs +3 -0
- package/esm2022/constants/line.mjs +5 -0
- package/esm2022/constants/pointer.mjs +19 -0
- package/esm2022/generator/geometry-shape.generator.mjs +22 -0
- package/esm2022/generator/line-active.generator.mjs +36 -0
- package/esm2022/generator/line.generator.mjs +43 -0
- package/esm2022/geometry.component.mjs +118 -0
- package/esm2022/interfaces/geometry.mjs +20 -0
- package/esm2022/interfaces/index.mjs +24 -0
- package/esm2022/interfaces/line.mjs +12 -0
- package/esm2022/interfaces/text.mjs +2 -0
- package/esm2022/line.component.mjs +152 -0
- package/esm2022/plait-draw.mjs +5 -0
- package/esm2022/plugins/with-draw-fragment.mjs +51 -0
- package/esm2022/plugins/with-draw-hotkey.mjs +19 -0
- package/esm2022/plugins/with-draw.mjs +76 -0
- package/esm2022/plugins/with-geometry-create.mjs +164 -0
- package/esm2022/plugins/with-geometry-resize.mjs +71 -0
- package/esm2022/plugins/with-line-bound-reaction.mjs +45 -0
- package/esm2022/plugins/with-line-create.mjs +66 -0
- package/esm2022/plugins/with-line-resize.mjs +52 -0
- package/esm2022/plugins/with-line-text.mjs +55 -0
- package/esm2022/public-api.mjs +5 -0
- package/esm2022/transforms/geometry-text.mjs +54 -0
- package/esm2022/transforms/geometry.mjs +31 -0
- package/esm2022/transforms/index.mjs +14 -0
- package/esm2022/transforms/line.mjs +16 -0
- package/esm2022/utils/clipboard.mjs +23 -0
- package/esm2022/utils/create-mode.mjs +13 -0
- package/esm2022/utils/engine/diamond.mjs +20 -0
- package/esm2022/utils/engine/ellipse.mjs +55 -0
- package/esm2022/utils/engine/index.mjs +18 -0
- package/esm2022/utils/engine/parallelogram.mjs +30 -0
- package/esm2022/utils/engine/rectangle.mjs +18 -0
- package/esm2022/utils/engine/round-rectangle.mjs +49 -0
- package/esm2022/utils/geometry-style/stroke.mjs +17 -0
- package/esm2022/utils/geometry.mjs +84 -0
- package/esm2022/utils/index.mjs +5 -0
- package/esm2022/utils/line.mjs +145 -0
- package/esm2022/utils/position/geometry.mjs +28 -0
- package/esm2022/utils/position/line.mjs +34 -0
- package/esm2022/utils/selected.mjs +15 -0
- package/fesm2022/plait-draw.mjs +1602 -0
- package/fesm2022/plait-draw.mjs.map +1 -0
- package/generator/geometry-shape.generator.d.ts +8 -0
- package/generator/line-active.generator.d.ts +9 -0
- package/generator/line.generator.d.ts +8 -0
- package/geometry.component.d.ts +27 -0
- package/index.d.ts +5 -0
- package/interfaces/geometry.d.ts +43 -0
- package/interfaces/index.d.ts +13 -0
- package/interfaces/line.d.ts +44 -0
- package/interfaces/text.d.ts +5 -0
- package/line.component.d.ts +36 -0
- package/package.json +25 -0
- package/plugins/with-draw-fragment.d.ts +2 -0
- package/plugins/with-draw-hotkey.d.ts +2 -0
- package/plugins/with-draw.d.ts +2 -0
- package/plugins/with-geometry-create.d.ts +3 -0
- package/plugins/with-geometry-resize.d.ts +2 -0
- package/plugins/with-line-bound-reaction.d.ts +2 -0
- package/plugins/with-line-create.d.ts +2 -0
- package/plugins/with-line-resize.d.ts +2 -0
- package/plugins/with-line-text.d.ts +2 -0
- package/public-api.d.ts +4 -0
- package/styles/styles.scss +16 -0
- package/transforms/geometry-text.d.ts +5 -0
- package/transforms/geometry.d.ts +6 -0
- package/transforms/index.d.ts +10 -0
- package/transforms/line.d.ts +5 -0
- package/utils/clipboard.d.ts +4 -0
- package/utils/create-mode.d.ts +7 -0
- package/utils/engine/diamond.d.ts +2 -0
- package/utils/engine/ellipse.d.ts +4 -0
- package/utils/engine/index.d.ts +3 -0
- package/utils/engine/parallelogram.d.ts +4 -0
- package/utils/engine/rectangle.d.ts +2 -0
- package/utils/engine/round-rectangle.d.ts +5 -0
- package/utils/geometry-style/stroke.d.ts +5 -0
- package/utils/geometry.d.ts +16 -0
- package/utils/index.d.ts +4 -0
- package/utils/line.d.ts +16 -0
- package/utils/position/geometry.d.ts +13 -0
- package/utils/position/line.d.ts +10 -0
- package/utils/selected.d.ts +5 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { PlaitBoard, PlaitPluginElementComponent, getElementById } from '@plait/core';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
import { TextManage } from '@plait/text';
|
|
5
|
+
import { LineShapeGenerator } from './generator/line.generator';
|
|
6
|
+
import { LineActiveGenerator } from './generator/line-active.generator';
|
|
7
|
+
import { getLineTextRectangle } from './utils';
|
|
8
|
+
import { DrawTransforms } from './transforms';
|
|
9
|
+
import { GeometryThreshold } from './constants';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class LineComponent extends PlaitPluginElementComponent {
|
|
12
|
+
constructor(viewContainerRef, cdr) {
|
|
13
|
+
super(cdr);
|
|
14
|
+
this.viewContainerRef = viewContainerRef;
|
|
15
|
+
this.cdr = cdr;
|
|
16
|
+
this.destroy$ = new Subject();
|
|
17
|
+
this.textManages = [];
|
|
18
|
+
this.boundedElements = {};
|
|
19
|
+
}
|
|
20
|
+
initializeGenerator() {
|
|
21
|
+
this.shapeGenerator = new LineShapeGenerator(this.board);
|
|
22
|
+
this.activeGenerator = new LineActiveGenerator(this.board);
|
|
23
|
+
this.initializeTextManages();
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
this.initializeGenerator();
|
|
27
|
+
this.shapeGenerator.draw(this.element, this.g);
|
|
28
|
+
this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });
|
|
29
|
+
super.ngOnInit();
|
|
30
|
+
this.boundedElements = this.getBoundedElements();
|
|
31
|
+
this.drawText();
|
|
32
|
+
}
|
|
33
|
+
getBoundedElements() {
|
|
34
|
+
const boundedElements = {};
|
|
35
|
+
if (this.element.source.boundId) {
|
|
36
|
+
const boundElement = getElementById(this.board, this.element.source.boundId);
|
|
37
|
+
if (boundElement) {
|
|
38
|
+
boundedElements.source = boundElement;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (this.element.target.boundId) {
|
|
42
|
+
const boundElement = getElementById(this.board, this.element.target.boundId);
|
|
43
|
+
if (boundElement) {
|
|
44
|
+
boundedElements.target = boundElement;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return boundedElements;
|
|
48
|
+
}
|
|
49
|
+
onContextChanged(value, previous) {
|
|
50
|
+
const boundedElements = this.getBoundedElements();
|
|
51
|
+
const isBoundedElementsChanged = boundedElements.source !== this.boundedElements.source || boundedElements.target !== this.boundedElements.target;
|
|
52
|
+
this.boundedElements = boundedElements;
|
|
53
|
+
if (value.element !== previous.element) {
|
|
54
|
+
this.shapeGenerator.draw(this.element, this.g);
|
|
55
|
+
this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });
|
|
56
|
+
this.updateText(previous.element.texts, value.element.texts);
|
|
57
|
+
this.updateTextRectangle();
|
|
58
|
+
}
|
|
59
|
+
if (isBoundedElementsChanged) {
|
|
60
|
+
this.shapeGenerator.draw(this.element, this.g);
|
|
61
|
+
this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });
|
|
62
|
+
this.updateTextRectangle();
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
const hasSameSelected = value.selected === previous.selected;
|
|
66
|
+
if (!hasSameSelected) {
|
|
67
|
+
this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
initializeTextManages() {
|
|
71
|
+
if (this.element.texts?.length) {
|
|
72
|
+
this.element.texts.forEach((text, index) => {
|
|
73
|
+
const manage = this.createTextManage(text, index);
|
|
74
|
+
this.textManages.push(manage);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
destroyTextManages() {
|
|
79
|
+
this.textManages.forEach(manage => {
|
|
80
|
+
manage.destroy();
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
drawText() {
|
|
84
|
+
if (this.element.texts?.length) {
|
|
85
|
+
this.textManages.forEach((manage, index) => {
|
|
86
|
+
manage.draw(this.element.texts[index].text);
|
|
87
|
+
this.g.append(manage.g);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
createTextManage(text, index) {
|
|
92
|
+
return new TextManage(this.board, this.viewContainerRef, {
|
|
93
|
+
getRectangle: () => {
|
|
94
|
+
return getLineTextRectangle(this.board, this.element, index);
|
|
95
|
+
},
|
|
96
|
+
onValueChangeHandle: (textManageRef) => {
|
|
97
|
+
const height = textManageRef.height / this.board.viewport.zoom;
|
|
98
|
+
const width = textManageRef.width / this.board.viewport.zoom;
|
|
99
|
+
const texts = [...this.element.texts];
|
|
100
|
+
texts.splice(index, 1, {
|
|
101
|
+
text: textManageRef.newValue ? textManageRef.newValue : this.element.texts[index].text,
|
|
102
|
+
position: this.element.texts[index].position,
|
|
103
|
+
width,
|
|
104
|
+
height
|
|
105
|
+
});
|
|
106
|
+
DrawTransforms.setLineTexts(this.board, this.element, texts);
|
|
107
|
+
},
|
|
108
|
+
getMaxWidth: () => GeometryThreshold.defaultTextMaxWidth
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
updateText(previousTexts, currentTexts) {
|
|
112
|
+
if (previousTexts === currentTexts)
|
|
113
|
+
return;
|
|
114
|
+
const previousTextsLength = previousTexts.length;
|
|
115
|
+
const currentTextsLength = currentTexts.length;
|
|
116
|
+
if (currentTextsLength === previousTextsLength) {
|
|
117
|
+
for (let i = 0; i < previousTextsLength; i++) {
|
|
118
|
+
if (previousTexts[i].text !== currentTexts[i].text) {
|
|
119
|
+
this.textManages[i].updateText(currentTexts[i].text);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
this.destroyTextManages();
|
|
125
|
+
this.textManages = [];
|
|
126
|
+
this.initializeTextManages();
|
|
127
|
+
this.drawText();
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
updateTextRectangle() {
|
|
131
|
+
this.textManages.forEach(manage => {
|
|
132
|
+
manage.updateRectangle();
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
ngOnDestroy() {
|
|
136
|
+
super.ngOnDestroy();
|
|
137
|
+
this.activeGenerator.destroy();
|
|
138
|
+
this.destroy$.next();
|
|
139
|
+
this.destroy$.complete();
|
|
140
|
+
}
|
|
141
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: LineComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
142
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: LineComponent, selector: "plait-draw-line", usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
143
|
+
}
|
|
144
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: LineComponent, decorators: [{
|
|
145
|
+
type: Component,
|
|
146
|
+
args: [{
|
|
147
|
+
selector: 'plait-draw-line',
|
|
148
|
+
template: ``,
|
|
149
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
150
|
+
}]
|
|
151
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.component.js","sourceRoot":"","sources":["../../../packages/draw/src/line.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAuC,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAE,UAAU,EAAE,2BAA2B,EAA+C,cAAc,EAAE,MAAM,aAAa,CAAC;AACnI,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,OAAO,EAAE,UAAU,EAA4B,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;;AAYhD,MAAM,OAAO,aAAc,SAAQ,2BAAkD;IAYjF,YAAoB,gBAAkC,EAAY,GAAsB;QACpF,KAAK,CAAC,GAAG,CAAC,CAAC;QADK,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAY,QAAG,GAAH,GAAG,CAAmB;QAVxF,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAM/B,gBAAW,GAAiB,EAAE,CAAC;QAE/B,oBAAe,GAAoB,EAAE,CAAC;IAItC,CAAC;IAED,mBAAmB;QACf,IAAI,CAAC,cAAc,GAAG,IAAI,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,eAAe,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3D,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAClH,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACjD,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED,kBAAkB;QACd,MAAM,eAAe,GAAoB,EAAE,CAAC;QAC5C,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE;YAC7B,MAAM,YAAY,GAAG,cAAc,CAAgB,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC5F,IAAI,YAAY,EAAE;gBACd,eAAe,CAAC,MAAM,GAAG,YAAY,CAAC;aACzC;SACJ;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE;YAC7B,MAAM,YAAY,GAAG,cAAc,CAAgB,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAC5F,IAAI,YAAY,EAAE;gBACd,eAAe,CAAC,MAAM,GAAG,YAAY,CAAC;aACzC;SACJ;QACD,OAAO,eAAe,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,KAAuD,EAAE,QAA0D;QAChI,MAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClD,MAAM,wBAAwB,GAC1B,eAAe,CAAC,MAAM,KAAK,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,eAAe,CAAC,MAAM,KAAK,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC;QACrH,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QAEvC,IAAI,KAAK,CAAC,OAAO,KAAK,QAAQ,CAAC,OAAO,EAAE;YACpC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;YAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAClH,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAC7D,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;QAED,IAAI,wBAAwB,EAAE;YAC1B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;YAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAClH,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,OAAO;SACV;QAED,MAAM,eAAe,GAAG,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,QAAQ,CAAC;QAC7D,IAAI,CAAC,eAAe,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;SACrH;IACL,CAAC;IAED,qBAAqB;QACjB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE;YAC5B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACvC,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAClD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAC9B,MAAM,CAAC,OAAO,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE;YAC5B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACvC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC;gBAC7C,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAC5B,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,gBAAgB,CAAC,IAAc,EAAE,KAAa;QAC1C,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,gBAAgB,EAAE;YACrD,YAAY,EAAE,GAAG,EAAE;gBACf,OAAO,oBAAoB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACjE,CAAC;YACD,mBAAmB,EAAE,CAAC,aAA4B,EAAE,EAAE;gBAClD,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;gBAC/D,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;gBAC7D,MAAM,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBACtC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE;oBACnB,IAAI,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI;oBACtF,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ;oBAC5C,KAAK;oBACL,MAAM;iBACT,CAAC,CAAC;gBACH,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACjE,CAAC;YACD,WAAW,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,mBAAmB;SAC3D,CAAC,CAAC;IACP,CAAC;IAED,UAAU,CAAC,aAAyB,EAAE,YAAwB;QAC1D,IAAI,aAAa,KAAK,YAAY;YAAE,OAAO;QAC3C,MAAM,mBAAmB,GAAG,aAAa,CAAC,MAAM,CAAC;QACjD,MAAM,kBAAkB,GAAG,YAAY,CAAC,MAAM,CAAC;QAC/C,IAAI,kBAAkB,KAAK,mBAAmB,EAAE;YAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,mBAAmB,EAAE,CAAC,EAAE,EAAE;gBAC1C,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;oBAChD,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;iBACxD;aACJ;SACJ;aAAM;YACH,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACtB,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;IACL,CAAC;IAED,mBAAmB;QACf,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAC9B,MAAM,CAAC,eAAe,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;8GApJQ,aAAa;kGAAb,aAAa,8EAHZ,EAAE;;2FAGH,aAAa;kBALzB,SAAS;mBAAC;oBACP,QAAQ,EAAE,iBAAiB;oBAC3B,QAAQ,EAAE,EAAE;oBACZ,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { PlaitBoard, PlaitPluginElementComponent, PlaitPluginElementContext, OnContextChanged, getElementById } from '@plait/core';\nimport { Subject } from 'rxjs';\nimport { LineText, PlaitGeometry, PlaitLine } from './interfaces';\nimport { TextManage, TextManageRef, buildText } from '@plait/text';\nimport { LineShapeGenerator } from './generator/line.generator';\nimport { LineActiveGenerator } from './generator/line-active.generator';\nimport { getLineTextRectangle } from './utils';\nimport { DrawTransforms } from './transforms';\nimport { GeometryThreshold } from './constants';\n\ninterface BoundedElements {\n    source?: PlaitGeometry;\n    target?: PlaitGeometry;\n}\n\n@Component({\n    selector: 'plait-draw-line',\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LineComponent extends PlaitPluginElementComponent<PlaitLine, PlaitBoard>\n    implements OnInit, OnDestroy, OnContextChanged<PlaitLine, PlaitBoard> {\n    destroy$ = new Subject<void>();\n\n    shapeGenerator!: LineShapeGenerator;\n\n    activeGenerator!: LineActiveGenerator;\n\n    textManages: TextManage[] = [];\n\n    boundedElements: BoundedElements = {};\n\n    constructor(private viewContainerRef: ViewContainerRef, protected cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    initializeGenerator() {\n        this.shapeGenerator = new LineShapeGenerator(this.board);\n        this.activeGenerator = new LineActiveGenerator(this.board);\n        this.initializeTextManages();\n    }\n\n    ngOnInit(): void {\n        this.initializeGenerator();\n        this.shapeGenerator.draw(this.element, this.g);\n        this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n        super.ngOnInit();\n        this.boundedElements = this.getBoundedElements();\n        this.drawText();\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        const boundedElements = this.getBoundedElements();\n        const isBoundedElementsChanged =\n            boundedElements.source !== this.boundedElements.source || boundedElements.target !== this.boundedElements.target;\n        this.boundedElements = boundedElements;\n\n        if (value.element !== previous.element) {\n            this.shapeGenerator.draw(this.element, this.g);\n            this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n            this.updateText(previous.element.texts, value.element.texts);\n            this.updateTextRectangle();\n        }\n\n        if (isBoundedElementsChanged) {\n            this.shapeGenerator.draw(this.element, this.g);\n            this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n            this.updateTextRectangle();\n            return;\n        }\n\n        const hasSameSelected = value.selected === previous.selected;\n        if (!hasSameSelected) {\n            this.activeGenerator.draw(this.element, PlaitBoard.getElementActiveHost(this.board), { selected: this.selected });\n        }\n    }\n\n    initializeTextManages() {\n        if (this.element.texts?.length) {\n            this.element.texts.forEach((text, index) => {\n                const manage = this.createTextManage(text, index);\n                this.textManages.push(manage);\n            });\n        }\n    }\n\n    destroyTextManages() {\n        this.textManages.forEach(manage => {\n            manage.destroy();\n        });\n    }\n\n    drawText() {\n        if (this.element.texts?.length) {\n            this.textManages.forEach((manage, index) => {\n                manage.draw(this.element.texts![index].text);\n                this.g.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            },\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        if (currentTextsLength === previousTextsLength) {\n            for (let i = 0; i < previousTextsLength; i++) {\n                if (previousTexts[i].text !== currentTexts[i].text) {\n                    this.textManages[i].updateText(currentTexts[i].text);\n                }\n            }\n        } else {\n            this.destroyTextManages();\n            this.textManages = [];\n            this.initializeTextManages();\n            this.drawText();\n        }\n    }\n\n    updateTextRectangle() {\n        this.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    }\n}\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhaXQtZHJhdy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3BsYWl0LWRyYXcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { getDataFromClipboard, getSelectedElements, setClipboardData } from '@plait/core';
|
|
2
|
+
import { getSelectedDrawElements } from '../utils/selected';
|
|
3
|
+
import { PlaitDrawElement } from '../interfaces';
|
|
4
|
+
import { CommonTransforms } from '@plait/common';
|
|
5
|
+
import { getTextFromClipboard, getTextSize } from '@plait/text';
|
|
6
|
+
import { buildClipboardData, insertClipboardData } from '../utils/clipboard';
|
|
7
|
+
import { DrawTransforms } from '../transforms';
|
|
8
|
+
export const withDrawFragment = (baseBoard) => {
|
|
9
|
+
const board = baseBoard;
|
|
10
|
+
const { deleteFragment, setFragment, insertFragment } = board;
|
|
11
|
+
board.deleteFragment = (data) => {
|
|
12
|
+
const drawElements = getSelectedDrawElements(board);
|
|
13
|
+
if (drawElements.length) {
|
|
14
|
+
const geometryElements = drawElements.filter(value => PlaitDrawElement.isDrawElement(value));
|
|
15
|
+
// query bound lines
|
|
16
|
+
const boundLineElements = [];
|
|
17
|
+
CommonTransforms.removeElements(board, [...geometryElements, ...boundLineElements]);
|
|
18
|
+
}
|
|
19
|
+
deleteFragment(data);
|
|
20
|
+
};
|
|
21
|
+
board.setFragment = (data, rectangle) => {
|
|
22
|
+
const targetDrawElements = getSelectedDrawElements(board);
|
|
23
|
+
if (targetDrawElements.length) {
|
|
24
|
+
const elements = buildClipboardData(board, targetDrawElements, rectangle ? [rectangle.x, rectangle.y] : [0, 0]);
|
|
25
|
+
setClipboardData(data, elements);
|
|
26
|
+
}
|
|
27
|
+
setFragment(data, rectangle);
|
|
28
|
+
};
|
|
29
|
+
board.insertFragment = (data, targetPoint) => {
|
|
30
|
+
const elements = getDataFromClipboard(data);
|
|
31
|
+
const drawElements = elements.filter(value => PlaitDrawElement.isDrawElement(value));
|
|
32
|
+
if (elements.length > 0 && drawElements.length > 0) {
|
|
33
|
+
insertClipboardData(board, drawElements, targetPoint);
|
|
34
|
+
}
|
|
35
|
+
else if (elements.length === 0) {
|
|
36
|
+
const text = getTextFromClipboard(data);
|
|
37
|
+
const selectedElements = getSelectedElements(board);
|
|
38
|
+
// (* ̄︶ ̄)
|
|
39
|
+
const insertAsChildren = selectedElements.length === 1 && selectedElements[0].children;
|
|
40
|
+
const insertAsFreeText = !insertAsChildren;
|
|
41
|
+
if (text && insertAsFreeText) {
|
|
42
|
+
const { width, height } = getTextSize(board, text);
|
|
43
|
+
DrawTransforms.insertText(board, [targetPoint, [targetPoint[0] + width, targetPoint[1] + height]], text);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
insertFragment(data, targetPoint);
|
|
48
|
+
};
|
|
49
|
+
return board;
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1kcmF3LWZyYWdtZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZHJhdy9zcmMvcGx1Z2lucy93aXRoLWRyYXctZnJhZ21lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFzQyxvQkFBb0IsRUFBRSxtQkFBbUIsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM5SCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzdFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxTQUFxQixFQUFFLEVBQUU7SUFDdEQsTUFBTSxLQUFLLEdBQUcsU0FBdUIsQ0FBQztJQUN0QyxNQUFNLEVBQUUsY0FBYyxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFFOUQsS0FBSyxDQUFDLGNBQWMsR0FBRyxDQUFDLElBQXlCLEVBQUUsRUFBRTtRQUNqRCxNQUFNLFlBQVksR0FBRyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwRCxJQUFJLFlBQVksQ0FBQyxNQUFNLEVBQUU7WUFDckIsTUFBTSxnQkFBZ0IsR0FBRyxZQUFZLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFvQixDQUFDO1lBRWhILG9CQUFvQjtZQUNwQixNQUFNLGlCQUFpQixHQUFnQixFQUFFLENBQUM7WUFFMUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDLEdBQUcsZ0JBQWdCLEVBQUUsR0FBRyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7U0FDdkY7UUFDRCxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDekIsQ0FBQyxDQUFDO0lBRUYsS0FBSyxDQUFDLFdBQVcsR0FBRyxDQUFDLElBQXlCLEVBQUUsU0FBaUMsRUFBRSxFQUFFO1FBQ2pGLE1BQU0sa0JBQWtCLEdBQUcsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUQsSUFBSSxrQkFBa0IsQ0FBQyxNQUFNLEVBQUU7WUFDM0IsTUFBTSxRQUFRLEdBQUcsa0JBQWtCLENBQUMsS0FBSyxFQUFFLGtCQUFrQixFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNoSCxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7U0FDcEM7UUFDRCxXQUFXLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ2pDLENBQUMsQ0FBQztJQUVGLEtBQUssQ0FBQyxjQUFjLEdBQUcsQ0FBQyxJQUF5QixFQUFFLFdBQWtCLEVBQUUsRUFBRTtRQUNyRSxNQUFNLFFBQVEsR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM1QyxNQUFNLFlBQVksR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUF1QixDQUFDO1FBQzNHLElBQUksUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksWUFBWSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDaEQsbUJBQW1CLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRSxXQUFXLENBQUMsQ0FBQztTQUN6RDthQUFNLElBQUksUUFBUSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDOUIsTUFBTSxJQUFJLEdBQUcsb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDeEMsTUFBTSxnQkFBZ0IsR0FBRyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNwRCxTQUFTO1lBQ1QsTUFBTSxnQkFBZ0IsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztZQUN2RixNQUFNLGdCQUFnQixHQUFHLENBQUMsZ0JBQWdCLENBQUM7WUFDM0MsSUFBSSxJQUFJLElBQUksZ0JBQWdCLEVBQUU7Z0JBQzFCLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEdBQUcsV0FBVyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztnQkFDbkQsY0FBYyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUN6RyxPQUFPO2FBQ1Y7U0FDSjtRQUNELGNBQWMsQ0FBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDdEMsQ0FBQyxDQUFDO0lBRUYsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUG9pbnQsIFJlY3RhbmdsZUNsaWVudCwgZ2V0RGF0YUZyb21DbGlwYm9hcmQsIGdldFNlbGVjdGVkRWxlbWVudHMsIHNldENsaXBib2FyZERhdGEgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBnZXRTZWxlY3RlZERyYXdFbGVtZW50cyB9IGZyb20gJy4uL3V0aWxzL3NlbGVjdGVkJztcbmltcG9ydCB7IFBsYWl0RHJhd0VsZW1lbnQsIFBsYWl0R2VvbWV0cnksIFBsYWl0TGluZSB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQ29tbW9uVHJhbnNmb3JtcyB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZ2V0VGV4dEZyb21DbGlwYm9hcmQsIGdldFRleHRTaXplIH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuaW1wb3J0IHsgYnVpbGRDbGlwYm9hcmREYXRhLCBpbnNlcnRDbGlwYm9hcmREYXRhIH0gZnJvbSAnLi4vdXRpbHMvY2xpcGJvYXJkJztcbmltcG9ydCB7IERyYXdUcmFuc2Zvcm1zIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcyc7XG5cbmV4cG9ydCBjb25zdCB3aXRoRHJhd0ZyYWdtZW50ID0gKGJhc2VCb2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IGJvYXJkID0gYmFzZUJvYXJkIGFzIFBsYWl0Qm9hcmQ7XG4gICAgY29uc3QgeyBkZWxldGVGcmFnbWVudCwgc2V0RnJhZ21lbnQsIGluc2VydEZyYWdtZW50IH0gPSBib2FyZDtcblxuICAgIGJvYXJkLmRlbGV0ZUZyYWdtZW50ID0gKGRhdGE6IERhdGFUcmFuc2ZlciB8IG51bGwpID0+IHtcbiAgICAgICAgY29uc3QgZHJhd0VsZW1lbnRzID0gZ2V0U2VsZWN0ZWREcmF3RWxlbWVudHMoYm9hcmQpO1xuICAgICAgICBpZiAoZHJhd0VsZW1lbnRzLmxlbmd0aCkge1xuICAgICAgICAgICAgY29uc3QgZ2VvbWV0cnlFbGVtZW50cyA9IGRyYXdFbGVtZW50cy5maWx0ZXIodmFsdWUgPT4gUGxhaXREcmF3RWxlbWVudC5pc0RyYXdFbGVtZW50KHZhbHVlKSkgYXMgUGxhaXRHZW9tZXRyeVtdO1xuXG4gICAgICAgICAgICAvLyBxdWVyeSBib3VuZCBsaW5lc1xuICAgICAgICAgICAgY29uc3QgYm91bmRMaW5lRWxlbWVudHM6IFBsYWl0TGluZVtdID0gW107XG5cbiAgICAgICAgICAgIENvbW1vblRyYW5zZm9ybXMucmVtb3ZlRWxlbWVudHMoYm9hcmQsIFsuLi5nZW9tZXRyeUVsZW1lbnRzLCAuLi5ib3VuZExpbmVFbGVtZW50c10pO1xuICAgICAgICB9XG4gICAgICAgIGRlbGV0ZUZyYWdtZW50KGRhdGEpO1xuICAgIH07XG5cbiAgICBib2FyZC5zZXRGcmFnbWVudCA9IChkYXRhOiBEYXRhVHJhbnNmZXIgfCBudWxsLCByZWN0YW5nbGU6IFJlY3RhbmdsZUNsaWVudCB8IG51bGwpID0+IHtcbiAgICAgICAgY29uc3QgdGFyZ2V0RHJhd0VsZW1lbnRzID0gZ2V0U2VsZWN0ZWREcmF3RWxlbWVudHMoYm9hcmQpO1xuICAgICAgICBpZiAodGFyZ2V0RHJhd0VsZW1lbnRzLmxlbmd0aCkge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudHMgPSBidWlsZENsaXBib2FyZERhdGEoYm9hcmQsIHRhcmdldERyYXdFbGVtZW50cywgcmVjdGFuZ2xlID8gW3JlY3RhbmdsZS54LCByZWN0YW5nbGUueV0gOiBbMCwgMF0pO1xuICAgICAgICAgICAgc2V0Q2xpcGJvYXJkRGF0YShkYXRhLCBlbGVtZW50cyk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0RnJhZ21lbnQoZGF0YSwgcmVjdGFuZ2xlKTtcbiAgICB9O1xuXG4gICAgYm9hcmQuaW5zZXJ0RnJhZ21lbnQgPSAoZGF0YTogRGF0YVRyYW5zZmVyIHwgbnVsbCwgdGFyZ2V0UG9pbnQ6IFBvaW50KSA9PiB7XG4gICAgICAgIGNvbnN0IGVsZW1lbnRzID0gZ2V0RGF0YUZyb21DbGlwYm9hcmQoZGF0YSk7XG4gICAgICAgIGNvbnN0IGRyYXdFbGVtZW50cyA9IGVsZW1lbnRzLmZpbHRlcih2YWx1ZSA9PiBQbGFpdERyYXdFbGVtZW50LmlzRHJhd0VsZW1lbnQodmFsdWUpKSBhcyBQbGFpdERyYXdFbGVtZW50W107XG4gICAgICAgIGlmIChlbGVtZW50cy5sZW5ndGggPiAwICYmIGRyYXdFbGVtZW50cy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBpbnNlcnRDbGlwYm9hcmREYXRhKGJvYXJkLCBkcmF3RWxlbWVudHMsIHRhcmdldFBvaW50KTtcbiAgICAgICAgfSBlbHNlIGlmIChlbGVtZW50cy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICAgIGNvbnN0IHRleHQgPSBnZXRUZXh0RnJvbUNsaXBib2FyZChkYXRhKTtcbiAgICAgICAgICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICAgICAgICAgIC8vICgq77+j77i277+jKVxuICAgICAgICAgICAgY29uc3QgaW5zZXJ0QXNDaGlsZHJlbiA9IHNlbGVjdGVkRWxlbWVudHMubGVuZ3RoID09PSAxICYmIHNlbGVjdGVkRWxlbWVudHNbMF0uY2hpbGRyZW47XG4gICAgICAgICAgICBjb25zdCBpbnNlcnRBc0ZyZWVUZXh0ID0gIWluc2VydEFzQ2hpbGRyZW47XG4gICAgICAgICAgICBpZiAodGV4dCAmJiBpbnNlcnRBc0ZyZWVUZXh0KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgeyB3aWR0aCwgaGVpZ2h0IH0gPSBnZXRUZXh0U2l6ZShib2FyZCwgdGV4dCk7XG4gICAgICAgICAgICAgICAgRHJhd1RyYW5zZm9ybXMuaW5zZXJ0VGV4dChib2FyZCwgW3RhcmdldFBvaW50LCBbdGFyZ2V0UG9pbnRbMF0gKyB3aWR0aCwgdGFyZ2V0UG9pbnRbMV0gKyBoZWlnaHRdXSwgdGV4dCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGluc2VydEZyYWdtZW50KGRhdGEsIHRhcmdldFBvaW50KTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIGJvYXJkO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { PlaitElement, getSelectedElements } from '@plait/core';
|
|
2
|
+
import { isVirtualKey, isSpaceHotkey } from '@plait/common';
|
|
3
|
+
import { PlaitDrawElement } from '../interfaces';
|
|
4
|
+
export const withDrawHotkey = (board) => {
|
|
5
|
+
const { keydown } = board;
|
|
6
|
+
board.keydown = (event) => {
|
|
7
|
+
const selectedElements = getSelectedElements(board);
|
|
8
|
+
const isSingleSelection = selectedElements.length === 1;
|
|
9
|
+
const targetElement = selectedElements[0];
|
|
10
|
+
if (!isVirtualKey(event) && !isSpaceHotkey(event) && isSingleSelection && PlaitDrawElement.isDrawElement(targetElement)) {
|
|
11
|
+
event.preventDefault();
|
|
12
|
+
PlaitElement.getComponent(targetElement).editText();
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
keydown(event);
|
|
16
|
+
};
|
|
17
|
+
return board;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1kcmF3LWhvdGtleS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2RyYXcvc3JjL3BsdWdpbnMvd2l0aC1kcmF3LWhvdGtleS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsWUFBWSxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVFLE9BQU8sRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7SUFDaEQsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLEtBQUssQ0FBQztJQUMxQixLQUFLLENBQUMsT0FBTyxHQUFHLENBQUMsS0FBb0IsRUFBRSxFQUFFO1FBQ3JDLE1BQU0sZ0JBQWdCLEdBQUcsbUJBQW1CLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDcEQsTUFBTSxpQkFBaUIsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO1FBQ3hELE1BQU0sYUFBYSxHQUFHLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTFDLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLElBQUksaUJBQWlCLElBQUksZ0JBQWdCLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxFQUFFO1lBQ3JILEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUV0QixZQUFZLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBdUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUMzRSxPQUFPO1NBQ1Y7UUFFRCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkIsQ0FBQyxDQUFDO0lBQ0YsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50LCBnZXRTZWxlY3RlZEVsZW1lbnRzIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgaXNWaXJ0dWFsS2V5LCBpc1NwYWNlSG90a2V5IH0gZnJvbSAnQHBsYWl0L2NvbW1vbic7XG5pbXBvcnQgeyBHZW9tZXRyeUNvbXBvbmVudCB9IGZyb20gJy4uL2dlb21ldHJ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQbGFpdERyYXdFbGVtZW50IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBjb25zdCB3aXRoRHJhd0hvdGtleSA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHsga2V5ZG93biB9ID0gYm9hcmQ7XG4gICAgYm9hcmQua2V5ZG93biA9IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge1xuICAgICAgICBjb25zdCBzZWxlY3RlZEVsZW1lbnRzID0gZ2V0U2VsZWN0ZWRFbGVtZW50cyhib2FyZCk7XG4gICAgICAgIGNvbnN0IGlzU2luZ2xlU2VsZWN0aW9uID0gc2VsZWN0ZWRFbGVtZW50cy5sZW5ndGggPT09IDE7XG4gICAgICAgIGNvbnN0IHRhcmdldEVsZW1lbnQgPSBzZWxlY3RlZEVsZW1lbnRzWzBdO1xuXG4gICAgICAgIGlmICghaXNWaXJ0dWFsS2V5KGV2ZW50KSAmJiAhaXNTcGFjZUhvdGtleShldmVudCkgJiYgaXNTaW5nbGVTZWxlY3Rpb24gJiYgUGxhaXREcmF3RWxlbWVudC5pc0RyYXdFbGVtZW50KHRhcmdldEVsZW1lbnQpKSB7XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuXG4gICAgICAgICAgICAoUGxhaXRFbGVtZW50LmdldENvbXBvbmVudCh0YXJnZXRFbGVtZW50KSBhcyBHZW9tZXRyeUNvbXBvbmVudCkuZWRpdFRleHQoKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGtleWRvd24oZXZlbnQpO1xuICAgIH07XG4gICAgcmV0dXJuIGJvYXJkO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { PlaitElement, RectangleClient, getSelectedElements, isPolylineHitRectangle } from '@plait/core';
|
|
2
|
+
import { GeometryComponent } from '../geometry.component';
|
|
3
|
+
import { LineComponent } from '../line.component';
|
|
4
|
+
import { PlaitDrawElement } from '../interfaces';
|
|
5
|
+
import { getRectangleByPoints } from '@plait/common';
|
|
6
|
+
import { withDrawHotkey } from './with-draw-hotkey';
|
|
7
|
+
import { withGeometryCreateByDraw, withGeometryCreateByDrag } from './with-geometry-create';
|
|
8
|
+
import { withDrawFragment } from './with-draw-fragment';
|
|
9
|
+
import { getElbowPoints, getTextRectangle, isHitPolyLine, isHitLineText } from '../utils';
|
|
10
|
+
import { getStrokeWidthByElement } from '../utils/geometry-style/stroke';
|
|
11
|
+
import { withLineCreateByDraw } from './with-line-create';
|
|
12
|
+
import { withGeometryResize } from './with-geometry-resize';
|
|
13
|
+
import { withLineResize } from './with-line-resize';
|
|
14
|
+
import { withLineBoundReaction } from './with-line-bound-reaction';
|
|
15
|
+
import { withLineText } from './with-line-text';
|
|
16
|
+
export const withDraw = (board) => {
|
|
17
|
+
const { drawElement, getRectangle, isHitSelection, isMovable, dblclick } = board;
|
|
18
|
+
board.drawElement = (context) => {
|
|
19
|
+
if (PlaitDrawElement.isGeometry(context.element)) {
|
|
20
|
+
return GeometryComponent;
|
|
21
|
+
}
|
|
22
|
+
else if (PlaitDrawElement.isLine(context.element)) {
|
|
23
|
+
return LineComponent;
|
|
24
|
+
}
|
|
25
|
+
return drawElement(context);
|
|
26
|
+
};
|
|
27
|
+
board.getRectangle = (element) => {
|
|
28
|
+
if (PlaitDrawElement.isGeometry(element)) {
|
|
29
|
+
return getRectangleByPoints(element.points);
|
|
30
|
+
}
|
|
31
|
+
return getRectangle(element);
|
|
32
|
+
};
|
|
33
|
+
board.isHitSelection = (element, range) => {
|
|
34
|
+
if (PlaitDrawElement.isGeometry(element)) {
|
|
35
|
+
const client = getRectangleByPoints(element.points);
|
|
36
|
+
const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);
|
|
37
|
+
if (element.textHeight > client.height) {
|
|
38
|
+
const textClient = getTextRectangle(element);
|
|
39
|
+
return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);
|
|
40
|
+
}
|
|
41
|
+
return RectangleClient.isHit(rangeRectangle, client);
|
|
42
|
+
}
|
|
43
|
+
if (PlaitDrawElement.isLine(element)) {
|
|
44
|
+
const points = getElbowPoints(board, element);
|
|
45
|
+
const strokeWidth = getStrokeWidthByElement(element);
|
|
46
|
+
const isHitText = isHitLineText(board, element, range.focus);
|
|
47
|
+
const isHit = isHitPolyLine(points, range.focus, strokeWidth, 3) || isHitText;
|
|
48
|
+
const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);
|
|
49
|
+
const isContainPolyLinePoint = points.some(point => {
|
|
50
|
+
return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));
|
|
51
|
+
});
|
|
52
|
+
const isIntersect = range.anchor === range.focus ? isHit : isPolylineHitRectangle(points, rangeRectangle);
|
|
53
|
+
return isContainPolyLinePoint || isIntersect;
|
|
54
|
+
}
|
|
55
|
+
return isHitSelection(element, range);
|
|
56
|
+
};
|
|
57
|
+
board.isMovable = (element) => {
|
|
58
|
+
if (PlaitDrawElement.isGeometry(element)) {
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
if (PlaitDrawElement.isLine(element)) {
|
|
62
|
+
return !element.source.boundId && !element.source.boundId;
|
|
63
|
+
}
|
|
64
|
+
return isMovable(element);
|
|
65
|
+
};
|
|
66
|
+
board.dblclick = (event) => {
|
|
67
|
+
const element = getSelectedElements(board)[0];
|
|
68
|
+
if (element && PlaitDrawElement.isGeometry(element)) {
|
|
69
|
+
const component = PlaitElement.getComponent(element);
|
|
70
|
+
component.editText();
|
|
71
|
+
}
|
|
72
|
+
dblclick(event);
|
|
73
|
+
};
|
|
74
|
+
return withLineText(withLineBoundReaction(withLineResize(withGeometryResize(withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDraw(withDrawFragment(withDrawHotkey(board)))))))));
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-draw.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-draw.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    PlaitBoard,\n    PlaitElement,\n    PlaitPluginElementContext,\n    Range,\n    RectangleClient,\n    getSelectedElements,\n    isPolylineHitRectangle,\n    preventTouchMove\n} from '@plait/core';\nimport { GeometryComponent } from '../geometry.component';\nimport { LineComponent } from '../line.component';\nimport { PlaitDrawElement } from '../interfaces';\nimport { getRectangleByPoints } from '@plait/common';\nimport { withDrawHotkey } from './with-draw-hotkey';\nimport { withGeometryCreateByDraw, withGeometryCreateByDrag } from './with-geometry-create';\nimport { withDrawFragment } from './with-draw-fragment';\nimport { getElbowPoints, getTextRectangle, getHitLineTextIndex, isHitPolyLine, isHitLineText } from '../utils';\nimport { getStrokeWidthByElement } from '../utils/geometry-style/stroke';\nimport { withLineCreateByDraw } from './with-line-create';\nimport { withGeometryResize } from './with-geometry-resize';\nimport { withLineResize } from './with-line-resize';\nimport { withLineBoundReaction } from './with-line-bound-reaction';\nimport { withLineText } from './with-line-text';\n\nexport const withDraw = (board: PlaitBoard) => {\n    const { drawElement, getRectangle, isHitSelection, isMovable, dblclick } = board;\n\n    board.drawElement = (context: PlaitPluginElementContext) => {\n        if (PlaitDrawElement.isGeometry(context.element)) {\n            return GeometryComponent;\n        } else if (PlaitDrawElement.isLine(context.element)) {\n            return LineComponent;\n        }\n        return drawElement(context);\n    };\n\n    board.getRectangle = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return getRectangleByPoints(element.points);\n        }\n        return getRectangle(element);\n    };\n\n    board.isHitSelection = (element: PlaitElement, range: Range) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            const client = getRectangleByPoints(element.points);\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            if (element.textHeight > client.height) {\n                const textClient = getTextRectangle(element);\n                return RectangleClient.isHit(rangeRectangle, client) || RectangleClient.isHit(rangeRectangle, textClient);\n            }\n            return RectangleClient.isHit(rangeRectangle, client);\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            const points = getElbowPoints(board, element);\n            const strokeWidth = getStrokeWidthByElement(element);\n            const isHitText = isHitLineText(board, element, range.focus);\n            const isHit = isHitPolyLine(points, range.focus, strokeWidth, 3) || isHitText;\n            const rangeRectangle = RectangleClient.toRectangleClient([range.anchor, range.focus]);\n            const isContainPolyLinePoint = points.some(point => {\n                return RectangleClient.isHit(rangeRectangle, RectangleClient.toRectangleClient([point, point]));\n            });\n            const isIntersect = range.anchor === range.focus ? isHit : isPolylineHitRectangle(points, rangeRectangle);\n            return isContainPolyLinePoint || isIntersect;\n        }\n\n        return isHitSelection(element, range);\n    };\n\n    board.isMovable = (element: PlaitElement) => {\n        if (PlaitDrawElement.isGeometry(element)) {\n            return true;\n        }\n        if (PlaitDrawElement.isLine(element)) {\n            return !element.source.boundId && !element.source.boundId;\n        }\n        return isMovable(element);\n    };\n\n    board.dblclick = (event: MouseEvent) => {\n        const element = getSelectedElements(board)[0];\n        if (element && PlaitDrawElement.isGeometry(element)) {\n            const component = PlaitElement.getComponent(element) as GeometryComponent;\n            component.editText();\n        }\n\n        dblclick(event);\n    };\n\n    return withLineText(\n        withLineBoundReaction(\n            withLineResize(\n                withGeometryResize(\n                    withLineCreateByDraw(withGeometryCreateByDrag(withGeometryCreateByDraw(withDrawFragment(withDrawHotkey(board)))))\n                )\n            )\n        )\n    );\n};\n"]}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { BoardTransforms, PlaitBoard, PlaitPointerType, RectangleClient, Transforms, addSelectedElement, clearSelectedElement, createForeignObject, createG, preventTouchMove, toPoint, transformPoint } from '@plait/core';
|
|
2
|
+
import { GeometryShape } from '../interfaces';
|
|
3
|
+
import { GeometryShapeGenerator } from '../generator/geometry-shape.generator';
|
|
4
|
+
import { DrawCreateMode, createGeometryElement, getCreateMode, getPointsByCenterPoint } from '../utils';
|
|
5
|
+
import { DefaultGeometryProperty, DefaultTextProperty, DrawPointerType, GeometryPointer, ShapeDefaultSpace } from '../constants';
|
|
6
|
+
import { normalizeShapePoints } from '@plait/common';
|
|
7
|
+
import { DrawTransforms } from '../transforms';
|
|
8
|
+
import { DEFAULT_FONT_SIZE } from '@plait/text';
|
|
9
|
+
import { isKeyHotkey } from 'is-hotkey';
|
|
10
|
+
export const withGeometryCreateByDrag = (board) => {
|
|
11
|
+
const { pointerMove, pointerUp } = board;
|
|
12
|
+
let createMode = undefined;
|
|
13
|
+
let geometryShapeG = null;
|
|
14
|
+
board.pointerMove = (event) => {
|
|
15
|
+
geometryShapeG?.remove();
|
|
16
|
+
geometryShapeG = createG();
|
|
17
|
+
createMode = getCreateMode(board);
|
|
18
|
+
const geometryGenerator = new GeometryShapeGenerator(board);
|
|
19
|
+
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
20
|
+
const dragMode = isGeometryPointer && createMode === DrawCreateMode.drag;
|
|
21
|
+
const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
22
|
+
const pointer = PlaitBoard.getPointer(board);
|
|
23
|
+
if (dragMode) {
|
|
24
|
+
const points = getDefaultGeometryPoints(pointer, movingPoint);
|
|
25
|
+
if (pointer === DrawPointerType.text) {
|
|
26
|
+
const textG = getTemporaryTextG(movingPoint);
|
|
27
|
+
geometryShapeG.appendChild(textG);
|
|
28
|
+
PlaitBoard.getElementActiveHost(board).append(geometryShapeG);
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
const temporaryElement = createGeometryElement(pointer, points, '', {
|
|
32
|
+
strokeColor: DefaultGeometryProperty.strokeColor,
|
|
33
|
+
strokeWidth: DefaultGeometryProperty.strokeWidth
|
|
34
|
+
});
|
|
35
|
+
geometryGenerator.draw(temporaryElement, geometryShapeG);
|
|
36
|
+
PlaitBoard.getElementActiveHost(board).append(geometryShapeG);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
pointerMove(event);
|
|
40
|
+
};
|
|
41
|
+
board.pointerUp = (event) => {
|
|
42
|
+
const pointer = PlaitBoard.getPointer(board);
|
|
43
|
+
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
44
|
+
const dragMode = isGeometryPointer && createMode === DrawCreateMode.drag;
|
|
45
|
+
if (dragMode) {
|
|
46
|
+
const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
47
|
+
const points = getDefaultGeometryPoints(pointer, targetPoint);
|
|
48
|
+
if (pointer === DrawPointerType.text) {
|
|
49
|
+
DrawTransforms.insertText(board, points);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
DrawTransforms.insertGeometry(board, points, pointer);
|
|
53
|
+
}
|
|
54
|
+
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
55
|
+
}
|
|
56
|
+
geometryShapeG?.remove();
|
|
57
|
+
geometryShapeG = null;
|
|
58
|
+
preventTouchMove(board, false);
|
|
59
|
+
pointerUp(event);
|
|
60
|
+
};
|
|
61
|
+
return board;
|
|
62
|
+
};
|
|
63
|
+
export const withGeometryCreateByDraw = (board) => {
|
|
64
|
+
const { pointerDown, pointerMove, pointerUp, keydown, keyup } = board;
|
|
65
|
+
let start = null;
|
|
66
|
+
let geometryShapeG = null;
|
|
67
|
+
let temporaryElement = null;
|
|
68
|
+
let isShift = false;
|
|
69
|
+
board.keydown = (event) => {
|
|
70
|
+
isShift = isKeyHotkey('shift', event);
|
|
71
|
+
keydown(event);
|
|
72
|
+
};
|
|
73
|
+
board.keyup = (event) => {
|
|
74
|
+
isShift = false;
|
|
75
|
+
keyup(event);
|
|
76
|
+
};
|
|
77
|
+
board.pointerDown = (event) => {
|
|
78
|
+
const createMode = getCreateMode(board);
|
|
79
|
+
const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);
|
|
80
|
+
if (isGeometryPointer && createMode === DrawCreateMode.draw) {
|
|
81
|
+
const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
82
|
+
start = point;
|
|
83
|
+
preventTouchMove(board, true);
|
|
84
|
+
const pointer = PlaitBoard.getPointer(board);
|
|
85
|
+
if (pointer === DrawPointerType.text) {
|
|
86
|
+
const points = getDefaultGeometryPoints(pointer, point);
|
|
87
|
+
const textElement = createGeometryElement(GeometryShape.text, points, DefaultTextProperty.text);
|
|
88
|
+
Transforms.insertNode(board, textElement, [board.children.length]);
|
|
89
|
+
clearSelectedElement(board);
|
|
90
|
+
addSelectedElement(board, textElement);
|
|
91
|
+
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
92
|
+
start = null;
|
|
93
|
+
preventTouchMove(board, false);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
pointerDown(event);
|
|
97
|
+
};
|
|
98
|
+
board.pointerMove = (event) => {
|
|
99
|
+
geometryShapeG?.remove();
|
|
100
|
+
geometryShapeG = createG();
|
|
101
|
+
const geometryGenerator = new GeometryShapeGenerator(board);
|
|
102
|
+
const drawMode = !!start;
|
|
103
|
+
const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
104
|
+
const pointer = PlaitBoard.getPointer(board);
|
|
105
|
+
if (drawMode && pointer !== DrawPointerType.text) {
|
|
106
|
+
const points = normalizeShapePoints([start, movingPoint], isShift);
|
|
107
|
+
temporaryElement = createGeometryElement(pointer, points, '', {
|
|
108
|
+
strokeColor: DefaultGeometryProperty.strokeColor,
|
|
109
|
+
strokeWidth: DefaultGeometryProperty.strokeWidth
|
|
110
|
+
});
|
|
111
|
+
geometryGenerator.draw(temporaryElement, geometryShapeG);
|
|
112
|
+
PlaitBoard.getElementActiveHost(board).append(geometryShapeG);
|
|
113
|
+
}
|
|
114
|
+
pointerMove(event);
|
|
115
|
+
};
|
|
116
|
+
board.pointerUp = (event) => {
|
|
117
|
+
const isDrawMode = !!start;
|
|
118
|
+
if (isDrawMode) {
|
|
119
|
+
const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
120
|
+
const { width, height } = RectangleClient.toRectangleClient([start, targetPoint]);
|
|
121
|
+
if (Math.hypot(width, height) === 0) {
|
|
122
|
+
const pointer = PlaitBoard.getPointer(board);
|
|
123
|
+
const points = getDefaultGeometryPoints(pointer, targetPoint);
|
|
124
|
+
if (pointer !== DrawPointerType.text) {
|
|
125
|
+
temporaryElement = createGeometryElement(pointer, points, '', {
|
|
126
|
+
strokeColor: DefaultGeometryProperty.strokeColor,
|
|
127
|
+
strokeWidth: DefaultGeometryProperty.strokeWidth
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
if (temporaryElement) {
|
|
133
|
+
Transforms.insertNode(board, temporaryElement, [board.children.length]);
|
|
134
|
+
clearSelectedElement(board);
|
|
135
|
+
addSelectedElement(board, temporaryElement);
|
|
136
|
+
BoardTransforms.updatePointerType(board, PlaitPointerType.selection);
|
|
137
|
+
}
|
|
138
|
+
geometryShapeG?.remove();
|
|
139
|
+
geometryShapeG = null;
|
|
140
|
+
start = null;
|
|
141
|
+
temporaryElement = null;
|
|
142
|
+
preventTouchMove(board, false);
|
|
143
|
+
pointerUp(event);
|
|
144
|
+
};
|
|
145
|
+
return board;
|
|
146
|
+
};
|
|
147
|
+
const getDefaultGeometryPoints = (pointer, targetPoint) => {
|
|
148
|
+
return pointer === DrawPointerType.text
|
|
149
|
+
? getPointsByCenterPoint(targetPoint, DefaultTextProperty.width, DefaultTextProperty.height)
|
|
150
|
+
: getPointsByCenterPoint(targetPoint, DefaultGeometryProperty.width, DefaultGeometryProperty.height);
|
|
151
|
+
};
|
|
152
|
+
const getTemporaryTextG = (movingPoint) => {
|
|
153
|
+
const textG = createG();
|
|
154
|
+
const width = DefaultTextProperty.width - ShapeDefaultSpace.rectangleAndText * 2;
|
|
155
|
+
const foreignObject = createForeignObject(movingPoint[0] - width / 2, movingPoint[1] - DefaultTextProperty.height / 2, width, DefaultTextProperty.height);
|
|
156
|
+
const richtext = document.createElement('div');
|
|
157
|
+
richtext.textContent = DefaultTextProperty.text;
|
|
158
|
+
richtext.style.fontSize = `${DEFAULT_FONT_SIZE}px`;
|
|
159
|
+
richtext.style.cursor = 'default';
|
|
160
|
+
foreignObject.appendChild(richtext);
|
|
161
|
+
textG.appendChild(foreignObject);
|
|
162
|
+
return textG;
|
|
163
|
+
};
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-geometry-create.js","sourceRoot":"","sources":["../../../../packages/draw/src/plugins/with-geometry-create.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    BoardTransforms,\n    PlaitBoard,\n    PlaitPointerType,\n    Point,\n    RectangleClient,\n    Transforms,\n    addSelectedElement,\n    clearSelectedElement,\n    createForeignObject,\n    createG,\n    preventTouchMove,\n    toPoint,\n    transformPoint\n} from '@plait/core';\nimport { GeometryShape, PlaitGeometry } from '../interfaces';\nimport { GeometryShapeGenerator } from '../generator/geometry-shape.generator';\nimport { DrawCreateMode, createGeometryElement, getCreateMode, getPointsByCenterPoint } from '../utils';\nimport { DefaultGeometryProperty, DefaultTextProperty, DrawPointerType, GeometryPointer, ShapeDefaultSpace } from '../constants';\nimport { normalizeShapePoints } from '@plait/common';\nimport { DrawTransforms } from '../transforms';\nimport { DEFAULT_FONT_SIZE } from '@plait/text';\nimport { isKeyHotkey } from 'is-hotkey';\n\nexport const withGeometryCreateByDrag = (board: PlaitBoard) => {\n    const { pointerMove, pointerUp } = board;\n\n    let createMode: DrawCreateMode | undefined = undefined;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        createMode = getCreateMode(board);\n\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        const dragMode = isGeometryPointer && createMode === DrawCreateMode.drag;\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (dragMode) {\n            const points = getDefaultGeometryPoints(pointer, movingPoint);\n            if (pointer === DrawPointerType.text) {\n                const textG = getTemporaryTextG(movingPoint);\n                geometryShapeG.appendChild(textG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            } else {\n                const temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                    strokeColor: DefaultGeometryProperty.strokeColor,\n                    strokeWidth: DefaultGeometryProperty.strokeWidth\n                });\n                geometryGenerator.draw(temporaryElement, geometryShapeG);\n                PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n            }\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        const dragMode = isGeometryPointer && createMode === DrawCreateMode.drag;\n\n        if (dragMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const points = getDefaultGeometryPoints(pointer, targetPoint);\n            if (pointer === DrawPointerType.text) {\n                DrawTransforms.insertText(board, points);\n            } else {\n                DrawTransforms.insertGeometry(board, points, (pointer as unknown) as GeometryShape);\n            }\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        preventTouchMove(board, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nexport const withGeometryCreateByDraw = (board: PlaitBoard) => {\n    const { pointerDown, pointerMove, pointerUp, keydown, keyup } = board;\n    let start: Point | null = null;\n\n    let geometryShapeG: SVGGElement | null = null;\n\n    let temporaryElement: PlaitGeometry | null = null;\n\n    let isShift = false;\n\n    board.keydown = (event: KeyboardEvent) => {\n        isShift = isKeyHotkey('shift', event);\n        keydown(event);\n    };\n\n    board.keyup = (event: KeyboardEvent) => {\n        isShift = false;\n        keyup(event);\n    };\n\n    board.pointerDown = (event: PointerEvent) => {\n        const createMode = getCreateMode(board);\n\n        const isGeometryPointer = PlaitBoard.isInPointer(board, GeometryPointer);\n        if (isGeometryPointer && createMode === DrawCreateMode.draw) {\n            const point = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            start = point;\n            preventTouchMove(board, true);\n\n            const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n            if (pointer === DrawPointerType.text) {\n                const points = getDefaultGeometryPoints(pointer, point);\n                const textElement = createGeometryElement(GeometryShape.text, points, DefaultTextProperty.text);\n                Transforms.insertNode(board, textElement, [board.children.length]);\n                clearSelectedElement(board);\n                addSelectedElement(board, textElement);\n                BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n                start = null;\n                preventTouchMove(board, false);\n            }\n        }\n        pointerDown(event);\n    };\n\n    board.pointerMove = (event: PointerEvent) => {\n        geometryShapeG?.remove();\n        geometryShapeG = createG();\n        const geometryGenerator = new GeometryShapeGenerator(board);\n        const drawMode = !!start;\n        const movingPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n        const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n\n        if (drawMode && pointer !== DrawPointerType.text) {\n            const points = normalizeShapePoints([start!, movingPoint], isShift);\n            temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                strokeColor: DefaultGeometryProperty.strokeColor,\n                strokeWidth: DefaultGeometryProperty.strokeWidth\n            });\n            geometryGenerator.draw(temporaryElement, geometryShapeG);\n            PlaitBoard.getElementActiveHost(board).append(geometryShapeG);\n        }\n\n        pointerMove(event);\n    };\n\n    board.pointerUp = (event: PointerEvent) => {\n        const isDrawMode = !!start;\n        if (isDrawMode) {\n            const targetPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));\n            const { width, height } = RectangleClient.toRectangleClient([start!, targetPoint]);\n            if (Math.hypot(width, height) === 0) {\n                const pointer = PlaitBoard.getPointer(board) as DrawPointerType;\n                const points = getDefaultGeometryPoints(pointer, targetPoint);\n                if (pointer !== DrawPointerType.text) {\n                    temporaryElement = createGeometryElement((pointer as unknown) as GeometryShape, points, '', {\n                        strokeColor: DefaultGeometryProperty.strokeColor,\n                        strokeWidth: DefaultGeometryProperty.strokeWidth\n                    });\n                }\n            }\n        }\n        if (temporaryElement) {\n            Transforms.insertNode(board, temporaryElement, [board.children.length]);\n            clearSelectedElement(board);\n            addSelectedElement(board, temporaryElement);\n            BoardTransforms.updatePointerType(board, PlaitPointerType.selection);\n        }\n\n        geometryShapeG?.remove();\n        geometryShapeG = null;\n        start = null;\n        temporaryElement = null;\n        preventTouchMove(board, false);\n\n        pointerUp(event);\n    };\n\n    return board;\n};\n\nconst getDefaultGeometryPoints = (pointer: DrawPointerType, targetPoint: Point) => {\n    return pointer === DrawPointerType.text\n        ? getPointsByCenterPoint(targetPoint, DefaultTextProperty.width, DefaultTextProperty.height)\n        : getPointsByCenterPoint(targetPoint, DefaultGeometryProperty.width, DefaultGeometryProperty.height);\n};\n\nconst getTemporaryTextG = (movingPoint: Point) => {\n    const textG = createG();\n    const width = DefaultTextProperty.width - ShapeDefaultSpace.rectangleAndText * 2;\n    const foreignObject = createForeignObject(\n        movingPoint[0] - width / 2,\n        movingPoint[1] - DefaultTextProperty.height / 2,\n        width,\n        DefaultTextProperty.height\n    );\n\n    const richtext = document.createElement('div');\n    richtext.textContent = DefaultTextProperty.text;\n    richtext.style.fontSize = `${DEFAULT_FONT_SIZE}px`;\n    richtext.style.cursor = 'default';\n    foreignObject.appendChild(richtext);\n    textG.appendChild(foreignObject);\n\n    return textG;\n};\n"]}
|