@finos/legend-extension-dsl-diagram 0.1.0 → 1.0.2
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/CHANGELOG.md +14 -0
- package/lib/DSLDiagram_Extension.d.ts +0 -5
- package/lib/DSLDiagram_Extension.d.ts.map +1 -1
- package/lib/DSLDiagram_Extension.js +0 -12
- package/lib/DSLDiagram_Extension.js.map +1 -1
- package/lib/DiagramRenderer.d.ts.map +1 -1
- package/lib/DiagramRenderer.js +76 -50
- package/lib/DiagramRenderer.js.map +1 -1
- package/lib/components/studio/ClassDiagramPreview.js +1 -1
- package/lib/components/studio/ClassDiagramPreview.js.map +1 -1
- package/lib/components/studio/{DSLDiagram_StudioPlugin.d.ts → DSLDiagram_LegendStudioPlugin.d.ts} +5 -5
- package/lib/components/studio/DSLDiagram_LegendStudioPlugin.d.ts.map +1 -0
- package/lib/components/studio/{DSLDiagram_StudioPlugin.js → DSLDiagram_LegendStudioPlugin.js} +4 -4
- package/lib/components/studio/DSLDiagram_LegendStudioPlugin.js.map +1 -0
- package/lib/components/studio/{DSLDiagram_StudioPlugin_Extension.d.ts → DSLDiagram_LegendStudioPlugin_Extension.d.ts} +3 -3
- package/lib/components/studio/DSLDiagram_LegendStudioPlugin_Extension.d.ts.map +1 -0
- package/lib/components/studio/{DSLDiagram_StudioPlugin_Extension.js → DSLDiagram_LegendStudioPlugin_Extension.js} +1 -1
- package/lib/components/studio/DSLDiagram_LegendStudioPlugin_Extension.js.map +1 -0
- package/lib/components/studio/DiagramEditor.js +36 -36
- package/lib/components/studio/DiagramEditor.js.map +1 -1
- package/lib/index.css +1 -1
- package/lib/index.css.map +1 -1
- package/lib/index.d.ts +2 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -1
- package/lib/index.js.map +1 -1
- package/lib/models/metamodels/pure/packageableElements/diagram/RelationshipView.d.ts.map +1 -1
- package/lib/models/metamodels/pure/packageableElements/diagram/RelationshipView.js +3 -0
- package/lib/models/metamodels/pure/packageableElements/diagram/RelationshipView.js.map +1 -1
- package/lib/stores/studio/DiagramEditorState.d.ts.map +1 -1
- package/lib/stores/studio/DiagramEditorState.js +3 -3
- package/lib/stores/studio/DiagramEditorState.js.map +1 -1
- package/package.json +15 -16
- package/src/DSLDiagram_Extension.ts +0 -15
- package/src/DiagramRenderer.ts +94 -73
- package/src/components/studio/{DSLDiagram_StudioPlugin.tsx → DSLDiagram_LegendStudioPlugin.tsx} +7 -7
- package/src/components/studio/{DSLDiagram_StudioPlugin_Extension.tsx → DSLDiagram_LegendStudioPlugin_Extension.tsx} +3 -3
- package/src/components/studio/DiagramEditor.tsx +2 -2
- package/src/index.ts +3 -1
- package/src/models/metamodels/pure/packageableElements/diagram/RelationshipView.ts +24 -14
- package/src/stores/studio/DiagramEditorState.ts +3 -7
- package/tsconfig.json +3 -2
- package/tsconfig.package.json +1 -0
- package/lib/components/studio/DSLDiagram_StudioPlugin.d.ts.map +0 -1
- package/lib/components/studio/DSLDiagram_StudioPlugin.js.map +0 -1
- package/lib/components/studio/DSLDiagram_StudioPlugin_Extension.d.ts.map +0 -1
- package/lib/components/studio/DSLDiagram_StudioPlugin_Extension.js.map +0 -1
@@ -33,20 +33,24 @@ export const manageInsidePointsDynamically = (
|
|
33
33
|
from: ClassView,
|
34
34
|
to: ClassView,
|
35
35
|
): Point[] => {
|
36
|
+
if (!path.length) {
|
37
|
+
return [];
|
38
|
+
}
|
39
|
+
|
36
40
|
let start = 0;
|
37
|
-
let startPoint = path[start];
|
41
|
+
let startPoint = path[start] as Point;
|
38
42
|
|
39
43
|
while (start < path.length - 1 && from.contains(startPoint.x, startPoint.y)) {
|
40
44
|
start++;
|
41
|
-
startPoint = path[start];
|
45
|
+
startPoint = path[start] as Point;
|
42
46
|
}
|
43
47
|
|
44
48
|
let end = path.length - 1;
|
45
|
-
let endPoint = path[end];
|
49
|
+
let endPoint = path[end] as Point;
|
46
50
|
|
47
51
|
while (end > 0 && to.contains(endPoint.x, endPoint.y)) {
|
48
52
|
end--;
|
49
|
-
endPoint = path[end];
|
53
|
+
endPoint = path[end] as Point;
|
50
54
|
}
|
51
55
|
|
52
56
|
return path.slice(start - 1, end + 2);
|
@@ -123,25 +127,31 @@ export class RelationshipView implements Hashable {
|
|
123
127
|
// if it does we will update the offset
|
124
128
|
if (newPath[0] !== fullPath[0]) {
|
125
129
|
const center = this.from.classView.value.center();
|
126
|
-
this.from.setOffsetX(newPath[0].x - center.x);
|
127
|
-
this.from.setOffsetY(newPath[0].y - center.y);
|
130
|
+
this.from.setOffsetX((newPath[0] as Point).x - center.x);
|
131
|
+
this.from.setOffsetY((newPath[0] as Point).y - center.y);
|
128
132
|
}
|
129
133
|
|
130
134
|
if (newPath[newPath.length - 1] !== fullPath[fullPath.length - 1]) {
|
131
135
|
const center = this.to.classView.value.center();
|
132
|
-
this.to.setOffsetX(newPath[newPath.length - 1].x - center.x);
|
133
|
-
this.to.setOffsetY(newPath[newPath.length - 1].y - center.y);
|
136
|
+
this.to.setOffsetX((newPath[newPath.length - 1] as Point).x - center.x);
|
137
|
+
this.to.setOffsetY((newPath[newPath.length - 1] as Point).y - center.y);
|
134
138
|
}
|
135
139
|
|
136
140
|
// find the point which can be flattened due to its wide angle
|
137
141
|
const result = [];
|
138
142
|
for (let i = 0; i < newPath.length - 2; i++) {
|
139
|
-
const v1 = Vector.fromPoints(
|
140
|
-
|
143
|
+
const v1 = Vector.fromPoints(
|
144
|
+
newPath[i + 1] as Point,
|
145
|
+
newPath[i] as Point,
|
146
|
+
).norm();
|
147
|
+
const v2 = Vector.fromPoints(
|
148
|
+
newPath[i + 1] as Point,
|
149
|
+
newPath[i + 2] as Point,
|
150
|
+
).norm();
|
141
151
|
const dot = v1.dotProduct(v2);
|
142
152
|
const angle = (Math.acos(dot) * 180) / Math.PI;
|
143
153
|
if (Math.abs(angle - 180) > 5) {
|
144
|
-
result.push(newPath[i + 1]);
|
154
|
+
result.push(newPath[i + 1] as Point);
|
145
155
|
}
|
146
156
|
}
|
147
157
|
// here's where we will modify the path, i.e. swallow inside points if we have to
|
@@ -173,8 +183,8 @@ export class RelationshipView implements Hashable {
|
|
173
183
|
let point;
|
174
184
|
|
175
185
|
for (let i = 0; i < fullPath.length - 1; i++) {
|
176
|
-
const a = fullPath[i];
|
177
|
-
const b = fullPath[i + 1];
|
186
|
+
const a = fullPath[i] as Point;
|
187
|
+
const b = fullPath[i + 1] as Point;
|
178
188
|
const n = new Vector(a.x, a.y).normal(new Vector(b.x, b.y)).norm();
|
179
189
|
const v = Vector.fromPoints(a, new Point(x, y));
|
180
190
|
|
@@ -191,7 +201,7 @@ export class RelationshipView implements Hashable {
|
|
191
201
|
}
|
192
202
|
|
193
203
|
if (i < fullPath.length - 2) {
|
194
|
-
newPath.push(fullPath[i + 1]);
|
204
|
+
newPath.push(fullPath[i + 1] as Point);
|
195
205
|
}
|
196
206
|
}
|
197
207
|
if (point && allowChange) {
|
@@ -22,7 +22,7 @@ import {
|
|
22
22
|
} from '@finos/legend-shared';
|
23
23
|
import type { DiagramRenderer } from '../../DiagramRenderer';
|
24
24
|
import { DIAGRAM_INTERACTION_MODE } from '../../DiagramRenderer';
|
25
|
-
import { PanelDisplayState } from '@finos/legend-art';
|
25
|
+
import { HotkeyConfiguration, PanelDisplayState } from '@finos/legend-art';
|
26
26
|
import type {
|
27
27
|
PackageableElement,
|
28
28
|
AbstractProperty,
|
@@ -37,11 +37,7 @@ import {
|
|
37
37
|
PropertyExplicitReference,
|
38
38
|
} from '@finos/legend-graph';
|
39
39
|
import type { EditorStore } from '@finos/legend-studio';
|
40
|
-
import {
|
41
|
-
ClassEditorState,
|
42
|
-
EditorHotkey,
|
43
|
-
ElementEditorState,
|
44
|
-
} from '@finos/legend-studio';
|
40
|
+
import { ClassEditorState, ElementEditorState } from '@finos/legend-studio';
|
45
41
|
import type { ClassView } from '../../models/metamodels/pure/packageableElements/diagram/ClassView';
|
46
42
|
import type { Point } from '../../models/metamodels/pure/packageableElements/diagram/geometry/Point';
|
47
43
|
import { Diagram } from '../../models/metamodels/pure/packageableElements/diagram/Diagram';
|
@@ -441,7 +437,7 @@ export class DiagramEditorState extends ElementEditorState {
|
|
441
437
|
DIAGRAM_EDITOR_HOTKEY.EJECT_PROPERTY,
|
442
438
|
].forEach((key) => {
|
443
439
|
this.editorStore.addHotKey(
|
444
|
-
new
|
440
|
+
new HotkeyConfiguration(
|
445
441
|
key,
|
446
442
|
[DIAGRAM_EDITOR_HOTKEY_MAP[key]],
|
447
443
|
this.createDiagramHotKeyAction((event?: KeyboardEvent) => {
|
package/tsconfig.json
CHANGED
@@ -22,6 +22,7 @@
|
|
22
22
|
"allowSyntheticDefaultImports": true,
|
23
23
|
"strict": true,
|
24
24
|
"noImplicitOverride": true,
|
25
|
+
"noUncheckedIndexedAccess": true,
|
25
26
|
"exactOptionalPropertyTypes": true,
|
26
27
|
"forceConsistentCasingInFileNames": true,
|
27
28
|
"outDir": "./lib",
|
@@ -74,8 +75,8 @@
|
|
74
75
|
"./src/models/protocols/pure/v1/transformation/pureProtocol/V1_DSLDiagram_ProtocolHelper.ts",
|
75
76
|
"./src/stores/studio/DiagramEditorState.ts",
|
76
77
|
"./src/components/studio/ClassDiagramPreview.tsx",
|
77
|
-
"./src/components/studio/
|
78
|
-
"./src/components/studio/
|
78
|
+
"./src/components/studio/DSLDiagram_LegendStudioPlugin.tsx",
|
79
|
+
"./src/components/studio/DSLDiagram_LegendStudioPlugin_Extension.tsx",
|
79
80
|
"./src/components/studio/DiagramEditor.tsx"
|
80
81
|
],
|
81
82
|
"include": [
|
package/tsconfig.package.json
CHANGED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DSLDiagram_StudioPlugin.d.ts","sourceRoot":"","sources":["../../../src/components/studio/DSLDiagram_StudioPlugin.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAGH,OAAO,KAAK,EACV,mBAAmB,EACnB,0BAA0B,EAG1B,yBAAyB,EACzB,iBAAiB,EACjB,mCAAmC,EACnC,iBAAiB,EACjB,qBAAqB,EACrB,0BAA0B,EAE1B,6BAA6B,EAC7B,6BAA6B,EAC7B,oBAAoB,EACrB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAWpD,qBAAa,uBACX,SAAQ,YACR,YAAW,0BAA0B;;IAMrC,OAAO,CAAC,aAAa,EAAE,mBAAmB,GAAG,IAAI;IAIxC,6BAA6B,IAAI,oBAAoB,EAAE;IAQhE,6BAA6B,IAAI,MAAM,EAAE;IAIzC,0BAA0B,IAAI,iBAAiB,EAAE;IAWjD,0BAA0B,IAAI,iBAAiB,EAAE;IAejD,8BAA8B,IAAI,qBAAqB,EAAE;IAWzD,mCAAmC,IAAI,0BAA0B,EAAE;IAenE,kCAAkC,IAAI,yBAAyB,EAAE;IAcjE,4CAA4C,IAAI,mCAAmC,EAAE;IAWrF,iCAAiC,IAAI,MAAM,EAAE;IAI7C,sCAAsC,IAAI,6BAA6B,EAAE;IAWzE,sCAAsC,IAAI,6BAA6B,EAAE;CAU1E"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DSLDiagram_StudioPlugin.js","sourceRoot":"","sources":["../../../src/components/studio/DSLDiagram_StudioPlugin.tsx"],"names":[],"mappings":"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"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DSLDiagram_StudioPlugin_Extension.d.ts","sourceRoot":"","sources":["../../../src/components/studio/DSLDiagram_StudioPlugin_Extension.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;;AAEH,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oEAAoE,CAAC;AACpG,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAEjF,oBAAY,6CAA6C,GAAG;IAC1D,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,CACR,kBAAkB,EAAE,kBAAkB,EACtC,SAAS,EAAE,SAAS,GAAG,SAAS,KAC7B,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;CAClC,CAAC;AAEF,MAAM,WAAW,iCACf,SAAQ,0BAA0B;IAClC;;OAEG;IACH,sDAAsD,CAAC,IAAI,6CAA6C,EAAE,CAAC;CAC5G"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DSLDiagram_StudioPlugin_Extension.js","sourceRoot":"","sources":["../../../src/components/studio/DSLDiagram_StudioPlugin_Extension.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG"}
|