ngx-vflow 1.8.2 → 1.10.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.
Files changed (75) hide show
  1. package/esm2022/lib/vflow/components/connection/connection.component.mjs +33 -13
  2. package/esm2022/lib/vflow/components/edge/edge.component.mjs +3 -3
  3. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +12 -8
  4. package/esm2022/lib/vflow/interfaces/curve-factory.interface.mjs +2 -0
  5. package/esm2022/lib/vflow/interfaces/edge.interface.mjs +1 -1
  6. package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +12 -14
  7. package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +5 -5
  8. package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +7 -9
  9. package/esm2022/lib/vflow/models/edge.model.mjs +24 -8
  10. package/esm2022/lib/vflow/services/edge-rendering.service.mjs +3 -1
  11. package/esm2022/lib/vflow/services/flow-entities.service.mjs +3 -1
  12. package/esm2022/lib/vflow/services/node-rendering.service.mjs +5 -1
  13. package/esm2022/lib/vflow/utils/entities-per-frame.mjs +2 -0
  14. package/esm2022/public-api.mjs +15 -13
  15. package/esm2022/testing/component-mocks/custom-template-edge-mock.component.mjs +16 -0
  16. package/esm2022/testing/component-mocks/handle-mock.component.mjs +24 -0
  17. package/esm2022/{lib/vflow/testing-utils → testing}/component-mocks/minimap-mock.component.mjs +1 -1
  18. package/esm2022/testing/component-mocks/node-toolbar-mock.component.mjs +23 -0
  19. package/esm2022/testing/component-mocks/resizable-mock.component.mjs +25 -0
  20. package/esm2022/testing/component-mocks/vflow-mock.component.mjs +296 -0
  21. package/esm2022/testing/directive-mocks/connection-controller-mock.directive.mjs +27 -0
  22. package/esm2022/testing/directive-mocks/drag-handle-mock.directive.mjs +11 -0
  23. package/esm2022/{lib/vflow/testing-utils → testing}/directive-mocks/selectable-mock.directive.mjs +1 -1
  24. package/esm2022/{lib/vflow/testing-utils → testing}/directive-mocks/template-mock.directive.mjs +1 -1
  25. package/esm2022/testing/ngx-vflow-testing.mjs +5 -0
  26. package/esm2022/testing/provide-custom-node-mocks.mjs +59 -0
  27. package/esm2022/testing/public-api.mjs +13 -0
  28. package/esm2022/testing/types.mjs +2 -0
  29. package/esm2022/testing/vflow-mocks.mjs +28 -0
  30. package/fesm2022/ngx-vflow-testing.mjs +626 -0
  31. package/fesm2022/ngx-vflow-testing.mjs.map +1 -0
  32. package/fesm2022/ngx-vflow.mjs +94 -648
  33. package/fesm2022/ngx-vflow.mjs.map +1 -1
  34. package/lib/vflow/components/connection/connection.component.d.ts +4 -2
  35. package/lib/vflow/components/vflow/vflow.component.d.ts +4 -0
  36. package/lib/vflow/interfaces/curve-factory.interface.d.ts +44 -0
  37. package/lib/vflow/interfaces/edge.interface.d.ts +2 -1
  38. package/lib/vflow/math/edge-path/bezier-path.d.ts +2 -5
  39. package/lib/vflow/math/edge-path/smooth-step-path.d.ts +2 -3
  40. package/lib/vflow/math/edge-path/straigh-path.d.ts +2 -4
  41. package/lib/vflow/models/edge.model.d.ts +6 -4
  42. package/lib/vflow/services/edge-rendering.service.d.ts +1 -0
  43. package/lib/vflow/services/flow-entities.service.d.ts +3 -0
  44. package/lib/vflow/services/node-rendering.service.d.ts +3 -0
  45. package/lib/vflow/utils/entities-per-frame.d.ts +1 -0
  46. package/package.json +9 -3
  47. package/public-api.d.ts +13 -11
  48. package/testing/component-mocks/custom-template-edge-mock.component.d.ts +7 -0
  49. package/{lib/vflow/testing-utils → testing}/component-mocks/handle-mock.component.d.ts +2 -3
  50. package/{lib/vflow/testing-utils → testing}/component-mocks/minimap-mock.component.d.ts +1 -1
  51. package/{lib/vflow/testing-utils → testing}/component-mocks/node-toolbar-mock.component.d.ts +1 -2
  52. package/{lib/vflow/testing-utils → testing}/component-mocks/resizable-mock.component.d.ts +1 -1
  53. package/{lib/vflow/testing-utils → testing}/component-mocks/vflow-mock.component.d.ts +2 -14
  54. package/{lib/vflow/testing-utils → testing}/directive-mocks/connection-controller-mock.directive.d.ts +2 -3
  55. package/{lib/vflow/testing-utils → testing}/directive-mocks/drag-handle-mock.directive.d.ts +1 -1
  56. package/{lib/vflow/testing-utils → testing}/directive-mocks/selectable-mock.directive.d.ts +1 -1
  57. package/{lib/vflow/testing-utils → testing}/directive-mocks/template-mock.directive.d.ts +1 -1
  58. package/testing/index.d.ts +5 -0
  59. package/testing/public-api.d.ts +11 -0
  60. package/{lib/vflow/testing-utils → testing}/vflow-mocks.d.ts +2 -1
  61. package/esm2022/lib/vflow/interfaces/path-data.interface.mjs +0 -2
  62. package/esm2022/lib/vflow/testing-utils/component-mocks/handle-mock.component.mjs +0 -24
  63. package/esm2022/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.mjs +0 -23
  64. package/esm2022/lib/vflow/testing-utils/component-mocks/resizable-mock.component.mjs +0 -25
  65. package/esm2022/lib/vflow/testing-utils/component-mocks/vflow-mock.component.mjs +0 -296
  66. package/esm2022/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.mjs +0 -27
  67. package/esm2022/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.mjs +0 -11
  68. package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +0 -68
  69. package/esm2022/lib/vflow/testing-utils/types.mjs +0 -2
  70. package/esm2022/lib/vflow/testing-utils/vflow-mocks.mjs +0 -26
  71. package/esm2022/lib/vflow/types/using-points.type.mjs +0 -2
  72. package/lib/vflow/interfaces/path-data.interface.d.ts +0 -8
  73. package/lib/vflow/types/using-points.type.d.ts +0 -5
  74. /package/{lib/vflow/testing-utils → testing}/provide-custom-node-mocks.d.ts +0 -0
  75. /package/{lib/vflow/testing-utils → testing}/types.d.ts +0 -0
@@ -1,296 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, contentChild, Input, input, output, signal, } from '@angular/core';
2
- import { NgTemplateOutlet } from '@angular/common';
3
- import { toObservable } from '@angular/core/rxjs-interop';
4
- import { ConnectionTemplateMockDirective, EdgeLabelHtmlTemplateMockDirective, EdgeTemplateMockDirective, GroupNodeTemplateMockDirective, NodeHtmlTemplateMockDirective, } from '../directive-mocks/template-mock.directive';
5
- import { ConnectionModel } from '../../models/connection.model';
6
- import * as i0 from "@angular/core";
7
- export class VflowMockComponent {
8
- constructor() {
9
- this.view = [400, 400];
10
- this.minZoom = 0.5;
11
- this.maxZoom = 3;
12
- this.background = '#fff';
13
- this.optimization = input({
14
- detachedGroupsLayer: false,
15
- });
16
- this.entitiesSelectable = true;
17
- this.keyboardShortcuts = {
18
- multiSelection: null,
19
- };
20
- this.connection = new ConnectionModel({});
21
- // eslint-disable-next-line @angular-eslint/no-output-on-prefix
22
- this.onComponentNodeEvent = output();
23
- this.nodeTemplateDirective = contentChild(NodeHtmlTemplateMockDirective);
24
- this.groupNodeTemplateDirective = contentChild(GroupNodeTemplateMockDirective);
25
- this.edgeTemplateDirective = contentChild(EdgeTemplateMockDirective);
26
- this.edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateMockDirective);
27
- this.connectionTemplateDirective = contentChild(ConnectionTemplateMockDirective);
28
- this.viewport = signal({
29
- x: 0,
30
- y: 0,
31
- zoom: 1,
32
- });
33
- this.nodesChange = signal([]);
34
- this.edgesChange = signal([]);
35
- this.viewportChange$ = toObservable(this.viewport);
36
- this.nodesChange$ = toObservable(this.nodesChange);
37
- this.edgesChange$ = toObservable(this.edgesChange);
38
- }
39
- // eslint-disable-next-line @angular-eslint/no-empty-lifecycle-method
40
- ngOnInit() { }
41
- viewportTo(viewport) {
42
- this.viewport.set(viewport);
43
- }
44
- zoomTo(zoom) {
45
- this.viewport.update((prev) => ({ ...prev, zoom }));
46
- }
47
- panTo(point) {
48
- this.viewport.update((prev) => ({ ...prev, x: point.x, y: point.y }));
49
- }
50
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
51
- fitView(options) { }
52
- documentPointToFlowPoint(point, options) {
53
- if (options?.spaces) {
54
- return [
55
- {
56
- nodeId: null,
57
- x: point.x,
58
- y: point.y,
59
- },
60
- ];
61
- }
62
- return point;
63
- }
64
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
65
- getIntesectingNodes(nodeId, options) {
66
- return [];
67
- }
68
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
69
- toNodeSpace(nodeId, spaceNodeId) {
70
- return { x: 0, y: 0 };
71
- }
72
- getNode(id) {
73
- return this.nodes.find((node) => node.id === id);
74
- }
75
- getDetachedEdges() {
76
- return [];
77
- }
78
- createSignal(value) {
79
- return signal(value);
80
- }
81
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowMockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
82
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: VflowMockComponent, isStandalone: true, selector: "vflow", inputs: { nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: false, isRequired: true, transformFunction: null }, edges: { classPropertyName: "edges", publicName: "edges", isSignal: false, isRequired: false, transformFunction: null }, view: { classPropertyName: "view", publicName: "view", isSignal: false, isRequired: false, transformFunction: null }, minZoom: { classPropertyName: "minZoom", publicName: "minZoom", isSignal: false, isRequired: false, transformFunction: null }, maxZoom: { classPropertyName: "maxZoom", publicName: "maxZoom", isSignal: false, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: false, isRequired: false, transformFunction: null }, optimization: { classPropertyName: "optimization", publicName: "optimization", isSignal: true, isRequired: false, transformFunction: null }, entitiesSelectable: { classPropertyName: "entitiesSelectable", publicName: "entitiesSelectable", isSignal: false, isRequired: false, transformFunction: null }, keyboardShortcuts: { classPropertyName: "keyboardShortcuts", publicName: "keyboardShortcuts", isSignal: false, isRequired: false, transformFunction: null }, connection: { classPropertyName: "connection", publicName: "connection", isSignal: false, isRequired: false, transformFunction: (settings) => new ConnectionModel(settings) }, snapGrid: { classPropertyName: "snapGrid", publicName: "snapGrid", isSignal: false, isRequired: false, transformFunction: null }, elevateNodesOnSelect: { classPropertyName: "elevateNodesOnSelect", publicName: "elevateNodesOnSelect", isSignal: false, isRequired: false, transformFunction: null }, elevateEdgesOnSelect: { classPropertyName: "elevateEdgesOnSelect", publicName: "elevateEdgesOnSelect", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onComponentNodeEvent: "onComponentNodeEvent" }, queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateMockDirective, descendants: true, isSignal: true }, { propertyName: "groupNodeTemplateDirective", first: true, predicate: GroupNodeTemplateMockDirective, descendants: true, isSignal: true }, { propertyName: "edgeTemplateDirective", first: true, predicate: EdgeTemplateMockDirective, descendants: true, isSignal: true }, { propertyName: "edgeLabelHtmlDirective", first: true, predicate: EdgeLabelHtmlTemplateMockDirective, descendants: true, isSignal: true }, { propertyName: "connectionTemplateDirective", first: true, predicate: ConnectionTemplateMockDirective, descendants: true, isSignal: true }], ngImport: i0, template: `
83
- <ng-content />
84
-
85
- @for (node of nodes; track $index) {
86
- @if (node.type === 'html-template') {
87
- <ng-component
88
- [ngTemplateOutlet]="nodeTemplateDirective()?.templateRef ?? null"
89
- [ngTemplateOutletContext]="{
90
- $implicit: {
91
- node: node,
92
- selected: createSignal(false),
93
- },
94
- }" />
95
- }
96
-
97
- @if (node.type === 'template-group') {
98
- <ng-component
99
- [ngTemplateOutlet]="groupNodeTemplateDirective()?.templateRef ?? null"
100
- [ngTemplateOutletContext]="{
101
- $implicit: {
102
- node: node,
103
- selected: createSignal(false),
104
- width: createSignal(node.width),
105
- height: createSignal(node.height),
106
- },
107
- }" />
108
- }
109
- }
110
-
111
- @for (edge of edges; track $index) {
112
- @if (edge.type === 'template') {
113
- <ng-component
114
- [ngTemplateOutlet]="edgeTemplateDirective()?.templateRef ?? null"
115
- [ngTemplateOutletContext]="{
116
- $implicit: {
117
- edge: edge,
118
- selected: createSignal(false),
119
- path: createSignal(''),
120
- markerStart: createSignal(''),
121
- markerEnd: createSignal(''),
122
- },
123
- }" />
124
-
125
- @if (edge.edgeLabels?.start) {
126
- <ng-component
127
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
128
- [ngTemplateOutletContext]="{
129
- $implicit: {
130
- edge: edge,
131
- },
132
- }" />
133
- }
134
-
135
- @if (edge.edgeLabels?.center) {
136
- <ng-component
137
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
138
- [ngTemplateOutletContext]="{
139
- $implicit: {
140
- edge: edge,
141
- label: edge.edgeLabels?.center,
142
- },
143
- }" />
144
- }
145
-
146
- @if (edge.edgeLabels?.end) {
147
- <ng-component
148
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
149
- [ngTemplateOutletContext]="{
150
- $implicit: {
151
- edge: edge,
152
- label: edge.edgeLabels?.end,
153
- },
154
- }" />
155
- }
156
- }
157
- }
158
-
159
- @if (connection.type === 'template') {
160
- <ng-component
161
- [ngTemplateOutlet]="connectionTemplateDirective()?.templateRef ?? null"
162
- [ngTemplateOutletContext]="{
163
- $implicit: {
164
- path: createSignal(''),
165
- marker: createSignal(''),
166
- },
167
- }" />
168
- }
169
- `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
170
- }
171
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowMockComponent, decorators: [{
172
- type: Component,
173
- args: [{
174
- selector: 'vflow',
175
- template: `
176
- <ng-content />
177
-
178
- @for (node of nodes; track $index) {
179
- @if (node.type === 'html-template') {
180
- <ng-component
181
- [ngTemplateOutlet]="nodeTemplateDirective()?.templateRef ?? null"
182
- [ngTemplateOutletContext]="{
183
- $implicit: {
184
- node: node,
185
- selected: createSignal(false),
186
- },
187
- }" />
188
- }
189
-
190
- @if (node.type === 'template-group') {
191
- <ng-component
192
- [ngTemplateOutlet]="groupNodeTemplateDirective()?.templateRef ?? null"
193
- [ngTemplateOutletContext]="{
194
- $implicit: {
195
- node: node,
196
- selected: createSignal(false),
197
- width: createSignal(node.width),
198
- height: createSignal(node.height),
199
- },
200
- }" />
201
- }
202
- }
203
-
204
- @for (edge of edges; track $index) {
205
- @if (edge.type === 'template') {
206
- <ng-component
207
- [ngTemplateOutlet]="edgeTemplateDirective()?.templateRef ?? null"
208
- [ngTemplateOutletContext]="{
209
- $implicit: {
210
- edge: edge,
211
- selected: createSignal(false),
212
- path: createSignal(''),
213
- markerStart: createSignal(''),
214
- markerEnd: createSignal(''),
215
- },
216
- }" />
217
-
218
- @if (edge.edgeLabels?.start) {
219
- <ng-component
220
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
221
- [ngTemplateOutletContext]="{
222
- $implicit: {
223
- edge: edge,
224
- },
225
- }" />
226
- }
227
-
228
- @if (edge.edgeLabels?.center) {
229
- <ng-component
230
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
231
- [ngTemplateOutletContext]="{
232
- $implicit: {
233
- edge: edge,
234
- label: edge.edgeLabels?.center,
235
- },
236
- }" />
237
- }
238
-
239
- @if (edge.edgeLabels?.end) {
240
- <ng-component
241
- [ngTemplateOutlet]="edgeLabelHtmlDirective()?.templateRef ?? null"
242
- [ngTemplateOutletContext]="{
243
- $implicit: {
244
- edge: edge,
245
- label: edge.edgeLabels?.end,
246
- },
247
- }" />
248
- }
249
- }
250
- }
251
-
252
- @if (connection.type === 'template') {
253
- <ng-component
254
- [ngTemplateOutlet]="connectionTemplateDirective()?.templateRef ?? null"
255
- [ngTemplateOutletContext]="{
256
- $implicit: {
257
- path: createSignal(''),
258
- marker: createSignal(''),
259
- },
260
- }" />
261
- }
262
- `,
263
- changeDetection: ChangeDetectionStrategy.OnPush,
264
- standalone: true,
265
- imports: [NgTemplateOutlet],
266
- }]
267
- }], propDecorators: { nodes: [{
268
- type: Input,
269
- args: [{ required: true }]
270
- }], edges: [{
271
- type: Input
272
- }], view: [{
273
- type: Input
274
- }], minZoom: [{
275
- type: Input
276
- }], maxZoom: [{
277
- type: Input
278
- }], background: [{
279
- type: Input
280
- }], entitiesSelectable: [{
281
- type: Input
282
- }], keyboardShortcuts: [{
283
- type: Input
284
- }], connection: [{
285
- type: Input,
286
- args: [{
287
- transform: (settings) => new ConnectionModel(settings),
288
- }]
289
- }], snapGrid: [{
290
- type: Input
291
- }], elevateNodesOnSelect: [{
292
- type: Input
293
- }], elevateEdgesOnSelect: [{
294
- type: Input
295
- }] } });
296
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vflow-mock.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/testing-utils/component-mocks/vflow-mock.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,KAAK,EACL,MAAM,EACN,MAAM,GAGP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAWnD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,OAAO,EACL,+BAA+B,EAC/B,kCAAkC,EAClC,yBAAyB,EACzB,8BAA8B,EAC9B,6BAA6B,GAC9B,MAAM,4CAA4C,CAAC;AAEpD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;;AAkGhE,MAAM,OAAO,kBAAkB;IA9F/B;QAsGkB,SAAI,GAA8B,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAG7C,YAAO,GAAG,GAAG,CAAC;QAGd,YAAO,GAAG,CAAC,CAAC;QAGZ,eAAU,GAAwB,MAAM,CAAC;QAEzC,iBAAY,GAAG,KAAK,CAAe;YACjD,mBAAmB,EAAE,KAAK;SAC3B,CAAC,CAAC;QAGa,uBAAkB,GAAG,IAAI,CAAC;QAG1B,sBAAiB,GAAsB;YACrD,cAAc,EAAE,IAAI;SACrB,CAAC;QAKc,eAAU,GAAoB,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QAWtE,+DAA+D;QAC/C,yBAAoB,GAAG,MAAM,EAAO,CAAC;QAE3C,0BAAqB,GAAG,YAAY,CAAC,6BAA6B,CAAC,CAAC;QAEpE,+BAA0B,GAAG,YAAY,CAAC,8BAA8B,CAAC,CAAC;QAE1E,0BAAqB,GAAG,YAAY,CAAC,yBAAyB,CAAC,CAAC;QAEhE,2BAAsB,GAAG,YAAY,CAAC,kCAAkC,CAAC,CAAC;QAE1E,gCAA2B,GAAG,YAAY,CAAC,+BAA+B,CAAC,CAAC;QAE/E,aAAQ,GAAG,MAAM,CAAgB;YACtC,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,IAAI,EAAE,CAAC;SACR,CAAC,CAAC;QAEI,gBAAW,GAAG,MAAM,CAAe,EAAE,CAAC,CAAC;QACvC,gBAAW,GAAG,MAAM,CAAe,EAAE,CAAC,CAAC;QAEvC,oBAAe,GAAG,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE9C,iBAAY,GAAG,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC9C,iBAAY,GAAG,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;KAyDtD;IAvDC,qEAAqE;IAC9D,QAAQ,KAAI,CAAC;IAEb,UAAU,CAAC,QAAuB;QACvC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC;IAEM,MAAM,CAAC,IAAY;QACxB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IACtD,CAAC;IAEM,KAAK,CAAC,KAAY;QACvB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,6DAA6D;IACtD,OAAO,CAAC,OAAwB,IAAS,CAAC;IAI1C,wBAAwB,CAAC,KAAY,EAAE,OAA6B;QACzE,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,OAAO;gBACL;oBACE,MAAM,EAAE,IAAI;oBACZ,CAAC,EAAE,KAAK,CAAC,CAAC;oBACV,CAAC,EAAE,KAAK,CAAC,CAAC;iBACX;aACF,CAAC;QACJ,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,6DAA6D;IACtD,mBAAmB,CAAC,MAAc,EAAE,OAAkC;QAC3E,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,6DAA6D;IACtD,WAAW,CAAC,MAAc,EAAE,WAAmB;QACpD,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IACxB,CAAC;IAEM,OAAO,CAAc,EAAU;QACpC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IACnD,CAAC;IAEM,gBAAgB;QACrB,OAAO,EAAE,CAAC;IACZ,CAAC;IAES,YAAY,CAAI,KAAQ;QAChC,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;+GA9HU,kBAAkB;mGAAlB,kBAAkB,02CAgChB,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC,0lBAgB7B,6BAA6B,6GAExB,8BAA8B,wGAEnC,yBAAyB,yGAExB,kCAAkC,8GAE7B,+BAA+B,gEApJ1E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuFT,4DAGS,gBAAgB;;4FAEf,kBAAkB;kBA9F9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuFT;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,gBAAgB,CAAC;iBAC5B;8BAGiB,KAAK;sBADpB,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAIT,KAAK;sBADpB,KAAK;gBAIU,IAAI;sBADnB,KAAK;gBAIU,OAAO;sBADtB,KAAK;gBAIU,OAAO;sBADtB,KAAK;gBAIU,UAAU;sBADzB,KAAK;gBAQU,kBAAkB;sBADjC,KAAK;gBAIU,iBAAiB;sBADhC,KAAK;gBAQU,UAAU;sBAHzB,KAAK;uBAAC;wBACL,SAAS,EAAE,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC;qBAC3E;gBAIe,QAAQ;sBADvB,KAAK;gBAIC,oBAAoB;sBAD1B,KAAK;gBAIC,oBAAoB;sBAD1B,KAAK","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  contentChild,\n  Input,\n  input,\n  output,\n  signal,\n  WritableSignal,\n  OnInit,\n} from '@angular/core';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { Node, DynamicNode } from '../../interfaces/node.interface';\nimport { Edge } from '../../interfaces/edge.interface';\nimport { SpacePoint, Point } from '../../interfaces/point.interface';\nimport { Background } from '../../types/background.type';\nimport { Optimization } from '../../interfaces/optimization.interface';\nimport { KeyboardShortcuts } from '../../types/keyboard-action.type';\nimport { ConnectionSettings } from '../../interfaces/connection-settings.interface';\nimport { ViewportState } from '../../interfaces/viewport.interface';\nimport { NodeChange } from '../../types/node-change.type';\nimport { EdgeChange } from '../../types/edge-change.type';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { FitViewOptions } from '../../interfaces/fit-view-options.interface';\nimport {\n  ConnectionTemplateMockDirective,\n  EdgeLabelHtmlTemplateMockDirective,\n  EdgeTemplateMockDirective,\n  GroupNodeTemplateMockDirective,\n  NodeHtmlTemplateMockDirective,\n} from '../directive-mocks/template-mock.directive';\nimport { VflowComponent } from '../../components/vflow/vflow.component';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { AsInterface } from '../types';\nimport { IntersectingNodesOptions } from '../../interfaces/intersecting-nodes-options.interface';\n\n@Component({\n  selector: 'vflow',\n  template: `\n    <ng-content />\n\n    @for (node of nodes; track $index) {\n      @if (node.type === 'html-template') {\n        <ng-component\n          [ngTemplateOutlet]=\"nodeTemplateDirective()?.templateRef ?? null\"\n          [ngTemplateOutletContext]=\"{\n            $implicit: {\n              node: node,\n              selected: createSignal(false),\n            },\n          }\" />\n      }\n\n      @if (node.type === 'template-group') {\n        <ng-component\n          [ngTemplateOutlet]=\"groupNodeTemplateDirective()?.templateRef ?? null\"\n          [ngTemplateOutletContext]=\"{\n            $implicit: {\n              node: node,\n              selected: createSignal(false),\n              width: createSignal(node.width),\n              height: createSignal(node.height),\n            },\n          }\" />\n      }\n    }\n\n    @for (edge of edges; track $index) {\n      @if (edge.type === 'template') {\n        <ng-component\n          [ngTemplateOutlet]=\"edgeTemplateDirective()?.templateRef ?? null\"\n          [ngTemplateOutletContext]=\"{\n            $implicit: {\n              edge: edge,\n              selected: createSignal(false),\n              path: createSignal(''),\n              markerStart: createSignal(''),\n              markerEnd: createSignal(''),\n            },\n          }\" />\n\n        @if (edge.edgeLabels?.start) {\n          <ng-component\n            [ngTemplateOutlet]=\"edgeLabelHtmlDirective()?.templateRef ?? null\"\n            [ngTemplateOutletContext]=\"{\n              $implicit: {\n                edge: edge,\n              },\n            }\" />\n        }\n\n        @if (edge.edgeLabels?.center) {\n          <ng-component\n            [ngTemplateOutlet]=\"edgeLabelHtmlDirective()?.templateRef ?? null\"\n            [ngTemplateOutletContext]=\"{\n              $implicit: {\n                edge: edge,\n                label: edge.edgeLabels?.center,\n              },\n            }\" />\n        }\n\n        @if (edge.edgeLabels?.end) {\n          <ng-component\n            [ngTemplateOutlet]=\"edgeLabelHtmlDirective()?.templateRef ?? null\"\n            [ngTemplateOutletContext]=\"{\n              $implicit: {\n                edge: edge,\n                label: edge.edgeLabels?.end,\n              },\n            }\" />\n        }\n      }\n    }\n\n    @if (connection.type === 'template') {\n      <ng-component\n        [ngTemplateOutlet]=\"connectionTemplateDirective()?.templateRef ?? null\"\n        [ngTemplateOutletContext]=\"{\n          $implicit: {\n            path: createSignal(''),\n            marker: createSignal(''),\n          },\n        }\" />\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgTemplateOutlet],\n})\nexport class VflowMockComponent implements AsInterface<VflowComponent>, OnInit {\n  @Input({ required: true })\n  public readonly nodes!: Node[] | DynamicNode[];\n\n  @Input()\n  public readonly edges!: Edge[];\n\n  @Input()\n  public readonly view: [number, number] | 'auto' = [400, 400];\n\n  @Input()\n  public readonly minZoom = 0.5;\n\n  @Input()\n  public readonly maxZoom = 3;\n\n  @Input()\n  public readonly background: Background | string = '#fff';\n\n  public readonly optimization = input<Optimization>({\n    detachedGroupsLayer: false,\n  });\n\n  @Input()\n  public readonly entitiesSelectable = true;\n\n  @Input()\n  public readonly keyboardShortcuts: KeyboardShortcuts = {\n    multiSelection: null,\n  };\n\n  @Input({\n    transform: (settings: ConnectionSettings) => new ConnectionModel(settings),\n  })\n  public readonly connection: ConnectionModel = new ConnectionModel({});\n\n  @Input()\n  public readonly snapGrid!: [number, number];\n\n  @Input()\n  public elevateNodesOnSelect!: boolean;\n\n  @Input()\n  public elevateEdgesOnSelect!: boolean;\n\n  // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n  public readonly onComponentNodeEvent = output<any>();\n\n  protected nodeTemplateDirective = contentChild(NodeHtmlTemplateMockDirective);\n\n  protected groupNodeTemplateDirective = contentChild(GroupNodeTemplateMockDirective);\n\n  protected edgeTemplateDirective = contentChild(EdgeTemplateMockDirective);\n\n  protected edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateMockDirective);\n\n  protected connectionTemplateDirective = contentChild(ConnectionTemplateMockDirective);\n\n  public viewport = signal<ViewportState>({\n    x: 0,\n    y: 0,\n    zoom: 1,\n  });\n\n  public nodesChange = signal<NodeChange[]>([]);\n  public edgesChange = signal<EdgeChange[]>([]);\n\n  public viewportChange$ = toObservable(this.viewport);\n\n  public nodesChange$ = toObservable(this.nodesChange);\n  public edgesChange$ = toObservable(this.edgesChange);\n\n  // eslint-disable-next-line @angular-eslint/no-empty-lifecycle-method\n  public ngOnInit() {}\n\n  public viewportTo(viewport: ViewportState): void {\n    this.viewport.set(viewport);\n  }\n\n  public zoomTo(zoom: number): void {\n    this.viewport.update((prev) => ({ ...prev, zoom }));\n  }\n\n  public panTo(point: Point): void {\n    this.viewport.update((prev) => ({ ...prev, x: point.x, y: point.y }));\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  public fitView(options?: FitViewOptions): void {}\n\n  public documentPointToFlowPoint(point: Point, options?: { spaces: false }): Point;\n  public documentPointToFlowPoint(point: Point, options: { spaces: true }): SpacePoint[];\n  public documentPointToFlowPoint(point: Point, options?: { spaces: boolean }): unknown {\n    if (options?.spaces) {\n      return [\n        {\n          nodeId: null,\n          x: point.x,\n          y: point.y,\n        },\n      ];\n    }\n\n    return point;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  public getIntesectingNodes(nodeId: string, options?: IntersectingNodesOptions): Node[] | DynamicNode[] {\n    return [];\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  public toNodeSpace(nodeId: string, spaceNodeId: string): Point {\n    return { x: 0, y: 0 };\n  }\n\n  public getNode<T = unknown>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.nodes.find((node) => node.id === id);\n  }\n\n  public getDetachedEdges(): Edge[] {\n    return [];\n  }\n\n  protected createSignal<T>(value: T): WritableSignal<T> {\n    return signal(value);\n  }\n}\n"]}
@@ -1,27 +0,0 @@
1
- import { Directive, output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class ConnectionControllerMockDirective {
4
- constructor() {
5
- // eslint-disable-next-line @angular-eslint/no-output-on-prefix
6
- this.onConnect = output();
7
- // eslint-disable-next-line @angular-eslint/no-output-on-prefix
8
- this.onReconnect = output();
9
- }
10
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
11
- startConnection(handle) { }
12
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
13
- startReconnection(handle) { }
14
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
15
- validateConnection(handle) { }
16
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
17
- resetValidateConnection(targetHandle) { }
18
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
19
- endConnection() { }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerMockDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
21
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ConnectionControllerMockDirective, isStandalone: true, selector: "[onConnect]", outputs: { onConnect: "onConnect", onReconnect: "onReconnect" }, ngImport: i0 }); }
22
- }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerMockDirective, decorators: [{
24
- type: Directive,
25
- args: [{ selector: '[onConnect]', standalone: true }]
26
- }] });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGlvbi1jb250cm9sbGVyLW1vY2suZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3Rlc3RpbmctdXRpbHMvZGlyZWN0aXZlLW1vY2tzL2Nvbm5lY3Rpb24tY29udHJvbGxlci1tb2NrLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPbEQsTUFBTSxPQUFPLGlDQUFpQztJQUQ5QztRQUVFLCtEQUErRDtRQUMvQyxjQUFTLEdBQUcsTUFBTSxFQUFjLENBQUM7UUFFakQsK0RBQStEO1FBQy9DLGdCQUFXLEdBQUcsTUFBTSxFQUFxQixDQUFDO0tBZ0IzRDtJQWRDLDZEQUE2RDtJQUN0RCxlQUFlLENBQUMsTUFBbUIsSUFBUyxDQUFDO0lBRXBELDZEQUE2RDtJQUN0RCxpQkFBaUIsQ0FBQyxNQUFtQixJQUFTLENBQUM7SUFFdEQsNkRBQTZEO0lBQ3RELGtCQUFrQixDQUFDLE1BQW1CLElBQVMsQ0FBQztJQUV2RCw2REFBNkQ7SUFDdEQsdUJBQXVCLENBQUMsWUFBeUIsSUFBUyxDQUFDO0lBRWxFLDZEQUE2RDtJQUN0RCxhQUFhLEtBQVUsQ0FBQzsrR0FwQnBCLGlDQUFpQzttR0FBakMsaUNBQWlDOzs0RkFBakMsaUNBQWlDO2tCQUQ3QyxTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbm5lY3Rpb24sIFJlY29ubmVjdGlvbkV2ZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9jb25uZWN0aW9uLmludGVyZmFjZSc7XG5pbXBvcnQgeyBBc0ludGVyZmFjZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IENvbm5lY3Rpb25Db250cm9sbGVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9jb25uZWN0aW9uLWNvbnRyb2xsZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7IEhhbmRsZU1vZGVsIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2hhbmRsZS5tb2RlbCc7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1tvbkNvbm5lY3RdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIENvbm5lY3Rpb25Db250cm9sbGVyTW9ja0RpcmVjdGl2ZSBpbXBsZW1lbnRzIEFzSW50ZXJmYWNlPENvbm5lY3Rpb25Db250cm9sbGVyRGlyZWN0aXZlPiB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvbm8tb3V0cHV0LW9uLXByZWZpeFxuICBwdWJsaWMgcmVhZG9ubHkgb25Db25uZWN0ID0gb3V0cHV0PENvbm5lY3Rpb24+KCk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9uby1vdXRwdXQtb24tcHJlZml4XG4gIHB1YmxpYyByZWFkb25seSBvblJlY29ubmVjdCA9IG91dHB1dDxSZWNvbm5lY3Rpb25FdmVudD4oKTtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gIHB1YmxpYyBzdGFydENvbm5lY3Rpb24oaGFuZGxlOiBIYW5kbGVNb2RlbCk6IHZvaWQge31cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gIHB1YmxpYyBzdGFydFJlY29ubmVjdGlvbihoYW5kbGU6IEhhbmRsZU1vZGVsKTogdm9pZCB7fVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgcHVibGljIHZhbGlkYXRlQ29ubmVjdGlvbihoYW5kbGU6IEhhbmRsZU1vZGVsKTogdm9pZCB7fVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgcHVibGljIHJlc2V0VmFsaWRhdGVDb25uZWN0aW9uKHRhcmdldEhhbmRsZTogSGFuZGxlTW9kZWwpOiB2b2lkIHt9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnVzZWQtdmFyc1xuICBwdWJsaWMgZW5kQ29ubmVjdGlvbigpOiB2b2lkIHt9XG59XG4iXX0=
@@ -1,11 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class DragHandleMockDirective {
4
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleMockDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
5
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: DragHandleMockDirective, isStandalone: true, selector: "[dragHandle]", ngImport: i0 }); }
6
- }
7
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleMockDirective, decorators: [{
8
- type: Directive,
9
- args: [{ selector: '[dragHandle]', standalone: true }]
10
- }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUtbW9jay5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvdGVzdGluZy11dGlscy9kaXJlY3RpdmUtbW9ja3MvZHJhZy1oYW5kbGUtbW9jay5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLMUMsTUFBTSxPQUFPLHVCQUF1QjsrR0FBdkIsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBRG5DLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsY0FBYyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFzSW50ZXJmYWNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgRHJhZ0hhbmRsZURpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMvZHJhZy1oYW5kbGUuZGlyZWN0aXZlJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW2RyYWdIYW5kbGVdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVNb2NrRGlyZWN0aXZlIGltcGxlbWVudHMgQXNJbnRlcmZhY2U8RHJhZ0hhbmRsZURpcmVjdGl2ZT4ge31cbiJdfQ==
@@ -1,68 +0,0 @@
1
- import { signal } from '@angular/core';
2
- import { ComponentEventBusService } from '../services/component-event-bus.service';
3
- import { HandleService } from '../services/handle.service';
4
- import { NodeModel } from '../models/node.model';
5
- import { FlowSettingsService } from '../services/flow-settings.service';
6
- import { FlowEntitiesService } from '../services/flow-entities.service';
7
- import { NodeAccessorService } from '../services/node-accessor.service';
8
- import { RootPointerDirective } from '../directives/root-pointer.directive';
9
- import { of } from 'rxjs';
10
- import { ViewportService } from '../services/viewport.service';
11
- import { SpacePointContextDirective } from '../directives/space-point-context.directive';
12
- import { SelectionService } from '../services/selection.service';
13
- const mockModel = () => new NodeModel({ id: 'mock', type: 'default', point: { x: 0, y: 0 } });
14
- export function provideCustomNodeMocks() {
15
- return [
16
- {
17
- provide: ComponentEventBusService,
18
- useValue: {
19
- pushEvent: () => { },
20
- },
21
- },
22
- {
23
- provide: NodeAccessorService,
24
- useFactory: () => ({
25
- model: signal(mockModel()),
26
- }),
27
- },
28
- FlowEntitiesService,
29
- // TODO: mocks below should be removed after the major release
30
- {
31
- provide: HandleService,
32
- useFactory: () => ({
33
- node: signal(mockModel()),
34
- createHandle: () => { },
35
- destroyHandle: () => { },
36
- }),
37
- },
38
- {
39
- provide: RootPointerDirective,
40
- useValue: {
41
- pointerMovement$: of({
42
- x: 0,
43
- y: 0,
44
- movementX: 0,
45
- movementY: 0,
46
- target: null,
47
- originalEvent: null,
48
- }),
49
- documentPointerEnd$: of(null),
50
- },
51
- },
52
- {
53
- provide: SpacePointContextDirective,
54
- useValue: {
55
- documentPointToFlowPoint: (point) => point,
56
- },
57
- },
58
- {
59
- provide: SelectionService,
60
- useValue: {
61
- select: () => { },
62
- },
63
- },
64
- FlowSettingsService,
65
- ViewportService,
66
- ];
67
- }
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1jdXN0b20tbm9kZS1tb2Nrcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy90ZXN0aW5nLXV0aWxzL3Byb3ZpZGUtY3VzdG9tLW5vZGUtbW9ja3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFZLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNuRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDMUIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRXpGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRWpFLE1BQU0sU0FBUyxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksU0FBUyxDQUFDLEVBQUUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztBQUU5RixNQUFNLFVBQVUsc0JBQXNCO0lBQ3BDLE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSx3QkFBd0I7WUFDakMsUUFBUSxFQUFFO2dCQUNSLFNBQVMsRUFBRSxHQUFHLEVBQUUsR0FBRSxDQUFDO2FBQ3BCO1NBQ0Y7UUFDRDtZQUNFLE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7Z0JBQ2pCLEtBQUssRUFBRSxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7YUFDM0IsQ0FBQztTQUNIO1FBQ0QsbUJBQW1CO1FBRW5CLDhEQUE4RDtRQUM5RDtZQUNFLE9BQU8sRUFBRSxhQUFhO1lBQ3RCLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO2dCQUNqQixJQUFJLEVBQUUsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUN6QixZQUFZLEVBQUUsR0FBRyxFQUFFLEdBQUUsQ0FBQztnQkFDdEIsYUFBYSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7YUFDeEIsQ0FBQztTQUNIO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsb0JBQW9CO1lBQzdCLFFBQVEsRUFBRTtnQkFDUixnQkFBZ0IsRUFBRSxFQUFFLENBQUM7b0JBQ25CLENBQUMsRUFBRSxDQUFDO29CQUNKLENBQUMsRUFBRSxDQUFDO29CQUNKLFNBQVMsRUFBRSxDQUFDO29CQUNaLFNBQVMsRUFBRSxDQUFDO29CQUNaLE1BQU0sRUFBRSxJQUFJO29CQUNaLGFBQWEsRUFBRSxJQUFJO2lCQUNwQixDQUFDO2dCQUNGLG1CQUFtQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUM7YUFDOUI7U0FDRjtRQUNEO1lBQ0UsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUU7Z0JBQ1Isd0JBQXdCLEVBQUUsQ0FBQyxLQUFZLEVBQUUsRUFBRSxDQUFDLEtBQUs7YUFDbEQ7U0FDRjtRQUNEO1lBQ0UsT0FBTyxFQUFFLGdCQUFnQjtZQUN6QixRQUFRLEVBQUU7Z0JBQ1IsTUFBTSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7YUFDakI7U0FDRjtRQUNELG1CQUFtQjtRQUNuQixlQUFlO0tBQ2hCLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvdmlkZXIsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50RXZlbnRCdXNTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvY29tcG9uZW50LWV2ZW50LWJ1cy5zZXJ2aWNlJztcbmltcG9ydCB7IEhhbmRsZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9oYW5kbGUuc2VydmljZSc7XG5pbXBvcnQgeyBOb2RlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvbm9kZS5tb2RlbCc7XG5pbXBvcnQgeyBGbG93U2V0dGluZ3NTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7IEZsb3dFbnRpdGllc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9mbG93LWVudGl0aWVzLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZUFjY2Vzc29yU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZSc7XG5pbXBvcnQgeyBSb290UG9pbnRlckRpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZXMvcm9vdC1wb2ludGVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBvZiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVmlld3BvcnRTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvdmlld3BvcnQuc2VydmljZSc7XG5pbXBvcnQgeyBTcGFjZVBvaW50Q29udGV4dERpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZXMvc3BhY2UtcG9pbnQtY29udGV4dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3BvaW50LmludGVyZmFjZSc7XG5pbXBvcnQgeyBTZWxlY3Rpb25TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvc2VsZWN0aW9uLnNlcnZpY2UnO1xuXG5jb25zdCBtb2NrTW9kZWwgPSAoKSA9PiBuZXcgTm9kZU1vZGVsKHsgaWQ6ICdtb2NrJywgdHlwZTogJ2RlZmF1bHQnLCBwb2ludDogeyB4OiAwLCB5OiAwIH0gfSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlQ3VzdG9tTm9kZU1vY2tzKCk6IFByb3ZpZGVyW10ge1xuICByZXR1cm4gW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IENvbXBvbmVudEV2ZW50QnVzU2VydmljZSxcbiAgICAgIHVzZVZhbHVlOiB7XG4gICAgICAgIHB1c2hFdmVudDogKCkgPT4ge30sXG4gICAgICB9LFxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogTm9kZUFjY2Vzc29yU2VydmljZSxcbiAgICAgIHVzZUZhY3Rvcnk6ICgpID0+ICh7XG4gICAgICAgIG1vZGVsOiBzaWduYWwobW9ja01vZGVsKCkpLFxuICAgICAgfSksXG4gICAgfSxcbiAgICBGbG93RW50aXRpZXNTZXJ2aWNlLFxuXG4gICAgLy8gVE9ETzogbW9ja3MgYmVsb3cgc2hvdWxkIGJlIHJlbW92ZWQgYWZ0ZXIgdGhlIG1ham9yIHJlbGVhc2VcbiAgICB7XG4gICAgICBwcm92aWRlOiBIYW5kbGVTZXJ2aWNlLFxuICAgICAgdXNlRmFjdG9yeTogKCkgPT4gKHtcbiAgICAgICAgbm9kZTogc2lnbmFsKG1vY2tNb2RlbCgpKSxcbiAgICAgICAgY3JlYXRlSGFuZGxlOiAoKSA9PiB7fSxcbiAgICAgICAgZGVzdHJveUhhbmRsZTogKCkgPT4ge30sXG4gICAgICB9KSxcbiAgICB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFJvb3RQb2ludGVyRGlyZWN0aXZlLFxuICAgICAgdXNlVmFsdWU6IHtcbiAgICAgICAgcG9pbnRlck1vdmVtZW50JDogb2Yoe1xuICAgICAgICAgIHg6IDAsXG4gICAgICAgICAgeTogMCxcbiAgICAgICAgICBtb3ZlbWVudFg6IDAsXG4gICAgICAgICAgbW92ZW1lbnRZOiAwLFxuICAgICAgICAgIHRhcmdldDogbnVsbCxcbiAgICAgICAgICBvcmlnaW5hbEV2ZW50OiBudWxsLFxuICAgICAgICB9KSxcbiAgICAgICAgZG9jdW1lbnRQb2ludGVyRW5kJDogb2YobnVsbCksXG4gICAgICB9LFxuICAgIH0sXG4gICAge1xuICAgICAgcHJvdmlkZTogU3BhY2VQb2ludENvbnRleHREaXJlY3RpdmUsXG4gICAgICB1c2VWYWx1ZToge1xuICAgICAgICBkb2N1bWVudFBvaW50VG9GbG93UG9pbnQ6IChwb2ludDogUG9pbnQpID0+IHBvaW50LFxuICAgICAgfSxcbiAgICB9LFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFNlbGVjdGlvblNlcnZpY2UsXG4gICAgICB1c2VWYWx1ZToge1xuICAgICAgICBzZWxlY3Q6ICgpID0+IHt9LFxuICAgICAgfSxcbiAgICB9LFxuICAgIEZsb3dTZXR0aW5nc1NlcnZpY2UsXG4gICAgVmlld3BvcnRTZXJ2aWNlLFxuICBdO1xufVxuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvdGVzdGluZy11dGlscy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQXNJbnRlcmZhY2U8VD4gPSBQaWNrPFQsIGtleW9mIFQ+O1xuIl19
@@ -1,26 +0,0 @@
1
- import { HandleMockComponent } from './component-mocks/handle-mock.component';
2
- import { MiniMapMockComponent } from './component-mocks/minimap-mock.component';
3
- import { NodeToolbarMockComponent } from './component-mocks/node-toolbar-mock.component';
4
- import { ResizableMockComponent } from './component-mocks/resizable-mock.component';
5
- import { VflowMockComponent } from './component-mocks/vflow-mock.component';
6
- import { ConnectionControllerMockDirective } from './directive-mocks/connection-controller-mock.directive';
7
- import { DragHandleMockDirective } from './directive-mocks/drag-handle-mock.directive';
8
- import { SelectableMockDirective } from './directive-mocks/selectable-mock.directive';
9
- import { ConnectionTemplateMockDirective, EdgeLabelHtmlTemplateMockDirective, EdgeTemplateMockDirective, GroupNodeTemplateMockDirective, HandleTemplateMockDirective, NodeHtmlTemplateMockDirective, } from './directive-mocks/template-mock.directive';
10
- export const VflowMocks = [
11
- VflowMockComponent,
12
- HandleMockComponent,
13
- ResizableMockComponent,
14
- SelectableMockDirective,
15
- MiniMapMockComponent,
16
- NodeToolbarMockComponent,
17
- DragHandleMockDirective,
18
- ConnectionControllerMockDirective,
19
- NodeHtmlTemplateMockDirective,
20
- GroupNodeTemplateMockDirective,
21
- EdgeLabelHtmlTemplateMockDirective,
22
- EdgeTemplateMockDirective,
23
- ConnectionTemplateMockDirective,
24
- HandleTemplateMockDirective,
25
- ];
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmZsb3ctbW9ja3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvdGVzdGluZy11dGlscy92Zmxvdy1tb2Nrcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNoRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUN6RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNwRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUMzRyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUN2RixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQ0wsK0JBQStCLEVBQy9CLGtDQUFrQyxFQUNsQyx5QkFBeUIsRUFDekIsOEJBQThCLEVBQzlCLDJCQUEyQixFQUMzQiw2QkFBNkIsR0FDOUIsTUFBTSwyQ0FBMkMsQ0FBQztBQUVuRCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsa0JBQWtCO0lBQ2xCLG1CQUFtQjtJQUNuQixzQkFBc0I7SUFDdEIsdUJBQXVCO0lBQ3ZCLG9CQUFvQjtJQUNwQix3QkFBd0I7SUFDeEIsdUJBQXVCO0lBQ3ZCLGlDQUFpQztJQUVqQyw2QkFBNkI7SUFDN0IsOEJBQThCO0lBQzlCLGtDQUFrQztJQUNsQyx5QkFBeUI7SUFDekIsK0JBQStCO0lBQy9CLDJCQUEyQjtDQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSGFuZGxlTW9ja0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50LW1vY2tzL2hhbmRsZS1tb2NrLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNaW5pTWFwTW9ja0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50LW1vY2tzL21pbmltYXAtbW9jay5jb21wb25lbnQnO1xuaW1wb3J0IHsgTm9kZVRvb2xiYXJNb2NrQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQtbW9ja3Mvbm9kZS10b29sYmFyLW1vY2suY29tcG9uZW50JztcbmltcG9ydCB7IFJlc2l6YWJsZU1vY2tDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC1tb2Nrcy9yZXNpemFibGUtbW9jay5jb21wb25lbnQnO1xuaW1wb3J0IHsgVmZsb3dNb2NrQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQtbW9ja3MvdmZsb3ctbW9jay5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29ubmVjdGlvbkNvbnRyb2xsZXJNb2NrRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmUtbW9ja3MvY29ubmVjdGlvbi1jb250cm9sbGVyLW1vY2suZGlyZWN0aXZlJztcbmltcG9ydCB7IERyYWdIYW5kbGVNb2NrRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmUtbW9ja3MvZHJhZy1oYW5kbGUtbW9jay5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgU2VsZWN0YWJsZU1vY2tEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZS1tb2Nrcy9zZWxlY3RhYmxlLW1vY2suZGlyZWN0aXZlJztcbmltcG9ydCB7XG4gIENvbm5lY3Rpb25UZW1wbGF0ZU1vY2tEaXJlY3RpdmUsXG4gIEVkZ2VMYWJlbEh0bWxUZW1wbGF0ZU1vY2tEaXJlY3RpdmUsXG4gIEVkZ2VUZW1wbGF0ZU1vY2tEaXJlY3RpdmUsXG4gIEdyb3VwTm9kZVRlbXBsYXRlTW9ja0RpcmVjdGl2ZSxcbiAgSGFuZGxlVGVtcGxhdGVNb2NrRGlyZWN0aXZlLFxuICBOb2RlSHRtbFRlbXBsYXRlTW9ja0RpcmVjdGl2ZSxcbn0gZnJvbSAnLi9kaXJlY3RpdmUtbW9ja3MvdGVtcGxhdGUtbW9jay5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgVmZsb3dNb2NrcyA9IFtcbiAgVmZsb3dNb2NrQ29tcG9uZW50LFxuICBIYW5kbGVNb2NrQ29tcG9uZW50LFxuICBSZXNpemFibGVNb2NrQ29tcG9uZW50LFxuICBTZWxlY3RhYmxlTW9ja0RpcmVjdGl2ZSxcbiAgTWluaU1hcE1vY2tDb21wb25lbnQsXG4gIE5vZGVUb29sYmFyTW9ja0NvbXBvbmVudCxcbiAgRHJhZ0hhbmRsZU1vY2tEaXJlY3RpdmUsXG4gIENvbm5lY3Rpb25Db250cm9sbGVyTW9ja0RpcmVjdGl2ZSxcblxuICBOb2RlSHRtbFRlbXBsYXRlTW9ja0RpcmVjdGl2ZSxcbiAgR3JvdXBOb2RlVGVtcGxhdGVNb2NrRGlyZWN0aXZlLFxuICBFZGdlTGFiZWxIdG1sVGVtcGxhdGVNb2NrRGlyZWN0aXZlLFxuICBFZGdlVGVtcGxhdGVNb2NrRGlyZWN0aXZlLFxuICBDb25uZWN0aW9uVGVtcGxhdGVNb2NrRGlyZWN0aXZlLFxuICBIYW5kbGVUZW1wbGF0ZU1vY2tEaXJlY3RpdmUsXG5dIGFzIGNvbnN0O1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNpbmctcG9pbnRzLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvdHlwZXMvdXNpbmctcG9pbnRzLnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFVzaW5nUG9pbnRzID0gW1xuICBzdGFydDogYm9vbGVhbiwgLy8gaXMgdXNlIHN0YXJ0XG4gIGNlbnRlcjogYm9vbGVhbiwgLy8gaXMgdXNlIGNlbnRlclxuICBlbmQ6IGJvb2xlYW4sIC8vICBpcyB1c2UgZW5kXG5dO1xuIl19
@@ -1,8 +0,0 @@
1
- import { EdgeLabelPosition } from './edge-label.interface';
2
- import { Point } from './point.interface';
3
- export interface PathData {
4
- path: string;
5
- points: {
6
- [key in EdgeLabelPosition]: Point;
7
- };
8
- }
@@ -1,5 +0,0 @@
1
- export type UsingPoints = [
2
- start: boolean,
3
- center: boolean,
4
- end: boolean
5
- ];
File without changes