ngx-vflow 1.0.1 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -10
- package/esm2022/lib/vflow/components/background/background.component.mjs +6 -10
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +8 -10
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +2 -2
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +4 -4
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +3 -3
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +3 -3
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +5 -7
- package/esm2022/lib/vflow/components/node/node.component.mjs +8 -8
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +5 -8
- package/esm2022/lib/vflow/decorators/microtask.decorator.mjs +1 -1
- package/esm2022/lib/vflow/decorators/run-in-injection-context.decorator.mjs +2 -2
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +64 -22
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +6 -3
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +3 -3
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +6 -4
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +2 -2
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +16 -14
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +2 -2
- package/esm2022/lib/vflow/directives/reference.directive.mjs +1 -1
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +7 -11
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +1 -1
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +1 -1
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +2 -2
- package/esm2022/lib/vflow/directives/template.directive.mjs +6 -6
- package/esm2022/lib/vflow/interfaces/box.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/connection-settings.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/connection.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/connection.internal.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/edge-label.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/edge.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/fit-view-options.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/flow-entity.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/marker.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +5 -5
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/path-data.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/point.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/rect.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/template-context.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/viewport.interface.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +4 -10
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +3 -3
- package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +6 -6
- package/esm2022/lib/vflow/math/point-on-line-by-ratio.mjs +1 -1
- package/esm2022/lib/vflow/models/connection.model.mjs +1 -1
- package/esm2022/lib/vflow/models/edge-label.model.mjs +2 -2
- package/esm2022/lib/vflow/models/edge.model.mjs +25 -25
- package/esm2022/lib/vflow/models/handle.model.mjs +41 -37
- package/esm2022/lib/vflow/models/minimap.model.mjs +2 -2
- package/esm2022/lib/vflow/models/node.model.mjs +9 -14
- package/esm2022/lib/vflow/models/toolbar.model.mjs +6 -6
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +3 -3
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +3 -3
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +2 -2
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +8 -16
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +3 -3
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +11 -17
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +1 -1
- package/esm2022/lib/vflow/services/draggable.service.mjs +10 -12
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +14 -20
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +7 -10
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +1 -1
- package/esm2022/lib/vflow/services/flow-status.service.mjs +2 -2
- package/esm2022/lib/vflow/services/handle.service.mjs +3 -3
- package/esm2022/lib/vflow/services/keyboard.service.mjs +8 -6
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +1 -1
- package/esm2022/lib/vflow/services/node-changes.service.mjs +13 -21
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +6 -7
- package/esm2022/lib/vflow/services/overlays.service.mjs +2 -2
- package/esm2022/lib/vflow/services/selection.service.mjs +6 -4
- package/esm2022/lib/vflow/services/viewport.service.mjs +13 -11
- package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +25 -25
- package/esm2022/lib/vflow/types/background.type.mjs +1 -1
- package/esm2022/lib/vflow/types/connection-mode.type.mjs +1 -1
- package/esm2022/lib/vflow/types/edge-change.type.mjs +1 -1
- package/esm2022/lib/vflow/types/handle-type.type.mjs +1 -1
- package/esm2022/lib/vflow/types/keyboard-action.type.mjs +1 -1
- package/esm2022/lib/vflow/types/node-change.type.mjs +1 -1
- package/esm2022/lib/vflow/types/position.type.mjs +1 -1
- package/esm2022/lib/vflow/types/using-points.type.mjs +1 -1
- package/esm2022/lib/vflow/types/viewport-change-type.type.mjs +1 -1
- package/esm2022/lib/vflow/utils/add-nodes-to-edges.mjs +2 -2
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +1 -1
- package/esm2022/lib/vflow/utils/get-os.mjs +6 -6
- package/esm2022/lib/vflow/utils/hash.mjs +2 -2
- package/esm2022/lib/vflow/utils/id.mjs +1 -1
- package/esm2022/lib/vflow/utils/is-defined.mjs +1 -1
- package/esm2022/lib/vflow/utils/is-group-node.mjs +1 -1
- package/esm2022/lib/vflow/utils/nodes.mjs +2 -2
- package/esm2022/lib/vflow/utils/reference-keeper.mjs +7 -7
- package/esm2022/lib/vflow/utils/resizable.mjs +4 -4
- package/esm2022/lib/vflow/utils/round.mjs +1 -1
- package/esm2022/lib/vflow/utils/transform-background.mjs +2 -4
- package/esm2022/lib/vflow/utils/viewport.mjs +1 -1
- package/esm2022/lib/vflow/vflow.mjs +10 -10
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/ngx-vflow.mjs +320 -322
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/node/node.component.d.ts +1 -1
- package/lib/vflow/components/vflow/vflow.component.d.ts +1 -1
- package/lib/vflow/decorators/run-in-injection-context.decorator.d.ts +1 -1
- package/lib/vflow/directives/changes-controller.directive.d.ts +29 -29
- package/lib/vflow/directives/connection-controller.directive.d.ts +4 -2
- package/lib/vflow/directives/pointer.directive.d.ts +4 -4
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +5 -5
- package/lib/vflow/interfaces/connection-settings.interface.d.ts +4 -4
- package/lib/vflow/interfaces/connection.internal.interface.d.ts +2 -2
- package/lib/vflow/interfaces/edge.interface.d.ts +3 -3
- package/lib/vflow/interfaces/flow-entity.interface.d.ts +1 -1
- package/lib/vflow/interfaces/node.interface.d.ts +4 -4
- package/lib/vflow/interfaces/path-data.interface.d.ts +2 -2
- package/lib/vflow/interfaces/template-context.interface.d.ts +2 -2
- package/lib/vflow/interfaces/viewport.interface.d.ts +2 -2
- package/lib/vflow/math/edge-path/straigh-path.d.ts +3 -3
- package/lib/vflow/math/point-on-line-by-ratio.d.ts +1 -1
- package/lib/vflow/models/connection.model.d.ts +3 -3
- package/lib/vflow/models/edge-label.model.d.ts +1 -1
- package/lib/vflow/models/edge.model.d.ts +8 -9
- package/lib/vflow/models/handle.model.d.ts +2 -2
- package/lib/vflow/models/minimap.model.d.ts +1 -1
- package/lib/vflow/models/toolbar.model.d.ts +3 -3
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +2 -2
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +2 -2
- package/lib/vflow/services/flow-status.service.d.ts +1 -1
- package/lib/vflow/testing-utils/provide-custom-node-mocks.d.ts +1 -1
- package/lib/vflow/types/node-change.type.d.ts +1 -1
- package/lib/vflow/types/viewport-change-type.type.d.ts +1 -3
- package/lib/vflow/utils/add-nodes-to-edges.d.ts +2 -2
- package/lib/vflow/utils/adjust-direction.d.ts +1 -1
- package/lib/vflow/utils/is-group-node.d.ts +1 -1
- package/lib/vflow/utils/nodes.d.ts +2 -2
- package/lib/vflow/utils/reference-keeper.d.ts +3 -3
- package/lib/vflow/utils/resizable.d.ts +2 -2
- package/lib/vflow/utils/transform-background.d.ts +1 -1
- package/lib/vflow/utils/viewport.d.ts +2 -2
- package/lib/vflow/vflow.d.ts +8 -8
- package/package.json +2 -2
|
@@ -12,37 +12,79 @@ export class ChangesControllerDirective {
|
|
|
12
12
|
* Watch nodes change
|
|
13
13
|
*/
|
|
14
14
|
this.onNodesChange = outputFromObservable(this.nodesChangeService.changes$);
|
|
15
|
-
this.onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {
|
|
15
|
+
this.onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {
|
|
16
|
+
alias: 'onNodesChange.position',
|
|
17
|
+
});
|
|
16
18
|
this.onNodesChangePositionSignle = outputFromObservable(this.singleChange(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.single' });
|
|
17
19
|
this.onNodesChangePositionMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.many' });
|
|
18
|
-
this.onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
this.
|
|
20
|
+
this.onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {
|
|
21
|
+
alias: 'onNodesChange.size',
|
|
22
|
+
});
|
|
23
|
+
this.onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {
|
|
24
|
+
alias: 'onNodesChange.size.single',
|
|
25
|
+
});
|
|
26
|
+
this.onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {
|
|
27
|
+
alias: 'onNodesChange.size.many',
|
|
28
|
+
});
|
|
29
|
+
this.onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {
|
|
30
|
+
alias: 'onNodesChange.add',
|
|
31
|
+
});
|
|
32
|
+
this.onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {
|
|
33
|
+
alias: 'onNodesChange.add.single',
|
|
34
|
+
});
|
|
35
|
+
this.onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {
|
|
36
|
+
alias: 'onNodesChange.add.many',
|
|
37
|
+
});
|
|
38
|
+
this.onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {
|
|
39
|
+
alias: 'onNodesChange.remove',
|
|
40
|
+
});
|
|
25
41
|
this.onNodesChangeRemoveSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('remove')), { alias: 'onNodesChange.remove.single' });
|
|
26
|
-
this.onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {
|
|
27
|
-
|
|
42
|
+
this.onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {
|
|
43
|
+
alias: 'onNodesChange.remove.many',
|
|
44
|
+
});
|
|
45
|
+
this.onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {
|
|
46
|
+
alias: 'onNodesChange.select',
|
|
47
|
+
});
|
|
28
48
|
this.onNodesChangeSelectSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('select')), { alias: 'onNodesChange.select.single' });
|
|
29
|
-
this.onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {
|
|
49
|
+
this.onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {
|
|
50
|
+
alias: 'onNodesChange.select.many',
|
|
51
|
+
});
|
|
30
52
|
/**
|
|
31
53
|
* Watch edges change
|
|
32
54
|
*/
|
|
33
55
|
this.onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);
|
|
34
|
-
this.onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {
|
|
56
|
+
this.onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {
|
|
57
|
+
alias: 'onEdgesChange.detached',
|
|
58
|
+
});
|
|
35
59
|
this.onNodesChangeDetachedSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.single' });
|
|
36
60
|
this.onNodesChangeDetachedMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.many' });
|
|
37
|
-
this.onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
this.
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
this.
|
|
44
|
-
|
|
45
|
-
|
|
61
|
+
this.onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {
|
|
62
|
+
alias: 'onEdgesChange.add',
|
|
63
|
+
});
|
|
64
|
+
this.onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {
|
|
65
|
+
alias: 'onEdgesChange.add.single',
|
|
66
|
+
});
|
|
67
|
+
this.onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {
|
|
68
|
+
alias: 'onEdgesChange.add.many',
|
|
69
|
+
});
|
|
70
|
+
this.onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {
|
|
71
|
+
alias: 'onEdgesChange.remove',
|
|
72
|
+
});
|
|
73
|
+
this.onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {
|
|
74
|
+
alias: 'onEdgesChange.remove.single',
|
|
75
|
+
});
|
|
76
|
+
this.onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {
|
|
77
|
+
alias: 'onEdgesChange.remove.many',
|
|
78
|
+
});
|
|
79
|
+
this.onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {
|
|
80
|
+
alias: 'onEdgesChange.select',
|
|
81
|
+
});
|
|
82
|
+
this.onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {
|
|
83
|
+
alias: 'onEdgesChange.select.single',
|
|
84
|
+
});
|
|
85
|
+
this.onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {
|
|
86
|
+
alias: 'onEdgesChange.select.many',
|
|
87
|
+
});
|
|
46
88
|
}
|
|
47
89
|
nodeChangesOfType(type) {
|
|
48
90
|
return this.nodesChangeService.changes$.pipe(map((changes) => changes.filter((c) => c.type === type)), filter((changes) => !!changes.length));
|
|
@@ -66,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
66
108
|
standalone: true,
|
|
67
109
|
}]
|
|
68
110
|
}] });
|
|
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"]}
|
|
111
|
+
//# 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 } 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 readonly onNodesChange = outputFromObservable(this.nodesChangeService.changes$);\n\n  public readonly onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {\n    alias: 'onNodesChange.position',\n  });\n\n  public readonly onNodesChangePositionSignle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.single' },\n  );\n\n  public readonly onNodesChangePositionMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.many' },\n  );\n\n  public readonly onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {\n    alias: 'onNodesChange.size',\n  });\n\n  public readonly onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.single',\n  });\n\n  public readonly onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.many',\n  });\n\n  public readonly onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {\n    alias: 'onNodesChange.add',\n  });\n\n  public readonly onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.single',\n  });\n\n  public readonly onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.many',\n  });\n\n  public readonly onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {\n    alias: 'onNodesChange.remove',\n  });\n\n  public readonly onNodesChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.single' },\n  );\n\n  public readonly onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {\n    alias: 'onNodesChange.remove.many',\n  });\n\n  public readonly onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {\n    alias: 'onNodesChange.select',\n  });\n\n  public readonly onNodesChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.single' },\n  );\n\n  public readonly onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {\n    alias: 'onNodesChange.select.many',\n  });\n\n  /**\n   * Watch edges change\n   */\n  public readonly onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);\n\n  public readonly onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {\n    alias: 'onEdgesChange.detached',\n  });\n\n  public readonly onNodesChangeDetachedSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.single' },\n  );\n\n  public readonly onNodesChangeDetachedMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.many' },\n  );\n\n  public readonly onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {\n    alias: 'onEdgesChange.add',\n  });\n\n  public readonly onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.single',\n  });\n\n  public readonly onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.many',\n  });\n\n  public readonly onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {\n    alias: 'onEdgesChange.remove',\n  });\n\n  public readonly onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.single',\n  });\n\n  public readonly onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.many',\n  });\n\n  public readonly onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {\n    alias: 'onEdgesChange.select',\n  });\n\n  public readonly onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.single',\n  });\n\n  public readonly onEdgeChangeSelectMany = outputFromObservable(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) => 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(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
1
|
import { Directive, computed, effect, inject, output } from '@angular/core';
|
|
2
|
-
import { FlowStatusService, batchStatusChanges
|
|
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";
|
|
@@ -12,7 +12,10 @@ export class ConnectionControllerDirective {
|
|
|
12
12
|
*
|
|
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
|
+
*
|
|
16
|
+
* @todo add connect event and deprecate onConnect
|
|
15
17
|
*/
|
|
18
|
+
// eslint-disable-next-line @angular-eslint/no-output-on-prefix
|
|
16
19
|
this.onConnect = output();
|
|
17
20
|
this.statusService = inject(FlowStatusService);
|
|
18
21
|
this.flowEntitiesService = inject(FlowEntitiesService);
|
|
@@ -98,7 +101,7 @@ export class ConnectionControllerDirective {
|
|
|
98
101
|
this.statusService.setConnectionStartStatus(status.payload.source, status.payload.sourceHandle);
|
|
99
102
|
}
|
|
100
103
|
}
|
|
101
|
-
endConnection(
|
|
104
|
+
endConnection() {
|
|
102
105
|
const status = this.statusService.status();
|
|
103
106
|
if (status.state === 'connection-validation') {
|
|
104
107
|
const source = status.payload.source;
|
|
@@ -122,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
122
125
|
standalone: true,
|
|
123
126
|
}]
|
|
124
127
|
}] });
|
|
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"]}
|
|
128
|
+
//# 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 { 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   * @todo add connect event and deprecate onConnect\n   */\n  // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n  public readonly 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(() => this.flowEntitiesService.connection().mode === 'strict');\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(status.payload.source, status.payload.sourceHandle);\n    }\n  }\n\n  public endConnection() {\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"]}
|
|
@@ -9,7 +9,7 @@ export class DragHandleDirective {
|
|
|
9
9
|
this.nodeAccessor = inject(NodeAccessorService);
|
|
10
10
|
this.model.dragHandlesCount.update((count) => count + 1);
|
|
11
11
|
inject(DestroyRef).onDestroy(() => {
|
|
12
|
-
this.model.dragHandlesCount.update(count => count - 1);
|
|
12
|
+
this.model.dragHandlesCount.update((count) => count - 1);
|
|
13
13
|
});
|
|
14
14
|
}
|
|
15
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DragHandleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
@@ -21,8 +21,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
21
21
|
standalone: true,
|
|
22
22
|
selector: '[dragHandle]',
|
|
23
23
|
host: {
|
|
24
|
-
|
|
24
|
+
class: 'vflow-drag-handle',
|
|
25
25
|
},
|
|
26
26
|
}]
|
|
27
27
|
}], ctorParameters: () => [] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZHJhZy1oYW5kbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFTeEUsTUFBTSxPQUFPLG1CQUFtQjtJQUc5QixJQUFZLEtBQUs7UUFDZixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUM7SUFDcEMsQ0FBQztJQUVEO1FBTlEsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQU9qRCxJQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRXpELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDM0QsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOytHQWJVLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQVAvQixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsY0FBYztvQkFDeEIsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSxtQkFBbUI7cUJBQzNCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzdHJveVJlZiwgRGlyZWN0aXZlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbZHJhZ0hhbmRsZV0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICd2Zmxvdy1kcmFnLWhhbmRsZScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIERyYWdIYW5kbGVEaXJlY3RpdmUge1xuICBwcml2YXRlIG5vZGVBY2Nlc3NvciA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKTtcblxuICBwcml2YXRlIGdldCBtb2RlbCgpIHtcbiAgICByZXR1cm4gdGhpcy5ub2RlQWNjZXNzb3IubW9kZWwoKSE7XG4gIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm1vZGVsLmRyYWdIYW5kbGVzQ291bnQudXBkYXRlKChjb3VudCkgPT4gY291bnQgKyAxKTtcblxuICAgIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xuICAgICAgdGhpcy5tb2RlbC5kcmFnSGFuZGxlc0NvdW50LnVwZGF0ZSgoY291bnQpID0+IGNvdW50IC0gMSk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -16,10 +16,12 @@ export class FlowSizeControllerDirective {
|
|
|
16
16
|
const view = this.flowSettingsService.view();
|
|
17
17
|
return view === 'auto' ? '100%' : view[1];
|
|
18
18
|
});
|
|
19
|
-
resizable([this.host.nativeElement], inject(NgZone))
|
|
19
|
+
resizable([this.host.nativeElement], inject(NgZone))
|
|
20
|
+
.pipe(tap(([entry]) => {
|
|
20
21
|
this.flowSettingsService.computedFlowWidth.set(entry.contentRect.width);
|
|
21
22
|
this.flowSettingsService.computedFlowHeight.set(entry.contentRect.height);
|
|
22
|
-
}), takeUntilDestroyed())
|
|
23
|
+
}), takeUntilDestroyed())
|
|
24
|
+
.subscribe();
|
|
23
25
|
}
|
|
24
26
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowSizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
25
27
|
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 }); }
|
|
@@ -31,8 +33,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
31
33
|
selector: 'svg[flowSizeController]',
|
|
32
34
|
host: {
|
|
33
35
|
'[attr.width]': 'flowWidth()',
|
|
34
|
-
'[attr.height]': 'flowHeight()'
|
|
36
|
+
'[attr.height]': 'flowHeight()',
|
|
35
37
|
},
|
|
36
38
|
}]
|
|
37
39
|
}], ctorParameters: () => [] });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvZmxvdy1zaXplLWNvbnRyb2xsZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBVSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQVVoRSxNQUFNLE9BQU8sMkJBQTJCO0lBZ0J0QztRQWZRLFNBQUksR0FBRyxNQUFNLENBQTRCLFVBQVUsQ0FBQyxDQUFDO1FBQ3JELHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRW5ELGNBQVMsR0FBNEIsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN4RCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFN0MsT0FBTyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUVJLGVBQVUsR0FBNEIsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN6RCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFN0MsT0FBTyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUdELFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQ2pELElBQUksQ0FDSCxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUU7WUFDZCxJQUFJLENBQUMsbUJBQW1CLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDeEUsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzVFLENBQUMsQ0FBQyxFQUNGLGtCQUFrQixFQUFFLENBQ3JCO2FBQ0EsU0FBUyxFQUFFLENBQUM7SUFDakIsQ0FBQzsrR0ExQlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBUnZDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLElBQUksRUFBRTt3QkFDSixjQUFjLEVBQUUsYUFBYTt3QkFDN0IsZUFBZSxFQUFFLGNBQWM7cUJBQ2hDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBOZ1pvbmUsIFNpZ25hbCwgY29tcHV0ZWQsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgcmVzaXphYmxlIH0gZnJvbSAnLi4vdXRpbHMvcmVzaXphYmxlJztcbmltcG9ydCB7IHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRmxvd1NldHRpbmdzU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2Zsb3ctc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ3N2Z1tmbG93U2l6ZUNvbnRyb2xsZXJdJyxcbiAgaG9zdDoge1xuICAgICdbYXR0ci53aWR0aF0nOiAnZmxvd1dpZHRoKCknLFxuICAgICdbYXR0ci5oZWlnaHRdJzogJ2Zsb3dIZWlnaHQoKScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIEZsb3dTaXplQ29udHJvbGxlckRpcmVjdGl2ZSB7XG4gIHByaXZhdGUgaG9zdCA9IGluamVjdDxFbGVtZW50UmVmPFNWR1NWR0VsZW1lbnQ+PihFbGVtZW50UmVmKTtcbiAgcHJpdmF0ZSBmbG93U2V0dGluZ3NTZXJ2aWNlID0gaW5qZWN0KEZsb3dTZXR0aW5nc1NlcnZpY2UpO1xuXG4gIHB1YmxpYyBmbG93V2lkdGg6IFNpZ25hbDxzdHJpbmcgfCBudW1iZXI+ID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IHZpZXcgPSB0aGlzLmZsb3dTZXR0aW5nc1NlcnZpY2UudmlldygpO1xuXG4gICAgcmV0dXJuIHZpZXcgPT09ICdhdXRvJyA/ICcxMDAlJyA6IHZpZXdbMF07XG4gIH0pO1xuXG4gIHB1YmxpYyBmbG93SGVpZ2h0OiBTaWduYWw8c3RyaW5nIHwgbnVtYmVyPiA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCB2aWV3ID0gdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLnZpZXcoKTtcblxuICAgIHJldHVybiB2aWV3ID09PSAnYXV0bycgPyAnMTAwJScgOiB2aWV3WzFdO1xuICB9KTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICByZXNpemFibGUoW3RoaXMuaG9zdC5uYXRpdmVFbGVtZW50XSwgaW5qZWN0KE5nWm9uZSkpXG4gICAgICAucGlwZShcbiAgICAgICAgdGFwKChbZW50cnldKSA9PiB7XG4gICAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd1dpZHRoLnNldChlbnRyeS5jb250ZW50UmVjdC53aWR0aCk7XG4gICAgICAgICAgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmNvbXB1dGVkRmxvd0hlaWdodC5zZXQoZW50cnkuY29udGVudFJlY3QuaGVpZ2h0KTtcbiAgICAgICAgfSksXG4gICAgICAgIHRha2VVbnRpbERlc3Ryb3llZCgpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, ElementRef, inject, input
|
|
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() {
|
|
@@ -38,4 +38,4 @@ function getChildStrokeWidth(element) {
|
|
|
38
38
|
}
|
|
39
39
|
return 0;
|
|
40
40
|
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLXNpemUtY29udHJvbGxlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9oYW5kbGUtc2l6ZS1jb250cm9sbGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPcEYsTUFBTSxPQUFPLDZCQUE2QjtJQUoxQztRQUtTLGdCQUFXLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBYztZQUMvQyxLQUFLLEVBQUUsc0JBQXNCO1NBQzlCLENBQUMsQ0FBQztRQUVLLGtCQUFhLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBNEIsQ0FBQztLQVl2RTtJQVZRLGVBQWU7UUFDcEIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUM7UUFDakQsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBRS9CLE1BQU0sTUFBTSxHQUFHLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQzFCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU07WUFDMUIsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTTtTQUM3QixDQUFDLENBQUM7SUFDTCxDQUFDOytHQWhCVSw2QkFBNkI7bUdBQTdCLDZCQUE2Qjs7NEZBQTdCLDZCQUE2QjtrQkFKekMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHdCQUF3QjtpQkFDbkM7O0FBb0JELFNBQVMsbUJBQW1CLENBQUMsT0FBb0I7SUFDL0MsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDO0lBRXhDLElBQUksS0FBSyxFQUFFLENBQUM7UUFDVixNQUFNLE1BQU0sR0FBRyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLENBQUM7UUFDbkQsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFeEQsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQztZQUMxQixPQUFPLENBQUMsQ0FBQztRQUNYLENBQUM7UUFFRCxPQUFPLGNBQWMsQ0FBQztJQUN4QixDQUFDO0lBRUQsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbaGFuZGxlU2l6ZUNvbnRyb2xsZXJdJyxcbn0pXG5leHBvcnQgY2xhc3MgSGFuZGxlU2l6ZUNvbnRyb2xsZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgcHVibGljIGhhbmRsZU1vZGVsID0gaW5wdXQucmVxdWlyZWQ8SGFuZGxlTW9kZWw+KHtcbiAgICBhbGlhczogJ2hhbmRsZVNpemVDb250cm9sbGVyJyxcbiAgfSk7XG5cbiAgcHJpdmF0ZSBoYW5kbGVXcmFwcGVyID0gaW5qZWN0KEVsZW1lbnRSZWYpIGFzIEVsZW1lbnRSZWY8U1ZHR0VsZW1lbnQ+O1xuXG4gIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgY29uc3QgZWxlbWVudCA9IHRoaXMuaGFuZGxlV3JhcHBlci5uYXRpdmVFbGVtZW50O1xuICAgIGNvbnN0IHJlY3QgPSBlbGVtZW50LmdldEJCb3goKTtcblxuICAgIGNvbnN0IHN0cm9rZSA9IGdldENoaWxkU3Ryb2tlV2lkdGgoZWxlbWVudCk7XG4gICAgdGhpcy5oYW5kbGVNb2RlbCgpLnNpemUuc2V0KHtcbiAgICAgIHdpZHRoOiByZWN0LndpZHRoICsgc3Ryb2tlLFxuICAgICAgaGVpZ2h0OiByZWN0LmhlaWdodCArIHN0cm9rZSxcbiAgICB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRDaGlsZFN0cm9rZVdpZHRoKGVsZW1lbnQ6IFNWR0dFbGVtZW50KSB7XG4gIGNvbnN0IGNoaWxkID0gZWxlbWVudC5maXJzdEVsZW1lbnRDaGlsZDtcblxuICBpZiAoY2hpbGQpIHtcbiAgICBjb25zdCBzdHJva2UgPSBnZXRDb21wdXRlZFN0eWxlKGNoaWxkKS5zdHJva2VXaWR0aDtcbiAgICBjb25zdCBzdHJva2VBc051bWJlciA9IE51bWJlcihzdHJva2UucmVwbGFjZSgncHgnLCAnJykpO1xuXG4gICAgaWYgKGlzTmFOKHN0cm9rZUFzTnVtYmVyKSkge1xuICAgICAgcmV0dXJuIDA7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0cm9rZUFzTnVtYmVyO1xuICB9XG5cbiAgcmV0dXJuIDA7XG59XG4iXX0=
|
|
@@ -25,25 +25,25 @@ export class MapContextDirective {
|
|
|
25
25
|
return;
|
|
26
26
|
}
|
|
27
27
|
// If only zoom provided
|
|
28
|
-
if (isDefined(state.zoom) &&
|
|
29
|
-
this.rootSvgSelection
|
|
30
|
-
.transition().duration(viewport.duration)
|
|
31
|
-
.call(this.zoomBehavior.scaleTo, state.zoom);
|
|
28
|
+
if (isDefined(state.zoom) && !isDefined(state.x) && !isDefined(state.y)) {
|
|
29
|
+
this.rootSvgSelection.transition().duration(viewport.duration).call(this.zoomBehavior.scaleTo, state.zoom);
|
|
32
30
|
return;
|
|
33
31
|
}
|
|
34
32
|
// If only pan provided
|
|
35
|
-
if (
|
|
33
|
+
if (isDefined(state.x) && isDefined(state.y) && !isDefined(state.zoom)) {
|
|
36
34
|
// remain same zoom value
|
|
37
35
|
const zoom = untracked(this.viewportService.readableViewport).zoom;
|
|
38
36
|
this.rootSvgSelection
|
|
39
|
-
.transition()
|
|
37
|
+
.transition()
|
|
38
|
+
.duration(viewport.duration)
|
|
40
39
|
.call(this.zoomBehavior.transform, zoomIdentity.translate(state.x, state.y).scale(zoom));
|
|
41
40
|
return;
|
|
42
41
|
}
|
|
43
42
|
// If whole viewort state provided
|
|
44
43
|
if (isDefined(state.x) && isDefined(state.y) && isDefined(state.zoom)) {
|
|
45
44
|
this.rootSvgSelection
|
|
46
|
-
.transition()
|
|
45
|
+
.transition()
|
|
46
|
+
.duration(viewport.duration)
|
|
47
47
|
.call(this.zoomBehavior.transform, zoomIdentity.translate(state.x, state.y).scale(state.zoom));
|
|
48
48
|
return;
|
|
49
49
|
}
|
|
@@ -55,14 +55,14 @@ export class MapContextDirective {
|
|
|
55
55
|
};
|
|
56
56
|
this.handleZoomStart = ({ transform }) => {
|
|
57
57
|
this.viewportForSelection = {
|
|
58
|
-
start: mapTransformToViewportState(transform)
|
|
58
|
+
start: mapTransformToViewportState(transform),
|
|
59
59
|
};
|
|
60
60
|
};
|
|
61
61
|
this.handleZoomEnd = ({ transform, sourceEvent }) => {
|
|
62
62
|
this.viewportForSelection = {
|
|
63
63
|
...this.viewportForSelection,
|
|
64
64
|
end: mapTransformToViewportState(transform),
|
|
65
|
-
target: evTarget(sourceEvent)
|
|
65
|
+
target: evTarget(sourceEvent),
|
|
66
66
|
};
|
|
67
67
|
this.selectionService.setViewport(this.viewportForSelection);
|
|
68
68
|
};
|
|
@@ -80,9 +80,7 @@ export class MapContextDirective {
|
|
|
80
80
|
.on('start', this.handleZoomStart)
|
|
81
81
|
.on('zoom', this.handleZoom)
|
|
82
82
|
.on('end', this.handleZoomEnd);
|
|
83
|
-
this.rootSvgSelection
|
|
84
|
-
.call(this.zoomBehavior)
|
|
85
|
-
.on('dblclick.zoom', null);
|
|
83
|
+
this.rootSvgSelection.call(this.zoomBehavior).on('dblclick.zoom', null);
|
|
86
84
|
}
|
|
87
85
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MapContextDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
88
86
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: MapContextDirective, isStandalone: true, selector: "g[mapContext]", ngImport: i0 }); }
|
|
@@ -94,11 +92,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
94
92
|
selector: 'g[mapContext]',
|
|
95
93
|
}]
|
|
96
94
|
}] });
|
|
97
|
-
const mapTransformToViewportState = (transform) => ({
|
|
95
|
+
const mapTransformToViewportState = (transform) => ({
|
|
96
|
+
zoom: transform.k,
|
|
97
|
+
x: transform.x,
|
|
98
|
+
y: transform.y,
|
|
99
|
+
});
|
|
98
100
|
const evTarget = (anyEvent) => {
|
|
99
101
|
if (anyEvent instanceof Event && anyEvent.target instanceof Element) {
|
|
100
102
|
return anyEvent.target;
|
|
101
103
|
}
|
|
102
104
|
return undefined;
|
|
103
105
|
};
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-context.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/map-context.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnInit, effect, inject, untracked } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3ZoomEvent, ZoomBehavior, ZoomTransform, zoom, zoomIdentity } from 'd3-zoom';\nimport { ViewportService } from '../services/viewport.service';\nimport { isDefined } from '../utils/is-defined';\nimport { RootSvgReferenceDirective } from './reference.directive';\nimport { ViewportState } from '../interfaces/viewport.interface';\nimport { SelectionService, ViewportForSelection } from '../services/selection.service';\nimport { FlowSettingsService } from '../services/flow-settings.service';\n\n@Directive({\n  standalone: true,\n  selector: 'g[mapContext]',\n})\nexport class MapContextDirective implements OnInit {\n  protected rootSvg = inject(RootSvgReferenceDirective).element\n  protected host = inject<ElementRef<SVGGElement>>(ElementRef).nativeElement\n  protected selectionService = inject(SelectionService)\n  protected viewportService = inject(ViewportService)\n  protected flowSettingsService = inject(FlowSettingsService);\n\n  protected rootSvgSelection = select(this.rootSvg)\n  protected zoomableSelection = select(this.host)\n\n  protected viewportForSelection: Partial<ViewportForSelection> = {}\n\n  // under the hood this effect triggers handleZoom, so error throws without this flag\n  protected manualViewportChangeEffect = effect(() => {\n    const viewport = this.viewportService.writableViewport()\n    const state = viewport.state\n\n    if (viewport.changeType === 'initial') {\n      return\n    }\n\n    // If only zoom provided\n    if (isDefined(state.zoom) && (!isDefined(state.x) && !isDefined(state.y))) {\n      this.rootSvgSelection\n        .transition().duration(viewport.duration)\n        .call(this.zoomBehavior.scaleTo, state.zoom)\n\n      return\n    }\n\n    // If only pan provided\n    if ((isDefined(state.x) && isDefined(state.y)) && !isDefined(state.zoom)) {\n      // remain same zoom value\n      const zoom = untracked(this.viewportService.readableViewport).zoom\n\n      this.rootSvgSelection\n        .transition().duration(viewport.duration)\n        .call(\n          this.zoomBehavior.transform,\n          zoomIdentity.translate(state.x, state.y).scale(zoom)\n        )\n\n      return\n    }\n\n    // If whole viewort state provided\n    if (isDefined(state.x) && isDefined(state.y) && isDefined(state.zoom)) {\n      this.rootSvgSelection\n        .transition().duration(viewport.duration)\n        .call(\n          this.zoomBehavior.transform,\n          zoomIdentity.translate(state.x, state.y).scale(state.zoom),\n        )\n\n      return\n    }\n  }, { allowSignalWrites: true })\n\n  protected zoomBehavior!: ZoomBehavior<SVGSVGElement, unknown>;\n\n  public ngOnInit(): void {\n    this.zoomBehavior = zoom<SVGSVGElement, unknown>()\n      .scaleExtent([this.flowSettingsService.minZoom(), this.flowSettingsService.maxZoom()])\n      .filter(this.filterCondition)\n      .on('start', this.handleZoomStart)\n      .on('zoom', this.handleZoom)\n      .on('end', this.handleZoomEnd)\n\n    this.rootSvgSelection\n      .call(this.zoomBehavior)\n      .on('dblclick.zoom', null)\n  }\n\n  private handleZoom = ({ transform }: ZoomEvent) => {\n    // update public signal for user to read\n    this.viewportService.readableViewport.set(mapTransformToViewportState(transform))\n\n    this.zoomableSelection.attr('transform', transform.toString())\n  }\n\n  private handleZoomStart = ({ transform }: ZoomEvent) => {\n    this.viewportForSelection = {\n      start: mapTransformToViewportState(transform)\n    }\n  }\n\n  private handleZoomEnd = ({ transform, sourceEvent }: ZoomEvent) => {\n    this.viewportForSelection = {\n      ...this.viewportForSelection,\n      end: mapTransformToViewportState(transform),\n      target: evTarget(sourceEvent)\n    }\n\n    this.selectionService.setViewport(\n      this.viewportForSelection as ViewportForSelection\n    )\n  }\n\n  private filterCondition = (event: Event) => {\n    if (event.type === 'mousedown' || event.type === 'touchstart') {\n      return (event.target as Element).closest('.vflow-node') === null\n    }\n\n    return true\n  }\n}\n\nconst mapTransformToViewportState = (transform: ZoomTransform): ViewportState =>\n  ({ zoom: transform.k, x: transform.x, y: transform.y })\n\nconst evTarget = (anyEvent: any): Element | undefined => {\n  if (anyEvent instanceof Event && anyEvent.target instanceof Element) {\n    return anyEvent.target\n  }\n\n  return undefined;\n}\n\ndeclare module 'd3-selection' {\n  interface Selection<GElement extends BaseType, Datum, PElement extends BaseType, PDatum> {\n    transition(): Selection<GElement, Datum, PElement, PDatum>\n    duration(duration: number): Selection<GElement, Datum, PElement, PDatum>\n  }\n}\n\ntype ZoomEvent = D3ZoomEvent<SVGSVGElement, unknown>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-context.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/map-context.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, OnInit, effect, inject, untracked } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3ZoomEvent, ZoomBehavior, ZoomTransform, zoom, zoomIdentity } from 'd3-zoom';\nimport { ViewportService } from '../services/viewport.service';\nimport { isDefined } from '../utils/is-defined';\nimport { RootSvgReferenceDirective } from './reference.directive';\nimport { ViewportState } from '../interfaces/viewport.interface';\nimport { SelectionService, ViewportForSelection } from '../services/selection.service';\nimport { FlowSettingsService } from '../services/flow-settings.service';\n\n@Directive({\n  standalone: true,\n  selector: 'g[mapContext]',\n})\nexport class MapContextDirective implements OnInit {\n  protected rootSvg = inject(RootSvgReferenceDirective).element;\n  protected host = inject<ElementRef<SVGGElement>>(ElementRef).nativeElement;\n  protected selectionService = inject(SelectionService);\n  protected viewportService = inject(ViewportService);\n  protected flowSettingsService = inject(FlowSettingsService);\n\n  protected rootSvgSelection = select(this.rootSvg);\n  protected zoomableSelection = select(this.host);\n\n  protected viewportForSelection: Partial<ViewportForSelection> = {};\n\n  // under the hood this effect triggers handleZoom, so error throws without this flag\n  protected manualViewportChangeEffect = effect(\n    () => {\n      const viewport = this.viewportService.writableViewport();\n      const state = viewport.state;\n\n      if (viewport.changeType === 'initial') {\n        return;\n      }\n\n      // If only zoom provided\n      if (isDefined(state.zoom) && !isDefined(state.x) && !isDefined(state.y)) {\n        this.rootSvgSelection.transition().duration(viewport.duration).call(this.zoomBehavior.scaleTo, state.zoom);\n\n        return;\n      }\n\n      // If only pan provided\n      if (isDefined(state.x) && isDefined(state.y) && !isDefined(state.zoom)) {\n        // remain same zoom value\n        const zoom = untracked(this.viewportService.readableViewport).zoom;\n\n        this.rootSvgSelection\n          .transition()\n          .duration(viewport.duration)\n          .call(this.zoomBehavior.transform, zoomIdentity.translate(state.x, state.y).scale(zoom));\n\n        return;\n      }\n\n      // If whole viewort state provided\n      if (isDefined(state.x) && isDefined(state.y) && isDefined(state.zoom)) {\n        this.rootSvgSelection\n          .transition()\n          .duration(viewport.duration)\n          .call(this.zoomBehavior.transform, zoomIdentity.translate(state.x, state.y).scale(state.zoom));\n\n        return;\n      }\n    },\n    { allowSignalWrites: true },\n  );\n\n  protected zoomBehavior!: ZoomBehavior<SVGSVGElement, unknown>;\n\n  public ngOnInit(): void {\n    this.zoomBehavior = zoom<SVGSVGElement, unknown>()\n      .scaleExtent([this.flowSettingsService.minZoom(), this.flowSettingsService.maxZoom()])\n      .filter(this.filterCondition)\n      .on('start', this.handleZoomStart)\n      .on('zoom', this.handleZoom)\n      .on('end', this.handleZoomEnd);\n\n    this.rootSvgSelection.call(this.zoomBehavior).on('dblclick.zoom', null);\n  }\n\n  private handleZoom = ({ transform }: ZoomEvent) => {\n    // update public signal for user to read\n    this.viewportService.readableViewport.set(mapTransformToViewportState(transform));\n\n    this.zoomableSelection.attr('transform', transform.toString());\n  };\n\n  private handleZoomStart = ({ transform }: ZoomEvent) => {\n    this.viewportForSelection = {\n      start: mapTransformToViewportState(transform),\n    };\n  };\n\n  private handleZoomEnd = ({ transform, sourceEvent }: ZoomEvent) => {\n    this.viewportForSelection = {\n      ...this.viewportForSelection,\n      end: mapTransformToViewportState(transform),\n      target: evTarget(sourceEvent),\n    };\n\n    this.selectionService.setViewport(this.viewportForSelection as ViewportForSelection);\n  };\n\n  private filterCondition = (event: Event) => {\n    if (event.type === 'mousedown' || event.type === 'touchstart') {\n      return (event.target as Element).closest('.vflow-node') === null;\n    }\n\n    return true;\n  };\n}\n\nconst mapTransformToViewportState = (transform: ZoomTransform): ViewportState => ({\n  zoom: transform.k,\n  x: transform.x,\n  y: transform.y,\n});\n\nconst evTarget = (anyEvent: any): Element | undefined => {\n  if (anyEvent instanceof Event && anyEvent.target instanceof Element) {\n    return anyEvent.target;\n  }\n\n  return undefined;\n};\n\ndeclare module 'd3-selection' {\n  interface Selection<GElement extends BaseType, Datum, PElement extends BaseType, PDatum> {\n    transition(): Selection<GElement, Datum, PElement, PDatum>;\n    duration(duration: number): Selection<GElement, Datum, PElement, PDatum>;\n  }\n}\n\ntype ZoomEvent = D3ZoomEvent<SVGSVGElement, unknown>;\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, ElementRef, HostListener, inject, output
|
|
1
|
+
import { Directive, ElementRef, HostListener, inject, output } from '@angular/core';
|
|
2
2
|
import { filter, tap } from 'rxjs';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { RootPointerDirective } from './root-pointer.directive';
|
|
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
80
80
|
type: HostListener,
|
|
81
81
|
args: ['mouseout', ['$event']]
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnRlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9wb2ludGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFNaEUsTUFBTSxPQUFPLGdCQUFnQjtJQUo3QjtRQUtZLGdCQUFXLEdBQUcsTUFBTSxDQUFzQixVQUFVLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDcEUsNkJBQXdCLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFFL0MsZ0JBQVcsR0FBRyxNQUFNLEVBQVMsQ0FBQztRQUU5QixlQUFVLEdBQUcsTUFBTSxFQUFTLENBQUM7UUFFaEQ7OztXQUdHO1FBQ2dCLGlCQUFZLEdBQUcsTUFBTSxFQUFTLENBQUM7UUFFL0IsZUFBVSxHQUFHLE1BQU0sRUFBUyxDQUFDO1FBMkJ4QyxtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUUvQiwrQ0FBK0M7UUFDckMsYUFBUSxHQUFHLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxTQUFTO2FBQ3pELElBQUksQ0FDSCxNQUFNLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUNuRCxHQUFHLENBQUMsQ0FBQyxFQUFFLGFBQWEsRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxFQUMvRCxrQkFBa0IsRUFBRSxDQUNyQjthQUNBLFNBQVMsRUFBRSxDQUFDO1FBRUwsaUJBQVksR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsY0FBYzthQUNsRSxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsYUFBYSxFQUFFLEVBQUUsRUFBRTtZQUNoQyxJQUFJLENBQUMscUJBQXFCLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQ3BELENBQUMsQ0FBQyxFQUNGLGtCQUFrQixFQUFFLENBQ3JCO2FBQ0EsU0FBUyxFQUFFLENBQUM7S0FnQmhCO0lBekRXLGNBQWMsQ0FBQyxLQUFZO1FBQ25DLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTlCLElBQUksS0FBSyxZQUFZLFVBQVUsRUFBRSxDQUFDO1lBQ2hDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkQsQ0FBQztJQUNILENBQUM7SUFHUyxZQUFZLENBQUMsS0FBWTtRQUNqQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBR1MsV0FBVyxDQUFDLEtBQVk7UUFDaEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUdTLFVBQVUsQ0FBQyxLQUFZO1FBQy9CLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFzQkQsd0NBQXdDO0lBQ2hDLHFCQUFxQixDQUFDLE1BQXNCLEVBQUUsS0FBaUI7UUFDckUsSUFBSSxNQUFNLEtBQUssSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2hDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzdCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQzdCLENBQUM7YUFBTSxDQUFDO1lBQ04scUNBQXFDO1lBQ3JDLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO2dCQUN4QixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM5QixDQUFDO1lBRUQsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUM7UUFDOUIsQ0FBQztJQUNILENBQUM7K0dBMUVVLGdCQUFnQjttR0FBaEIsZ0JBQWdCOzs0RkFBaEIsZ0JBQWdCO2tCQUo1QixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsMkRBQTJEO2lCQUN0RTs4QkFtQlcsY0FBYztzQkFGdkIsWUFBWTt1QkFBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUM7O3NCQUNwQyxZQUFZO3VCQUFDLFlBQVksRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFVNUIsWUFBWTtzQkFEckIsWUFBWTt1QkFBQyxTQUFTLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBTXpCLFdBQVc7c0JBRHBCLFlBQVk7dUJBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQU0zQixVQUFVO3NCQURuQixZQUFZO3VCQUFDLFVBQVUsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBpbmplY3QsIG91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZmlsdGVyLCB0YXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7IFJvb3RQb2ludGVyRGlyZWN0aXZlIH0gZnJvbSAnLi9yb290LXBvaW50ZXIuZGlyZWN0aXZlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW3BvaW50ZXJTdGFydF0sIFtwb2ludGVyRW5kXSwgW3BvaW50ZXJPdmVyXSwgW3BvaW50ZXJPdXRdJyxcbn0pXG5leHBvcnQgY2xhc3MgUG9pbnRlckRpcmVjdGl2ZSB7XG4gIHByb3RlY3RlZCBob3N0RWxlbWVudCA9IGluamVjdDxFbGVtZW50UmVmPEVsZW1lbnQ+PihFbGVtZW50UmVmKS5uYXRpdmVFbGVtZW50O1xuICBwcm90ZWN0ZWQgcG9pbnRlck1vdmVtZW50RGlyZWN0aXZlID0gaW5qZWN0KFJvb3RQb2ludGVyRGlyZWN0aXZlKTtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgcG9pbnRlck92ZXIgPSBvdXRwdXQ8RXZlbnQ+KCk7XG5cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHBvaW50ZXJPdXQgPSBvdXRwdXQ8RXZlbnQ+KCk7XG5cbiAgLyoqXG4gICAqIEB0b2RvIHRoZSBBbmd1bGFyIG1heSBzb21laG93IGlnbm9yZSB0aGUgZXZlbnQuXG4gICAqIHJlcHJvZHVjZWQgaGVyZTogaHR0cHM6Ly93d3cubmd4LXZmbG93Lm9yZy93b3Jrc2hvcHMvbGF5b3V0L3ZpemRvbS1sYXlvdXRcbiAgICovXG4gIHByb3RlY3RlZCByZWFkb25seSBwb2ludGVyU3RhcnQgPSBvdXRwdXQ8RXZlbnQ+KCk7XG5cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHBvaW50ZXJFbmQgPSBvdXRwdXQ8RXZlbnQ+KCk7XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2Vkb3duJywgWyckZXZlbnQnXSlcbiAgQEhvc3RMaXN0ZW5lcigndG91Y2hzdGFydCcsIFsnJGV2ZW50J10pXG4gIHByb3RlY3RlZCBvblBvaW50ZXJTdGFydChldmVudDogRXZlbnQpIHtcbiAgICB0aGlzLnBvaW50ZXJTdGFydC5lbWl0KGV2ZW50KTtcblxuICAgIGlmIChldmVudCBpbnN0YW5jZW9mIFRvdWNoRXZlbnQpIHtcbiAgICAgIHRoaXMucG9pbnRlck1vdmVtZW50RGlyZWN0aXZlLnNldEluaXRpYWxUb3VjaChldmVudCk7XG4gICAgfVxuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2V1cCcsIFsnJGV2ZW50J10pXG4gIHByb3RlY3RlZCBvblBvaW50ZXJFbmQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgdGhpcy5wb2ludGVyRW5kLmVtaXQoZXZlbnQpO1xuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2VvdmVyJywgWyckZXZlbnQnXSlcbiAgcHJvdGVjdGVkIG9uTW91c2VPdmVyKGV2ZW50OiBFdmVudCkge1xuICAgIHRoaXMucG9pbnRlck92ZXIuZW1pdChldmVudCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdtb3VzZW91dCcsIFsnJGV2ZW50J10pXG4gIHByb3RlY3RlZCBvbk1vdXNlT3V0KGV2ZW50OiBFdmVudCkge1xuICAgIHRoaXMucG9pbnRlck91dC5lbWl0KGV2ZW50KTtcbiAgfVxuXG4gIHByaXZhdGUgd2FzUG9pbnRlck92ZXIgPSBmYWxzZTtcblxuICAvLyBUT0RPIGNoZWNrIGlmIGkgY291bGQgYXZvaWQgZ2xvYmFsIHRvdWNoIGVuZFxuICBwcm90ZWN0ZWQgdG91Y2hFbmQgPSB0aGlzLnBvaW50ZXJNb3ZlbWVudERpcmVjdGl2ZS50b3VjaEVuZCRcbiAgICAucGlwZShcbiAgICAgIGZpbHRlcigoeyB0YXJnZXQgfSkgPT4gdGFyZ2V0ID09PSB0aGlzLmhvc3RFbGVtZW50KSxcbiAgICAgIHRhcCgoeyBvcmlnaW5hbEV2ZW50IH0pID0+IHRoaXMucG9pbnRlckVuZC5lbWl0KG9yaWdpbmFsRXZlbnQpKSxcbiAgICAgIHRha2VVbnRpbERlc3Ryb3llZCgpLFxuICAgIClcbiAgICAuc3Vic2NyaWJlKCk7XG5cbiAgcHJvdGVjdGVkIHRvdWNoT3Zlck91dCA9IHRoaXMucG9pbnRlck1vdmVtZW50RGlyZWN0aXZlLnRvdWNoTW92ZW1lbnQkXG4gICAgLnBpcGUoXG4gICAgICB0YXAoKHsgdGFyZ2V0LCBvcmlnaW5hbEV2ZW50IH0pID0+IHtcbiAgICAgICAgdGhpcy5oYW5kbGVUb3VjaE92ZXJBbmRPdXQodGFyZ2V0LCBvcmlnaW5hbEV2ZW50KTtcbiAgICAgIH0pLFxuICAgICAgdGFrZVVudGlsRGVzdHJveWVkKCksXG4gICAgKVxuICAgIC5zdWJzY3JpYmUoKTtcblxuICAvLyBUT0RPOiBkaXJ0eSBpbXBlcmF0aXZlIGltcGxlbWVudGF0aW9uXG4gIHByaXZhdGUgaGFuZGxlVG91Y2hPdmVyQW5kT3V0KHRhcmdldDogRWxlbWVudCB8IG51bGwsIGV2ZW50OiBUb3VjaEV2ZW50KSB7XG4gICAgaWYgKHRhcmdldCA9PT0gdGhpcy5ob3N0RWxlbWVudCkge1xuICAgICAgdGhpcy5wb2ludGVyT3Zlci5lbWl0KGV2ZW50KTtcbiAgICAgIHRoaXMud2FzUG9pbnRlck92ZXIgPSB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBzaG91bGQgbm90IGVtaXQgYmVmb3JlIHBvaW50ZXJPdmVyXG4gICAgICBpZiAodGhpcy53YXNQb2ludGVyT3Zlcikge1xuICAgICAgICB0aGlzLnBvaW50ZXJPdXQuZW1pdChldmVudCk7XG4gICAgICB9XG5cbiAgICAgIHRoaXMud2FzUG9pbnRlck92ZXIgPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -14,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
14
14
|
selector: 'svg[rootSvgRef]',
|
|
15
15
|
}]
|
|
16
16
|
}] });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmZXJlbmNlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9kaXJlY3RpdmVzL3JlZmVyZW5jZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU05RCxNQUFNLE9BQU8seUJBQXlCO0lBSnRDO1FBS2tCLFlBQU8sR0FBRyxNQUFNLENBQTRCLFVBQVUsQ0FBQyxDQUFDLGFBQWEsQ0FBQztLQUN2RjsrR0FGWSx5QkFBeUI7bUdBQXpCLHlCQUF5Qjs7NEZBQXpCLHlCQUF5QjtrQkFKckMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGlCQUFpQjtpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdzdmdbcm9vdFN2Z1JlZl0nLFxufSlcbmV4cG9ydCBjbGFzcyBSb290U3ZnUmVmZXJlbmNlRGlyZWN0aXZlIHtcbiAgcHVibGljIHJlYWRvbmx5IGVsZW1lbnQgPSBpbmplY3Q8RWxlbWVudFJlZjxTVkdTVkdFbGVtZW50Pj4oRWxlbWVudFJlZikubmF0aXZlRWxlbWVudDtcbn1cbiJdfQ==
|