ngx-vflow 1.16.3 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +35 -69
- package/fesm2022/ngx-vflow-testing.mjs +77 -67
- package/fesm2022/ngx-vflow-testing.mjs.map +1 -1
- package/fesm2022/ngx-vflow.mjs +926 -559
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +1 -1
- package/lib/vflow/components/vflow/vflow.component.d.ts +18 -9
- package/lib/vflow/directives/auto-pan.directive.d.ts +16 -0
- package/lib/vflow/directives/changes-controller.directive.d.ts +13 -87
- package/lib/vflow/directives/connection-controller.directive.d.ts +8 -10
- package/lib/vflow/directives/space-point-context.directive.d.ts +2 -1
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +1 -2
- package/lib/vflow/interfaces/connection-events.interface.d.ts +66 -0
- package/lib/vflow/interfaces/connection-settings.interface.d.ts +7 -1
- package/lib/vflow/interfaces/connection.interface.d.ts +0 -5
- package/lib/vflow/interfaces/curve-factory.interface.d.ts +2 -2
- package/lib/vflow/interfaces/edge-label.interface.d.ts +0 -4
- package/lib/vflow/interfaces/edge.interface.d.ts +36 -8
- package/lib/vflow/interfaces/node.interface.d.ts +44 -63
- package/lib/vflow/interfaces/selection-strategy.interface.d.ts +16 -0
- package/lib/vflow/interfaces/template-context.interface.d.ts +8 -3
- package/lib/vflow/models/connection.model.d.ts +1 -1
- package/lib/vflow/models/edge.model.d.ts +20 -23
- package/lib/vflow/models/handle.model.d.ts +1 -1
- package/lib/vflow/models/node.model.d.ts +4 -7
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +1 -1
- package/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.d.ts +2 -1
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +1 -1
- package/lib/vflow/services/draggable.service.d.ts +3 -0
- package/lib/vflow/services/flow-entities.service.d.ts +2 -2
- package/lib/vflow/services/flow-settings.service.d.ts +3 -0
- package/lib/vflow/services/flow-status.service.d.ts +35 -7
- package/lib/vflow/services/selection.service.d.ts +4 -1
- package/lib/vflow/strategies/default-selection.strategy.d.ts +6 -0
- package/lib/vflow/strategies/manual-selection.strategy.d.ts +5 -0
- package/lib/vflow/types/selection-mode.type.d.ts +1 -0
- package/lib/vflow/types/unwrap-signal.type.d.ts +4 -0
- package/lib/vflow/utils/adjust-direction.d.ts +2 -6
- package/lib/vflow/utils/identity-checker/reference-identity-checker.d.ts +2 -2
- package/lib/vflow/utils/is-vflow-component.d.ts +0 -2
- package/lib/vflow/utils/signals/to-lazy-signal.d.ts +4 -4
- package/package.json +3 -7
- package/public-api.d.ts +3 -2
- package/testing/component-mocks/vflow-mock.component.d.ts +8 -6
- package/testing/directive-mocks/connection-controller-mock.directive.d.ts +8 -6
- package/esm2022/lib/vflow/components/alignment-helper/alignment-helper.component.mjs +0 -103
- package/esm2022/lib/vflow/components/background/background.component.mjs +0 -121
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +0 -157
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +0 -57
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +0 -16
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +0 -16
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +0 -54
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +0 -76
- package/esm2022/lib/vflow/components/node/node.component.mjs +0 -107
- package/esm2022/lib/vflow/components/preview-flow/draw-node.mjs +0 -100
- package/esm2022/lib/vflow/components/preview-flow/preview-flow.component.mjs +0 -62
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +0 -437
- package/esm2022/lib/vflow/constants/magic-number-to-fix-glitch-in-chrome.constant.mjs +0 -4
- package/esm2022/lib/vflow/decorators/microtask.decorator.mjs +0 -11
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +0 -165
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +0 -145
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +0 -28
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +0 -40
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +0 -41
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +0 -116
- package/esm2022/lib/vflow/directives/node-handles-controller.directive.mjs +0 -33
- package/esm2022/lib/vflow/directives/node-resize-controller.directive.mjs +0 -37
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +0 -84
- package/esm2022/lib/vflow/directives/reference.directive.mjs +0 -17
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +0 -58
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +0 -35
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +0 -48
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +0 -42
- package/esm2022/lib/vflow/directives/template.directive.mjs +0 -119
- package/esm2022/lib/vflow/interfaces/alignment-helper-settings.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/box.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection-settings.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/connection.internal.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/contextable.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/curve-factory.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/edge-label.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/edge.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/fit-view-options.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/flow-entity.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/intersecting-nodes-options.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/marker.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/node-preview.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +0 -53
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +0 -7
- package/esm2022/lib/vflow/interfaces/point.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/rect.mjs +0 -10
- package/esm2022/lib/vflow/interfaces/template-context.interface.mjs +0 -2
- package/esm2022/lib/vflow/interfaces/viewport.interface.mjs +0 -2
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +0 -66
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +0 -226
- package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +0 -12
- package/esm2022/lib/vflow/math/point-on-line-by-ratio.mjs +0 -12
- package/esm2022/lib/vflow/models/connection.model.mjs +0 -31
- package/esm2022/lib/vflow/models/edge-label.model.mjs +0 -8
- package/esm2022/lib/vflow/models/edge.model.mjs +0 -208
- package/esm2022/lib/vflow/models/handle.model.mjs +0 -98
- package/esm2022/lib/vflow/models/minimap.model.mjs +0 -7
- package/esm2022/lib/vflow/models/node.model.mjs +0 -181
- package/esm2022/lib/vflow/models/toolbar.model.mjs +0 -36
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +0 -25
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +0 -24
- package/esm2022/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.mjs +0 -29
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +0 -53
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +0 -108
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +0 -73
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +0 -272
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +0 -18
- package/esm2022/lib/vflow/services/draggable.service.mjs +0 -124
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +0 -43
- package/esm2022/lib/vflow/services/edge-rendering.service.mjs +0 -40
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +0 -56
- package/esm2022/lib/vflow/services/flow-rendering.service.mjs +0 -41
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +0 -33
- package/esm2022/lib/vflow/services/flow-status.service.mjs +0 -49
- package/esm2022/lib/vflow/services/handle.service.mjs +0 -30
- package/esm2022/lib/vflow/services/keyboard.service.mjs +0 -47
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +0 -16
- package/esm2022/lib/vflow/services/node-changes.service.mjs +0 -41
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +0 -66
- package/esm2022/lib/vflow/services/overlays.service.mjs +0 -35
- package/esm2022/lib/vflow/services/preview-flow-render-strategy.service.mjs +0 -21
- package/esm2022/lib/vflow/services/selection.service.mjs +0 -54
- package/esm2022/lib/vflow/services/viewport.service.mjs +0 -64
- package/esm2022/lib/vflow/types/background.type.mjs +0 -2
- package/esm2022/lib/vflow/types/connection-mode.type.mjs +0 -2
- package/esm2022/lib/vflow/types/edge-change.type.mjs +0 -2
- package/esm2022/lib/vflow/types/handle-type.type.mjs +0 -2
- package/esm2022/lib/vflow/types/keyboard-action.type.mjs +0 -2
- package/esm2022/lib/vflow/types/node-change.type.mjs +0 -2
- package/esm2022/lib/vflow/types/position.type.mjs +0 -2
- package/esm2022/lib/vflow/types/viewport-change-type.type.mjs +0 -2
- package/esm2022/lib/vflow/utils/add-nodes-to-edges.mjs +0 -11
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +0 -30
- package/esm2022/lib/vflow/utils/align-number.mjs +0 -4
- package/esm2022/lib/vflow/utils/assert-injector.mjs +0 -27
- package/esm2022/lib/vflow/utils/event.mjs +0 -4
- package/esm2022/lib/vflow/utils/get-os.mjs +0 -24
- package/esm2022/lib/vflow/utils/get-overlapping-area.mjs +0 -6
- package/esm2022/lib/vflow/utils/get-space-points.mjs +0 -25
- package/esm2022/lib/vflow/utils/hash.mjs +0 -7
- package/esm2022/lib/vflow/utils/id.mjs +0 -5
- package/esm2022/lib/vflow/utils/identity-checker/reference-identity-checker.mjs +0 -28
- package/esm2022/lib/vflow/utils/is-callable.mjs +0 -10
- package/esm2022/lib/vflow/utils/is-defined.mjs +0 -4
- package/esm2022/lib/vflow/utils/is-group-node.mjs +0 -4
- package/esm2022/lib/vflow/utils/is-vflow-component.mjs +0 -9
- package/esm2022/lib/vflow/utils/nodes.mjs +0 -60
- package/esm2022/lib/vflow/utils/resizable.mjs +0 -11
- package/esm2022/lib/vflow/utils/round.mjs +0 -2
- package/esm2022/lib/vflow/utils/signals/extended-computed.mjs +0 -15
- package/esm2022/lib/vflow/utils/signals/to-lazy-signal.mjs +0 -35
- package/esm2022/lib/vflow/utils/to-unified-node.mjs +0 -24
- package/esm2022/lib/vflow/utils/transform-background.mjs +0 -4
- package/esm2022/lib/vflow/utils/viewport.mjs +0 -51
- package/esm2022/lib/vflow/vflow.mjs +0 -29
- package/esm2022/ngx-vflow.mjs +0 -5
- package/esm2022/public-api.mjs +0 -55
- package/esm2022/testing/component-mocks/custom-template-edge-mock.component.mjs +0 -16
- package/esm2022/testing/component-mocks/handle-mock.component.mjs +0 -26
- package/esm2022/testing/component-mocks/minimap-mock.component.mjs +0 -24
- package/esm2022/testing/component-mocks/node-toolbar-mock.component.mjs +0 -23
- package/esm2022/testing/component-mocks/resizable-mock.component.mjs +0 -27
- package/esm2022/testing/component-mocks/vflow-mock.component.mjs +0 -299
- package/esm2022/testing/directive-mocks/connection-controller-mock.directive.mjs +0 -29
- package/esm2022/testing/directive-mocks/drag-handle-mock.directive.mjs +0 -11
- package/esm2022/testing/directive-mocks/selectable-mock.directive.mjs +0 -14
- package/esm2022/testing/directive-mocks/template-mock.directive.mjs +0 -101
- package/esm2022/testing/ngx-vflow-testing.mjs +0 -5
- package/esm2022/testing/provide-custom-node-mocks.mjs +0 -60
- package/esm2022/testing/public-api.mjs +0 -13
- package/esm2022/testing/types.mjs +0 -2
- package/esm2022/testing/vflow-mocks.mjs +0 -28
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +0 -13
- package/lib/vflow/utils/to-unified-node.d.ts +0 -2
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, effect, ElementRef, inject, input, Renderer2 } from '@angular/core';
|
|
2
|
-
import { ViewportService } from '../../services/viewport.service';
|
|
3
|
-
import { PreviewFlowRenderStrategyService } from '../../services/preview-flow-render-strategy.service';
|
|
4
|
-
import { drawNode } from './draw-node';
|
|
5
|
-
import { NodeRenderingService } from '../../services/node-rendering.service';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export class PreviewFlowComponent {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.viewportService = inject(ViewportService);
|
|
10
|
-
this.renderStrategy = inject(PreviewFlowRenderStrategyService);
|
|
11
|
-
this.nodeRenderingService = inject(NodeRenderingService);
|
|
12
|
-
this.renderer2 = inject(Renderer2);
|
|
13
|
-
this.element = inject(ElementRef).nativeElement;
|
|
14
|
-
this.ctx = this.element.getContext('2d');
|
|
15
|
-
this.width = input(0);
|
|
16
|
-
this.height = input(0);
|
|
17
|
-
this.dpr = window.devicePixelRatio;
|
|
18
|
-
effect(() => {
|
|
19
|
-
// Set the "actual" size of the canvas
|
|
20
|
-
this.renderer2.setProperty(this.element, 'width', this.width() * this.dpr);
|
|
21
|
-
this.renderer2.setProperty(this.element, 'height', this.height() * this.dpr);
|
|
22
|
-
// Set the "drawn" size of the canvas
|
|
23
|
-
this.renderer2.setStyle(this.element, 'width', `${this.width()}px`);
|
|
24
|
-
this.renderer2.setStyle(this.element, 'height', `${this.height()}px`);
|
|
25
|
-
// Scale the context to match device pixel ratio
|
|
26
|
-
this.ctx.scale(this.dpr, this.dpr);
|
|
27
|
-
});
|
|
28
|
-
effect(() => {
|
|
29
|
-
const viewport = this.viewportService.readableViewport();
|
|
30
|
-
this.ctx.clearRect(0, 0, this.width(), this.height());
|
|
31
|
-
// Save the current context state
|
|
32
|
-
this.ctx.save();
|
|
33
|
-
// Apply viewport transformations (zoom and pan)
|
|
34
|
-
this.ctx.setTransform(viewport.zoom * this.dpr, // horizontal scaling with DPR
|
|
35
|
-
0, // horizontal skewing
|
|
36
|
-
0, // vertical skewing
|
|
37
|
-
viewport.zoom * this.dpr, // vertical scaling with DPR
|
|
38
|
-
viewport.x * this.dpr, // horizontal translation with DPR
|
|
39
|
-
viewport.y * this.dpr);
|
|
40
|
-
for (let i = 0; i < this.nodeRenderingService.viewportNodes().length; i++) {
|
|
41
|
-
const node = this.nodeRenderingService.viewportNodes()[i];
|
|
42
|
-
if (this.renderStrategy.shouldRenderNode(node)) {
|
|
43
|
-
drawNode(this.ctx, node);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
// Restore the context state
|
|
47
|
-
this.ctx.restore();
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PreviewFlowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: PreviewFlowComponent, isStandalone: true, selector: "canvas[previewFlow]", inputs: { width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
52
|
-
}
|
|
53
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PreviewFlowComponent, decorators: [{
|
|
54
|
-
type: Component,
|
|
55
|
-
args: [{
|
|
56
|
-
standalone: true,
|
|
57
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
58
|
-
selector: 'canvas[previewFlow]',
|
|
59
|
-
template: '',
|
|
60
|
-
}]
|
|
61
|
-
}], ctorParameters: () => [] });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy1mbG93LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9jb21wb25lbnRzL3ByZXZpZXctZmxvdy9wcmV2aWV3LWZsb3cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqSCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0scURBQXFELENBQUM7QUFDdkcsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN2QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7QUFRN0UsTUFBTSxPQUFPLG9CQUFvQjtJQWMvQjtRQWJRLG9CQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQzFDLG1CQUFjLEdBQUcsTUFBTSxDQUFDLGdDQUFnQyxDQUFDLENBQUM7UUFDMUQseUJBQW9CLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFDcEQsY0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUU5QixZQUFPLEdBQUcsTUFBTSxDQUFnQyxVQUFVLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDMUUsUUFBRyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBRSxDQUFDO1FBRXBDLFVBQUssR0FBRyxLQUFLLENBQVMsQ0FBQyxDQUFDLENBQUM7UUFDekIsV0FBTSxHQUFHLEtBQUssQ0FBUyxDQUFDLENBQUMsQ0FBQztRQUVsQixRQUFHLEdBQUcsTUFB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ZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBlZmZlY3QsIEVsZW1lbnRSZWYsIGluamVjdCwgaW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVmlld3BvcnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdmlld3BvcnQuc2VydmljZSc7XG5pbXBvcnQgeyBQcmV2aWV3Rmxvd1JlbmRlclN0cmF0ZWd5U2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3ByZXZpZXctZmxvdy1yZW5kZXItc3RyYXRlZ3kuc2VydmljZSc7XG5pbXBvcnQgeyBkcmF3Tm9kZSB9IGZyb20gJy4vZHJhdy1ub2RlJztcbmltcG9ydCB7IE5vZGVSZW5kZXJpbmdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbm9kZS1yZW5kZXJpbmcuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc2VsZWN0b3I6ICdjYW52YXNbcHJldmlld0Zsb3ddJyxcbiAgdGVtcGxhdGU6ICcnLFxufSlcbmV4cG9ydCBjbGFzcyBQcmV2aWV3Rmxvd0NvbXBvbmVudCB7XG4gIHByaXZhdGUgdmlld3BvcnRTZXJ2aWNlID0gaW5qZWN0KFZpZXdwb3J0U2VydmljZSk7XG4gIHByaXZhdGUgcmVuZGVyU3RyYXRlZ3kgPSBpbmplY3QoUHJldmlld0Zsb3dSZW5kZXJTdHJhdGVneVNlcnZpY2UpO1xuICBwcml2YXRlIG5vZGVSZW5kZXJpbmdTZXJ2aWNlID0gaW5qZWN0KE5vZGVSZW5kZXJpbmdTZXJ2aWNlKTtcbiAgcHJpdmF0ZSByZW5kZXJlcjIgPSBpbmplY3QoUmVuZGVyZXIyKTtcblxuICBwcml2YXRlIGVsZW1lbnQgPSBpbmplY3Q8RWxlbWVudFJlZjxIVE1MQ2FudmFzRWxlbWVudD4+KEVsZW1lbnRSZWYpLm5hdGl2ZUVsZW1lbnQ7XG4gIHByaXZhdGUgY3R4ID0gdGhpcy5lbGVtZW50LmdldENvbnRleHQoJzJkJykhO1xuXG4gIHJlYWRvbmx5IHdpZHRoID0gaW5wdXQ8bnVtYmVyPigwKTtcbiAgcmVhZG9ubHkgaGVpZ2h0ID0gaW5wdXQ8bnVtYmVyPigwKTtcblxuICBwcml2YXRlIHJlYWRvbmx5IGRwciA9IHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGVmZmVjdCgoKSA9PiB7XG4gICAgICAvLyBTZXQgdGhlIFwiYWN0dWFsXCIgc2l6ZSBvZiB0aGUgY2FudmFzXG4gICAgICB0aGlzLnJlbmRlcmVyMi5zZXRQcm9wZXJ0eSh0aGlzLmVsZW1lbnQsICd3aWR0aCcsIHRoaXMud2lkdGgoKSAqIHRoaXMuZHByKTtcbiAgICAgIHRoaXMucmVuZGVyZXIyLnNldFByb3BlcnR5KHRoaXMuZWxlbWVudCwgJ2hlaWdodCcsIHRoaXMuaGVpZ2h0KCkgKiB0aGlzLmRwcik7XG5cbiAgICAgIC8vIFNldCB0aGUgXCJkcmF3blwiIHNpemUgb2YgdGhlIGNhbnZhc1xuICAgICAgdGhpcy5yZW5kZXJlcjIuc2V0U3R5bGUodGhpcy5lbGVtZW50LCAnd2lkdGgnLCBgJHt0aGlzLndpZHRoKCl9cHhgKTtcbiAgICAgIHRoaXMucmVuZGVyZXIyLnNldFN0eWxlKHRoaXMuZWxlbWVudCwgJ2hlaWdodCcsIGAke3RoaXMuaGVpZ2h0KCl9cHhgKTtcblxuICAgICAgLy8gU2NhbGUgdGhlIGNvbnRleHQgdG8gbWF0Y2ggZGV2aWNlIHBpeGVsIHJhdGlvXG4gICAgICB0aGlzLmN0eC5zY2FsZSh0aGlzLmRwciwgdGhpcy5kcHIpO1xuICAgIH0pO1xuXG4gICAgZWZmZWN0KCgpID0+IHtcbiAgICAgIGNvbnN0IHZpZXdwb3J0ID0gdGhpcy52aWV3cG9ydFNlcnZpY2UucmVhZGFibGVWaWV3cG9ydCgpO1xuXG4gICAgICB0aGlzLmN0eC5jbGVhclJlY3QoMCwgMCwgdGhpcy53aWR0aCgpLCB0aGlzLmhlaWdodCgpKTtcblxuICAgICAgLy8gU2F2ZSB0aGUgY3VycmVudCBjb250ZXh0IHN0YXRlXG4gICAgICB0aGlzLmN0eC5zYXZlKCk7XG5cbiAgICAgIC8vIEFwcGx5IHZpZXdwb3J0IHRyYW5zZm9ybWF0aW9ucyAoem9vbSBhbmQgcGFuKVxuICAgICAgdGhpcy5jdHguc2V0VHJhbnNmb3JtKFxuICAgICAgICB2aWV3cG9ydC56b29tICogdGhpcy5kcHIsIC8vIGhvcml6b250YWwgc2NhbGluZyB3aXRoIERQUlxuICAgICAgICAwLCAvLyBob3Jpem9udGFsIHNrZXdpbmdcbiAgICAgICAgMCwgLy8gdmVydGljYWwgc2tld2luZ1xuICAgICAgICB2aWV3cG9ydC56b29tICogdGhpcy5kcHIsIC8vIHZlcnRpY2FsIHNjYWxpbmcgd2l0aCBEUFJcbiAgICAgICAgdmlld3BvcnQueCAqIHRoaXMuZHByLCAvLyBob3Jpem9udGFsIHRyYW5zbGF0aW9uIHdpdGggRFBSXG4gICAgICAgIHZpZXdwb3J0LnkgKiB0aGlzLmRwciwgLy8gdmVydGljYWwgdHJhbnNsYXRpb24gd2l0aCBEUFJcbiAgICAgICk7XG5cbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5ub2RlUmVuZGVyaW5nU2VydmljZS52aWV3cG9ydE5vZGVzKCkubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgY29uc3Qgbm9kZSA9IHRoaXMubm9kZVJlbmRlcmluZ1NlcnZpY2Uudmlld3BvcnROb2RlcygpW2ldO1xuXG4gICAgICAgIGlmICh0aGlzLnJlbmRlclN0cmF0ZWd5LnNob3VsZFJlbmRlck5vZGUobm9kZSkpIHtcbiAgICAgICAgICBkcmF3Tm9kZSh0aGlzLmN0eCwgbm9kZSk7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gUmVzdG9yZSB0aGUgY29udGV4dCBzdGF0ZVxuICAgICAgdGhpcy5jdHgucmVzdG9yZSgpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -1,437 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Injector, Input, inject, runInInjectionContext, contentChild, viewChild, input, } from '@angular/core';
|
|
2
|
-
import { MapContextDirective } from '../../directives/map-context.directive';
|
|
3
|
-
import { DraggableService } from '../../services/draggable.service';
|
|
4
|
-
import { ViewportService } from '../../services/viewport.service';
|
|
5
|
-
import { toObservable, outputFromObservable } from '@angular/core/rxjs-interop';
|
|
6
|
-
import { ConnectionTemplateDirective, EdgeLabelHtmlTemplateDirective, EdgeTemplateDirective, GroupNodeTemplateDirective, NodeHtmlTemplateDirective, NodeSvgTemplateDirective, } from '../../directives/template.directive';
|
|
7
|
-
import { addNodesToEdges } from '../../utils/add-nodes-to-edges';
|
|
8
|
-
import { skip } from 'rxjs';
|
|
9
|
-
import { FlowStatusService } from '../../services/flow-status.service';
|
|
10
|
-
import { FlowEntitiesService } from '../../services/flow-entities.service';
|
|
11
|
-
import { ConnectionModel } from '../../models/connection.model';
|
|
12
|
-
import { ReferenceIdentityChecker } from '../../utils/identity-checker/reference-identity-checker';
|
|
13
|
-
import { NodesChangeService } from '../../services/node-changes.service';
|
|
14
|
-
import { EdgeChangesService } from '../../services/edge-changes.service';
|
|
15
|
-
import { ChangesControllerDirective } from '../../directives/changes-controller.directive';
|
|
16
|
-
import { NodeRenderingService } from '../../services/node-rendering.service';
|
|
17
|
-
import { SelectionService } from '../../services/selection.service';
|
|
18
|
-
import { FlowSettingsService } from '../../services/flow-settings.service';
|
|
19
|
-
import { ComponentEventBusService } from '../../services/component-event-bus.service';
|
|
20
|
-
import { SpacePointContextDirective } from '../../directives/space-point-context.directive';
|
|
21
|
-
import { KeyboardService } from '../../services/keyboard.service';
|
|
22
|
-
import { transformBackground } from '../../utils/transform-background';
|
|
23
|
-
import { OverlaysService } from '../../services/overlays.service';
|
|
24
|
-
import { NgTemplateOutlet } from '@angular/common';
|
|
25
|
-
import { EdgeComponent } from '../edge/edge.component';
|
|
26
|
-
import { NodeComponent } from '../node/node.component';
|
|
27
|
-
import { ConnectionComponent } from '../connection/connection.component';
|
|
28
|
-
import { BackgroundComponent } from '../background/background.component';
|
|
29
|
-
import { DefsComponent } from '../defs/defs.component';
|
|
30
|
-
import { FlowSizeControllerDirective } from '../../directives/flow-size-controller.directive';
|
|
31
|
-
import { RootPointerDirective } from '../../directives/root-pointer.directive';
|
|
32
|
-
import { RootSvgContextDirective } from '../../directives/root-svg-context.directive';
|
|
33
|
-
import { RootSvgReferenceDirective } from '../../directives/reference.directive';
|
|
34
|
-
import { EdgeRenderingService } from '../../services/edge-rendering.service';
|
|
35
|
-
import { getSpacePoints } from '../../utils/get-space-points';
|
|
36
|
-
import { getIntesectingNodes } from '../../utils/nodes';
|
|
37
|
-
import { PreviewFlowComponent } from '../preview-flow/preview-flow.component';
|
|
38
|
-
import { PreviewFlowRenderStrategyService, ViewportPreviewFlowRenderStrategyService, } from '../../services/preview-flow-render-strategy.service';
|
|
39
|
-
import { toLazySignal } from '../../utils/signals/to-lazy-signal';
|
|
40
|
-
import { FlowRenderingService } from '../../services/flow-rendering.service';
|
|
41
|
-
import { AlignmentHelperComponent } from '../alignment-helper/alignment-helper.component';
|
|
42
|
-
import * as i0 from "@angular/core";
|
|
43
|
-
import * as i1 from "../../directives/changes-controller.directive";
|
|
44
|
-
const changesControllerHostDirective = {
|
|
45
|
-
directive: ChangesControllerDirective,
|
|
46
|
-
outputs: [
|
|
47
|
-
'onNodesChange',
|
|
48
|
-
'onNodesChange.position',
|
|
49
|
-
'onNodesChange.position.single',
|
|
50
|
-
'onNodesChange.position.many',
|
|
51
|
-
'onNodesChange.size',
|
|
52
|
-
'onNodesChange.size.single',
|
|
53
|
-
'onNodesChange.size.many',
|
|
54
|
-
'onNodesChange.add',
|
|
55
|
-
'onNodesChange.add.single',
|
|
56
|
-
'onNodesChange.add.many',
|
|
57
|
-
'onNodesChange.remove',
|
|
58
|
-
'onNodesChange.remove.single',
|
|
59
|
-
'onNodesChange.remove.many',
|
|
60
|
-
'onNodesChange.select',
|
|
61
|
-
'onNodesChange.select.single',
|
|
62
|
-
'onNodesChange.select.many',
|
|
63
|
-
'onEdgesChange',
|
|
64
|
-
'onEdgesChange.detached',
|
|
65
|
-
'onEdgesChange.detached.single',
|
|
66
|
-
'onEdgesChange.detached.many',
|
|
67
|
-
'onEdgesChange.add',
|
|
68
|
-
'onEdgesChange.add.single',
|
|
69
|
-
'onEdgesChange.add.many',
|
|
70
|
-
'onEdgesChange.remove',
|
|
71
|
-
'onEdgesChange.remove.single',
|
|
72
|
-
'onEdgesChange.remove.many',
|
|
73
|
-
'onEdgesChange.select',
|
|
74
|
-
'onEdgesChange.select.single',
|
|
75
|
-
'onEdgesChange.select.many',
|
|
76
|
-
],
|
|
77
|
-
};
|
|
78
|
-
export class VflowComponent {
|
|
79
|
-
constructor() {
|
|
80
|
-
// #region DI
|
|
81
|
-
this.viewportService = inject(ViewportService);
|
|
82
|
-
this.flowEntitiesService = inject(FlowEntitiesService);
|
|
83
|
-
this.nodesChangeService = inject(NodesChangeService);
|
|
84
|
-
this.edgesChangeService = inject(EdgeChangesService);
|
|
85
|
-
this.nodeRenderingService = inject(NodeRenderingService);
|
|
86
|
-
this.edgeRenderingService = inject(EdgeRenderingService);
|
|
87
|
-
this.flowSettingsService = inject(FlowSettingsService);
|
|
88
|
-
this.componentEventBusService = inject(ComponentEventBusService);
|
|
89
|
-
this.keyboardService = inject(KeyboardService);
|
|
90
|
-
this.injector = inject(Injector);
|
|
91
|
-
this.flowRenderingService = inject(FlowRenderingService);
|
|
92
|
-
this.alignmentHelper = input(false);
|
|
93
|
-
this.nodeModels = this.nodeRenderingService.nodes;
|
|
94
|
-
this.groups = this.nodeRenderingService.groups;
|
|
95
|
-
this.nonGroups = this.nodeRenderingService.nonGroups;
|
|
96
|
-
this.edgeModels = this.edgeRenderingService.edges;
|
|
97
|
-
// #endregion
|
|
98
|
-
// #region OUTPUTS
|
|
99
|
-
/**
|
|
100
|
-
* Event that accumulates all custom node events
|
|
101
|
-
*
|
|
102
|
-
* @experimental
|
|
103
|
-
*/
|
|
104
|
-
this.onComponentNodeEvent = outputFromObservable(this.componentEventBusService.event$); // TODO: research how to remove any
|
|
105
|
-
// #endregion
|
|
106
|
-
// #region TEMPLATES
|
|
107
|
-
this.nodeTemplateDirective = contentChild(NodeHtmlTemplateDirective);
|
|
108
|
-
this.nodeSvgTemplateDirective = contentChild(NodeSvgTemplateDirective);
|
|
109
|
-
this.groupNodeTemplateDirective = contentChild(GroupNodeTemplateDirective);
|
|
110
|
-
this.edgeTemplateDirective = contentChild(EdgeTemplateDirective);
|
|
111
|
-
this.edgeLabelHtmlDirective = contentChild(EdgeLabelHtmlTemplateDirective);
|
|
112
|
-
this.connectionTemplateDirective = contentChild(ConnectionTemplateDirective);
|
|
113
|
-
// #endregion
|
|
114
|
-
// #region DIRECTIVES
|
|
115
|
-
this.mapContext = viewChild(MapContextDirective);
|
|
116
|
-
this.spacePointContext = viewChild.required(SpacePointContextDirective);
|
|
117
|
-
// #endregion
|
|
118
|
-
// #region SIGNAL_API
|
|
119
|
-
/**
|
|
120
|
-
* Signal for reading viewport change
|
|
121
|
-
*/
|
|
122
|
-
this.viewport = this.viewportService.readableViewport.asReadonly();
|
|
123
|
-
/**
|
|
124
|
-
* Signal for reading nodes change
|
|
125
|
-
*/
|
|
126
|
-
this.nodesChange = toLazySignal(this.nodesChangeService.changes$, {
|
|
127
|
-
initialValue: [],
|
|
128
|
-
});
|
|
129
|
-
/**
|
|
130
|
-
* Signal to reading edges change
|
|
131
|
-
*/
|
|
132
|
-
this.edgesChange = toLazySignal(this.edgesChangeService.changes$, {
|
|
133
|
-
initialValue: [],
|
|
134
|
-
});
|
|
135
|
-
this.initialized = this.flowRenderingService.flowInitialized.asReadonly();
|
|
136
|
-
// #endregion
|
|
137
|
-
// #region RX_API
|
|
138
|
-
/**
|
|
139
|
-
* Observable with viewport change
|
|
140
|
-
*/
|
|
141
|
-
this.viewportChange$ = toObservable(this.viewportService.readableViewport).pipe(skip(1)); // skip default value that set by signal
|
|
142
|
-
/**
|
|
143
|
-
* Observable with nodes change
|
|
144
|
-
*/
|
|
145
|
-
this.nodesChange$ = this.nodesChangeService.changes$;
|
|
146
|
-
/**
|
|
147
|
-
* Observable with edges change
|
|
148
|
-
*/
|
|
149
|
-
this.edgesChange$ = this.edgesChangeService.changes$;
|
|
150
|
-
this.initialized$ = toObservable(this.flowRenderingService.flowInitialized);
|
|
151
|
-
// #endregion
|
|
152
|
-
this.markers = this.flowEntitiesService.markers;
|
|
153
|
-
this.minimap = this.flowEntitiesService.minimap;
|
|
154
|
-
this.flowOptimization = this.flowSettingsService.optimization;
|
|
155
|
-
this.flowWidth = this.flowSettingsService.computedFlowWidth;
|
|
156
|
-
this.flowHeight = this.flowSettingsService.computedFlowHeight;
|
|
157
|
-
}
|
|
158
|
-
// #endregion
|
|
159
|
-
// #region SETTINGS
|
|
160
|
-
/**
|
|
161
|
-
* Size for flow view
|
|
162
|
-
*
|
|
163
|
-
* accepts
|
|
164
|
-
* - absolute size in format [width, height] or
|
|
165
|
-
* - 'auto' to compute size based on parent element size
|
|
166
|
-
*/
|
|
167
|
-
set view(view) {
|
|
168
|
-
this.flowSettingsService.view.set(view);
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* Minimum zoom value
|
|
172
|
-
*/
|
|
173
|
-
set minZoom(value) {
|
|
174
|
-
this.flowSettingsService.minZoom.set(value);
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* Maximum zoom value
|
|
178
|
-
*/
|
|
179
|
-
set maxZoom(value) {
|
|
180
|
-
this.flowSettingsService.maxZoom.set(value);
|
|
181
|
-
}
|
|
182
|
-
/**
|
|
183
|
-
* Background for flow
|
|
184
|
-
*/
|
|
185
|
-
set background(value) {
|
|
186
|
-
this.flowSettingsService.background.set(transformBackground(value));
|
|
187
|
-
}
|
|
188
|
-
set optimization(newOptimization) {
|
|
189
|
-
this.flowSettingsService.optimization.update((optimization) => ({
|
|
190
|
-
...optimization,
|
|
191
|
-
...newOptimization,
|
|
192
|
-
}));
|
|
193
|
-
}
|
|
194
|
-
/**
|
|
195
|
-
* Global rule if you can or can't select entities
|
|
196
|
-
*/
|
|
197
|
-
set entitiesSelectable(value) {
|
|
198
|
-
this.flowSettingsService.entitiesSelectable.set(value);
|
|
199
|
-
}
|
|
200
|
-
set keyboardShortcuts(value) {
|
|
201
|
-
this.keyboardService.setShortcuts(value);
|
|
202
|
-
}
|
|
203
|
-
/**
|
|
204
|
-
* Settings for connection (it renders when user tries to create edge between nodes)
|
|
205
|
-
*
|
|
206
|
-
* You need to pass `ConnectionSettings` in this input.
|
|
207
|
-
*/
|
|
208
|
-
set connection(connection) {
|
|
209
|
-
this.flowEntitiesService.connection.set(connection);
|
|
210
|
-
}
|
|
211
|
-
get connection() {
|
|
212
|
-
return this.flowEntitiesService.connection();
|
|
213
|
-
}
|
|
214
|
-
/**
|
|
215
|
-
* Snap grid for node movement. Passes as [x, y]
|
|
216
|
-
*/
|
|
217
|
-
set snapGrid(value) {
|
|
218
|
-
this.flowSettingsService.snapGrid.set(value);
|
|
219
|
-
}
|
|
220
|
-
/**
|
|
221
|
-
* Raizing z-index for selected node
|
|
222
|
-
*/
|
|
223
|
-
set elevateNodesOnSelect(value) {
|
|
224
|
-
this.flowSettingsService.elevateNodesOnSelect.set(value);
|
|
225
|
-
}
|
|
226
|
-
/**
|
|
227
|
-
* Raizing z-index for selected edge
|
|
228
|
-
*/
|
|
229
|
-
set elevateEdgesOnSelect(value) {
|
|
230
|
-
this.flowSettingsService.elevateEdgesOnSelect.set(value);
|
|
231
|
-
}
|
|
232
|
-
// #endregion
|
|
233
|
-
// #region MAIN_INPUTS
|
|
234
|
-
/**
|
|
235
|
-
* Nodes to render
|
|
236
|
-
*/
|
|
237
|
-
set nodes(newNodes) {
|
|
238
|
-
const models = runInInjectionContext(this.injector, () => ReferenceIdentityChecker.nodes(newNodes, this.flowEntitiesService.nodes()));
|
|
239
|
-
// TODO: consider calling only fo new nodes
|
|
240
|
-
// quick and dirty binding nodes to edges
|
|
241
|
-
addNodesToEdges(models, this.flowEntitiesService.edges());
|
|
242
|
-
this.flowEntitiesService.nodes.set(models);
|
|
243
|
-
models.forEach((model) => this.nodeRenderingService.pullNode(model));
|
|
244
|
-
}
|
|
245
|
-
/**
|
|
246
|
-
* Edges to render
|
|
247
|
-
*/
|
|
248
|
-
set edges(newEdges) {
|
|
249
|
-
const newModels = runInInjectionContext(this.injector, () => ReferenceIdentityChecker.edges(newEdges, this.flowEntitiesService.edges()));
|
|
250
|
-
// quick and dirty binding nodes to edges
|
|
251
|
-
addNodesToEdges(this.flowEntitiesService.nodes(), newModels);
|
|
252
|
-
this.flowEntitiesService.edges.set(newModels);
|
|
253
|
-
}
|
|
254
|
-
// #region METHODS_API
|
|
255
|
-
/**
|
|
256
|
-
* Change viewport to specified state
|
|
257
|
-
*
|
|
258
|
-
* @param viewport viewport state
|
|
259
|
-
*/
|
|
260
|
-
viewportTo(viewport) {
|
|
261
|
-
this.viewportService.writableViewport.set({
|
|
262
|
-
changeType: 'absolute',
|
|
263
|
-
state: viewport,
|
|
264
|
-
duration: 0,
|
|
265
|
-
});
|
|
266
|
-
}
|
|
267
|
-
/**
|
|
268
|
-
* Change zoom
|
|
269
|
-
*
|
|
270
|
-
* @param zoom zoom value
|
|
271
|
-
*/
|
|
272
|
-
zoomTo(zoom) {
|
|
273
|
-
this.viewportService.writableViewport.set({
|
|
274
|
-
changeType: 'absolute',
|
|
275
|
-
state: { zoom },
|
|
276
|
-
duration: 0,
|
|
277
|
-
});
|
|
278
|
-
}
|
|
279
|
-
/**
|
|
280
|
-
* Move to specified coordinate
|
|
281
|
-
*
|
|
282
|
-
* @param point point where to move
|
|
283
|
-
*/
|
|
284
|
-
panTo(point) {
|
|
285
|
-
this.viewportService.writableViewport.set({
|
|
286
|
-
changeType: 'absolute',
|
|
287
|
-
state: point,
|
|
288
|
-
duration: 0,
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
fitView(options) {
|
|
292
|
-
this.viewportService.fitView(options);
|
|
293
|
-
}
|
|
294
|
-
/**
|
|
295
|
-
* Get node by id
|
|
296
|
-
*
|
|
297
|
-
* @param id node id
|
|
298
|
-
*/
|
|
299
|
-
getNode(id) {
|
|
300
|
-
return this.flowEntitiesService.getNode(id)?.rawNode;
|
|
301
|
-
}
|
|
302
|
-
/**
|
|
303
|
-
* Sync method to get detached edges
|
|
304
|
-
*/
|
|
305
|
-
getDetachedEdges() {
|
|
306
|
-
return this.flowEntitiesService.getDetachedEdges().map((e) => e.edge);
|
|
307
|
-
}
|
|
308
|
-
documentPointToFlowPoint(point, options) {
|
|
309
|
-
const transformedPoint = this.spacePointContext().documentPointToFlowPoint(point);
|
|
310
|
-
if (options?.spaces) {
|
|
311
|
-
return getSpacePoints(transformedPoint, this.nodeRenderingService.groups());
|
|
312
|
-
}
|
|
313
|
-
return transformedPoint;
|
|
314
|
-
}
|
|
315
|
-
/**
|
|
316
|
-
* Gets nodes that intersect with the specified node
|
|
317
|
-
*
|
|
318
|
-
* @template T - The type of data associated with the nodes
|
|
319
|
-
* @param nodeId - The ID of the node to check intersections for
|
|
320
|
-
* @param options.partially - If true, returns nodes that partially intersect. If false, only returns fully intersecting nodes
|
|
321
|
-
* @returns An array of nodes that intersect with the specified node
|
|
322
|
-
*/
|
|
323
|
-
getIntesectingNodes(nodeId, options = { partially: true }) {
|
|
324
|
-
return getIntesectingNodes(nodeId, this.nodeModels(), options).map((n) => n.rawNode);
|
|
325
|
-
}
|
|
326
|
-
/**
|
|
327
|
-
* Converts a node's position to the coordinate space of another node
|
|
328
|
-
*
|
|
329
|
-
* @param nodeId - The ID of the node whose position should be converted
|
|
330
|
-
* @param spaceNodeId - The ID of the node that defines the target coordinate space.
|
|
331
|
-
* If null, returns the position in global coordinates
|
|
332
|
-
* @returns {Point} The converted position. Returns {x: Infinity, y: Infinity} if either node is not found
|
|
333
|
-
*/
|
|
334
|
-
toNodeSpace(nodeId, spaceNodeId) {
|
|
335
|
-
const node = this.nodeModels().find((n) => n.rawNode.id === nodeId);
|
|
336
|
-
if (!node)
|
|
337
|
-
return { x: Infinity, y: Infinity };
|
|
338
|
-
if (spaceNodeId === null) {
|
|
339
|
-
return node.globalPoint();
|
|
340
|
-
}
|
|
341
|
-
const coordinateSpaceNode = this.nodeModels().find((n) => n.rawNode.id === spaceNodeId);
|
|
342
|
-
if (!coordinateSpaceNode)
|
|
343
|
-
return { x: Infinity, y: Infinity };
|
|
344
|
-
return getSpacePoints(node.globalPoint(), [coordinateSpaceNode])[0];
|
|
345
|
-
}
|
|
346
|
-
// #endregion
|
|
347
|
-
trackNodes(idx, { rawNode: node }) {
|
|
348
|
-
return node;
|
|
349
|
-
}
|
|
350
|
-
trackEdges(idx, { edge }) {
|
|
351
|
-
return edge;
|
|
352
|
-
}
|
|
353
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
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: [
|
|
355
|
-
DraggableService,
|
|
356
|
-
ViewportService,
|
|
357
|
-
FlowStatusService,
|
|
358
|
-
FlowEntitiesService,
|
|
359
|
-
NodesChangeService,
|
|
360
|
-
EdgeChangesService,
|
|
361
|
-
NodeRenderingService,
|
|
362
|
-
EdgeRenderingService,
|
|
363
|
-
SelectionService,
|
|
364
|
-
FlowSettingsService,
|
|
365
|
-
ComponentEventBusService,
|
|
366
|
-
KeyboardService,
|
|
367
|
-
OverlaysService,
|
|
368
|
-
{ provide: PreviewFlowRenderStrategyService, useClass: ViewportPreviewFlowRenderStrategyService },
|
|
369
|
-
FlowRenderingService,
|
|
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 }); }
|
|
371
|
-
}
|
|
372
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, decorators: [{
|
|
373
|
-
type: Component,
|
|
374
|
-
args: [{ standalone: true, selector: 'vflow', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
375
|
-
DraggableService,
|
|
376
|
-
ViewportService,
|
|
377
|
-
FlowStatusService,
|
|
378
|
-
FlowEntitiesService,
|
|
379
|
-
NodesChangeService,
|
|
380
|
-
EdgeChangesService,
|
|
381
|
-
NodeRenderingService,
|
|
382
|
-
EdgeRenderingService,
|
|
383
|
-
SelectionService,
|
|
384
|
-
FlowSettingsService,
|
|
385
|
-
ComponentEventBusService,
|
|
386
|
-
KeyboardService,
|
|
387
|
-
OverlaysService,
|
|
388
|
-
{ provide: PreviewFlowRenderStrategyService, useClass: ViewportPreviewFlowRenderStrategyService },
|
|
389
|
-
FlowRenderingService,
|
|
390
|
-
], hostDirectives: [changesControllerHostDirective], imports: [
|
|
391
|
-
RootSvgReferenceDirective,
|
|
392
|
-
RootSvgContextDirective,
|
|
393
|
-
RootPointerDirective,
|
|
394
|
-
FlowSizeControllerDirective,
|
|
395
|
-
DefsComponent,
|
|
396
|
-
BackgroundComponent,
|
|
397
|
-
MapContextDirective,
|
|
398
|
-
SpacePointContextDirective,
|
|
399
|
-
ConnectionComponent,
|
|
400
|
-
NodeComponent,
|
|
401
|
-
EdgeComponent,
|
|
402
|
-
NgTemplateOutlet,
|
|
403
|
-
PreviewFlowComponent,
|
|
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"] }]
|
|
406
|
-
}], propDecorators: { view: [{
|
|
407
|
-
type: Input
|
|
408
|
-
}], minZoom: [{
|
|
409
|
-
type: Input
|
|
410
|
-
}], maxZoom: [{
|
|
411
|
-
type: Input
|
|
412
|
-
}], background: [{
|
|
413
|
-
type: Input
|
|
414
|
-
}], optimization: [{
|
|
415
|
-
type: Input
|
|
416
|
-
}], entitiesSelectable: [{
|
|
417
|
-
type: Input
|
|
418
|
-
}], keyboardShortcuts: [{
|
|
419
|
-
type: Input
|
|
420
|
-
}], connection: [{
|
|
421
|
-
type: Input,
|
|
422
|
-
args: [{
|
|
423
|
-
transform: (settings) => new ConnectionModel(settings),
|
|
424
|
-
}]
|
|
425
|
-
}], snapGrid: [{
|
|
426
|
-
type: Input
|
|
427
|
-
}], elevateNodesOnSelect: [{
|
|
428
|
-
type: Input
|
|
429
|
-
}], elevateEdgesOnSelect: [{
|
|
430
|
-
type: Input
|
|
431
|
-
}], nodes: [{
|
|
432
|
-
type: Input,
|
|
433
|
-
args: [{ required: true }]
|
|
434
|
-
}], edges: [{
|
|
435
|
-
type: Input
|
|
436
|
-
}] } });
|
|
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"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
// this is a number to fix visual artifact in chrome.
|
|
2
|
-
// the bug reproduces if edgeLabelWrapperRef size fully matched the size of parent foreignObject
|
|
3
|
-
export const MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME = 2;
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtbnVtYmVyLXRvLWZpeC1nbGl0Y2gtaW4tY2hyb21lLmNvbnN0YW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2NvbnN0YW50cy9tYWdpYy1udW1iZXItdG8tZml4LWdsaXRjaC1pbi1jaHJvbWUuY29uc3RhbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscURBQXFEO0FBQ3JELGdHQUFnRztBQUNoRyxNQUFNLENBQUMsTUFBTSxvQ0FBb0MsR0FBRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0aGlzIGlzIGEgbnVtYmVyIHRvIGZpeCB2aXN1YWwgYXJ0aWZhY3QgaW4gY2hyb21lLlxuLy8gdGhlIGJ1ZyByZXByb2R1Y2VzIGlmIGVkZ2VMYWJlbFdyYXBwZXJSZWYgc2l6ZSBmdWxseSBtYXRjaGVkIHRoZSBzaXplIG9mIHBhcmVudCBmb3JlaWduT2JqZWN0XG5leHBvcnQgY29uc3QgTUFHSUNfTlVNQkVSX1RPX0ZJWF9HTElUQ0hfSU5fQ0hST01FID0gMjtcbiJdfQ==
|