ngx-vflow 1.11.1 → 1.12.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/background/background.component.mjs +4 -3
- package/esm2022/lib/vflow/components/node/node.component.mjs +3 -1
- package/esm2022/lib/vflow/components/preview-flow/draw-node.mjs +100 -0
- package/esm2022/lib/vflow/components/preview-flow/preview-flow.component.mjs +62 -0
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +26 -12
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +28 -18
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +3 -3
- package/esm2022/lib/vflow/interfaces/node-preview.interface.mjs +2 -0
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +6 -2
- package/esm2022/lib/vflow/models/edge.model.mjs +42 -15
- package/esm2022/lib/vflow/models/handle.model.mjs +3 -1
- package/esm2022/lib/vflow/models/node.model.mjs +6 -1
- package/esm2022/lib/vflow/services/edge-rendering.service.mjs +14 -2
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +3 -1
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +35 -2
- package/esm2022/lib/vflow/services/preview-flow-render-strategy.service.mjs +21 -0
- package/esm2022/lib/vflow/services/viewport.service.mjs +8 -1
- package/esm2022/lib/vflow/utils/assert-injector.mjs +27 -0
- package/esm2022/lib/vflow/utils/signals/extended-computed.mjs +15 -0
- package/esm2022/lib/vflow/utils/signals/to-lazy-signal.mjs +35 -0
- package/esm2022/lib/vflow/utils/viewport.mjs +37 -1
- package/esm2022/public-api.mjs +2 -1
- package/esm2022/testing/component-mocks/vflow-mock.component.mjs +7 -7
- package/fesm2022/ngx-vflow-testing.mjs +6 -6
- package/fesm2022/ngx-vflow-testing.mjs.map +1 -1
- package/fesm2022/ngx-vflow.mjs +436 -46
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/preview-flow/draw-node.d.ts +2 -0
- package/lib/vflow/components/preview-flow/preview-flow.component.d.ts +15 -0
- package/lib/vflow/components/vflow/vflow.component.d.ts +5 -2
- package/lib/vflow/directives/map-context.directive.d.ts +3 -2
- package/lib/vflow/interfaces/node-preview.interface.d.ts +3 -0
- package/lib/vflow/interfaces/node.interface.d.ts +3 -0
- package/lib/vflow/interfaces/optimization.interface.d.ts +17 -1
- package/lib/vflow/models/node.model.d.ts +3 -0
- package/lib/vflow/services/edge-rendering.service.d.ts +2 -0
- package/lib/vflow/services/flow-settings.service.d.ts +2 -0
- package/lib/vflow/services/node-rendering.service.d.ts +4 -0
- package/lib/vflow/services/preview-flow-render-strategy.service.d.ts +12 -0
- package/lib/vflow/services/viewport.service.d.ts +3 -0
- package/lib/vflow/utils/assert-injector.d.ts +44 -0
- package/lib/vflow/utils/signals/extended-computed.d.ts +5 -0
- package/lib/vflow/utils/signals/to-lazy-signal.d.ts +20 -0
- package/lib/vflow/utils/viewport.d.ts +19 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/testing/component-mocks/vflow-mock.component.d.ts +3 -3
|
@@ -1,2 +1,6 @@
|
|
|
1
|
-
export {
|
|
2
|
-
|
|
1
|
+
export const DEFAULT_OPTIMIZATION = {
|
|
2
|
+
detachedGroupsLayer: false,
|
|
3
|
+
virtualization: false,
|
|
4
|
+
virtualizationZoomThreshold: 0.5,
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW1pemF0aW9uLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9pbnRlcmZhY2VzL29wdGltaXphdGlvbi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQTJCO0lBQzFELG1CQUFtQixFQUFFLEtBQUs7SUFDMUIsY0FBYyxFQUFFLEtBQUs7SUFDckIsMkJBQTJCLEVBQUUsR0FBRztDQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFRkFVTFRfT1BUSU1JWkFUSU9OOiBSZXF1aXJlZDxPcHRpbWl6YXRpb24+ID0ge1xuICBkZXRhY2hlZEdyb3Vwc0xheWVyOiBmYWxzZSxcbiAgdmlydHVhbGl6YXRpb246IGZhbHNlLFxuICB2aXJ0dWFsaXphdGlvblpvb21UaHJlc2hvbGQ6IDAuNSxcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3B0aW1pemF0aW9uIHtcbiAgLyoqXG4gICAqIElmIHRydWUsIHRoZSBsYXllciB3aXRoIGdyb3VwcyB3aWxsIGJlIHBsYWNlZCBiZWhpbmQgdGhlIGVkZ2VzIGxheWVyLlxuICAgKiBUaGlzIGFwcHJvYWNoIGZpeGVzIHRoZSBpc3N1ZSB3aGVuIHlvdSBjYW4ndCBzZWxlY3QgYW4gZWRnZSBpbnNpZGUgZ3JvdXAuXG4gICAqXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICBkZXRhY2hlZEdyb3Vwc0xheWVyPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogSWYgdHJ1ZSwgZW5hYmxlcyB2aWV3cG9ydCB2aXJ0dWFsaXphdGlvbiB0byBpbXByb3ZlIHBlcmZvcm1hbmNlIGJ5IG9ubHkgcmVuZGVyaW5nXG4gICAqIG5vZGVzIGFuZCBlZGdlcyB0aGF0IGFyZSBjdXJyZW50bHkgdmlzaWJsZSBpbiB0aGUgdmlld3BvcnQuIFRoaXMgb3B0aW1pemF0aW9uXG4gICAqIGZpbHRlcnMgb3V0IGVudGl0aWVzIHRoYXQgYXJlIG91dHNpZGUgdGhlIHZpc2libGUgYXJlYSwgcmVkdWNpbmcgdGhlIG51bWJlciBvZlxuICAgKiBET00gZWxlbWVudHMgYW5kIGltcHJvdmluZyByZW5kZXJpbmcgcGVyZm9ybWFuY2UgZm9yIGxhcmdlIGZsb3dzLlxuICAgKlxuICAgKiBJdCB1c2VzIGNhbnZhcyBhcyBhIHZpcnR1YWxpemF0aW9uIGxheWVyIGR1cmluZyB2aWV3cG9ydCBjaGFuZ2UuXG4gICAqIFdoZW4gdGhlIHZpZXdwb3J0IGNoYW5nZSBlbmRzLCB0aGUgbGlicmFyeSBoeWRyYXRlcyB0aGUgY2FudmFzIHdpdGggdGhlIGFjdHVhbCBub2RlcyBhbmQgZWRnZXMuXG4gICAqL1xuICB2aXJ0dWFsaXphdGlvbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSB6b29tIHRocmVzaG9sZCBiZWxvdyB3aGljaCB0aGUgb25seSB2aXJ0dWFsaXphdGlvbiBsYXllciBpcyBkcmF3bi5cbiAgICogVGhpcyBzaG91bGQgaGVscCB0byBhdm9pZCBwZXJmb3JtYW5jZSBpc3N1ZXMgd2hlbiB6b29taW5nIG91dCB0b28gbXVjaC5cbiAgICovXG4gIHZpcnR1YWxpemF0aW9uWm9vbVRocmVzaG9sZD86IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -6,6 +6,7 @@ import { toObservable } from '@angular/core/rxjs-interop';
|
|
|
6
6
|
import { smoothStepPath } from '../math/edge-path/smooth-step-path';
|
|
7
7
|
import { hashCode } from '../utils/hash';
|
|
8
8
|
import { FlowEntitiesService } from '../services/flow-entities.service';
|
|
9
|
+
import { extendedComputed } from '../utils/signals/extended-computed';
|
|
9
10
|
export class EdgeModel {
|
|
10
11
|
constructor(edge) {
|
|
11
12
|
this.edge = edge;
|
|
@@ -66,25 +67,51 @@ export class EdgeModel {
|
|
|
66
67
|
return this.curve(params);
|
|
67
68
|
}
|
|
68
69
|
});
|
|
69
|
-
this.sourceHandle =
|
|
70
|
+
this.sourceHandle = extendedComputed((previousHandle) => {
|
|
71
|
+
let handle = null;
|
|
70
72
|
if (this.edge.sourceHandle) {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
73
|
+
handle =
|
|
74
|
+
this.source()
|
|
75
|
+
?.handles()
|
|
76
|
+
.find((handle) => handle.rawHandle.id === this.edge.sourceHandle) ?? null;
|
|
74
77
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
+
else {
|
|
79
|
+
handle =
|
|
80
|
+
this.source()
|
|
81
|
+
?.handles()
|
|
82
|
+
.find((handle) => handle.rawHandle.type === 'source') ?? null;
|
|
83
|
+
}
|
|
84
|
+
// In case of virtual scrolling, if the node is scrolled out of view the handle may disappear
|
|
85
|
+
// which could lead to the edge not being rendered
|
|
86
|
+
// so we return the previous handle if the current one is null
|
|
87
|
+
// TODO: check if this breaks anything
|
|
88
|
+
if (handle === null) {
|
|
89
|
+
return previousHandle;
|
|
90
|
+
}
|
|
91
|
+
return handle;
|
|
78
92
|
});
|
|
79
|
-
this.targetHandle =
|
|
93
|
+
this.targetHandle = extendedComputed((previousHandle) => {
|
|
94
|
+
let handle = null;
|
|
80
95
|
if (this.edge.targetHandle) {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
96
|
+
handle =
|
|
97
|
+
this.target()
|
|
98
|
+
?.handles()
|
|
99
|
+
.find((handle) => handle.rawHandle.id === this.edge.targetHandle) ?? null;
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
handle =
|
|
103
|
+
this.target()
|
|
104
|
+
?.handles()
|
|
105
|
+
.find((handle) => handle.rawHandle.type === 'target') ?? null;
|
|
106
|
+
}
|
|
107
|
+
// In case of virtual scrolling, if the node is scrolled out of view the handle may disappear
|
|
108
|
+
// which could lead to the edge not being rendered
|
|
109
|
+
// so we return the previous handle if the current one is null
|
|
110
|
+
// TODO: check if this breaks anything
|
|
111
|
+
if (handle === null) {
|
|
112
|
+
return previousHandle;
|
|
84
113
|
}
|
|
85
|
-
return
|
|
86
|
-
?.handles()
|
|
87
|
-
.find((handle) => handle.rawHandle.type === 'target') ?? null);
|
|
114
|
+
return handle;
|
|
88
115
|
});
|
|
89
116
|
/**
|
|
90
117
|
* TODO: not reactive
|
|
@@ -134,4 +161,4 @@ export class EdgeModel {
|
|
|
134
161
|
};
|
|
135
162
|
}
|
|
136
163
|
}
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/edge.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, inject, signal } from '@angular/core';\nimport { EdgeLabelPosition } from '../interfaces/edge-label.interface';\nimport { Edge, Curve, EdgeType } from '../interfaces/edge.interface';\nimport { EdgeLabelModel } from './edge-label.model';\nimport { NodeModel } from './node.model';\nimport { straightPath } from '../math/edge-path/straigh-path';\nimport { bezierPath } from '../math/edge-path/bezier-path';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { smoothStepPath } from '../math/edge-path/smooth-step-path';\nimport { hashCode } from '../utils/hash';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { EdgeContext } from '../interfaces/template-context.interface';\nimport { HandleModel } from './handle.model';\nimport { CurveFactoryParams } from '../interfaces/curve-factory.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\n\nexport class EdgeModel implements FlowEntity, Contextable<EdgeContext> {\n  private readonly flowEntitiesService = inject(FlowEntitiesService);\n\n  public source = signal<NodeModel | undefined>(undefined);\n  public target = signal<NodeModel | undefined>(undefined);\n  public curve: Curve;\n  public type: EdgeType;\n  public reconnectable: boolean | 'source' | 'target';\n\n  public selected = signal(false);\n  public selected$ = toObservable(this.selected);\n\n  public renderOrder = signal(0);\n\n  public detached = computed(() => {\n    const source = this.source();\n    const target = this.target();\n\n    if (!source || !target) {\n      return true;\n    }\n\n    let existsSourceHandle = false;\n    let existsTargetHandle = false;\n\n    if (this.edge.sourceHandle) {\n      existsSourceHandle = !!source.handles().find((handle) => handle.rawHandle.id === this.edge.sourceHandle);\n    } else {\n      existsSourceHandle = !!source.handles().find((handle) => handle.rawHandle.type === 'source');\n    }\n\n    if (this.edge.targetHandle) {\n      existsTargetHandle = !!target.handles().find((handle) => handle.rawHandle.id === this.edge.targetHandle);\n    } else {\n      existsTargetHandle = !!target.handles().find((handle) => handle.rawHandle.type === 'target');\n    }\n\n    return !existsSourceHandle || !existsTargetHandle;\n  });\n\n  public detached$ = toObservable(this.detached);\n\n  public path = computed(() => {\n    const source = this.sourceHandle();\n    const target = this.targetHandle();\n\n    // TODO: don't like this\n    if (!source || !target) {\n      return {\n        path: '',\n        labelPoints: {\n          start: { x: 0, y: 0 },\n          center: { x: 0, y: 0 },\n          end: { x: 0, y: 0 },\n        },\n      };\n    }\n\n    const params = this.getPathFactoryParams(source, target);\n\n    switch (this.curve) {\n      case 'straight':\n        return straightPath(params);\n      case 'bezier':\n        return bezierPath(params);\n      case 'smooth-step':\n        return smoothStepPath(params);\n      case 'step':\n        return smoothStepPath(params, 0);\n      default:\n        return this.curve(params);\n    }\n  });\n\n  public sourceHandle = computed(() => {\n    if (this.edge.sourceHandle) {\n      return (\n        this.source()\n          ?.handles()\n          .find((handle) => handle.rawHandle.id === this.edge.sourceHandle) ?? null\n      );\n    }\n\n    return (\n      this.source()\n        ?.handles()\n        .find((handle) => handle.rawHandle.type === 'source') ?? null\n    );\n  });\n\n  public targetHandle = computed(() => {\n    if (this.edge.targetHandle) {\n      return (\n        this.target()\n          ?.handles()\n          .find((handle) => handle.rawHandle.id === this.edge.targetHandle) ?? null\n      );\n    }\n\n    return (\n      this.target()\n        ?.handles()\n        .find((handle) => handle.rawHandle.type === 'target') ?? null\n    );\n  });\n\n  /**\n   * TODO: not reactive\n   */\n  public markerStartUrl = computed(() => {\n    const marker = this.edge.markers?.start;\n\n    return marker ? `url(#${hashCode(JSON.stringify(marker))})` : '';\n  });\n\n  /**\n   * TODO: not reactive\n   */\n  public markerEndUrl = computed(() => {\n    const marker = this.edge.markers?.end;\n\n    return marker ? `url(#${hashCode(JSON.stringify(marker))})` : '';\n  });\n\n  public context = {\n    $implicit: {\n      // TODO: check if edge could change\n      edge: this.edge,\n      path: computed(() => this.path().path),\n      markerStart: this.markerStartUrl,\n      markerEnd: this.markerEndUrl,\n      selected: this.selected.asReadonly(),\n    },\n  };\n\n  public edgeLabels: { [position in EdgeLabelPosition]?: EdgeLabelModel } = {};\n\n  constructor(public edge: Edge) {\n    this.type = edge.type ?? 'default';\n    this.curve = edge.curve ?? 'bezier';\n    this.reconnectable = edge.reconnectable ?? false;\n\n    if (edge.edgeLabels?.start) this.edgeLabels.start = new EdgeLabelModel(edge.edgeLabels.start);\n    if (edge.edgeLabels?.center) this.edgeLabels.center = new EdgeLabelModel(edge.edgeLabels.center);\n    if (edge.edgeLabels?.end) this.edgeLabels.end = new EdgeLabelModel(edge.edgeLabels.end);\n  }\n\n  private getPathFactoryParams(source: HandleModel, target: HandleModel): CurveFactoryParams {\n    return {\n      mode: 'edge',\n      edge: this.edge,\n      sourcePoint: source.pointAbsolute(),\n      targetPoint: target.pointAbsolute(),\n      sourcePosition: source.rawHandle.position,\n      targetPosition: target.rawHandle.position,\n      allEdges: this.flowEntitiesService.rawEdges(),\n      allNodes: this.flowEntitiesService.rawNodes(),\n    };\n  }\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/edge.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, inject, signal } from '@angular/core';\nimport { EdgeLabelPosition } from '../interfaces/edge-label.interface';\nimport { Edge, Curve, EdgeType } from '../interfaces/edge.interface';\nimport { EdgeLabelModel } from './edge-label.model';\nimport { NodeModel } from './node.model';\nimport { straightPath } from '../math/edge-path/straigh-path';\nimport { bezierPath } from '../math/edge-path/bezier-path';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { smoothStepPath } from '../math/edge-path/smooth-step-path';\nimport { hashCode } from '../utils/hash';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { EdgeContext } from '../interfaces/template-context.interface';\nimport { HandleModel } from './handle.model';\nimport { CurveFactoryParams } from '../interfaces/curve-factory.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { extendedComputed } from '../utils/signals/extended-computed';\n\nexport class EdgeModel implements FlowEntity, Contextable<EdgeContext> {\n  private readonly flowEntitiesService = inject(FlowEntitiesService);\n\n  public source = signal<NodeModel | undefined>(undefined);\n  public target = signal<NodeModel | undefined>(undefined);\n  public curve: Curve;\n  public type: EdgeType;\n  public reconnectable: boolean | 'source' | 'target';\n\n  public selected = signal(false);\n  public selected$ = toObservable(this.selected);\n\n  public renderOrder = signal(0);\n\n  public detached = computed(() => {\n    const source = this.source();\n    const target = this.target();\n\n    if (!source || !target) {\n      return true;\n    }\n\n    let existsSourceHandle = false;\n    let existsTargetHandle = false;\n\n    if (this.edge.sourceHandle) {\n      existsSourceHandle = !!source.handles().find((handle) => handle.rawHandle.id === this.edge.sourceHandle);\n    } else {\n      existsSourceHandle = !!source.handles().find((handle) => handle.rawHandle.type === 'source');\n    }\n\n    if (this.edge.targetHandle) {\n      existsTargetHandle = !!target.handles().find((handle) => handle.rawHandle.id === this.edge.targetHandle);\n    } else {\n      existsTargetHandle = !!target.handles().find((handle) => handle.rawHandle.type === 'target');\n    }\n\n    return !existsSourceHandle || !existsTargetHandle;\n  });\n\n  public detached$ = toObservable(this.detached);\n\n  public path = computed(() => {\n    const source = this.sourceHandle();\n    const target = this.targetHandle();\n\n    // TODO: don't like this\n    if (!source || !target) {\n      return {\n        path: '',\n        labelPoints: {\n          start: { x: 0, y: 0 },\n          center: { x: 0, y: 0 },\n          end: { x: 0, y: 0 },\n        },\n      };\n    }\n\n    const params = this.getPathFactoryParams(source, target);\n\n    switch (this.curve) {\n      case 'straight':\n        return straightPath(params);\n      case 'bezier':\n        return bezierPath(params);\n      case 'smooth-step':\n        return smoothStepPath(params);\n      case 'step':\n        return smoothStepPath(params, 0);\n      default:\n        return this.curve(params);\n    }\n  });\n\n  public sourceHandle = extendedComputed<HandleModel | null>((previousHandle) => {\n    let handle: HandleModel | null = null;\n\n    if (this.edge.sourceHandle) {\n      handle =\n        this.source()\n          ?.handles()\n          .find((handle) => handle.rawHandle.id === this.edge.sourceHandle) ?? null;\n    } else {\n      handle =\n        this.source()\n          ?.handles()\n          .find((handle) => handle.rawHandle.type === 'source') ?? null;\n    }\n\n    // In case of virtual scrolling, if the node is scrolled out of view the handle may disappear\n    // which could lead to the edge not being rendered\n    // so we return the previous handle if the current one is null\n    // TODO: check if this breaks anything\n    if (handle === null) {\n      return previousHandle;\n    }\n\n    return handle;\n  });\n\n  public targetHandle = extendedComputed<HandleModel | null>((previousHandle) => {\n    let handle: HandleModel | null = null;\n\n    if (this.edge.targetHandle) {\n      handle =\n        this.target()\n          ?.handles()\n          .find((handle) => handle.rawHandle.id === this.edge.targetHandle) ?? null;\n    } else {\n      handle =\n        this.target()\n          ?.handles()\n          .find((handle) => handle.rawHandle.type === 'target') ?? null;\n    }\n\n    // In case of virtual scrolling, if the node is scrolled out of view the handle may disappear\n    // which could lead to the edge not being rendered\n    // so we return the previous handle if the current one is null\n    // TODO: check if this breaks anything\n    if (handle === null) {\n      return previousHandle;\n    }\n\n    return handle;\n  });\n\n  /**\n   * TODO: not reactive\n   */\n  public markerStartUrl = computed(() => {\n    const marker = this.edge.markers?.start;\n\n    return marker ? `url(#${hashCode(JSON.stringify(marker))})` : '';\n  });\n\n  /**\n   * TODO: not reactive\n   */\n  public markerEndUrl = computed(() => {\n    const marker = this.edge.markers?.end;\n\n    return marker ? `url(#${hashCode(JSON.stringify(marker))})` : '';\n  });\n\n  public context = {\n    $implicit: {\n      // TODO: check if edge could change\n      edge: this.edge,\n      path: computed(() => this.path().path),\n      markerStart: this.markerStartUrl,\n      markerEnd: this.markerEndUrl,\n      selected: this.selected.asReadonly(),\n    },\n  };\n\n  public edgeLabels: { [position in EdgeLabelPosition]?: EdgeLabelModel } = {};\n\n  constructor(public edge: Edge) {\n    this.type = edge.type ?? 'default';\n    this.curve = edge.curve ?? 'bezier';\n    this.reconnectable = edge.reconnectable ?? false;\n\n    if (edge.edgeLabels?.start) this.edgeLabels.start = new EdgeLabelModel(edge.edgeLabels.start);\n    if (edge.edgeLabels?.center) this.edgeLabels.center = new EdgeLabelModel(edge.edgeLabels.center);\n    if (edge.edgeLabels?.end) this.edgeLabels.end = new EdgeLabelModel(edge.edgeLabels.end);\n  }\n\n  private getPathFactoryParams(source: HandleModel, target: HandleModel): CurveFactoryParams {\n    return {\n      mode: 'edge',\n      edge: this.edge,\n      sourcePoint: source.pointAbsolute(),\n      targetPoint: target.pointAbsolute(),\n      sourcePosition: source.rawHandle.position,\n      targetPosition: target.rawHandle.position,\n      allEdges: this.flowEntitiesService.rawEdges(),\n      allNodes: this.flowEntitiesService.rawNodes(),\n    };\n  }\n}\n"]}
|
|
@@ -22,9 +22,11 @@ export class HandleModel {
|
|
|
22
22
|
});
|
|
23
23
|
this.state = signal('idle');
|
|
24
24
|
this.updateHostSizeAndPosition$ = new Subject();
|
|
25
|
+
// TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here
|
|
25
26
|
this.hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {
|
|
26
27
|
initialValue: { width: 0, height: 0 },
|
|
27
28
|
});
|
|
29
|
+
// TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here
|
|
28
30
|
this.hostPosition = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => ({
|
|
29
31
|
x: this.hostReference instanceof HTMLElement ? this.hostReference.offsetLeft : 0, // for now just 0 for group nodes
|
|
30
32
|
y: this.hostReference instanceof HTMLElement ? this.hostReference.offsetTop : 0, // for now just 0 for group nodes
|
|
@@ -93,4 +95,4 @@ export class HandleModel {
|
|
|
93
95
|
return { width: 0, height: 0 };
|
|
94
96
|
}
|
|
95
97
|
}
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handle.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/handle.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, signal } from '@angular/core';\nimport { NodeHandle } from '../services/handle.service';\nimport { NodeModel } from './node.model';\nimport { Subject, map } from 'rxjs';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\nexport type HandleState = 'valid' | 'invalid' | 'idle';\n\nexport class HandleModel {\n  public readonly strokeWidth = 2;\n\n  /**\n   * Pre-computed size for default handle, changed dynamically\n   * for custom handles\n   */\n  public size = signal({\n    width: 10 + 2 * this.strokeWidth,\n    height: 10 + 2 * this.strokeWidth,\n  });\n\n  public pointAbsolute = computed(() => {\n    return {\n      x: this.parentNode.globalPoint().x + this.hostOffset().x + this.sizeOffset().x,\n      y: this.parentNode.globalPoint().y + this.hostOffset().y + this.sizeOffset().y,\n    };\n  });\n\n  public state = signal<HandleState>('idle');\n\n  private updateHostSizeAndPosition$ = new Subject<void>();\n\n  // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here\n  private hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {\n    initialValue: { width: 0, height: 0 },\n  });\n\n  // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here\n  private hostPosition = toSignal(\n    this.updateHostSizeAndPosition$.pipe(\n      map(() => ({\n        x: this.hostReference instanceof HTMLElement ? this.hostReference.offsetLeft : 0, // for now just 0 for group nodes\n        y: this.hostReference instanceof HTMLElement ? this.hostReference.offsetTop : 0, // for now just 0 for group nodes\n      })),\n    ),\n    {\n      initialValue: { x: 0, y: 0 },\n    },\n  );\n\n  public hostOffset = computed(() => {\n    switch (this.rawHandle.position) {\n      case 'left':\n        return {\n          x: 0,\n          y: this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'right':\n        return {\n          x: this.parentNode.size().width,\n          y: this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'top':\n        return {\n          x: this.hostPosition().x + this.hostSize().width / 2,\n          y: 0,\n        };\n      case 'bottom':\n        return {\n          x: this.hostPosition().x + this.hostSize().width / 2,\n          y: this.parentNode.size().height,\n        };\n    }\n  });\n\n  private sizeOffset = computed(() => {\n    switch (this.rawHandle.position) {\n      case 'left':\n        return { x: -(this.size().width / 2), y: 0 };\n      case 'right':\n        return { x: this.size().width / 2, y: 0 };\n      case 'top':\n        return { x: 0, y: -(this.size().height / 2) };\n      case 'bottom':\n        return { x: 0, y: this.size().height / 2 };\n    }\n  });\n\n  public hostReference = this.rawHandle.hostReference!;\n\n  public template = this.rawHandle.template;\n\n  public templateContext = {\n    $implicit: {\n      point: this.hostOffset,\n      state: this.state,\n      node: this.parentNode.rawNode,\n    },\n  };\n\n  constructor(\n    public rawHandle: NodeHandle,\n    public parentNode: NodeModel,\n  ) {}\n\n  public updateHost() {\n    this.updateHostSizeAndPosition$.next();\n  }\n\n  private getHostSize(): { width: number; height: number } {\n    if (this.hostReference instanceof HTMLElement) {\n      return {\n        width: this.hostReference.offsetWidth,\n        height: this.hostReference.offsetHeight,\n      };\n    } else if (this.hostReference instanceof SVGGraphicsElement) {\n      return this.hostReference.getBBox();\n    }\n\n    return { width: 0, height: 0 };\n  }\n}\n"]}
|
|
@@ -11,6 +11,7 @@ export class NodeModel {
|
|
|
11
11
|
constructor(rawNode) {
|
|
12
12
|
this.rawNode = rawNode;
|
|
13
13
|
this.entitiesService = inject(FlowEntitiesService);
|
|
14
|
+
this.isVisible = signal(false);
|
|
14
15
|
this.point = signal({ x: 0, y: 0 });
|
|
15
16
|
this.width = signal(NodeModel.defaultWidth);
|
|
16
17
|
this.height = signal(NodeModel.defaultHeight);
|
|
@@ -24,6 +25,7 @@ export class NodeModel {
|
|
|
24
25
|
this.foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
|
|
25
26
|
this.renderOrder = signal(0);
|
|
26
27
|
this.selected = signal(false);
|
|
28
|
+
this.preview = signal({ style: {} });
|
|
27
29
|
this.globalPoint = computed(() => {
|
|
28
30
|
let parent = this.parent();
|
|
29
31
|
let x = this.point().x;
|
|
@@ -75,6 +77,9 @@ export class NodeModel {
|
|
|
75
77
|
if (internalNode.parentId) {
|
|
76
78
|
this.parentId = internalNode.parentId;
|
|
77
79
|
}
|
|
80
|
+
if (internalNode.preview) {
|
|
81
|
+
this.preview = internalNode.preview;
|
|
82
|
+
}
|
|
78
83
|
if (internalNode.type === 'default-group' && internalNode.color) {
|
|
79
84
|
this.color = internalNode.color;
|
|
80
85
|
}
|
|
@@ -124,4 +129,4 @@ export class NodeModel {
|
|
|
124
129
|
this.point.set(point);
|
|
125
130
|
}
|
|
126
131
|
}
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/node.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TemplateRef, computed, inject, signal } from '@angular/core';\nimport { DynamicNode, Node, isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { GroupNodeContext, NodeContext } from '../interfaces/template-context.interface';\nimport { toUnifiedNode } from '../utils/to-unified-node';\nimport { Observable } from 'rxjs';\n\nexport class NodeModel<T = unknown>\n  implements FlowEntity, Contextable<NodeContext | GroupNodeContext | { $implicit: object }>\n{\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private entitiesService = inject(FlowEntitiesService);\n\n  public point = signal<Point>({ x: 0, y: 0 });\n  public point$: Observable<Point>;\n\n  public width = signal(NodeModel.defaultWidth);\n  public width$: Observable<number>;\n\n  public height = signal(NodeModel.defaultHeight);\n  public height$: Observable<number>;\n\n  /**\n   * @deprecated use width or height signals\n   */\n  public size = computed(() => ({ width: this.width(), height: this.height() }));\n  /**\n   * @deprecated use width$ or height$\n   */\n  public size$: Observable<{ width: number; height: number }>;\n\n  public styleWidth = computed(() => `${this.width()}px`);\n  public styleHeight = computed(() => `${this.height()}px`);\n\n  public foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n  public foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n\n  public renderOrder = signal(0);\n\n  public selected = signal(false);\n  public selected$: Observable<boolean>;\n\n  public globalPoint = computed(() => {\n    let parent = this.parent();\n    let x = this.point().x;\n    let y = this.point().y;\n\n    while (parent !== null) {\n      x += parent.point().x;\n      y += parent.point().y;\n\n      parent = parent.parent();\n    }\n\n    return { x, y };\n  });\n\n  public pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);\n\n  public handles = signal<HandleModel[]>([]);\n  public handles$: Observable<HandleModel[]>;\n\n  public draggable = signal(true);\n\n  public dragHandlesCount = signal(0);\n\n  // disabled for configuration for now\n  public readonly magnetRadius = 20;\n\n  // TODO: not sure if we need to statically store it\n  public isComponentType =\n    isComponentStaticNode(this.rawNode as Node) || isComponentDynamicNode(this.rawNode as DynamicNode);\n\n  // Default node specific thing\n  public text = signal('');\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.rawNode,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.id));\n\n  public color = signal(NodeModel.defaultColor);\n\n  public resizable = signal(false);\n  public resizing = signal(false);\n  public resizerTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  public context = {\n    $implicit: {},\n  };\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public rawNode: Node<T> | DynamicNode<T>) {\n    const internalNode = toUnifiedNode(rawNode);\n\n    if (internalNode.point) {\n      this.point = internalNode.point;\n    }\n\n    if (internalNode.width) {\n      this.width = internalNode.width;\n    }\n\n    if (internalNode.height) {\n      this.height = internalNode.height;\n    }\n\n    if (internalNode.draggable) {\n      this.draggable = internalNode.draggable;\n    }\n\n    if (internalNode.parentId) {\n      this.parentId = internalNode.parentId;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.color) {\n      this.color = internalNode.color;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.resizable) {\n      this.resizable = internalNode.resizable;\n    }\n\n    if (internalNode.type === 'default' && internalNode.text) {\n      this.text = internalNode.text;\n    }\n\n    if (internalNode.type === 'html-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n        },\n      };\n    }\n\n    if (internalNode.type === 'svg-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    if (internalNode.type === 'template-group') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    // Initialize Observables after all signal assignments\n    this.point$ = toObservable(this.point);\n    this.width$ = toObservable(this.width);\n    this.height$ = toObservable(this.height);\n    this.size$ = toObservable(this.size);\n    this.selected$ = toObservable(this.selected);\n    this.handles$ = toObservable(this.handles);\n  }\n\n  public setPoint(point: Point) {\n    this.point.set(point);\n  }\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/node.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACtE,OAAO,EAAqB,sBAAsB,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAChH,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAI1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,oCAAoC,EAAE,MAAM,4DAA4D,CAAC;AAGlH,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAIzD,MAAM,OAAO,SAAS;aAGL,iBAAY,GAAG,GAAG,AAAN,CAAO;aACnB,kBAAa,GAAG,EAAE,AAAL,CAAM;aACnB,iBAAY,GAAG,SAAS,AAAZ,CAAa;IA4FxC,YAAmB,OAAiC;QAAjC,YAAO,GAAP,OAAO,CAA0B;QA1F5C,oBAAe,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAE/C,cAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAE1B,UAAK,GAAG,MAAM,CAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAGtC,UAAK,GAAG,MAAM,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAGvC,WAAM,GAAG,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAGhD;;WAEG;QACI,SAAI,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC;QAMxE,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACjD,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAEnD,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,oCAAoC,CAAC,CAAC;QAC9E,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,oCAAoC,CAAC,CAAC;QAEhF,gBAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAExB,aAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAGzB,YAAO,GAAG,MAAM,CAAc,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAE7C,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YACjC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAEvB,OAAO,MAAM,KAAK,IAAI,EAAE,CAAC;gBACvB,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBACtB,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBAEtB,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC;YAC3B,CAAC;YAED,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;QAEI,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,aAAa,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;QAE/F,YAAO,GAAG,MAAM,CAAgB,EAAE,CAAC,CAAC;QAGpC,cAAS,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;QAEzB,qBAAgB,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEpC,qCAAqC;QACrB,iBAAY,GAAG,EAAE,CAAC;QAElC,mDAAmD;QAC5C,oBAAe,GACpB,qBAAqB,CAAC,IAAI,CAAC,OAAe,CAAC,IAAI,sBAAsB,CAAC,IAAI,CAAC,OAAsB,CAAC,CAAC;QAErG,8BAA8B;QACvB,SAAI,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAEzB,gCAAgC;QACzB,wBAAmB,GAAG;YAC3B,IAAI,EAAE,IAAI,CAAC,OAAO;SACnB,CAAC;QAEK,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC;QAE5G,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAExG,UAAK,GAAG,MAAM,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAEvC,cAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1B,aAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACzB,oBAAe,GAAG,MAAM,CAA8B,IAAI,CAAC,CAAC;QAE5D,YAAO,GAAG;YACf,SAAS,EAAE,EAAE;SACd,CAAC;QAEM,aAAQ,GAAG,MAAM,CAAgB,IAAI,CAAC,CAAC;QAG7C,MAAM,YAAY,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;QAE5C,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAClC,CAAC;QAED,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAClC,CAAC;QAED,IAAI,YAAY,CAAC,MAAM,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC;QACpC,CAAC;QAED,IAAI,YAAY,CAAC,SAAS,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,SAAS,CAAC;QAC1C,CAAC;QAED,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAC;QACxC,CAAC;QAED,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC;QACtC,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,eAAe,IAAI,YAAY,CAAC,KAAK,EAAE,CAAC;YAChE,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAClC,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,eAAe,IAAI,YAAY,CAAC,SAAS,EAAE,CAAC;YACpE,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,SAAS,CAAC;QAC1C,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,SAAS,IAAI,YAAY,CAAC,IAAI,EAAE,CAAC;YACzD,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC,IAAI,CAAC;QAChC,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,eAAe,EAAE,CAAC;YAC1C,IAAI,CAAC,OAAO,GAAG;gBACb,SAAS,EAAE;oBACT,IAAI,EAAE,OAAO;oBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB;aACF,CAAC;QACJ,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;YACzC,IAAI,CAAC,OAAO,GAAG;gBACb,SAAS,EAAE;oBACT,IAAI,EAAE,OAAO;oBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,MAAM,EAAE,IAAI,CAAC,MAAM;iBACpB;aACF,CAAC;QACJ,CAAC;QAED,IAAI,YAAY,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;YAC3C,IAAI,CAAC,OAAO,GAAG;gBACb,SAAS,EAAE;oBACT,IAAI,EAAE,OAAO;oBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE;oBACpC,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,MAAM,EAAE,IAAI,CAAC,MAAM;iBACpB;aACF,CAAC;QACJ,CAAC;QAED,sDAAsD;QACtD,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAEM,QAAQ,CAAC,KAAY;QAC1B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC","sourcesContent":["import { TemplateRef, computed, inject, signal } from '@angular/core';\nimport { DynamicNode, Node, isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { GroupNodeContext, NodeContext } from '../interfaces/template-context.interface';\nimport { toUnifiedNode } from '../utils/to-unified-node';\nimport { Observable } from 'rxjs';\nimport { NodePreview } from '../interfaces/node-preview.interface';\n\nexport class NodeModel<T = unknown>\n  implements FlowEntity, Contextable<NodeContext | GroupNodeContext | { $implicit: object }>\n{\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private entitiesService = inject(FlowEntitiesService);\n\n  public isVisible = signal(false);\n\n  public point = signal<Point>({ x: 0, y: 0 });\n  public point$: Observable<Point>;\n\n  public width = signal(NodeModel.defaultWidth);\n  public width$: Observable<number>;\n\n  public height = signal(NodeModel.defaultHeight);\n  public height$: Observable<number>;\n\n  /**\n   * @deprecated use width or height signals\n   */\n  public size = computed(() => ({ width: this.width(), height: this.height() }));\n  /**\n   * @deprecated use width$ or height$\n   */\n  public size$: Observable<{ width: number; height: number }>;\n\n  public styleWidth = computed(() => `${this.width()}px`);\n  public styleHeight = computed(() => `${this.height()}px`);\n\n  public foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n  public foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n\n  public renderOrder = signal(0);\n\n  public selected = signal(false);\n  public selected$: Observable<boolean>;\n\n  public preview = signal<NodePreview>({ style: {} });\n\n  public globalPoint = computed(() => {\n    let parent = this.parent();\n    let x = this.point().x;\n    let y = this.point().y;\n\n    while (parent !== null) {\n      x += parent.point().x;\n      y += parent.point().y;\n\n      parent = parent.parent();\n    }\n\n    return { x, y };\n  });\n\n  public pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);\n\n  public handles = signal<HandleModel[]>([]);\n  public handles$: Observable<HandleModel[]>;\n\n  public draggable = signal(true);\n\n  public dragHandlesCount = signal(0);\n\n  // disabled for configuration for now\n  public readonly magnetRadius = 20;\n\n  // TODO: not sure if we need to statically store it\n  public isComponentType =\n    isComponentStaticNode(this.rawNode as Node) || isComponentDynamicNode(this.rawNode as DynamicNode);\n\n  // Default node specific thing\n  public text = signal('');\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.rawNode,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.id));\n\n  public color = signal(NodeModel.defaultColor);\n\n  public resizable = signal(false);\n  public resizing = signal(false);\n  public resizerTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  public context = {\n    $implicit: {},\n  };\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public rawNode: Node<T> | DynamicNode<T>) {\n    const internalNode = toUnifiedNode(rawNode);\n\n    if (internalNode.point) {\n      this.point = internalNode.point;\n    }\n\n    if (internalNode.width) {\n      this.width = internalNode.width;\n    }\n\n    if (internalNode.height) {\n      this.height = internalNode.height;\n    }\n\n    if (internalNode.draggable) {\n      this.draggable = internalNode.draggable;\n    }\n\n    if (internalNode.parentId) {\n      this.parentId = internalNode.parentId;\n    }\n\n    if (internalNode.preview) {\n      this.preview = internalNode.preview;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.color) {\n      this.color = internalNode.color;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.resizable) {\n      this.resizable = internalNode.resizable;\n    }\n\n    if (internalNode.type === 'default' && internalNode.text) {\n      this.text = internalNode.text;\n    }\n\n    if (internalNode.type === 'html-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n        },\n      };\n    }\n\n    if (internalNode.type === 'svg-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    if (internalNode.type === 'template-group') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    // Initialize Observables after all signal assignments\n    this.point$ = toObservable(this.point);\n    this.width$ = toObservable(this.width);\n    this.height$ = toObservable(this.height);\n    this.size$ = toObservable(this.size);\n    this.selected$ = toObservable(this.selected);\n    this.handles$ = toObservable(this.handles);\n  }\n\n  public setPoint(point: Point) {\n    this.point.set(point);\n  }\n}\n"]}
|
|
@@ -1,11 +1,23 @@
|
|
|
1
1
|
import { Injectable, computed, inject } from '@angular/core';
|
|
2
2
|
import { FlowEntitiesService } from './flow-entities.service';
|
|
3
|
+
import { FlowSettingsService } from './flow-settings.service';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export class EdgeRenderingService {
|
|
5
6
|
constructor() {
|
|
6
7
|
this.flowEntitiesService = inject(FlowEntitiesService);
|
|
8
|
+
this.flowSettingsService = inject(FlowSettingsService);
|
|
7
9
|
this.edges = computed(() => {
|
|
8
|
-
|
|
10
|
+
if (!this.flowSettingsService.optimization().virtualization) {
|
|
11
|
+
return [...this.flowEntitiesService.validEdges()].sort((aEdge, bEdge) => aEdge.renderOrder() - bEdge.renderOrder());
|
|
12
|
+
}
|
|
13
|
+
return this.viewportEdges().sort((aEdge, bEdge) => aEdge.renderOrder() - bEdge.renderOrder());
|
|
14
|
+
});
|
|
15
|
+
this.viewportEdges = computed(() => {
|
|
16
|
+
return this.flowEntitiesService.validEdges().filter((e) => {
|
|
17
|
+
const sourceHandle = e.sourceHandle();
|
|
18
|
+
const targetHandle = e.targetHandle();
|
|
19
|
+
return sourceHandle && targetHandle;
|
|
20
|
+
});
|
|
9
21
|
});
|
|
10
22
|
this.maxOrder = computed(() => {
|
|
11
23
|
return Math.max(...this.flowEntitiesService.validEdges().map((n) => n.renderOrder()));
|
|
@@ -25,4 +37,4 @@ export class EdgeRenderingService {
|
|
|
25
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: EdgeRenderingService, decorators: [{
|
|
26
38
|
type: Injectable
|
|
27
39
|
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRnZS1yZW5kZXJpbmcuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9zZXJ2aWNlcy9lZGdlLXJlbmRlcmluZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUU5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFHOUQsTUFBTSxPQUFPLG9CQUFvQjtJQURqQztRQUVVLHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2xELHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRTFDLFVBQUssR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsWUFBWSxFQUFFLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQzVELE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FDcEQsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLEdBQUcsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUM1RCxDQUFDO1lBQ0osQ0FBQztZQUVELE9BQU8sSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUNoRyxDQUFDLENBQUMsQ0FBQztRQUVLLGtCQUFhLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNwQyxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtnQkFDeEQsTUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDLFlBQVksRUFBRSxDQUFDO2dCQUN0QyxNQUFNLFlBQVksR0FBRyxDQUFDLENBQUMsWUFBWSxFQUFFLENBQUM7Z0JBRXRDLE9BQU8sWUFBWSxJQUFJLFlBQVksQ0FBQztZQUN0QyxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUssYUFBUSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFVBQVUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN4RixDQUFDLENBQUMsQ0FBQztLQVlKO0lBVlEsSUFBSSxDQUFDLElBQWU7UUFDekIsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLEtBQUssSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRTFGLElBQUksY0FBYyxFQUFFLENBQUM7WUFDbkIsT0FBTztRQUNULENBQUM7UUFFRCxZQUFZO1FBQ1osSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzVDLENBQUM7K0dBcENVLG9CQUFvQjttSEFBcEIsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQURoQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgY29tcHV0ZWQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmxvd0VudGl0aWVzU2VydmljZSB9IGZyb20gJy4vZmxvdy1lbnRpdGllcy5zZXJ2aWNlJztcbmltcG9ydCB7IEVkZ2VNb2RlbCB9IGZyb20gJy4uL21vZGVscy9lZGdlLm1vZGVsJztcbmltcG9ydCB7IEZsb3dTZXR0aW5nc1NlcnZpY2UgfSBmcm9tICcuL2Zsb3ctc2V0dGluZ3Muc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBFZGdlUmVuZGVyaW5nU2VydmljZSB7XG4gIHByaXZhdGUgZmxvd0VudGl0aWVzU2VydmljZSA9IGluamVjdChGbG93RW50aXRpZXNTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBmbG93U2V0dGluZ3NTZXJ2aWNlID0gaW5qZWN0KEZsb3dTZXR0aW5nc1NlcnZpY2UpO1xuXG4gIHB1YmxpYyByZWFkb25seSBlZGdlcyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBpZiAoIXRoaXMuZmxvd1NldHRpbmdzU2VydmljZS5vcHRpbWl6YXRpb24oKS52aXJ0dWFsaXphdGlvbikge1xuICAgICAgcmV0dXJuIFsuLi50aGlzLmZsb3dFbnRpdGllc1NlcnZpY2UudmFsaWRFZGdlcygpXS5zb3J0KFxuICAgICAgICAoYUVkZ2UsIGJFZGdlKSA9PiBhRWRnZS5yZW5kZXJPcmRlcigpIC0gYkVkZ2UucmVuZGVyT3JkZXIoKSxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMudmlld3BvcnRFZGdlcygpLnNvcnQoKGFFZGdlLCBiRWRnZSkgPT4gYUVkZ2UucmVuZGVyT3JkZXIoKSAtIGJFZGdlLnJlbmRlck9yZGVyKCkpO1xuICB9KTtcblxuICBwcml2YXRlIHZpZXdwb3J0RWRnZXMgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIHRoaXMuZmxvd0VudGl0aWVzU2VydmljZS52YWxpZEVkZ2VzKCkuZmlsdGVyKChlKSA9PiB7XG4gICAgICBjb25zdCBzb3VyY2VIYW5kbGUgPSBlLnNvdXJjZUhhbmRsZSgpO1xuICAgICAgY29uc3QgdGFyZ2V0SGFuZGxlID0gZS50YXJnZXRIYW5kbGUoKTtcblxuICAgICAgcmV0dXJuIHNvdXJjZUhhbmRsZSAmJiB0YXJnZXRIYW5kbGU7XG4gICAgfSk7XG4gIH0pO1xuXG4gIHByaXZhdGUgbWF4T3JkZXIgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgcmV0dXJuIE1hdGgubWF4KC4uLnRoaXMuZmxvd0VudGl0aWVzU2VydmljZS52YWxpZEVkZ2VzKCkubWFwKChuKSA9PiBuLnJlbmRlck9yZGVyKCkpKTtcbiAgfSk7XG5cbiAgcHVibGljIHB1bGwoZWRnZTogRWRnZU1vZGVsKSB7XG4gICAgY29uc3QgaXNBbHJlYWR5T25Ub3AgPSBlZGdlLnJlbmRlck9yZGVyKCkgIT09IDAgJiYgdGhpcy5tYXhPcmRlcigpID09PSBlZGdlLnJlbmRlck9yZGVyKCk7XG5cbiAgICBpZiAoaXNBbHJlYWR5T25Ub3ApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBwdWxsIG5vZGVcbiAgICBlZGdlLnJlbmRlck9yZGVyLnNldCh0aGlzLm1heE9yZGVyKCkgKyAxKTtcbiAgfVxufVxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Injectable, signal } from '@angular/core';
|
|
2
|
+
import { DEFAULT_OPTIMIZATION } from '../interfaces/optimization.interface';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export class FlowSettingsService {
|
|
4
5
|
constructor() {
|
|
@@ -21,6 +22,7 @@ export class FlowSettingsService {
|
|
|
21
22
|
this.maxZoom = signal(3);
|
|
22
23
|
this.background = signal({ type: 'solid', color: '#fff' });
|
|
23
24
|
this.snapGrid = signal([1, 1]);
|
|
25
|
+
this.optimization = signal(DEFAULT_OPTIMIZATION);
|
|
24
26
|
}
|
|
25
27
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSettingsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
26
28
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSettingsService }); }
|
|
@@ -28,4 +30,4 @@ export class FlowSettingsService {
|
|
|
28
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSettingsService, decorators: [{
|
|
29
31
|
type: Injectable
|
|
30
32
|
}] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zZXR0aW5ncy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3NlcnZpY2VzL2Zsb3ctc2V0dGluZ3Muc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFrQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkUsT0FBTyxFQUFFLG9CQUFvQixFQUFnQixNQUFNLHNDQUFzQyxDQUFDOztBQUcxRixNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRVMsdUJBQWtCLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWxDLHlCQUFvQixHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyx5QkFBb0IsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFM0M7O1dBRUc7UUFDSSxTQUFJLEdBQThDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRTVFOztXQUVHO1FBQ0ksc0JBQWlCLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRXJDOztXQUVHO1FBQ0ksdUJBQWtCLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRS9CLFlBQU8sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFdEIsWUFBTyxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUVwQixlQUFVLEdBQUcsTUFBTSxDQUFhLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUVsRSxhQUFRLEdBQUcsTUFBTSxDQUFtQixDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTVDLGlCQUFZLEdBQUcsTUFBTSxDQUF5QixvQkFBb0IsQ0FBQyxDQUFDO0tBQzVFOytHQTlCWSxtQkFBbUI7bUhBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFEL0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIFdyaXRhYmxlU2lnbmFsLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhY2tncm91bmQgfSBmcm9tICcuLi90eXBlcy9iYWNrZ3JvdW5kLnR5cGUnO1xuaW1wb3J0IHsgREVGQVVMVF9PUFRJTUlaQVRJT04sIE9wdGltaXphdGlvbiB9IGZyb20gJy4uL2ludGVyZmFjZXMvb3B0aW1pemF0aW9uLmludGVyZmFjZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBGbG93U2V0dGluZ3NTZXJ2aWNlIHtcbiAgcHVibGljIGVudGl0aWVzU2VsZWN0YWJsZSA9IHNpZ25hbCh0cnVlKTtcblxuICBwdWJsaWMgZWxldmF0ZU5vZGVzT25TZWxlY3QgPSBzaWduYWwodHJ1ZSk7XG4gIHB1YmxpYyBlbGV2YXRlRWRnZXNPblNlbGVjdCA9IHNpZ25hbCh0cnVlKTtcblxuICAvKipcbiAgICogQHNlZSB7VmZsb3dDb21wb25lbnQudmlld31cbiAgICovXG4gIHB1YmxpYyB2aWV3OiBXcml0YWJsZVNpZ25hbDxbbnVtYmVyLCBudW1iZXJdIHwgJ2F1dG8nPiA9IHNpZ25hbChbNDAwLCA0MDBdKTtcblxuICAvKipcbiAgICogU2V0IGJhc2VkIG9uIHZpZXcgcHJvcGVydHkuIE1heSBjaGFuZ2UgaWYgdmlldyBpcyAnYXV0bydcbiAgICovXG4gIHB1YmxpYyBjb21wdXRlZEZsb3dXaWR0aCA9IHNpZ25hbCgwKTtcblxuICAvKipcbiAgICogU2V0IGJhc2VkIG9uIHZpZXcgcHJvcGVydHkuIE1heSBjaGFuZ2UgaWYgdmlldyBpcyAnYXV0bydcbiAgICovXG4gIHB1YmxpYyBjb21wdXRlZEZsb3dIZWlnaHQgPSBzaWduYWwoMCk7XG5cbiAgcHVibGljIG1pblpvb20gPSBzaWduYWwoMC41KTtcblxuICBwdWJsaWMgbWF4Wm9vbSA9IHNpZ25hbCgzKTtcblxuICBwdWJsaWMgYmFja2dyb3VuZCA9IHNpZ25hbDxCYWNrZ3JvdW5kPih7IHR5cGU6ICdzb2xpZCcsIGNvbG9yOiAnI2ZmZicgfSk7XG5cbiAgcHVibGljIHNuYXBHcmlkID0gc2lnbmFsPFtudW1iZXIsIG51bWJlcl0+KFsxLCAxXSk7XG5cbiAgcHVibGljIG9wdGltaXphdGlvbiA9IHNpZ25hbDxSZXF1aXJlZDxPcHRpbWl6YXRpb24+PihERUZBVUxUX09QVElNSVpBVElPTik7XG59XG4iXX0=
|
|
@@ -1,12 +1,23 @@
|
|
|
1
1
|
import { Injectable, computed, inject } from '@angular/core';
|
|
2
2
|
import { FlowEntitiesService } from './flow-entities.service';
|
|
3
3
|
import { isGroupNode } from '../utils/is-group-node';
|
|
4
|
+
import { FlowSettingsService } from './flow-settings.service';
|
|
5
|
+
import { isRectInViewport } from '../utils/viewport';
|
|
6
|
+
import { ViewportService } from './viewport.service';
|
|
7
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
8
|
+
import { asyncScheduler, debounceTime, filter, map, merge, observeOn } from 'rxjs';
|
|
9
|
+
import { toLazySignal } from '../utils/signals/to-lazy-signal';
|
|
4
10
|
import * as i0 from "@angular/core";
|
|
5
11
|
export class NodeRenderingService {
|
|
6
12
|
constructor() {
|
|
7
13
|
this.flowEntitiesService = inject(FlowEntitiesService);
|
|
14
|
+
this.flowSettingsService = inject(FlowSettingsService);
|
|
15
|
+
this.viewportService = inject(ViewportService);
|
|
8
16
|
this.nodes = computed(() => {
|
|
9
|
-
|
|
17
|
+
if (!this.flowSettingsService.optimization().virtualization) {
|
|
18
|
+
return [...this.flowEntitiesService.nodes()].sort((aNode, bNode) => aNode.renderOrder() - bNode.renderOrder());
|
|
19
|
+
}
|
|
20
|
+
return this.viewportNodesAfterInteraction().sort((aNode, bNode) => aNode.renderOrder() - bNode.renderOrder());
|
|
10
21
|
});
|
|
11
22
|
this.groups = computed(() => {
|
|
12
23
|
return this.nodes().filter((n) => isGroupNode(n));
|
|
@@ -14,6 +25,28 @@ export class NodeRenderingService {
|
|
|
14
25
|
this.nonGroups = computed(() => {
|
|
15
26
|
return this.nodes().filter((n) => !isGroupNode(n));
|
|
16
27
|
});
|
|
28
|
+
this.viewportNodes = computed(() => {
|
|
29
|
+
const nodes = this.flowEntitiesService.nodes();
|
|
30
|
+
const viewport = this.viewportService.readableViewport();
|
|
31
|
+
const flowWidth = this.flowSettingsService.computedFlowWidth();
|
|
32
|
+
const flowHeight = this.flowSettingsService.computedFlowHeight();
|
|
33
|
+
return nodes.filter((n) => {
|
|
34
|
+
const { x, y } = n.globalPoint();
|
|
35
|
+
const width = n.width();
|
|
36
|
+
const height = n.height();
|
|
37
|
+
return isRectInViewport({ x, y, width, height }, viewport, flowWidth, flowHeight);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
this.viewportNodesAfterInteraction = toLazySignal(merge(
|
|
41
|
+
// TODO: maybe there is a better way wait when viewport is ready?
|
|
42
|
+
// (to correctly calculate viewport nodes on first render)
|
|
43
|
+
toObservable(this.flowEntitiesService.nodes).pipe(observeOn(asyncScheduler), filter((nodes) => !!nodes.length)), this.viewportService.viewportChangeEnd$.pipe(debounceTime(300))).pipe(map(() => {
|
|
44
|
+
const viewport = this.viewportService.readableViewport();
|
|
45
|
+
const zoomThreshold = this.flowSettingsService.optimization().virtualizationZoomThreshold;
|
|
46
|
+
return viewport.zoom < zoomThreshold ? [] : this.viewportNodes();
|
|
47
|
+
})), {
|
|
48
|
+
initialValue: [],
|
|
49
|
+
});
|
|
17
50
|
this.maxOrder = computed(() => {
|
|
18
51
|
return Math.max(...this.flowEntitiesService.nodes().map((n) => n.renderOrder()));
|
|
19
52
|
});
|
|
@@ -30,4 +63,4 @@ export class NodeRenderingService {
|
|
|
30
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeRenderingService, decorators: [{
|
|
31
64
|
type: Injectable
|
|
32
65
|
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-rendering.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/node-rendering.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, computed, inject } from '@angular/core';\nimport { FlowEntitiesService } from './flow-entities.service';\nimport { NodeModel } from '../models/node.model';\nimport { isGroupNode } from '../utils/is-group-node';\nimport { FlowSettingsService } from './flow-settings.service';\nimport { isRectInViewport } from '../utils/viewport';\nimport { ViewportService } from './viewport.service';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { asyncScheduler, debounceTime, filter, map, merge, observeOn } from 'rxjs';\nimport { toLazySignal } from '../utils/signals/to-lazy-signal';\n\n@Injectable()\nexport class NodeRenderingService {\n  private flowEntitiesService = inject(FlowEntitiesService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private viewportService = inject(ViewportService);\n\n  public readonly nodes = computed(() => {\n    if (!this.flowSettingsService.optimization().virtualization) {\n      return [...this.flowEntitiesService.nodes()].sort((aNode, bNode) => aNode.renderOrder() - bNode.renderOrder());\n    }\n\n    return this.viewportNodesAfterInteraction().sort((aNode, bNode) => aNode.renderOrder() - bNode.renderOrder());\n  });\n\n  public readonly groups = computed(() => {\n    return this.nodes().filter((n) => isGroupNode(n));\n  });\n\n  public readonly nonGroups = computed(() => {\n    return this.nodes().filter((n) => !isGroupNode(n));\n  });\n\n  public viewportNodes = computed(() => {\n    const nodes = this.flowEntitiesService.nodes();\n    const viewport = this.viewportService.readableViewport();\n    const flowWidth = this.flowSettingsService.computedFlowWidth();\n    const flowHeight = this.flowSettingsService.computedFlowHeight();\n\n    return nodes.filter((n) => {\n      const { x, y } = n.globalPoint();\n      const width = n.width();\n      const height = n.height();\n\n      return isRectInViewport({ x, y, width, height }, viewport, flowWidth, flowHeight);\n    });\n  });\n\n  private viewportNodesAfterInteraction = toLazySignal(\n    merge(\n      // TODO: maybe there is a better way wait when viewport is ready?\n      // (to correctly calculate viewport nodes on first render)\n      toObservable(this.flowEntitiesService.nodes).pipe(\n        observeOn(asyncScheduler),\n        filter((nodes) => !!nodes.length),\n      ),\n\n      this.viewportService.viewportChangeEnd$.pipe(debounceTime(300)),\n    ).pipe(\n      map(() => {\n        const viewport = this.viewportService.readableViewport();\n        const zoomThreshold = this.flowSettingsService.optimization().virtualizationZoomThreshold;\n\n        return viewport.zoom < zoomThreshold ? [] : this.viewportNodes();\n      }),\n    ),\n    {\n      initialValue: [],\n    },\n  );\n\n  private maxOrder = computed(() => {\n    return Math.max(...this.flowEntitiesService.nodes().map((n) => n.renderOrder()));\n  });\n\n  public pullNode(node: NodeModel) {\n    // pull node\n    node.renderOrder.set(this.maxOrder() + 1);\n\n    // pull children\n    node.children().forEach((n) => this.pullNode(n));\n  }\n}\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class PreviewFlowRenderStrategyService {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PreviewFlowRenderStrategyService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
5
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PreviewFlowRenderStrategyService }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PreviewFlowRenderStrategyService, decorators: [{
|
|
8
|
+
type: Injectable
|
|
9
|
+
}] });
|
|
10
|
+
export class ViewportPreviewFlowRenderStrategyService extends PreviewFlowRenderStrategyService {
|
|
11
|
+
shouldRenderNode(node) {
|
|
12
|
+
// Do not render preview node if the real node is visible
|
|
13
|
+
return !node.isVisible();
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ViewportPreviewFlowRenderStrategyService, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
16
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ViewportPreviewFlowRenderStrategyService }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ViewportPreviewFlowRenderStrategyService, decorators: [{
|
|
19
|
+
type: Injectable
|
|
20
|
+
}] });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy1mbG93LXJlbmRlci1zdHJhdGVneS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3NlcnZpY2VzL3ByZXZpZXctZmxvdy1yZW5kZXItc3RyYXRlZ3kuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUkzQyxNQUFNLE9BQWdCLGdDQUFnQzsrR0FBaEMsZ0NBQWdDO21IQUFoQyxnQ0FBZ0M7OzRGQUFoQyxnQ0FBZ0M7a0JBRHJELFVBQVU7O0FBTVgsTUFBTSxPQUFPLHdDQUF5QyxTQUFRLGdDQUFnQztJQUNyRixnQkFBZ0IsQ0FBQyxJQUFlO1FBQ3JDLHlEQUF5RDtRQUN6RCxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQzNCLENBQUM7K0dBSlUsd0NBQXdDO21IQUF4Qyx3Q0FBd0M7OzRGQUF4Qyx3Q0FBd0M7a0JBRHBELFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvbm9kZS5tb2RlbCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBQcmV2aWV3Rmxvd1JlbmRlclN0cmF0ZWd5U2VydmljZSB7XG4gIHB1YmxpYyBhYnN0cmFjdCBzaG91bGRSZW5kZXJOb2RlKG5vZGU6IE5vZGVNb2RlbCk6IGJvb2xlYW47XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBWaWV3cG9ydFByZXZpZXdGbG93UmVuZGVyU3RyYXRlZ3lTZXJ2aWNlIGV4dGVuZHMgUHJldmlld0Zsb3dSZW5kZXJTdHJhdGVneVNlcnZpY2Uge1xuICBwdWJsaWMgc2hvdWxkUmVuZGVyTm9kZShub2RlOiBOb2RlTW9kZWwpOiBib29sZWFuIHtcbiAgICAvLyBEbyBub3QgcmVuZGVyIHByZXZpZXcgbm9kZSBpZiB0aGUgcmVhbCBub2RlIGlzIHZpc2libGVcbiAgICByZXR1cm4gIW5vZGUuaXNWaXNpYmxlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -3,6 +3,7 @@ import { getNodesBounds } from '../utils/nodes';
|
|
|
3
3
|
import { FlowEntitiesService } from './flow-entities.service';
|
|
4
4
|
import { getViewportForBounds } from '../utils/viewport';
|
|
5
5
|
import { FlowSettingsService } from './flow-settings.service';
|
|
6
|
+
import { Subject } from 'rxjs';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class ViewportService {
|
|
8
9
|
constructor() {
|
|
@@ -23,6 +24,7 @@ export class ViewportService {
|
|
|
23
24
|
* - writableViewport signal
|
|
24
25
|
*/
|
|
25
26
|
this.readableViewport = signal(ViewportService.getDefaultViewport());
|
|
27
|
+
this.viewportChangeEnd$ = new Subject();
|
|
26
28
|
}
|
|
27
29
|
/**
|
|
28
30
|
* The default value used by d3, just copy it here
|
|
@@ -39,6 +41,11 @@ export class ViewportService {
|
|
|
39
41
|
const duration = options.duration ?? 0;
|
|
40
42
|
this.writableViewport.set({ changeType: 'absolute', state, duration });
|
|
41
43
|
}
|
|
44
|
+
triggerViewportChangeEvent(type) {
|
|
45
|
+
if (type === 'end') {
|
|
46
|
+
this.viewportChangeEnd$.next();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
42
49
|
getBoundsNodes(nodeIds) {
|
|
43
50
|
return !nodeIds?.length
|
|
44
51
|
? // If nodes option not passed or the list is empty, then get fit the whole view
|
|
@@ -54,4 +61,4 @@ export class ViewportService {
|
|
|
54
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ViewportService, decorators: [{
|
|
55
62
|
type: Injectable
|
|
56
63
|
}] });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9zZXJ2aWNlcy92aWV3cG9ydC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWtCLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0UsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRzlELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBRy9CLE1BQU0sT0FBTyxlQUFlO0lBRDVCO1FBRVUsb0JBQWUsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUM5Qyx3QkFBbUIsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQVcxRDs7O1dBR0c7UUFDYSxxQkFBZ0IsR0FBcUMsTUFBTSxDQUFDO1lBQzFFLFVBQVUsRUFBRSxTQUFTO1lBQ3JCLEtBQUssRUFBRSxlQUFlLENBQUMsa0JBQWtCLEVBQUU7WUFDM0MsUUFBUSxFQUFFLENBQUM7U0FDWixDQUFDLENBQUM7UUFFSDs7OztXQUlHO1FBQ2EscUJBQWdCLEdBQWtDLE1BQU0sQ0FBQyxlQUFlLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO1FBRS9GLHVCQUFrQixHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7S0FvQzFEO0lBOURDOzs7O09BSUc7SUFDSyxNQUFNLENBQUMsa0JBQWtCO1FBQy9CLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFxQkQsZ0ZBQWdGO0lBRXpFLE9BQU8sQ0FBQyxVQUEwQixFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFO1FBQy9FLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUMsQ0FBQztRQUV2RCxNQUFNLEtBQUssR0FBRyxvQkFBb0IsQ0FDaEMsY0FBYyxDQUFDLEtBQUssQ0FBQyxFQUNyQixJQUFJLENBQUMsbUJBQW1CLENBQUMsaUJBQWlCLEVBQUUsRUFDNUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixFQUFFLEVBQzdDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLEVBQUUsRUFDbEMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxFQUNsQyxPQUFPLENBQUMsT0FBTyxJQUFJLEdBQUcsQ0FDdkIsQ0FBQztRQUVGLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLElBQUksQ0FBQyxDQUFDO1FBRXZDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFFTSwwQkFBMEIsQ0FBQyxJQUFXO1FBQzNDLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNqQyxDQUFDO0lBQ0gsQ0FBQztJQUVPLGNBQWMsQ0FBQyxPQUFpQjtRQUN0QyxPQUFPLENBQUMsT0FBTyxFQUFFLE1BQU07WUFDckIsQ0FBQyxDQUFDLCtFQUErRTtnQkFDL0UsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUU7WUFDOUIsQ0FBQyxDQUFDLGtDQUFrQztnQkFDbEMsT0FBTztxQkFDSixHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsS0FBSyxNQUFNLENBQUMsQ0FBQztxQkFDMUYsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFxQixFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JELENBQUM7K0dBakVVLGVBQWU7bUhBQWYsZUFBZTs7NEZBQWYsZUFBZTtrQkFEM0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIFdyaXRhYmxlU2lnbmFsLCBpbmplY3QsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVmlld3BvcnRTdGF0ZSwgV3JpdGFibGVWaWV3cG9ydCB9IGZyb20gJy4uL2ludGVyZmFjZXMvdmlld3BvcnQuaW50ZXJmYWNlJztcbmltcG9ydCB7IGdldE5vZGVzQm91bmRzIH0gZnJvbSAnLi4vdXRpbHMvbm9kZXMnO1xuaW1wb3J0IHsgRmxvd0VudGl0aWVzU2VydmljZSB9IGZyb20gJy4vZmxvdy1lbnRpdGllcy5zZXJ2aWNlJztcbmltcG9ydCB7IGdldFZpZXdwb3J0Rm9yQm91bmRzIH0gZnJvbSAnLi4vdXRpbHMvdmlld3BvcnQnO1xuaW1wb3J0IHsgRmxvd1NldHRpbmdzU2VydmljZSB9IGZyb20gJy4vZmxvdy1zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7IEZpdFZpZXdPcHRpb25zIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9maXQtdmlldy1vcHRpb25zLmludGVyZmFjZSc7XG5pbXBvcnQgeyBOb2RlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvbm9kZS5tb2RlbCc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBWaWV3cG9ydFNlcnZpY2Uge1xuICBwcml2YXRlIGVudGl0aWVzU2VydmljZSA9IGluamVjdChGbG93RW50aXRpZXNTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBmbG93U2V0dGluZ3NTZXJ2aWNlID0gaW5qZWN0KEZsb3dTZXR0aW5nc1NlcnZpY2UpO1xuXG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCB2YWx1ZSB1c2VkIGJ5IGQzLCBqdXN0IGNvcHkgaXQgaGVyZVxuICAgKlxuICAgKiBAcmV0dXJucyBkZWZhdWx0IHZpZXdwb3J0IHZhbHVlXG4gICAqL1xuICBwcml2YXRlIHN0YXRpYyBnZXREZWZhdWx0Vmlld3BvcnQoKTogVmlld3BvcnRTdGF0ZSB7XG4gICAgcmV0dXJuIHsgem9vbTogMSwgeDogMCwgeTogMCB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEludGVybmFsIHNpZ25hbCB0aGF0IGFjY2VwdHMgdmFsdWUgZnJvbSB1c2VyIGJ5IGxpYiBhcGlcbiAgICogV2hlbiB0aGlzIHNpZ25hbCBjaGFuZ2VzLCBsaWIgc2V0cyBuZXcgdmlldyBzdGF0ZSBhbmQgdXBkYXRlIHJlYWRhYmxlVmlld3BvcnQgc2lnbmFsXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgd3JpdGFibGVWaWV3cG9ydDogV3JpdGFibGVTaWduYWw8V3JpdGFibGVWaWV3cG9ydD4gPSBzaWduYWwoe1xuICAgIGNoYW5nZVR5cGU6ICdpbml0aWFsJyxcbiAgICBzdGF0ZTogVmlld3BvcnRTZXJ2aWNlLmdldERlZmF1bHRWaWV3cG9ydCgpLFxuICAgIGR1cmF0aW9uOiAwLFxuICB9KTtcblxuICAvKipcbiAgICogUHVibGljIHNpZ25hbCB3aXRoIHZpZXdwb3J0IHN0YXRlLiBVc2VyIGNhbiBkaXJlY3RseSByZWFkIGZyb20gdGhpcyBzaWduYWwuIEl0J3MgdXBkYXRlZCBieTpcbiAgICogLSB1c2VyIGV2ZW50cyBvbiBmbG93XG4gICAqIC0gd3JpdGFibGVWaWV3cG9ydCBzaWduYWxcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSByZWFkYWJsZVZpZXdwb3J0OiBXcml0YWJsZVNpZ25hbDxWaWV3cG9ydFN0YXRlPiA9IHNpZ25hbChWaWV3cG9ydFNlcnZpY2UuZ2V0RGVmYXVsdFZpZXdwb3J0KCkpO1xuXG4gIHB1YmxpYyByZWFkb25seSB2aWV3cG9ydENoYW5nZUVuZCQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIC8vIFRPRE86IGFkZCB3cml0YWJsZVZpZXdwb3J0V2l0aENvbnN0cmFpbnRzICh0byBhcHBseSBtaW4gem9vbS9tYXggem9vbSB2YWx1ZXMpXG5cbiAgcHVibGljIGZpdFZpZXcob3B0aW9uczogRml0Vmlld09wdGlvbnMgPSB7IHBhZGRpbmc6IDAuMSwgZHVyYXRpb246IDAsIG5vZGVzOiBbXSB9KSB7XG4gICAgY29uc3Qgbm9kZXMgPSB0aGlzLmdldEJvdW5kc05vZGVzKG9wdGlvbnMubm9kZXMgPz8gW10pO1xuXG4gICAgY29uc3Qgc3RhdGUgPSBnZXRWaWV3cG9ydEZvckJvdW5kcyhcbiAgICAgIGdldE5vZGVzQm91bmRzKG5vZGVzKSxcbiAgICAgIHRoaXMuZmxvd1NldHRpbmdzU2VydmljZS5jb21wdXRlZEZsb3dXaWR0aCgpLFxuICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd0hlaWdodCgpLFxuICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLm1pblpvb20oKSxcbiAgICAgIHRoaXMuZmxvd1NldHRpbmdzU2VydmljZS5tYXhab29tKCksXG4gICAgICBvcHRpb25zLnBhZGRpbmcgPz8gMC4xLFxuICAgICk7XG5cbiAgICBjb25zdCBkdXJhdGlvbiA9IG9wdGlvbnMuZHVyYXRpb24gPz8gMDtcblxuICAgIHRoaXMud3JpdGFibGVWaWV3cG9ydC5zZXQoeyBjaGFuZ2VUeXBlOiAnYWJzb2x1dGUnLCBzdGF0ZSwgZHVyYXRpb24gfSk7XG4gIH1cblxuICBwdWJsaWMgdHJpZ2dlclZpZXdwb3J0Q2hhbmdlRXZlbnQodHlwZTogJ2VuZCcpIHtcbiAgICBpZiAodHlwZSA9PT0gJ2VuZCcpIHtcbiAgICAgIHRoaXMudmlld3BvcnRDaGFuZ2VFbmQkLm5leHQoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldEJvdW5kc05vZGVzKG5vZGVJZHM6IHN0cmluZ1tdKSB7XG4gICAgcmV0dXJuICFub2RlSWRzPy5sZW5ndGhcbiAgICAgID8gLy8gSWYgbm9kZXMgb3B0aW9uIG5vdCBwYXNzZWQgb3IgdGhlIGxpc3QgaXMgZW1wdHksIHRoZW4gZ2V0IGZpdCB0aGUgd2hvbGUgdmlld1xuICAgICAgICB0aGlzLmVudGl0aWVzU2VydmljZS5ub2RlcygpXG4gICAgICA6IC8vIE90aGVyd2lzZSBmaXQgdG8gc3BlY2lmaWMgbm9kZXNcbiAgICAgICAgbm9kZUlkc1xuICAgICAgICAgIC5tYXAoKG5vZGVJZCkgPT4gdGhpcy5lbnRpdGllc1NlcnZpY2Uubm9kZXMoKS5maW5kKCh7IHJhd05vZGUgfSkgPT4gcmF3Tm9kZS5pZCA9PT0gbm9kZUlkKSlcbiAgICAgICAgICAuZmlsdGVyKChub2RlKTogbm9kZSBpcyBOb2RlTW9kZWwgPT4gISFub2RlKTtcbiAgfVxufVxuIl19
|