ngx-vflow 1.0.2 → 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 +7 -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/public-components/handle/handle.component.d.ts +1 -1
- 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
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { computed, effect, inject, signal } from '@angular/core';
|
|
2
|
-
import { isDynamicNode } from '../interfaces/node.interface';
|
|
2
|
+
import { isComponentDynamicNode, isComponentStaticNode, isDynamicNode, } from '../interfaces/node.interface';
|
|
3
3
|
import { isDefined } from '../utils/is-defined';
|
|
4
4
|
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { FlowSettingsService } from '../services/flow-settings.service';
|
|
6
|
-
import { animationFrameScheduler, merge, observeOn, Subject
|
|
7
|
-
import { CustomNodeComponent } from '../public-components/custom-node/custom-node.component';
|
|
8
|
-
import { CustomDynamicNodeComponent } from '../public-components/custom-dynamic-node/custom-dynamic-node.component';
|
|
6
|
+
import { animationFrameScheduler, merge, observeOn, Subject } from 'rxjs';
|
|
9
7
|
import { FlowEntitiesService } from '../services/flow-entities.service';
|
|
10
8
|
// TODO bad naming around points
|
|
11
9
|
export class NodeModel {
|
|
@@ -20,7 +18,7 @@ export class NodeModel {
|
|
|
20
18
|
this.throttledPoint$ = toObservable(this.internalPoint).pipe(observeOn(animationFrameScheduler));
|
|
21
19
|
this.notThrottledPoint$ = new Subject();
|
|
22
20
|
this.point = toSignal(merge(this.throttledPoint$, this.notThrottledPoint$), {
|
|
23
|
-
initialValue: this.internalPoint()
|
|
21
|
+
initialValue: this.internalPoint(),
|
|
24
22
|
});
|
|
25
23
|
this.point$ = this.throttledPoint$;
|
|
26
24
|
this.size = signal({ width: 0, height: 0 });
|
|
@@ -49,16 +47,15 @@ export class NodeModel {
|
|
|
49
47
|
// disabled for configuration for now
|
|
50
48
|
this.magnetRadius = 20;
|
|
51
49
|
// TODO: not sure if we need to statically store it
|
|
52
|
-
this.isComponentType =
|
|
53
|
-
CustomDynamicNodeComponent.isPrototypeOf(this.node.type);
|
|
50
|
+
this.isComponentType = isComponentStaticNode(this.node) || isComponentDynamicNode(this.node);
|
|
54
51
|
// Default node specific thing
|
|
55
52
|
this.text = this.createTextSignal();
|
|
56
53
|
// Component node specific thing
|
|
57
54
|
this.componentTypeInputs = {
|
|
58
55
|
node: this.node,
|
|
59
56
|
};
|
|
60
|
-
this.parent = computed(() => this.entitiesService.nodes().find(n => n.node.id === this.parentId()) ?? null);
|
|
61
|
-
this.children = computed(() => this.entitiesService.nodes().filter(n => n.parentId() === this.node.id));
|
|
57
|
+
this.parent = computed(() => this.entitiesService.nodes().find((n) => n.node.id === this.parentId()) ?? null);
|
|
58
|
+
this.children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.node.id));
|
|
62
59
|
this.color = signal(NodeModel.defaultColor);
|
|
63
60
|
this.resizable = signal(false);
|
|
64
61
|
this.resizing = signal(false);
|
|
@@ -125,7 +122,7 @@ export class NodeModel {
|
|
|
125
122
|
else {
|
|
126
123
|
this.size.set({
|
|
127
124
|
width: node.width ?? NodeModel.defaultWidth,
|
|
128
|
-
height: node.height ?? NodeModel.defaultHeight
|
|
125
|
+
height: node.height ?? NodeModel.defaultHeight,
|
|
129
126
|
});
|
|
130
127
|
}
|
|
131
128
|
}
|
|
@@ -161,9 +158,7 @@ export class NodeModel {
|
|
|
161
158
|
return signal('');
|
|
162
159
|
}
|
|
163
160
|
createInternalPointSignal() {
|
|
164
|
-
return isDynamicNode(this.node)
|
|
165
|
-
? this.node.point
|
|
166
|
-
: signal({ x: this.node.point.x, y: this.node.point.y });
|
|
161
|
+
return isDynamicNode(this.node) ? this.node.point : signal({ x: this.node.point.x, y: this.node.point.y });
|
|
167
162
|
}
|
|
168
163
|
}
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/node.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signal, TemplateRef, computed, effect, inject, signal } from '@angular/core'\nimport { DynamicNode, Node, isDynamicNode } from '../interfaces/node.interface'\nimport { isDefined } from '../utils/is-defined'\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop'\nimport { HandleModel } from './handle.model'\nimport { FlowEntity } from '../interfaces/flow-entity.interface'\nimport { FlowSettingsService } from '../services/flow-settings.service'\nimport { animationFrameScheduler, merge, observeOn, Subject, } from 'rxjs'\nimport { Point } from '../interfaces/point.interface'\nimport { CustomNodeComponent } from '../public-components/custom-node/custom-node.component'\nimport { CustomDynamicNodeComponent } from '../public-components/custom-dynamic-node/custom-dynamic-node.component'\nimport { FlowEntitiesService } from '../services/flow-entities.service'\n\n// TODO bad naming around points\nexport class NodeModel<T = unknown> implements FlowEntity {\n  private static defaultWidth = 100\n  private static defaultHeight = 50\n  private static defaultColor = '#1b262c'\n\n  private flowSettingsService = inject(FlowSettingsService)\n  private entitiesService = inject(FlowEntitiesService);\n\n  private internalPoint = this.createInternalPointSignal()\n\n  private throttledPoint$ = toObservable(this.internalPoint).pipe(\n    observeOn(animationFrameScheduler)\n  )\n\n  private notThrottledPoint$ = new Subject<Point>()\n\n  public point = toSignal(\n    merge(this.throttledPoint$, this.notThrottledPoint$),\n    {\n      initialValue: this.internalPoint()\n    }\n  )\n\n  public point$ = this.throttledPoint$;\n\n  public size = signal({ width: 0, height: 0 })\n  public size$ = toObservable(this.size)\n\n  public width = computed(() => this.size().width)\n  public height = computed(() => this.size().height)\n\n  public renderOrder = signal(0)\n\n  public selected = signal(false)\n  public selected$ = toObservable(this.selected)\n\n  public globalPoint = computed(() => {\n    let parent = this.parent()\n    let x = this.point().x\n    let y = this.point().y\n\n    while (parent !== null) {\n      x += parent.point().x\n      y += parent.point().y\n\n      parent = parent.parent()\n    }\n\n    return { x, y }\n  })\n\n  public pointTransform = computed(() =>\n    `translate(${this.globalPoint().x}, ${this.globalPoint().y})`\n  )\n\n  public handles = signal<HandleModel[]>([])\n\n  public handles$ = toObservable(this.handles)\n\n  public draggable = signal(true)\n\n  public dragHandlesCount = signal(0)\n\n  // disabled for configuration for now\n  public readonly magnetRadius = 20\n\n  // TODO: not sure if we need to statically store it\n  public isComponentType =\n    CustomNodeComponent.isPrototypeOf(this.node.type) ||\n    CustomDynamicNodeComponent.isPrototypeOf(this.node.type)\n\n  // Default node specific thing\n  public text = this.createTextSignal()\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.node,\n  }\n\n  public parent = computed(() =>\n    this.entitiesService.nodes().find(n => n.node.id === this.parentId()) ?? null\n  )\n\n  public children = computed(() =>\n    this.entitiesService.nodes().filter(n => n.parentId() === this.node.id)\n  )\n\n  public color = signal(NodeModel.defaultColor)\n\n  public resizable = signal(false)\n  public resizing = signal(false)\n  public resizerTemplate = signal<TemplateRef<unknown> | null>(null)\n\n  private parentId = signal<string | null>(null)\n\n  constructor(\n    public node: Node<T> | DynamicNode<T>\n  ) {\n    if (isDefined(node.draggable)) {\n      if (isDynamicNode(node)) {\n        this.draggable = node.draggable\n      } else {\n        this.draggable.set(node.draggable)\n      }\n    }\n\n    if (isDefined(node.parentId)) {\n      if (isDynamicNode(node)) {\n        this.parentId = node.parentId\n      } else {\n        this.parentId.set(node.parentId)\n      }\n    }\n\n    if (node.type === 'default-group' && node.color) {\n      if (isDynamicNode(node)) {\n        this.color = node.color\n      } else {\n        this.color.set(node.color)\n      }\n    }\n\n    if (node.type === 'default-group' && node.resizable) {\n      if (isDynamicNode(node)) {\n        this.resizable = node.resizable\n      } else {\n        this.resizable.set(node.resizable)\n      }\n    }\n  }\n\n  public setPoint(point: Point, throttle: boolean) {\n    if (throttle) {\n      this.internalPoint.set(point);\n    } else {\n      this.notThrottledPoint$.next(point)\n    }\n  }\n\n  /**\n   * TODO find the way to implement this better\n   */\n  public linkDefaultNodeSizeWithModelSize() {\n    const node = this.node\n\n    switch (node.type) {\n      case 'default':\n      case 'default-group':\n      case 'template-group': {\n        if (isDynamicNode(node)) {\n          effect(() => {\n            this.size.set({\n              width: node.width?.() ?? NodeModel.defaultWidth,\n              height: node.height?.() ?? NodeModel.defaultHeight,\n            })\n          }, { allowSignalWrites: true })\n        } else {\n          this.size.set({\n            width: node.width ?? NodeModel.defaultWidth,\n            height: node.height ?? NodeModel.defaultHeight\n          })\n        }\n      }\n    }\n\n    if (node.type === 'html-template' || this.isComponentType) {\n      if (isDynamicNode(node)) {\n        effect(() => {\n          if (node.width && node.height) {\n            this.size.set({\n              width: node.width(),\n              height: node.height(),\n            })\n          }\n        }, { allowSignalWrites: true })\n      } else {\n        if (node.width && node.height) {\n          this.size.set({ width: node.width, height: node.height })\n        }\n      }\n    }\n  }\n\n  private createTextSignal(): Signal<string> {\n    const node = this.node\n\n    if (node.type === 'default') {\n      if (isDynamicNode(node)) {\n        return node.text ?? signal('')\n      } else {\n        return signal(node.text ?? '')\n      }\n    }\n\n    return signal('')\n  }\n\n  private createInternalPointSignal() {\n    return isDynamicNode(this.node)\n      ? this.node.point\n      : signal({ x: this.node.point.x, y: this.node.point.y })\n  }\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/node.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signal, TemplateRef, computed, effect, inject, signal } from '@angular/core';\nimport {\n  DynamicNode,\n  Node,\n  isComponentDynamicNode,\n  isComponentStaticNode,\n  isDynamicNode,\n} from '../interfaces/node.interface';\nimport { isDefined } from '../utils/is-defined';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { FlowSettingsService } from '../services/flow-settings.service';\nimport { animationFrameScheduler, merge, observeOn, Subject } from 'rxjs';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\n\n// TODO bad naming around points\nexport class NodeModel<T = unknown> implements FlowEntity {\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private flowSettingsService = inject(FlowSettingsService);\n  private entitiesService = inject(FlowEntitiesService);\n\n  private internalPoint = this.createInternalPointSignal();\n\n  private throttledPoint$ = toObservable(this.internalPoint).pipe(observeOn(animationFrameScheduler));\n\n  private notThrottledPoint$ = new Subject<Point>();\n\n  public point = toSignal(merge(this.throttledPoint$, this.notThrottledPoint$), {\n    initialValue: this.internalPoint(),\n  });\n\n  public point$ = this.throttledPoint$;\n\n  public size = signal({ width: 0, height: 0 });\n  public size$ = toObservable(this.size);\n\n  public width = computed(() => this.size().width);\n  public height = computed(() => this.size().height);\n\n  public renderOrder = signal(0);\n\n  public selected = signal(false);\n  public selected$ = toObservable(this.selected);\n\n  public globalPoint = computed(() => {\n    let parent = this.parent();\n    let x = this.point().x;\n    let y = this.point().y;\n\n    while (parent !== null) {\n      x += parent.point().x;\n      y += parent.point().y;\n\n      parent = parent.parent();\n    }\n\n    return { x, y };\n  });\n\n  public pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);\n\n  public handles = signal<HandleModel[]>([]);\n\n  public handles$ = toObservable(this.handles);\n\n  public draggable = signal(true);\n\n  public dragHandlesCount = signal(0);\n\n  // disabled for configuration for now\n  public readonly magnetRadius = 20;\n\n  // TODO: not sure if we need to statically store it\n  public isComponentType = isComponentStaticNode(this.node as Node) || isComponentDynamicNode(this.node as DynamicNode);\n\n  // Default node specific thing\n  public text = this.createTextSignal();\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.node,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.node.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.node.id));\n\n  public color = signal(NodeModel.defaultColor);\n\n  public resizable = signal(false);\n  public resizing = signal(false);\n  public resizerTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public node: Node<T> | DynamicNode<T>) {\n    if (isDefined(node.draggable)) {\n      if (isDynamicNode(node)) {\n        this.draggable = node.draggable;\n      } else {\n        this.draggable.set(node.draggable);\n      }\n    }\n\n    if (isDefined(node.parentId)) {\n      if (isDynamicNode(node)) {\n        this.parentId = node.parentId;\n      } else {\n        this.parentId.set(node.parentId);\n      }\n    }\n\n    if (node.type === 'default-group' && node.color) {\n      if (isDynamicNode(node)) {\n        this.color = node.color;\n      } else {\n        this.color.set(node.color);\n      }\n    }\n\n    if (node.type === 'default-group' && node.resizable) {\n      if (isDynamicNode(node)) {\n        this.resizable = node.resizable;\n      } else {\n        this.resizable.set(node.resizable);\n      }\n    }\n  }\n\n  public setPoint(point: Point, throttle: boolean) {\n    if (throttle) {\n      this.internalPoint.set(point);\n    } else {\n      this.notThrottledPoint$.next(point);\n    }\n  }\n\n  /**\n   * TODO find the way to implement this better\n   */\n  public linkDefaultNodeSizeWithModelSize() {\n    const node = this.node;\n\n    switch (node.type) {\n      case 'default':\n      case 'default-group':\n      case 'template-group': {\n        if (isDynamicNode(node)) {\n          effect(\n            () => {\n              this.size.set({\n                width: node.width?.() ?? NodeModel.defaultWidth,\n                height: node.height?.() ?? NodeModel.defaultHeight,\n              });\n            },\n            { allowSignalWrites: true },\n          );\n        } else {\n          this.size.set({\n            width: node.width ?? NodeModel.defaultWidth,\n            height: node.height ?? NodeModel.defaultHeight,\n          });\n        }\n      }\n    }\n\n    if (node.type === 'html-template' || this.isComponentType) {\n      if (isDynamicNode(node)) {\n        effect(\n          () => {\n            if (node.width && node.height) {\n              this.size.set({\n                width: node.width(),\n                height: node.height(),\n              });\n            }\n          },\n          { allowSignalWrites: true },\n        );\n      } else {\n        if (node.width && node.height) {\n          this.size.set({ width: node.width, height: node.height });\n        }\n      }\n    }\n  }\n\n  private createTextSignal(): Signal<string> {\n    const node = this.node;\n\n    if (node.type === 'default') {\n      if (isDynamicNode(node)) {\n        return node.text ?? signal('');\n      } else {\n        return signal(node.text ?? '');\n      }\n    }\n\n    return signal('');\n  }\n\n  private createInternalPointSignal() {\n    return isDynamicNode(this.node) ? this.node.point : signal({ x: this.node.point.x, y: this.node.point.y });\n  }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { computed, signal } from
|
|
1
|
+
import { computed, signal } from '@angular/core';
|
|
2
2
|
export class ToolbarModel {
|
|
3
3
|
constructor(node) {
|
|
4
4
|
this.node = node;
|
|
@@ -10,22 +10,22 @@ export class ToolbarModel {
|
|
|
10
10
|
case 'top':
|
|
11
11
|
return {
|
|
12
12
|
x: this.node.size().width / 2 - this.size().width / 2,
|
|
13
|
-
y: -this.size().height - this.offset()
|
|
13
|
+
y: -this.size().height - this.offset(),
|
|
14
14
|
};
|
|
15
15
|
case 'bottom':
|
|
16
16
|
return {
|
|
17
17
|
x: this.node.size().width / 2 - this.size().width / 2,
|
|
18
|
-
y: this.node.size().height + this.offset()
|
|
18
|
+
y: this.node.size().height + this.offset(),
|
|
19
19
|
};
|
|
20
20
|
case 'left':
|
|
21
21
|
return {
|
|
22
22
|
x: -this.size().width - this.offset(),
|
|
23
|
-
y: this.node.size().height / 2 - this.size().height / 2
|
|
23
|
+
y: this.node.size().height / 2 - this.size().height / 2,
|
|
24
24
|
};
|
|
25
25
|
case 'right':
|
|
26
26
|
return {
|
|
27
27
|
x: this.node.size().width + this.offset(),
|
|
28
|
-
y: this.node.size().height / 2 - this.size().height / 2
|
|
28
|
+
y: this.node.size().height / 2 - this.size().height / 2,
|
|
29
29
|
};
|
|
30
30
|
}
|
|
31
31
|
});
|
|
@@ -33,4 +33,4 @@ export class ToolbarModel {
|
|
|
33
33
|
this.size = signal({ width: 0, height: 0 });
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9tb2RlbHMvdG9vbGJhci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUk5RCxNQUFNLE9BQU8sWUFBWTtJQW1DdkIsWUFBbUIsSUFBZTtRQUFmLFNBQUksR0FBSixJQUFJLENBQVc7UUFsQzNCLGFBQVEsR0FBRyxNQUFNLENBQVcsS0FBSyxDQUFDLENBQUM7UUFDbkMsYUFBUSxHQUFHLE1BQU0sQ0FBOEIsSUFBSSxDQUFDLENBQUM7UUFFckQsV0FBTSxHQUFHLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUVwQixVQUFLLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMzQixRQUFRLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO2dCQUN4QixLQUFLLEtBQUs7b0JBQ1IsT0FBTzt3QkFDTCxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQzt3QkFDckQsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFO3FCQUN2QyxDQUFDO2dCQUNKLEtBQUssUUFBUTtvQkFDWCxPQUFPO3dCQUNMLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDO3dCQUNyRCxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRTtxQkFDM0MsQ0FBQztnQkFDSixLQUFLLE1BQU07b0JBQ1QsT0FBTzt3QkFDTCxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUU7d0JBQ3JDLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxDQUFDO3FCQUN4RCxDQUFDO2dCQUNKLEtBQUssT0FBTztvQkFDVixPQUFPO3dCQUNMLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFO3dCQUN6QyxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQztxQkFDeEQsQ0FBQztZQUNOLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVJLGNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsYUFBYSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRTlFLFNBQUksR0FBRyxNQUFNLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBRVQsQ0FBQztDQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBzaWduYWwsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQb3NpdGlvbiB9IGZyb20gJy4uL3R5cGVzL3Bvc2l0aW9uLnR5cGUnO1xuaW1wb3J0IHsgTm9kZU1vZGVsIH0gZnJvbSAnLi9ub2RlLm1vZGVsJztcblxuZXhwb3J0IGNsYXNzIFRvb2xiYXJNb2RlbCB7XG4gIHB1YmxpYyBwb3NpdGlvbiA9IHNpZ25hbDxQb3NpdGlvbj4oJ3RvcCcpO1xuICBwdWJsaWMgdGVtcGxhdGUgPSBzaWduYWw8VGVtcGxhdGVSZWY8dW5rbm93bj4gfCBudWxsPihudWxsKTtcblxuICBwdWJsaWMgb2Zmc2V0ID0gc2lnbmFsKDEwKTtcblxuICBwdWJsaWMgcG9pbnQgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgc3dpdGNoICh0aGlzLnBvc2l0aW9uKCkpIHtcbiAgICAgIGNhc2UgJ3RvcCc6XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgeDogdGhpcy5ub2RlLnNpemUoKS53aWR0aCAvIDIgLSB0aGlzLnNpemUoKS53aWR0aCAvIDIsXG4gICAgICAgICAgeTogLXRoaXMuc2l6ZSgpLmhlaWdodCAtIHRoaXMub2Zmc2V0KCksXG4gICAgICAgIH07XG4gICAgICBjYXNlICdib3R0b20nOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHg6IHRoaXMubm9kZS5zaXplKCkud2lkdGggLyAyIC0gdGhpcy5zaXplKCkud2lkdGggLyAyLFxuICAgICAgICAgIHk6IHRoaXMubm9kZS5zaXplKCkuaGVpZ2h0ICsgdGhpcy5vZmZzZXQoKSxcbiAgICAgICAgfTtcbiAgICAgIGNhc2UgJ2xlZnQnOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHg6IC10aGlzLnNpemUoKS53aWR0aCAtIHRoaXMub2Zmc2V0KCksXG4gICAgICAgICAgeTogdGhpcy5ub2RlLnNpemUoKS5oZWlnaHQgLyAyIC0gdGhpcy5zaXplKCkuaGVpZ2h0IC8gMixcbiAgICAgICAgfTtcbiAgICAgIGNhc2UgJ3JpZ2h0JzpcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICB4OiB0aGlzLm5vZGUuc2l6ZSgpLndpZHRoICsgdGhpcy5vZmZzZXQoKSxcbiAgICAgICAgICB5OiB0aGlzLm5vZGUuc2l6ZSgpLmhlaWdodCAvIDIgLSB0aGlzLnNpemUoKS5oZWlnaHQgLyAyLFxuICAgICAgICB9O1xuICAgIH1cbiAgfSk7XG5cbiAgcHVibGljIHRyYW5zZm9ybSA9IGNvbXB1dGVkKCgpID0+IGB0cmFuc2xhdGUoJHt0aGlzLnBvaW50KCkueH0sICR7dGhpcy5wb2ludCgpLnl9KWApO1xuXG4gIHB1YmxpYyBzaXplID0gc2lnbmFsKHsgd2lkdGg6IDAsIGhlaWdodDogMCB9KTtcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgbm9kZTogTm9kZU1vZGVsKSB7fVxufVxuIl19
|
package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Directive, input } from
|
|
2
|
-
import { CustomNodeBaseComponent } from
|
|
1
|
+
import { Directive, input } from '@angular/core';
|
|
2
|
+
import { CustomNodeBaseComponent } from '../../components/custom-node-base/custom-node-base.component';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class CustomDynamicNodeComponent extends CustomNodeBaseComponent {
|
|
5
5
|
constructor() {
|
|
@@ -22,4 +22,4 @@ export class CustomDynamicNodeComponent extends CustomNodeBaseComponent {
|
|
|
22
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomDynamicNodeComponent, decorators: [{
|
|
23
23
|
type: Directive
|
|
24
24
|
}] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWR5bmFtaWMtbm9kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvY3VzdG9tLWR5bmFtaWMtbm9kZS9jdXN0b20tZHluYW1pYy1ub2RlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7QUFHdkcsTUFBTSxPQUFnQiwwQkFBb0MsU0FBUSx1QkFBMEI7SUFENUY7O1FBRUU7O1dBRUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBMkIsQ0FBQztLQVd6RDtJQVRpQixRQUFRO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUM7UUFFOUIsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ25CLENBQUM7UUFFRCxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkIsQ0FBQzsrR0FkbUIsMEJBQTBCO21HQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBRC9DLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudER5bmFtaWNOb2RlIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9ub2RlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvY3VzdG9tLW5vZGUtYmFzZS9jdXN0b20tbm9kZS1iYXNlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbUR5bmFtaWNOb2RlQ29tcG9uZW50PFQgPSBhbnk+IGV4dGVuZHMgQ3VzdG9tTm9kZUJhc2VDb21wb25lbnQ8VD4gaW1wbGVtZW50cyBPbkluaXQge1xuICAvKipcbiAgICogUmVmZXJlbmNlIHRvIG5vZGUgYm91bmQgdG8gdGhpcyBjb21wb25lbnRcbiAgICovXG4gIHB1YmxpYyBub2RlID0gaW5wdXQucmVxdWlyZWQ8Q29tcG9uZW50RHluYW1pY05vZGU8VD4+KCk7XG5cbiAgcHVibGljIG92ZXJyaWRlIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGRhdGEgPSB0aGlzLm5vZGUoKS5kYXRhO1xuXG4gICAgaWYgKGRhdGEpIHtcbiAgICAgIHRoaXMuZGF0YSA9IGRhdGE7XG4gICAgfVxuXG4gICAgc3VwZXIubmdPbkluaXQoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Directive, input } from
|
|
2
|
-
import { CustomNodeBaseComponent } from
|
|
1
|
+
import { Directive, input } from '@angular/core';
|
|
2
|
+
import { CustomNodeBaseComponent } from '../../components/custom-node-base/custom-node-base.component';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class CustomNodeComponent extends CustomNodeBaseComponent {
|
|
5
5
|
constructor() {
|
|
@@ -21,4 +21,4 @@ export class CustomNodeComponent extends CustomNodeBaseComponent {
|
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomNodeComponent, decorators: [{
|
|
22
22
|
type: Directive
|
|
23
23
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL2N1c3RvbS1ub2RlL2N1c3RvbS1ub2RlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7QUFHdkcsTUFBTSxPQUFnQixtQkFBNkIsU0FBUSx1QkFBMEI7SUFEckY7O1FBRUU7O1dBRUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBb0IsQ0FBQztLQVNsRDtJQVBpQixRQUFRO1FBQ3RCLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsQyxDQUFDO1FBRUQsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25CLENBQUM7K0dBWm1CLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUR4QyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnROb2RlIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9ub2RlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvY3VzdG9tLW5vZGUtYmFzZS9jdXN0b20tbm9kZS1iYXNlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbU5vZGVDb21wb25lbnQ8VCA9IGFueT4gZXh0ZW5kcyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudDxUPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIC8qKlxuICAgKiBSZWZlcmVuY2UgdG8gbm9kZSBib3VuZCB0byB0aGlzIGNvbXBvbmVudFxuICAgKi9cbiAgcHVibGljIG5vZGUgPSBpbnB1dC5yZXF1aXJlZDxDb21wb25lbnROb2RlPFQ+PigpO1xuXG4gIHB1YmxpYyBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5ub2RlKCkuZGF0YSkge1xuICAgICAgdGhpcy5kYXRhLnNldCh0aGlzLm5vZGUoKS5kYXRhKTtcbiAgICB9XG5cbiAgICBzdXBlci5uZ09uSW5pdCgpO1xuICB9XG59XG4iXX0=
|
|
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, Injector, inject, input, } from '@angular/core';
|
|
3
3
|
import { HandleService } from '../../services/handle.service';
|
|
4
4
|
import { HandleModel } from '../../models/handle.model';
|
|
5
|
-
import { InjectionContext
|
|
5
|
+
import { InjectionContext } from '../../decorators/run-in-injection-context.decorator';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export class HandleComponent {
|
|
8
8
|
constructor() {
|
|
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
49
49
|
type: Component,
|
|
50
50
|
args: [{ standalone: true, selector: 'handle', changeDetection: ChangeDetectionStrategy.OnPush, template: "" }]
|
|
51
51
|
}], propDecorators: { ngOnInit: [] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsVUFBVSxFQUNWLFFBQVEsRUFHUixNQUFNLEVBQ04sS0FBSyxHQUNOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFnQixNQUFNLHFEQUFxRCxDQUFDOztBQVFyRyxNQUFNLE9BQU8sZUFBZTtJQU41QjtRQU9TLGFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDM0Isa0JBQWEsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDdEMsWUFBTyxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUMsYUFBYSxDQUFDO1FBQ3BFLGVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFeEM7O1dBRUc7UUFDSSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBWSxDQUFDO1FBRTdDOztXQUVHO1FBQ0ksU0FBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXVCLENBQUM7UUFFcEQ7O1dBRUc7UUFDSSxPQUFFLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFckIsYUFBUSxHQUFHLEtBQUssRUFBb0IsQ0FBQztLQTJCN0M7SUF0QlEsUUFBUTtRQUNiLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFdkMsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxXQUFXLENBQzFCO2dCQUNFLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN6QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRTtnQkFDakIsRUFBRSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7Z0JBQ2IsZUFBZSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYztnQkFDNUMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7YUFDMUIsRUFDRCxJQUFJLENBQ0wsQ0FBQztZQUVGLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUU1QyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7WUFFdkQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDaEYsQ0FBQztJQUNILENBQUM7K0dBL0NVLGVBQWU7bUdBQWYsZUFBZSxrakJDdEI1QixFQUFBOztBRGdEUztJQUROLGdCQUFnQjsrQ0FzQmhCOzRGQS9DVSxlQUFlO2tCQU4zQixTQUFTO2lDQUNJLElBQUksWUFDTixRQUFRLG1CQUVELHVCQUF1QixDQUFDLE1BQU07OEJBNEJ4QyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRGVzdHJveVJlZixcbiAgRWxlbWVudFJlZixcbiAgSW5qZWN0b3IsXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIGluamVjdCxcbiAgaW5wdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi8uLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IEhhbmRsZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9oYW5kbGUuc2VydmljZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuaW1wb3J0IHsgSW5qZWN0aW9uQ29udGV4dCwgV2l0aEluamVjdG9yIH0gZnJvbSAnLi4vLi4vZGVjb3JhdG9ycy9ydW4taW4taW5qZWN0aW9uLWNvbnRleHQuZGVjb3JhdG9yJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnaGFuZGxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2hhbmRsZS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBIYW5kbGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIFdpdGhJbmplY3RvciB7XG4gIHB1YmxpYyBpbmplY3RvciA9IGluamVjdChJbmplY3Rvcik7XG4gIHByaXZhdGUgaGFuZGxlU2VydmljZSA9IGluamVjdChIYW5kbGVTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBlbGVtZW50ID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKS5uYXRpdmVFbGVtZW50O1xuICBwcml2YXRlIGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgLyoqXG4gICAqIEF0IHdoYXQgc2lkZSBvZiBub2RlIHRoaXMgY29tcG9uZW50IHNob3VsZCBiZSBwbGFjZWRcbiAgICovXG4gIHB1YmxpYyBwb3NpdGlvbiA9IGlucHV0LnJlcXVpcmVkPFBvc2l0aW9uPigpO1xuXG4gIC8qKlxuICAgKiBTb3VyY2Ugb3IgdGFyZ2V0XG4gICAqL1xuICBwdWJsaWMgdHlwZSA9IGlucHV0LnJlcXVpcmVkPCdzb3VyY2UnIHwgJ3RhcmdldCc+KCk7XG5cbiAgLyoqXG4gICAqIFNob3VsZCBiZSB1c2VkIGlmIG5vZGUgaGFzIG1vcmUgdGhhbiBvbmUgc291cmNlL3RhcmdldFxuICAgKi9cbiAgcHVibGljIGlkID0gaW5wdXQ8c3RyaW5nPigpO1xuXG4gIHB1YmxpYyB0ZW1wbGF0ZSA9IGlucHV0PFRlbXBsYXRlUmVmPGFueT4+KCk7XG5cbiAgcHVibGljIG1vZGVsITogSGFuZGxlTW9kZWw7XG5cbiAgQEluamVjdGlvbkNvbnRleHRcbiAgcHVibGljIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IG5vZGUgPSB0aGlzLmhhbmRsZVNlcnZpY2Uubm9kZSgpO1xuXG4gICAgaWYgKG5vZGUpIHtcbiAgICAgIHRoaXMubW9kZWwgPSBuZXcgSGFuZGxlTW9kZWwoXG4gICAgICAgIHtcbiAgICAgICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbigpLFxuICAgICAgICAgIHR5cGU6IHRoaXMudHlwZSgpLFxuICAgICAgICAgIGlkOiB0aGlzLmlkKCksXG4gICAgICAgICAgcGFyZW50UmVmZXJlbmNlOiB0aGlzLmVsZW1lbnQucGFyZW50RWxlbWVudCEsXG4gICAgICAgICAgdGVtcGxhdGU6IHRoaXMudGVtcGxhdGUoKSxcbiAgICAgICAgfSxcbiAgICAgICAgbm9kZSxcbiAgICAgICk7XG5cbiAgICAgIHRoaXMuaGFuZGxlU2VydmljZS5jcmVhdGVIYW5kbGUodGhpcy5tb2RlbCk7XG5cbiAgICAgIHJlcXVlc3RBbmltYXRpb25GcmFtZSgoKSA9PiB0aGlzLm1vZGVsLnVwZGF0ZVBhcmVudCgpKTtcblxuICAgICAgdGhpcy5kZXN0cm95UmVmLm9uRGVzdHJveSgoKSA9PiB0aGlzLmhhbmRsZVNlcnZpY2UuZGVzdHJveUhhbmRsZSh0aGlzLm1vZGVsKSk7XG4gICAgfVxuICB9XG59XG4iLCIiXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, computed, inject, Injector, signal, input, viewChild, } from '@angular/core';
|
|
1
|
+
import { Component, computed, inject, Injector, signal, input, viewChild, ChangeDetectionStrategy, } 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';
|
|
@@ -51,26 +51,18 @@ export class MiniMapComponent {
|
|
|
51
51
|
return { x: this.minimapOffset, y: this.minimapOffset };
|
|
52
52
|
case 'top-right':
|
|
53
53
|
return {
|
|
54
|
-
x: this.flowSettingsService.computedFlowWidth() -
|
|
55
|
-
this.minimapWidth() -
|
|
56
|
-
this.minimapOffset,
|
|
54
|
+
x: this.flowSettingsService.computedFlowWidth() - this.minimapWidth() - this.minimapOffset,
|
|
57
55
|
y: this.minimapOffset,
|
|
58
56
|
};
|
|
59
57
|
case 'bottom-left':
|
|
60
58
|
return {
|
|
61
59
|
x: this.minimapOffset,
|
|
62
|
-
y: this.flowSettingsService.computedFlowHeight() -
|
|
63
|
-
this.minimapHeight() -
|
|
64
|
-
this.minimapOffset,
|
|
60
|
+
y: this.flowSettingsService.computedFlowHeight() - this.minimapHeight() - this.minimapOffset,
|
|
65
61
|
};
|
|
66
62
|
case 'bottom-right':
|
|
67
63
|
return {
|
|
68
|
-
x: this.flowSettingsService.computedFlowWidth() -
|
|
69
|
-
|
|
70
|
-
this.minimapOffset,
|
|
71
|
-
y: this.flowSettingsService.computedFlowHeight() -
|
|
72
|
-
this.minimapHeight() -
|
|
73
|
-
this.minimapOffset,
|
|
64
|
+
x: this.flowSettingsService.computedFlowWidth() - this.minimapWidth() - this.minimapOffset,
|
|
65
|
+
y: this.flowSettingsService.computedFlowHeight() - this.minimapHeight() - this.minimapOffset,
|
|
74
66
|
};
|
|
75
67
|
}
|
|
76
68
|
});
|
|
@@ -107,10 +99,10 @@ export class MiniMapComponent {
|
|
|
107
99
|
return node;
|
|
108
100
|
}
|
|
109
101
|
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()\"
|
|
102
|
+
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 fill=\"none\"\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.stroke]=\"strokeColor()\" />\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 <svg:rect [attr.width]=\"minimapWidth()\" [attr.height]=\"minimapHeight()\" [attr.fill]=\"maskColor()\" />\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 @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n <ng-container>\n @if (model.node.type === 'default' || model.node.type === 'html-template' || model.isComponentType) {\n <svg:foreignObject\n [attr.transform]=\"model.pointTransform()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\">\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 <div [outerHTML]=\"model.text()\"></div>\n </default-node>\n </svg:foreignObject>\n }\n @if (model.node.type === 'default-group' || model.node.type === 'template-group') {\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 </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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
111
103
|
}
|
|
112
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiniMapComponent, decorators: [{
|
|
113
105
|
type: Component,
|
|
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()\"
|
|
106
|
+
args: [{ standalone: true, selector: 'mini-map', imports: [DefaultNodeComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #minimap>\n <svg:rect\n fill=\"none\"\n [attr.x]=\"minimapPoint().x\"\n [attr.y]=\"minimapPoint().y\"\n [attr.width]=\"minimapWidth()\"\n [attr.height]=\"minimapHeight()\"\n [attr.stroke]=\"strokeColor()\" />\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 <svg:rect [attr.width]=\"minimapWidth()\" [attr.height]=\"minimapHeight()\" [attr.fill]=\"maskColor()\" />\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 @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n <ng-container>\n @if (model.node.type === 'default' || model.node.type === 'html-template' || model.isComponentType) {\n <svg:foreignObject\n [attr.transform]=\"model.pointTransform()\"\n [attr.width]=\"model.size().width\"\n [attr.height]=\"model.size().height\">\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 <div [outerHTML]=\"model.text()\"></div>\n </default-node>\n </svg:foreignObject>\n }\n @if (model.node.type === 'default-group' || model.node.type === 'template-group') {\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 </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
107
|
}] });
|
|
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"]}
|
|
108
|
+
//# 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  OnInit,\n  signal,\n  TemplateRef,\n  input,\n  viewChild,\n  ChangeDetectionStrategy,\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 = 'top-left' | 'top-right' | 'bottom-left' | '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  changeDetection: ChangeDetectionStrategy.OnPush,\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: 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(() => this.flowSettingsService.computedFlowWidth() * this.minimapScale());\n  protected minimapHeight = computed(() => this.flowSettingsService.computedFlowHeight() * this.minimapScale());\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    fill=\"none\"\n    [attr.x]=\"minimapPoint().x\"\n    [attr.y]=\"minimapPoint().y\"\n    [attr.width]=\"minimapWidth()\"\n    [attr.height]=\"minimapHeight()\"\n    [attr.stroke]=\"strokeColor()\" />\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    <svg:rect [attr.width]=\"minimapWidth()\" [attr.height]=\"minimapHeight()\" [attr.fill]=\"maskColor()\" />\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      @for (model of entitiesService.nodes(); track trackNodes($index, model)) {\n        <ng-container>\n          @if (model.node.type === 'default' || model.node.type === 'html-template' || model.isComponentType) {\n            <svg:foreignObject\n              [attr.transform]=\"model.pointTransform()\"\n              [attr.width]=\"model.size().width\"\n              [attr.height]=\"model.size().height\">\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                <div [outerHTML]=\"model.text()\"></div>\n              </default-node>\n            </svg:foreignObject>\n          }\n          @if (model.node.type === 'default-group' || model.node.type === 'template-group') {\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        </ng-container>\n      }\n    </svg:g>\n  </svg:svg>\n</ng-template>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, inject, input, viewChild, effect, forwardRef } from '@angular/core';
|
|
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';
|
|
@@ -57,7 +57,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
57
57
|
type: Directive,
|
|
58
58
|
args: [{
|
|
59
59
|
selector: '[nodeToolbarWrapper]',
|
|
60
|
-
standalone: true
|
|
60
|
+
standalone: true,
|
|
61
61
|
}]
|
|
62
62
|
}] });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9ub2RlLXRvb2xiYXIvbm9kZS10b29sYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUlOLEtBQUssRUFDTCxTQUFTLEVBQ1QsTUFBTSxFQUNOLFVBQVUsR0FDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBc0IzRSxNQUFNLE9BQU8sb0JBQW9CO0lBVS9CO1FBVFEsb0JBQWUsR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDMUMsZ0JBQVcsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUUzQyxhQUFRLEdBQUcsS0FBSyxDQUFXLEtBQUssQ0FBQyxDQUFDO1FBRWxDLDJCQUFzQixHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQXVCLFNBQVMsQ0FBQyxDQUFDO1FBRTFFLFVBQUssR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRyxDQUFDLENBQUM7UUFHNUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLGlCQUFpQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUMsQ0FBQztRQUV2RCxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELENBQUM7K0dBdEJVLG9CQUFvQjttR0FBcEIsb0JBQW9CLHdWQWpCckI7Ozs7OztHQU1ULDJIQXdDVSwyQkFBMkI7OzRGQTdCM0Isb0JBQW9CO2tCQXBCaEMsU0FBUztpQ0FDSSxJQUFJLFlBQ04sY0FBYyxZQUNkOzs7Ozs7R0FNVCxtQkFRZ0IsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDOztBQStCMUQsTUFBTSxPQUFPLDJCQUEyQjtJQUp4QztRQUtVLFlBQU8sR0FBRyxNQUFNLENBQTBCLFVBQVUsQ0FBQyxDQUFDO1FBRXZELFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFnQixDQUFDO0tBUS9DO0lBTlEsUUFBUTtRQUNiLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ3BCLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxXQUFXO1lBQzdDLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxZQUFZO1NBQ2hELENBQUMsQ0FBQztJQUNMLENBQUM7K0dBVlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBSnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtvQkFDaEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgaW5qZWN0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIGlucHV0LFxuICB2aWV3Q2hpbGQsXG4gIGVmZmVjdCxcbiAgZm9yd2FyZFJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBvc2l0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMvcG9zaXRpb24udHlwZSc7XG5pbXBvcnQgeyBUb29sYmFyTW9kZWwgfSBmcm9tICcuLi8uLi9tb2RlbHMvdG9vbGJhci5tb2RlbCc7XG5pbXBvcnQgeyBPdmVybGF5c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9vdmVybGF5cy5zZXJ2aWNlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdub2RlLXRvb2xiYXInLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxuZy10ZW1wbGF0ZSAjdG9vbGJhcj5cbiAgICAgIDxkaXYgY2xhc3M9XCJ3cmFwcGVyXCIgbm9kZVRvb2xiYXJXcmFwcGVyIFttb2RlbF09XCJtb2RlbFwiPlxuICAgICAgICA8bmctY29udGVudCAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9uZy10ZW1wbGF0ZT5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgLndyYXBwZXIge1xuICAgICAgICB3aWR0aDogbWF4LWNvbnRlbnQ7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtmb3J3YXJkUmVmKCgpID0+IE5vZGVUb29sYmFyV3JhcHBlckRpcmVjdGl2ZSldLFxufSlcbmV4cG9ydCBjbGFzcyBOb2RlVG9vbGJhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSBvdmVybGF5c1NlcnZpY2UgPSBpbmplY3QoT3ZlcmxheXNTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBub2RlU2VydmljZSA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKTtcblxuICBwdWJsaWMgcG9zaXRpb24gPSBpbnB1dDxQb3NpdGlvbj4oJ3RvcCcpO1xuXG4gIHB1YmxpYyB0b29sYmFyQ29udGVudFRlbXBsYXRlID0gdmlld0NoaWxkLnJlcXVpcmVkPFRlbXBsYXRlUmVmPHVua25vd24+PigndG9vbGJhcicpO1xuXG4gIHByb3RlY3RlZCBtb2RlbCA9IG5ldyBUb29sYmFyTW9kZWwodGhpcy5ub2RlU2VydmljZS5tb2RlbCgpISk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgZWZmZWN0KCgpID0+IHRoaXMubW9kZWwucG9zaXRpb24uc2V0KHRoaXMucG9zaXRpb24oKSksIHsgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUgfSk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5tb2RlbC50ZW1wbGF0ZS5zZXQodGhpcy50b29sYmFyQ29udGVudFRlbXBsYXRlKCkpO1xuXG4gICAgdGhpcy5vdmVybGF5c1NlcnZpY2UuYWRkVG9vbGJhcih0aGlzLm1vZGVsKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXJsYXlzU2VydmljZS5yZW1vdmVUb29sYmFyKHRoaXMubW9kZWwpO1xuICB9XG59XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tub2RlVG9vbGJhcldyYXBwZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTm9kZVRvb2xiYXJXcmFwcGVyRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHJpdmF0ZSBlbGVtZW50ID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICBwdWJsaWMgbW9kZWwgPSBpbnB1dC5yZXF1aXJlZDxUb29sYmFyTW9kZWw+KCk7XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubW9kZWwoKS5zaXplLnNldCh7XG4gICAgICB3aWR0aDogdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuY2xpZW50V2lkdGgsXG4gICAgICBoZWlnaHQ6IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsaWVudEhlaWdodCxcbiAgICB9KTtcbiAgfVxufVxuIl19
|