ngx-vflow 0.16.0 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -1
- package/esm2022/lib/vflow/components/background/background.component.mjs +6 -7
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +66 -53
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +32 -25
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +9 -11
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +9 -12
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +21 -24
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +26 -31
- package/esm2022/lib/vflow/components/node/node.component.mjs +54 -50
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +93 -91
- package/esm2022/lib/vflow/decorators/run-in-injection-context.decorator.mjs +1 -1
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +41 -125
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +16 -16
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +15 -12
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +18 -19
- package/esm2022/lib/vflow/directives/reference.directive.mjs +6 -5
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +10 -7
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/template.directive.mjs +43 -25
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +1 -1
- package/esm2022/lib/vflow/models/connection.model.mjs +1 -1
- package/esm2022/lib/vflow/models/edge.model.mjs +1 -1
- package/esm2022/lib/vflow/models/handle.model.mjs +2 -2
- package/esm2022/lib/vflow/models/node.model.mjs +4 -10
- package/esm2022/lib/vflow/models/toolbar.model.mjs +1 -1
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +16 -10
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +15 -10
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +52 -0
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +35 -44
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +24 -27
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +60 -45
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +3 -3
- package/esm2022/lib/vflow/services/draggable.service.mjs +4 -4
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +4 -4
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +4 -10
- package/esm2022/lib/vflow/services/flow-status.service.mjs +4 -4
- package/esm2022/lib/vflow/services/handle.service.mjs +4 -4
- package/esm2022/lib/vflow/services/keyboard.service.mjs +5 -5
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +3 -3
- package/esm2022/lib/vflow/services/overlays.service.mjs +3 -3
- package/esm2022/lib/vflow/services/selection.service.mjs +4 -4
- package/esm2022/lib/vflow/services/viewport.service.mjs +3 -3
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +1 -1
- package/esm2022/lib/vflow/utils/get-os.mjs +1 -1
- package/esm2022/lib/vflow/utils/nodes.mjs +1 -1
- package/esm2022/lib/vflow/vflow.mjs +24 -0
- package/esm2022/public-api.mjs +4 -5
- package/fesm2022/ngx-vflow.mjs +914 -1022
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/background/background.component.d.ts +3 -3
- package/lib/vflow/components/connection/connection.component.d.ts +3 -3
- package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +4 -9
- package/lib/vflow/components/default-node/default-node.component.d.ts +2 -2
- package/lib/vflow/components/defs/defs.component.d.ts +2 -2
- package/lib/vflow/components/edge/edge.component.d.ts +7 -7
- package/lib/vflow/components/edge-label/edge-label.component.d.ts +9 -8
- package/lib/vflow/components/node/node.component.d.ts +5 -6
- package/lib/vflow/components/vflow/vflow.component.d.ts +19 -29
- package/lib/vflow/directives/changes-controller.directive.d.ts +29 -30
- package/lib/vflow/directives/connection-controller.directive.d.ts +1 -2
- package/lib/vflow/directives/drag-handle.directive.d.ts +1 -1
- package/lib/vflow/directives/flow-size-controller.directive.d.ts +1 -1
- package/lib/vflow/directives/handle-size-controller.directive.d.ts +2 -2
- package/lib/vflow/directives/map-context.directive.d.ts +1 -1
- package/lib/vflow/directives/pointer.directive.d.ts +9 -6
- package/lib/vflow/directives/reference.directive.d.ts +1 -1
- package/lib/vflow/directives/root-pointer.directive.d.ts +1 -1
- package/lib/vflow/directives/root-svg-context.directive.d.ts +1 -1
- package/lib/vflow/directives/selectable.directive.d.ts +1 -1
- package/lib/vflow/directives/space-point-context.directive.d.ts +1 -1
- package/lib/vflow/directives/template.directive.d.ts +6 -6
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +3 -3
- package/lib/vflow/interfaces/node.interface.d.ts +14 -14
- package/lib/vflow/interfaces/optimization.interface.d.ts +0 -7
- package/lib/vflow/models/edge.model.d.ts +1 -17
- package/lib/vflow/models/handle.model.d.ts +4 -4
- package/lib/vflow/models/node.model.d.ts +2 -5
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +3 -3
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +3 -3
- package/lib/vflow/{components → public-components}/handle/handle.component.d.ts +5 -5
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +8 -10
- package/lib/vflow/public-components/node-toolbar/node-toolbar.component.d.ts +6 -5
- package/lib/vflow/public-components/resizable/resizable.component.d.ts +5 -4
- package/lib/vflow/services/flow-settings.service.d.ts +0 -7
- package/lib/vflow/utils/reference-keeper.d.ts +1 -1
- package/lib/vflow/vflow.d.ts +9 -0
- package/package.json +3 -3
- package/public-api.d.ts +2 -3
- package/esm2022/lib/vflow/components/handle/handle.component.mjs +0 -49
- package/esm2022/lib/vflow/interfaces/handle-positions.interface.mjs +0 -2
- package/esm2022/lib/vflow/vflow.module.mjs +0 -121
- package/lib/vflow/interfaces/handle-positions.interface.d.ts +0 -5
- package/lib/vflow/vflow.module.d.ts +0 -30
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Injector, Input, computed, inject, runInInjectionContext, input, contentChild, viewChild, } from '@angular/core';
|
|
2
2
|
import { MapContextDirective } from '../../directives/map-context.directive';
|
|
3
3
|
import { DraggableService } from '../../services/draggable.service';
|
|
4
4
|
import { ViewportService } from '../../services/viewport.service';
|
|
5
|
-
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
6
|
-
import { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, GroupNodeTemplateDirective, NodeHtmlTemplateDirective } from '../../directives/template.directive';
|
|
5
|
+
import { toObservable, toSignal, outputFromObservable, } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, GroupNodeTemplateDirective, NodeHtmlTemplateDirective, } from '../../directives/template.directive';
|
|
7
7
|
import { addNodesToEdges } from '../../utils/add-nodes-to-edges';
|
|
8
8
|
import { skip } from 'rxjs';
|
|
9
9
|
import { FlowStatusService } from '../../services/flow-status.service';
|
|
@@ -22,24 +22,22 @@ import { SpacePointContextDirective } from '../../directives/space-point-context
|
|
|
22
22
|
import { KeyboardService } from '../../services/keyboard.service';
|
|
23
23
|
import { transformBackground } from '../../utils/transform-background';
|
|
24
24
|
import { OverlaysService } from '../../services/overlays.service';
|
|
25
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
26
|
+
import { EdgeComponent } from '../edge/edge.component';
|
|
27
|
+
import { NodeComponent } from '../node/node.component';
|
|
28
|
+
import { ConnectionComponent } from '../connection/connection.component';
|
|
29
|
+
import { BackgroundComponent } from '../background/background.component';
|
|
30
|
+
import { DefsComponent } from '../defs/defs.component';
|
|
31
|
+
import { FlowSizeControllerDirective } from '../../directives/flow-size-controller.directive';
|
|
32
|
+
import { RootPointerDirective } from '../../directives/root-pointer.directive';
|
|
33
|
+
import { RootSvgContextDirective } from '../../directives/root-svg-context.directive';
|
|
34
|
+
import { RootSvgReferenceDirective } from '../../directives/reference.directive';
|
|
25
35
|
import * as i0 from "@angular/core";
|
|
26
36
|
import * as i1 from "../../directives/connection-controller.directive";
|
|
27
37
|
import * as i2 from "../../directives/changes-controller.directive";
|
|
28
|
-
import * as i3 from "@angular/common";
|
|
29
|
-
import * as i4 from "../node/node.component";
|
|
30
|
-
import * as i5 from "../edge/edge.component";
|
|
31
|
-
import * as i6 from "../connection/connection.component";
|
|
32
|
-
import * as i7 from "../defs/defs.component";
|
|
33
|
-
import * as i8 from "../background/background.component";
|
|
34
|
-
import * as i9 from "../../directives/space-point-context.directive";
|
|
35
|
-
import * as i10 from "../../directives/map-context.directive";
|
|
36
|
-
import * as i11 from "../../directives/reference.directive";
|
|
37
|
-
import * as i12 from "../../directives/root-svg-context.directive";
|
|
38
|
-
import * as i13 from "../../directives/root-pointer.directive";
|
|
39
|
-
import * as i14 from "../../directives/flow-size-controller.directive";
|
|
40
38
|
const connectionControllerHostDirective = {
|
|
41
39
|
directive: ConnectionControllerDirective,
|
|
42
|
-
outputs: ['onConnect']
|
|
40
|
+
outputs: ['onConnect'],
|
|
43
41
|
};
|
|
44
42
|
const changesControllerHostDirective = {
|
|
45
43
|
directive: ChangesControllerDirective,
|
|
@@ -73,7 +71,7 @@ const changesControllerHostDirective = {
|
|
|
73
71
|
'onEdgesChange.select',
|
|
74
72
|
'onEdgesChange.select.single',
|
|
75
73
|
'onEdgesChange.select.many',
|
|
76
|
-
]
|
|
74
|
+
],
|
|
77
75
|
};
|
|
78
76
|
export class VflowComponent {
|
|
79
77
|
constructor() {
|
|
@@ -87,10 +85,9 @@ export class VflowComponent {
|
|
|
87
85
|
this.componentEventBusService = inject(ComponentEventBusService);
|
|
88
86
|
this.keyboardService = inject(KeyboardService);
|
|
89
87
|
this.injector = inject(Injector);
|
|
90
|
-
this.optimization = {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
};
|
|
88
|
+
this.optimization = input({
|
|
89
|
+
detachedGroupsLayer: false,
|
|
90
|
+
});
|
|
94
91
|
this.nodeModels = computed(() => this.nodeRenderingService.nodes());
|
|
95
92
|
this.groups = computed(() => this.nodeRenderingService.groups());
|
|
96
93
|
this.nonGroups = computed(() => this.nodeRenderingService.nonGroups());
|
|
@@ -102,7 +99,18 @@ export class VflowComponent {
|
|
|
102
99
|
*
|
|
103
100
|
* @experimental
|
|
104
101
|
*/
|
|
105
|
-
this.onComponentNodeEvent = this.componentEventBusService.event
|
|
102
|
+
this.onComponentNodeEvent = outputFromObservable(this.componentEventBusService.event$); // TODO: research how to remove any
|
|
103
|
+
// #endregion
|
|
104
|
+
// #region TEMPLATES
|
|
105
|
+
this.nodeTemplateDirective = contentChild(NodeHtmlTemplateDirective);
|
|
106
|
+
this.groupNodeTemplateDirective = contentChild(GroupNodeTemplateDirective);
|
|
107
|
+
this.edgeTemplateDirective = contentChild(EdgeTemplateDirective);
|
|
108
|
+
this.edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateDirective);
|
|
109
|
+
this.connectionTemplateDirective = contentChild(ConnectionTemplateDirective);
|
|
110
|
+
// #endregion
|
|
111
|
+
// #region DIRECTIVES
|
|
112
|
+
this.mapContext = viewChild(MapContextDirective);
|
|
113
|
+
this.spacePointContext = viewChild.required(SpacePointContextDirective);
|
|
106
114
|
// #endregion
|
|
107
115
|
// #region SIGNAL_API
|
|
108
116
|
/**
|
|
@@ -112,18 +120,21 @@ export class VflowComponent {
|
|
|
112
120
|
/**
|
|
113
121
|
* Signal for reading nodes change
|
|
114
122
|
*/
|
|
115
|
-
this.nodesChange = toSignal(this.nodesChangeService.changes$, {
|
|
123
|
+
this.nodesChange = toSignal(this.nodesChangeService.changes$, {
|
|
124
|
+
initialValue: [],
|
|
125
|
+
});
|
|
116
126
|
/**
|
|
117
127
|
* Signal to reading edges change
|
|
118
128
|
*/
|
|
119
|
-
this.edgesChange = toSignal(this.edgesChangeService.changes$, {
|
|
129
|
+
this.edgesChange = toSignal(this.edgesChangeService.changes$, {
|
|
130
|
+
initialValue: [],
|
|
131
|
+
});
|
|
120
132
|
// #endregion
|
|
121
133
|
// #region RX_API
|
|
122
134
|
/**
|
|
123
135
|
* Observable with viewport change
|
|
124
136
|
*/
|
|
125
|
-
this.viewportChange$ = toObservable(this.viewportService.readableViewport)
|
|
126
|
-
.pipe(skip(1)); // skip default value that set by signal
|
|
137
|
+
this.viewportChange$ = toObservable(this.viewportService.readableViewport).pipe(skip(1)); // skip default value that set by signal
|
|
127
138
|
/**
|
|
128
139
|
* Observable with nodes change
|
|
129
140
|
*/
|
|
@@ -160,17 +171,6 @@ export class VflowComponent {
|
|
|
160
171
|
set maxZoom(value) {
|
|
161
172
|
this.flowSettingsService.maxZoom.set(value);
|
|
162
173
|
}
|
|
163
|
-
/**
|
|
164
|
-
* Object that controls flow direction.
|
|
165
|
-
*
|
|
166
|
-
* For example, if you want to archieve right to left direction
|
|
167
|
-
* then you need to pass these positions { source: 'left', target: 'right' }
|
|
168
|
-
*
|
|
169
|
-
* @deprecated
|
|
170
|
-
*/
|
|
171
|
-
set handlePositions(handlePositions) {
|
|
172
|
-
this.flowSettingsService.handlePositions.set(handlePositions);
|
|
173
|
-
}
|
|
174
174
|
/**
|
|
175
175
|
* Background for flow
|
|
176
176
|
*/
|
|
@@ -191,8 +191,12 @@ export class VflowComponent {
|
|
|
191
191
|
*
|
|
192
192
|
* You need to pass `ConnectionSettings` in this input.
|
|
193
193
|
*/
|
|
194
|
-
set connection(connection) {
|
|
195
|
-
|
|
194
|
+
set connection(connection) {
|
|
195
|
+
this.flowEntitiesService.connection.set(connection);
|
|
196
|
+
}
|
|
197
|
+
get connection() {
|
|
198
|
+
return this.flowEntitiesService.connection();
|
|
199
|
+
}
|
|
196
200
|
// #endregion
|
|
197
201
|
// #region MAIN_INPUTS
|
|
198
202
|
/**
|
|
@@ -223,7 +227,11 @@ export class VflowComponent {
|
|
|
223
227
|
* @param viewport viewport state
|
|
224
228
|
*/
|
|
225
229
|
viewportTo(viewport) {
|
|
226
|
-
this.viewportService.writableViewport.set({
|
|
230
|
+
this.viewportService.writableViewport.set({
|
|
231
|
+
changeType: 'absolute',
|
|
232
|
+
state: viewport,
|
|
233
|
+
duration: 0,
|
|
234
|
+
});
|
|
227
235
|
}
|
|
228
236
|
/**
|
|
229
237
|
* Change zoom
|
|
@@ -231,7 +239,11 @@ export class VflowComponent {
|
|
|
231
239
|
* @param zoom zoom value
|
|
232
240
|
*/
|
|
233
241
|
zoomTo(zoom) {
|
|
234
|
-
this.viewportService.writableViewport.set({
|
|
242
|
+
this.viewportService.writableViewport.set({
|
|
243
|
+
changeType: 'absolute',
|
|
244
|
+
state: { zoom },
|
|
245
|
+
duration: 0,
|
|
246
|
+
});
|
|
235
247
|
}
|
|
236
248
|
/**
|
|
237
249
|
* Move to specified coordinate
|
|
@@ -239,7 +251,11 @@ export class VflowComponent {
|
|
|
239
251
|
* @param point point where to move
|
|
240
252
|
*/
|
|
241
253
|
panTo(point) {
|
|
242
|
-
this.viewportService.writableViewport.set({
|
|
254
|
+
this.viewportService.writableViewport.set({
|
|
255
|
+
changeType: 'absolute',
|
|
256
|
+
state: point,
|
|
257
|
+
duration: 0,
|
|
258
|
+
});
|
|
243
259
|
}
|
|
244
260
|
fitView(options) {
|
|
245
261
|
this.viewportService.fitView(options);
|
|
@@ -256,13 +272,13 @@ export class VflowComponent {
|
|
|
256
272
|
* Sync method to get detached edges
|
|
257
273
|
*/
|
|
258
274
|
getDetachedEdges() {
|
|
259
|
-
return this.flowEntitiesService.getDetachedEdges().map(e => e.edge);
|
|
275
|
+
return this.flowEntitiesService.getDetachedEdges().map((e) => e.edge);
|
|
260
276
|
}
|
|
261
277
|
/**
|
|
262
278
|
* Convert point received from document to point on the flow
|
|
263
279
|
*/
|
|
264
280
|
documentPointToFlowPoint(point) {
|
|
265
|
-
return this.spacePointContext.documentPointToFlowPoint(point);
|
|
281
|
+
return this.spacePointContext().documentPointToFlowPoint(point);
|
|
266
282
|
}
|
|
267
283
|
// #endregion
|
|
268
284
|
trackNodes(idx, { node }) {
|
|
@@ -272,19 +288,17 @@ export class VflowComponent {
|
|
|
272
288
|
return edge;
|
|
273
289
|
}
|
|
274
290
|
setInitialNodesOrder() {
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
this.nodeRenderingService.pullNode(model);
|
|
281
|
-
}
|
|
291
|
+
this.nodeModels().forEach((model) => {
|
|
292
|
+
switch (model.node.type) {
|
|
293
|
+
case 'default-group':
|
|
294
|
+
case 'template-group': {
|
|
295
|
+
this.nodeRenderingService.pullNode(model);
|
|
282
296
|
}
|
|
283
|
-
}
|
|
284
|
-
}
|
|
297
|
+
}
|
|
298
|
+
});
|
|
285
299
|
}
|
|
286
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
287
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
300
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
301
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: VflowComponent, isStandalone: true, selector: "vflow", inputs: { 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) }, nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: false, isRequired: true, transformFunction: null }, edges: { classPropertyName: "edges", publicName: "edges", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onComponentNodeEvent: "onComponentNodeEvent" }, providers: [
|
|
288
302
|
DraggableService,
|
|
289
303
|
ViewportService,
|
|
290
304
|
FlowStatusService,
|
|
@@ -296,12 +310,12 @@ export class VflowComponent {
|
|
|
296
310
|
FlowSettingsService,
|
|
297
311
|
ComponentEventBusService,
|
|
298
312
|
KeyboardService,
|
|
299
|
-
OverlaysService
|
|
300
|
-
], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true }, { propertyName: "groupNodeTemplateDirective", first: true, predicate: GroupNodeTemplateDirective, descendants: true }, { propertyName: "edgeTemplateDirective", first: true, predicate: EdgeTemplateDirective, descendants: true }, { propertyName: "edgeLabelHtmlDirective", first: true, predicate: EdgeLabelHtmlTemplateDirective, descendants: true }, { propertyName: "connectionTemplateDirective", first: true, predicate: ConnectionTemplateDirective, descendants: true }], viewQueries: [{ propertyName: "mapContext", first: true, predicate: MapContextDirective, descendants: true }, { propertyName: "spacePointContext", first: true, predicate: SpacePointContextDirective, descendants: true }], hostDirectives: [{ directive: i1.ConnectionControllerDirective, outputs: ["onConnect", "onConnect"] }, { directive: i2.ChangesControllerDirective, outputs: ["onNodesChange", "onNodesChange", "onNodesChange.position", "onNodesChange.position", "onNodesChange.position.single", "onNodesChange.position.single", "onNodesChange.position.many", "onNodesChange.position.many", "onNodesChange.size", "onNodesChange.size", "onNodesChange.size.single", "onNodesChange.size.single", "onNodesChange.size.many", "onNodesChange.size.many", "onNodesChange.add", "onNodesChange.add", "onNodesChange.add.single", "onNodesChange.add.single", "onNodesChange.add.many", "onNodesChange.add.many", "onNodesChange.remove", "onNodesChange.remove", "onNodesChange.remove.single", "onNodesChange.remove.single", "onNodesChange.remove.many", "onNodesChange.remove.many", "onNodesChange.select", "onNodesChange.select", "onNodesChange.select.single", "onNodesChange.select.single", "onNodesChange.select.many", "onNodesChange.select.many", "onEdgesChange", "onEdgesChange", "onEdgesChange.detached", "onEdgesChange.detached", "onEdgesChange.detached.single", "onEdgesChange.detached.single", "onEdgesChange.detached.many", "onEdgesChange.detached.many", "onEdgesChange.add", "onEdgesChange.add", "onEdgesChange.add.single", "onEdgesChange.add.single", "onEdgesChange.add.many", "onEdgesChange.add.many", "onEdgesChange.remove", "onEdgesChange.remove", "onEdgesChange.remove.single", "onEdgesChange.remove.single", "onEdgesChange.remove.many", "onEdgesChange.remove.many", "onEdgesChange.select", "onEdgesChange.select", "onEdgesChange.select.single", "onEdgesChange.select.single", "onEdgesChange.select.many", "onEdgesChange.select.many"] }], ngImport: i0, template: "<svg:svg\n rootSvgRef\n rootSvgContext\n rootPointer\n flowSizeController\n class=\"root-svg\"\n #flow\n>\n <defs [markers]=\"markers()\" flowDefs />\n\n <g background />\n\n <svg:g
|
|
313
|
+
OverlaysService,
|
|
314
|
+
], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "groupNodeTemplateDirective", first: true, predicate: GroupNodeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeTemplateDirective", first: true, predicate: EdgeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeLabelHtmlDirective", first: true, predicate: EdgeLabelHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "connectionTemplateDirective", first: true, predicate: ConnectionTemplateDirective, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "mapContext", first: true, predicate: MapContextDirective, descendants: true, isSignal: true }, { propertyName: "spacePointContext", first: true, predicate: SpacePointContextDirective, descendants: true, isSignal: true }], hostDirectives: [{ directive: i1.ConnectionControllerDirective, outputs: ["onConnect", "onConnect"] }, { directive: i2.ChangesControllerDirective, outputs: ["onNodesChange", "onNodesChange", "onNodesChange.position", "onNodesChange.position", "onNodesChange.position.single", "onNodesChange.position.single", "onNodesChange.position.many", "onNodesChange.position.many", "onNodesChange.size", "onNodesChange.size", "onNodesChange.size.single", "onNodesChange.size.single", "onNodesChange.size.many", "onNodesChange.size.many", "onNodesChange.add", "onNodesChange.add", "onNodesChange.add.single", "onNodesChange.add.single", "onNodesChange.add.many", "onNodesChange.add.many", "onNodesChange.remove", "onNodesChange.remove", "onNodesChange.remove.single", "onNodesChange.remove.single", "onNodesChange.remove.many", "onNodesChange.remove.many", "onNodesChange.select", "onNodesChange.select", "onNodesChange.select.single", "onNodesChange.select.single", "onNodesChange.select.many", "onNodesChange.select.many", "onEdgesChange", "onEdgesChange", "onEdgesChange.detached", "onEdgesChange.detached", "onEdgesChange.detached.single", "onEdgesChange.detached.single", "onEdgesChange.detached.many", "onEdgesChange.detached.many", "onEdgesChange.add", "onEdgesChange.add", "onEdgesChange.add.single", "onEdgesChange.add.single", "onEdgesChange.add.many", "onEdgesChange.add.many", "onEdgesChange.remove", "onEdgesChange.remove", "onEdgesChange.remove.single", "onEdgesChange.remove.single", "onEdgesChange.remove.many", "onEdgesChange.remove.many", "onEdgesChange.select", "onEdgesChange.select", "onEdgesChange.select.single", "onEdgesChange.select.single", "onEdgesChange.select.many", "onEdgesChange.select.many"] }], ngImport: i0, template: "<svg:svg\n rootSvgRef\n rootSvgContext\n rootPointer\n flowSizeController\n class=\"root-svg\"\n #flow\n>\n <defs [markers]=\"markers()\" flowDefs />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g\n connection\n [model]=\"connection\"\n [template]=\"connectionTemplateDirective()?.templateRef\"\n />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n @for (model of groups(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n <!-- Edges -->\n @for (model of edgeModels(); track trackEdges($index, model)) {\n <svg:g\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n />\n }\n <!-- Nodes -->\n @for (model of nonGroups(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n @for (model of edgeModels(); track trackEdges($index, model)) {\n <svg:g\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n />\n }\n <!-- Nodes -->\n @for (model of nodeModels(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: RootSvgReferenceDirective, selector: "svg[rootSvgRef]" }, { kind: "directive", type: RootSvgContextDirective, selector: "svg[rootSvgContext]" }, { kind: "directive", type: RootPointerDirective, selector: "svg[rootPointer]" }, { kind: "directive", type: FlowSizeControllerDirective, selector: "svg[flowSizeController]" }, { kind: "component", type: DefsComponent, selector: "defs[flowDefs]", inputs: ["markers"] }, { kind: "component", type: BackgroundComponent, selector: "g[background]" }, { kind: "directive", type: MapContextDirective, selector: "g[mapContext]" }, { kind: "directive", type: SpacePointContextDirective, selector: "g[spacePointContext]" }, { kind: "component", type: ConnectionComponent, selector: "g[connection]", inputs: ["model", "template"] }, { kind: "component", type: NodeComponent, selector: "g[node]", inputs: ["nodeModel", "nodeTemplate", "groupNodeTemplate"] }, { kind: "component", type: EdgeComponent, selector: "g[edge]", inputs: ["model", "edgeTemplate", "edgeLabelHtmlTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
301
315
|
}
|
|
302
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
316
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, decorators: [{
|
|
303
317
|
type: Component,
|
|
304
|
-
args: [{ selector: 'vflow', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
318
|
+
args: [{ standalone: true, selector: 'vflow', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
305
319
|
DraggableService,
|
|
306
320
|
ViewportService,
|
|
307
321
|
FlowStatusService,
|
|
@@ -313,57 +327,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
313
327
|
FlowSettingsService,
|
|
314
328
|
ComponentEventBusService,
|
|
315
329
|
KeyboardService,
|
|
316
|
-
OverlaysService
|
|
330
|
+
OverlaysService,
|
|
317
331
|
], hostDirectives: [
|
|
318
332
|
connectionControllerHostDirective,
|
|
319
|
-
changesControllerHostDirective
|
|
320
|
-
],
|
|
333
|
+
changesControllerHostDirective,
|
|
334
|
+
], imports: [
|
|
335
|
+
RootSvgReferenceDirective,
|
|
336
|
+
RootSvgContextDirective,
|
|
337
|
+
RootPointerDirective,
|
|
338
|
+
FlowSizeControllerDirective,
|
|
339
|
+
DefsComponent,
|
|
340
|
+
BackgroundComponent,
|
|
341
|
+
MapContextDirective,
|
|
342
|
+
SpacePointContextDirective,
|
|
343
|
+
ConnectionComponent,
|
|
344
|
+
NodeComponent,
|
|
345
|
+
EdgeComponent,
|
|
346
|
+
NgTemplateOutlet,
|
|
347
|
+
], template: "<svg:svg\n rootSvgRef\n rootSvgContext\n rootPointer\n flowSizeController\n class=\"root-svg\"\n #flow\n>\n <defs [markers]=\"markers()\" flowDefs />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g\n connection\n [model]=\"connection\"\n [template]=\"connectionTemplateDirective()?.templateRef\"\n />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n @for (model of groups(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n <!-- Edges -->\n @for (model of edgeModels(); track trackEdges($index, model)) {\n <svg:g\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n />\n }\n <!-- Nodes -->\n @for (model of nonGroups(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n @for (model of edgeModels(); track trackEdges($index, model)) {\n <svg:g\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n />\n }\n <!-- Nodes -->\n @for (model of nodeModels(); track trackNodes($index, model)) {\n <svg:g\n node\n [nodeModel]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\"\n />\n }\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"] }]
|
|
321
348
|
}], propDecorators: { view: [{
|
|
322
349
|
type: Input
|
|
323
350
|
}], minZoom: [{
|
|
324
351
|
type: Input
|
|
325
352
|
}], maxZoom: [{
|
|
326
353
|
type: Input
|
|
327
|
-
}], handlePositions: [{
|
|
328
|
-
type: Input
|
|
329
354
|
}], background: [{
|
|
330
355
|
type: Input
|
|
331
|
-
}], optimization: [{
|
|
332
|
-
type: Input
|
|
333
356
|
}], entitiesSelectable: [{
|
|
334
357
|
type: Input
|
|
335
358
|
}], keyboardShortcuts: [{
|
|
336
359
|
type: Input
|
|
337
360
|
}], connection: [{
|
|
338
361
|
type: Input,
|
|
339
|
-
args: [{
|
|
362
|
+
args: [{
|
|
363
|
+
transform: (settings) => new ConnectionModel(settings),
|
|
364
|
+
}]
|
|
340
365
|
}], nodes: [{
|
|
341
366
|
type: Input,
|
|
342
367
|
args: [{ required: true }]
|
|
343
368
|
}], edges: [{
|
|
344
369
|
type: Input
|
|
345
|
-
}], onComponentNodeEvent: [{
|
|
346
|
-
type: Output
|
|
347
|
-
}], nodeTemplateDirective: [{
|
|
348
|
-
type: ContentChild,
|
|
349
|
-
args: [NodeHtmlTemplateDirective]
|
|
350
|
-
}], groupNodeTemplateDirective: [{
|
|
351
|
-
type: ContentChild,
|
|
352
|
-
args: [GroupNodeTemplateDirective]
|
|
353
|
-
}], edgeTemplateDirective: [{
|
|
354
|
-
type: ContentChild,
|
|
355
|
-
args: [EdgeTemplateDirective]
|
|
356
|
-
}], edgeLabelHtmlDirective: [{
|
|
357
|
-
type: ContentChild,
|
|
358
|
-
args: [EdgeLabelHtmlTemplateDirective]
|
|
359
|
-
}], connectionTemplateDirective: [{
|
|
360
|
-
type: ContentChild,
|
|
361
|
-
args: [ConnectionTemplateDirective]
|
|
362
|
-
}], mapContext: [{
|
|
363
|
-
type: ViewChild,
|
|
364
|
-
args: [MapContextDirective]
|
|
365
|
-
}], spacePointContext: [{
|
|
366
|
-
type: ViewChild,
|
|
367
|
-
args: [SpacePointContextDirective]
|
|
368
370
|
}] } });
|
|
369
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vflow.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/vflow/vflow.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/vflow/vflow.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAgB,QAAQ,EAAE,KAAK,EAAqB,MAAM,EAAyB,SAAS,EAAE,QAAQ,EAAU,MAAM,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAEhP,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAGpE,OAAO,EAAE,2BAA2B,EAAE,8BAA8B,EAAE,qBAAqB,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,MAAM,qCAAqC,CAAC;AAEhM,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AACjG,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAEzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,+CAA+C,CAAC;AAE3F,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AAEtF,OAAO,EAAE,0BAA0B,EAAE,MAAM,gDAAgD,CAAC;AAI5F,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;;;;;AAElE,MAAM,iCAAiC,GAAG;IACxC,SAAS,EAAE,6BAA6B;IACxC,OAAO,EAAE,CAAC,WAAW,CAAC;CACvB,CAAA;AAED,MAAM,8BAA8B,GAAG;IACrC,SAAS,EAAE,0BAA0B;IACrC,OAAO,EAAE;QACP,eAAe;QACf,wBAAwB;QACxB,+BAA+B;QAC/B,6BAA6B;QAC7B,oBAAoB;QACpB,2BAA2B;QAC3B,yBAAyB;QACzB,mBAAmB;QACnB,0BAA0B;QAC1B,wBAAwB;QACxB,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,eAAe;QACf,wBAAwB;QACxB,+BAA+B;QAC/B,6BAA6B;QAC7B,mBAAmB;QACnB,0BAA0B;QAC1B,wBAAwB;QACxB,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;KAC5B;CACF,CAAA;AA0BD,MAAM,OAAO,cAAc;IAxB3B;QAyBE,aAAa;QACL,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAA;QACzC,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAA;QACjD,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAA;QAC/C,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAA;QAC/C,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAA;QACnD,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAA;QACjD,6BAAwB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAA;QAC3D,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAA;QACzC,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAA;QAuD5B,iBAAY,GAAiB;YAClC,mBAAmB,EAAE,IAAI;YACzB,mBAAmB,EAAE,KAAK;SAC3B,CAAA;QA0CS,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC,CAAA;QAC9D,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC,CAAA;QAC3D,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,SAAS,EAAE,CAAC,CAAA;QAiBjE,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,CAAC,CAAA;QAC5E,aAAa;QAEb,kBAAkB;QAClB;;;;WAIG;QAEI,yBAAoB,GAAG,IAAI,CAAC,wBAAwB,CAAC,MAAa,CAAA,CAAC,sCAAsC;QA0BhH,aAAa;QAEb,qBAAqB;QACrB;;WAEG;QACa,aAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAA;QAE7E;;WAEG;QACa,gBAAW,GACzB,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,EAAE,YAAY,EAAE,EAAkB,EAAE,CAAC,CAAA;QAElF;;WAEG;QACa,gBAAW,GACzB,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,EAAE,YAAY,EAAE,EAAkB,EAAE,CAAC,CAAA;QAClF,aAAa;QAEb,iBAAiB;QACjB;;WAEG;QACa,oBAAe,GAAG,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC;aAClF,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA,CAAC,wCAAwC;QAEzD;;WAEG;QACa,iBAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAA;QAE/D;;WAEG;QACa,iBAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAA;QAC/D,aAAa;QAEH,YAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAA;QAE1C,YAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAA;KAmFrD;IAtRC,aAAa;IAEb,mBAAmB;IAEnB;;;;;;OAMG;IACH,IACW,IAAI,CAAC,IAA+B;QAC7C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACzC,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC7C,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC7C,CAAC;IAED;;;;;;;OAOG;IACH,IACW,eAAe,CAAC,eAAgC;QACzD,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;IAC/D,CAAC;IAED;;OAEG;IACH,IACW,UAAU,CAAC,KAA0B;QAC9C,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAA;IACrE,CAAC;IAQD;;OAEG;IACH,IACW,kBAAkB,CAAC,KAAc;QAC1C,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACxD,CAAC;IAED,IACW,iBAAiB,CAAC,KAAwB;QACnD,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;IAC1C,CAAC;IAED;;;;OAIG;IACH,IACW,UAAU,CAAC,UAA2B,IAAI,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA,CAAC,CAAC;IAE1G,IAAW,UAAU,KAAK,OAAO,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,CAAA,CAAC,CAAC;IACxE,aAAa;IAEb,sBAAsB;IACtB;;OAEG;IACH,IACW,KAAK,CAAC,QAAgC;QAC/C,MAAM,SAAS,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EACnD,GAAG,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CACxE,CAAA;QAED,yCAAyC;QACzC,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAAA;QAE5D,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IAC/C,CAAC;IAMD;;OAEG;IACH,IACW,KAAK,CAAC,QAAgB;QAC/B,MAAM,SAAS,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EACnD,GAAG,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CACxE,CAAA;QAED,yCAAyC;QACzC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,SAAS,CAAC,CAAA;QAE7C,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IAC/C,CAAC;IAiFM,QAAQ;QACb,IAAI,CAAC,oBAAoB,EAAE,CAAA;IAC7B,CAAC;IAED,sBAAsB;IACtB;;;;OAIG;IACI,UAAU,CAAC,QAAuB;QACvC,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAA;IACrG,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,IAAY;QACxB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAA;IACrG,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,KAAY;QACvB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAA;IAClG,CAAC;IAEM,OAAO,CAAC,OAAwB;QACrC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IACvC,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAc,EAAU;QACpC,OAAO,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAI,EAAE,CAAC,EAAE,IAAI,CAAA;IACtD,CAAC;IAED;;OAEG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IACrE,CAAC;IAED;;OAEG;IACI,wBAAwB,CAAC,KAAY;QAC1C,OAAO,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAA;IAC/D,CAAC;IACD,aAAa;IAEH,UAAU,CAAC,GAAW,EAAE,EAAE,IAAI,EAAa;QACnD,OAAO,IAAI,CAAA;IACb,CAAC;IAES,UAAU,CAAC,GAAW,EAAE,EAAE,IAAI,EAAa;QACnD,OAAO,IAAI,CAAA;IACb,CAAC;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE;YAEzC,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBAChC,QAAQ,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;oBACvB,KAAK,eAAe,CAAC;oBACrB,KAAK,gBAAgB,CAAC,CAAC;wBACrB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;qBAC1C;iBACF;YACH,CAAC,CAAC,CAAA;SACH;IACH,CAAC;+GAhSU,cAAc;mGAAd,cAAc,4SAwFL,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC,2GA3GxE;YACT,gBAAgB;YAChB,eAAe;YACf,iBAAiB;YACjB,mBAAmB;YACnB,kBAAkB;YAClB,kBAAkB;YAClB,oBAAoB;YACpB,gBAAgB;YAChB,mBAAmB;YACnB,wBAAwB;YACxB,eAAe;YACf,eAAe;SAChB,6EAqJa,yBAAyB,6FAGzB,0BAA0B,wFAG1B,qBAAqB,yFAGrB,8BAA8B,8FAG9B,2BAA2B,4FAK9B,mBAAmB,oFAGnB,0BAA0B,quDC1QvC,8rEAiFA;;4FDsBa,cAAc;kBAxB1B,SAAS;+BACE,OAAO,mBAGA,uBAAuB,CAAC,MAAM,aACpC;wBACT,gBAAgB;wBAChB,eAAe;wBACf,iBAAiB;wBACjB,mBAAmB;wBACnB,kBAAkB;wBAClB,kBAAkB;wBAClB,oBAAoB;wBACpB,gBAAgB;wBAChB,mBAAmB;wBACnB,wBAAwB;wBACxB,eAAe;wBACf,eAAe;qBAChB,kBACe;wBACd,iCAAiC;wBACjC,8BAA8B;qBAC/B;8BAyBU,IAAI;sBADd,KAAK;gBASK,OAAO;sBADjB,KAAK;gBASK,OAAO;sBADjB,KAAK;gBAcK,eAAe;sBADzB,KAAK;gBASK,UAAU;sBADpB,KAAK;gBAMC,YAAY;sBADlB,KAAK;gBAUK,kBAAkB;sBAD5B,KAAK;gBAMK,iBAAiB;sBAD3B,KAAK;gBAWK,UAAU;sBADpB,KAAK;uBAAC,EAAE,SAAS,EAAE,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE;gBAW1E,KAAK;sBADf,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAoBd,KAAK;sBADf,KAAK;gBAsBC,oBAAoB;sBAD1B,MAAM;gBAMG,qBAAqB;sBAD9B,YAAY;uBAAC,yBAAyB;gBAI7B,0BAA0B;sBADnC,YAAY;uBAAC,0BAA0B;gBAI9B,qBAAqB;sBAD9B,YAAY;uBAAC,qBAAqB;gBAIzB,sBAAsB;sBAD/B,YAAY;uBAAC,8BAA8B;gBAIlC,2BAA2B;sBADpC,YAAY;uBAAC,2BAA2B;gBAM/B,UAAU;sBADnB,SAAS;uBAAC,mBAAmB;gBAIpB,iBAAiB;sBAD1B,SAAS;uBAAC,0BAA0B","sourcesContent":["import { AfterContentInit, ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Injector, Input, OnChanges, OnInit, Output, Signal, SimpleChanges, ViewChild, computed, effect, inject, runInInjectionContext } from '@angular/core';\nimport { DynamicNode, Node } from '../../interfaces/node.interface';\nimport { MapContextDirective } from '../../directives/map-context.directive';\nimport { DraggableService } from '../../services/draggable.service';\nimport { NodeModel } from '../../models/node.model';\nimport { ViewportService } from '../../services/viewport.service';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { Edge } from '../../interfaces/edge.interface';\nimport { EdgeModel } from '../../models/edge.model';\nimport { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, GroupNodeTemplateDirective, NodeHtmlTemplateDirective } from '../../directives/template.directive';\nimport { HandlePositions } from '../../interfaces/handle-positions.interface';\nimport { addNodesToEdges } from '../../utils/add-nodes-to-edges';\nimport { skip } from 'rxjs';\nimport { Point } from '../../interfaces/point.interface';\nimport { ViewportState } from '../../interfaces/viewport.interface';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { ConnectionControllerDirective } from '../../directives/connection-controller.directive';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { ConnectionSettings } from '../../interfaces/connection-settings.interface';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { ReferenceKeeper } from '../../utils/reference-keeper';\nimport { NodesChangeService } from '../../services/node-changes.service';\nimport { EdgeChangesService } from '../../services/edge-changes.service';\nimport { NodeChange } from '../../types/node-change.type';\nimport { ChangesControllerDirective } from '../../directives/changes-controller.directive';\nimport { EdgeChange } from '../../types/edge-change.type';\nimport { NodeRenderingService } from '../../services/node-rendering.service';\nimport { SelectionService } from '../../services/selection.service';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { ComponentEventBusService } from '../../services/component-event-bus.service';\nimport { Background } from '../../types/background.type';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { FitViewOptions } from '../../interfaces/fit-view-options.interface';\nimport { Optimization } from '../../interfaces/optimization.interface';\nimport { KeyboardShortcuts } from '../../types/keyboard-action.type';\nimport { KeyboardService } from '../../services/keyboard.service';\nimport { transformBackground } from '../../utils/transform-background';\nimport { OverlaysService } from '../../services/overlays.service';\n\nconst connectionControllerHostDirective = {\n  directive: ConnectionControllerDirective,\n  outputs: ['onConnect']\n}\n\nconst changesControllerHostDirective = {\n  directive: ChangesControllerDirective,\n  outputs: [\n    'onNodesChange',\n    'onNodesChange.position',\n    'onNodesChange.position.single',\n    'onNodesChange.position.many',\n    'onNodesChange.size',\n    'onNodesChange.size.single',\n    'onNodesChange.size.many',\n    'onNodesChange.add',\n    'onNodesChange.add.single',\n    'onNodesChange.add.many',\n    'onNodesChange.remove',\n    'onNodesChange.remove.single',\n    'onNodesChange.remove.many',\n    'onNodesChange.select',\n    'onNodesChange.select.single',\n    'onNodesChange.select.many',\n    'onEdgesChange',\n    'onEdgesChange.detached',\n    'onEdgesChange.detached.single',\n    'onEdgesChange.detached.many',\n    'onEdgesChange.add',\n    'onEdgesChange.add.single',\n    'onEdgesChange.add.many',\n    'onEdgesChange.remove',\n    'onEdgesChange.remove.single',\n    'onEdgesChange.remove.many',\n    'onEdgesChange.select',\n    'onEdgesChange.select.single',\n    'onEdgesChange.select.many',\n  ]\n}\n\n@Component({\n  selector: 'vflow',\n  templateUrl: './vflow.component.html',\n  styleUrls: ['./vflow.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    DraggableService,\n    ViewportService,\n    FlowStatusService,\n    FlowEntitiesService,\n    NodesChangeService,\n    EdgeChangesService,\n    NodeRenderingService,\n    SelectionService,\n    FlowSettingsService,\n    ComponentEventBusService,\n    KeyboardService,\n    OverlaysService\n  ],\n  hostDirectives: [\n    connectionControllerHostDirective,\n    changesControllerHostDirective\n  ]\n})\nexport class VflowComponent implements OnInit {\n  // #region DI\n  private viewportService = inject(ViewportService)\n  private flowEntitiesService = inject(FlowEntitiesService)\n  private nodesChangeService = inject(NodesChangeService)\n  private edgesChangeService = inject(EdgeChangesService)\n  private nodeRenderingService = inject(NodeRenderingService)\n  private flowSettingsService = inject(FlowSettingsService)\n  private componentEventBusService = inject(ComponentEventBusService)\n  private keyboardService = inject(KeyboardService)\n  private injector = inject(Injector)\n  // #endregion\n\n  // #region SETTINGS\n\n  /**\n   * Size for flow view\n   *\n   * accepts\n   * - absolute size in format [width, height] or\n   * - 'auto' to compute size based on parent element size\n   */\n  @Input()\n  public set view(view: [number, number] | 'auto') {\n    this.flowSettingsService.view.set(view)\n  }\n\n  /**\n   * Minimum zoom value\n   */\n  @Input()\n  public set minZoom(value: number) {\n    this.flowSettingsService.minZoom.set(value)\n  }\n\n  /**\n   * Maximum zoom value\n   */\n  @Input()\n  public set maxZoom(value: number) {\n    this.flowSettingsService.maxZoom.set(value)\n  }\n\n  /**\n   * Object that controls flow direction.\n   *\n   * For example, if you want to archieve right to left direction\n   * then you need to pass these positions { source: 'left', target: 'right' }\n   *\n   * @deprecated\n   */\n  @Input()\n  public set handlePositions(handlePositions: HandlePositions) {\n    this.flowSettingsService.handlePositions.set(handlePositions)\n  }\n\n  /**\n   * Background for flow\n   */\n  @Input()\n  public set background(value: Background | string) {\n    this.flowSettingsService.background.set(transformBackground(value))\n  }\n\n  @Input()\n  public optimization: Optimization = {\n    computeLayersOnInit: true,\n    detachedGroupsLayer: false\n  }\n\n  /**\n   * Global rule if you can or can't select entities\n   */\n  @Input()\n  public set entitiesSelectable(value: boolean) {\n    this.flowSettingsService.entitiesSelectable.set(value)\n  }\n\n  @Input()\n  public set keyboardShortcuts(value: KeyboardShortcuts) {\n    this.keyboardService.setShortcuts(value)\n  }\n\n  /**\n   * Settings for connection (it renders when user tries to create edge between nodes)\n   *\n   * You need to pass `ConnectionSettings` in this input.\n   */\n  @Input({ transform: (settings: ConnectionSettings) => new ConnectionModel(settings) })\n  public set connection(connection: ConnectionModel) { this.flowEntitiesService.connection.set(connection) }\n\n  public get connection() { return this.flowEntitiesService.connection() }\n  // #endregion\n\n  // #region MAIN_INPUTS\n  /**\n   * Nodes to render\n   */\n  @Input({ required: true })\n  public set nodes(newNodes: Node[] | DynamicNode[]) {\n    const newModels = runInInjectionContext(this.injector,\n      () => ReferenceKeeper.nodes(newNodes, this.flowEntitiesService.nodes())\n    )\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(newModels, this.flowEntitiesService.edges())\n\n    this.flowEntitiesService.nodes.set(newModels)\n  }\n\n  protected nodeModels = computed(() => this.nodeRenderingService.nodes())\n  protected groups = computed(() => this.nodeRenderingService.groups())\n  protected nonGroups = computed(() => this.nodeRenderingService.nonGroups())\n\n  /**\n   * Edges to render\n   */\n  @Input()\n  public set edges(newEdges: Edge[]) {\n    const newModels = runInInjectionContext(this.injector,\n      () => ReferenceKeeper.edges(newEdges, this.flowEntitiesService.edges())\n    )\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(this.nodeModels(), newModels)\n\n    this.flowEntitiesService.edges.set(newModels)\n  }\n\n  protected edgeModels = computed(() => this.flowEntitiesService.validEdges())\n  // #endregion\n\n  // #region OUTPUTS\n  /**\n   * Event that accumulates all custom node events\n   *\n   * @experimental\n   */\n  @Output()\n  public onComponentNodeEvent = this.componentEventBusService.event$ as any // TODO: research how to remove as any\n  // #endregion\n\n  // #region TEMPLATES\n  @ContentChild(NodeHtmlTemplateDirective)\n  protected nodeTemplateDirective?: NodeHtmlTemplateDirective\n\n  @ContentChild(GroupNodeTemplateDirective)\n  protected groupNodeTemplateDirective?: GroupNodeTemplateDirective\n\n  @ContentChild(EdgeTemplateDirective)\n  protected edgeTemplateDirective?: EdgeTemplateDirective\n\n  @ContentChild(EdgeLabelHtmlTemplateDirective)\n  protected edgeLabelHtmlDirective?: EdgeLabelHtmlTemplateDirective\n\n  @ContentChild(ConnectionTemplateDirective)\n  protected connectionTemplateDirective?: ConnectionTemplateDirective\n  // #endregion\n\n  // #region DIRECTIVES\n  @ViewChild(MapContextDirective)\n  protected mapContext!: MapContextDirective\n\n  @ViewChild(SpacePointContextDirective)\n  protected spacePointContext!: SpacePointContextDirective\n  // #endregion\n\n  // #region SIGNAL_API\n  /**\n   * Signal for reading viewport change\n   */\n  public readonly viewport = this.viewportService.readableViewport.asReadonly()\n\n  /**\n   * Signal for reading nodes change\n   */\n  public readonly nodesChange =\n    toSignal(this.nodesChangeService.changes$, { initialValue: [] as NodeChange[] })\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange =\n    toSignal(this.edgesChangeService.changes$, { initialValue: [] as EdgeChange[] })\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(this.viewportService.readableViewport)\n    .pipe(skip(1)) // skip default value that set by signal\n\n  /**\n   * Observable with nodes change\n   */\n  public readonly nodesChange$ = this.nodesChangeService.changes$\n\n  /**\n   * Observable with edges change\n   */\n  public readonly edgesChange$ = this.edgesChangeService.changes$\n  // #endregion\n\n  protected markers = this.flowEntitiesService.markers\n\n  protected minimap = this.flowEntitiesService.minimap\n\n  public ngOnInit(): void {\n    this.setInitialNodesOrder()\n  }\n\n  // #region METHODS_API\n  /**\n   * Change viewport to specified state\n   *\n   * @param viewport viewport state\n   */\n  public viewportTo(viewport: ViewportState): void {\n    this.viewportService.writableViewport.set({ changeType: 'absolute', state: viewport, duration: 0 })\n  }\n\n  /**\n   * Change zoom\n   *\n   * @param zoom zoom value\n   */\n  public zoomTo(zoom: number): void {\n    this.viewportService.writableViewport.set({ changeType: 'absolute', state: { zoom }, duration: 0 })\n  }\n\n  /**\n   * Move to specified coordinate\n   *\n   * @param point point where to move\n   */\n  public panTo(point: Point): void {\n    this.viewportService.writableViewport.set({ changeType: 'absolute', state: point, duration: 0 })\n  }\n\n  public fitView(options?: FitViewOptions) {\n    this.viewportService.fitView(options)\n  }\n\n  /**\n   * Get node by id\n   *\n   * @param id node id\n   */\n  public getNode<T = unknown>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.node\n  }\n\n  /**\n   * Sync method to get detached edges\n   */\n  public getDetachedEdges(): Edge[] {\n    return this.flowEntitiesService.getDetachedEdges().map(e => e.edge)\n  }\n\n  /**\n   * Convert point received from document to point on the flow\n   */\n  public documentPointToFlowPoint(point: Point): Point {\n    return this.spacePointContext.documentPointToFlowPoint(point)\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { node }: NodeModel) {\n    return node\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge\n  }\n\n  private setInitialNodesOrder() {\n    if (this.optimization.computeLayersOnInit) {\n\n      this.nodeModels().forEach(model => {\n        switch (model.node.type) {\n          case 'default-group':\n          case 'template-group': {\n            this.nodeRenderingService.pullNode(model)\n          }\n        }\n      })\n    }\n  }\n}\n\n","<svg:svg\n  rootSvgRef\n  rootSvgContext\n  rootPointer\n  flowSizeController\n  class=\"root-svg\"\n  #flow\n>\n  <defs [markers]=\"markers()\" flowDefs />\n\n  <g background />\n\n  <svg:g\n    mapContext\n    spacePointContext\n  >\n    <!-- Connection -->\n    <svg:g\n      connection\n      [model]=\"connection\"\n      [template]=\"connectionTemplateDirective?.templateRef\"\n    />\n\n    <ng-container *ngIf=\"optimization.detachedGroupsLayer\">\n      <!-- Groups -->\n      <svg:g\n        *ngFor=\"let model of groups(); trackBy: trackNodes\"\n        node\n        [nodeModel]=\"model\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\"\n      />\n\n      <!-- Edges  -->\n      <svg:g\n        *ngFor=\"let model of edgeModels(); trackBy: trackEdges\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective?.templateRef\"\n      />\n\n      <!-- Nodes -->\n      <svg:g\n        *ngFor=\"let model of nonGroups(); trackBy: trackNodes\"\n        node\n        [nodeModel]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\"\n      />\n    </ng-container>\n\n    <ng-container *ngIf=\"!optimization.detachedGroupsLayer\">\n      <!-- Edges  -->\n      <svg:g\n        *ngFor=\"let model of edgeModels(); trackBy: trackEdges\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective?.templateRef\"\n      />\n\n      <!-- Nodes -->\n      <svg:g\n        *ngFor=\"let model of nodeModels(); trackBy: trackNodes\"\n        node\n        [nodeModel]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective?.templateRef\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\"\n      />\n    </ng-container>\n\n  </svg:g>\n\n  <!-- Minimap -->\n  <ng-container *ngIf=\"minimap() as minimap\">\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  </ng-container>\n</svg:svg>\n\n"]}
|
|
371
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vflow.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/vflow/vflow.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/vflow/vflow.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,qBAAqB,EACrB,KAAK,EAEL,YAAY,EACZ,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EACL,YAAY,EACZ,QAAQ,EACR,oBAAoB,GACrB,MAAM,4BAA4B,CAAC;AAGpC,OAAO,EACL,2BAA2B,EAC3B,8BAA8B,EAC9B,qBAAqB,EACrB,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAG5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AACjG,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAEzE,OAAO,EAAE,0BAA0B,EAAE,MAAM,+CAA+C,CAAC;AAE3F,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AAEtF,OAAO,EAAE,0BAA0B,EAAE,MAAM,gDAAgD,CAAC;AAI5F,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,iDAAiD,CAAC;AAC9F,OAAO,EAAE,oBAAoB,EAAE,MAAM,yCAAyC,CAAC;AAC/E,OAAO,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AACtF,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;;;;AAEjF,MAAM,iCAAiC,GAAG;IACxC,SAAS,EAAE,6BAA6B;IACxC,OAAO,EAAE,CAAC,WAAW,CAAC;CACvB,CAAC;AAEF,MAAM,8BAA8B,GAAG;IACrC,SAAS,EAAE,0BAA0B;IACrC,OAAO,EAAE;QACP,eAAe;QACf,wBAAwB;QACxB,+BAA+B;QAC/B,6BAA6B;QAC7B,oBAAoB;QACpB,2BAA2B;QAC3B,yBAAyB;QACzB,mBAAmB;QACnB,0BAA0B;QAC1B,wBAAwB;QACxB,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,eAAe;QACf,wBAAwB;QACxB,+BAA+B;QAC/B,6BAA6B;QAC7B,mBAAmB;QACnB,0BAA0B;QAC1B,wBAAwB;QACxB,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;QAC3B,sBAAsB;QACtB,6BAA6B;QAC7B,2BAA2B;KAC5B;CACF,CAAC;AAyCF,MAAM,OAAO,cAAc;IAvC3B;QAwCE,aAAa;QACL,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChD,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChD,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QACpD,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,6BAAwB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAC5D,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAyC7B,iBAAY,GAAG,KAAK,CAAe;YACxC,mBAAmB,EAAE,KAAK;SAC3B,CAAC,CAAC;QAgDO,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/D,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC,CAAC;QAC5D,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,SAAS,EAAE,CAAC,CAAC;QAiBlE,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,CAAC,CAAC;QAC7E,aAAa;QAEb,kBAAkB;QAClB;;;;WAIG;QACI,yBAAoB,GAAG,oBAAoB,CAChD,IAAI,CAAC,wBAAwB,CAAC,MAAM,CACrC,CAAC,CAAC,mCAAmC;QACtC,aAAa;QAEb,oBAAoB;QACV,0BAAqB,GAAG,YAAY,CAAC,yBAAyB,CAAC,CAAC;QAEhE,+BAA0B,GAAG,YAAY,CACjD,0BAA0B,CAC3B,CAAC;QAEQ,0BAAqB,GAAG,YAAY,CAAC,qBAAqB,CAAC,CAAC;QAE5D,2BAAsB,GAAG,YAAY,CAC7C,8BAA8B,CAC/B,CAAC;QAEQ,gCAA2B,GAAG,YAAY,CAClD,2BAA2B,CAC5B,CAAC;QACF,aAAa;QAEb,qBAAqB;QACX,eAAU,GAAG,SAAS,CAAC,mBAAmB,CAAC,CAAC;QAE5C,sBAAiB,GAAG,SAAS,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CAAC;QAC7E,aAAa;QAEb,qBAAqB;QACrB;;WAEG;QACa,aAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QAE9E;;WAEG;QACa,gBAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE;YACvE,YAAY,EAAE,EAAkB;SACjC,CAAC,CAAC;QAEH;;WAEG;QACa,gBAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE;YACvE,YAAY,EAAE,EAAkB;SACjC,CAAC,CAAC;QACH,aAAa;QAEb,iBAAiB;QACjB;;WAEG;QACa,oBAAe,GAAG,YAAY,CAC5C,IAAI,CAAC,eAAe,CAAC,gBAAgB,CACtC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,wCAAwC;QAEzD;;WAEG;QACa,iBAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC;QAEhE;;WAEG;QACa,iBAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC;QAChE,aAAa;QAEH,YAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC;QAE3C,YAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC;KA8FtD;IA3RC,aAAa;IAEb,mBAAmB;IAEnB;;;;;;OAMG;IACH,IACW,IAAI,CAAC,IAA+B;QAC7C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,IACW,UAAU,CAAC,KAA0B;QAC9C,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,CAAC;IAMD;;OAEG;IACH,IACW,kBAAkB,CAAC,KAAc;QAC1C,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,IACW,iBAAiB,CAAC,KAAwB;QACnD,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED;;;;OAIG;IACH,IAGW,UAAU,CAAC,UAA2B;QAC/C,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACtD,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,CAAC;IAC/C,CAAC;IACD,aAAa;IAEb,sBAAsB;IACtB;;OAEG;IACH,IACW,KAAK,CAAC,QAAgC;QAC/C,MAAM,SAAS,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,CAC1D,eAAe,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAClE,CAAC;QAEF,yCAAyC;QACzC,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAAC;QAE7D,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC;IAMD;;OAEG;IACH,IACW,KAAK,CAAC,QAAgB;QAC/B,MAAM,SAAS,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,CAC1D,eAAe,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,CAAC,CAClE,CAAC;QAEF,yCAAyC;QACzC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,SAAS,CAAC,CAAC;QAE9C,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC;IAoFM,QAAQ;QACb,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,sBAAsB;IACtB;;;;OAIG;IACI,UAAU,CAAC,QAAuB;QACvC,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC;YACxC,UAAU,EAAE,UAAU;YACtB,KAAK,EAAE,QAAQ;YACf,QAAQ,EAAE,CAAC;SACZ,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,IAAY;QACxB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC;YACxC,UAAU,EAAE,UAAU;YACtB,KAAK,EAAE,EAAE,IAAI,EAAE;YACf,QAAQ,EAAE,CAAC;SACZ,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,KAAY;QACvB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,GAAG,CAAC;YACxC,UAAU,EAAE,UAAU;YACtB,KAAK,EAAE,KAAK;YACZ,QAAQ,EAAE,CAAC;SACZ,CAAC,CAAC;IACL,CAAC;IAEM,OAAO,CAAC,OAAwB;QACrC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,OAAO,CACZ,EAAU;QAEV,OAAO,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAI,EAAE,CAAC,EAAE,IAAI,CAAC;IACvD,CAAC;IAED;;OAEG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;IACI,wBAAwB,CAAC,KAAY;QAC1C,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC;IAClE,CAAC;IACD,aAAa;IAEH,UAAU,CAAC,GAAW,EAAE,EAAE,IAAI,EAAa;QACnD,OAAO,IAAI,CAAC;IACd,CAAC;IAES,UAAU,CAAC,GAAW,EAAE,EAAE,IAAI,EAAa;QACnD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAClC,QAAQ,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACxB,KAAK,eAAe,CAAC;gBACrB,KAAK,gBAAgB,CAAC,CAAC,CAAC;oBACtB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC5C,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;+GArSU,cAAc;mGAAd,cAAc,ynCA0EZ,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC,6TA3GjE;YACT,gBAAgB;YAChB,eAAe;YACf,iBAAiB;YACjB,mBAAmB;YACnB,kBAAkB;YAClB,kBAAkB;YAClB,oBAAoB;YACpB,gBAAgB;YAChB,mBAAmB;YACnB,wBAAwB;YACxB,eAAe;YACf,eAAe;SAChB,6EA2J8C,yBAAyB,6GAGtE,0BAA0B,wGAGmB,qBAAqB,yGAGlE,8BAA8B,8GAI9B,2BAA2B,4GAKI,mBAAmB,oGAEH,0BAA0B,qvDCjT7E,+tEA8EA,yLD0DI,yBAAyB,4DACzB,uBAAuB,gEACvB,oBAAoB,6DACpB,2BAA2B,oEAC3B,aAAa,gFACb,mBAAmB,0DACnB,mBAAmB,0DACnB,0BAA0B,iEAC1B,mBAAmB,yFACnB,aAAa,gHACb,aAAa,gHACb,gBAAgB;;4FAGP,cAAc;kBAvC1B,SAAS;iCACI,IAAI,YACN,OAAO,mBAGA,uBAAuB,CAAC,MAAM,aACpC;wBACT,gBAAgB;wBAChB,eAAe;wBACf,iBAAiB;wBACjB,mBAAmB;wBACnB,kBAAkB;wBAClB,kBAAkB;wBAClB,oBAAoB;wBACpB,gBAAgB;wBAChB,mBAAmB;wBACnB,wBAAwB;wBACxB,eAAe;wBACf,eAAe;qBAChB,kBACe;wBACd,iCAAiC;wBACjC,8BAA8B;qBAC/B,WACQ;wBACP,yBAAyB;wBACzB,uBAAuB;wBACvB,oBAAoB;wBACpB,2BAA2B;wBAC3B,aAAa;wBACb,mBAAmB;wBACnB,mBAAmB;wBACnB,0BAA0B;wBAC1B,mBAAmB;wBACnB,aAAa;wBACb,aAAa;wBACb,gBAAgB;qBACjB;8BAyBU,IAAI;sBADd,KAAK;gBASK,OAAO;sBADjB,KAAK;gBASK,OAAO;sBADjB,KAAK;gBASK,UAAU;sBADpB,KAAK;gBAaK,kBAAkB;sBAD5B,KAAK;gBAMK,iBAAiB;sBAD3B,KAAK;gBAaK,UAAU;sBAHpB,KAAK;uBAAC;wBACL,SAAS,EAAE,CAAC,QAA4B,EAAE,EAAE,CAAC,IAAI,eAAe,CAAC,QAAQ,CAAC;qBAC3E;gBAeU,KAAK;sBADf,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAoBd,KAAK;sBADf,KAAK","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n  OnInit,\n  computed,\n  inject,\n  runInInjectionContext,\n  input,\n  output,\n  contentChild,\n  viewChild,\n} from '@angular/core';\nimport { DynamicNode, Node } from '../../interfaces/node.interface';\nimport { MapContextDirective } from '../../directives/map-context.directive';\nimport { DraggableService } from '../../services/draggable.service';\nimport { NodeModel } from '../../models/node.model';\nimport { ViewportService } from '../../services/viewport.service';\nimport {\n  toObservable,\n  toSignal,\n  outputFromObservable,\n} from '@angular/core/rxjs-interop';\nimport { Edge } from '../../interfaces/edge.interface';\nimport { EdgeModel } from '../../models/edge.model';\nimport {\n  ConnectionTemplateDirective,\n  EdgeLabelHtmlTemplateDirective,\n  EdgeTemplateDirective,\n  GroupNodeTemplateDirective,\n  NodeHtmlTemplateDirective,\n} from '../../directives/template.directive';\nimport { addNodesToEdges } from '../../utils/add-nodes-to-edges';\nimport { skip } from 'rxjs';\nimport { Point } from '../../interfaces/point.interface';\nimport { ViewportState } from '../../interfaces/viewport.interface';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { ConnectionControllerDirective } from '../../directives/connection-controller.directive';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { ConnectionSettings } from '../../interfaces/connection-settings.interface';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { ReferenceKeeper } from '../../utils/reference-keeper';\nimport { NodesChangeService } from '../../services/node-changes.service';\nimport { EdgeChangesService } from '../../services/edge-changes.service';\nimport { NodeChange } from '../../types/node-change.type';\nimport { ChangesControllerDirective } from '../../directives/changes-controller.directive';\nimport { EdgeChange } from '../../types/edge-change.type';\nimport { NodeRenderingService } from '../../services/node-rendering.service';\nimport { SelectionService } from '../../services/selection.service';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { ComponentEventBusService } from '../../services/component-event-bus.service';\nimport { Background } from '../../types/background.type';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { FitViewOptions } from '../../interfaces/fit-view-options.interface';\nimport { Optimization } from '../../interfaces/optimization.interface';\nimport { KeyboardShortcuts } from '../../types/keyboard-action.type';\nimport { KeyboardService } from '../../services/keyboard.service';\nimport { transformBackground } from '../../utils/transform-background';\nimport { OverlaysService } from '../../services/overlays.service';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { EdgeComponent } from '../edge/edge.component';\nimport { NodeComponent } from '../node/node.component';\nimport { ConnectionComponent } from '../connection/connection.component';\nimport { BackgroundComponent } from '../background/background.component';\nimport { DefsComponent } from '../defs/defs.component';\nimport { FlowSizeControllerDirective } from '../../directives/flow-size-controller.directive';\nimport { RootPointerDirective } from '../../directives/root-pointer.directive';\nimport { RootSvgContextDirective } from '../../directives/root-svg-context.directive';\nimport { RootSvgReferenceDirective } from '../../directives/reference.directive';\n\nconst connectionControllerHostDirective = {\n  directive: ConnectionControllerDirective,\n  outputs: ['onConnect'],\n};\n\nconst changesControllerHostDirective = {\n  directive: ChangesControllerDirective,\n  outputs: [\n    'onNodesChange',\n    'onNodesChange.position',\n    'onNodesChange.position.single',\n    'onNodesChange.position.many',\n    'onNodesChange.size',\n    'onNodesChange.size.single',\n    'onNodesChange.size.many',\n    'onNodesChange.add',\n    'onNodesChange.add.single',\n    'onNodesChange.add.many',\n    'onNodesChange.remove',\n    'onNodesChange.remove.single',\n    'onNodesChange.remove.many',\n    'onNodesChange.select',\n    'onNodesChange.select.single',\n    'onNodesChange.select.many',\n    'onEdgesChange',\n    'onEdgesChange.detached',\n    'onEdgesChange.detached.single',\n    'onEdgesChange.detached.many',\n    'onEdgesChange.add',\n    'onEdgesChange.add.single',\n    'onEdgesChange.add.many',\n    'onEdgesChange.remove',\n    'onEdgesChange.remove.single',\n    'onEdgesChange.remove.many',\n    'onEdgesChange.select',\n    'onEdgesChange.select.single',\n    'onEdgesChange.select.many',\n  ],\n};\n\n@Component({\n  standalone: true,\n  selector: 'vflow',\n  templateUrl: './vflow.component.html',\n  styleUrls: ['./vflow.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    DraggableService,\n    ViewportService,\n    FlowStatusService,\n    FlowEntitiesService,\n    NodesChangeService,\n    EdgeChangesService,\n    NodeRenderingService,\n    SelectionService,\n    FlowSettingsService,\n    ComponentEventBusService,\n    KeyboardService,\n    OverlaysService,\n  ],\n  hostDirectives: [\n    connectionControllerHostDirective,\n    changesControllerHostDirective,\n  ],\n  imports: [\n    RootSvgReferenceDirective,\n    RootSvgContextDirective,\n    RootPointerDirective,\n    FlowSizeControllerDirective,\n    DefsComponent,\n    BackgroundComponent,\n    MapContextDirective,\n    SpacePointContextDirective,\n    ConnectionComponent,\n    NodeComponent,\n    EdgeComponent,\n    NgTemplateOutlet,\n  ],\n})\nexport class VflowComponent implements OnInit {\n  // #region DI\n  private viewportService = inject(ViewportService);\n  private flowEntitiesService = inject(FlowEntitiesService);\n  private nodesChangeService = inject(NodesChangeService);\n  private edgesChangeService = inject(EdgeChangesService);\n  private nodeRenderingService = inject(NodeRenderingService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private componentEventBusService = inject(ComponentEventBusService);\n  private keyboardService = inject(KeyboardService);\n  private injector = inject(Injector);\n  // #endregion\n\n  // #region SETTINGS\n\n  /**\n   * Size for flow view\n   *\n   * accepts\n   * - absolute size in format [width, height] or\n   * - 'auto' to compute size based on parent element size\n   */\n  @Input()\n  public set view(view: [number, number] | 'auto') {\n    this.flowSettingsService.view.set(view);\n  }\n\n  /**\n   * Minimum zoom value\n   */\n  @Input()\n  public set minZoom(value: number) {\n    this.flowSettingsService.minZoom.set(value);\n  }\n\n  /**\n   * Maximum zoom value\n   */\n  @Input()\n  public set maxZoom(value: number) {\n    this.flowSettingsService.maxZoom.set(value);\n  }\n\n  /**\n   * Background for flow\n   */\n  @Input()\n  public set background(value: Background | string) {\n    this.flowSettingsService.background.set(transformBackground(value));\n  }\n\n  public optimization = input<Optimization>({\n    detachedGroupsLayer: false,\n  });\n\n  /**\n   * Global rule if you can or can't select entities\n   */\n  @Input()\n  public set entitiesSelectable(value: boolean) {\n    this.flowSettingsService.entitiesSelectable.set(value);\n  }\n\n  @Input()\n  public set keyboardShortcuts(value: KeyboardShortcuts) {\n    this.keyboardService.setShortcuts(value);\n  }\n\n  /**\n   * Settings for connection (it renders when user tries to create edge between nodes)\n   *\n   * You need to pass `ConnectionSettings` in this input.\n   */\n  @Input({\n    transform: (settings: ConnectionSettings) => new ConnectionModel(settings),\n  })\n  public set connection(connection: ConnectionModel) {\n    this.flowEntitiesService.connection.set(connection);\n  }\n\n  public get connection() {\n    return this.flowEntitiesService.connection();\n  }\n  // #endregion\n\n  // #region MAIN_INPUTS\n  /**\n   * Nodes to render\n   */\n  @Input({ required: true })\n  public set nodes(newNodes: Node[] | DynamicNode[]) {\n    const newModels = runInInjectionContext(this.injector, () =>\n      ReferenceKeeper.nodes(newNodes, this.flowEntitiesService.nodes()),\n    );\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(newModels, this.flowEntitiesService.edges());\n\n    this.flowEntitiesService.nodes.set(newModels);\n  }\n\n  protected nodeModels = computed(() => this.nodeRenderingService.nodes());\n  protected groups = computed(() => this.nodeRenderingService.groups());\n  protected nonGroups = computed(() => this.nodeRenderingService.nonGroups());\n\n  /**\n   * Edges to render\n   */\n  @Input()\n  public set edges(newEdges: Edge[]) {\n    const newModels = runInInjectionContext(this.injector, () =>\n      ReferenceKeeper.edges(newEdges, this.flowEntitiesService.edges()),\n    );\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(this.nodeModels(), newModels);\n\n    this.flowEntitiesService.edges.set(newModels);\n  }\n\n  protected edgeModels = computed(() => this.flowEntitiesService.validEdges());\n  // #endregion\n\n  // #region OUTPUTS\n  /**\n   * Event that accumulates all custom node events\n   *\n   * @experimental\n   */\n  public onComponentNodeEvent = outputFromObservable<any>(\n    this.componentEventBusService.event$,\n  ); // TODO: research how to remove any\n  // #endregion\n\n  // #region TEMPLATES\n  protected nodeTemplateDirective = contentChild(NodeHtmlTemplateDirective);\n\n  protected groupNodeTemplateDirective = contentChild(\n    GroupNodeTemplateDirective,\n  );\n\n  protected edgeTemplateDirective = contentChild(EdgeTemplateDirective);\n\n  protected edgeLabelHtmlDirective = contentChild(\n    EdgeLabelHtmlTemplateDirective,\n  );\n\n  protected connectionTemplateDirective = contentChild(\n    ConnectionTemplateDirective,\n  );\n  // #endregion\n\n  // #region DIRECTIVES\n  protected mapContext = viewChild(MapContextDirective);\n\n  protected spacePointContext = viewChild.required(SpacePointContextDirective);\n  // #endregion\n\n  // #region SIGNAL_API\n  /**\n   * Signal for reading viewport change\n   */\n  public readonly viewport = this.viewportService.readableViewport.asReadonly();\n\n  /**\n   * Signal for reading nodes change\n   */\n  public readonly nodesChange = toSignal(this.nodesChangeService.changes$, {\n    initialValue: [] as NodeChange[],\n  });\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange = toSignal(this.edgesChangeService.changes$, {\n    initialValue: [] as EdgeChange[],\n  });\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(\n    this.viewportService.readableViewport,\n  ).pipe(skip(1)); // skip default value that set by signal\n\n  /**\n   * Observable with nodes change\n   */\n  public readonly nodesChange$ = this.nodesChangeService.changes$;\n\n  /**\n   * Observable with edges change\n   */\n  public readonly edgesChange$ = this.edgesChangeService.changes$;\n  // #endregion\n\n  protected markers = this.flowEntitiesService.markers;\n\n  protected minimap = this.flowEntitiesService.minimap;\n\n  public ngOnInit(): void {\n    this.setInitialNodesOrder();\n  }\n\n  // #region METHODS_API\n  /**\n   * Change viewport to specified state\n   *\n   * @param viewport viewport state\n   */\n  public viewportTo(viewport: ViewportState): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: viewport,\n      duration: 0,\n    });\n  }\n\n  /**\n   * Change zoom\n   *\n   * @param zoom zoom value\n   */\n  public zoomTo(zoom: number): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: { zoom },\n      duration: 0,\n    });\n  }\n\n  /**\n   * Move to specified coordinate\n   *\n   * @param point point where to move\n   */\n  public panTo(point: Point): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: point,\n      duration: 0,\n    });\n  }\n\n  public fitView(options?: FitViewOptions) {\n    this.viewportService.fitView(options);\n  }\n\n  /**\n   * Get node by id\n   *\n   * @param id node id\n   */\n  public getNode<T = unknown>(\n    id: string,\n  ): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.node;\n  }\n\n  /**\n   * Sync method to get detached edges\n   */\n  public getDetachedEdges(): Edge[] {\n    return this.flowEntitiesService.getDetachedEdges().map((e) => e.edge);\n  }\n\n  /**\n   * Convert point received from document to point on the flow\n   */\n  public documentPointToFlowPoint(point: Point): Point {\n    return this.spacePointContext().documentPointToFlowPoint(point);\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { node }: NodeModel) {\n    return node;\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge;\n  }\n\n  private setInitialNodesOrder() {\n    this.nodeModels().forEach((model) => {\n      switch (model.node.type) {\n        case 'default-group':\n        case 'template-group': {\n          this.nodeRenderingService.pullNode(model);\n        }\n      }\n    });\n  }\n}\n","<svg:svg\n  rootSvgRef\n  rootSvgContext\n  rootPointer\n  flowSizeController\n  class=\"root-svg\"\n  #flow\n>\n  <defs [markers]=\"markers()\" flowDefs />\n\n  <g background />\n\n  <svg:g mapContext spacePointContext>\n    <!-- Connection -->\n    <svg:g\n      connection\n      [model]=\"connection\"\n      [template]=\"connectionTemplateDirective()?.templateRef\"\n    />\n\n    @if (optimization().detachedGroupsLayer) {\n      <!-- Groups -->\n      @for (model of groups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [nodeModel]=\"model\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\"\n        />\n      }\n      <!-- Edges  -->\n      @for (model of edgeModels(); track trackEdges($index, model)) {\n        <svg:g\n          edge\n          [model]=\"model\"\n          [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n          [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n        />\n      }\n      <!-- Nodes -->\n      @for (model of nonGroups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [nodeModel]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\"\n        />\n      }\n    }\n\n    @if (!optimization().detachedGroupsLayer) {\n      <!-- Edges  -->\n      @for (model of edgeModels(); track trackEdges($index, model)) {\n        <svg:g\n          edge\n          [model]=\"model\"\n          [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n          [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\"\n        />\n      }\n      <!-- Nodes -->\n      @for (model of nodeModels(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [nodeModel]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\"\n        />\n      }\n    }\n  </svg:g>\n\n  <!-- Minimap -->\n  @if (minimap(); as minimap) {\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  }\n</svg:svg>\n"]}
|
|
@@ -15,4 +15,4 @@ export function InjectionContext(target, key, descriptor) {
|
|
|
15
15
|
const implementsWithInjector = (instance) => {
|
|
16
16
|
return 'injector' in instance && 'get' in instance.injector;
|
|
17
17
|
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVuLWluLWluamVjdGlvbi1jb250ZXh0LmRlY29yYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9kZWNvcmF0b3JzL3J1bi1pbi1pbmplY3Rpb24tY29udGV4dC5kZWNvcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUErQixxQkFBcUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRixNQUFNLFVBQVUsZ0JBQWdCLENBQUMsTUFBVyxFQUFFLEdBQVcsRUFBRSxVQUE4QjtJQUN2RixNQUFNLGNBQWMsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDO0lBRXhDLFVBQVUsQ0FBQyxLQUFLLEdBQUcsVUFBVSxHQUFHLElBQVc7UUFDekMsSUFBSSxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ2pDLE9BQU8scUJBQXFCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFBO1FBQ3JGLENBQUM7YUFBTSxDQUFDO1lBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQywrRUFBK0UsQ0FBQyxDQUFBO1FBQ2xHLENBQUM7SUFDSCxDQUFDLENBQUM7SUFFRixpQ0FBaUM7SUFDakMsT0FBTyxVQUFVLENBQUM7QUFDcEIsQ0FBQztBQU1ELE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxRQUFZLEVBQTRCLEVBQUU7SUFDeEUsT0FBTyxVQUFVLElBQUksUUFBUSxJQUFJLEtBQUssSUFBSyxRQUFRLENBQUMsUUFBcUIsQ0FBQztBQUM1RSxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEluamVjdG9yLCBpbmplY3QsIHJ1bkluSW5qZWN0aW9uQ29udGV4dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBJbmplY3Rpb25Db250ZXh0KHRhcmdldDogYW55LCBrZXk6IHN0cmluZywgZGVzY3JpcHRvcjogUHJvcGVydHlEZXNjcmlwdG9yKSB7XG4gIGNvbnN0IG9yaWdpbmFsTWV0aG9kID0gZGVzY3JpcHRvci52YWx1ZTtcblxuICBkZXNjcmlwdG9yLnZhbHVlID0gZnVuY3Rpb24gKC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgaWYgKGltcGxlbWVudHNXaXRoSW5qZWN0b3IodGhpcykpIHtcbiAgICAgIHJldHVybiBydW5JbkluamVjdGlvbkNvbnRleHQodGhpcy5pbmplY3RvciwgKCkgPT4gb3JpZ2luYWxNZXRob2QuYXBwbHkodGhpcywgYXJncykpXG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2xhc3MgdGhhdCBjb250YWlucyBkZWNvcmF0ZWQgbWV0aG9kIG11c3QgZXh0ZW5kcyBXaXRoSW5qZWN0b3JEaXJlY3RpdmUgY2xhc3MnKVxuICAgIH1cbiAgfTtcblxuICAvLyBSZXR1cm4gdGhlIG1vZGlmaWVkIGRlc2NyaXB0b3JcbiAgcmV0dXJuIGRlc2NyaXB0b3I7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2l0aEluamVjdG9yIHtcbiAgaW5qZWN0b3I6IEluamVjdG9yXG59XG5cbmNvbnN0IGltcGxlbWVudHNXaXRoSW5qZWN0b3IgPSAoaW5zdGFuY2U6IHt9KTogaW5zdGFuY2UgaXMgV2l0aEluamVjdG9yID0+IHtcbiAgcmV0dXJuICdpbmplY3RvcicgaW4gaW5zdGFuY2UgJiYgJ2dldCcgaW4gKGluc3RhbmNlLmluamVjdG9yIGFzIEluamVjdG9yKTtcbn1cbiJdfQ==
|