ngx-vflow 1.7.0 → 1.7.1

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.
@@ -12,26 +12,18 @@ export class NodeModel {
12
12
  this.rawNode = rawNode;
13
13
  this.entitiesService = inject(FlowEntitiesService);
14
14
  this.point = signal({ x: 0, y: 0 });
15
- this.point$ = toObservable(this.point);
16
15
  this.width = signal(NodeModel.defaultWidth);
17
- this.width$ = toObservable(this.width);
18
16
  this.height = signal(NodeModel.defaultHeight);
19
- this.height$ = toObservable(this.height);
20
17
  /**
21
18
  * @deprecated use width or height signals
22
19
  */
23
20
  this.size = computed(() => ({ width: this.width(), height: this.height() }));
24
- /**
25
- * @deprecated use width$ or height$
26
- */
27
- this.size$ = toObservable(this.size);
28
21
  this.styleWidth = computed(() => `${this.width()}px`);
29
22
  this.styleHeight = computed(() => `${this.height()}px`);
30
23
  this.foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
31
24
  this.foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
32
25
  this.renderOrder = signal(0);
33
26
  this.selected = signal(false);
34
- this.selected$ = toObservable(this.selected);
35
27
  this.globalPoint = computed(() => {
36
28
  let parent = this.parent();
37
29
  let x = this.point().x;
@@ -45,7 +37,6 @@ export class NodeModel {
45
37
  });
46
38
  this.pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);
47
39
  this.handles = signal([]);
48
- this.handles$ = toObservable(this.handles);
49
40
  this.draggable = signal(true);
50
41
  this.dragHandlesCount = signal(0);
51
42
  // disabled for configuration for now
@@ -121,9 +112,16 @@ export class NodeModel {
121
112
  },
122
113
  };
123
114
  }
115
+ // Initialize Observables after all signal assignments
116
+ this.point$ = toObservable(this.point);
117
+ this.width$ = toObservable(this.width);
118
+ this.height$ = toObservable(this.height);
119
+ this.size$ = toObservable(this.size);
120
+ this.selected$ = toObservable(this.selected);
121
+ this.handles$ = toObservable(this.handles);
124
122
  }
125
123
  setPoint(point) {
126
124
  this.point.set(point);
127
125
  }
128
126
  }
129
- //# 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 { TemplateRef, computed, inject, signal } from '@angular/core';\nimport { DynamicNode, Node, isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { GroupNodeContext, NodeContext } from '../interfaces/template-context.interface';\nimport { toUnifiedNode } from '../utils/to-unified-node';\n\nexport class NodeModel<T = unknown>\n  implements FlowEntity, Contextable<NodeContext | GroupNodeContext | { $implicit: object }>\n{\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private entitiesService = inject(FlowEntitiesService);\n\n  public point = signal<Point>({ x: 0, y: 0 });\n  public point$ = toObservable(this.point);\n\n  public width = signal(NodeModel.defaultWidth);\n  public width$ = toObservable(this.width);\n\n  public height = signal(NodeModel.defaultHeight);\n  public height$ = toObservable(this.height);\n\n  /**\n   * @deprecated use width or height signals\n   */\n  public size = computed(() => ({ width: this.width(), height: this.height() }));\n  /**\n   * @deprecated use width$ or height$\n   */\n  public size$ = toObservable(this.size);\n\n  public styleWidth = computed(() => `${this.width()}px`);\n  public styleHeight = computed(() => `${this.height()}px`);\n\n  public foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n  public foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\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  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    isComponentStaticNode(this.rawNode as Node) || isComponentDynamicNode(this.rawNode as DynamicNode);\n\n  // Default node specific thing\n  public text = signal('');\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.rawNode,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.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  public context = {\n    $implicit: {},\n  };\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public rawNode: Node<T> | DynamicNode<T>) {\n    const internalNode = toUnifiedNode(rawNode);\n\n    if (internalNode.point) {\n      this.point = internalNode.point;\n    }\n\n    if (internalNode.width) {\n      this.width = internalNode.width;\n    }\n\n    if (internalNode.height) {\n      this.height = internalNode.height;\n    }\n\n    if (internalNode.draggable) {\n      this.draggable = internalNode.draggable;\n    }\n\n    if (internalNode.parentId) {\n      this.parentId = internalNode.parentId;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.color) {\n      this.color = internalNode.color;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.resizable) {\n      this.resizable = internalNode.resizable;\n    }\n\n    if (internalNode.type === 'default' && internalNode.text) {\n      this.text = internalNode.text;\n    }\n\n    if (internalNode.type === 'html-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n        },\n      };\n    }\n\n    if (internalNode.type === 'svg-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    if (internalNode.type === 'template-group') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n  }\n\n  public setPoint(point: Point) {\n    this.point.set(point);\n  }\n}\n"]}
127
+ //# 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 { TemplateRef, computed, inject, signal } from '@angular/core';\nimport { DynamicNode, Node, isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { GroupNodeContext, NodeContext } from '../interfaces/template-context.interface';\nimport { toUnifiedNode } from '../utils/to-unified-node';\nimport { Observable } from 'rxjs';\n\nexport class NodeModel<T = unknown>\n  implements FlowEntity, Contextable<NodeContext | GroupNodeContext | { $implicit: object }>\n{\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private entitiesService = inject(FlowEntitiesService);\n\n  public point = signal<Point>({ x: 0, y: 0 });\n  public point$: Observable<Point>;\n\n  public width = signal(NodeModel.defaultWidth);\n  public width$: Observable<number>;\n\n  public height = signal(NodeModel.defaultHeight);\n  public height$: Observable<number>;\n\n  /**\n   * @deprecated use width or height signals\n   */\n  public size = computed(() => ({ width: this.width(), height: this.height() }));\n  /**\n   * @deprecated use width$ or height$\n   */\n  public size$: Observable<{ width: number; height: number }>;\n\n  public styleWidth = computed(() => `${this.width()}px`);\n  public styleHeight = computed(() => `${this.height()}px`);\n\n  public foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n  public foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n\n  public renderOrder = signal(0);\n\n  public selected = signal(false);\n  public selected$: Observable<boolean>;\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  public handles$: Observable<HandleModel[]>;\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    isComponentStaticNode(this.rawNode as Node) || isComponentDynamicNode(this.rawNode as DynamicNode);\n\n  // Default node specific thing\n  public text = signal('');\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.rawNode,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.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  public context = {\n    $implicit: {},\n  };\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public rawNode: Node<T> | DynamicNode<T>) {\n    const internalNode = toUnifiedNode(rawNode);\n\n    if (internalNode.point) {\n      this.point = internalNode.point;\n    }\n\n    if (internalNode.width) {\n      this.width = internalNode.width;\n    }\n\n    if (internalNode.height) {\n      this.height = internalNode.height;\n    }\n\n    if (internalNode.draggable) {\n      this.draggable = internalNode.draggable;\n    }\n\n    if (internalNode.parentId) {\n      this.parentId = internalNode.parentId;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.color) {\n      this.color = internalNode.color;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.resizable) {\n      this.resizable = internalNode.resizable;\n    }\n\n    if (internalNode.type === 'default' && internalNode.text) {\n      this.text = internalNode.text;\n    }\n\n    if (internalNode.type === 'html-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n        },\n      };\n    }\n\n    if (internalNode.type === 'svg-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected,\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    if (internalNode.type === 'template-group') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width,\n          height: this.height,\n        },\n      };\n    }\n\n    // Initialize Observables after all signal assignments\n    this.point$ = toObservable(this.point);\n    this.width$ = toObservable(this.width);\n    this.height$ = toObservable(this.height);\n    this.size$ = toObservable(this.size);\n    this.selected$ = toObservable(this.selected);\n    this.handles$ = toObservable(this.handles);\n  }\n\n  public setPoint(point: Point) {\n    this.point.set(point);\n  }\n}\n"]}
@@ -1,8 +1,11 @@
1
- import { ChangeDetectionStrategy, Component, ElementRef, inject, input, viewChild, effect, forwardRef, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, ElementRef, inject, input, viewChild, effect, forwardRef, NgZone, DestroyRef, } 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';
5
5
  import { NodeAccessorService } from '../../services/node-accessor.service';
6
+ import { resizable } from '../../utils/resizable';
7
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
8
+ import { tap } from 'rxjs';
6
9
  import * as i0 from "@angular/core";
7
10
  export class NodeToolbarComponent {
8
11
  constructor() {
@@ -42,9 +45,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
42
45
  export class NodeToolbarWrapperDirective {
43
46
  constructor() {
44
47
  this.element = inject(ElementRef);
48
+ this.zone = inject(NgZone);
49
+ this.destroyRef = inject(DestroyRef);
45
50
  this.model = input.required();
46
51
  }
47
52
  ngOnInit() {
53
+ resizable([this.element.nativeElement], this.zone)
54
+ .pipe(tap(() => this.setSize()), takeUntilDestroyed(this.destroyRef))
55
+ .subscribe();
56
+ }
57
+ setSize() {
48
58
  this.model().size.set({
49
59
  width: this.element.nativeElement.clientWidth,
50
60
  height: this.element.nativeElement.clientHeight,
@@ -60,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
60
70
  standalone: true,
61
71
  }]
62
72
  }] });
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9ub2RlLXRvb2xiYXIvbm9kZS10b29sYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUlOLEtBQUssRUFDTCxTQUFTLEVBQ1QsTUFBTSxFQUNOLFVBQVUsR0FDWCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBc0IzRSxNQUFNLE9BQU8sb0JBQW9CO0lBVS9CO1FBVFEsb0JBQWUsR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDMUMsZ0JBQVcsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUUzQyxhQUFRLEdBQUcsS0FBSyxDQUFXLEtBQUssQ0FBQyxDQUFDO1FBRS9CLDJCQUFzQixHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQXVCLFNBQVMsQ0FBQyxDQUFDO1FBRTdFLFVBQUssR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRyxDQUFDLENBQUM7UUFHNUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxFQUFFLGlCQUFpQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUMsQ0FBQztRQUV2RCxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELENBQUM7K0dBdEJVLG9CQUFvQjttR0FBcEIsb0JBQW9CLHdWQWpCckI7Ozs7OztHQU1ULDJIQXdDVSwyQkFBMkI7OzRGQTdCM0Isb0JBQW9CO2tCQXBCaEMsU0FBUztpQ0FDSSxJQUFJLFlBQ04sY0FBYyxZQUNkOzs7Ozs7R0FNVCxtQkFRZ0IsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDOztBQStCMUQsTUFBTSxPQUFPLDJCQUEyQjtJQUp4QztRQUtVLFlBQU8sR0FBRyxNQUFNLENBQTBCLFVBQVUsQ0FBQyxDQUFDO1FBRXZELFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFnQixDQUFDO0tBUS9DO0lBTlEsUUFBUTtRQUNiLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ3BCLEtBQUssRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxXQUFXO1lBQzdDLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxZQUFZO1NBQ2hELENBQUMsQ0FBQztJQUNMLENBQUM7K0dBVlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBSnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtvQkFDaEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgaW5qZWN0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIGlucHV0LFxuICB2aWV3Q2hpbGQsXG4gIGVmZmVjdCxcbiAgZm9yd2FyZFJlZixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBvc2l0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMvcG9zaXRpb24udHlwZSc7XG5pbXBvcnQgeyBUb29sYmFyTW9kZWwgfSBmcm9tICcuLi8uLi9tb2RlbHMvdG9vbGJhci5tb2RlbCc7XG5pbXBvcnQgeyBPdmVybGF5c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9vdmVybGF5cy5zZXJ2aWNlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdub2RlLXRvb2xiYXInLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxuZy10ZW1wbGF0ZSAjdG9vbGJhcj5cbiAgICAgIDxkaXYgY2xhc3M9XCJ3cmFwcGVyXCIgbm9kZVRvb2xiYXJXcmFwcGVyIFttb2RlbF09XCJtb2RlbFwiPlxuICAgICAgICA8bmctY29udGVudCAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9uZy10ZW1wbGF0ZT5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgLndyYXBwZXIge1xuICAgICAgICB3aWR0aDogbWF4LWNvbnRlbnQ7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtmb3J3YXJkUmVmKCgpID0+IE5vZGVUb29sYmFyV3JhcHBlckRpcmVjdGl2ZSldLFxufSlcbmV4cG9ydCBjbGFzcyBOb2RlVG9vbGJhckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSBvdmVybGF5c1NlcnZpY2UgPSBpbmplY3QoT3ZlcmxheXNTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBub2RlU2VydmljZSA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKTtcblxuICBwdWJsaWMgcG9zaXRpb24gPSBpbnB1dDxQb3NpdGlvbj4oJ3RvcCcpO1xuXG4gIHByb3RlY3RlZCB0b29sYmFyQ29udGVudFRlbXBsYXRlID0gdmlld0NoaWxkLnJlcXVpcmVkPFRlbXBsYXRlUmVmPHVua25vd24+PigndG9vbGJhcicpO1xuXG4gIHByb3RlY3RlZCBtb2RlbCA9IG5ldyBUb29sYmFyTW9kZWwodGhpcy5ub2RlU2VydmljZS5tb2RlbCgpISk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgZWZmZWN0KCgpID0+IHRoaXMubW9kZWwucG9zaXRpb24uc2V0KHRoaXMucG9zaXRpb24oKSksIHsgYWxsb3dTaWduYWxXcml0ZXM6IHRydWUgfSk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5tb2RlbC50ZW1wbGF0ZS5zZXQodGhpcy50b29sYmFyQ29udGVudFRlbXBsYXRlKCkpO1xuXG4gICAgdGhpcy5vdmVybGF5c1NlcnZpY2UuYWRkVG9vbGJhcih0aGlzLm1vZGVsKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXJsYXlzU2VydmljZS5yZW1vdmVUb29sYmFyKHRoaXMubW9kZWwpO1xuICB9XG59XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tub2RlVG9vbGJhcldyYXBwZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTm9kZVRvb2xiYXJXcmFwcGVyRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHJpdmF0ZSBlbGVtZW50ID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICBwdWJsaWMgbW9kZWwgPSBpbnB1dC5yZXF1aXJlZDxUb29sYmFyTW9kZWw+KCk7XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubW9kZWwoKS5zaXplLnNldCh7XG4gICAgICB3aWR0aDogdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuY2xpZW50V2lkdGgsXG4gICAgICBoZWlnaHQ6IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsaWVudEhlaWdodCxcbiAgICB9KTtcbiAgfVxufVxuIl19
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10b29sYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9ub2RlLXRvb2xiYXIvbm9kZS10b29sYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUlOLEtBQUssRUFDTCxTQUFTLEVBQ1QsTUFBTSxFQUNOLFVBQVUsRUFDVixNQUFNLEVBQ04sVUFBVSxHQUNYLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFzQjNCLE1BQU0sT0FBTyxvQkFBb0I7SUFVL0I7UUFUUSxvQkFBZSxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUMxQyxnQkFBVyxHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRTNDLGFBQVEsR0FBRyxLQUFLLENBQVcsS0FBSyxDQUFDLENBQUM7UUFFL0IsMkJBQXNCLEdBQUcsU0FBUyxDQUFDLFFBQVEsQ0FBdUIsU0FBUyxDQUFDLENBQUM7UUFFN0UsVUFBSyxHQUFHLElBQUksWUFBWSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFHLENBQUMsQ0FBQztRQUc1RCxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN0RixDQUFDO0lBRU0sUUFBUTtRQUNiLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQyxDQUFDO1FBRXZELElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsQ0FBQzsrR0F0QlUsb0JBQW9CO21HQUFwQixvQkFBb0Isd1ZBakJyQjs7Ozs7O0dBTVQsMkhBd0NVLDJCQUEyQjs7NEZBN0IzQixvQkFBb0I7a0JBcEJoQyxTQUFTO2lDQUNJLElBQUksWUFDTixjQUFjLFlBQ2Q7Ozs7OztHQU1ULG1CQVFnQix1QkFBdUIsQ0FBQyxNQUFNLFdBQ3RDLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLDJCQUEyQixDQUFDLENBQUM7O0FBK0IxRCxNQUFNLE9BQU8sMkJBQTJCO0lBSnhDO1FBS1UsWUFBTyxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUM7UUFDN0MsU0FBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0QixlQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRTFDLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFnQixDQUFDO0tBaUIvQztJQWZRLFFBQVE7UUFDYixTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDL0MsSUFBSSxDQUNILEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsRUFDekIsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUNwQzthQUNBLFNBQVMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFFTyxPQUFPO1FBQ2IsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDcEIsS0FBSyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFdBQVc7WUFDN0MsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLFlBQVk7U0FDaEQsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzsrR0FyQlUsMkJBQTJCO21HQUEzQiwyQkFBMkI7OzRGQUEzQiwyQkFBMkI7a0JBSnZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtvQkFDaEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgaW5qZWN0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIGlucHV0LFxuICB2aWV3Q2hpbGQsXG4gIGVmZmVjdCxcbiAgZm9yd2FyZFJlZixcbiAgTmdab25lLFxuICBEZXN0cm95UmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi8uLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IFRvb2xiYXJNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy90b29sYmFyLm1vZGVsJztcbmltcG9ydCB7IE92ZXJsYXlzU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL292ZXJsYXlzLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZUFjY2Vzc29yU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZSc7XG5pbXBvcnQgeyByZXNpemFibGUgfSBmcm9tICcuLi8uLi91dGlscy9yZXNpemFibGUnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgdGFwIH0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ25vZGUtdG9vbGJhcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG5nLXRlbXBsYXRlICN0b29sYmFyPlxuICAgICAgPGRpdiBjbGFzcz1cIndyYXBwZXJcIiBub2RlVG9vbGJhcldyYXBwZXIgW21vZGVsXT1cIm1vZGVsXCI+XG4gICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLXRlbXBsYXRlPlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAud3JhcHBlciB7XG4gICAgICAgIHdpZHRoOiBtYXgtY29udGVudDtcbiAgICAgIH1cbiAgICBgLFxuICBdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW2ZvcndhcmRSZWYoKCkgPT4gTm9kZVRvb2xiYXJXcmFwcGVyRGlyZWN0aXZlKV0sXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVUb29sYmFyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBwcml2YXRlIG92ZXJsYXlzU2VydmljZSA9IGluamVjdChPdmVybGF5c1NlcnZpY2UpO1xuICBwcml2YXRlIG5vZGVTZXJ2aWNlID0gaW5qZWN0KE5vZGVBY2Nlc3NvclNlcnZpY2UpO1xuXG4gIHB1YmxpYyBwb3NpdGlvbiA9IGlucHV0PFBvc2l0aW9uPigndG9wJyk7XG5cbiAgcHJvdGVjdGVkIHRvb2xiYXJDb250ZW50VGVtcGxhdGUgPSB2aWV3Q2hpbGQucmVxdWlyZWQ8VGVtcGxhdGVSZWY8dW5rbm93bj4+KCd0b29sYmFyJyk7XG5cbiAgcHJvdGVjdGVkIG1vZGVsID0gbmV3IFRvb2xiYXJNb2RlbCh0aGlzLm5vZGVTZXJ2aWNlLm1vZGVsKCkhKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBlZmZlY3QoKCkgPT4gdGhpcy5tb2RlbC5wb3NpdGlvbi5zZXQodGhpcy5wb3NpdGlvbigpKSwgeyBhbGxvd1NpZ25hbFdyaXRlczogdHJ1ZSB9KTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm1vZGVsLnRlbXBsYXRlLnNldCh0aGlzLnRvb2xiYXJDb250ZW50VGVtcGxhdGUoKSk7XG5cbiAgICB0aGlzLm92ZXJsYXlzU2VydmljZS5hZGRUb29sYmFyKHRoaXMubW9kZWwpO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMub3ZlcmxheXNTZXJ2aWNlLnJlbW92ZVRvb2xiYXIodGhpcy5tb2RlbCk7XG4gIH1cbn1cblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25vZGVUb29sYmFyV3JhcHBlcl0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBOb2RlVG9vbGJhcldyYXBwZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcml2YXRlIGVsZW1lbnQgPSBpbmplY3Q8RWxlbWVudFJlZjxIVE1MRWxlbWVudD4+KEVsZW1lbnRSZWYpO1xuICBwcml2YXRlIHJlYWRvbmx5IHpvbmUgPSBpbmplY3QoTmdab25lKTtcbiAgcHJpdmF0ZSByZWFkb25seSBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuXG4gIHB1YmxpYyBtb2RlbCA9IGlucHV0LnJlcXVpcmVkPFRvb2xiYXJNb2RlbD4oKTtcblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgcmVzaXphYmxlKFt0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudF0sIHRoaXMuem9uZSlcbiAgICAgIC5waXBlKFxuICAgICAgICB0YXAoKCkgPT4gdGhpcy5zZXRTaXplKCkpLFxuICAgICAgICB0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKSxcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKTtcbiAgfVxuXG4gIHByaXZhdGUgc2V0U2l6ZSgpIHtcbiAgICB0aGlzLm1vZGVsKCkuc2l6ZS5zZXQoe1xuICAgICAgd2lkdGg6IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmNsaWVudFdpZHRoLFxuICAgICAgaGVpZ2h0OiB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5jbGllbnRIZWlnaHQsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -936,26 +936,18 @@ class NodeModel {
936
936
  this.rawNode = rawNode;
937
937
  this.entitiesService = inject(FlowEntitiesService);
938
938
  this.point = signal({ x: 0, y: 0 });
939
- this.point$ = toObservable(this.point);
940
939
  this.width = signal(NodeModel.defaultWidth);
941
- this.width$ = toObservable(this.width);
942
940
  this.height = signal(NodeModel.defaultHeight);
943
- this.height$ = toObservable(this.height);
944
941
  /**
945
942
  * @deprecated use width or height signals
946
943
  */
947
944
  this.size = computed(() => ({ width: this.width(), height: this.height() }));
948
- /**
949
- * @deprecated use width$ or height$
950
- */
951
- this.size$ = toObservable(this.size);
952
945
  this.styleWidth = computed(() => `${this.width()}px`);
953
946
  this.styleHeight = computed(() => `${this.height()}px`);
954
947
  this.foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
955
948
  this.foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
956
949
  this.renderOrder = signal(0);
957
950
  this.selected = signal(false);
958
- this.selected$ = toObservable(this.selected);
959
951
  this.globalPoint = computed(() => {
960
952
  let parent = this.parent();
961
953
  let x = this.point().x;
@@ -969,7 +961,6 @@ class NodeModel {
969
961
  });
970
962
  this.pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);
971
963
  this.handles = signal([]);
972
- this.handles$ = toObservable(this.handles);
973
964
  this.draggable = signal(true);
974
965
  this.dragHandlesCount = signal(0);
975
966
  // disabled for configuration for now
@@ -1045,6 +1036,13 @@ class NodeModel {
1045
1036
  },
1046
1037
  };
1047
1038
  }
1039
+ // Initialize Observables after all signal assignments
1040
+ this.point$ = toObservable(this.point);
1041
+ this.width$ = toObservable(this.width);
1042
+ this.height$ = toObservable(this.height);
1043
+ this.size$ = toObservable(this.size);
1044
+ this.selected$ = toObservable(this.selected);
1045
+ this.handles$ = toObservable(this.handles);
1048
1046
  }
1049
1047
  setPoint(point) {
1050
1048
  this.point.set(point);
@@ -3782,9 +3780,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
3782
3780
  class NodeToolbarWrapperDirective {
3783
3781
  constructor() {
3784
3782
  this.element = inject(ElementRef);
3783
+ this.zone = inject(NgZone);
3784
+ this.destroyRef = inject(DestroyRef);
3785
3785
  this.model = input.required();
3786
3786
  }
3787
3787
  ngOnInit() {
3788
+ resizable([this.element.nativeElement], this.zone)
3789
+ .pipe(tap(() => this.setSize()), takeUntilDestroyed(this.destroyRef))
3790
+ .subscribe();
3791
+ }
3792
+ setSize() {
3788
3793
  this.model().size.set({
3789
3794
  width: this.element.nativeElement.clientWidth,
3790
3795
  height: this.element.nativeElement.clientHeight,