ngx-vflow 1.15.0 → 1.16.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/esm2022/lib/vflow/components/alignment-helper/alignment-helper.component.mjs +103 -0
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +8 -5
- package/esm2022/lib/vflow/interfaces/alignment-helper-settings.interface.mjs +2 -0
- package/esm2022/lib/vflow/interfaces/rect.mjs +10 -2
- package/esm2022/lib/vflow/services/draggable.service.mjs +7 -1
- package/esm2022/lib/vflow/services/flow-status.service.mjs +13 -1
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/testing/component-mocks/vflow-mock.component.mjs +4 -3
- package/fesm2022/ngx-vflow-testing.mjs +3 -2
- package/fesm2022/ngx-vflow-testing.mjs.map +1 -1
- package/fesm2022/ngx-vflow.mjs +160 -38
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/alignment-helper/alignment-helper.component.d.ts +21 -0
- package/lib/vflow/components/vflow/vflow.component.d.ts +3 -1
- package/lib/vflow/interfaces/alignment-helper-settings.interface.d.ts +4 -0
- package/lib/vflow/interfaces/rect.d.ts +7 -0
- package/lib/vflow/services/draggable.service.d.ts +1 -0
- package/lib/vflow/services/flow-status.service.d.ts +17 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/testing/component-mocks/vflow-mock.component.d.ts +3 -2
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';
|
|
2
|
+
import { nodeToRect } from '../../utils/nodes';
|
|
3
|
+
import { FlowStatusService, isNodeDragEndStatus, isNodeDragStartStatus } from '../../services/flow-status.service';
|
|
4
|
+
import { rectToRectWithSides } from '../../interfaces/rect';
|
|
5
|
+
import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { filter, map, tap } from 'rxjs';
|
|
7
|
+
import { extendedComputed } from '../../utils/signals/extended-computed';
|
|
8
|
+
import { NodeRenderingService } from '../../services/node-rendering.service';
|
|
9
|
+
import { getSpacePoints } from '../../utils/get-space-points';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class AlignmentHelperComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.nodeRenderingService = inject(NodeRenderingService);
|
|
14
|
+
this.flowStatus = inject(FlowStatusService);
|
|
15
|
+
this.tolerance = input(10);
|
|
16
|
+
this.lineColor = input('#1b262c');
|
|
17
|
+
this.isNodeDragging = computed(() => isNodeDragStartStatus(this.flowStatus.status()));
|
|
18
|
+
this.intersections = extendedComputed((lastValue) => {
|
|
19
|
+
const status = this.flowStatus.status();
|
|
20
|
+
if (isNodeDragStartStatus(status)) {
|
|
21
|
+
const node = status.payload.node;
|
|
22
|
+
const d = rectToRectWithSides(nodeToRect(node));
|
|
23
|
+
const otherRects = this.nodeRenderingService
|
|
24
|
+
.viewportNodes()
|
|
25
|
+
.filter((n) => n !== node)
|
|
26
|
+
// do not check children of the dragged node
|
|
27
|
+
.filter((n) => !node.children().includes(n))
|
|
28
|
+
.map((n) => rectToRectWithSides(nodeToRect(n)));
|
|
29
|
+
const lines = [];
|
|
30
|
+
let snappedX = d.x;
|
|
31
|
+
let snappedY = d.y;
|
|
32
|
+
let closestXDiff = Infinity;
|
|
33
|
+
let closestYDiff = Infinity;
|
|
34
|
+
otherRects.forEach((o) => {
|
|
35
|
+
const dCenterX = d.left + d.width / 2;
|
|
36
|
+
const oCenterX = o.left + o.width / 2;
|
|
37
|
+
for (const [dX, oX, snapX, isCenter] of [
|
|
38
|
+
// center check
|
|
39
|
+
[dCenterX, oCenterX, oCenterX - d.width / 2, true],
|
|
40
|
+
[d.left, o.left, o.left, false],
|
|
41
|
+
[d.left, o.right, o.right, false],
|
|
42
|
+
[d.right, o.left, o.left - d.width, false],
|
|
43
|
+
[d.right, o.right, o.right - d.width, false],
|
|
44
|
+
]) {
|
|
45
|
+
const diff = Math.abs(dX - oX);
|
|
46
|
+
if (diff <= this.tolerance()) {
|
|
47
|
+
const y = Math.min(d.top, o.top);
|
|
48
|
+
const y2 = Math.max(d.bottom, o.bottom);
|
|
49
|
+
lines.push({ x: oX, y, x2: oX, y2, isCenter });
|
|
50
|
+
if (diff < closestXDiff) {
|
|
51
|
+
closestXDiff = diff;
|
|
52
|
+
snappedX = snapX;
|
|
53
|
+
}
|
|
54
|
+
if (isCenter)
|
|
55
|
+
break;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
const dCenterY = d.top + d.height / 2;
|
|
59
|
+
const oCenterY = o.top + o.height / 2;
|
|
60
|
+
for (const [dY, oY, snapY, isCenter] of [
|
|
61
|
+
// center check
|
|
62
|
+
[dCenterY, oCenterY, oCenterY - d.height / 2, true],
|
|
63
|
+
[d.top, o.top, o.top, false],
|
|
64
|
+
[d.top, o.bottom, o.bottom, false],
|
|
65
|
+
[d.bottom, o.top, o.top - d.height, false],
|
|
66
|
+
[d.bottom, o.bottom, o.bottom - d.height, false],
|
|
67
|
+
]) {
|
|
68
|
+
const diff = Math.abs(dY - oY);
|
|
69
|
+
if (diff <= this.tolerance()) {
|
|
70
|
+
const x = Math.min(d.left, o.left);
|
|
71
|
+
const x2 = Math.max(d.right, o.right);
|
|
72
|
+
lines.push({ x, y: oY, x2, y2: oY, isCenter });
|
|
73
|
+
if (diff < closestYDiff) {
|
|
74
|
+
closestYDiff = diff;
|
|
75
|
+
snappedY = snapY;
|
|
76
|
+
}
|
|
77
|
+
if (isCenter)
|
|
78
|
+
break;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
return { lines, snappedX, snappedY };
|
|
83
|
+
}
|
|
84
|
+
return lastValue;
|
|
85
|
+
});
|
|
86
|
+
toObservable(this.flowStatus.status)
|
|
87
|
+
.pipe(filter(isNodeDragEndStatus), map((status) => status.payload.node), map((node) => [node, this.intersections()]), tap(([node, intersections]) => {
|
|
88
|
+
if (intersections) {
|
|
89
|
+
const snapped = { x: intersections.snappedX, y: intersections.snappedY };
|
|
90
|
+
const parentIfExists = node.parent() ? [node.parent()] : [];
|
|
91
|
+
node.setPoint(getSpacePoints(snapped, parentIfExists)[0]);
|
|
92
|
+
}
|
|
93
|
+
}), takeUntilDestroyed())
|
|
94
|
+
.subscribe();
|
|
95
|
+
}
|
|
96
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AlignmentHelperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
97
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: AlignmentHelperComponent, isStandalone: true, selector: "g[alignmentHelper]", inputs: { tolerance: { classPropertyName: "tolerance", publicName: "tolerance", isSignal: true, isRequired: false, transformFunction: null }, lineColor: { classPropertyName: "lineColor", publicName: "lineColor", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (isNodeDragging()) {\n @if (intersections(); as intersections) {\n @for (intersection of intersections.lines; track $index) {\n <svg:line\n [attr.stroke]=\"lineColor()\"\n [attr.stroke-dasharray]=\"intersection.isCenter ? 4 : null\"\n [attr.x1]=\"intersection.x\"\n [attr.y1]=\"intersection.y\"\n [attr.x2]=\"intersection.x2\"\n [attr.y2]=\"intersection.y2\" />\n }\n }\n}\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
98
|
+
}
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AlignmentHelperComponent, decorators: [{
|
|
100
|
+
type: Component,
|
|
101
|
+
args: [{ selector: 'g[alignmentHelper]', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "@if (isNodeDragging()) {\n @if (intersections(); as intersections) {\n @for (intersection of intersections.lines; track $index) {\n <svg:line\n [attr.stroke]=\"lineColor()\"\n [attr.stroke-dasharray]=\"intersection.isCenter ? 4 : null\"\n [attr.x1]=\"intersection.x\"\n [attr.y1]=\"intersection.y\"\n [attr.x2]=\"intersection.x2\"\n [attr.y2]=\"intersection.y2\" />\n }\n }\n}\n" }]
|
|
102
|
+
}], ctorParameters: () => [] });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alignment-helper.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/alignment-helper/alignment-helper.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/alignment-helper/alignment-helper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, inject, input } from '@angular/core';\nimport { nodeToRect } from '../../utils/nodes';\nimport { FlowStatusService, isNodeDragEndStatus, isNodeDragStartStatus } from '../../services/flow-status.service';\nimport { rectToRectWithSides } from '../../interfaces/rect';\nimport { Box } from '../../interfaces/box';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { filter, map, tap } from 'rxjs';\nimport { extendedComputed } from '../../utils/signals/extended-computed';\nimport { NodeRenderingService } from '../../services/node-rendering.service';\nimport { getSpacePoints } from '../../utils/get-space-points';\n\ninterface Intersection {\n  lines: (Box & { isCenter: boolean })[];\n  snappedX: number;\n  snappedY: number;\n}\n\n@Component({\n  selector: 'g[alignmentHelper]',\n  templateUrl: './alignment-helper.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n})\nexport class AlignmentHelperComponent {\n  private nodeRenderingService = inject(NodeRenderingService);\n  private flowStatus = inject(FlowStatusService);\n\n  readonly tolerance = input(10);\n  readonly lineColor = input('#1b262c');\n\n  protected isNodeDragging = computed(() => isNodeDragStartStatus(this.flowStatus.status()));\n\n  protected readonly intersections = extendedComputed<Intersection>((lastValue) => {\n    const status = this.flowStatus.status();\n\n    if (isNodeDragStartStatus(status)) {\n      const node = status.payload.node;\n\n      const d = rectToRectWithSides(nodeToRect(node));\n      const otherRects = this.nodeRenderingService\n        .viewportNodes()\n        .filter((n) => n !== node)\n        // do not check children of the dragged node\n        .filter((n) => !node.children().includes(n))\n        .map((n) => rectToRectWithSides(nodeToRect(n)));\n\n      const lines: Intersection['lines'] = [];\n\n      let snappedX = d.x;\n      let snappedY = d.y;\n      let closestXDiff = Infinity;\n      let closestYDiff = Infinity;\n\n      otherRects.forEach((o) => {\n        const dCenterX = d.left + d.width / 2;\n        const oCenterX = o.left + o.width / 2;\n\n        for (const [dX, oX, snapX, isCenter] of [\n          // center check\n          [dCenterX, oCenterX, oCenterX - d.width / 2, true] as const,\n          [d.left, o.left, o.left, false] as const,\n          [d.left, o.right, o.right, false] as const,\n          [d.right, o.left, o.left - d.width, false] as const,\n          [d.right, o.right, o.right - d.width, false] as const,\n        ]) {\n          const diff = Math.abs(dX - oX);\n\n          if (diff <= this.tolerance()) {\n            const y = Math.min(d.top, o.top);\n            const y2 = Math.max(d.bottom, o.bottom);\n\n            lines.push({ x: oX, y, x2: oX, y2, isCenter });\n\n            if (diff < closestXDiff) {\n              closestXDiff = diff;\n              snappedX = snapX;\n            }\n\n            if (isCenter) break;\n          }\n        }\n\n        const dCenterY = d.top + d.height / 2;\n        const oCenterY = o.top + o.height / 2;\n\n        for (const [dY, oY, snapY, isCenter] of [\n          // center check\n          [dCenterY, oCenterY, oCenterY - d.height / 2, true] as const,\n          [d.top, o.top, o.top, false] as const,\n          [d.top, o.bottom, o.bottom, false] as const,\n          [d.bottom, o.top, o.top - d.height, false] as const,\n          [d.bottom, o.bottom, o.bottom - d.height, false] as const,\n        ]) {\n          const diff = Math.abs(dY - oY);\n\n          if (diff <= this.tolerance()) {\n            const x = Math.min(d.left, o.left);\n            const x2 = Math.max(d.right, o.right);\n\n            lines.push({ x, y: oY, x2, y2: oY, isCenter });\n\n            if (diff < closestYDiff) {\n              closestYDiff = diff;\n              snappedY = snapY;\n            }\n\n            if (isCenter) break;\n          }\n        }\n      });\n\n      return { lines, snappedX, snappedY };\n    }\n\n    return lastValue;\n  });\n\n  constructor() {\n    toObservable(this.flowStatus.status)\n      .pipe(\n        filter(isNodeDragEndStatus),\n        map((status) => status.payload.node),\n        map((node) => [node, this.intersections()] as const),\n        tap(([node, intersections]) => {\n          if (intersections) {\n            const snapped = { x: intersections.snappedX, y: intersections.snappedY };\n            const parentIfExists = node.parent() ? [node.parent()!] : [];\n\n            node.setPoint(getSpacePoints(snapped, parentIfExists)[0]);\n          }\n        }),\n        takeUntilDestroyed(),\n      )\n      .subscribe();\n  }\n}\n","@if (isNodeDragging()) {\n  @if (intersections(); as intersections) {\n    @for (intersection of intersections.lines; track $index) {\n      <svg:line\n        [attr.stroke]=\"lineColor()\"\n        [attr.stroke-dasharray]=\"intersection.isCenter ? 4 : null\"\n        [attr.x1]=\"intersection.x\"\n        [attr.y1]=\"intersection.y\"\n        [attr.x2]=\"intersection.x2\"\n        [attr.y2]=\"intersection.y2\" />\n    }\n  }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Injector, Input, inject, runInInjectionContext, contentChild, viewChild, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Injector, Input, inject, runInInjectionContext, contentChild, viewChild, input, } 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';
|
|
@@ -38,6 +38,7 @@ import { PreviewFlowComponent } from '../preview-flow/preview-flow.component';
|
|
|
38
38
|
import { PreviewFlowRenderStrategyService, ViewportPreviewFlowRenderStrategyService, } from '../../services/preview-flow-render-strategy.service';
|
|
39
39
|
import { toLazySignal } from '../../utils/signals/to-lazy-signal';
|
|
40
40
|
import { FlowRenderingService } from '../../services/flow-rendering.service';
|
|
41
|
+
import { AlignmentHelperComponent } from '../alignment-helper/alignment-helper.component';
|
|
41
42
|
import * as i0 from "@angular/core";
|
|
42
43
|
import * as i1 from "../../directives/changes-controller.directive";
|
|
43
44
|
const changesControllerHostDirective = {
|
|
@@ -88,6 +89,7 @@ export class VflowComponent {
|
|
|
88
89
|
this.keyboardService = inject(KeyboardService);
|
|
89
90
|
this.injector = inject(Injector);
|
|
90
91
|
this.flowRenderingService = inject(FlowRenderingService);
|
|
92
|
+
this.alignmentHelper = input(false);
|
|
91
93
|
this.nodeModels = this.nodeRenderingService.nodes;
|
|
92
94
|
this.groups = this.nodeRenderingService.groups;
|
|
93
95
|
this.nonGroups = this.nodeRenderingService.nonGroups;
|
|
@@ -349,7 +351,7 @@ export class VflowComponent {
|
|
|
349
351
|
return edge;
|
|
350
352
|
}
|
|
351
353
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
352
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: VflowComponent, isStandalone: true, selector: "vflow", inputs: { view: "view", minZoom: "minZoom", maxZoom: "maxZoom", background: "background", optimization: "optimization", entitiesSelectable: "entitiesSelectable", keyboardShortcuts: "keyboardShortcuts", connection:
|
|
354
|
+
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: false, 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 }, nodes: { classPropertyName: "nodes", publicName: "nodes", isSignal: false, isRequired: true, transformFunction: null }, alignmentHelper: { classPropertyName: "alignmentHelper", publicName: "alignmentHelper", isSignal: true, isRequired: false, transformFunction: null }, edges: { classPropertyName: "edges", publicName: "edges", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onComponentNodeEvent: "onComponentNodeEvent" }, providers: [
|
|
353
355
|
DraggableService,
|
|
354
356
|
ViewportService,
|
|
355
357
|
FlowStatusService,
|
|
@@ -365,7 +367,7 @@ export class VflowComponent {
|
|
|
365
367
|
OverlaysService,
|
|
366
368
|
{ provide: PreviewFlowRenderStrategyService, useClass: ViewportPreviewFlowRenderStrategyService },
|
|
367
369
|
FlowRenderingService,
|
|
368
|
-
], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "nodeSvgTemplateDirective", first: true, predicate: NodeSvgTemplateDirective, 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.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 #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (flowOptimization().detachedGroupsLayer) {\n <!-- Groups -->\n @for (model of groups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\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 <!-- Nodes -->\n @for (model of nonGroups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n\n @if (!flowOptimization().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 @for (model of nodeModels(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n\n@if (flowOptimization().virtualization) {\n <canvas previewFlow class=\"preview-flow\" [width]=\"flowWidth()\" [height]=\"flowHeight()\"></canvas>\n}\n", styles: [":host{display:grid;grid-template-columns:1fr;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}.root-svg{grid-row-start:1;grid-column-start:1}.preview-flow{pointer-events:none;grid-row-start:1;grid-column-start:1}\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: ["model", "nodeTemplate", "nodeSvgTemplate", "groupNodeTemplate"] }, { kind: "component", type: EdgeComponent, selector: "g[edge]", inputs: ["model", "edgeTemplate", "edgeLabelHtmlTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: PreviewFlowComponent, selector: "canvas[previewFlow]", inputs: ["width", "height"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
370
|
+
], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "nodeSvgTemplateDirective", first: true, predicate: NodeSvgTemplateDirective, 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.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 #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n @if (alignmentHelper(); as alignmentHelper) {\n @if (alignmentHelper === true) {\n <svg:g alignmentHelper />\n } @else {\n <svg:g alignmentHelper [tolerance]=\"alignmentHelper.tolerance\" [lineColor]=\"alignmentHelper.lineColor\" />\n }\n }\n\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (flowOptimization().detachedGroupsLayer) {\n <!-- Groups -->\n @for (model of groups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\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 <!-- Nodes -->\n @for (model of nonGroups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n\n @if (!flowOptimization().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 @for (model of nodeModels(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n\n@if (flowOptimization().virtualization) {\n <canvas previewFlow class=\"preview-flow\" [width]=\"flowWidth()\" [height]=\"flowHeight()\"></canvas>\n}\n", styles: [":host{display:grid;grid-template-columns:1fr;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}.root-svg{grid-row-start:1;grid-column-start:1}.preview-flow{pointer-events:none;grid-row-start:1;grid-column-start:1}\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: ["model", "nodeTemplate", "nodeSvgTemplate", "groupNodeTemplate"] }, { kind: "component", type: EdgeComponent, selector: "g[edge]", inputs: ["model", "edgeTemplate", "edgeLabelHtmlTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: PreviewFlowComponent, selector: "canvas[previewFlow]", inputs: ["width", "height"] }, { kind: "component", type: AlignmentHelperComponent, selector: "g[alignmentHelper]", inputs: ["tolerance", "lineColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
369
371
|
}
|
|
370
372
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, decorators: [{
|
|
371
373
|
type: Component,
|
|
@@ -399,7 +401,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
399
401
|
EdgeComponent,
|
|
400
402
|
NgTemplateOutlet,
|
|
401
403
|
PreviewFlowComponent,
|
|
402
|
-
|
|
404
|
+
AlignmentHelperComponent,
|
|
405
|
+
], template: "<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n @if (alignmentHelper(); as alignmentHelper) {\n @if (alignmentHelper === true) {\n <svg:g alignmentHelper />\n } @else {\n <svg:g alignmentHelper [tolerance]=\"alignmentHelper.tolerance\" [lineColor]=\"alignmentHelper.lineColor\" />\n }\n }\n\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (flowOptimization().detachedGroupsLayer) {\n <!-- Groups -->\n @for (model of groups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\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 <!-- Nodes -->\n @for (model of nonGroups(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n\n @if (!flowOptimization().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 @for (model of nodeModels(); track trackNodes($index, model)) {\n <svg:g\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n\n@if (flowOptimization().virtualization) {\n <canvas previewFlow class=\"preview-flow\" [width]=\"flowWidth()\" [height]=\"flowHeight()\"></canvas>\n}\n", styles: [":host{display:grid;grid-template-columns:1fr;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}.root-svg{grid-row-start:1;grid-column-start:1}.preview-flow{pointer-events:none;grid-row-start:1;grid-column-start:1}\n"] }]
|
|
403
406
|
}], propDecorators: { view: [{
|
|
404
407
|
type: Input
|
|
405
408
|
}], minZoom: [{
|
|
@@ -431,4 +434,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
431
434
|
}], edges: [{
|
|
432
435
|
type: Input
|
|
433
436
|
}] } });
|
|
434
|
-
//# 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":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n  inject,\n  runInInjectionContext,\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 { toObservable, outputFromObservable } 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  NodeSvgTemplateDirective,\n} from '../../directives/template.directive';\nimport { addNodesToEdges } from '../../utils/add-nodes-to-edges';\nimport { skip } from 'rxjs';\nimport { SpacePoint, Point } from '../../interfaces/point.interface';\nimport { ViewportState } from '../../interfaces/viewport.interface';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { ConnectionSettings } from '../../interfaces/connection-settings.interface';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { ReferenceIdentityChecker } from '../../utils/identity-checker/reference-identity-checker';\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';\nimport { EdgeRenderingService } from '../../services/edge-rendering.service';\nimport { getSpacePoints } from '../../utils/get-space-points';\nimport { getIntesectingNodes } from '../../utils/nodes';\nimport { IntersectingNodesOptions } from '../../interfaces/intersecting-nodes-options.interface';\nimport { PreviewFlowComponent } from '../preview-flow/preview-flow.component';\nimport {\n  PreviewFlowRenderStrategyService,\n  ViewportPreviewFlowRenderStrategyService,\n} from '../../services/preview-flow-render-strategy.service';\nimport { toLazySignal } from '../../utils/signals/to-lazy-signal';\nimport { FlowRenderingService } from '../../services/flow-rendering.service';\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    EdgeRenderingService,\n    SelectionService,\n    FlowSettingsService,\n    ComponentEventBusService,\n    KeyboardService,\n    OverlaysService,\n    { provide: PreviewFlowRenderStrategyService, useClass: ViewportPreviewFlowRenderStrategyService },\n    FlowRenderingService,\n  ],\n  hostDirectives: [changesControllerHostDirective],\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    PreviewFlowComponent,\n  ],\n})\nexport class VflowComponent {\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 edgeRenderingService = inject(EdgeRenderingService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private componentEventBusService = inject(ComponentEventBusService);\n  private keyboardService = inject(KeyboardService);\n  private injector = inject(Injector);\n  private flowRenderingService = inject(FlowRenderingService);\n\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  @Input()\n  public set optimization(newOptimization: Optimization) {\n    this.flowSettingsService.optimization.update((optimization) => ({\n      ...optimization,\n      ...newOptimization,\n    }));\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\n  /**\n   * Snap grid for node movement. Passes as [x, y]\n   */\n  @Input()\n  public set snapGrid(value: [number, number]) {\n    this.flowSettingsService.snapGrid.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected node\n   */\n  @Input()\n  public set elevateNodesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateNodesOnSelect.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected edge\n   */\n  @Input()\n  public set elevateEdgesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateEdgesOnSelect.set(value);\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 models = runInInjectionContext(this.injector, () =>\n      ReferenceIdentityChecker.nodes(newNodes, this.flowEntitiesService.nodes()),\n    );\n\n    // TODO: consider calling only fo new nodes\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(models, this.flowEntitiesService.edges());\n\n    this.flowEntitiesService.nodes.set(models);\n\n    models.forEach((model) => this.nodeRenderingService.pullNode(model));\n  }\n\n  protected nodeModels = this.nodeRenderingService.nodes;\n  protected groups = this.nodeRenderingService.groups;\n  protected nonGroups = 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      ReferenceIdentityChecker.edges(newEdges, this.flowEntitiesService.edges()),\n    );\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(this.flowEntitiesService.nodes(), newModels);\n\n    this.flowEntitiesService.edges.set(newModels);\n  }\n\n  protected edgeModels = this.edgeRenderingService.edges;\n  // #endregion\n\n  // #region OUTPUTS\n  /**\n   * Event that accumulates all custom node events\n   *\n   * @experimental\n   */\n  public readonly onComponentNodeEvent = outputFromObservable<any>(this.componentEventBusService.event$); // TODO: research how to remove any\n  // #endregion\n\n  // #region TEMPLATES\n  protected nodeTemplateDirective = contentChild(NodeHtmlTemplateDirective);\n\n  protected nodeSvgTemplateDirective = contentChild(NodeSvgTemplateDirective);\n\n  protected groupNodeTemplateDirective = contentChild(GroupNodeTemplateDirective);\n\n  protected edgeTemplateDirective = contentChild(EdgeTemplateDirective);\n\n  protected edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateDirective);\n\n  protected connectionTemplateDirective = contentChild(ConnectionTemplateDirective);\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 = toLazySignal(this.nodesChangeService.changes$, {\n    initialValue: [] as NodeChange[],\n  });\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange = toLazySignal(this.edgesChangeService.changes$, {\n    initialValue: [] as EdgeChange[],\n  });\n\n  public readonly initialized = this.flowRenderingService.flowInitialized.asReadonly();\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(this.viewportService.readableViewport).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\n  public readonly initialized$ = toObservable(this.flowRenderingService.flowInitialized);\n  // #endregion\n\n  protected markers = this.flowEntitiesService.markers;\n  protected minimap = this.flowEntitiesService.minimap;\n\n  protected flowOptimization = this.flowSettingsService.optimization;\n  protected flowWidth = this.flowSettingsService.computedFlowWidth;\n  protected flowHeight = this.flowSettingsService.computedFlowHeight;\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>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.rawNode;\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  public documentPointToFlowPoint(point: Point, options?: { spaces: false }): Point;\n  /**\n   * Convert point received from document to a stack of space points on the flow\n   * Space point has a spaceNodeId, coordinates are relative to this node\n   */\n  public documentPointToFlowPoint(point: Point, options?: { spaces: true }): SpacePoint[];\n  public documentPointToFlowPoint(point: Point, options?: { spaces: boolean }): unknown {\n    const transformedPoint = this.spacePointContext().documentPointToFlowPoint(point);\n\n    if (options?.spaces) {\n      return getSpacePoints(transformedPoint, this.nodeRenderingService.groups());\n    }\n\n    return transformedPoint;\n  }\n\n  /**\n   * Gets nodes that intersect with the specified node\n   *\n   * @template T - The type of data associated with the nodes\n   * @param nodeId - The ID of the node to check intersections for\n   * @param options.partially - If true, returns nodes that partially intersect. If false, only returns fully intersecting nodes\n   * @returns An array of nodes that intersect with the specified node\n   */\n  public getIntesectingNodes<T>(\n    nodeId: string,\n    options: IntersectingNodesOptions = { partially: true },\n  ): Node<T>[] | DynamicNode<T>[] {\n    return getIntesectingNodes(nodeId, this.nodeModels(), options).map((n) => n.rawNode) as\n      | Node<T>[]\n      | DynamicNode<T>[];\n  }\n\n  /**\n   * Converts a node's position to the coordinate space of another node\n   *\n   * @param nodeId - The ID of the node whose position should be converted\n   * @param spaceNodeId - The ID of the node that defines the target coordinate space.\n   *                      If null, returns the position in global coordinates\n   * @returns {Point} The converted position. Returns {x: Infinity, y: Infinity} if either node is not found\n   */\n  public toNodeSpace(nodeId: string, spaceNodeId: string | null): Point {\n    const node = this.nodeModels().find((n) => n.rawNode.id === nodeId);\n\n    if (!node) return { x: Infinity, y: Infinity };\n\n    if (spaceNodeId === null) {\n      return node.globalPoint();\n    }\n\n    const coordinateSpaceNode = this.nodeModels().find((n) => n.rawNode.id === spaceNodeId);\n\n    if (!coordinateSpaceNode) return { x: Infinity, y: Infinity };\n\n    return getSpacePoints(node.globalPoint(), [coordinateSpaceNode])[0];\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { rawNode: node }: NodeModel) {\n    return node;\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge;\n  }\n}\n","<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n  <defs flowDefs [markers]=\"markers()\" />\n\n  <g background />\n\n  <svg:g mapContext spacePointContext>\n    <!-- Connection -->\n    <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n    @if (flowOptimization().detachedGroupsLayer) {\n      <!-- Groups -->\n      @for (model of groups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\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      <!-- Nodes -->\n      @for (model of nonGroups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\n      }\n    }\n\n    @if (!flowOptimization().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      @for (model of nodeModels(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\n      }\n    }\n  </svg:g>\n\n  <!-- Minimap -->\n  @if (minimap(); as minimap) {\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  }\n</svg:svg>\n\n@if (flowOptimization().virtualization) {\n  <canvas previewFlow class=\"preview-flow\" [width]=\"flowWidth()\" [height]=\"flowHeight()\"></canvas>\n}\n"]}
|
|
437
|
+
//# 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":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Injector,\n  Input,\n  inject,\n  runInInjectionContext,\n  contentChild,\n  viewChild,\n  input,\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 { toObservable, outputFromObservable } 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  NodeSvgTemplateDirective,\n} from '../../directives/template.directive';\nimport { addNodesToEdges } from '../../utils/add-nodes-to-edges';\nimport { skip } from 'rxjs';\nimport { SpacePoint, Point } from '../../interfaces/point.interface';\nimport { ViewportState } from '../../interfaces/viewport.interface';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { ConnectionSettings } from '../../interfaces/connection-settings.interface';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { ReferenceIdentityChecker } from '../../utils/identity-checker/reference-identity-checker';\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';\nimport { EdgeRenderingService } from '../../services/edge-rendering.service';\nimport { getSpacePoints } from '../../utils/get-space-points';\nimport { getIntesectingNodes } from '../../utils/nodes';\nimport { IntersectingNodesOptions } from '../../interfaces/intersecting-nodes-options.interface';\nimport { PreviewFlowComponent } from '../preview-flow/preview-flow.component';\nimport {\n  PreviewFlowRenderStrategyService,\n  ViewportPreviewFlowRenderStrategyService,\n} from '../../services/preview-flow-render-strategy.service';\nimport { toLazySignal } from '../../utils/signals/to-lazy-signal';\nimport { FlowRenderingService } from '../../services/flow-rendering.service';\nimport { AlignmentHelperComponent } from '../alignment-helper/alignment-helper.component';\nimport { AlignmentHelperSettings } from '../../interfaces/alignment-helper-settings.interface';\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    EdgeRenderingService,\n    SelectionService,\n    FlowSettingsService,\n    ComponentEventBusService,\n    KeyboardService,\n    OverlaysService,\n    { provide: PreviewFlowRenderStrategyService, useClass: ViewportPreviewFlowRenderStrategyService },\n    FlowRenderingService,\n  ],\n  hostDirectives: [changesControllerHostDirective],\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    PreviewFlowComponent,\n    AlignmentHelperComponent,\n  ],\n})\nexport class VflowComponent {\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 edgeRenderingService = inject(EdgeRenderingService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private componentEventBusService = inject(ComponentEventBusService);\n  private keyboardService = inject(KeyboardService);\n  private injector = inject(Injector);\n  private flowRenderingService = inject(FlowRenderingService);\n\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  @Input()\n  public set optimization(newOptimization: Optimization) {\n    this.flowSettingsService.optimization.update((optimization) => ({\n      ...optimization,\n      ...newOptimization,\n    }));\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\n  /**\n   * Snap grid for node movement. Passes as [x, y]\n   */\n  @Input()\n  public set snapGrid(value: [number, number]) {\n    this.flowSettingsService.snapGrid.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected node\n   */\n  @Input()\n  public set elevateNodesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateNodesOnSelect.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected edge\n   */\n  @Input()\n  public set elevateEdgesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateEdgesOnSelect.set(value);\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 models = runInInjectionContext(this.injector, () =>\n      ReferenceIdentityChecker.nodes(newNodes, this.flowEntitiesService.nodes()),\n    );\n\n    // TODO: consider calling only fo new nodes\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(models, this.flowEntitiesService.edges());\n\n    this.flowEntitiesService.nodes.set(models);\n\n    models.forEach((model) => this.nodeRenderingService.pullNode(model));\n  }\n\n  public alignmentHelper = input<AlignmentHelperSettings | boolean>(false);\n\n  protected nodeModels = this.nodeRenderingService.nodes;\n  protected groups = this.nodeRenderingService.groups;\n  protected nonGroups = 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      ReferenceIdentityChecker.edges(newEdges, this.flowEntitiesService.edges()),\n    );\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(this.flowEntitiesService.nodes(), newModels);\n\n    this.flowEntitiesService.edges.set(newModels);\n  }\n\n  protected edgeModels = this.edgeRenderingService.edges;\n  // #endregion\n\n  // #region OUTPUTS\n  /**\n   * Event that accumulates all custom node events\n   *\n   * @experimental\n   */\n  public readonly onComponentNodeEvent = outputFromObservable<any>(this.componentEventBusService.event$); // TODO: research how to remove any\n  // #endregion\n\n  // #region TEMPLATES\n  protected nodeTemplateDirective = contentChild(NodeHtmlTemplateDirective);\n\n  protected nodeSvgTemplateDirective = contentChild(NodeSvgTemplateDirective);\n\n  protected groupNodeTemplateDirective = contentChild(GroupNodeTemplateDirective);\n\n  protected edgeTemplateDirective = contentChild(EdgeTemplateDirective);\n\n  protected edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateDirective);\n\n  protected connectionTemplateDirective = contentChild(ConnectionTemplateDirective);\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 = toLazySignal(this.nodesChangeService.changes$, {\n    initialValue: [] as NodeChange[],\n  });\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange = toLazySignal(this.edgesChangeService.changes$, {\n    initialValue: [] as EdgeChange[],\n  });\n\n  public readonly initialized = this.flowRenderingService.flowInitialized.asReadonly();\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(this.viewportService.readableViewport).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\n  public readonly initialized$ = toObservable(this.flowRenderingService.flowInitialized);\n  // #endregion\n\n  protected markers = this.flowEntitiesService.markers;\n  protected minimap = this.flowEntitiesService.minimap;\n\n  protected flowOptimization = this.flowSettingsService.optimization;\n  protected flowWidth = this.flowSettingsService.computedFlowWidth;\n  protected flowHeight = this.flowSettingsService.computedFlowHeight;\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>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.rawNode;\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  public documentPointToFlowPoint(point: Point, options?: { spaces: false }): Point;\n  /**\n   * Convert point received from document to a stack of space points on the flow\n   * Space point has a spaceNodeId, coordinates are relative to this node\n   */\n  public documentPointToFlowPoint(point: Point, options?: { spaces: true }): SpacePoint[];\n  public documentPointToFlowPoint(point: Point, options?: { spaces: boolean }): unknown {\n    const transformedPoint = this.spacePointContext().documentPointToFlowPoint(point);\n\n    if (options?.spaces) {\n      return getSpacePoints(transformedPoint, this.nodeRenderingService.groups());\n    }\n\n    return transformedPoint;\n  }\n\n  /**\n   * Gets nodes that intersect with the specified node\n   *\n   * @template T - The type of data associated with the nodes\n   * @param nodeId - The ID of the node to check intersections for\n   * @param options.partially - If true, returns nodes that partially intersect. If false, only returns fully intersecting nodes\n   * @returns An array of nodes that intersect with the specified node\n   */\n  public getIntesectingNodes<T>(\n    nodeId: string,\n    options: IntersectingNodesOptions = { partially: true },\n  ): Node<T>[] | DynamicNode<T>[] {\n    return getIntesectingNodes(nodeId, this.nodeModels(), options).map((n) => n.rawNode) as\n      | Node<T>[]\n      | DynamicNode<T>[];\n  }\n\n  /**\n   * Converts a node's position to the coordinate space of another node\n   *\n   * @param nodeId - The ID of the node whose position should be converted\n   * @param spaceNodeId - The ID of the node that defines the target coordinate space.\n   *                      If null, returns the position in global coordinates\n   * @returns {Point} The converted position. Returns {x: Infinity, y: Infinity} if either node is not found\n   */\n  public toNodeSpace(nodeId: string, spaceNodeId: string | null): Point {\n    const node = this.nodeModels().find((n) => n.rawNode.id === nodeId);\n\n    if (!node) return { x: Infinity, y: Infinity };\n\n    if (spaceNodeId === null) {\n      return node.globalPoint();\n    }\n\n    const coordinateSpaceNode = this.nodeModels().find((n) => n.rawNode.id === spaceNodeId);\n\n    if (!coordinateSpaceNode) return { x: Infinity, y: Infinity };\n\n    return getSpacePoints(node.globalPoint(), [coordinateSpaceNode])[0];\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { rawNode: node }: NodeModel) {\n    return node;\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge;\n  }\n}\n","<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n  <defs flowDefs [markers]=\"markers()\" />\n\n  <g background />\n\n  <svg:g mapContext spacePointContext>\n    @if (alignmentHelper(); as alignmentHelper) {\n      @if (alignmentHelper === true) {\n        <svg:g alignmentHelper />\n      } @else {\n        <svg:g alignmentHelper [tolerance]=\"alignmentHelper.tolerance\" [lineColor]=\"alignmentHelper.lineColor\" />\n      }\n    }\n\n    <!-- Connection -->\n    <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n    @if (flowOptimization().detachedGroupsLayer) {\n      <!-- Groups -->\n      @for (model of groups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\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      <!-- Nodes -->\n      @for (model of nonGroups(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\n      }\n    }\n\n    @if (!flowOptimization().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      @for (model of nodeModels(); track trackNodes($index, model)) {\n        <svg:g\n          node\n          [model]=\"model\"\n          [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n          [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n          [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n          [attr.transform]=\"model.pointTransform()\" />\n      }\n    }\n  </svg:g>\n\n  <!-- Minimap -->\n  @if (minimap(); as minimap) {\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  }\n</svg:svg>\n\n@if (flowOptimization().virtualization) {\n  <canvas previewFlow class=\"preview-flow\" [width]=\"flowWidth()\" [height]=\"flowHeight()\"></canvas>\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxpZ25tZW50LWhlbHBlci1zZXR0aW5ncy5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvaW50ZXJmYWNlcy9hbGlnbm1lbnQtaGVscGVyLXNldHRpbmdzLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBbGlnbm1lbnRIZWxwZXJTZXR0aW5ncyB7XG4gIHRvbGVyYW5jZTogbnVtYmVyO1xuICBsaW5lQ29sb3I6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -1,2 +1,10 @@
|
|
|
1
|
-
export {
|
|
2
|
-
|
|
1
|
+
export function rectToRectWithSides(rect) {
|
|
2
|
+
return {
|
|
3
|
+
...rect,
|
|
4
|
+
left: rect.x,
|
|
5
|
+
right: rect.x + rect.width,
|
|
6
|
+
top: rect.y,
|
|
7
|
+
bottom: rect.y + rect.height,
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9pbnRlcmZhY2VzL3JlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsTUFBTSxVQUFVLG1CQUFtQixDQUFDLElBQVU7SUFDNUMsT0FBTztRQUNMLEdBQUcsSUFBSTtRQUNQLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNaLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLO1FBQzFCLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNYLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNO0tBQzdCLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBSZWN0IHtcbiAgeDogbnVtYmVyO1xuICB5OiBudW1iZXI7XG4gIHdpZHRoOiBudW1iZXI7XG4gIGhlaWdodDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY3RXaXRoU2lkZXMgZXh0ZW5kcyBSZWN0IHtcbiAgbGVmdDogbnVtYmVyO1xuICByaWdodDogbnVtYmVyO1xuICB0b3A6IG51bWJlcjtcbiAgYm90dG9tOiBudW1iZXI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWN0VG9SZWN0V2l0aFNpZGVzKHJlY3Q6IFJlY3QpOiBSZWN0V2l0aFNpZGVzIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5yZWN0LFxuICAgIGxlZnQ6IHJlY3QueCxcbiAgICByaWdodDogcmVjdC54ICsgcmVjdC53aWR0aCxcbiAgICB0b3A6IHJlY3QueSxcbiAgICBib3R0b206IHJlY3QueSArIHJlY3QuaGVpZ2h0LFxuICB9O1xufVxuIl19
|
|
@@ -5,11 +5,13 @@ import { round } from '../utils/round';
|
|
|
5
5
|
import { FlowEntitiesService } from './flow-entities.service';
|
|
6
6
|
import { FlowSettingsService } from './flow-settings.service';
|
|
7
7
|
import { align } from '../utils/align-number';
|
|
8
|
+
import { FlowStatusService } from './flow-status.service';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
export class DraggableService {
|
|
10
11
|
constructor() {
|
|
11
12
|
this.entitiesService = inject(FlowEntitiesService);
|
|
12
13
|
this.settingsService = inject(FlowSettingsService);
|
|
14
|
+
this.flowStatusService = inject(FlowStatusService);
|
|
13
15
|
}
|
|
14
16
|
/**
|
|
15
17
|
* Enable draggable behavior for element.
|
|
@@ -57,6 +59,7 @@ export class DraggableService {
|
|
|
57
59
|
.filter(filterCondition)
|
|
58
60
|
.on('start', (event) => {
|
|
59
61
|
dragNodes = this.getDragNodes(model);
|
|
62
|
+
this.flowStatusService.setNodeDragStartStatus(model);
|
|
60
63
|
initialPositions = dragNodes.map((node) => ({
|
|
61
64
|
x: node.point().x - event.x,
|
|
62
65
|
y: node.point().y - event.y,
|
|
@@ -70,6 +73,9 @@ export class DraggableService {
|
|
|
70
73
|
};
|
|
71
74
|
this.moveNode(model, point);
|
|
72
75
|
});
|
|
76
|
+
})
|
|
77
|
+
.on('end', () => {
|
|
78
|
+
this.flowStatusService.setNodeDragEndStatus(model);
|
|
73
79
|
});
|
|
74
80
|
}
|
|
75
81
|
getDragNodes(model) {
|
|
@@ -115,4 +121,4 @@ export class DraggableService {
|
|
|
115
121
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DraggableService, decorators: [{
|
|
116
122
|
type: Injectable
|
|
117
123
|
}] });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/draggable.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3DragEvent, drag } from 'd3-drag';\nimport { NodeModel } from '../models/node.model';\nimport { round } from '../utils/round';\nimport { FlowEntitiesService } from './flow-entities.service';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowSettingsService } from './flow-settings.service';\nimport { align } from '../utils/align-number';\n\ntype DragEvent = D3DragEvent<Element, unknown, unknown>;\n\n@Injectable()\nexport class DraggableService {\n  private entitiesService = inject(FlowEntitiesService);\n  private settingsService = inject(FlowSettingsService);\n\n  /**\n   * Enable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public enable(element: Element, model: NodeModel) {\n    select(element).call(this.getDragBehavior(model));\n  }\n\n  /**\n   * Disable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public disable(element: Element) {\n    select(element).call(drag().on('drag', null));\n  }\n\n  /**\n   * TODO: not shure if this work, need to check\n   *\n   * @param element\n   */\n  public destroy(element: Element) {\n    select(element).on('.drag', null);\n  }\n\n  /**\n   * Node drag behavior. Updated node's coordinate according to dragging\n   *\n   * @param model\n   * @returns\n   */\n  private getDragBehavior(model: NodeModel) {\n    let dragNodes: NodeModel[] = [];\n    let initialPositions: Point[] = [];\n\n    const filterCondition = (event: Event) => {\n      // if there is at least one drag handle, we should check if we are dragging it\n      if (model.dragHandlesCount()) {\n        return !!(event.target as Element).closest('.vflow-drag-handle');\n      }\n\n      return true;\n    };\n\n    return drag()\n      .filter(filterCondition)\n      .on('start', (event: DragEvent) => {\n        dragNodes = this.getDragNodes(model);\n\n        initialPositions = dragNodes.map((node) => ({\n          x: node.point().x - event.x,\n          y: node.point().y - event.y,\n        }));\n      })\n\n      .on('drag', (event: DragEvent) => {\n        dragNodes.forEach((model, index) => {\n          const point = {\n            x: round(event.x + initialPositions[index].x),\n            y: round(event.y + initialPositions[index].y),\n          };\n\n          this.moveNode(model, point);\n        });\n      });\n  }\n\n  private getDragNodes(model: NodeModel) {\n    return model.selected()\n      ? this.entitiesService\n          .nodes()\n          // selected draggable nodes (with current node)\n          .filter((node) => node.selected() && node.draggable())\n      : // we only can move current node if it's not selected\n        [model];\n  }\n\n  /**\n   * @todo make it unit testable\n   */\n  private moveNode(model: NodeModel, point: Point) {\n    point = this.alignToGrid(point);\n\n    const parent = model.parent();\n    // keep node in bounds of parent\n    if (parent) {\n      point.x = Math.min(parent.width() - model.width(), point.x);\n      point.x = Math.max(0, point.x);\n\n      point.y = Math.min(parent.height() - model.height(), point.y);\n      point.y = Math.max(0, point.y);\n    }\n\n    model.setPoint(point);\n  }\n\n  /**\n   * @todo make it unit testable\n   */\n  private alignToGrid(point: Point) {\n    const [snapX, snapY] = this.settingsService.snapGrid();\n\n    if (snapX > 1) {\n      point.x = align(point.x, snapX);\n    }\n\n    if (snapY > 1) {\n      point.y = align(point.y, snapY);\n    }\n\n    return point;\n  }\n}\n"]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/draggable.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3DragEvent, drag } from 'd3-drag';\nimport { NodeModel } from '../models/node.model';\nimport { round } from '../utils/round';\nimport { FlowEntitiesService } from './flow-entities.service';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowSettingsService } from './flow-settings.service';\nimport { align } from '../utils/align-number';\nimport { FlowStatusService } from './flow-status.service';\n\ntype DragEvent = D3DragEvent<Element, unknown, unknown>;\n\n@Injectable()\nexport class DraggableService {\n  private entitiesService = inject(FlowEntitiesService);\n  private settingsService = inject(FlowSettingsService);\n  private flowStatusService = inject(FlowStatusService);\n\n  /**\n   * Enable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public enable(element: Element, model: NodeModel) {\n    select(element).call(this.getDragBehavior(model));\n  }\n\n  /**\n   * Disable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public disable(element: Element) {\n    select(element).call(drag().on('drag', null));\n  }\n\n  /**\n   * TODO: not shure if this work, need to check\n   *\n   * @param element\n   */\n  public destroy(element: Element) {\n    select(element).on('.drag', null);\n  }\n\n  /**\n   * Node drag behavior. Updated node's coordinate according to dragging\n   *\n   * @param model\n   * @returns\n   */\n  private getDragBehavior(model: NodeModel) {\n    let dragNodes: NodeModel[] = [];\n    let initialPositions: Point[] = [];\n\n    const filterCondition = (event: Event) => {\n      // if there is at least one drag handle, we should check if we are dragging it\n      if (model.dragHandlesCount()) {\n        return !!(event.target as Element).closest('.vflow-drag-handle');\n      }\n\n      return true;\n    };\n\n    return drag()\n      .filter(filterCondition)\n      .on('start', (event: DragEvent) => {\n        dragNodes = this.getDragNodes(model);\n\n        this.flowStatusService.setNodeDragStartStatus(model);\n\n        initialPositions = dragNodes.map((node) => ({\n          x: node.point().x - event.x,\n          y: node.point().y - event.y,\n        }));\n      })\n\n      .on('drag', (event: DragEvent) => {\n        dragNodes.forEach((model, index) => {\n          const point = {\n            x: round(event.x + initialPositions[index].x),\n            y: round(event.y + initialPositions[index].y),\n          };\n\n          this.moveNode(model, point);\n        });\n      })\n\n      .on('end', () => {\n        this.flowStatusService.setNodeDragEndStatus(model);\n      });\n  }\n\n  private getDragNodes(model: NodeModel) {\n    return model.selected()\n      ? this.entitiesService\n          .nodes()\n          // selected draggable nodes (with current node)\n          .filter((node) => node.selected() && node.draggable())\n      : // we only can move current node if it's not selected\n        [model];\n  }\n\n  /**\n   * @todo make it unit testable\n   */\n  private moveNode(model: NodeModel, point: Point) {\n    point = this.alignToGrid(point);\n\n    const parent = model.parent();\n    // keep node in bounds of parent\n    if (parent) {\n      point.x = Math.min(parent.width() - model.width(), point.x);\n      point.x = Math.max(0, point.x);\n\n      point.y = Math.min(parent.height() - model.height(), point.y);\n      point.y = Math.max(0, point.y);\n    }\n\n    model.setPoint(point);\n  }\n\n  /**\n   * @todo make it unit testable\n   */\n  private alignToGrid(point: Point) {\n    const [snapX, snapY] = this.settingsService.snapGrid();\n\n    if (snapX > 1) {\n      point.x = align(point.x, snapX);\n    }\n\n    if (snapY > 1) {\n      point.y = align(point.y, snapY);\n    }\n\n    return point;\n  }\n}\n"]}
|
|
@@ -28,10 +28,22 @@ export class FlowStatusService {
|
|
|
28
28
|
setReconnectionEndStatus(source, target, sourceHandle, targetHandle, oldEdge) {
|
|
29
29
|
this.status.set({ state: 'reconnection-end', payload: { source, target, sourceHandle, targetHandle, oldEdge } });
|
|
30
30
|
}
|
|
31
|
+
setNodeDragStartStatus(node) {
|
|
32
|
+
this.status.set({ state: 'node-drag-start', payload: { node } });
|
|
33
|
+
}
|
|
34
|
+
setNodeDragEndStatus(node) {
|
|
35
|
+
this.status.set({ state: 'node-drag-end', payload: { node } });
|
|
36
|
+
}
|
|
31
37
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowStatusService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
32
38
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowStatusService }); }
|
|
33
39
|
}
|
|
34
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowStatusService, decorators: [{
|
|
35
41
|
type: Injectable
|
|
36
42
|
}] });
|
|
37
|
-
|
|
43
|
+
export function isNodeDragStartStatus(params) {
|
|
44
|
+
return params.state === 'node-drag-start';
|
|
45
|
+
}
|
|
46
|
+
export function isNodeDragEndStatus(params) {
|
|
47
|
+
return params.state === 'node-drag-end';
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flow-status.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/flow-status.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal } from '@angular/core';\nimport { NodeModel } from '../models/node.model';\nimport { HandleModel } from '../models/handle.model';\nimport { ConnectionInternal } from '../interfaces/connection.internal.interface';\nimport { EdgeModel } from '../models/edge.model';\n\nexport interface FlowStatusIdle {\n  state: 'idle';\n  payload: null;\n}\n\nexport interface FlowStatusConnectionStart {\n  state: 'connection-start';\n  payload: Omit<ConnectionInternal, 'target' | 'targetHandle'>;\n}\n\nexport interface FlowStatusConnectionValidation {\n  state: 'connection-validation';\n  payload: ConnectionInternal & {\n    valid: boolean;\n  };\n}\n\nexport interface FlowStatusConnectionEnd {\n  state: 'connection-end';\n  payload: ConnectionInternal;\n}\n\nexport interface FlowStatusReconnectionStart {\n  state: 'reconnection-start';\n  payload: Omit<ConnectionInternal, 'target' | 'targetHandle'> & {\n    oldEdge: EdgeModel;\n  };\n}\n\nexport interface FlowStatusReconnectionValidation {\n  state: 'reconnection-validation';\n  payload: ConnectionInternal & {\n    valid: boolean;\n    oldEdge: EdgeModel;\n  };\n}\n\nexport interface FlowStatusReconnectionEnd {\n  state: 'reconnection-end';\n  payload: ConnectionInternal & {\n    oldEdge: EdgeModel;\n  };\n}\n\nexport interface FlowStatusNodeDragStart {\n  state: 'node-drag-start';\n  payload: {\n    node: NodeModel;\n  };\n}\n\nexport interface FlowStatusNodeDragEnd {\n  state: 'node-drag-end';\n  payload: {\n    node: NodeModel;\n  };\n}\n\nexport type FlowStatus =\n  | FlowStatusIdle\n  | FlowStatusConnectionStart\n  | FlowStatusConnectionValidation\n  | FlowStatusConnectionEnd\n  | FlowStatusReconnectionStart\n  | FlowStatusReconnectionValidation\n  | FlowStatusReconnectionEnd\n  | FlowStatusNodeDragStart\n  | FlowStatusNodeDragEnd;\n\n@Injectable()\nexport class FlowStatusService {\n  public readonly status = signal<FlowStatus>({ state: 'idle', payload: null });\n\n  public setIdleStatus() {\n    this.status.set({ state: 'idle', payload: null });\n  }\n\n  public setConnectionStartStatus(source: NodeModel, sourceHandle: HandleModel) {\n    this.status.set({ state: 'connection-start', payload: { source, sourceHandle } });\n  }\n\n  public setReconnectionStartStatus(source: NodeModel, sourceHandle: HandleModel, oldEdge: EdgeModel) {\n    this.status.set({ state: 'reconnection-start', payload: { source, sourceHandle, oldEdge } });\n  }\n\n  public setConnectionValidationStatus(\n    valid: boolean,\n    source: NodeModel,\n    target: NodeModel,\n    sourceHandle: HandleModel,\n    targetHandle: HandleModel,\n  ) {\n    this.status.set({ state: 'connection-validation', payload: { source, target, sourceHandle, targetHandle, valid } });\n  }\n\n  public setReconnectionValidationStatus(\n    valid: boolean,\n    source: NodeModel,\n    target: NodeModel,\n    sourceHandle: HandleModel,\n    targetHandle: HandleModel,\n    oldEdge: EdgeModel,\n  ) {\n    this.status.set({\n      state: 'reconnection-validation',\n      payload: { source, target, sourceHandle, targetHandle, valid, oldEdge },\n    });\n  }\n\n  public setConnectionEndStatus(\n    source: NodeModel,\n    target: NodeModel,\n    sourceHandle: HandleModel,\n    targetHandle: HandleModel,\n  ) {\n    this.status.set({ state: 'connection-end', payload: { source, target, sourceHandle, targetHandle } });\n  }\n\n  public setReconnectionEndStatus(\n    source: NodeModel,\n    target: NodeModel,\n    sourceHandle: HandleModel,\n    targetHandle: HandleModel,\n    oldEdge: EdgeModel,\n  ) {\n    this.status.set({ state: 'reconnection-end', payload: { source, target, sourceHandle, targetHandle, oldEdge } });\n  }\n\n  public setNodeDragStartStatus(node: NodeModel) {\n    this.status.set({ state: 'node-drag-start', payload: { node } });\n  }\n\n  public setNodeDragEndStatus(node: NodeModel) {\n    this.status.set({ state: 'node-drag-end', payload: { node } });\n  }\n}\n\nexport function isNodeDragStartStatus(params: FlowStatus): params is FlowStatusNodeDragStart {\n  return params.state === 'node-drag-start';\n}\n\nexport function isNodeDragEndStatus(params: FlowStatus): params is FlowStatusNodeDragEnd {\n  return params.state === 'node-drag-end';\n}\n"]}
|