ngx-vflow 0.16.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.
- package/README.md +8 -1
- package/esm2022/lib/vflow/components/background/background.component.mjs +6 -7
- package/esm2022/lib/vflow/components/connection/connection.component.mjs +66 -53
- package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +32 -25
- package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +9 -11
- package/esm2022/lib/vflow/components/defs/defs.component.mjs +9 -12
- package/esm2022/lib/vflow/components/edge/edge.component.mjs +21 -24
- package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +26 -31
- package/esm2022/lib/vflow/components/node/node.component.mjs +54 -50
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +93 -91
- package/esm2022/lib/vflow/decorators/run-in-injection-context.decorator.mjs +1 -1
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +41 -125
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +16 -16
- package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +7 -6
- package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +15 -12
- package/esm2022/lib/vflow/directives/map-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/pointer.directive.mjs +18 -19
- package/esm2022/lib/vflow/directives/reference.directive.mjs +6 -5
- package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +10 -7
- package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +8 -5
- package/esm2022/lib/vflow/directives/template.directive.mjs +43 -25
- package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/node.interface.mjs +1 -1
- package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +1 -1
- package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +1 -1
- package/esm2022/lib/vflow/models/connection.model.mjs +1 -1
- package/esm2022/lib/vflow/models/edge.model.mjs +1 -1
- package/esm2022/lib/vflow/models/handle.model.mjs +2 -2
- package/esm2022/lib/vflow/models/node.model.mjs +4 -10
- package/esm2022/lib/vflow/models/toolbar.model.mjs +1 -1
- package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +16 -10
- package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +15 -10
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +52 -0
- package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +35 -44
- package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +24 -27
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +60 -45
- package/esm2022/lib/vflow/services/component-event-bus.service.mjs +3 -3
- package/esm2022/lib/vflow/services/draggable.service.mjs +4 -4
- package/esm2022/lib/vflow/services/edge-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/flow-entities.service.mjs +4 -4
- package/esm2022/lib/vflow/services/flow-settings.service.mjs +4 -10
- package/esm2022/lib/vflow/services/flow-status.service.mjs +4 -4
- package/esm2022/lib/vflow/services/handle.service.mjs +4 -4
- package/esm2022/lib/vflow/services/keyboard.service.mjs +5 -5
- package/esm2022/lib/vflow/services/node-accessor.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-changes.service.mjs +3 -3
- package/esm2022/lib/vflow/services/node-rendering.service.mjs +3 -3
- package/esm2022/lib/vflow/services/overlays.service.mjs +3 -3
- package/esm2022/lib/vflow/services/selection.service.mjs +4 -4
- package/esm2022/lib/vflow/services/viewport.service.mjs +3 -3
- package/esm2022/lib/vflow/utils/adjust-direction.mjs +1 -1
- package/esm2022/lib/vflow/utils/get-os.mjs +1 -1
- package/esm2022/lib/vflow/utils/nodes.mjs +1 -1
- package/esm2022/lib/vflow/vflow.mjs +24 -0
- package/esm2022/public-api.mjs +4 -5
- package/fesm2022/ngx-vflow.mjs +914 -1022
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/background/background.component.d.ts +3 -3
- package/lib/vflow/components/connection/connection.component.d.ts +3 -3
- package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +4 -9
- package/lib/vflow/components/default-node/default-node.component.d.ts +2 -2
- package/lib/vflow/components/defs/defs.component.d.ts +2 -2
- package/lib/vflow/components/edge/edge.component.d.ts +7 -7
- package/lib/vflow/components/edge-label/edge-label.component.d.ts +9 -8
- package/lib/vflow/components/node/node.component.d.ts +5 -6
- package/lib/vflow/components/vflow/vflow.component.d.ts +19 -29
- package/lib/vflow/directives/changes-controller.directive.d.ts +29 -30
- package/lib/vflow/directives/connection-controller.directive.d.ts +1 -2
- package/lib/vflow/directives/drag-handle.directive.d.ts +1 -1
- package/lib/vflow/directives/flow-size-controller.directive.d.ts +1 -1
- package/lib/vflow/directives/handle-size-controller.directive.d.ts +2 -2
- package/lib/vflow/directives/map-context.directive.d.ts +1 -1
- package/lib/vflow/directives/pointer.directive.d.ts +9 -6
- package/lib/vflow/directives/reference.directive.d.ts +1 -1
- package/lib/vflow/directives/root-pointer.directive.d.ts +1 -1
- package/lib/vflow/directives/root-svg-context.directive.d.ts +1 -1
- package/lib/vflow/directives/selectable.directive.d.ts +1 -1
- package/lib/vflow/directives/space-point-context.directive.d.ts +1 -1
- package/lib/vflow/directives/template.directive.d.ts +6 -6
- package/lib/vflow/interfaces/component-node-event.interface.d.ts +3 -3
- package/lib/vflow/interfaces/node.interface.d.ts +14 -14
- package/lib/vflow/interfaces/optimization.interface.d.ts +0 -7
- package/lib/vflow/models/edge.model.d.ts +1 -17
- package/lib/vflow/models/handle.model.d.ts +4 -4
- package/lib/vflow/models/node.model.d.ts +2 -5
- package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +3 -3
- package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +3 -3
- package/lib/vflow/{components → public-components}/handle/handle.component.d.ts +5 -5
- package/lib/vflow/public-components/minimap/minimap.component.d.ts +8 -10
- package/lib/vflow/public-components/node-toolbar/node-toolbar.component.d.ts +6 -5
- package/lib/vflow/public-components/resizable/resizable.component.d.ts +5 -4
- package/lib/vflow/services/flow-settings.service.d.ts +0 -7
- package/lib/vflow/utils/reference-keeper.d.ts +1 -1
- package/lib/vflow/vflow.d.ts +9 -0
- package/package.json +3 -3
- package/public-api.d.ts +2 -3
- package/esm2022/lib/vflow/components/handle/handle.component.mjs +0 -49
- package/esm2022/lib/vflow/interfaces/handle-positions.interface.mjs +0 -2
- package/esm2022/lib/vflow/vflow.module.mjs +0 -121
- package/lib/vflow/interfaces/handle-positions.interface.d.ts +0 -5
- package/lib/vflow/vflow.module.d.ts +0 -30
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import { Component, computed, inject, Injector,
|
|
1
|
+
import { Component, computed, inject, Injector, signal, input, viewChild, } from '@angular/core';
|
|
2
2
|
import { FlowEntitiesService } from '../../services/flow-entities.service';
|
|
3
3
|
import { MinimapModel } from '../../models/minimap.model';
|
|
4
4
|
import { FlowSettingsService } from '../../services/flow-settings.service';
|
|
5
5
|
import { getViewportForBounds } from '../../utils/viewport';
|
|
6
6
|
import { getNodesBounds } from '../../utils/nodes';
|
|
7
7
|
import { ViewportService } from '../../services/viewport.service';
|
|
8
|
+
import { DefaultNodeComponent } from '../../components/default-node/default-node.component';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/common";
|
|
10
|
-
import * as i2 from "../../components/default-node/default-node.component";
|
|
11
10
|
export class MiniMapComponent {
|
|
12
11
|
constructor() {
|
|
13
12
|
this.entitiesService = inject(FlowEntitiesService);
|
|
@@ -17,14 +16,23 @@ export class MiniMapComponent {
|
|
|
17
16
|
/**
|
|
18
17
|
* The color outside the viewport (invisible area)
|
|
19
18
|
*/
|
|
20
|
-
this.maskColor = `rgba(215, 215, 215, 0.6)
|
|
19
|
+
this.maskColor = input(`rgba(215, 215, 215, 0.6)`);
|
|
21
20
|
/**
|
|
22
21
|
* The minimap stroke color
|
|
23
22
|
*/
|
|
24
|
-
this.strokeColor = `rgb(200, 200, 200)
|
|
23
|
+
this.strokeColor = input(`rgb(200, 200, 200)`);
|
|
24
|
+
/**
|
|
25
|
+
* The corner of the flow where to render a mini-map
|
|
26
|
+
*/
|
|
27
|
+
this.position = input('bottom-right');
|
|
28
|
+
/**
|
|
29
|
+
* Make a minimap bigger on hover
|
|
30
|
+
*/
|
|
31
|
+
this.scaleOnHover = input(false);
|
|
32
|
+
this.minimap = viewChild.required('minimap');
|
|
25
33
|
this.minimapOffset = 10;
|
|
26
34
|
this.minimapScale = computed(() => {
|
|
27
|
-
if (this.
|
|
35
|
+
if (this.scaleOnHover()) {
|
|
28
36
|
return this.hovered() ? 0.4 : 0.2;
|
|
29
37
|
}
|
|
30
38
|
return 0.2;
|
|
@@ -38,23 +46,31 @@ export class MiniMapComponent {
|
|
|
38
46
|
});
|
|
39
47
|
this.hovered = signal(false);
|
|
40
48
|
this.minimapPoint = computed(() => {
|
|
41
|
-
switch (this.
|
|
49
|
+
switch (this.position()) {
|
|
42
50
|
case 'top-left':
|
|
43
51
|
return { x: this.minimapOffset, y: this.minimapOffset };
|
|
44
52
|
case 'top-right':
|
|
45
53
|
return {
|
|
46
|
-
x: this.flowSettingsService.computedFlowWidth() -
|
|
47
|
-
|
|
54
|
+
x: this.flowSettingsService.computedFlowWidth() -
|
|
55
|
+
this.minimapWidth() -
|
|
56
|
+
this.minimapOffset,
|
|
57
|
+
y: this.minimapOffset,
|
|
48
58
|
};
|
|
49
59
|
case 'bottom-left':
|
|
50
60
|
return {
|
|
51
61
|
x: this.minimapOffset,
|
|
52
|
-
y: this.flowSettingsService.computedFlowHeight() -
|
|
62
|
+
y: this.flowSettingsService.computedFlowHeight() -
|
|
63
|
+
this.minimapHeight() -
|
|
64
|
+
this.minimapOffset,
|
|
53
65
|
};
|
|
54
66
|
case 'bottom-right':
|
|
55
67
|
return {
|
|
56
|
-
x: this.flowSettingsService.computedFlowWidth() -
|
|
57
|
-
|
|
68
|
+
x: this.flowSettingsService.computedFlowWidth() -
|
|
69
|
+
this.minimapWidth() -
|
|
70
|
+
this.minimapOffset,
|
|
71
|
+
y: this.flowSettingsService.computedFlowHeight() -
|
|
72
|
+
this.minimapHeight() -
|
|
73
|
+
this.minimapOffset,
|
|
58
74
|
};
|
|
59
75
|
}
|
|
60
76
|
});
|
|
@@ -81,45 +97,20 @@ export class MiniMapComponent {
|
|
|
81
97
|
const scale = vport.zoom * this.minimapScale();
|
|
82
98
|
return `translate(${x} ${y}) scale(${scale})`;
|
|
83
99
|
});
|
|
84
|
-
this.minimapPosition = signal('bottom-right');
|
|
85
|
-
this.scaleOnHoverSignal = signal(false);
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* The corner of the flow where to render a mini-map
|
|
89
|
-
*/
|
|
90
|
-
set position(value) {
|
|
91
|
-
this.minimapPosition.set(value);
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* Make a minimap bigger on hover
|
|
95
|
-
*/
|
|
96
|
-
set scaleOnHover(value) {
|
|
97
|
-
this.scaleOnHoverSignal.set(value);
|
|
98
100
|
}
|
|
99
101
|
ngOnInit() {
|
|
100
102
|
const model = new MinimapModel();
|
|
101
|
-
model.template.set(this.minimap);
|
|
103
|
+
model.template.set(this.minimap());
|
|
102
104
|
this.entitiesService.minimap.set(model);
|
|
103
105
|
}
|
|
104
106
|
trackNodes(idx, { node }) {
|
|
105
107
|
return node;
|
|
106
108
|
}
|
|
107
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
108
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
109
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiniMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MiniMapComponent, isStandalone: true, selector: "mini-map", inputs: { maskColor: { classPropertyName: "maskColor", publicName: "maskColor", isSignal: true, isRequired: false, transformFunction: null }, strokeColor: { classPropertyName: "strokeColor", publicName: "strokeColor", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null }, scaleOnHover: { classPropertyName: "scaleOnHover", publicName: "scaleOnHover", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "minimap", first: true, predicate: ["minimap"], descendants: true, isSignal: true }], ngImport: i0, template: "<ng-template #minimap>\n <svg:rect\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.stroke]=\"strokeColor()\"\n fill=\"none\"\n />\n\n <svg:svg\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n (mouseover)=\"hovered.set(true)\"\n (mouseleave)=\"hovered.set(false)\"\n >\n <svg:rect\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.fill]=\"maskColor()\"\n />\n\n <svg:g [attr.transform]=\"minimapTransform()\">\n <svg:rect\n [attr.fill]=\"viewportColor()\"\n [attr.transform]=\"viewportTransform()\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n />\n\n @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n <ng-container>\n @if (\n model.node.type === \"default\" ||\n model.node.type === \"html-template\" ||\n model.isComponentType\n ) {\n <svg:foreignObject\n [attr.transform]=\"model.pointTransform()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\"\n >\n <default-node\n [selected]=\"model.selected()\"\n [style.width.px]=\"model.size().width\"\n [style.height.px]=\"model.size().height\"\n [style.max-width.px]=\"model.size().width\"\n [style.max-height.px]=\"model.size().height\"\n >\n <div [outerHTML]=\"model.text()\"></div>\n </default-node>\n </svg:foreignObject>\n }\n @if (\n model.node.type === \"default-group\" ||\n model.node.type === \"template-group\"\n ) {\n <svg:rect\n class=\"default-group-node\"\n rx=\"5\"\n ry=\"5\"\n [attr.transform]=\"model.pointTransform()\"\n [class.default-group-node_selected]=\"model.selected()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\"\n [style.stroke]=\"model.color()\"\n [style.fill]=\"model.color()\"\n />\n }\n </ng-container>\n }\n </svg:g>\n </svg:svg>\n</ng-template>\n", styles: [".default-group-node{stroke-width:1.5px;fill-opacity:.05}.default-group-node_selected{stroke-width:2px}\n"], dependencies: [{ kind: "component", type: DefaultNodeComponent, selector: "default-node", inputs: ["selected"] }] }); }
|
|
109
111
|
}
|
|
110
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
112
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiniMapComponent, decorators: [{
|
|
111
113
|
type: Component,
|
|
112
|
-
args: [{ selector: 'mini-map', template: "<ng-template #minimap>\n <svg:rect\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.stroke]=\"strokeColor\"\n fill=\"none\"\n />\n\n <svg:svg\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n (mouseover)=\"hovered.set(true)\"\n (mouseleave)=\"hovered.set(false)\"\n >\n <svg:rect\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.fill]=\"maskColor\"\n />\n\n <svg:g [attr.transform]=\"minimapTransform()\">\n <svg:rect\n [attr.fill]=\"viewportColor()\"\n [attr.transform]=\"viewportTransform()\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n />\n\n
|
|
113
|
-
}]
|
|
114
|
-
type: Input
|
|
115
|
-
}], maskColor: [{
|
|
116
|
-
type: Input
|
|
117
|
-
}], strokeColor: [{
|
|
118
|
-
type: Input
|
|
119
|
-
}], scaleOnHover: [{
|
|
120
|
-
type: Input
|
|
121
|
-
}], minimap: [{
|
|
122
|
-
type: ViewChild,
|
|
123
|
-
args: ['minimap', { static: true }]
|
|
124
|
-
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"minimap.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/minimap/minimap.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/minimap/minimap.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, inject, Injector, Input, OnInit, signal, TemplateRef, ViewChild } from '@angular/core';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { MinimapModel } from '../../models/minimap.model';\nimport { NodeModel } from '../../models/node.model';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { getViewportForBounds } from '../../utils/viewport';\nimport { getNodesBounds } from '../../utils/nodes';\nimport { ViewportService } from '../../services/viewport.service';\n\nexport type MiniMapPosition = 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n\n@Component({\n  selector: 'mini-map',\n  templateUrl: './minimap.component.html',\n  styleUrls: [`./minimap.component.scss`]\n})\nexport class MiniMapComponent implements OnInit {\n  protected entitiesService = inject(FlowEntitiesService)\n  protected flowSettingsService = inject(FlowSettingsService)\n  protected viewportService = inject(ViewportService)\n  protected injector = inject(Injector)\n\n  /**\n   * The corner of the flow where to render a mini-map\n   */\n  @Input()\n  public set position(value: MiniMapPosition) {\n    this.minimapPosition.set(value)\n  }\n\n  /**\n   * The color outside the viewport (invisible area)\n   */\n  @Input()\n  public maskColor = `rgba(215, 215, 215, 0.6)`\n\n  /**\n   * The minimap stroke color\n   */\n  @Input()\n  public strokeColor = `rgb(200, 200, 200)`\n\n  /**\n   * Make a minimap bigger on hover\n   */\n  @Input()\n  public set scaleOnHover(value: boolean) {\n    this.scaleOnHoverSignal.set(value)\n  }\n\n  @ViewChild('minimap', { static: true })\n  private minimap!: TemplateRef<unknown>\n\n  private readonly minimapOffset = 10\n\n  private readonly minimapScale = computed(() => {\n    if (this.scaleOnHoverSignal()) {\n      return this.hovered() ? 0.4 : 0.2\n    }\n\n    return 0.2\n  })\n\n  protected viewportColor = computed(() => {\n    const bg = this.flowSettingsService.background()\n\n    if (bg.type === 'dots' || bg.type === 'solid') {\n      return bg.color ?? '#fff'\n    }\n\n    return '#fff'\n  })\n\n  protected hovered = signal(false)\n\n  protected minimapPoint = computed(() => {\n    switch (this.minimapPosition()) {\n      case 'top-left':\n        return { x: this.minimapOffset, y: this.minimapOffset }\n      case 'top-right':\n        return {\n          x: this.flowSettingsService.computedFlowWidth() - this.minimapWidth() - this.minimapOffset,\n          y: this.minimapOffset\n        }\n      case 'bottom-left':\n        return {\n          x: this.minimapOffset,\n          y: this.flowSettingsService.computedFlowHeight() - this.minimapHeight() - this.minimapOffset\n        }\n      case 'bottom-right':\n        return {\n          x: this.flowSettingsService.computedFlowWidth() - this.minimapWidth() - this.minimapOffset,\n          y: this.flowSettingsService.computedFlowHeight() - this.minimapHeight() - this.minimapOffset\n        }\n    }\n  })\n\n  protected minimapWidth = computed(() =>\n    this.flowSettingsService.computedFlowWidth() * this.minimapScale()\n  )\n  protected minimapHeight = computed(() =>\n    this.flowSettingsService.computedFlowHeight() * this.minimapScale()\n  )\n\n  protected viewportTransform = computed(() => {\n    const viewport = this.viewportService.readableViewport();\n    let scale = 1 / viewport.zoom\n\n    let x = -(viewport.x * this.minimapScale()) * scale\n    x /= this.minimapScale()\n\n    let y = -(viewport.y * this.minimapScale()) * scale\n    y /= this.minimapScale()\n\n    scale /= this.minimapScale()\n\n    return `translate(${x}, ${y}) scale(${scale})`;\n  });\n\n\n  protected boundsViewport = computed(() => {\n    const nodes = this.entitiesService.nodes()\n\n    return getViewportForBounds(\n      getNodesBounds(nodes),\n      this.flowSettingsService.computedFlowWidth(),\n      this.flowSettingsService.computedFlowHeight(),\n      -Infinity,\n      1.5,\n      0\n    )\n\n  })\n\n  protected minimapTransform = computed(() => {\n    const vport = this.boundsViewport()\n\n    const x = vport.x * this.minimapScale()\n    const y = vport.y * this.minimapScale()\n    const scale = vport.zoom * this.minimapScale()\n\n    return `translate(${x} ${y}) scale(${scale})`\n  })\n\n  private minimapPosition = signal<MiniMapPosition>('bottom-right')\n\n  private scaleOnHoverSignal = signal(false)\n\n  public ngOnInit(): void {\n    const model = new MinimapModel()\n    model.template.set(this.minimap)\n\n    this.entitiesService.minimap.set(model)\n  }\n\n  protected trackNodes(idx: number, { node }: NodeModel) {\n    return node\n  }\n}\n","<ng-template #minimap>\n  <svg:rect\n    [attr.x]=\"minimapPoint().x\"\n    [attr.y]=\"minimapPoint().y\"\n    [attr.width]=\"minimapWidth()\"\n    [attr.height]=\"minimapHeight()\"\n    [attr.stroke]=\"strokeColor\"\n    fill=\"none\"\n  />\n\n  <svg:svg\n    [attr.x]=\"minimapPoint().x\"\n    [attr.y]=\"minimapPoint().y\"\n    [attr.width]=\"minimapWidth()\"\n    [attr.height]=\"minimapHeight()\"\n    (mouseover)=\"hovered.set(true)\"\n    (mouseleave)=\"hovered.set(false)\"\n  >\n    <svg:rect\n      [attr.width]=\"minimapWidth()\"\n      [attr.height]=\"minimapHeight()\"\n      [attr.fill]=\"maskColor\"\n    />\n\n    <svg:g [attr.transform]=\"minimapTransform()\">\n      <svg:rect\n        [attr.fill]=\"viewportColor()\"\n        [attr.transform]=\"viewportTransform()\"\n        [attr.width]=\"minimapWidth()\"\n        [attr.height]=\"minimapHeight()\"\n      />\n\n      <ng-container\n        *ngFor=\"let model of entitiesService.nodes(); trackBy: trackNodes\"\n      >\n        <svg:foreignObject\n          *ngIf=\"model.node.type === 'default' || model.node.type === 'html-template' || model.isComponentType\"\n          [attr.transform]=\"model.pointTransform()\"\n          [attr.width]=\"model.size().width\"\n          [attr.height]=\"model.size().height\"\n        >\n          <default-node\n            [selected]=\"model.selected()\"\n            [style.width.px]=\"model.size().width\"\n            [style.height.px]=\"model.size().height\"\n            [style.max-width.px]=\"model.size().width\"\n            [style.max-height.px]=\"model.size().height\"\n          >\n            <div [outerHTML]=\"model.text()\"></div>\n          </default-node>\n        </svg:foreignObject>\n\n        <svg:rect\n          *ngIf=\"model.node.type === 'default-group' || model.node.type === 'template-group'\"\n          class=\"default-group-node\"\n          rx=\"5\"\n          ry=\"5\"\n          [attr.transform]=\"model.pointTransform()\"\n          [class.default-group-node_selected]=\"model.selected()\"\n          [attr.width]=\"model.size().width\"\n          [attr.height]=\"model.size().height\"\n          [style.stroke]=\"model.color()\"\n          [style.fill]=\"model.color()\"\n        />\n\n      </ng-container>\n    </svg:g>\n  </svg:svg>\n</ng-template>\n"]}
|
|
114
|
+
args: [{ standalone: true, selector: 'mini-map', imports: [DefaultNodeComponent], template: "<ng-template #minimap>\n <svg:rect\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.stroke]=\"strokeColor()\"\n fill=\"none\"\n />\n\n <svg:svg\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n (mouseover)=\"hovered.set(true)\"\n (mouseleave)=\"hovered.set(false)\"\n >\n <svg:rect\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.fill]=\"maskColor()\"\n />\n\n <svg:g [attr.transform]=\"minimapTransform()\">\n <svg:rect\n [attr.fill]=\"viewportColor()\"\n [attr.transform]=\"viewportTransform()\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n />\n\n @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n <ng-container>\n @if (\n model.node.type === \"default\" ||\n model.node.type === \"html-template\" ||\n model.isComponentType\n ) {\n <svg:foreignObject\n [attr.transform]=\"model.pointTransform()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\"\n >\n <default-node\n [selected]=\"model.selected()\"\n [style.width.px]=\"model.size().width\"\n [style.height.px]=\"model.size().height\"\n [style.max-width.px]=\"model.size().width\"\n [style.max-height.px]=\"model.size().height\"\n >\n <div [outerHTML]=\"model.text()\"></div>\n </default-node>\n </svg:foreignObject>\n }\n @if (\n model.node.type === \"default-group\" ||\n model.node.type === \"template-group\"\n ) {\n <svg:rect\n class=\"default-group-node\"\n rx=\"5\"\n ry=\"5\"\n [attr.transform]=\"model.pointTransform()\"\n [class.default-group-node_selected]=\"model.selected()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\"\n [style.stroke]=\"model.color()\"\n [style.fill]=\"model.color()\"\n />\n }\n </ng-container>\n }\n </svg:g>\n </svg:svg>\n</ng-template>\n", styles: [".default-group-node{stroke-width:1.5px;fill-opacity:.05}.default-group-node_selected{stroke-width:2px}\n"] }]
|
|
115
|
+
}] });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"minimap.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/minimap/minimap.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/minimap/minimap.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  computed,\n  inject,\n  Injector,\n  Input,\n  OnInit,\n  signal,\n  TemplateRef,\n  input,\n  viewChild,\n} from '@angular/core';\nimport { FlowEntitiesService } from '../../services/flow-entities.service';\nimport { MinimapModel } from '../../models/minimap.model';\nimport { NodeModel } from '../../models/node.model';\nimport { FlowSettingsService } from '../../services/flow-settings.service';\nimport { getViewportForBounds } from '../../utils/viewport';\nimport { getNodesBounds } from '../../utils/nodes';\nimport { ViewportService } from '../../services/viewport.service';\nimport { DefaultNodeComponent } from '../../components/default-node/default-node.component';\n\nexport type MiniMapPosition =\n  | 'top-left'\n  | 'top-right'\n  | 'bottom-left'\n  | 'bottom-right';\n\n@Component({\n  standalone: true,\n  selector: 'mini-map',\n  templateUrl: './minimap.component.html',\n  styleUrls: [`./minimap.component.scss`],\n  imports: [DefaultNodeComponent],\n})\nexport class MiniMapComponent implements OnInit {\n  protected entitiesService = inject(FlowEntitiesService);\n  protected flowSettingsService = inject(FlowSettingsService);\n  protected viewportService = inject(ViewportService);\n  protected injector = inject(Injector);\n\n  /**\n   * The color outside the viewport (invisible area)\n   */\n  public maskColor = input(`rgba(215, 215, 215, 0.6)`);\n\n  /**\n   * The minimap stroke color\n   */\n  public strokeColor = input(`rgb(200, 200, 200)`);\n\n  /**\n   * The corner of the flow where to render a mini-map\n   */\n  public position = input<MiniMapPosition>('bottom-right');\n\n  /**\n   * Make a minimap bigger on hover\n   */\n  public scaleOnHover = input(false);\n\n  private minimap = viewChild.required<TemplateRef<unknown>>('minimap');\n\n  private readonly minimapOffset = 10;\n\n  private readonly minimapScale = computed(() => {\n    if (this.scaleOnHover()) {\n      return this.hovered() ? 0.4 : 0.2;\n    }\n\n    return 0.2;\n  });\n\n  protected viewportColor = computed(() => {\n    const bg = this.flowSettingsService.background();\n\n    if (bg.type === 'dots' || bg.type === 'solid') {\n      return bg.color ?? '#fff';\n    }\n\n    return '#fff';\n  });\n\n  protected hovered = signal(false);\n\n  protected minimapPoint = computed(() => {\n    switch (this.position()) {\n      case 'top-left':\n        return { x: this.minimapOffset, y: this.minimapOffset };\n      case 'top-right':\n        return {\n          x:\n            this.flowSettingsService.computedFlowWidth() -\n            this.minimapWidth() -\n            this.minimapOffset,\n          y: this.minimapOffset,\n        };\n      case 'bottom-left':\n        return {\n          x: this.minimapOffset,\n          y:\n            this.flowSettingsService.computedFlowHeight() -\n            this.minimapHeight() -\n            this.minimapOffset,\n        };\n      case 'bottom-right':\n        return {\n          x:\n            this.flowSettingsService.computedFlowWidth() -\n            this.minimapWidth() -\n            this.minimapOffset,\n          y:\n            this.flowSettingsService.computedFlowHeight() -\n            this.minimapHeight() -\n            this.minimapOffset,\n        };\n    }\n  });\n\n  protected minimapWidth = computed(\n    () => this.flowSettingsService.computedFlowWidth() * this.minimapScale(),\n  );\n  protected minimapHeight = computed(\n    () => this.flowSettingsService.computedFlowHeight() * this.minimapScale(),\n  );\n\n  protected viewportTransform = computed(() => {\n    const viewport = this.viewportService.readableViewport();\n    let scale = 1 / viewport.zoom;\n\n    let x = -(viewport.x * this.minimapScale()) * scale;\n    x /= this.minimapScale();\n\n    let y = -(viewport.y * this.minimapScale()) * scale;\n    y /= this.minimapScale();\n\n    scale /= this.minimapScale();\n\n    return `translate(${x}, ${y}) scale(${scale})`;\n  });\n\n  protected boundsViewport = computed(() => {\n    const nodes = this.entitiesService.nodes();\n\n    return getViewportForBounds(\n      getNodesBounds(nodes),\n      this.flowSettingsService.computedFlowWidth(),\n      this.flowSettingsService.computedFlowHeight(),\n      -Infinity,\n      1.5,\n      0,\n    );\n  });\n\n  protected minimapTransform = computed(() => {\n    const vport = this.boundsViewport();\n\n    const x = vport.x * this.minimapScale();\n    const y = vport.y * this.minimapScale();\n    const scale = vport.zoom * this.minimapScale();\n\n    return `translate(${x} ${y}) scale(${scale})`;\n  });\n\n  public ngOnInit(): void {\n    const model = new MinimapModel();\n    model.template.set(this.minimap());\n\n    this.entitiesService.minimap.set(model);\n  }\n\n  protected trackNodes(idx: number, { node }: NodeModel) {\n    return node;\n  }\n}\n","<ng-template #minimap>\n  <svg:rect\n    [attr.x]=\"minimapPoint().x\"\n    [attr.y]=\"minimapPoint().y\"\n    [attr.width]=\"minimapWidth()\"\n    [attr.height]=\"minimapHeight()\"\n    [attr.stroke]=\"strokeColor()\"\n    fill=\"none\"\n  />\n\n  <svg:svg\n    [attr.x]=\"minimapPoint().x\"\n    [attr.y]=\"minimapPoint().y\"\n    [attr.width]=\"minimapWidth()\"\n    [attr.height]=\"minimapHeight()\"\n    (mouseover)=\"hovered.set(true)\"\n    (mouseleave)=\"hovered.set(false)\"\n  >\n    <svg:rect\n      [attr.width]=\"minimapWidth()\"\n      [attr.height]=\"minimapHeight()\"\n      [attr.fill]=\"maskColor()\"\n    />\n\n    <svg:g [attr.transform]=\"minimapTransform()\">\n      <svg:rect\n        [attr.fill]=\"viewportColor()\"\n        [attr.transform]=\"viewportTransform()\"\n        [attr.width]=\"minimapWidth()\"\n        [attr.height]=\"minimapHeight()\"\n      />\n\n      @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n        <ng-container>\n          @if (\n            model.node.type === \"default\" ||\n            model.node.type === \"html-template\" ||\n            model.isComponentType\n          ) {\n            <svg:foreignObject\n              [attr.transform]=\"model.pointTransform()\"\n              [attr.width]=\"model.size().width\"\n              [attr.height]=\"model.size().height\"\n            >\n              <default-node\n                [selected]=\"model.selected()\"\n                [style.width.px]=\"model.size().width\"\n                [style.height.px]=\"model.size().height\"\n                [style.max-width.px]=\"model.size().width\"\n                [style.max-height.px]=\"model.size().height\"\n              >\n                <div [outerHTML]=\"model.text()\"></div>\n              </default-node>\n            </svg:foreignObject>\n          }\n          @if (\n            model.node.type === \"default-group\" ||\n            model.node.type === \"template-group\"\n          ) {\n            <svg:rect\n              class=\"default-group-node\"\n              rx=\"5\"\n              ry=\"5\"\n              [attr.transform]=\"model.pointTransform()\"\n              [class.default-group-node_selected]=\"model.selected()\"\n              [attr.width]=\"model.size().width\"\n              [attr.height]=\"model.size().height\"\n              [style.stroke]=\"model.color()\"\n              [style.fill]=\"model.color()\"\n            />\n          }\n        </ng-container>\n      }\n    </svg:g>\n  </svg:svg>\n</ng-template>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, inject,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, inject, input, viewChild, effect, forwardRef } from '@angular/core';
|
|
2
2
|
import { Directive } from '@angular/core';
|
|
3
3
|
import { ToolbarModel } from '../../models/toolbar.model';
|
|
4
4
|
import { OverlaysService } from '../../services/overlays.service';
|
|
@@ -8,59 +8,56 @@ export class NodeToolbarComponent {
|
|
|
8
8
|
constructor() {
|
|
9
9
|
this.overlaysService = inject(OverlaysService);
|
|
10
10
|
this.nodeService = inject(NodeAccessorService);
|
|
11
|
+
this.position = input('top');
|
|
12
|
+
this.toolbarContentTemplate = viewChild.required('toolbar');
|
|
11
13
|
this.model = new ToolbarModel(this.nodeService.model());
|
|
12
|
-
|
|
13
|
-
set position(value) {
|
|
14
|
-
this.model.position.set(value);
|
|
14
|
+
effect(() => this.model.position.set(this.position()), { allowSignalWrites: true });
|
|
15
15
|
}
|
|
16
16
|
ngOnInit() {
|
|
17
|
-
this.model.template.set(this.toolbarContentTemplate);
|
|
17
|
+
this.model.template.set(this.toolbarContentTemplate());
|
|
18
18
|
this.overlaysService.addToolbar(this.model);
|
|
19
19
|
}
|
|
20
20
|
ngOnDestroy() {
|
|
21
21
|
this.overlaysService.removeToolbar(this.model);
|
|
22
22
|
}
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.12", type: NodeToolbarComponent, isStandalone: true, selector: "node-toolbar", inputs: { position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "toolbarContentTemplate", first: true, predicate: ["toolbar"], descendants: true, isSignal: true }], ngImport: i0, template: `
|
|
25
25
|
<ng-template #toolbar>
|
|
26
26
|
<div class="wrapper" nodeToolbarWrapper [model]="model">
|
|
27
27
|
<ng-content />
|
|
28
28
|
</div>
|
|
29
29
|
</ng-template>
|
|
30
|
-
`, isInline: true, styles: [".wrapper{width:max-content}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(
|
|
30
|
+
`, isInline: true, styles: [".wrapper{width:max-content}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(() => NodeToolbarWrapperDirective), selector: "[nodeToolbarWrapper]", inputs: ["model"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
31
31
|
}
|
|
32
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeToolbarComponent, decorators: [{
|
|
33
33
|
type: Component,
|
|
34
|
-
args: [{ selector: 'node-toolbar', template: `
|
|
34
|
+
args: [{ standalone: true, selector: 'node-toolbar', template: `
|
|
35
35
|
<ng-template #toolbar>
|
|
36
36
|
<div class="wrapper" nodeToolbarWrapper [model]="model">
|
|
37
37
|
<ng-content />
|
|
38
38
|
</div>
|
|
39
39
|
</ng-template>
|
|
40
|
-
`, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".wrapper{width:max-content}\n"] }]
|
|
41
|
-
}],
|
|
42
|
-
type: Input
|
|
43
|
-
}], toolbarContentTemplate: [{
|
|
44
|
-
type: ViewChild,
|
|
45
|
-
args: ['toolbar', { static: true }]
|
|
46
|
-
}] } });
|
|
40
|
+
`, changeDetection: ChangeDetectionStrategy.OnPush, imports: [forwardRef(() => NodeToolbarWrapperDirective)], styles: [".wrapper{width:max-content}\n"] }]
|
|
41
|
+
}], ctorParameters: () => [] });
|
|
47
42
|
export class NodeToolbarWrapperDirective {
|
|
48
43
|
constructor() {
|
|
49
44
|
this.element = inject(ElementRef);
|
|
45
|
+
this.model = input.required();
|
|
50
46
|
}
|
|
51
47
|
ngOnInit() {
|
|
52
|
-
this.model.size.set({
|
|
48
|
+
this.model().size.set({
|
|
53
49
|
width: this.element.nativeElement.clientWidth,
|
|
54
|
-
height: this.element.nativeElement.clientHeight
|
|
50
|
+
height: this.element.nativeElement.clientHeight,
|
|
55
51
|
});
|
|
56
52
|
}
|
|
57
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
58
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
53
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeToolbarWrapperDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
54
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: NodeToolbarWrapperDirective, isStandalone: true, selector: "[nodeToolbarWrapper]", inputs: { model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0 }); }
|
|
59
55
|
}
|
|
60
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeToolbarWrapperDirective, decorators: [{
|
|
61
57
|
type: Directive,
|
|
62
|
-
args: [{
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
58
|
+
args: [{
|
|
59
|
+
selector: '[nodeToolbarWrapper]',
|
|
60
|
+
standalone: true
|
|
61
|
+
}]
|
|
62
|
+
}] });
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9ub2RlLXRvb2xiYXIvbm9kZS10b29sYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUF5QyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkwsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOztBQXNCM0UsTUFBTSxPQUFPLG9CQUFvQjtJQVUvQjtRQVRRLG9CQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQzFDLGdCQUFXLEdBQUcsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFM0MsYUFBUSxHQUFHLEtBQUssQ0FBVyxLQUFLLENBQUMsQ0FBQztRQUVsQywyQkFBc0IsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUF1QixTQUFTLENBQUMsQ0FBQztRQUUxRSxVQUFLLEdBQUcsSUFBSSxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUcsQ0FBQyxDQUFDO1FBRzVELE1BQU0sQ0FDSixHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLEVBQzlDLEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLENBQzVCLENBQUM7SUFDSixDQUFDO0lBRU0sUUFBUTtRQUNiLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQyxDQUFDO1FBRXZELElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsQ0FBQzsrR0F6QlUsb0JBQW9CO21HQUFwQixvQkFBb0Isd1ZBakJyQjs7Ozs7O0dBTVQsMkhBMkNVLDJCQUEyQjs7NEZBaEMzQixvQkFBb0I7a0JBcEJoQyxTQUFTO2lDQUNJLElBQUksWUFDTixjQUFjLFlBQ2Q7Ozs7OztHQU1ULG1CQVFnQix1QkFBdUIsQ0FBQyxNQUFNLFdBQ3RDLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLDJCQUEyQixDQUFDLENBQUM7O0FBa0MxRCxNQUFNLE9BQU8sMkJBQTJCO0lBSnhDO1FBS1UsWUFBTyxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUM7UUFFdkQsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQWdCLENBQUM7S0FRL0M7SUFOUSxRQUFRO1FBQ2IsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDcEIsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFdBQVc7WUFDN0MsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFlBQVk7U0FDaEQsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzsrR0FWVSwyQkFBMkI7bUdBQTNCLDJCQUEyQjs7NEZBQTNCLDJCQUEyQjtrQkFKdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRWxlbWVudFJlZiwgaW5qZWN0LCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQsIFRlbXBsYXRlUmVmLCBpbnB1dCwgdmlld0NoaWxkLCBlZmZlY3QsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi8uLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IFRvb2xiYXJNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy90b29sYmFyLm1vZGVsJztcbmltcG9ydCB7IE92ZXJsYXlzU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL292ZXJsYXlzLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZUFjY2Vzc29yU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ25vZGUtdG9vbGJhcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG5nLXRlbXBsYXRlICN0b29sYmFyPlxuICAgICAgPGRpdiBjbGFzcz1cIndyYXBwZXJcIiBub2RlVG9vbGJhcldyYXBwZXIgW21vZGVsXT1cIm1vZGVsXCI+XG4gICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLXRlbXBsYXRlPlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAud3JhcHBlciB7XG4gICAgICAgIHdpZHRoOiBtYXgtY29udGVudDtcbiAgICAgIH1cbiAgICBgLFxuICBdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW2ZvcndhcmRSZWYoKCkgPT4gTm9kZVRvb2xiYXJXcmFwcGVyRGlyZWN0aXZlKV0sXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVUb29sYmFyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBwcml2YXRlIG92ZXJsYXlzU2VydmljZSA9IGluamVjdChPdmVybGF5c1NlcnZpY2UpO1xuICBwcml2YXRlIG5vZGVTZXJ2aWNlID0gaW5qZWN0KE5vZGVBY2Nlc3NvclNlcnZpY2UpO1xuXG4gIHB1YmxpYyBwb3NpdGlvbiA9IGlucHV0PFBvc2l0aW9uPigndG9wJyk7XG5cbiAgcHVibGljIHRvb2xiYXJDb250ZW50VGVtcGxhdGUgPSB2aWV3Q2hpbGQucmVxdWlyZWQ8VGVtcGxhdGVSZWY8dW5rbm93bj4+KCd0b29sYmFyJyk7XG5cbiAgcHJvdGVjdGVkIG1vZGVsID0gbmV3IFRvb2xiYXJNb2RlbCh0aGlzLm5vZGVTZXJ2aWNlLm1vZGVsKCkhKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBlZmZlY3QoXG4gICAgICAoKSA9PiB0aGlzLm1vZGVsLnBvc2l0aW9uLnNldCh0aGlzLnBvc2l0aW9uKCkpLFxuICAgICAgeyBhbGxvd1NpZ25hbFdyaXRlczogdHJ1ZSB9XG4gICAgKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm1vZGVsLnRlbXBsYXRlLnNldCh0aGlzLnRvb2xiYXJDb250ZW50VGVtcGxhdGUoKSk7XG5cbiAgICB0aGlzLm92ZXJsYXlzU2VydmljZS5hZGRUb29sYmFyKHRoaXMubW9kZWwpO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMub3ZlcmxheXNTZXJ2aWNlLnJlbW92ZVRvb2xiYXIodGhpcy5tb2RlbCk7XG4gIH1cbn1cblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25vZGVUb29sYmFyV3JhcHBlcl0nLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVUb29sYmFyV3JhcHBlckRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHByaXZhdGUgZWxlbWVudCA9IGluamVjdDxFbGVtZW50UmVmPEhUTUxFbGVtZW50Pj4oRWxlbWVudFJlZik7XG5cbiAgcHVibGljIG1vZGVsID0gaW5wdXQucmVxdWlyZWQ8VG9vbGJhck1vZGVsPigpO1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm1vZGVsKCkuc2l6ZS5zZXQoe1xuICAgICAgd2lkdGg6IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsaWVudFdpZHRoLFxuICAgICAgaGVpZ2h0OiB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5jbGllbnRIZWlnaHQsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|