ngx-vflow 0.15.0 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/README.md +8 -1
  2. package/esm2022/lib/vflow/components/background/background.component.mjs +75 -8
  3. package/esm2022/lib/vflow/components/connection/connection.component.mjs +67 -49
  4. package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +32 -25
  5. package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +9 -11
  6. package/esm2022/lib/vflow/components/defs/defs.component.mjs +9 -12
  7. package/esm2022/lib/vflow/components/edge/edge.component.mjs +21 -24
  8. package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +26 -31
  9. package/esm2022/lib/vflow/components/node/node.component.mjs +54 -50
  10. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +95 -90
  11. package/esm2022/lib/vflow/decorators/run-in-injection-context.decorator.mjs +1 -1
  12. package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +41 -125
  13. package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +16 -16
  14. package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +7 -6
  15. package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +7 -6
  16. package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +15 -12
  17. package/esm2022/lib/vflow/directives/map-context.directive.mjs +8 -5
  18. package/esm2022/lib/vflow/directives/pointer.directive.mjs +18 -19
  19. package/esm2022/lib/vflow/directives/reference.directive.mjs +6 -5
  20. package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +8 -5
  21. package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +8 -5
  22. package/esm2022/lib/vflow/directives/selectable.directive.mjs +10 -7
  23. package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +8 -5
  24. package/esm2022/lib/vflow/directives/template.directive.mjs +43 -25
  25. package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +1 -1
  26. package/esm2022/lib/vflow/interfaces/edge.interface.mjs +1 -1
  27. package/esm2022/lib/vflow/interfaces/node.interface.mjs +1 -1
  28. package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +1 -1
  29. package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +1 -1
  30. package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +170 -0
  31. package/esm2022/lib/vflow/models/connection.model.mjs +1 -1
  32. package/esm2022/lib/vflow/models/edge.model.mjs +6 -1
  33. package/esm2022/lib/vflow/models/handle.model.mjs +2 -2
  34. package/esm2022/lib/vflow/models/node.model.mjs +4 -10
  35. package/esm2022/lib/vflow/models/toolbar.model.mjs +1 -1
  36. package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +16 -10
  37. package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +15 -10
  38. package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +52 -0
  39. package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +42 -45
  40. package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +24 -27
  41. package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +60 -45
  42. package/esm2022/lib/vflow/services/component-event-bus.service.mjs +3 -3
  43. package/esm2022/lib/vflow/services/draggable.service.mjs +4 -4
  44. package/esm2022/lib/vflow/services/edge-changes.service.mjs +3 -3
  45. package/esm2022/lib/vflow/services/flow-entities.service.mjs +4 -4
  46. package/esm2022/lib/vflow/services/flow-settings.service.mjs +4 -10
  47. package/esm2022/lib/vflow/services/flow-status.service.mjs +4 -4
  48. package/esm2022/lib/vflow/services/handle.service.mjs +4 -4
  49. package/esm2022/lib/vflow/services/keyboard.service.mjs +5 -5
  50. package/esm2022/lib/vflow/services/node-accessor.service.mjs +3 -3
  51. package/esm2022/lib/vflow/services/node-changes.service.mjs +3 -3
  52. package/esm2022/lib/vflow/services/node-rendering.service.mjs +11 -4
  53. package/esm2022/lib/vflow/services/overlays.service.mjs +3 -3
  54. package/esm2022/lib/vflow/services/selection.service.mjs +4 -4
  55. package/esm2022/lib/vflow/services/viewport.service.mjs +3 -3
  56. package/esm2022/lib/vflow/types/background.type.mjs +1 -1
  57. package/esm2022/lib/vflow/utils/adjust-direction.mjs +1 -1
  58. package/esm2022/lib/vflow/utils/get-os.mjs +1 -1
  59. package/esm2022/lib/vflow/utils/is-group-node.mjs +4 -0
  60. package/esm2022/lib/vflow/utils/nodes.mjs +1 -1
  61. package/esm2022/lib/vflow/vflow.mjs +24 -0
  62. package/esm2022/public-api.mjs +4 -5
  63. package/fesm2022/ngx-vflow.mjs +1160 -1005
  64. package/fesm2022/ngx-vflow.mjs.map +1 -1
  65. package/lib/vflow/components/background/background.component.d.ts +14 -1
  66. package/lib/vflow/components/connection/connection.component.d.ts +3 -3
  67. package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +4 -9
  68. package/lib/vflow/components/default-node/default-node.component.d.ts +2 -2
  69. package/lib/vflow/components/defs/defs.component.d.ts +2 -2
  70. package/lib/vflow/components/edge/edge.component.d.ts +7 -7
  71. package/lib/vflow/components/edge-label/edge-label.component.d.ts +9 -8
  72. package/lib/vflow/components/node/node.component.d.ts +5 -6
  73. package/lib/vflow/components/vflow/vflow.component.d.ts +19 -27
  74. package/lib/vflow/directives/changes-controller.directive.d.ts +29 -30
  75. package/lib/vflow/directives/connection-controller.directive.d.ts +1 -2
  76. package/lib/vflow/directives/drag-handle.directive.d.ts +1 -1
  77. package/lib/vflow/directives/flow-size-controller.directive.d.ts +1 -1
  78. package/lib/vflow/directives/handle-size-controller.directive.d.ts +2 -2
  79. package/lib/vflow/directives/map-context.directive.d.ts +1 -1
  80. package/lib/vflow/directives/pointer.directive.d.ts +9 -6
  81. package/lib/vflow/directives/reference.directive.d.ts +1 -1
  82. package/lib/vflow/directives/root-pointer.directive.d.ts +1 -1
  83. package/lib/vflow/directives/root-svg-context.directive.d.ts +1 -1
  84. package/lib/vflow/directives/selectable.directive.d.ts +1 -1
  85. package/lib/vflow/directives/space-point-context.directive.d.ts +1 -1
  86. package/lib/vflow/directives/template.directive.d.ts +6 -6
  87. package/lib/vflow/interfaces/component-node-event.interface.d.ts +3 -3
  88. package/lib/vflow/interfaces/edge.interface.d.ts +1 -1
  89. package/lib/vflow/interfaces/node.interface.d.ts +14 -14
  90. package/lib/vflow/interfaces/optimization.interface.d.ts +7 -1
  91. package/lib/vflow/math/edge-path/smooth-step-path.d.ts +5 -0
  92. package/lib/vflow/models/edge.model.d.ts +1 -17
  93. package/lib/vflow/models/handle.model.d.ts +4 -4
  94. package/lib/vflow/models/node.model.d.ts +2 -5
  95. package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +3 -3
  96. package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +3 -3
  97. package/lib/vflow/{components → public-components}/handle/handle.component.d.ts +5 -5
  98. package/lib/vflow/public-components/minimap/minimap.component.d.ts +8 -10
  99. package/lib/vflow/public-components/node-toolbar/node-toolbar.component.d.ts +6 -5
  100. package/lib/vflow/public-components/resizable/resizable.component.d.ts +5 -4
  101. package/lib/vflow/services/flow-settings.service.d.ts +0 -7
  102. package/lib/vflow/services/node-rendering.service.d.ts +2 -0
  103. package/lib/vflow/types/background.type.d.ts +24 -1
  104. package/lib/vflow/utils/is-group-node.d.ts +2 -0
  105. package/lib/vflow/utils/reference-keeper.d.ts +1 -1
  106. package/lib/vflow/vflow.d.ts +9 -0
  107. package/package.json +3 -3
  108. package/public-api.d.ts +2 -3
  109. package/esm2022/lib/vflow/components/handle/handle.component.mjs +0 -49
  110. package/esm2022/lib/vflow/interfaces/handle-positions.interface.mjs +0 -2
  111. package/esm2022/lib/vflow/vflow.module.mjs +0 -121
  112. package/lib/vflow/interfaces/handle-positions.interface.d.ts +0 -5
  113. package/lib/vflow/vflow.module.d.ts +0 -30
@@ -1,7 +1,8 @@
1
- import { Directive, Output, inject } from '@angular/core';
1
+ import { Directive, inject } from '@angular/core';
2
2
  import { EdgeChangesService } from '../services/edge-changes.service';
3
3
  import { NodesChangeService } from '../services/node-changes.service';
4
4
  import { filter, map } from 'rxjs';
5
+ import { outputFromObservable } from '@angular/core/rxjs-interop';
5
6
  import * as i0 from "@angular/core";
6
7
  export class ChangesControllerDirective {
7
8
  constructor() {
@@ -10,144 +11,59 @@ export class ChangesControllerDirective {
10
11
  /**
11
12
  * Watch nodes change
12
13
  */
13
- this.onNodesChange = this.nodesChangeService.changes$;
14
- this.onNodesChangePosition = this.nodeChangesOfType('position');
15
- this.onNodesChangePositionSignle = this.singleChange(this.nodeChangesOfType('position'));
16
- this.onNodesChangePositionMany = this.manyChanges(this.nodeChangesOfType('position'));
17
- this.onNodesChangeSize = this.nodeChangesOfType('size');
18
- this.onNodesChangeSizeSingle = this.singleChange(this.nodeChangesOfType('size'));
19
- this.onNodesChangeSizeMany = this.manyChanges(this.nodeChangesOfType('size'));
20
- this.onNodesChangeAdd = this.nodeChangesOfType('add');
21
- this.onNodesChangeAddSingle = this.singleChange(this.nodeChangesOfType('add'));
22
- this.onNodesChangeAddMany = this.manyChanges(this.nodeChangesOfType('add'));
23
- this.onNodesChangeRemove = this.nodeChangesOfType('remove');
24
- this.onNodesChangeRemoveSingle = this.singleChange(this.nodeChangesOfType('remove'));
25
- this.onNodesChangeRemoveMany = this.manyChanges(this.nodeChangesOfType('remove'));
26
- this.onNodesChangeSelect = this.nodeChangesOfType('select');
27
- this.onNodesChangeSelectSingle = this.singleChange(this.nodeChangesOfType('select'));
28
- this.onNodesChangeSelectMany = this.manyChanges(this.nodeChangesOfType('select'));
14
+ this.onNodesChange = outputFromObservable(this.nodesChangeService.changes$);
15
+ this.onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), { alias: 'onNodesChange.position' });
16
+ this.onNodesChangePositionSignle = outputFromObservable(this.singleChange(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.single' });
17
+ this.onNodesChangePositionMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.many' });
18
+ this.onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), { alias: 'onNodesChange.size' });
19
+ this.onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), { alias: 'onNodesChange.size.single' });
20
+ this.onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), { alias: 'onNodesChange.size.many' });
21
+ this.onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), { alias: 'onNodesChange.add' });
22
+ this.onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), { alias: 'onNodesChange.add.single' });
23
+ this.onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), { alias: 'onNodesChange.add.many' });
24
+ this.onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), { alias: 'onNodesChange.remove' });
25
+ this.onNodesChangeRemoveSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('remove')), { alias: 'onNodesChange.remove.single' });
26
+ this.onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), { alias: 'onNodesChange.remove.many' });
27
+ this.onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), { alias: 'onNodesChange.select' });
28
+ this.onNodesChangeSelectSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('select')), { alias: 'onNodesChange.select.single' });
29
+ this.onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), { alias: 'onNodesChange.select.many' });
29
30
  /**
30
31
  * Watch edges change
31
32
  */
32
- this.onEdgesChange = this.edgesChangeService.changes$;
33
- this.onNodesChangeDetached = this.edgeChangesOfType('detached');
34
- this.onNodesChangeDetachedSingle = this.singleChange(this.edgeChangesOfType('detached'));
35
- this.onNodesChangeDetachedMany = this.manyChanges(this.edgeChangesOfType('detached'));
36
- this.onEdgesChangeAdd = this.edgeChangesOfType('add');
37
- this.onEdgeChangeAddSingle = this.singleChange(this.edgeChangesOfType('add'));
38
- this.onEdgeChangeAddMany = this.manyChanges(this.edgeChangesOfType('add'));
39
- this.onEdgeChangeRemove = this.edgeChangesOfType('remove');
40
- this.onEdgeChangeRemoveSingle = this.singleChange(this.edgeChangesOfType('remove'));
41
- this.onEdgeChangeRemoveMany = this.manyChanges(this.edgeChangesOfType('remove'));
42
- this.onEdgeChangeSelect = this.edgeChangesOfType('select');
43
- this.onEdgeChangeSelectSingle = this.singleChange(this.edgeChangesOfType('select'));
44
- this.onEdgeChangeSelectMany = this.manyChanges(this.edgeChangesOfType('select'));
33
+ this.onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);
34
+ this.onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), { alias: 'onEdgesChange.detached' });
35
+ this.onNodesChangeDetachedSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.single' });
36
+ this.onNodesChangeDetachedMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.many' });
37
+ this.onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), { alias: 'onEdgesChange.add' });
38
+ this.onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), { alias: 'onEdgesChange.add.single' });
39
+ this.onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), { alias: 'onEdgesChange.add.many' });
40
+ this.onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), { alias: 'onEdgesChange.remove' });
41
+ this.onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), { alias: 'onEdgesChange.remove.single' });
42
+ this.onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), { alias: 'onEdgesChange.remove.many' });
43
+ this.onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), { alias: 'onEdgesChange.select' });
44
+ this.onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), { alias: 'onEdgesChange.select.single' });
45
+ this.onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), { alias: 'onEdgesChange.select.many' });
45
46
  }
46
47
  nodeChangesOfType(type) {
47
- return this.nodesChangeService.changes$.pipe(map(changes => changes.filter((c) => c.type === type)), filter(changes => !!changes.length));
48
+ return this.nodesChangeService.changes$.pipe(map((changes) => changes.filter((c) => c.type === type)), filter((changes) => !!changes.length));
48
49
  }
49
50
  edgeChangesOfType(type) {
50
- return this.edgesChangeService.changes$.pipe(map(changes => changes.filter((c) => c.type === type)), filter(changes => !!changes.length));
51
+ return this.edgesChangeService.changes$.pipe(map((changes) => changes.filter((c) => c.type === type)), filter((changes) => !!changes.length));
51
52
  }
52
53
  singleChange(changes$) {
53
- return changes$.pipe(filter(changes => changes.length === 1), map(([first]) => first));
54
+ return changes$.pipe(filter((changes) => changes.length === 1), map(([first]) => first));
54
55
  }
55
56
  manyChanges(changes$) {
56
- return changes$.pipe(filter(changes => changes.length > 1));
57
+ return changes$.pipe(filter((changes) => changes.length > 1));
57
58
  }
58
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChangesControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
59
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ChangesControllerDirective, isStandalone: true, selector: "[changesController]", outputs: { onNodesChange: "onNodesChange", onNodesChangePosition: "onNodesChange.position", onNodesChangePositionSignle: "onNodesChange.position.single", onNodesChangePositionMany: "onNodesChange.position.many", onNodesChangeSize: "onNodesChange.size", onNodesChangeSizeSingle: "onNodesChange.size.single", onNodesChangeSizeMany: "onNodesChange.size.many", onNodesChangeAdd: "onNodesChange.add", onNodesChangeAddSingle: "onNodesChange.add.single", onNodesChangeAddMany: "onNodesChange.add.many", onNodesChangeRemove: "onNodesChange.remove", onNodesChangeRemoveSingle: "onNodesChange.remove.single", onNodesChangeRemoveMany: "onNodesChange.remove.many", onNodesChangeSelect: "onNodesChange.select", onNodesChangeSelectSingle: "onNodesChange.select.single", onNodesChangeSelectMany: "onNodesChange.select.many", onEdgesChange: "onEdgesChange", onNodesChangeDetached: "onEdgesChange.detached", onNodesChangeDetachedSingle: "onEdgesChange.detached.single", onNodesChangeDetachedMany: "onEdgesChange.detached.many", onEdgesChangeAdd: "onEdgesChange.add", onEdgeChangeAddSingle: "onEdgesChange.add.single", onEdgeChangeAddMany: "onEdgesChange.add.many", onEdgeChangeRemove: "onEdgesChange.remove", onEdgeChangeRemoveSingle: "onEdgesChange.remove.single", onEdgeChangeRemoveMany: "onEdgesChange.remove.many", onEdgeChangeSelect: "onEdgesChange.select", onEdgeChangeSelectSingle: "onEdgesChange.select.single", onEdgeChangeSelectMany: "onEdgesChange.select.many" }, ngImport: i0 }); }
59
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChangesControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
60
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ChangesControllerDirective, isStandalone: true, selector: "[changesController]", outputs: { onNodesChange: "onNodesChange", onNodesChangePosition: "onNodesChange.position", onNodesChangePositionSignle: "onNodesChange.position.single", onNodesChangePositionMany: "onNodesChange.position.many", onNodesChangeSize: "onNodesChange.size", onNodesChangeSizeSingle: "onNodesChange.size.single", onNodesChangeSizeMany: "onNodesChange.size.many", onNodesChangeAdd: "onNodesChange.add", onNodesChangeAddSingle: "onNodesChange.add.single", onNodesChangeAddMany: "onNodesChange.add.many", onNodesChangeRemove: "onNodesChange.remove", onNodesChangeRemoveSingle: "onNodesChange.remove.single", onNodesChangeRemoveMany: "onNodesChange.remove.many", onNodesChangeSelect: "onNodesChange.select", onNodesChangeSelectSingle: "onNodesChange.select.single", onNodesChangeSelectMany: "onNodesChange.select.many", onEdgesChange: "onEdgesChange", onNodesChangeDetached: "onEdgesChange.detached", onNodesChangeDetachedSingle: "onEdgesChange.detached.single", onNodesChangeDetachedMany: "onEdgesChange.detached.many", onEdgesChangeAdd: "onEdgesChange.add", onEdgeChangeAddSingle: "onEdgesChange.add.single", onEdgeChangeAddMany: "onEdgesChange.add.many", onEdgeChangeRemove: "onEdgesChange.remove", onEdgeChangeRemoveSingle: "onEdgesChange.remove.single", onEdgeChangeRemoveMany: "onEdgesChange.remove.many", onEdgeChangeSelect: "onEdgesChange.select", onEdgeChangeSelectSingle: "onEdgesChange.select.single", onEdgeChangeSelectMany: "onEdgesChange.select.many" }, ngImport: i0 }); }
60
61
  }
61
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChangesControllerDirective, decorators: [{
62
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChangesControllerDirective, decorators: [{
62
63
  type: Directive,
63
64
  args: [{
64
65
  selector: '[changesController]',
65
- standalone: true
66
+ standalone: true,
66
67
  }]
67
- }], propDecorators: { onNodesChange: [{
68
- type: Output
69
- }], onNodesChangePosition: [{
70
- type: Output,
71
- args: ['onNodesChange.position']
72
- }], onNodesChangePositionSignle: [{
73
- type: Output,
74
- args: ['onNodesChange.position.single']
75
- }], onNodesChangePositionMany: [{
76
- type: Output,
77
- args: ['onNodesChange.position.many']
78
- }], onNodesChangeSize: [{
79
- type: Output,
80
- args: ['onNodesChange.size']
81
- }], onNodesChangeSizeSingle: [{
82
- type: Output,
83
- args: ['onNodesChange.size.single']
84
- }], onNodesChangeSizeMany: [{
85
- type: Output,
86
- args: ['onNodesChange.size.many']
87
- }], onNodesChangeAdd: [{
88
- type: Output,
89
- args: ['onNodesChange.add']
90
- }], onNodesChangeAddSingle: [{
91
- type: Output,
92
- args: ['onNodesChange.add.single']
93
- }], onNodesChangeAddMany: [{
94
- type: Output,
95
- args: ['onNodesChange.add.many']
96
- }], onNodesChangeRemove: [{
97
- type: Output,
98
- args: ['onNodesChange.remove']
99
- }], onNodesChangeRemoveSingle: [{
100
- type: Output,
101
- args: ['onNodesChange.remove.single']
102
- }], onNodesChangeRemoveMany: [{
103
- type: Output,
104
- args: ['onNodesChange.remove.many']
105
- }], onNodesChangeSelect: [{
106
- type: Output,
107
- args: ['onNodesChange.select']
108
- }], onNodesChangeSelectSingle: [{
109
- type: Output,
110
- args: ['onNodesChange.select.single']
111
- }], onNodesChangeSelectMany: [{
112
- type: Output,
113
- args: ['onNodesChange.select.many']
114
- }], onEdgesChange: [{
115
- type: Output
116
- }], onNodesChangeDetached: [{
117
- type: Output,
118
- args: ['onEdgesChange.detached']
119
- }], onNodesChangeDetachedSingle: [{
120
- type: Output,
121
- args: ['onEdgesChange.detached.single']
122
- }], onNodesChangeDetachedMany: [{
123
- type: Output,
124
- args: ['onEdgesChange.detached.many']
125
- }], onEdgesChangeAdd: [{
126
- type: Output,
127
- args: ['onEdgesChange.add']
128
- }], onEdgeChangeAddSingle: [{
129
- type: Output,
130
- args: ['onEdgesChange.add.single']
131
- }], onEdgeChangeAddMany: [{
132
- type: Output,
133
- args: ['onEdgesChange.add.many']
134
- }], onEdgeChangeRemove: [{
135
- type: Output,
136
- args: ['onEdgesChange.remove']
137
- }], onEdgeChangeRemoveSingle: [{
138
- type: Output,
139
- args: ['onEdgesChange.remove.single']
140
- }], onEdgeChangeRemoveMany: [{
141
- type: Output,
142
- args: ['onEdgesChange.remove.many']
143
- }], onEdgeChangeSelect: [{
144
- type: Output,
145
- args: ['onEdgesChange.select']
146
- }], onEdgeChangeSelectSingle: [{
147
- type: Output,
148
- args: ['onEdgesChange.select.single']
149
- }], onEdgeChangeSelectMany: [{
150
- type: Output,
151
- args: ['onEdgesChange.select.many']
152
- }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"changes-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/changes-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Output, inject } from '@angular/core';\nimport { NodeAddChange, NodeChange, NodePositionChange, NodeRemoveChange, NodeSelectedChange, NodeSizeChange } from '../types/node-change.type';\nimport { EdgeChangesService } from '../services/edge-changes.service';\nimport { NodesChangeService } from '../services/node-changes.service';\nimport { Observable, filter, map } from 'rxjs';\nimport { EdgeAddChange, EdgeChange, EdgeDetachedChange, EdgeRemoveChange, EdgeSelectChange } from '../types/edge-change.type';\n\n@Directive({\n  selector: '[changesController]',\n  standalone: true\n})\nexport class ChangesControllerDirective {\n  protected nodesChangeService = inject(NodesChangeService)\n  protected edgesChangeService = inject(EdgeChangesService)\n\n  /**\n   * Watch nodes change\n   */\n  @Output()\n  public onNodesChange = this.nodesChangeService.changes$\n\n  @Output('onNodesChange.position')\n  public onNodesChangePosition = this.nodeChangesOfType('position')\n\n  @Output('onNodesChange.position.single')\n  public onNodesChangePositionSignle = this.singleChange(\n    this.nodeChangesOfType('position')\n  )\n\n  @Output('onNodesChange.position.many')\n  public onNodesChangePositionMany = this.manyChanges(\n    this.nodeChangesOfType('position')\n  )\n\n  @Output('onNodesChange.size')\n  public onNodesChangeSize = this.nodeChangesOfType('size')\n\n  @Output('onNodesChange.size.single')\n  public onNodesChangeSizeSingle = this.singleChange(\n    this.nodeChangesOfType('size')\n  )\n\n  @Output('onNodesChange.size.many')\n  public onNodesChangeSizeMany = this.manyChanges(\n    this.nodeChangesOfType('size')\n  )\n\n  @Output('onNodesChange.add')\n  public onNodesChangeAdd = this.nodeChangesOfType('add')\n\n  @Output('onNodesChange.add.single')\n  public onNodesChangeAddSingle = this.singleChange(\n    this.nodeChangesOfType('add')\n  )\n\n  @Output('onNodesChange.add.many')\n  public onNodesChangeAddMany = this.manyChanges(\n    this.nodeChangesOfType('add')\n  )\n\n  @Output('onNodesChange.remove')\n  public onNodesChangeRemove = this.nodeChangesOfType('remove')\n\n  @Output('onNodesChange.remove.single')\n  public onNodesChangeRemoveSingle = this.singleChange(\n    this.nodeChangesOfType('remove')\n  )\n\n  @Output('onNodesChange.remove.many')\n  public onNodesChangeRemoveMany = this.manyChanges(\n    this.nodeChangesOfType('remove')\n  )\n\n  @Output('onNodesChange.select')\n  public onNodesChangeSelect = this.nodeChangesOfType('select')\n\n  @Output('onNodesChange.select.single')\n  public onNodesChangeSelectSingle = this.singleChange(\n    this.nodeChangesOfType('select')\n  )\n\n  @Output('onNodesChange.select.many')\n  public onNodesChangeSelectMany = this.manyChanges(\n    this.nodeChangesOfType('select')\n  )\n\n  /**\n   * Watch edges change\n   */\n  @Output()\n  public onEdgesChange = this.edgesChangeService.changes$\n\n  @Output('onEdgesChange.detached')\n  public onNodesChangeDetached = this.edgeChangesOfType('detached')\n\n  @Output('onEdgesChange.detached.single')\n  public onNodesChangeDetachedSingle = this.singleChange(\n    this.edgeChangesOfType('detached')\n  )\n\n  @Output('onEdgesChange.detached.many')\n  public onNodesChangeDetachedMany = this.manyChanges(\n    this.edgeChangesOfType('detached')\n  )\n\n  @Output('onEdgesChange.add')\n  public onEdgesChangeAdd = this.edgeChangesOfType('add')\n\n  @Output('onEdgesChange.add.single')\n  public onEdgeChangeAddSingle = this.singleChange(\n    this.edgeChangesOfType('add')\n  )\n\n  @Output('onEdgesChange.add.many')\n  public onEdgeChangeAddMany = this.manyChanges(\n    this.edgeChangesOfType('add')\n  )\n\n  @Output('onEdgesChange.remove')\n  public onEdgeChangeRemove = this.edgeChangesOfType('remove')\n\n  @Output('onEdgesChange.remove.single')\n  public onEdgeChangeRemoveSingle = this.singleChange(\n    this.edgeChangesOfType('remove')\n  )\n\n  @Output('onEdgesChange.remove.many')\n  public onEdgeChangeRemoveMany = this.manyChanges(\n    this.edgeChangesOfType('remove')\n  )\n\n  @Output('onEdgesChange.select')\n  public onEdgeChangeSelect = this.edgeChangesOfType('select')\n\n  @Output('onEdgesChange.select.single')\n  public onEdgeChangeSelectSingle = this.singleChange(\n    this.edgeChangesOfType('select')\n  )\n\n  @Output('onEdgesChange.select.many')\n  public onEdgeChangeSelectMany = this.manyChanges(\n    this.edgeChangesOfType('select')\n  )\n\n  private nodeChangesOfType<T extends NodeChange['type']>(type: T) {\n    return this.nodesChangeService.changes$.pipe(\n      map(changes => changes.filter((c): c is NodeChangeMap[T] => c.type === type)),\n      filter(changes => !!changes.length)\n    )\n  }\n\n  private edgeChangesOfType<T extends EdgeChange['type']>(type: T) {\n    return this.edgesChangeService.changes$.pipe(\n      map(changes => changes.filter((c): c is EdgeChangeMap[T] => c.type === type)),\n      filter(changes => !!changes.length)\n    )\n  }\n\n  private singleChange<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter(changes => changes.length === 1),\n      map(([first]) => first)\n    )\n  }\n\n  private manyChanges<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter(changes => changes.length > 1),\n    )\n  }\n}\n\n// TODO: do not write this types manually\ntype NodeChangeMap = {\n  position: NodePositionChange,\n  size: NodeSizeChange,\n  add: NodeAddChange,\n  remove: NodeRemoveChange,\n  select: NodeSelectedChange\n}\n\ntype EdgeChangeMap = {\n  detached: EdgeDetachedChange,\n  add: EdgeAddChange,\n  remove: EdgeRemoveChange,\n  select: EdgeSelectChange\n}\n"]}
68
+ }] });
69
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"changes-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/changes-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, inject, output } from '@angular/core';\nimport {\n  NodeAddChange,\n  NodeChange,\n  NodePositionChange,\n  NodeRemoveChange,\n  NodeSelectedChange,\n  NodeSizeChange,\n} from '../types/node-change.type';\nimport { EdgeChangesService } from '../services/edge-changes.service';\nimport { NodesChangeService } from '../services/node-changes.service';\nimport { Observable, filter, map } from 'rxjs';\nimport {\n  EdgeAddChange,\n  EdgeChange,\n  EdgeDetachedChange,\n  EdgeRemoveChange,\n  EdgeSelectChange,\n} from '../types/edge-change.type';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\n\n@Directive({\n  selector: '[changesController]',\n  standalone: true,\n})\nexport class ChangesControllerDirective {\n  protected nodesChangeService = inject(NodesChangeService);\n  protected edgesChangeService = inject(EdgeChangesService);\n\n  /**\n   * Watch nodes change\n   */\n  public onNodesChange = outputFromObservable(this.nodesChangeService.changes$);\n\n  public onNodesChangePosition = outputFromObservable(\n    this.nodeChangesOfType('position'),\n    { alias: 'onNodesChange.position' },\n  );\n\n  public onNodesChangePositionSignle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.single' },\n  );\n\n  public onNodesChangePositionMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.many' },\n  );\n\n  public onNodesChangeSize = outputFromObservable(\n    this.nodeChangesOfType('size'),\n    { alias: 'onNodesChange.size' },\n  );\n\n  public onNodesChangeSizeSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('size')),\n    { alias: 'onNodesChange.size.single' },\n  );\n\n  public onNodesChangeSizeMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('size')),\n    { alias: 'onNodesChange.size.many' },\n  );\n\n  public onNodesChangeAdd = outputFromObservable(\n    this.nodeChangesOfType('add'),\n    { alias: 'onNodesChange.add' },\n  );\n\n  public onNodesChangeAddSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('add')),\n    { alias: 'onNodesChange.add.single' },\n  );\n\n  public onNodesChangeAddMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('add')),\n    { alias: 'onNodesChange.add.many' },\n  );\n\n  public onNodesChangeRemove = outputFromObservable(\n    this.nodeChangesOfType('remove'),\n    { alias: 'onNodesChange.remove' },\n  );\n\n  public onNodesChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.single' },\n  );\n\n  public onNodesChangeRemoveMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.many' },\n  );\n\n  public onNodesChangeSelect = outputFromObservable(\n    this.nodeChangesOfType('select'),\n    { alias: 'onNodesChange.select' },\n  );\n\n  public onNodesChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.single' },\n  );\n\n  public onNodesChangeSelectMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.many' },\n  );\n\n  /**\n   * Watch edges change\n   */\n  public onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);\n\n  public onNodesChangeDetached = outputFromObservable(\n    this.edgeChangesOfType('detached'),\n    { alias: 'onEdgesChange.detached' },\n  );\n\n  public onNodesChangeDetachedSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.single' },\n  );\n\n  public onNodesChangeDetachedMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.many' },\n  );\n\n  public onEdgesChangeAdd = outputFromObservable(\n    this.edgeChangesOfType('add'),\n    { alias: 'onEdgesChange.add' },\n  );\n\n  public onEdgeChangeAddSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('add')),\n    { alias: 'onEdgesChange.add.single' },\n  );\n\n  public onEdgeChangeAddMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('add')),\n    { alias: 'onEdgesChange.add.many' },\n  );\n\n  public onEdgeChangeRemove = outputFromObservable(\n    this.edgeChangesOfType('remove'),\n    { alias: 'onEdgesChange.remove' },\n  );\n\n  public onEdgeChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('remove')),\n    { alias: 'onEdgesChange.remove.single' },\n  );\n\n  public onEdgeChangeRemoveMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('remove')),\n    { alias: 'onEdgesChange.remove.many' },\n  );\n\n  public onEdgeChangeSelect = outputFromObservable(\n    this.edgeChangesOfType('select'),\n    { alias: 'onEdgesChange.select' },\n  );\n\n  public onEdgeChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('select')),\n    { alias: 'onEdgesChange.select.single' },\n  );\n\n  public onEdgeChangeSelectMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('select')),\n    { alias: 'onEdgesChange.select.many' },\n  );\n\n  private nodeChangesOfType<T extends NodeChange['type']>(type: T) {\n    return this.nodesChangeService.changes$.pipe(\n      map((changes) =>\n        changes.filter((c): c is NodeChangeMap[T] => c.type === type),\n      ),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private edgeChangesOfType<T extends EdgeChange['type']>(type: T) {\n    return this.edgesChangeService.changes$.pipe(\n      map((changes) =>\n        changes.filter((c): c is EdgeChangeMap[T] => c.type === type),\n      ),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private singleChange<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter((changes) => changes.length === 1),\n      map(([first]) => first),\n    );\n  }\n\n  private manyChanges<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(filter((changes) => changes.length > 1));\n  }\n}\n\n// TODO: do not write this types manually\ntype NodeChangeMap = {\n  position: NodePositionChange;\n  size: NodeSizeChange;\n  add: NodeAddChange;\n  remove: NodeRemoveChange;\n  select: NodeSelectedChange;\n};\n\ntype EdgeChangeMap = {\n  detached: EdgeDetachedChange;\n  add: EdgeAddChange;\n  remove: EdgeRemoveChange;\n  select: EdgeSelectChange;\n};\n"]}
@@ -1,5 +1,5 @@
1
- import { Directive, EventEmitter, Output, computed, effect, inject } from '@angular/core';
2
- import { FlowStatusService, batchStatusChanges } from '../services/flow-status.service';
1
+ import { Directive, computed, effect, inject, output } from '@angular/core';
2
+ import { FlowStatusService, batchStatusChanges, } from '../services/flow-status.service';
3
3
  import { FlowEntitiesService } from '../services/flow-entities.service';
4
4
  import { adjustDirection } from '../utils/adjust-direction';
5
5
  import * as i0 from "@angular/core";
@@ -13,7 +13,7 @@ export class ConnectionControllerDirective {
13
13
  * Also it's important to note, that this event only fires when connection is valid by validator function in `ConnectionSettings`,
14
14
  * by default without passing the validator every connection concidered valid.
15
15
  */
16
- this.onConnect = new EventEmitter();
16
+ this.onConnect = output();
17
17
  this.statusService = inject(FlowStatusService);
18
18
  this.flowEntitiesService = inject(FlowEntitiesService);
19
19
  this.connectEffect = effect(() => {
@@ -28,7 +28,7 @@ export class ConnectionControllerDirective {
28
28
  source: status.payload.source,
29
29
  sourceHandle: status.payload.sourceHandle,
30
30
  target: status.payload.target,
31
- targetHandle: status.payload.targetHandle
31
+ targetHandle: status.payload.targetHandle,
32
32
  });
33
33
  source = adjusted.source;
34
34
  target = adjusted.target;
@@ -41,8 +41,10 @@ export class ConnectionControllerDirective {
41
41
  const targetHandleId = targetHandle.rawHandle.id;
42
42
  const connectionModel = this.flowEntitiesService.connection();
43
43
  const connection = {
44
- source: sourceId, target: targetId,
45
- sourceHandle: sourceHandleId, targetHandle: targetHandleId
44
+ source: sourceId,
45
+ target: targetId,
46
+ sourceHandle: sourceHandleId,
47
+ targetHandle: targetHandleId,
46
48
  };
47
49
  if (connectionModel.validator(connection)) {
48
50
  this.onConnect.emit(connection);
@@ -67,7 +69,7 @@ export class ConnectionControllerDirective {
67
69
  source: status.payload.source,
68
70
  sourceHandle: status.payload.sourceHandle,
69
71
  target: handle.parentNode,
70
- targetHandle: handle
72
+ targetHandle: handle,
71
73
  });
72
74
  source = adjusted.source;
73
75
  target = adjusted.target;
@@ -78,7 +80,7 @@ export class ConnectionControllerDirective {
78
80
  source: source.node.id,
79
81
  target: target.node.id,
80
82
  sourceHandle: sourceHandle.rawHandle.id,
81
- targetHandle: targetHandle.rawHandle.id
83
+ targetHandle: targetHandle.rawHandle.id,
82
84
  });
83
85
  // TODO: check how react flow handles highlight of handle
84
86
  // if direction changes
@@ -110,16 +112,14 @@ export class ConnectionControllerDirective {
110
112
  () => this.statusService.setIdleStatus());
111
113
  }
112
114
  }
113
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectionControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
114
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: ConnectionControllerDirective, isStandalone: true, selector: "[connectionController]", outputs: { onConnect: "onConnect" }, ngImport: i0 }); }
115
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
116
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ConnectionControllerDirective, isStandalone: true, selector: "[connectionController]", outputs: { onConnect: "onConnect" }, ngImport: i0 }); }
115
117
  }
116
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectionControllerDirective, decorators: [{
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ConnectionControllerDirective, decorators: [{
117
119
  type: Directive,
118
120
  args: [{
119
121
  selector: '[connectionController]',
120
- standalone: true
122
+ standalone: true,
121
123
  }]
122
- }], propDecorators: { onConnect: [{
123
- type: Output
124
- }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/connection-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Output, computed, effect, inject } from '@angular/core';\nimport { Connection } from '../interfaces/connection.interface';\nimport { FlowStatusService, batchStatusChanges } from '../services/flow-status.service';\n\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { HandleModel } from '../models/handle.model';\nimport { adjustDirection } from '../utils/adjust-direction';\n\n@Directive({\n  selector: '[connectionController]',\n  standalone: true\n})\nexport class ConnectionControllerDirective {\n  /**\n   * This event fires when user tries to create new Edge.\n   *\n   * `Connection` is an entity that contains data about source and target nodes.\n   *\n   * Also it's important to note, that this event only fires when connection is valid by validator function in `ConnectionSettings`,\n   * by default without passing the validator every connection concidered valid.\n   */\n  @Output()\n  public onConnect = new EventEmitter<Connection>()\n\n  private statusService = inject(FlowStatusService)\n  private flowEntitiesService = inject(FlowEntitiesService)\n\n  protected connectEffect = effect(() => {\n    const status = this.statusService.status()\n\n    if (status.state === 'connection-end') {\n      let source = status.payload.source\n      let target = status.payload.target\n      let sourceHandle = status.payload.sourceHandle\n      let targetHandle = status.payload.targetHandle\n\n      if (this.isStrictMode()) {\n        const adjusted = adjustDirection({\n          source: status.payload.source,\n          sourceHandle: status.payload.sourceHandle,\n          target: status.payload.target,\n          targetHandle: status.payload.targetHandle\n        })\n\n        source = adjusted.source\n        target = adjusted.target\n        sourceHandle = adjusted.sourceHandle\n        targetHandle = adjusted.targetHandle\n      }\n\n      const sourceId = source.node.id\n      const targetId = target.node.id\n\n      const sourceHandleId = sourceHandle.rawHandle.id\n      const targetHandleId = targetHandle.rawHandle.id\n\n      const connectionModel = this.flowEntitiesService.connection()\n      const connection = {\n        source: sourceId, target: targetId,\n        sourceHandle: sourceHandleId, targetHandle: targetHandleId\n      }\n\n      if (connectionModel.validator(connection)) {\n        this.onConnect.emit(connection)\n      }\n    }\n  }, { allowSignalWrites: true })\n\n  protected isStrictMode = computed(() =>\n    this.flowEntitiesService.connection().mode === 'strict'\n  )\n\n  public startConnection(handle: HandleModel) {\n    this.statusService.setConnectionStartStatus(handle.parentNode, handle)\n  }\n\n  public validateConnection(handle: HandleModel) {\n    const status = this.statusService.status()\n\n    if (status.state === 'connection-start') {\n      let source = status.payload.source\n      let target = handle.parentNode\n      let sourceHandle = status.payload.sourceHandle\n      let targetHandle = handle\n\n      if (this.isStrictMode()) {\n        // swap direction (if needed) according to actual source and target of strict mode\n        const adjusted = adjustDirection({\n          source: status.payload.source,\n          sourceHandle: status.payload.sourceHandle,\n          target: handle.parentNode,\n          targetHandle: handle\n        })\n\n        source = adjusted.source\n        target = adjusted.target\n        sourceHandle = adjusted.sourceHandle\n        targetHandle = adjusted.targetHandle\n      }\n\n      const valid = this.flowEntitiesService.connection().validator({\n        source: source.node.id,\n        target: target.node.id,\n        sourceHandle: sourceHandle.rawHandle.id,\n        targetHandle: targetHandle.rawHandle.id\n      })\n\n      // TODO: check how react flow handles highlight of handle\n      // if direction changes\n      handle.state.set(valid ? 'valid' : 'invalid')\n\n      // status is about how we draw connection, so we don't need\n      // swapped diretion here\n      this.statusService.setConnectionValidationStatus(\n        valid,\n        status.payload.source, handle.parentNode,\n        status.payload.sourceHandle, handle\n      )\n    }\n  }\n\n  public resetValidateConnection(targetHandle: HandleModel) {\n    targetHandle.state.set('idle')\n\n    // drop back to start status\n    const status = this.statusService.status()\n    if (status.state === 'connection-validation') {\n      this.statusService.setConnectionStartStatus(\n        status.payload.source,\n        status.payload.sourceHandle\n      )\n    }\n  }\n\n  public endConnection(handle: HandleModel) {\n    const status = this.statusService.status()\n\n    if (status.state === 'connection-validation') {\n      const source = status.payload.source\n      const sourceHandle = status.payload.sourceHandle\n      const target = status.payload.target\n      const targetHandle = status.payload.targetHandle\n\n      batchStatusChanges(\n        // call to create connection\n        () => this.statusService.setConnectionEndStatus(source!, target!, sourceHandle!, targetHandle!),\n        // when connection created, we need go back to idle status\n        () => this.statusService.setIdleStatus()\n      )\n    }\n  }\n}\n"]}
124
+ }] });
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/connection-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, computed, effect, inject, output } from '@angular/core';\nimport { Connection } from '../interfaces/connection.interface';\nimport {\n  FlowStatusService,\n  batchStatusChanges,\n} from '../services/flow-status.service';\n\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { HandleModel } from '../models/handle.model';\nimport { adjustDirection } from '../utils/adjust-direction';\n\n@Directive({\n  selector: '[connectionController]',\n  standalone: true,\n})\nexport class ConnectionControllerDirective {\n  /**\n   * This event fires when user tries to create new Edge.\n   *\n   * `Connection` is an entity that contains data about source and target nodes.\n   *\n   * Also it's important to note, that this event only fires when connection is valid by validator function in `ConnectionSettings`,\n   * by default without passing the validator every connection concidered valid.\n   */\n  public onConnect = output<Connection>();\n\n  private statusService = inject(FlowStatusService);\n  private flowEntitiesService = inject(FlowEntitiesService);\n\n  protected connectEffect = effect(\n    () => {\n      const status = this.statusService.status();\n\n      if (status.state === 'connection-end') {\n        let source = status.payload.source;\n        let target = status.payload.target;\n        let sourceHandle = status.payload.sourceHandle;\n        let targetHandle = status.payload.targetHandle;\n\n        if (this.isStrictMode()) {\n          const adjusted = adjustDirection({\n            source: status.payload.source,\n            sourceHandle: status.payload.sourceHandle,\n            target: status.payload.target,\n            targetHandle: status.payload.targetHandle,\n          });\n\n          source = adjusted.source;\n          target = adjusted.target;\n          sourceHandle = adjusted.sourceHandle;\n          targetHandle = adjusted.targetHandle;\n        }\n\n        const sourceId = source.node.id;\n        const targetId = target.node.id;\n\n        const sourceHandleId = sourceHandle.rawHandle.id;\n        const targetHandleId = targetHandle.rawHandle.id;\n\n        const connectionModel = this.flowEntitiesService.connection();\n        const connection = {\n          source: sourceId,\n          target: targetId,\n          sourceHandle: sourceHandleId,\n          targetHandle: targetHandleId,\n        };\n\n        if (connectionModel.validator(connection)) {\n          this.onConnect.emit(connection);\n        }\n      }\n    },\n    { allowSignalWrites: true },\n  );\n\n  protected isStrictMode = computed(\n    () => this.flowEntitiesService.connection().mode === 'strict',\n  );\n\n  public startConnection(handle: HandleModel) {\n    this.statusService.setConnectionStartStatus(handle.parentNode, handle);\n  }\n\n  public validateConnection(handle: HandleModel) {\n    const status = this.statusService.status();\n\n    if (status.state === 'connection-start') {\n      let source = status.payload.source;\n      let target = handle.parentNode;\n      let sourceHandle = status.payload.sourceHandle;\n      let targetHandle = handle;\n\n      if (this.isStrictMode()) {\n        // swap direction (if needed) according to actual source and target of strict mode\n        const adjusted = adjustDirection({\n          source: status.payload.source,\n          sourceHandle: status.payload.sourceHandle,\n          target: handle.parentNode,\n          targetHandle: handle,\n        });\n\n        source = adjusted.source;\n        target = adjusted.target;\n        sourceHandle = adjusted.sourceHandle;\n        targetHandle = adjusted.targetHandle;\n      }\n\n      const valid = this.flowEntitiesService.connection().validator({\n        source: source.node.id,\n        target: target.node.id,\n        sourceHandle: sourceHandle.rawHandle.id,\n        targetHandle: targetHandle.rawHandle.id,\n      });\n\n      // TODO: check how react flow handles highlight of handle\n      // if direction changes\n      handle.state.set(valid ? 'valid' : 'invalid');\n\n      // status is about how we draw connection, so we don't need\n      // swapped diretion here\n      this.statusService.setConnectionValidationStatus(\n        valid,\n        status.payload.source,\n        handle.parentNode,\n        status.payload.sourceHandle,\n        handle,\n      );\n    }\n  }\n\n  public resetValidateConnection(targetHandle: HandleModel) {\n    targetHandle.state.set('idle');\n\n    // drop back to start status\n    const status = this.statusService.status();\n    if (status.state === 'connection-validation') {\n      this.statusService.setConnectionStartStatus(\n        status.payload.source,\n        status.payload.sourceHandle,\n      );\n    }\n  }\n\n  public endConnection(handle: HandleModel) {\n    const status = this.statusService.status();\n\n    if (status.state === 'connection-validation') {\n      const source = status.payload.source;\n      const sourceHandle = status.payload.sourceHandle;\n      const target = status.payload.target;\n      const targetHandle = status.payload.targetHandle;\n\n      batchStatusChanges(\n        // call to create connection\n        () =>\n          this.statusService.setConnectionEndStatus(\n            source!,\n            target!,\n            sourceHandle!,\n            targetHandle!,\n          ),\n        // when connection created, we need go back to idle status\n        () => this.statusService.setIdleStatus(),\n      );\n    }\n  }\n}\n"]}
@@ -12,16 +12,17 @@ export class DragHandleDirective {
12
12
  this.model.dragHandlesCount.update(count => count - 1);
13
13
  });
14
14
  }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DragHandleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
16
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DragHandleDirective, selector: "[dragHandle]", host: { classAttribute: "vflow-drag-handle" }, ngImport: i0 }); }
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
16
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: DragHandleDirective, isStandalone: true, selector: "[dragHandle]", host: { classAttribute: "vflow-drag-handle" }, ngImport: i0 }); }
17
17
  }
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DragHandleDirective, decorators: [{
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleDirective, decorators: [{
19
19
  type: Directive,
20
20
  args: [{
21
+ standalone: true,
21
22
  selector: '[dragHandle]',
22
23
  host: {
23
24
  'class': 'vflow-drag-handle'
24
- }
25
+ },
25
26
  }]
26
- }], ctorParameters: function () { return []; } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZHJhZy1oYW5kbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFjLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFReEUsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QixJQUFZLEtBQUs7UUFDZixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUE7SUFDbkMsQ0FBQztJQUVEO1FBTlEsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtRQU9oRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFBO1FBRXhELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFBO1FBQ3hELENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQzsrR0FiVSxtQkFBbUI7bUdBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFOL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsSUFBSSxFQUFFO3dCQUNKLE9BQU8sRUFBRSxtQkFBbUI7cUJBQzdCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZHJhZ0hhbmRsZV0nLFxuICBob3N0OiB7XG4gICAgJ2NsYXNzJzogJ3ZmbG93LWRyYWctaGFuZGxlJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVEaXJlY3RpdmUge1xuICBwcml2YXRlIG5vZGVBY2Nlc3NvciA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKVxuXG4gIHByaXZhdGUgZ2V0IG1vZGVsKCkge1xuICAgIHJldHVybiB0aGlzLm5vZGVBY2Nlc3Nvci5tb2RlbCgpIVxuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5tb2RlbC5kcmFnSGFuZGxlc0NvdW50LnVwZGF0ZSgoY291bnQpID0+IGNvdW50ICsgMSlcblxuICAgIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xuICAgICAgdGhpcy5tb2RlbC5kcmFnSGFuZGxlc0NvdW50LnVwZGF0ZShjb3VudCA9PiBjb3VudCAtIDEpXG4gICAgfSlcbiAgfVxufVxuIl19
27
+ }], ctorParameters: () => [] });
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZHJhZy1oYW5kbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFjLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFTeEUsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QixJQUFZLEtBQUs7UUFDZixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUE7SUFDbkMsQ0FBQztJQUVEO1FBTlEsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtRQU9oRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFBO1FBRXhELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFBO1FBQ3hELENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQzsrR0FiVSxtQkFBbUI7bUdBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFQL0IsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLElBQUksRUFBRTt3QkFDSixPQUFPLEVBQUUsbUJBQW1CO3FCQUM3QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlQWNjZXNzb3JTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvbm9kZS1hY2Nlc3Nvci5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2RyYWdIYW5kbGVdJyxcbiAgaG9zdDoge1xuICAgICdjbGFzcyc6ICd2Zmxvdy1kcmFnLWhhbmRsZSdcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJhZ0hhbmRsZURpcmVjdGl2ZSB7XG4gIHByaXZhdGUgbm9kZUFjY2Vzc29yID0gaW5qZWN0KE5vZGVBY2Nlc3NvclNlcnZpY2UpXG5cbiAgcHJpdmF0ZSBnZXQgbW9kZWwoKSB7XG4gICAgcmV0dXJuIHRoaXMubm9kZUFjY2Vzc29yLm1vZGVsKCkhXG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm1vZGVsLmRyYWdIYW5kbGVzQ291bnQudXBkYXRlKChjb3VudCkgPT4gY291bnQgKyAxKVxuXG4gICAgaW5qZWN0KERlc3Ryb3lSZWYpLm9uRGVzdHJveSgoKSA9PiB7XG4gICAgICB0aGlzLm1vZGVsLmRyYWdIYW5kbGVzQ291bnQudXBkYXRlKGNvdW50ID0+IGNvdW50IC0gMSlcbiAgICB9KVxuICB9XG59XG4iXX0=
@@ -21,17 +21,18 @@ export class FlowSizeControllerDirective {
21
21
  this.flowSettingsService.computedFlowHeight.set(entry.contentRect.height);
22
22
  }), takeUntilDestroyed()).subscribe();
23
23
  }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FlowSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
25
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: FlowSizeControllerDirective, selector: "svg[flowSizeController]", host: { properties: { "attr.width": "flowWidth()", "attr.height": "flowHeight()" } }, ngImport: i0 }); }
24
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
25
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FlowSizeControllerDirective, isStandalone: true, selector: "svg[flowSizeController]", host: { properties: { "attr.width": "flowWidth()", "attr.height": "flowHeight()" } }, ngImport: i0 }); }
26
26
  }
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FlowSizeControllerDirective, decorators: [{
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSizeControllerDirective, decorators: [{
28
28
  type: Directive,
29
29
  args: [{
30
+ standalone: true,
30
31
  selector: 'svg[flowSizeController]',
31
32
  host: {
32
33
  '[attr.width]': 'flowWidth()',
33
34
  '[attr.height]': 'flowHeight()'
34
- }
35
+ },
35
36
  }]
36
- }], ctorParameters: function () { return []; } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBMEIsUUFBUSxFQUFVLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN4SCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDL0MsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMzQixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFTaEUsTUFBTSxPQUFPLDJCQUEyQjtJQWdCdEM7UUFmUSxTQUFJLEdBQUcsTUFBTSxDQUE0QixVQUFVLENBQUMsQ0FBQTtRQUNwRCx3QkFBbUIsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtRQUVsRCxjQUFTLEdBQTRCLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDeEQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFBO1lBRTVDLE9BQU8sSUFBSSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDM0MsQ0FBQyxDQUFDLENBQUE7UUFFSyxlQUFVLEdBQTRCLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDekQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFBO1lBRTVDLE9BQU8sSUFBSSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDM0MsQ0FBQyxDQUFDLENBQUE7UUFHQSxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDdkQsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQ2QsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3ZFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQTtRQUMzRSxDQUFDLENBQUMsRUFDRixrQkFBa0IsRUFBRSxDQUNyQixDQUFDLFNBQVMsRUFBRSxDQUFBO0lBQ2YsQ0FBQzsrR0F4QlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBUHZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsSUFBSSxFQUFFO3dCQUNKLGNBQWMsRUFBRSxhQUFhO3dCQUM3QixlQUFlLEVBQUUsY0FBYztxQkFDaEM7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIE5nWm9uZSwgU2lnbmFsLCBXcml0YWJsZVNpZ25hbCwgY29tcHV0ZWQsIGVmZmVjdCwgaW5qZWN0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHJlc2l6YWJsZSB9IGZyb20gJy4uL3V0aWxzL3Jlc2l6YWJsZSc7XG5pbXBvcnQgeyB0YXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEZsb3dTZXR0aW5nc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9mbG93LXNldHRpbmdzLnNlcnZpY2UnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdzdmdbZmxvd1NpemVDb250cm9sbGVyXScsXG4gIGhvc3Q6IHtcbiAgICAnW2F0dHIud2lkdGhdJzogJ2Zsb3dXaWR0aCgpJyxcbiAgICAnW2F0dHIuaGVpZ2h0XSc6ICdmbG93SGVpZ2h0KCknXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgRmxvd1NpemVDb250cm9sbGVyRGlyZWN0aXZlIHtcbiAgcHJpdmF0ZSBob3N0ID0gaW5qZWN0PEVsZW1lbnRSZWY8U1ZHU1ZHRWxlbWVudD4+KEVsZW1lbnRSZWYpXG4gIHByaXZhdGUgZmxvd1NldHRpbmdzU2VydmljZSA9IGluamVjdChGbG93U2V0dGluZ3NTZXJ2aWNlKVxuXG4gIHB1YmxpYyBmbG93V2lkdGg6IFNpZ25hbDxzdHJpbmcgfCBudW1iZXI+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IHZpZXcgPSB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UudmlldygpXG5cbiAgICByZXR1cm4gdmlldyA9PT0gJ2F1dG8nID8gJzEwMCUnIDogdmlld1swXVxuICB9KVxuXG4gIHB1YmxpYyBmbG93SGVpZ2h0OiBTaWduYWw8c3RyaW5nIHwgbnVtYmVyPiA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCB2aWV3ID0gdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLnZpZXcoKVxuXG4gICAgcmV0dXJuIHZpZXcgPT09ICdhdXRvJyA/ICcxMDAlJyA6IHZpZXdbMV1cbiAgfSlcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICByZXNpemFibGUoW3RoaXMuaG9zdC5uYXRpdmVFbGVtZW50XSwgaW5qZWN0KE5nWm9uZSkpLnBpcGUoXG4gICAgICB0YXAoKFtlbnRyeV0pID0+IHtcbiAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd1dpZHRoLnNldChlbnRyeS5jb250ZW50UmVjdC53aWR0aClcbiAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd0hlaWdodC5zZXQoZW50cnkuY29udGVudFJlY3QuaGVpZ2h0KVxuICAgICAgfSksXG4gICAgICB0YWtlVW50aWxEZXN0cm95ZWQoKVxuICAgICkuc3Vic2NyaWJlKClcbiAgfVxufVxuIl19
37
+ }], ctorParameters: () => [] });
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBMEIsUUFBUSxFQUFVLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN4SCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDL0MsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMzQixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFVaEUsTUFBTSxPQUFPLDJCQUEyQjtJQWdCdEM7UUFmUSxTQUFJLEdBQUcsTUFBTSxDQUE0QixVQUFVLENBQUMsQ0FBQTtRQUNwRCx3QkFBbUIsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtRQUVsRCxjQUFTLEdBQTRCLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDeEQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFBO1lBRTVDLE9BQU8sSUFBSSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDM0MsQ0FBQyxDQUFDLENBQUE7UUFFSyxlQUFVLEdBQTRCLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDekQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFBO1lBRTVDLE9BQU8sSUFBSSxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDM0MsQ0FBQyxDQUFDLENBQUE7UUFHQSxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDdkQsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQ2QsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ3ZFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQTtRQUMzRSxDQUFDLENBQUMsRUFDRixrQkFBa0IsRUFBRSxDQUNyQixDQUFDLFNBQVMsRUFBRSxDQUFBO0lBQ2YsQ0FBQzsrR0F4QlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBUnZDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLElBQUksRUFBRTt3QkFDSixjQUFjLEVBQUUsYUFBYTt3QkFDN0IsZUFBZSxFQUFFLGNBQWM7cUJBQ2hDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBOZ1pvbmUsIFNpZ25hbCwgV3JpdGFibGVTaWduYWwsIGNvbXB1dGVkLCBlZmZlY3QsIGluamVjdCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyByZXNpemFibGUgfSBmcm9tICcuLi91dGlscy9yZXNpemFibGUnO1xuaW1wb3J0IHsgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBGbG93U2V0dGluZ3NTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnc3ZnW2Zsb3dTaXplQ29udHJvbGxlcl0nLFxuICBob3N0OiB7XG4gICAgJ1thdHRyLndpZHRoXSc6ICdmbG93V2lkdGgoKScsXG4gICAgJ1thdHRyLmhlaWdodF0nOiAnZmxvd0hlaWdodCgpJ1xuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBGbG93U2l6ZUNvbnRyb2xsZXJEaXJlY3RpdmUge1xuICBwcml2YXRlIGhvc3QgPSBpbmplY3Q8RWxlbWVudFJlZjxTVkdTVkdFbGVtZW50Pj4oRWxlbWVudFJlZilcbiAgcHJpdmF0ZSBmbG93U2V0dGluZ3NTZXJ2aWNlID0gaW5qZWN0KEZsb3dTZXR0aW5nc1NlcnZpY2UpXG5cbiAgcHVibGljIGZsb3dXaWR0aDogU2lnbmFsPHN0cmluZyB8IG51bWJlcj4gPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3QgdmlldyA9IHRoaXMuZmxvd1NldHRpbmdzU2VydmljZS52aWV3KClcblxuICAgIHJldHVybiB2aWV3ID09PSAnYXV0bycgPyAnMTAwJScgOiB2aWV3WzBdXG4gIH0pXG5cbiAgcHVibGljIGZsb3dIZWlnaHQ6IFNpZ25hbDxzdHJpbmcgfCBudW1iZXI+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IHZpZXcgPSB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UudmlldygpXG5cbiAgICByZXR1cm4gdmlldyA9PT0gJ2F1dG8nID8gJzEwMCUnIDogdmlld1sxXVxuICB9KVxuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHJlc2l6YWJsZShbdGhpcy5ob3N0Lm5hdGl2ZUVsZW1lbnRdLCBpbmplY3QoTmdab25lKSkucGlwZShcbiAgICAgIHRhcCgoW2VudHJ5XSkgPT4ge1xuICAgICAgICB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UuY29tcHV0ZWRGbG93V2lkdGguc2V0KGVudHJ5LmNvbnRlbnRSZWN0LndpZHRoKVxuICAgICAgICB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UuY29tcHV0ZWRGbG93SGVpZ2h0LnNldChlbnRyeS5jb250ZW50UmVjdC5oZWlnaHQpXG4gICAgICB9KSxcbiAgICAgIHRha2VVbnRpbERlc3Ryb3llZCgpXG4gICAgKS5zdWJzY3JpYmUoKVxuICB9XG59XG4iXX0=
@@ -1,28 +1,31 @@
1
- import { Directive, ElementRef, Input, inject } from '@angular/core';
1
+ import { Directive, ElementRef, inject, input, } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class HandleSizeControllerDirective {
4
4
  constructor() {
5
+ this.handleModel = input.required({
6
+ alias: 'handleSizeController',
7
+ });
5
8
  this.handleWrapper = inject(ElementRef);
6
9
  }
7
10
  ngAfterViewInit() {
8
11
  const element = this.handleWrapper.nativeElement;
9
12
  const rect = element.getBBox();
10
13
  const stroke = getChildStrokeWidth(element);
11
- this.handleModel.size.set({
14
+ this.handleModel().size.set({
12
15
  width: rect.width + stroke,
13
- height: rect.height + stroke
16
+ height: rect.height + stroke,
14
17
  });
15
18
  }
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HandleSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
17
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: HandleSizeControllerDirective, selector: "[handleSizeController]", inputs: { handleModel: ["handleSizeController", "handleModel"] }, ngImport: i0 }); }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
20
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: HandleSizeControllerDirective, isStandalone: true, selector: "[handleSizeController]", inputs: { handleModel: { classPropertyName: "handleModel", publicName: "handleSizeController", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 }); }
18
21
  }
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: HandleSizeControllerDirective, decorators: [{
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleSizeControllerDirective, decorators: [{
20
23
  type: Directive,
21
- args: [{ selector: '[handleSizeController]' }]
22
- }], propDecorators: { handleModel: [{
23
- type: Input,
24
- args: [{ required: true, alias: 'handleSizeController' }]
25
- }] } });
24
+ args: [{
25
+ standalone: true,
26
+ selector: '[handleSizeController]',
27
+ }]
28
+ }] });
26
29
  function getChildStrokeWidth(element) {
27
30
  const child = element.firstElementChild;
28
31
  if (child) {
@@ -35,4 +38,4 @@ function getChildStrokeWidth(element) {
35
38
  }
36
39
  return 0;
37
40
  }
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLXNpemUtY29udHJvbGxlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9oYW5kbGUtc2l6ZS1jb250cm9sbGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJcEYsTUFBTSxPQUFPLDZCQUE2QjtJQUQxQztRQUtVLGtCQUFhLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBNEIsQ0FBQTtLQVl0RTtJQVZRLGVBQWU7UUFDcEIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUE7UUFDaEQsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBRTlCLE1BQU0sTUFBTSxHQUFHLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQzNDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUN4QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNO1lBQzFCLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU07U0FDN0IsQ0FBQyxDQUFBO0lBQ0osQ0FBQzsrR0FmVSw2QkFBNkI7bUdBQTdCLDZCQUE2Qjs7NEZBQTdCLDZCQUE2QjtrQkFEekMsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSx3QkFBd0IsRUFBRTs4QkFHeEMsV0FBVztzQkFEakIsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLHNCQUFzQixFQUFFOztBQWlCMUQsU0FBUyxtQkFBbUIsQ0FBQyxPQUFvQjtJQUMvQyxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUE7SUFFdkMsSUFBSSxLQUFLLEVBQUU7UUFDVCxNQUFNLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLENBQUE7UUFDbEQsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUE7UUFFdkQsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLEVBQUU7WUFDekIsT0FBTyxDQUFDLENBQUE7U0FDVDtRQUVELE9BQU8sY0FBYyxDQUFBO0tBQ3RCO0lBRUQsT0FBTyxDQUFDLENBQUE7QUFDVixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbaGFuZGxlU2l6ZUNvbnRyb2xsZXJdJyB9KVxuZXhwb3J0IGNsYXNzIEhhbmRsZVNpemVDb250cm9sbGVyRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlLCBhbGlhczogJ2hhbmRsZVNpemVDb250cm9sbGVyJyB9KVxuICBwdWJsaWMgaGFuZGxlTW9kZWwhOiBIYW5kbGVNb2RlbFxuXG4gIHByaXZhdGUgaGFuZGxlV3JhcHBlciA9IGluamVjdChFbGVtZW50UmVmKSBhcyBFbGVtZW50UmVmPFNWR0dFbGVtZW50PlxuXG4gIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgY29uc3QgZWxlbWVudCA9IHRoaXMuaGFuZGxlV3JhcHBlci5uYXRpdmVFbGVtZW50XG4gICAgY29uc3QgcmVjdCA9IGVsZW1lbnQuZ2V0QkJveCgpXG5cbiAgICBjb25zdCBzdHJva2UgPSBnZXRDaGlsZFN0cm9rZVdpZHRoKGVsZW1lbnQpXG4gICAgdGhpcy5oYW5kbGVNb2RlbC5zaXplLnNldCh7XG4gICAgICB3aWR0aDogcmVjdC53aWR0aCArIHN0cm9rZSxcbiAgICAgIGhlaWdodDogcmVjdC5oZWlnaHQgKyBzdHJva2VcbiAgICB9KVxuICB9XG59XG5cbmZ1bmN0aW9uIGdldENoaWxkU3Ryb2tlV2lkdGgoZWxlbWVudDogU1ZHR0VsZW1lbnQpIHtcbiAgY29uc3QgY2hpbGQgPSBlbGVtZW50LmZpcnN0RWxlbWVudENoaWxkXG5cbiAgaWYgKGNoaWxkKSB7XG4gICAgY29uc3Qgc3Ryb2tlID0gZ2V0Q29tcHV0ZWRTdHlsZShjaGlsZCkuc3Ryb2tlV2lkdGhcbiAgICBjb25zdCBzdHJva2VBc051bWJlciA9IE51bWJlcihzdHJva2UucmVwbGFjZSgncHgnLCAnJykpXG5cbiAgICBpZiAoaXNOYU4oc3Ryb2tlQXNOdW1iZXIpKSB7XG4gICAgICByZXR1cm4gMFxuICAgIH1cblxuICAgIHJldHVybiBzdHJva2VBc051bWJlclxuICB9XG5cbiAgcmV0dXJuIDBcbn1cbiJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLXNpemUtY29udHJvbGxlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9oYW5kbGUtc2l6ZS1jb250cm9sbGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFVBQVUsRUFDVixNQUFNLEVBQ04sS0FBSyxHQUNOLE1BQU0sZUFBZSxDQUFDOztBQU92QixNQUFNLE9BQU8sNkJBQTZCO0lBSjFDO1FBS1MsZ0JBQVcsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFjO1lBQy9DLEtBQUssRUFBRSxzQkFBc0I7U0FDOUIsQ0FBQyxDQUFDO1FBRUssa0JBQWEsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUE0QixDQUFDO0tBWXZFO0lBVlEsZUFBZTtRQUNwQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7UUFFL0IsTUFBTSxNQUFNLEdBQUcsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDMUIsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTTtZQUMxQixNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNO1NBQzdCLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBaEJVLDZCQUE2QjttR0FBN0IsNkJBQTZCOzs0RkFBN0IsNkJBQTZCO2tCQUp6QyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsd0JBQXdCO2lCQUNuQzs7QUFvQkQsU0FBUyxtQkFBbUIsQ0FBQyxPQUFvQjtJQUMvQyxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUM7SUFFeEMsSUFBSSxLQUFLLEVBQUUsQ0FBQztRQUNWLE1BQU0sTUFBTSxHQUFHLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDLFdBQVcsQ0FBQztRQUNuRCxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUV4RCxJQUFJLEtBQUssQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1lBQzFCLE9BQU8sQ0FBQyxDQUFDO1FBQ1gsQ0FBQztRQUVELE9BQU8sY0FBYyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxPQUFPLENBQUMsQ0FBQztBQUNYLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIGluamVjdCxcbiAgaW5wdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSGFuZGxlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvaGFuZGxlLm1vZGVsJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2hhbmRsZVNpemVDb250cm9sbGVyXScsXG59KVxuZXhwb3J0IGNsYXNzIEhhbmRsZVNpemVDb250cm9sbGVyRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gIHB1YmxpYyBoYW5kbGVNb2RlbCA9IGlucHV0LnJlcXVpcmVkPEhhbmRsZU1vZGVsPih7XG4gICAgYWxpYXM6ICdoYW5kbGVTaXplQ29udHJvbGxlcicsXG4gIH0pO1xuXG4gIHByaXZhdGUgaGFuZGxlV3JhcHBlciA9IGluamVjdChFbGVtZW50UmVmKSBhcyBFbGVtZW50UmVmPFNWR0dFbGVtZW50PjtcblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGVsZW1lbnQgPSB0aGlzLmhhbmRsZVdyYXBwZXIubmF0aXZlRWxlbWVudDtcbiAgICBjb25zdCByZWN0ID0gZWxlbWVudC5nZXRCQm94KCk7XG5cbiAgICBjb25zdCBzdHJva2UgPSBnZXRDaGlsZFN0cm9rZVdpZHRoKGVsZW1lbnQpO1xuICAgIHRoaXMuaGFuZGxlTW9kZWwoKS5zaXplLnNldCh7XG4gICAgICB3aWR0aDogcmVjdC53aWR0aCArIHN0cm9rZSxcbiAgICAgIGhlaWdodDogcmVjdC5oZWlnaHQgKyBzdHJva2UsXG4gICAgfSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gZ2V0Q2hpbGRTdHJva2VXaWR0aChlbGVtZW50OiBTVkdHRWxlbWVudCkge1xuICBjb25zdCBjaGlsZCA9IGVsZW1lbnQuZmlyc3RFbGVtZW50Q2hpbGQ7XG5cbiAgaWYgKGNoaWxkKSB7XG4gICAgY29uc3Qgc3Ryb2tlID0gZ2V0Q29tcHV0ZWRTdHlsZShjaGlsZCkuc3Ryb2tlV2lkdGg7XG4gICAgY29uc3Qgc3Ryb2tlQXNOdW1iZXIgPSBOdW1iZXIoc3Ryb2tlLnJlcGxhY2UoJ3B4JywgJycpKTtcblxuICAgIGlmIChpc05hTihzdHJva2VBc051bWJlcikpIHtcbiAgICAgIHJldHVybiAwO1xuICAgIH1cblxuICAgIHJldHVybiBzdHJva2VBc051bWJlcjtcbiAgfVxuXG4gIHJldHVybiAwO1xufVxuIl19