ngx-vflow 1.8.2 → 1.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/esm2022/lib/vflow/components/connection/connection.component.mjs +33 -13
  2. package/esm2022/lib/vflow/components/edge/edge.component.mjs +3 -3
  3. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +12 -8
  4. package/esm2022/lib/vflow/interfaces/curve-factory.interface.mjs +2 -0
  5. package/esm2022/lib/vflow/interfaces/edge.interface.mjs +1 -1
  6. package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +12 -14
  7. package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +5 -5
  8. package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +7 -9
  9. package/esm2022/lib/vflow/models/edge.model.mjs +24 -8
  10. package/esm2022/lib/vflow/services/edge-rendering.service.mjs +3 -1
  11. package/esm2022/lib/vflow/services/flow-entities.service.mjs +3 -1
  12. package/esm2022/lib/vflow/services/node-rendering.service.mjs +5 -1
  13. package/esm2022/lib/vflow/utils/entities-per-frame.mjs +2 -0
  14. package/esm2022/public-api.mjs +15 -13
  15. package/esm2022/testing/component-mocks/custom-template-edge-mock.component.mjs +16 -0
  16. package/esm2022/testing/component-mocks/handle-mock.component.mjs +24 -0
  17. package/esm2022/{lib/vflow/testing-utils → testing}/component-mocks/minimap-mock.component.mjs +1 -1
  18. package/esm2022/testing/component-mocks/node-toolbar-mock.component.mjs +23 -0
  19. package/esm2022/testing/component-mocks/resizable-mock.component.mjs +25 -0
  20. package/esm2022/testing/component-mocks/vflow-mock.component.mjs +296 -0
  21. package/esm2022/testing/directive-mocks/connection-controller-mock.directive.mjs +27 -0
  22. package/esm2022/testing/directive-mocks/drag-handle-mock.directive.mjs +11 -0
  23. package/esm2022/{lib/vflow/testing-utils → testing}/directive-mocks/selectable-mock.directive.mjs +1 -1
  24. package/esm2022/{lib/vflow/testing-utils → testing}/directive-mocks/template-mock.directive.mjs +1 -1
  25. package/esm2022/testing/ngx-vflow-testing.mjs +5 -0
  26. package/esm2022/testing/provide-custom-node-mocks.mjs +59 -0
  27. package/esm2022/testing/public-api.mjs +13 -0
  28. package/esm2022/testing/types.mjs +2 -0
  29. package/esm2022/testing/vflow-mocks.mjs +28 -0
  30. package/fesm2022/ngx-vflow-testing.mjs +626 -0
  31. package/fesm2022/ngx-vflow-testing.mjs.map +1 -0
  32. package/fesm2022/ngx-vflow.mjs +94 -648
  33. package/fesm2022/ngx-vflow.mjs.map +1 -1
  34. package/lib/vflow/components/connection/connection.component.d.ts +4 -2
  35. package/lib/vflow/components/vflow/vflow.component.d.ts +4 -0
  36. package/lib/vflow/interfaces/curve-factory.interface.d.ts +44 -0
  37. package/lib/vflow/interfaces/edge.interface.d.ts +2 -1
  38. package/lib/vflow/math/edge-path/bezier-path.d.ts +2 -5
  39. package/lib/vflow/math/edge-path/smooth-step-path.d.ts +2 -3
  40. package/lib/vflow/math/edge-path/straigh-path.d.ts +2 -4
  41. package/lib/vflow/models/edge.model.d.ts +6 -4
  42. package/lib/vflow/services/edge-rendering.service.d.ts +1 -0
  43. package/lib/vflow/services/flow-entities.service.d.ts +3 -0
  44. package/lib/vflow/services/node-rendering.service.d.ts +3 -0
  45. package/lib/vflow/utils/entities-per-frame.d.ts +1 -0
  46. package/package.json +9 -3
  47. package/public-api.d.ts +13 -11
  48. package/testing/component-mocks/custom-template-edge-mock.component.d.ts +7 -0
  49. package/{lib/vflow/testing-utils → testing}/component-mocks/handle-mock.component.d.ts +2 -3
  50. package/{lib/vflow/testing-utils → testing}/component-mocks/minimap-mock.component.d.ts +1 -1
  51. package/{lib/vflow/testing-utils → testing}/component-mocks/node-toolbar-mock.component.d.ts +1 -2
  52. package/{lib/vflow/testing-utils → testing}/component-mocks/resizable-mock.component.d.ts +1 -1
  53. package/{lib/vflow/testing-utils → testing}/component-mocks/vflow-mock.component.d.ts +2 -14
  54. package/{lib/vflow/testing-utils → testing}/directive-mocks/connection-controller-mock.directive.d.ts +2 -3
  55. package/{lib/vflow/testing-utils → testing}/directive-mocks/drag-handle-mock.directive.d.ts +1 -1
  56. package/{lib/vflow/testing-utils → testing}/directive-mocks/selectable-mock.directive.d.ts +1 -1
  57. package/{lib/vflow/testing-utils → testing}/directive-mocks/template-mock.directive.d.ts +1 -1
  58. package/testing/index.d.ts +5 -0
  59. package/testing/public-api.d.ts +11 -0
  60. package/{lib/vflow/testing-utils → testing}/vflow-mocks.d.ts +2 -1
  61. package/esm2022/lib/vflow/interfaces/path-data.interface.mjs +0 -2
  62. package/esm2022/lib/vflow/testing-utils/component-mocks/handle-mock.component.mjs +0 -24
  63. package/esm2022/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.mjs +0 -23
  64. package/esm2022/lib/vflow/testing-utils/component-mocks/resizable-mock.component.mjs +0 -25
  65. package/esm2022/lib/vflow/testing-utils/component-mocks/vflow-mock.component.mjs +0 -296
  66. package/esm2022/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.mjs +0 -27
  67. package/esm2022/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.mjs +0 -11
  68. package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +0 -68
  69. package/esm2022/lib/vflow/testing-utils/types.mjs +0 -2
  70. package/esm2022/lib/vflow/testing-utils/vflow-mocks.mjs +0 -26
  71. package/esm2022/lib/vflow/types/using-points.type.mjs +0 -2
  72. package/lib/vflow/interfaces/path-data.interface.d.ts +0 -8
  73. package/lib/vflow/types/using-points.type.d.ts +0 -5
  74. /package/{lib/vflow/testing-utils → testing}/provide-custom-node-mocks.d.ts +0 -0
  75. /package/{lib/vflow/testing-utils → testing}/types.d.ts +0 -0
@@ -6,30 +6,36 @@ import { bezierPath } from '../../math/edge-path/bezier-path';
6
6
  import { hashCode } from '../../utils/hash';
7
7
  import { smoothStepPath } from '../../math/edge-path/smooth-step-path';
8
8
  import { NgTemplateOutlet } from '@angular/common';
9
+ import { FlowEntitiesService } from '../../services/flow-entities.service';
9
10
  import * as i0 from "@angular/core";
10
11
  export class ConnectionComponent {
11
12
  constructor() {
12
- this.model = input.required();
13
- this.template = input();
14
13
  this.flowStatusService = inject(FlowStatusService);
15
14
  this.spacePointContext = inject(SpacePointContextDirective);
15
+ this.flowEntitiesService = inject(FlowEntitiesService);
16
+ this.model = input.required();
17
+ this.template = input();
16
18
  this.path = computed(() => {
17
19
  const status = this.flowStatusService.status();
20
+ const curve = this.model().curve;
18
21
  if (status.state === 'connection-start' || status.state === 'reconnection-start') {
19
22
  const sourceHandle = status.payload.sourceHandle;
20
23
  const sourcePoint = sourceHandle.pointAbsolute();
21
24
  const sourcePosition = sourceHandle.rawHandle.position;
22
25
  const targetPoint = this.spacePointContext.svgCurrentSpacePoint();
23
26
  const targetPosition = getOppositePostion(sourceHandle.rawHandle.position);
24
- switch (this.model().curve) {
27
+ const params = this.getPathFactoryParams(sourcePoint, targetPoint, sourcePosition, targetPosition);
28
+ switch (curve) {
25
29
  case 'straight':
26
- return straightPath(sourcePoint, targetPoint).path;
30
+ return straightPath(params).path;
27
31
  case 'bezier':
28
- return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
32
+ return bezierPath(params).path;
29
33
  case 'smooth-step':
30
- return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
34
+ return smoothStepPath(params).path;
31
35
  case 'step':
32
- return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;
36
+ return smoothStepPath(params, 0).path;
37
+ default:
38
+ return curve(params).path;
33
39
  }
34
40
  }
35
41
  if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {
@@ -44,15 +50,18 @@ export class ConnectionComponent {
44
50
  const targetPosition = status.payload.valid
45
51
  ? targetHandle.rawHandle.position
46
52
  : getOppositePostion(sourceHandle.rawHandle.position);
47
- switch (this.model().curve) {
53
+ const params = this.getPathFactoryParams(sourcePoint, targetPoint, sourcePosition, targetPosition);
54
+ switch (curve) {
48
55
  case 'straight':
49
- return straightPath(sourcePoint, targetPoint).path;
56
+ return straightPath(params).path;
50
57
  case 'bezier':
51
- return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
58
+ return bezierPath(params).path;
52
59
  case 'smooth-step':
53
- return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;
60
+ return smoothStepPath(params).path;
54
61
  case 'step':
55
- return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;
62
+ return smoothStepPath(params, 0).path;
63
+ default:
64
+ return curve(params).path;
56
65
  }
57
66
  }
58
67
  return null;
@@ -75,6 +84,17 @@ export class ConnectionComponent {
75
84
  },
76
85
  };
77
86
  }
87
+ getPathFactoryParams(sourcePoint, targetPoint, sourcePosition, targetPosition) {
88
+ return {
89
+ mode: 'connection',
90
+ sourcePoint,
91
+ targetPoint,
92
+ sourcePosition,
93
+ targetPosition,
94
+ allEdges: this.flowEntitiesService.rawEdges(),
95
+ allNodes: this.flowEntitiesService.rawNodes(),
96
+ };
97
+ }
78
98
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
79
99
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ConnectionComponent, isStandalone: true, selector: "g[connection]", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
80
100
  @if (model().type === 'default') {
@@ -134,4 +154,4 @@ function getOppositePostion(position) {
134
154
  return 'left';
135
155
  }
136
156
  }
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/connection/connection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, TemplateRef, computed, inject, input } from '@angular/core';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { straightPath } from '../../math/edge-path/straigh-path';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { bezierPath } from '../../math/edge-path/bezier-path';\nimport { hashCode } from '../../utils/hash';\nimport { Position } from '../../types/position.type';\nimport { smoothStepPath } from '../../math/edge-path/smooth-step-path';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ConnectionContext } from '../../interfaces/template-context.interface';\n\n@Component({\n  standalone: true,\n  selector: 'g[connection]',\n  template: `\n    @if (model().type === 'default') {\n      @if (path(); as path) {\n        <svg:path\n          fill=\"none\"\n          stroke-width=\"2\"\n          [attr.d]=\"path\"\n          [attr.marker-end]=\"markerUrl()\"\n          [attr.stroke]=\"defaultColor\" />\n      }\n    }\n\n    @if (model().type === 'template') {\n      @if (template(); as template) {\n        <ng-container *ngTemplateOutlet=\"template; context: getContext()\" />\n      }\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgTemplateOutlet],\n})\nexport class ConnectionComponent {\n  public model = input.required<ConnectionModel>();\n\n  public template = input<TemplateRef<any>>();\n\n  private flowStatusService = inject(FlowStatusService);\n  private spacePointContext = inject(SpacePointContextDirective);\n\n  protected path = computed(() => {\n    const status = this.flowStatusService.status();\n\n    if (status.state === 'connection-start' || status.state === 'reconnection-start') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetPoint = this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = getOppositePostion(sourceHandle.rawHandle.position);\n\n      switch (this.model().curve) {\n        case 'straight':\n          return straightPath(sourcePoint, targetPoint).path;\n        case 'bezier':\n          return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;\n        case 'smooth-step':\n          return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;\n        case 'step':\n          return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;\n      }\n    }\n\n    if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetHandle = status.payload.targetHandle;\n      // ignore magnet if validation failed\n      const targetPoint = status.payload.valid\n        ? targetHandle.pointAbsolute()\n        : this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = status.payload.valid\n        ? targetHandle.rawHandle.position\n        : getOppositePostion(sourceHandle.rawHandle.position);\n\n      switch (this.model().curve) {\n        case 'straight':\n          return straightPath(sourcePoint, targetPoint).path;\n        case 'bezier':\n          return bezierPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;\n        case 'smooth-step':\n          return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition).path;\n        case 'step':\n          return smoothStepPath(sourcePoint, targetPoint, sourcePosition, targetPosition, 0).path;\n      }\n    }\n\n    return null;\n  });\n\n  protected markerUrl = computed(() => {\n    const marker = this.model().settings.marker;\n\n    if (marker) {\n      return `url(#${hashCode(JSON.stringify(marker))})`;\n    }\n\n    return '';\n  });\n\n  protected readonly defaultColor = 'rgb(177, 177, 183)';\n\n  // TODO: move context to model\n  protected getContext(): ConnectionContext {\n    return {\n      $implicit: {\n        path: this.path,\n        marker: this.markerUrl,\n      },\n    };\n  }\n}\n\nfunction getOppositePostion(position: Position): Position {\n  switch (position) {\n    case 'top':\n      return 'bottom';\n    case 'bottom':\n      return 'top';\n    case 'left':\n      return 'right';\n    case 'right':\n      return 'left';\n  }\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/connection/connection.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, TemplateRef, computed, inject, input } from '@angular/core';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { straightPath } from '../../math/edge-path/straigh-path';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { ConnectionModel } from '../../models/connection.model';\nimport { bezierPath } from '../../math/edge-path/bezier-path';\nimport { hashCode } from '../../utils/hash';\nimport { Position } from '../../types/position.type';\nimport { smoothStepPath } from '../../math/edge-path/smooth-step-path';\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ConnectionContext } from '../../interfaces/template-context.interface';\nimport { Point } from '../../interfaces/point.interface';\nimport { CurveFactoryParams } from '../../interfaces/curve-factory.interface';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\n\n@Component({\n  standalone: true,\n  selector: 'g[connection]',\n  template: `\n    @if (model().type === 'default') {\n      @if (path(); as path) {\n        <svg:path\n          fill=\"none\"\n          stroke-width=\"2\"\n          [attr.d]=\"path\"\n          [attr.marker-end]=\"markerUrl()\"\n          [attr.stroke]=\"defaultColor\" />\n      }\n    }\n\n    @if (model().type === 'template') {\n      @if (template(); as template) {\n        <ng-container *ngTemplateOutlet=\"template; context: getContext()\" />\n      }\n    }\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgTemplateOutlet],\n})\nexport class ConnectionComponent {\n  private readonly flowStatusService = inject(FlowStatusService);\n  private readonly spacePointContext = inject(SpacePointContextDirective);\n  private readonly flowEntitiesService = inject(FlowEntitiesService);\n\n  public model = input.required<ConnectionModel>();\n\n  public template = input<TemplateRef<any>>();\n\n  protected path = computed(() => {\n    const status = this.flowStatusService.status();\n    const curve = this.model().curve;\n\n    if (status.state === 'connection-start' || status.state === 'reconnection-start') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetPoint = this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = getOppositePostion(sourceHandle.rawHandle.position);\n\n      const params = this.getPathFactoryParams(sourcePoint, targetPoint, sourcePosition, targetPosition);\n\n      switch (curve) {\n        case 'straight':\n          return straightPath(params).path;\n        case 'bezier':\n          return bezierPath(params).path;\n        case 'smooth-step':\n          return smoothStepPath(params).path;\n        case 'step':\n          return smoothStepPath(params, 0).path;\n        default:\n          return curve(params).path;\n      }\n    }\n\n    if (status.state === 'connection-validation' || status.state === 'reconnection-validation') {\n      const sourceHandle = status.payload.sourceHandle;\n      const sourcePoint = sourceHandle.pointAbsolute();\n      const sourcePosition = sourceHandle.rawHandle.position;\n\n      const targetHandle = status.payload.targetHandle;\n      // ignore magnet if validation failed\n      const targetPoint = status.payload.valid\n        ? targetHandle.pointAbsolute()\n        : this.spacePointContext.svgCurrentSpacePoint();\n      const targetPosition = status.payload.valid\n        ? targetHandle.rawHandle.position\n        : getOppositePostion(sourceHandle.rawHandle.position);\n\n      const params = this.getPathFactoryParams(sourcePoint, targetPoint, sourcePosition, targetPosition);\n\n      switch (curve) {\n        case 'straight':\n          return straightPath(params).path;\n        case 'bezier':\n          return bezierPath(params).path;\n        case 'smooth-step':\n          return smoothStepPath(params).path;\n        case 'step':\n          return smoothStepPath(params, 0).path;\n        default:\n          return curve(params).path;\n      }\n    }\n\n    return null;\n  });\n\n  protected markerUrl = computed(() => {\n    const marker = this.model().settings.marker;\n\n    if (marker) {\n      return `url(#${hashCode(JSON.stringify(marker))})`;\n    }\n\n    return '';\n  });\n\n  protected readonly defaultColor = 'rgb(177, 177, 183)';\n\n  // TODO: move context to model\n  protected getContext(): ConnectionContext {\n    return {\n      $implicit: {\n        path: this.path,\n        marker: this.markerUrl,\n      },\n    };\n  }\n\n  private getPathFactoryParams(\n    sourcePoint: Point,\n    targetPoint: Point,\n    sourcePosition: Position,\n    targetPosition: Position,\n  ): CurveFactoryParams {\n    return {\n      mode: 'connection',\n      sourcePoint,\n      targetPoint,\n      sourcePosition,\n      targetPosition,\n      allEdges: this.flowEntitiesService.rawEdges(),\n      allNodes: this.flowEntitiesService.rawNodes(),\n    };\n  }\n}\n\nfunction getOppositePostion(position: Position): Position {\n  switch (position) {\n    case 'top':\n      return 'bottom';\n    case 'bottom':\n      return 'top';\n    case 'left':\n      return 'right';\n    case 'right':\n      return 'left';\n  }\n}\n"]}
@@ -42,13 +42,13 @@ export class EdgeComponent {
42
42
  this.connectionController?.startReconnection(handle, this.model());
43
43
  }
44
44
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: EdgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
45
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: EdgeComponent, isStandalone: true, selector: "g[edge]", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, edgeTemplate: { classPropertyName: "edgeTemplate", publicName: "edgeTemplate", isSignal: true, isRequired: false, transformFunction: null }, edgeLabelHtmlTemplate: { classPropertyName: "edgeLabelHtmlTemplate", publicName: "edgeLabelHtmlTemplate", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.visibility": "isReconnecting() ? \"hidden\" : \"visible\"" }, classAttribute: "selectable" }, ngImport: i0, template: "@if (model().type === 'default') {\n <svg:path\n class=\"edge\"\n [attr.d]=\"model().path().path\"\n [attr.marker-start]=\"model().markerStartUrl()\"\n [attr.marker-end]=\"model().markerEndUrl()\"\n [class.edge_selected]=\"model().selected()\" />\n\n <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n @if (edgeTemplate(); as edgeTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"edgeTemplate\"\n [ngTemplateOutletContext]=\"model().context\"\n [ngTemplateOutletInjector]=\"injector\" />\n }\n}\n\n@if (model().edgeLabels.start; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.start\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.center; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.center\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.end; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.end\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n @if (model().reconnectable === true || model().reconnectable === 'source') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n }\n\n @if (model().reconnectable === true || model().reconnectable === 'target') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n }\n}\n", styles: [".edge{fill:none;stroke-width:2;stroke:#b1b1b7}.edge_selected{stroke-width:2.5;stroke:#0f4c75}.interactive-edge{fill:none;stroke-width:20;stroke:transparent}.reconnect-handle{fill:transparent;cursor:move}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: EdgeLabelComponent, selector: "g[edgeLabel]", inputs: ["model", "edgeModel", "point", "htmlTemplate"] }, { kind: "directive", type: PointerDirective, selector: "[pointerStart], [pointerEnd], [pointerOver], [pointerOut]", outputs: ["pointerOver", "pointerOut", "pointerStart", "pointerEnd"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
45
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: EdgeComponent, isStandalone: true, selector: "g[edge]", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, edgeTemplate: { classPropertyName: "edgeTemplate", publicName: "edgeTemplate", isSignal: true, isRequired: false, transformFunction: null }, edgeLabelHtmlTemplate: { classPropertyName: "edgeLabelHtmlTemplate", publicName: "edgeLabelHtmlTemplate", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.visibility": "isReconnecting() ? \"hidden\" : \"visible\"" }, classAttribute: "selectable" }, ngImport: i0, template: "@if (model().type === 'default') {\n <svg:path\n class=\"edge\"\n [attr.d]=\"model().path().path\"\n [attr.marker-start]=\"model().markerStartUrl()\"\n [attr.marker-end]=\"model().markerEndUrl()\"\n [class.edge_selected]=\"model().selected()\" />\n\n <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n @if (edgeTemplate(); as edgeTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"edgeTemplate\"\n [ngTemplateOutletContext]=\"model().context\"\n [ngTemplateOutletInjector]=\"injector\" />\n }\n}\n\n@if (model().edgeLabels.start; as label) {\n @if (model().path().labelPoints?.start; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().edgeLabels.center; as label) {\n @if (model().path().labelPoints?.center; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().edgeLabels.end; as label) {\n @if (model().path().labelPoints?.end; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n @if (model().reconnectable === true || model().reconnectable === 'source') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n }\n\n @if (model().reconnectable === true || model().reconnectable === 'target') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n }\n}\n", styles: [".edge{fill:none;stroke-width:2;stroke:#b1b1b7}.edge_selected{stroke-width:2.5;stroke:#0f4c75}.interactive-edge{fill:none;stroke-width:20;stroke:transparent}.reconnect-handle{fill:transparent;cursor:move}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: EdgeLabelComponent, selector: "g[edgeLabel]", inputs: ["model", "edgeModel", "point", "htmlTemplate"] }, { kind: "directive", type: PointerDirective, selector: "[pointerStart], [pointerEnd], [pointerOver], [pointerOut]", outputs: ["pointerOver", "pointerOut", "pointerStart", "pointerEnd"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
46
46
  }
47
47
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: EdgeComponent, decorators: [{
48
48
  type: Component,
49
49
  args: [{ standalone: true, selector: 'g[edge]', changeDetection: ChangeDetectionStrategy.OnPush, host: {
50
50
  class: 'selectable',
51
51
  '[style.visibility]': 'isReconnecting() ? "hidden" : "visible"',
52
- }, imports: [NgTemplateOutlet, EdgeLabelComponent, PointerDirective], template: "@if (model().type === 'default') {\n <svg:path\n class=\"edge\"\n [attr.d]=\"model().path().path\"\n [attr.marker-start]=\"model().markerStartUrl()\"\n [attr.marker-end]=\"model().markerEndUrl()\"\n [class.edge_selected]=\"model().selected()\" />\n\n <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n @if (edgeTemplate(); as edgeTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"edgeTemplate\"\n [ngTemplateOutletContext]=\"model().context\"\n [ngTemplateOutletInjector]=\"injector\" />\n }\n}\n\n@if (model().edgeLabels.start; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.start\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.center; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.center\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.end; as label) {\n <svg:g\n edgeLabel\n [model]=\"label\"\n [point]=\"model().path().points.end\"\n [edgeModel]=\"model()\"\n [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n @if (model().reconnectable === true || model().reconnectable === 'source') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n }\n\n @if (model().reconnectable === true || model().reconnectable === 'target') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n }\n}\n", styles: [".edge{fill:none;stroke-width:2;stroke:#b1b1b7}.edge_selected{stroke-width:2.5;stroke:#0f4c75}.interactive-edge{fill:none;stroke-width:20;stroke:transparent}.reconnect-handle{fill:transparent;cursor:move}\n"] }]
52
+ }, imports: [NgTemplateOutlet, EdgeLabelComponent, PointerDirective], template: "@if (model().type === 'default') {\n <svg:path\n class=\"edge\"\n [attr.d]=\"model().path().path\"\n [attr.marker-start]=\"model().markerStartUrl()\"\n [attr.marker-end]=\"model().markerEndUrl()\"\n [class.edge_selected]=\"model().selected()\" />\n\n <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n @if (edgeTemplate(); as edgeTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"edgeTemplate\"\n [ngTemplateOutletContext]=\"model().context\"\n [ngTemplateOutletInjector]=\"injector\" />\n }\n}\n\n@if (model().edgeLabels.start; as label) {\n @if (model().path().labelPoints?.start; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().edgeLabels.center; as label) {\n @if (model().path().labelPoints?.center; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().edgeLabels.end; as label) {\n @if (model().path().labelPoints?.end; as point) {\n <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n }\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n @if (model().reconnectable === true || model().reconnectable === 'source') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n }\n\n @if (model().reconnectable === true || model().reconnectable === 'target') {\n <svg:circle\n class=\"reconnect-handle\"\n r=\"10\"\n [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n }\n}\n", styles: [".edge{fill:none;stroke-width:2;stroke:#b1b1b7}.edge_selected{stroke-width:2.5;stroke:#0f4c75}.interactive-edge{fill:none;stroke-width:20;stroke:transparent}.reconnect-handle{fill:transparent;cursor:move}\n"] }]
53
53
  }] });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/edge/edge.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/edge/edge.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAe,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACnH,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAInD,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AAEjG,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;;AActE,MAAM,OAAO,aAAa;IAZ1B;QAaY,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9B,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAE5D,6CAA6C;QACrC,yBAAoB,GAAG,MAAM,CAAC,6BAA6B,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAElF,UAAK,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;QAEpC,iBAAY,GAAG,KAAK,EAA4B,CAAC;QAEjD,0BAAqB,GAAG,KAAK,EAAoB,CAAC;QAE/C,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC;YAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,KAAK,oBAAoB,IAAI,MAAM,CAAC,KAAK,KAAK,yBAAyB,CAAC;YAE3G,OAAO,cAAc,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;QACnE,CAAC,CAAC,CAAC;KAoBJ;IAlBQ,MAAM;QACX,IAAI,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,EAAE,CAAC;YAClD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;IAEM,IAAI;QACT,IAAI,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,EAAE,CAAC;YACpD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IAES,iBAAiB,CAAC,KAAY,EAAE,MAAmB;QAC3D,sCAAsC;QACtC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,oBAAoB,EAAE,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACrE,CAAC;+GAxCU,aAAa;mGAAb,aAAa,snBC1B1B,qjEAkEA,uQD1CY,gBAAgB,oJAAE,kBAAkB,kHAAE,gBAAgB;;4FAErD,aAAa;kBAZzB,SAAS;iCACI,IAAI,YACN,SAAS,mBAGF,uBAAuB,CAAC,MAAM,QACzC;wBACJ,KAAK,EAAE,YAAY;wBACnB,oBAAoB,EAAE,yCAAyC;qBAChE,WACQ,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, Injector, TemplateRef, computed, inject, input } from '@angular/core';\nimport { NgTemplateOutlet } from '@angular/common';\n\nimport { EdgeModel } from '../../models/edge.model';\nimport { EdgeContext } from '../../interfaces/template-context.interface';\nimport { SelectionService } from '../../services/selection.service';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { EdgeLabelComponent } from '../edge-label/edge-label.component';\nimport { ConnectionControllerDirective } from '../../directives/connection-controller.directive';\nimport { HandleModel } from '../../models/handle.model';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { EdgeRenderingService } from '../../services/edge-rendering.service';\nimport { PointerDirective } from '../../directives/pointer.directive';\n\n@Component({\n  standalone: true,\n  selector: 'g[edge]',\n  templateUrl: './edge.component.html',\n  styleUrls: ['./edge.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'selectable',\n    '[style.visibility]': 'isReconnecting() ? \"hidden\" : \"visible\"',\n  },\n  imports: [NgTemplateOutlet, EdgeLabelComponent, PointerDirective],\n})\nexport class EdgeComponent {\n  protected injector = inject(Injector);\n  private selectionService = inject(SelectionService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private flowStatusService = inject(FlowStatusService);\n  private edgeRenderingService = inject(EdgeRenderingService);\n\n  // TODO remove dependency from this directive\n  private connectionController = inject(ConnectionControllerDirective, { optional: true });\n\n  public model = input.required<EdgeModel>();\n\n  public edgeTemplate = input<TemplateRef<EdgeContext>>();\n\n  public edgeLabelHtmlTemplate = input<TemplateRef<any>>();\n\n  protected isReconnecting = computed(() => {\n    const status = this.flowStatusService.status();\n    const isReconnecting = status.state === 'reconnection-start' || status.state === 'reconnection-validation';\n\n    return isReconnecting && status.payload.oldEdge === this.model();\n  });\n\n  public select() {\n    if (this.flowSettingsService.entitiesSelectable()) {\n      this.selectionService.select(this.model());\n    }\n  }\n\n  public pull() {\n    if (this.flowSettingsService.elevateEdgesOnSelect()) {\n      this.edgeRenderingService.pull(this.model());\n    }\n  }\n\n  protected startReconnection(event: Event, handle: HandleModel) {\n    // ignore drag by stopping propagation\n    event.stopPropagation();\n\n    this.connectionController?.startReconnection(handle, this.model());\n  }\n}\n","@if (model().type === 'default') {\n  <svg:path\n    class=\"edge\"\n    [attr.d]=\"model().path().path\"\n    [attr.marker-start]=\"model().markerStartUrl()\"\n    [attr.marker-end]=\"model().markerEndUrl()\"\n    [class.edge_selected]=\"model().selected()\" />\n\n  <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n  @if (edgeTemplate(); as edgeTemplate) {\n    <ng-container\n      [ngTemplateOutlet]=\"edgeTemplate\"\n      [ngTemplateOutletContext]=\"model().context\"\n      [ngTemplateOutletInjector]=\"injector\" />\n  }\n}\n\n@if (model().edgeLabels.start; as label) {\n  <svg:g\n    edgeLabel\n    [model]=\"label\"\n    [point]=\"model().path().points.start\"\n    [edgeModel]=\"model()\"\n    [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.center; as label) {\n  <svg:g\n    edgeLabel\n    [model]=\"label\"\n    [point]=\"model().path().points.center\"\n    [edgeModel]=\"model()\"\n    [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().edgeLabels.end; as label) {\n  <svg:g\n    edgeLabel\n    [model]=\"label\"\n    [point]=\"model().path().points.end\"\n    [edgeModel]=\"model()\"\n    [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n  @if (model().reconnectable === true || model().reconnectable === 'source') {\n    <svg:circle\n      class=\"reconnect-handle\"\n      r=\"10\"\n      [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n      [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n      (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n  }\n\n  @if (model().reconnectable === true || model().reconnectable === 'target') {\n    <svg:circle\n      class=\"reconnect-handle\"\n      r=\"10\"\n      [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n      [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n      (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n  }\n}\n"]}
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edge.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/edge/edge.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/components/edge/edge.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAe,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACnH,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAInD,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AAEjG,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;;AActE,MAAM,OAAO,aAAa;IAZ1B;QAaY,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9B,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAC5C,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAE5D,6CAA6C;QACrC,yBAAoB,GAAG,MAAM,CAAC,6BAA6B,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAElF,UAAK,GAAG,KAAK,CAAC,QAAQ,EAAa,CAAC;QAEpC,iBAAY,GAAG,KAAK,EAA4B,CAAC;QAEjD,0BAAqB,GAAG,KAAK,EAAoB,CAAC;QAE/C,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC;YAC/C,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,KAAK,oBAAoB,IAAI,MAAM,CAAC,KAAK,KAAK,yBAAyB,CAAC;YAE3G,OAAO,cAAc,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;QACnE,CAAC,CAAC,CAAC;KAoBJ;IAlBQ,MAAM;QACX,IAAI,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,EAAE,CAAC;YAClD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;IAEM,IAAI;QACT,IAAI,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,EAAE,EAAE,CAAC;YACpD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IAES,iBAAiB,CAAC,KAAY,EAAE,MAAmB;QAC3D,sCAAsC;QACtC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,oBAAoB,EAAE,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IACrE,CAAC;+GAxCU,aAAa;mGAAb,aAAa,snBC1B1B,kmEAyDA,uQDjCY,gBAAgB,oJAAE,kBAAkB,kHAAE,gBAAgB;;4FAErD,aAAa;kBAZzB,SAAS;iCACI,IAAI,YACN,SAAS,mBAGF,uBAAuB,CAAC,MAAM,QACzC;wBACJ,KAAK,EAAE,YAAY;wBACnB,oBAAoB,EAAE,yCAAyC;qBAChE,WACQ,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, Injector, TemplateRef, computed, inject, input } from '@angular/core';\nimport { NgTemplateOutlet } from '@angular/common';\n\nimport { EdgeModel } from '../../models/edge.model';\nimport { EdgeContext } from '../../interfaces/template-context.interface';\nimport { SelectionService } from '../../services/selection.service';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { EdgeLabelComponent } from '../edge-label/edge-label.component';\nimport { ConnectionControllerDirective } from '../../directives/connection-controller.directive';\nimport { HandleModel } from '../../models/handle.model';\nimport { FlowStatusService } from '../../services/flow-status.service';\nimport { EdgeRenderingService } from '../../services/edge-rendering.service';\nimport { PointerDirective } from '../../directives/pointer.directive';\n\n@Component({\n  standalone: true,\n  selector: 'g[edge]',\n  templateUrl: './edge.component.html',\n  styleUrls: ['./edge.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'selectable',\n    '[style.visibility]': 'isReconnecting() ? \"hidden\" : \"visible\"',\n  },\n  imports: [NgTemplateOutlet, EdgeLabelComponent, PointerDirective],\n})\nexport class EdgeComponent {\n  protected injector = inject(Injector);\n  private selectionService = inject(SelectionService);\n  private flowSettingsService = inject(FlowSettingsService);\n  private flowStatusService = inject(FlowStatusService);\n  private edgeRenderingService = inject(EdgeRenderingService);\n\n  // TODO remove dependency from this directive\n  private connectionController = inject(ConnectionControllerDirective, { optional: true });\n\n  public model = input.required<EdgeModel>();\n\n  public edgeTemplate = input<TemplateRef<EdgeContext>>();\n\n  public edgeLabelHtmlTemplate = input<TemplateRef<any>>();\n\n  protected isReconnecting = computed(() => {\n    const status = this.flowStatusService.status();\n    const isReconnecting = status.state === 'reconnection-start' || status.state === 'reconnection-validation';\n\n    return isReconnecting && status.payload.oldEdge === this.model();\n  });\n\n  public select() {\n    if (this.flowSettingsService.entitiesSelectable()) {\n      this.selectionService.select(this.model());\n    }\n  }\n\n  public pull() {\n    if (this.flowSettingsService.elevateEdgesOnSelect()) {\n      this.edgeRenderingService.pull(this.model());\n    }\n  }\n\n  protected startReconnection(event: Event, handle: HandleModel) {\n    // ignore drag by stopping propagation\n    event.stopPropagation();\n\n    this.connectionController?.startReconnection(handle, this.model());\n  }\n}\n","@if (model().type === 'default') {\n  <svg:path\n    class=\"edge\"\n    [attr.d]=\"model().path().path\"\n    [attr.marker-start]=\"model().markerStartUrl()\"\n    [attr.marker-end]=\"model().markerEndUrl()\"\n    [class.edge_selected]=\"model().selected()\" />\n\n  <svg:path class=\"interactive-edge\" [attr.d]=\"model().path().path\" (pointerStart)=\"select(); pull()\" />\n}\n\n@if (model().type === 'template' && edgeTemplate()) {\n  @if (edgeTemplate(); as edgeTemplate) {\n    <ng-container\n      [ngTemplateOutlet]=\"edgeTemplate\"\n      [ngTemplateOutletContext]=\"model().context\"\n      [ngTemplateOutletInjector]=\"injector\" />\n  }\n}\n\n@if (model().edgeLabels.start; as label) {\n  @if (model().path().labelPoints?.start; as point) {\n    <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n  }\n}\n\n@if (model().edgeLabels.center; as label) {\n  @if (model().path().labelPoints?.center; as point) {\n    <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n  }\n}\n\n@if (model().edgeLabels.end; as label) {\n  @if (model().path().labelPoints?.end; as point) {\n    <svg:g edgeLabel [model]=\"label\" [point]=\"point\" [edgeModel]=\"model()\" [htmlTemplate]=\"edgeLabelHtmlTemplate()\" />\n  }\n}\n\n@if (model().sourceHandle() && model().targetHandle()) {\n  @if (model().reconnectable === true || model().reconnectable === 'source') {\n    <svg:circle\n      class=\"reconnect-handle\"\n      r=\"10\"\n      [attr.cx]=\"model().sourceHandle()!.pointAbsolute().x\"\n      [attr.cy]=\"model().sourceHandle()!.pointAbsolute().y\"\n      (pointerStart)=\"startReconnection($event, model().targetHandle()!)\" />\n  }\n\n  @if (model().reconnectable === true || model().reconnectable === 'target') {\n    <svg:circle\n      class=\"reconnect-handle\"\n      r=\"10\"\n      [attr.cx]=\"model().targetHandle()!.pointAbsolute().x\"\n      [attr.cy]=\"model().targetHandle()!.pointAbsolute().y\"\n      (pointerStart)=\"startReconnection($event, model().sourceHandle()!)\" />\n  }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, Injector, Input, computed, inject, runInInjectionContext, input, contentChild, viewChild, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Injector, Input, inject, runInInjectionContext, input, contentChild, viewChild, } from '@angular/core';
2
2
  import { MapContextDirective } from '../../directives/map-context.directive';
3
3
  import { DraggableService } from '../../services/draggable.service';
4
4
  import { ViewportService } from '../../services/viewport.service';
@@ -87,10 +87,14 @@ export class VflowComponent {
87
87
  this.optimization = input({
88
88
  detachedGroupsLayer: false,
89
89
  });
90
- this.nodeModels = computed(() => this.nodeRenderingService.nodes());
91
- this.groups = computed(() => this.nodeRenderingService.groups());
92
- this.nonGroups = computed(() => this.nodeRenderingService.nonGroups());
93
- this.edgeModels = computed(() => this.edgeRenderingService.edges());
90
+ this.nodeModels = this.nodeRenderingService.nodes;
91
+ this.nodesPerFrame = this.nodeRenderingService.nodesPerFrame;
92
+ this.groups = this.nodeRenderingService.groups;
93
+ this.groupsPerFrame = this.nodeRenderingService.groupsPerFrame;
94
+ this.nonGroups = this.nodeRenderingService.nonGroups;
95
+ this.nonGroupsPerFrame = this.nodeRenderingService.nonGroupsPerFrame;
96
+ this.edgeModels = this.edgeRenderingService.edges;
97
+ this.edgesPerFrame = this.edgeRenderingService.edgesPerFrame;
94
98
  // #endregion
95
99
  // #region OUTPUTS
96
100
  /**
@@ -351,7 +355,7 @@ export class VflowComponent {
351
355
  ComponentEventBusService,
352
356
  KeyboardService,
353
357
  OverlaysService,
354
- ], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "nodeSvgTemplateDirective", first: true, predicate: NodeSvgTemplateDirective, descendants: true, isSignal: true }, { propertyName: "groupNodeTemplateDirective", first: true, predicate: GroupNodeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeTemplateDirective", first: true, predicate: EdgeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeLabelHtmlDirective", first: true, predicate: EdgeLabelHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "connectionTemplateDirective", first: true, predicate: ConnectionTemplateDirective, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "mapContext", first: true, predicate: MapContextDirective, descendants: true, isSignal: true }, { propertyName: "spacePointContext", first: true, predicate: SpacePointContextDirective, descendants: true, isSignal: true }], hostDirectives: [{ directive: i1.ChangesControllerDirective, outputs: ["onNodesChange", "onNodesChange", "onNodesChange.position", "onNodesChange.position", "onNodesChange.position.single", "onNodesChange.position.single", "onNodesChange.position.many", "onNodesChange.position.many", "onNodesChange.size", "onNodesChange.size", "onNodesChange.size.single", "onNodesChange.size.single", "onNodesChange.size.many", "onNodesChange.size.many", "onNodesChange.add", "onNodesChange.add", "onNodesChange.add.single", "onNodesChange.add.single", "onNodesChange.add.many", "onNodesChange.add.many", "onNodesChange.remove", "onNodesChange.remove", "onNodesChange.remove.single", "onNodesChange.remove.single", "onNodesChange.remove.many", "onNodesChange.remove.many", "onNodesChange.select", "onNodesChange.select", "onNodesChange.select.single", "onNodesChange.select.single", "onNodesChange.select.many", "onNodesChange.select.many", "onEdgesChange", "onEdgesChange", "onEdgesChange.detached", "onEdgesChange.detached", "onEdgesChange.detached.single", "onEdgesChange.detached.single", "onEdgesChange.detached.many", "onEdgesChange.detached.many", "onEdgesChange.add", "onEdgesChange.add", "onEdgesChange.add.single", "onEdgesChange.add.single", "onEdgesChange.add.many", "onEdgesChange.add.many", "onEdgesChange.remove", "onEdgesChange.remove", "onEdgesChange.remove.single", "onEdgesChange.remove.single", "onEdgesChange.remove.many", "onEdgesChange.remove.many", "onEdgesChange.select", "onEdgesChange.select", "onEdgesChange.select.single", "onEdgesChange.select.single", "onEdgesChange.select.many", "onEdgesChange.select.many"] }], ngImport: i0, template: "<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n <svg:g\n *lazyFor=\"let model of groups(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nonGroups(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nodeModels(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: RootSvgReferenceDirective, selector: "svg[rootSvgRef]" }, { kind: "directive", type: RootSvgContextDirective, selector: "svg[rootSvgContext]" }, { kind: "directive", type: RootPointerDirective, selector: "svg[rootPointer]" }, { kind: "directive", type: FlowSizeControllerDirective, selector: "svg[flowSizeController]" }, { kind: "component", type: DefsComponent, selector: "defs[flowDefs]", inputs: ["markers"] }, { kind: "component", type: BackgroundComponent, selector: "g[background]" }, { kind: "directive", type: MapContextDirective, selector: "g[mapContext]" }, { kind: "directive", type: SpacePointContextDirective, selector: "g[spacePointContext]" }, { kind: "component", type: ConnectionComponent, selector: "g[connection]", inputs: ["model", "template"] }, { kind: "component", type: NodeComponent, selector: "g[node]", inputs: ["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: "directive", type: LazyForDirective, selector: "[lazyFor][lazyForOf]", inputs: ["lazyForOf", "lazyForTrackBy", "lazyForItemsPerFrame", "lazyForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
358
+ ], queries: [{ propertyName: "nodeTemplateDirective", first: true, predicate: NodeHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "nodeSvgTemplateDirective", first: true, predicate: NodeSvgTemplateDirective, descendants: true, isSignal: true }, { propertyName: "groupNodeTemplateDirective", first: true, predicate: GroupNodeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeTemplateDirective", first: true, predicate: EdgeTemplateDirective, descendants: true, isSignal: true }, { propertyName: "edgeLabelHtmlDirective", first: true, predicate: EdgeLabelHtmlTemplateDirective, descendants: true, isSignal: true }, { propertyName: "connectionTemplateDirective", first: true, predicate: ConnectionTemplateDirective, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "mapContext", first: true, predicate: MapContextDirective, descendants: true, isSignal: true }, { propertyName: "spacePointContext", first: true, predicate: SpacePointContextDirective, descendants: true, isSignal: true }], hostDirectives: [{ directive: i1.ChangesControllerDirective, outputs: ["onNodesChange", "onNodesChange", "onNodesChange.position", "onNodesChange.position", "onNodesChange.position.single", "onNodesChange.position.single", "onNodesChange.position.many", "onNodesChange.position.many", "onNodesChange.size", "onNodesChange.size", "onNodesChange.size.single", "onNodesChange.size.single", "onNodesChange.size.many", "onNodesChange.size.many", "onNodesChange.add", "onNodesChange.add", "onNodesChange.add.single", "onNodesChange.add.single", "onNodesChange.add.many", "onNodesChange.add.many", "onNodesChange.remove", "onNodesChange.remove", "onNodesChange.remove.single", "onNodesChange.remove.single", "onNodesChange.remove.many", "onNodesChange.remove.many", "onNodesChange.select", "onNodesChange.select", "onNodesChange.select.single", "onNodesChange.select.single", "onNodesChange.select.many", "onNodesChange.select.many", "onEdgesChange", "onEdgesChange", "onEdgesChange.detached", "onEdgesChange.detached", "onEdgesChange.detached.single", "onEdgesChange.detached.single", "onEdgesChange.detached.many", "onEdgesChange.detached.many", "onEdgesChange.add", "onEdgesChange.add", "onEdgesChange.add.single", "onEdgesChange.add.single", "onEdgesChange.add.many", "onEdgesChange.add.many", "onEdgesChange.remove", "onEdgesChange.remove", "onEdgesChange.remove.single", "onEdgesChange.remove.single", "onEdgesChange.remove.many", "onEdgesChange.remove.many", "onEdgesChange.select", "onEdgesChange.select", "onEdgesChange.select.single", "onEdgesChange.select.single", "onEdgesChange.select.many", "onEdgesChange.select.many"] }], ngImport: i0, template: "<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n <svg:g\n *lazyFor=\"let model of groups(); trackBy: trackNodes; itemsPerFrame: groupsPerFrame()\"\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nonGroups(); trackBy: trackNodes; itemsPerFrame: nonGroupsPerFrame()\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nodeModels(); trackBy: trackNodes; itemsPerFrame: nodesPerFrame()\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: RootSvgReferenceDirective, selector: "svg[rootSvgRef]" }, { kind: "directive", type: RootSvgContextDirective, selector: "svg[rootSvgContext]" }, { kind: "directive", type: RootPointerDirective, selector: "svg[rootPointer]" }, { kind: "directive", type: FlowSizeControllerDirective, selector: "svg[flowSizeController]" }, { kind: "component", type: DefsComponent, selector: "defs[flowDefs]", inputs: ["markers"] }, { kind: "component", type: BackgroundComponent, selector: "g[background]" }, { kind: "directive", type: MapContextDirective, selector: "g[mapContext]" }, { kind: "directive", type: SpacePointContextDirective, selector: "g[spacePointContext]" }, { kind: "component", type: ConnectionComponent, selector: "g[connection]", inputs: ["model", "template"] }, { kind: "component", type: NodeComponent, selector: "g[node]", inputs: ["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: "directive", type: LazyForDirective, selector: "[lazyFor][lazyForOf]", inputs: ["lazyForOf", "lazyForTrackBy", "lazyForItemsPerFrame", "lazyForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
355
359
  }
356
360
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: VflowComponent, decorators: [{
357
361
  type: Component,
@@ -383,7 +387,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
383
387
  EdgeComponent,
384
388
  NgTemplateOutlet,
385
389
  LazyForDirective,
386
- ], template: "<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n <svg:g\n *lazyFor=\"let model of groups(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nonGroups(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nodeModels(); trackBy: trackNodes\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"] }]
390
+ ], template: "<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n <defs flowDefs [markers]=\"markers()\" />\n\n <g background />\n\n <svg:g mapContext spacePointContext>\n <!-- Connection -->\n <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n @if (optimization().detachedGroupsLayer) {\n <!-- Groups -->\n <svg:g\n *lazyFor=\"let model of groups(); trackBy: trackNodes; itemsPerFrame: groupsPerFrame()\"\n node\n [model]=\"model\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nonGroups(); trackBy: trackNodes; itemsPerFrame: nonGroupsPerFrame()\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n\n @if (!optimization().detachedGroupsLayer) {\n <!-- Edges -->\n <svg:g\n *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n edge\n [model]=\"model\"\n [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n <!-- Nodes -->\n <svg:g\n *lazyFor=\"let model of nodeModels(); trackBy: trackNodes; itemsPerFrame: nodesPerFrame()\"\n node\n [model]=\"model\"\n [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n [attr.transform]=\"model.pointTransform()\" />\n }\n </svg:g>\n\n <!-- Minimap -->\n @if (minimap(); as minimap) {\n <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n }\n</svg:svg>\n", styles: [":host{display:block;width:100%;height:100%;-webkit-user-select:none;user-select:none}:host ::ng-deep *{box-sizing:border-box}\n"] }]
387
391
  }], propDecorators: { view: [{
388
392
  type: Input
389
393
  }], minZoom: [{
@@ -413,4 +417,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
413
417
  }], edges: [{
414
418
  type: Input
415
419
  }] } });
416
- //# 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  computed,\n  inject,\n  runInInjectionContext,\n  input,\n  contentChild,\n  viewChild,\n} from '@angular/core';\nimport { DynamicNode, Node } from '../../interfaces/node.interface';\nimport { MapContextDirective } from '../../directives/map-context.directive';\nimport { DraggableService } from '../../services/draggable.service';\nimport { NodeModel } from '../../models/node.model';\nimport { ViewportService } from '../../services/viewport.service';\nimport { toObservable, toSignal, 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 { LazyForDirective } from '../../directives/lazy-for.directive';\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  ],\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    LazyForDirective,\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\n  // #endregion\n\n  // #region SETTINGS\n\n  /**\n   * Size for flow view\n   *\n   * accepts\n   * - absolute size in format [width, height] or\n   * - 'auto' to compute size based on parent element size\n   */\n  @Input()\n  public set view(view: [number, number] | 'auto') {\n    this.flowSettingsService.view.set(view);\n  }\n\n  /**\n   * Minimum zoom value\n   */\n  @Input()\n  public set minZoom(value: number) {\n    this.flowSettingsService.minZoom.set(value);\n  }\n\n  /**\n   * Maximum zoom value\n   */\n  @Input()\n  public set maxZoom(value: number) {\n    this.flowSettingsService.maxZoom.set(value);\n  }\n\n  /**\n   * Background for flow\n   */\n  @Input()\n  public set background(value: Background | string) {\n    this.flowSettingsService.background.set(transformBackground(value));\n  }\n\n  public optimization = input<Optimization>({\n    detachedGroupsLayer: false,\n  });\n\n  /**\n   * Global rule if you can or can't select entities\n   */\n  @Input()\n  public set entitiesSelectable(value: boolean) {\n    this.flowSettingsService.entitiesSelectable.set(value);\n  }\n\n  @Input()\n  public set keyboardShortcuts(value: KeyboardShortcuts) {\n    this.keyboardService.setShortcuts(value);\n  }\n\n  /**\n   * Settings for connection (it renders when user tries to create edge between nodes)\n   *\n   * You need to pass `ConnectionSettings` in this input.\n   */\n  @Input({\n    transform: (settings: ConnectionSettings) => new ConnectionModel(settings),\n  })\n  public set connection(connection: ConnectionModel) {\n    this.flowEntitiesService.connection.set(connection);\n  }\n\n  public get connection() {\n    return this.flowEntitiesService.connection();\n  }\n\n  /**\n   * Snap grid for node movement. Passes as [x, y]\n   */\n  @Input()\n  public set snapGrid(value: [number, number]) {\n    this.flowSettingsService.snapGrid.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected node\n   */\n  @Input()\n  public set elevateNodesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateNodesOnSelect.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected edge\n   */\n  @Input()\n  public set elevateEdgesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateEdgesOnSelect.set(value);\n  }\n  // #endregion\n\n  // #region MAIN_INPUTS\n  /**\n   * Nodes to render\n   */\n  @Input({ required: true })\n  public set nodes(newNodes: Node[] | DynamicNode[]) {\n    const models = runInInjectionContext(this.injector, () =>\n      ReferenceIdentityChecker.nodes(newNodes, this.flowEntitiesService.nodes()),\n    );\n\n    // TODO: consider calling only fo new nodes\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(models, this.flowEntitiesService.edges());\n\n    this.flowEntitiesService.nodes.set(models);\n\n    models.forEach((model) => this.nodeRenderingService.pullNode(model));\n  }\n\n  protected nodeModels = computed(() => this.nodeRenderingService.nodes());\n  protected groups = computed(() => this.nodeRenderingService.groups());\n  protected nonGroups = computed(() => this.nodeRenderingService.nonGroups());\n\n  /**\n   * Edges to render\n   */\n  @Input()\n  public set edges(newEdges: Edge[]) {\n    const newModels = runInInjectionContext(this.injector, () =>\n      ReferenceIdentityChecker.edges(newEdges, this.flowEntitiesService.edges()),\n    );\n\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(this.nodeModels(), newModels);\n\n    this.flowEntitiesService.edges.set(newModels);\n  }\n\n  protected edgeModels = computed(() => this.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 = toSignal(this.nodesChangeService.changes$, {\n    initialValue: [] as NodeChange[],\n  });\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange = toSignal(this.edgesChangeService.changes$, {\n    initialValue: [] as EdgeChange[],\n  });\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(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  // #endregion\n\n  protected markers = this.flowEntitiesService.markers;\n\n  protected minimap = this.flowEntitiesService.minimap;\n\n  // #region METHODS_API\n  /**\n   * Change viewport to specified state\n   *\n   * @param viewport viewport state\n   */\n  public viewportTo(viewport: ViewportState): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: viewport,\n      duration: 0,\n    });\n  }\n\n  /**\n   * Change zoom\n   *\n   * @param zoom zoom value\n   */\n  public zoomTo(zoom: number): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: { zoom },\n      duration: 0,\n    });\n  }\n\n  /**\n   * Move to specified coordinate\n   *\n   * @param point point where to move\n   */\n  public panTo(point: Point): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: point,\n      duration: 0,\n    });\n  }\n\n  public fitView(options?: FitViewOptions) {\n    this.viewportService.fitView(options);\n  }\n\n  /**\n   * Get node by id\n   *\n   * @param id node id\n   */\n  public getNode<T = unknown>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.rawNode;\n  }\n\n  /**\n   * Sync method to get detached edges\n   */\n  public getDetachedEdges(): Edge[] {\n    return this.flowEntitiesService.getDetachedEdges().map((e) => e.edge);\n  }\n\n  /**\n   * Convert point received from document to point on the flow\n   */\n  public documentPointToFlowPoint(point: Point): Point;\n  public documentPointToFlowPoint(point: Point, options?: { spaces: false }): Point;\n  /**\n   * Convert point received from document to a stack of space points on the flow\n   * Space point has a spaceNodeId, coordinates are relative to this node\n   */\n  public documentPointToFlowPoint(point: Point, options?: { spaces: true }): SpacePoint[];\n  public documentPointToFlowPoint(point: Point, options?: { spaces: boolean }): unknown {\n    const transformedPoint = this.spacePointContext().documentPointToFlowPoint(point);\n\n    if (options?.spaces) {\n      return getSpacePoints(transformedPoint, this.nodeRenderingService.groups());\n    }\n\n    return transformedPoint;\n  }\n\n  /**\n   * Gets nodes that intersect with the specified node\n   *\n   * @template T - The type of data associated with the nodes\n   * @param nodeId - The ID of the node to check intersections for\n   * @param options.partially - If true, returns nodes that partially intersect. If false, only returns fully intersecting nodes\n   * @returns An array of nodes that intersect with the specified node\n   */\n  public getIntesectingNodes<T>(\n    nodeId: string,\n    options: IntersectingNodesOptions = { partially: true },\n  ): Node<T>[] | DynamicNode<T>[] {\n    return getIntesectingNodes(nodeId, this.nodeModels(), options).map((n) => n.rawNode) as\n      | Node<T>[]\n      | DynamicNode<T>[];\n  }\n\n  /**\n   * Converts a node's position to the coordinate space of another node\n   *\n   * @param nodeId - The ID of the node whose position should be converted\n   * @param spaceNodeId - The ID of the node that defines the target coordinate space.\n   *                      If null, returns the position in global coordinates\n   * @returns {Point} The converted position. Returns {x: Infinity, y: Infinity} if either node is not found\n   */\n  public toNodeSpace(nodeId: string, spaceNodeId: string | null): Point {\n    const node = this.nodeModels().find((n) => n.rawNode.id === nodeId);\n\n    if (!node) return { x: Infinity, y: Infinity };\n\n    if (spaceNodeId === null) {\n      return node.globalPoint();\n    }\n\n    const coordinateSpaceNode = this.nodeModels().find((n) => n.rawNode.id === spaceNodeId);\n\n    if (!coordinateSpaceNode) return { x: Infinity, y: Infinity };\n\n    return getSpacePoints(node.globalPoint(), [coordinateSpaceNode])[0];\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { rawNode: node }: NodeModel) {\n    return node;\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge;\n  }\n}\n","<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n  <defs flowDefs [markers]=\"markers()\" />\n\n  <g background />\n\n  <svg:g mapContext spacePointContext>\n    <!-- Connection -->\n    <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n    @if (optimization().detachedGroupsLayer) {\n      <!-- Groups -->\n      <svg:g\n        *lazyFor=\"let model of groups(); trackBy: trackNodes\"\n        node\n        [model]=\"model\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n\n      <!-- Edges  -->\n      <svg:g\n        *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n      <!-- Nodes -->\n      <svg:g\n        *lazyFor=\"let model of nonGroups(); trackBy: trackNodes\"\n        node\n        [model]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n        [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n    }\n\n    @if (!optimization().detachedGroupsLayer) {\n      <!-- Edges  -->\n      <svg:g\n        *lazyFor=\"let model of edgeModels(); trackBy: trackEdges\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n      <!-- Nodes -->\n      <svg:g\n        *lazyFor=\"let model of nodeModels(); trackBy: trackNodes\"\n        node\n        [model]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n        [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n    }\n  </svg:g>\n\n  <!-- Minimap -->\n  @if (minimap(); as minimap) {\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  }\n</svg:svg>\n"]}
420
+ //# 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  input,\n  contentChild,\n  viewChild,\n} from '@angular/core';\nimport { DynamicNode, Node } from '../../interfaces/node.interface';\nimport { MapContextDirective } from '../../directives/map-context.directive';\nimport { DraggableService } from '../../services/draggable.service';\nimport { NodeModel } from '../../models/node.model';\nimport { ViewportService } from '../../services/viewport.service';\nimport { toObservable, toSignal, 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 { LazyForDirective } from '../../directives/lazy-for.directive';\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  ],\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    LazyForDirective,\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\n  // #endregion\n\n  // #region SETTINGS\n\n  /**\n   * Size for flow view\n   *\n   * accepts\n   * - absolute size in format [width, height] or\n   * - 'auto' to compute size based on parent element size\n   */\n  @Input()\n  public set view(view: [number, number] | 'auto') {\n    this.flowSettingsService.view.set(view);\n  }\n\n  /**\n   * Minimum zoom value\n   */\n  @Input()\n  public set minZoom(value: number) {\n    this.flowSettingsService.minZoom.set(value);\n  }\n\n  /**\n   * Maximum zoom value\n   */\n  @Input()\n  public set maxZoom(value: number) {\n    this.flowSettingsService.maxZoom.set(value);\n  }\n\n  /**\n   * Background for flow\n   */\n  @Input()\n  public set background(value: Background | string) {\n    this.flowSettingsService.background.set(transformBackground(value));\n  }\n\n  public optimization = input<Optimization>({\n    detachedGroupsLayer: false,\n  });\n\n  /**\n   * Global rule if you can or can't select entities\n   */\n  @Input()\n  public set entitiesSelectable(value: boolean) {\n    this.flowSettingsService.entitiesSelectable.set(value);\n  }\n\n  @Input()\n  public set keyboardShortcuts(value: KeyboardShortcuts) {\n    this.keyboardService.setShortcuts(value);\n  }\n\n  /**\n   * Settings for connection (it renders when user tries to create edge between nodes)\n   *\n   * You need to pass `ConnectionSettings` in this input.\n   */\n  @Input({\n    transform: (settings: ConnectionSettings) => new ConnectionModel(settings),\n  })\n  public set connection(connection: ConnectionModel) {\n    this.flowEntitiesService.connection.set(connection);\n  }\n\n  public get connection() {\n    return this.flowEntitiesService.connection();\n  }\n\n  /**\n   * Snap grid for node movement. Passes as [x, y]\n   */\n  @Input()\n  public set snapGrid(value: [number, number]) {\n    this.flowSettingsService.snapGrid.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected node\n   */\n  @Input()\n  public set elevateNodesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateNodesOnSelect.set(value);\n  }\n\n  /**\n   * Raizing z-index for selected edge\n   */\n  @Input()\n  public set elevateEdgesOnSelect(value: boolean) {\n    this.flowSettingsService.elevateEdgesOnSelect.set(value);\n  }\n  // #endregion\n\n  // #region MAIN_INPUTS\n  /**\n   * Nodes to render\n   */\n  @Input({ required: true })\n  public set nodes(newNodes: Node[] | DynamicNode[]) {\n    const models = runInInjectionContext(this.injector, () =>\n      ReferenceIdentityChecker.nodes(newNodes, this.flowEntitiesService.nodes()),\n    );\n\n    // TODO: consider calling only fo new nodes\n    // quick and dirty binding nodes to edges\n    addNodesToEdges(models, this.flowEntitiesService.edges());\n\n    this.flowEntitiesService.nodes.set(models);\n\n    models.forEach((model) => this.nodeRenderingService.pullNode(model));\n  }\n\n  protected nodeModels = this.nodeRenderingService.nodes;\n  protected nodesPerFrame = this.nodeRenderingService.nodesPerFrame;\n\n  protected groups = this.nodeRenderingService.groups;\n  protected groupsPerFrame = this.nodeRenderingService.groupsPerFrame;\n\n  protected nonGroups = this.nodeRenderingService.nonGroups;\n  protected nonGroupsPerFrame = this.nodeRenderingService.nonGroupsPerFrame;\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.nodeModels(), newModels);\n\n    this.flowEntitiesService.edges.set(newModels);\n  }\n\n  protected edgeModels = this.edgeRenderingService.edges;\n  protected edgesPerFrame = this.edgeRenderingService.edgesPerFrame;\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 = toSignal(this.nodesChangeService.changes$, {\n    initialValue: [] as NodeChange[],\n  });\n\n  /**\n   * Signal to reading edges change\n   */\n  public readonly edgesChange = toSignal(this.edgesChangeService.changes$, {\n    initialValue: [] as EdgeChange[],\n  });\n  // #endregion\n\n  // #region RX_API\n  /**\n   * Observable with viewport change\n   */\n  public readonly viewportChange$ = toObservable(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  // #endregion\n\n  protected markers = this.flowEntitiesService.markers;\n\n  protected minimap = this.flowEntitiesService.minimap;\n\n  // #region METHODS_API\n  /**\n   * Change viewport to specified state\n   *\n   * @param viewport viewport state\n   */\n  public viewportTo(viewport: ViewportState): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: viewport,\n      duration: 0,\n    });\n  }\n\n  /**\n   * Change zoom\n   *\n   * @param zoom zoom value\n   */\n  public zoomTo(zoom: number): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: { zoom },\n      duration: 0,\n    });\n  }\n\n  /**\n   * Move to specified coordinate\n   *\n   * @param point point where to move\n   */\n  public panTo(point: Point): void {\n    this.viewportService.writableViewport.set({\n      changeType: 'absolute',\n      state: point,\n      duration: 0,\n    });\n  }\n\n  public fitView(options?: FitViewOptions) {\n    this.viewportService.fitView(options);\n  }\n\n  /**\n   * Get node by id\n   *\n   * @param id node id\n   */\n  public getNode<T = unknown>(id: string): Node<T> | DynamicNode<T> | undefined {\n    return this.flowEntitiesService.getNode<T>(id)?.rawNode;\n  }\n\n  /**\n   * Sync method to get detached edges\n   */\n  public getDetachedEdges(): Edge[] {\n    return this.flowEntitiesService.getDetachedEdges().map((e) => e.edge);\n  }\n\n  /**\n   * Convert point received from document to point on the flow\n   */\n  public documentPointToFlowPoint(point: Point): Point;\n  public documentPointToFlowPoint(point: Point, options?: { spaces: false }): Point;\n  /**\n   * Convert point received from document to a stack of space points on the flow\n   * Space point has a spaceNodeId, coordinates are relative to this node\n   */\n  public documentPointToFlowPoint(point: Point, options?: { spaces: true }): SpacePoint[];\n  public documentPointToFlowPoint(point: Point, options?: { spaces: boolean }): unknown {\n    const transformedPoint = this.spacePointContext().documentPointToFlowPoint(point);\n\n    if (options?.spaces) {\n      return getSpacePoints(transformedPoint, this.nodeRenderingService.groups());\n    }\n\n    return transformedPoint;\n  }\n\n  /**\n   * Gets nodes that intersect with the specified node\n   *\n   * @template T - The type of data associated with the nodes\n   * @param nodeId - The ID of the node to check intersections for\n   * @param options.partially - If true, returns nodes that partially intersect. If false, only returns fully intersecting nodes\n   * @returns An array of nodes that intersect with the specified node\n   */\n  public getIntesectingNodes<T>(\n    nodeId: string,\n    options: IntersectingNodesOptions = { partially: true },\n  ): Node<T>[] | DynamicNode<T>[] {\n    return getIntesectingNodes(nodeId, this.nodeModels(), options).map((n) => n.rawNode) as\n      | Node<T>[]\n      | DynamicNode<T>[];\n  }\n\n  /**\n   * Converts a node's position to the coordinate space of another node\n   *\n   * @param nodeId - The ID of the node whose position should be converted\n   * @param spaceNodeId - The ID of the node that defines the target coordinate space.\n   *                      If null, returns the position in global coordinates\n   * @returns {Point} The converted position. Returns {x: Infinity, y: Infinity} if either node is not found\n   */\n  public toNodeSpace(nodeId: string, spaceNodeId: string | null): Point {\n    const node = this.nodeModels().find((n) => n.rawNode.id === nodeId);\n\n    if (!node) return { x: Infinity, y: Infinity };\n\n    if (spaceNodeId === null) {\n      return node.globalPoint();\n    }\n\n    const coordinateSpaceNode = this.nodeModels().find((n) => n.rawNode.id === spaceNodeId);\n\n    if (!coordinateSpaceNode) return { x: Infinity, y: Infinity };\n\n    return getSpacePoints(node.globalPoint(), [coordinateSpaceNode])[0];\n  }\n  // #endregion\n\n  protected trackNodes(idx: number, { rawNode: node }: NodeModel) {\n    return node;\n  }\n\n  protected trackEdges(idx: number, { edge }: EdgeModel) {\n    return edge;\n  }\n}\n","<svg:svg #flow rootSvgRef rootSvgContext rootPointer flowSizeController class=\"root-svg\">\n  <defs flowDefs [markers]=\"markers()\" />\n\n  <g background />\n\n  <svg:g mapContext spacePointContext>\n    <!-- Connection -->\n    <svg:g connection [model]=\"connection\" [template]=\"connectionTemplateDirective()?.templateRef\" />\n\n    @if (optimization().detachedGroupsLayer) {\n      <!-- Groups -->\n      <svg:g\n        *lazyFor=\"let model of groups(); trackBy: trackNodes; itemsPerFrame: groupsPerFrame()\"\n        node\n        [model]=\"model\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n\n      <!-- Edges  -->\n      <svg:g\n        *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n      <!-- Nodes -->\n      <svg:g\n        *lazyFor=\"let model of nonGroups(); trackBy: trackNodes; itemsPerFrame: nonGroupsPerFrame()\"\n        node\n        [model]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n        [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n    }\n\n    @if (!optimization().detachedGroupsLayer) {\n      <!-- Edges  -->\n      <svg:g\n        *lazyFor=\"let model of edgeModels(); trackBy: trackEdges; itemsPerFrame: edgesPerFrame()\"\n        edge\n        [model]=\"model\"\n        [edgeTemplate]=\"edgeTemplateDirective()?.templateRef\"\n        [edgeLabelHtmlTemplate]=\"edgeLabelHtmlDirective()?.templateRef\" />\n\n      <!-- Nodes -->\n      <svg:g\n        *lazyFor=\"let model of nodeModels(); trackBy: trackNodes; itemsPerFrame: nodesPerFrame()\"\n        node\n        [model]=\"model\"\n        [nodeTemplate]=\"nodeTemplateDirective()?.templateRef\"\n        [nodeSvgTemplate]=\"nodeSvgTemplateDirective()?.templateRef\"\n        [groupNodeTemplate]=\"groupNodeTemplateDirective()?.templateRef\"\n        [attr.transform]=\"model.pointTransform()\" />\n    }\n  </svg:g>\n\n  <!-- Minimap -->\n  @if (minimap(); as minimap) {\n    <ng-container [ngTemplateOutlet]=\"minimap.template()\" />\n  }\n</svg:svg>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VydmUtZmFjdG9yeS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvaW50ZXJmYWNlcy9jdXJ2ZS1mYWN0b3J5LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IEVkZ2VMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi9lZGdlLWxhYmVsLmludGVyZmFjZSc7XG5pbXBvcnQgeyBFZGdlIH0gZnJvbSAnLi9lZGdlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBEeW5hbWljTm9kZSwgTm9kZSB9IGZyb20gJy4vbm9kZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUG9pbnQgfSBmcm9tICcuL3BvaW50LmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VydmVGYWN0b3J5U2hhcmVkUGFyYW1zIHtcbiAgLyoqIFN0YXJ0aW5nIHBvaW50IGNvb3JkaW5hdGVzIG9mIHRoZSBjdXJ2ZSAqL1xuICBzb3VyY2VQb2ludDogUG9pbnQ7XG4gIC8qKiBFbmRpbmcgcG9pbnQgY29vcmRpbmF0ZXMgb2YgdGhlIGN1cnZlICovXG4gIHRhcmdldFBvaW50OiBQb2ludDtcbiAgLyoqIFBvc2l0aW9uIG9mIHRoZSBzb3VyY2UgaGFuZGxlIHJlbGF0aXZlIHRvIHRoZSBzb3VyY2Ugbm9kZSAqL1xuICBzb3VyY2VQb3NpdGlvbjogUG9zaXRpb247XG4gIC8qKiBQb3NpdGlvbiBvZiB0aGUgdGFyZ2V0IGhhbmRsZSByZWxhdGl2ZSB0byB0aGUgdGFyZ2V0IG5vZGUgKi9cbiAgdGFyZ2V0UG9zaXRpb246IFBvc2l0aW9uO1xuICAvKiogQXJyYXkgb2YgYWxsIGVkZ2VzIGluIHRoZSBmbG93ICovXG4gIGFsbEVkZ2VzOiBFZGdlW107XG4gIC8qKiBBcnJheSBvZiBhbGwgbm9kZXMgaW4gdGhlIGZsb3cgKi9cbiAgYWxsTm9kZXM6IE5vZGVbXSB8IER5bmFtaWNOb2RlW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29ubmVjdGlvbkN1cnZlRmFjdG9yeVBhcmFtcyBleHRlbmRzIEN1cnZlRmFjdG9yeVNoYXJlZFBhcmFtcyB7XG4gIC8qKiBJbmRpY2F0ZXMgdGhpcyBpcyBhIHRlbXBvcmFyeSBjb25uZWN0aW9uIGJlaW5nIGRyYXduICovXG4gIG1vZGU6ICdjb25uZWN0aW9uJztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFZGdlQ3VydmVGYWN0b3J5UGFyYW1zIGV4dGVuZHMgQ3VydmVGYWN0b3J5U2hhcmVkUGFyYW1zIHtcbiAgLyoqIEluZGljYXRlcyB0aGlzIGlzIGEgcGVybWFuZW50IGVkZ2UgKi9cbiAgbW9kZTogJ2VkZ2UnO1xuICAvKiogVGhlIGVkZ2UgaW5zdGFuY2UgdGhpcyBjdXJ2ZSBiZWxvbmdzIHRvICovXG4gIGVkZ2U6IEVkZ2U7XG59XG5cbi8qKlxuICogTGF5b3V0IGluZm9ybWF0aW9uIGZvciBhIGN1cnZlXG4gKiAqL1xuZXhwb3J0IGludGVyZmFjZSBDdXJ2ZUxheW91dCB7XG4gIC8qKiBTVkcgcGF0aCBzdHJpbmcgZGVmaW5pbmcgdGhlIGN1cnZlXG4gICAqIChkIGF0dHJpYnV0ZSAtIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL1NWRy9SZWZlcmVuY2UvQXR0cmlidXRlL2QpXG4gICAqICovXG4gIHBhdGg6IHN0cmluZztcbiAgLyoqIE9wdGlvbmFsIHBvaW50cyBmb3IgbGFiZWwgcGxhY2VtZW50IGFsb25nIHRoZSBjdXJ2ZSAqL1xuICBsYWJlbFBvaW50cz86IHsgW2tleSBpbiBFZGdlTGFiZWxQb3NpdGlvbl06IFBvaW50IH07XG59XG5cbmV4cG9ydCB0eXBlIEN1cnZlRmFjdG9yeVBhcmFtcyA9IENvbm5lY3Rpb25DdXJ2ZUZhY3RvcnlQYXJhbXMgfCBFZGdlQ3VydmVGYWN0b3J5UGFyYW1zO1xuXG5leHBvcnQgdHlwZSBDdXJ2ZUZhY3RvcnkgPSAocGFyYW1zOiBDdXJ2ZUZhY3RvcnlQYXJhbXMpID0+IEN1cnZlTGF5b3V0O1xuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRnZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvaW50ZXJmYWNlcy9lZGdlLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29ubmVjdGlvbiB9IGZyb20gJy4vY29ubmVjdGlvbi5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRWRnZUxhYmVsLCBFZGdlTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4vZWRnZS1sYWJlbC5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgTWFya2VyIH0gZnJvbSAnLi9tYXJrZXIuaW50ZXJmYWNlJztcblxuZXhwb3J0IHR5cGUgRWRnZVR5cGUgPSAnZGVmYXVsdCcgfCAndGVtcGxhdGUnO1xuZXhwb3J0IHR5cGUgQ3VydmUgPSAnc3RyYWlnaHQnIHwgJ2JlemllcicgfCAnc21vb3RoLXN0ZXAnIHwgJ3N0ZXAnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEVkZ2U8VCA9IHVua25vd24+IGV4dGVuZHMgQ29ubmVjdGlvbiB7XG4gIGlkOiBzdHJpbmc7XG4gIHR5cGU/OiBFZGdlVHlwZTtcbiAgY3VydmU/OiBDdXJ2ZTtcbiAgZGF0YT86IFQ7XG4gIGVkZ2VMYWJlbHM/OiB7IFtwb3NpdGlvbiBpbiBFZGdlTGFiZWxQb3NpdGlvbl0/OiBFZGdlTGFiZWwgfTtcbiAgbWFya2Vycz86IHtcbiAgICBzdGFydD86IE1hcmtlcjtcbiAgICBlbmQ/OiBNYXJrZXI7XG4gIH07XG4gIHJlY29ubmVjdGFibGU/OiBib29sZWFuIHwgJ3NvdXJjZScgfCAndGFyZ2V0Jztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRnZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvaW50ZXJmYWNlcy9lZGdlLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29ubmVjdGlvbiB9IGZyb20gJy4vY29ubmVjdGlvbi5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQ3VydmVGYWN0b3J5IH0gZnJvbSAnLi9jdXJ2ZS1mYWN0b3J5LmludGVyZmFjZSc7XG5pbXBvcnQgeyBFZGdlTGFiZWwsIEVkZ2VMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi9lZGdlLWxhYmVsLmludGVyZmFjZSc7XG5pbXBvcnQgeyBNYXJrZXIgfSBmcm9tICcuL21hcmtlci5pbnRlcmZhY2UnO1xuXG5leHBvcnQgdHlwZSBFZGdlVHlwZSA9ICdkZWZhdWx0JyB8ICd0ZW1wbGF0ZSc7XG5leHBvcnQgdHlwZSBDdXJ2ZSA9ICdzdHJhaWdodCcgfCAnYmV6aWVyJyB8ICdzbW9vdGgtc3RlcCcgfCAnc3RlcCcgfCBDdXJ2ZUZhY3Rvcnk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWRnZTxUID0gdW5rbm93bj4gZXh0ZW5kcyBDb25uZWN0aW9uIHtcbiAgaWQ6IHN0cmluZztcbiAgdHlwZT86IEVkZ2VUeXBlO1xuICBjdXJ2ZT86IEN1cnZlO1xuICBkYXRhPzogVDtcbiAgZWRnZUxhYmVscz86IHsgW3Bvc2l0aW9uIGluIEVkZ2VMYWJlbFBvc2l0aW9uXT86IEVkZ2VMYWJlbCB9O1xuICBtYXJrZXJzPzoge1xuICAgIHN0YXJ0PzogTWFya2VyO1xuICAgIGVuZD86IE1hcmtlcjtcbiAgfTtcbiAgcmVjb25uZWN0YWJsZT86IGJvb2xlYW4gfCAnc291cmNlJyB8ICd0YXJnZXQnO1xufVxuIl19