ngx-vflow 1.0.6 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/vflow/components/node/node.component.mjs +24 -54
- package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +5 -11
- package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +55 -1
- package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +37 -47
- package/esm2022/lib/vflow/directives/node-handles-controller.directive.mjs +33 -0
- package/esm2022/lib/vflow/directives/node-resize-controller.directive.mjs +35 -0
- package/esm2022/lib/vflow/directives/selectable.directive.mjs +2 -2
- package/esm2022/lib/vflow/models/handle.model.mjs +33 -33
- package/esm2022/lib/vflow/models/node.model.mjs +30 -67
- package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +3 -3
- package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +4 -3
- package/esm2022/lib/vflow/services/draggable.service.mjs +2 -2
- package/esm2022/lib/vflow/services/flow-status.service.mjs +1 -15
- package/esm2022/lib/vflow/services/handle.service.mjs +1 -1
- package/esm2022/lib/vflow/testing-utils/component-mocks/handle-mock.component.mjs +22 -0
- package/esm2022/lib/vflow/testing-utils/component-mocks/minimap-mock.component.mjs +22 -0
- package/esm2022/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.mjs +19 -0
- package/esm2022/lib/vflow/testing-utils/component-mocks/resizable-mock.component.mjs +21 -0
- package/esm2022/lib/vflow/testing-utils/component-mocks/vflow-mock.component.mjs +251 -0
- package/esm2022/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.mjs +15 -0
- package/esm2022/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.mjs +11 -0
- package/esm2022/lib/vflow/testing-utils/directive-mocks/selectable-mock.directive.mjs +14 -0
- package/esm2022/lib/vflow/testing-utils/directive-mocks/template-mock.directive.mjs +87 -0
- package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +9 -8
- package/esm2022/lib/vflow/testing-utils/vflow-mocks.mjs +26 -0
- package/esm2022/lib/vflow/vflow.mjs +3 -1
- package/esm2022/public-api.mjs +11 -1
- package/fesm2022/ngx-vflow.mjs +857 -378
- package/fesm2022/ngx-vflow.mjs.map +1 -1
- package/lib/vflow/components/node/node.component.d.ts +6 -12
- package/lib/vflow/components/vflow/vflow.component.d.ts +4 -5
- package/lib/vflow/directives/changes-controller.directive.d.ts +54 -0
- package/lib/vflow/directives/connection-controller.directive.d.ts +4 -5
- package/lib/vflow/directives/node-handles-controller.directive.d.ts +11 -0
- package/lib/vflow/directives/node-resize-controller.directive.d.ts +11 -0
- package/lib/vflow/models/handle.model.d.ts +8 -23
- package/lib/vflow/models/node.model.d.ts +17 -13
- package/lib/vflow/services/flow-status.service.d.ts +0 -6
- package/lib/vflow/services/handle.service.d.ts +1 -1
- package/lib/vflow/testing-utils/component-mocks/handle-mock.component.d.ts +11 -0
- package/lib/vflow/testing-utils/component-mocks/minimap-mock.component.d.ts +10 -0
- package/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.d.ts +7 -0
- package/lib/vflow/testing-utils/component-mocks/resizable-mock.component.d.ts +8 -0
- package/lib/vflow/testing-utils/component-mocks/vflow-mock.component.d.ts +48 -0
- package/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.d.ts +7 -0
- package/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.d.ts +5 -0
- package/lib/vflow/testing-utils/directive-mocks/selectable-mock.directive.d.ts +5 -0
- package/lib/vflow/testing-utils/directive-mocks/template-mock.directive.d.ts +32 -0
- package/lib/vflow/testing-utils/vflow-mocks.d.ts +10 -0
- package/lib/vflow/vflow.d.ts +2 -1
- package/package.json +1 -1
- package/public-api.d.ts +10 -0
|
@@ -14,26 +14,43 @@ export class HandleModel {
|
|
|
14
14
|
width: 10 + 2 * this.strokeWidth,
|
|
15
15
|
height: 10 + 2 * this.strokeWidth,
|
|
16
16
|
});
|
|
17
|
-
this.
|
|
17
|
+
this.pointAbsolute = computed(() => {
|
|
18
|
+
return {
|
|
19
|
+
x: this.parentNode.globalPoint().x + this.hostOffset().x + this.sizeOffset().x,
|
|
20
|
+
y: this.parentNode.globalPoint().y + this.hostOffset().y + this.sizeOffset().y,
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
this.state = signal('idle');
|
|
24
|
+
this.updateHostSizeAndPosition$ = new Subject();
|
|
25
|
+
this.hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {
|
|
26
|
+
initialValue: { width: 0, height: 0 },
|
|
27
|
+
});
|
|
28
|
+
this.hostPosition = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => ({
|
|
29
|
+
x: this.hostReference instanceof HTMLElement ? this.hostReference.offsetLeft : 0, // for now just 0 for group nodes
|
|
30
|
+
y: this.hostReference instanceof HTMLElement ? this.hostReference.offsetTop : 0, // for now just 0 for group nodes
|
|
31
|
+
}))), {
|
|
32
|
+
initialValue: { x: 0, y: 0 },
|
|
33
|
+
});
|
|
34
|
+
this.hostOffset = computed(() => {
|
|
18
35
|
switch (this.rawHandle.position) {
|
|
19
36
|
case 'left':
|
|
20
37
|
return {
|
|
21
38
|
x: 0,
|
|
22
|
-
y: this.
|
|
39
|
+
y: this.hostPosition().y + this.hostSize().height / 2,
|
|
23
40
|
};
|
|
24
41
|
case 'right':
|
|
25
42
|
return {
|
|
26
43
|
x: this.parentNode.size().width,
|
|
27
|
-
y: this.
|
|
44
|
+
y: this.hostPosition().y + this.hostSize().height / 2,
|
|
28
45
|
};
|
|
29
46
|
case 'top':
|
|
30
47
|
return {
|
|
31
|
-
x: this.
|
|
48
|
+
x: this.hostPosition().x + this.hostSize().width / 2,
|
|
32
49
|
y: 0,
|
|
33
50
|
};
|
|
34
51
|
case 'bottom':
|
|
35
52
|
return {
|
|
36
|
-
x: this.
|
|
53
|
+
x: this.hostPosition().x + this.hostSize().width / 2,
|
|
37
54
|
y: this.parentNode.size().height,
|
|
38
55
|
};
|
|
39
56
|
}
|
|
@@ -50,47 +67,30 @@ export class HandleModel {
|
|
|
50
67
|
return { x: 0, y: this.size().height / 2 };
|
|
51
68
|
}
|
|
52
69
|
});
|
|
53
|
-
this.
|
|
54
|
-
return {
|
|
55
|
-
x: this.parentNode.globalPoint().x + this.offset().x + this.sizeOffset().x,
|
|
56
|
-
y: this.parentNode.globalPoint().y + this.offset().y + this.sizeOffset().y,
|
|
57
|
-
};
|
|
58
|
-
});
|
|
59
|
-
this.state = signal('idle');
|
|
60
|
-
this.updateParentSizeAndPosition$ = new Subject();
|
|
61
|
-
this.parentSize = toSignal(this.updateParentSizeAndPosition$.pipe(map(() => this.getParentSize())), {
|
|
62
|
-
initialValue: { width: 0, height: 0 },
|
|
63
|
-
});
|
|
64
|
-
this.parentPosition = toSignal(this.updateParentSizeAndPosition$.pipe(map(() => ({
|
|
65
|
-
x: this.parentReference instanceof HTMLElement ? this.parentReference.offsetLeft : 0, // for now just 0 for group nodes
|
|
66
|
-
y: this.parentReference instanceof HTMLElement ? this.parentReference.offsetTop : 0, // for now just 0 for group nodes
|
|
67
|
-
}))), {
|
|
68
|
-
initialValue: { x: 0, y: 0 },
|
|
69
|
-
});
|
|
70
|
-
this.parentReference = this.rawHandle.parentReference;
|
|
70
|
+
this.hostReference = this.rawHandle.hostReference;
|
|
71
71
|
this.template = this.rawHandle.template;
|
|
72
72
|
this.templateContext = {
|
|
73
73
|
$implicit: {
|
|
74
|
-
point: this.
|
|
74
|
+
point: this.hostOffset,
|
|
75
75
|
state: this.state,
|
|
76
76
|
node: this.parentNode.node,
|
|
77
77
|
},
|
|
78
78
|
};
|
|
79
79
|
}
|
|
80
|
-
|
|
81
|
-
this.
|
|
80
|
+
updateHost() {
|
|
81
|
+
this.updateHostSizeAndPosition$.next();
|
|
82
82
|
}
|
|
83
|
-
|
|
84
|
-
if (this.
|
|
83
|
+
getHostSize() {
|
|
84
|
+
if (this.hostReference instanceof HTMLElement) {
|
|
85
85
|
return {
|
|
86
|
-
width: this.
|
|
87
|
-
height: this.
|
|
86
|
+
width: this.hostReference.offsetWidth,
|
|
87
|
+
height: this.hostReference.offsetHeight,
|
|
88
88
|
};
|
|
89
89
|
}
|
|
90
|
-
else if (this.
|
|
91
|
-
return this.
|
|
90
|
+
else if (this.hostReference instanceof SVGGraphicsElement) {
|
|
91
|
+
return this.hostReference.getBBox();
|
|
92
92
|
}
|
|
93
93
|
return { width: 0, height: 0 };
|
|
94
94
|
}
|
|
95
95
|
}
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handle.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/handle.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, signal } from '@angular/core';\nimport { NodeHandle } from '../services/handle.service';\nimport { NodeModel } from './node.model';\nimport { Subject, map } from 'rxjs';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\nexport type HandleState = 'valid' | 'invalid' | 'idle';\n\nexport class HandleModel {\n  public readonly strokeWidth = 2;\n\n  /**\n   * Pre-computed size for default handle, changed dynamically\n   * for custom handles\n   */\n  public size = signal({\n    width: 10 + 2 * this.strokeWidth,\n    height: 10 + 2 * this.strokeWidth,\n  });\n\n  public pointAbsolute = computed(() => {\n    return {\n      x: this.parentNode.globalPoint().x + this.hostOffset().x + this.sizeOffset().x,\n      y: this.parentNode.globalPoint().y + this.hostOffset().y + this.sizeOffset().y,\n    };\n  });\n\n  public state = signal<HandleState>('idle');\n\n  private updateHostSizeAndPosition$ = new Subject<void>();\n\n  private hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {\n    initialValue: { width: 0, height: 0 },\n  });\n\n  private hostPosition = toSignal(\n    this.updateHostSizeAndPosition$.pipe(\n      map(() => ({\n        x: this.hostReference instanceof HTMLElement ? this.hostReference.offsetLeft : 0, // for now just 0 for group nodes\n        y: this.hostReference instanceof HTMLElement ? this.hostReference.offsetTop : 0, // for now just 0 for group nodes\n      })),\n    ),\n    {\n      initialValue: { x: 0, y: 0 },\n    },\n  );\n\n  public hostOffset = computed(() => {\n    switch (this.rawHandle.position) {\n      case 'left':\n        return {\n          x: 0,\n          y: this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'right':\n        return {\n          x: this.parentNode.size().width,\n          y: this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'top':\n        return {\n          x: this.hostPosition().x + this.hostSize().width / 2,\n          y: 0,\n        };\n      case 'bottom':\n        return {\n          x: this.hostPosition().x + this.hostSize().width / 2,\n          y: this.parentNode.size().height,\n        };\n    }\n  });\n\n  private sizeOffset = computed(() => {\n    switch (this.rawHandle.position) {\n      case 'left':\n        return { x: -(this.size().width / 2), y: 0 };\n      case 'right':\n        return { x: this.size().width / 2, y: 0 };\n      case 'top':\n        return { x: 0, y: -(this.size().height / 2) };\n      case 'bottom':\n        return { x: 0, y: this.size().height / 2 };\n    }\n  });\n\n  public hostReference = this.rawHandle.hostReference!;\n\n  public template = this.rawHandle.template;\n\n  public templateContext = {\n    $implicit: {\n      point: this.hostOffset,\n      state: this.state,\n      node: this.parentNode.node,\n    },\n  };\n\n  constructor(\n    public rawHandle: NodeHandle,\n    public parentNode: NodeModel,\n  ) {}\n\n  public updateHost() {\n    this.updateHostSizeAndPosition$.next();\n  }\n\n  private getHostSize(): { width: number; height: number } {\n    if (this.hostReference instanceof HTMLElement) {\n      return {\n        width: this.hostReference.offsetWidth,\n        height: this.hostReference.offsetHeight,\n      };\n    } else if (this.hostReference instanceof SVGGraphicsElement) {\n      return this.hostReference.getBBox();\n    }\n\n    return { width: 0, height: 0 };\n  }\n}\n"]}
|
|
@@ -1,30 +1,31 @@
|
|
|
1
|
-
import { computed,
|
|
1
|
+
import { computed, inject, signal } from '@angular/core';
|
|
2
2
|
import { isComponentDynamicNode, isComponentStaticNode, isDynamicNode, } from '../interfaces/node.interface';
|
|
3
3
|
import { isDefined } from '../utils/is-defined';
|
|
4
|
-
import { toObservable
|
|
5
|
-
import { FlowSettingsService } from '../services/flow-settings.service';
|
|
6
|
-
import { animationFrameScheduler, merge, observeOn, Subject } from 'rxjs';
|
|
4
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
7
5
|
import { FlowEntitiesService } from '../services/flow-entities.service';
|
|
8
|
-
// TODO bad naming around points
|
|
9
6
|
export class NodeModel {
|
|
10
7
|
static { this.defaultWidth = 100; }
|
|
11
8
|
static { this.defaultHeight = 50; }
|
|
12
9
|
static { this.defaultColor = '#1b262c'; }
|
|
13
10
|
constructor(node) {
|
|
14
11
|
this.node = node;
|
|
15
|
-
this.flowSettingsService = inject(FlowSettingsService);
|
|
16
12
|
this.entitiesService = inject(FlowEntitiesService);
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
13
|
+
this.point = this.createInternalPointSignal();
|
|
14
|
+
this.point$ = toObservable(this.point);
|
|
15
|
+
this.width = this.createWidthSignal(NodeModel.defaultWidth);
|
|
16
|
+
this.width$ = toObservable(this.width);
|
|
17
|
+
this.height = this.createHeightSignal(NodeModel.defaultHeight);
|
|
18
|
+
this.height$ = toObservable(this.height);
|
|
19
|
+
/**
|
|
20
|
+
* @deprecated use width or height signals
|
|
21
|
+
*/
|
|
22
|
+
this.size = computed(() => ({ width: this.width(), height: this.height() }));
|
|
23
|
+
/**
|
|
24
|
+
* @deprecated use width$ or height$
|
|
25
|
+
*/
|
|
25
26
|
this.size$ = toObservable(this.size);
|
|
26
|
-
this.
|
|
27
|
-
this.
|
|
27
|
+
this.styleWidth = computed(() => `${this.width()}px`);
|
|
28
|
+
this.styleHeight = computed(() => `${this.height()}px`);
|
|
28
29
|
this.renderOrder = signal(0);
|
|
29
30
|
this.selected = signal(false);
|
|
30
31
|
this.selected$ = toObservable(this.selected);
|
|
@@ -94,56 +95,8 @@ export class NodeModel {
|
|
|
94
95
|
}
|
|
95
96
|
}
|
|
96
97
|
}
|
|
97
|
-
setPoint(point
|
|
98
|
-
|
|
99
|
-
this.internalPoint.set(point);
|
|
100
|
-
}
|
|
101
|
-
else {
|
|
102
|
-
this.notThrottledPoint$.next(point);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* TODO find the way to implement this better
|
|
107
|
-
*/
|
|
108
|
-
linkDefaultNodeSizeWithModelSize() {
|
|
109
|
-
const node = this.node;
|
|
110
|
-
switch (node.type) {
|
|
111
|
-
case 'default':
|
|
112
|
-
case 'default-group':
|
|
113
|
-
case 'template-group': {
|
|
114
|
-
if (isDynamicNode(node)) {
|
|
115
|
-
effect(() => {
|
|
116
|
-
this.size.set({
|
|
117
|
-
width: node.width?.() ?? NodeModel.defaultWidth,
|
|
118
|
-
height: node.height?.() ?? NodeModel.defaultHeight,
|
|
119
|
-
});
|
|
120
|
-
}, { allowSignalWrites: true });
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
this.size.set({
|
|
124
|
-
width: node.width ?? NodeModel.defaultWidth,
|
|
125
|
-
height: node.height ?? NodeModel.defaultHeight,
|
|
126
|
-
});
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
if (node.type === 'html-template' || this.isComponentType) {
|
|
131
|
-
if (isDynamicNode(node)) {
|
|
132
|
-
effect(() => {
|
|
133
|
-
if (node.width && node.height) {
|
|
134
|
-
this.size.set({
|
|
135
|
-
width: node.width(),
|
|
136
|
-
height: node.height(),
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
}, { allowSignalWrites: true });
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
if (node.width && node.height) {
|
|
143
|
-
this.size.set({ width: node.width, height: node.height });
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
98
|
+
setPoint(point) {
|
|
99
|
+
this.point.set(point);
|
|
147
100
|
}
|
|
148
101
|
createTextSignal() {
|
|
149
102
|
const node = this.node;
|
|
@@ -160,5 +113,15 @@ export class NodeModel {
|
|
|
160
113
|
createInternalPointSignal() {
|
|
161
114
|
return isDynamicNode(this.node) ? this.node.point : signal({ x: this.node.point.x, y: this.node.point.y });
|
|
162
115
|
}
|
|
116
|
+
createWidthSignal(defaultValue) {
|
|
117
|
+
return isDynamicNode(this.node)
|
|
118
|
+
? (this.node.width ?? signal(defaultValue))
|
|
119
|
+
: signal(this.node.width ?? defaultValue);
|
|
120
|
+
}
|
|
121
|
+
createHeightSignal(defaultValue) {
|
|
122
|
+
return isDynamicNode(this.node)
|
|
123
|
+
? (this.node.height ?? signal(defaultValue))
|
|
124
|
+
: signal(this.node.height ?? defaultValue);
|
|
125
|
+
}
|
|
163
126
|
}
|
|
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"]}
|
|
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 { Signal, TemplateRef, computed, 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 } 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';\n\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 entitiesService = inject(FlowEntitiesService);\n\n  public point = this.createInternalPointSignal();\n  public point$ = toObservable(this.point);\n\n  public width = this.createWidthSignal(NodeModel.defaultWidth);\n  public width$ = toObservable(this.width);\n\n  public height = this.createHeightSignal(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 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 = 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) {\n    this.point.set(point);\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  private createWidthSignal(defaultValue: number) {\n    return isDynamicNode(this.node)\n      ? (this.node.width ?? signal(defaultValue))\n      : signal(this.node.width ?? defaultValue);\n  }\n\n  private createHeightSignal(defaultValue: number) {\n    return isDynamicNode(this.node)\n      ? (this.node.height ?? signal(defaultValue))\n      : signal(this.node.height ?? defaultValue);\n  }\n}\n"]}
|
|
@@ -31,11 +31,11 @@ export class HandleComponent {
|
|
|
31
31
|
position: this.position(),
|
|
32
32
|
type: this.type(),
|
|
33
33
|
id: this.id(),
|
|
34
|
-
|
|
34
|
+
hostReference: this.element.parentElement,
|
|
35
35
|
template: this.template(),
|
|
36
36
|
}, node);
|
|
37
37
|
this.handleService.createHandle(this.model);
|
|
38
|
-
requestAnimationFrame(() => this.model.
|
|
38
|
+
requestAnimationFrame(() => this.model.updateHost());
|
|
39
39
|
this.destroyRef.onDestroy(() => this.handleService.destroyHandle(this.model));
|
|
40
40
|
}
|
|
41
41
|
}
|
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsVUFBVSxFQUNWLFFBQVEsRUFHUixNQUFNLEVBQ04sS0FBSyxHQUNOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFnQixNQUFNLHFEQUFxRCxDQUFDOztBQVFyRyxNQUFNLE9BQU8sZUFBZTtJQU41QjtRQU9TLGFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDM0Isa0JBQWEsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDdEMsWUFBTyxHQUFHLE1BQU0sQ0FBMEIsVUFBVSxDQUFDLENBQUMsYUFBYSxDQUFDO1FBQ3BFLGVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFeEM7O1dBRUc7UUFDSSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBWSxDQUFDO1FBRTdDOztXQUVHO1FBQ0ksU0FBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXVCLENBQUM7UUFFcEQ7O1dBRUc7UUFDSSxPQUFFLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFckIsYUFBUSxHQUFHLEtBQUssRUFBb0IsQ0FBQztLQTJCN0M7SUF0QlEsUUFBUTtRQUNiLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFdkMsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxXQUFXLENBQzFCO2dCQUNFLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN6QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRTtnQkFDakIsRUFBRSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUU7Z0JBQ2IsYUFBYSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYztnQkFDMUMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7YUFDMUIsRUFDRCxJQUFJLENBQ0wsQ0FBQztZQUVGLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUU1QyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7WUFFckQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDaEYsQ0FBQztJQUNILENBQUM7K0dBL0NVLGVBQWU7bUdBQWYsZUFBZSxrakJDdEI1QixFQUFBOztBRGdEUztJQUROLGdCQUFnQjsrQ0FzQmhCOzRGQS9DVSxlQUFlO2tCQU4zQixTQUFTO2lDQUNJLElBQUksWUFDTixRQUFRLG1CQUVELHVCQUF1QixDQUFDLE1BQU07OEJBNEJ4QyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRGVzdHJveVJlZixcbiAgRWxlbWVudFJlZixcbiAgSW5qZWN0b3IsXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIGluamVjdCxcbiAgaW5wdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi8uLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IEhhbmRsZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9oYW5kbGUuc2VydmljZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuaW1wb3J0IHsgSW5qZWN0aW9uQ29udGV4dCwgV2l0aEluamVjdG9yIH0gZnJvbSAnLi4vLi4vZGVjb3JhdG9ycy9ydW4taW4taW5qZWN0aW9uLWNvbnRleHQuZGVjb3JhdG9yJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnaGFuZGxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2hhbmRsZS5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBIYW5kbGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIFdpdGhJbmplY3RvciB7XG4gIHB1YmxpYyBpbmplY3RvciA9IGluamVjdChJbmplY3Rvcik7XG4gIHByaXZhdGUgaGFuZGxlU2VydmljZSA9IGluamVjdChIYW5kbGVTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBlbGVtZW50ID0gaW5qZWN0PEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+PihFbGVtZW50UmVmKS5uYXRpdmVFbGVtZW50O1xuICBwcml2YXRlIGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgLyoqXG4gICAqIEF0IHdoYXQgc2lkZSBvZiBub2RlIHRoaXMgY29tcG9uZW50IHNob3VsZCBiZSBwbGFjZWRcbiAgICovXG4gIHB1YmxpYyBwb3NpdGlvbiA9IGlucHV0LnJlcXVpcmVkPFBvc2l0aW9uPigpO1xuXG4gIC8qKlxuICAgKiBTb3VyY2Ugb3IgdGFyZ2V0XG4gICAqL1xuICBwdWJsaWMgdHlwZSA9IGlucHV0LnJlcXVpcmVkPCdzb3VyY2UnIHwgJ3RhcmdldCc+KCk7XG5cbiAgLyoqXG4gICAqIFNob3VsZCBiZSB1c2VkIGlmIG5vZGUgaGFzIG1vcmUgdGhhbiBvbmUgc291cmNlL3RhcmdldFxuICAgKi9cbiAgcHVibGljIGlkID0gaW5wdXQ8c3RyaW5nPigpO1xuXG4gIHB1YmxpYyB0ZW1wbGF0ZSA9IGlucHV0PFRlbXBsYXRlUmVmPGFueT4+KCk7XG5cbiAgcHVibGljIG1vZGVsITogSGFuZGxlTW9kZWw7XG5cbiAgQEluamVjdGlvbkNvbnRleHRcbiAgcHVibGljIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IG5vZGUgPSB0aGlzLmhhbmRsZVNlcnZpY2Uubm9kZSgpO1xuXG4gICAgaWYgKG5vZGUpIHtcbiAgICAgIHRoaXMubW9kZWwgPSBuZXcgSGFuZGxlTW9kZWwoXG4gICAgICAgIHtcbiAgICAgICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbigpLFxuICAgICAgICAgIHR5cGU6IHRoaXMudHlwZSgpLFxuICAgICAgICAgIGlkOiB0aGlzLmlkKCksXG4gICAgICAgICAgaG9zdFJlZmVyZW5jZTogdGhpcy5lbGVtZW50LnBhcmVudEVsZW1lbnQhLFxuICAgICAgICAgIHRlbXBsYXRlOiB0aGlzLnRlbXBsYXRlKCksXG4gICAgICAgIH0sXG4gICAgICAgIG5vZGUsXG4gICAgICApO1xuXG4gICAgICB0aGlzLmhhbmRsZVNlcnZpY2UuY3JlYXRlSGFuZGxlKHRoaXMubW9kZWwpO1xuXG4gICAgICByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4gdGhpcy5tb2RlbC51cGRhdGVIb3N0KCkpO1xuXG4gICAgICB0aGlzLmRlc3Ryb3lSZWYub25EZXN0cm95KCgpID0+IHRoaXMuaGFuZGxlU2VydmljZS5kZXN0cm95SGFuZGxlKHRoaXMubW9kZWwpKTtcbiAgICB9XG4gIH1cbn1cbiIsIiJdfQ==
|
|
@@ -67,8 +67,9 @@ export class ResizableComponent {
|
|
|
67
67
|
return;
|
|
68
68
|
const offset = calcOffset(event.movementX, event.movementY, this.zoom());
|
|
69
69
|
const { x, y, width, height } = constrainRect(applyResize(this.resizeSide, this.model, offset), this.model, this.resizeSide, this.minWidth, this.minHeight);
|
|
70
|
-
this.model.setPoint({ x, y }
|
|
71
|
-
this.model.
|
|
70
|
+
this.model.setPoint({ x, y });
|
|
71
|
+
this.model.width.set(width);
|
|
72
|
+
this.model.height.set(height);
|
|
72
73
|
}
|
|
73
74
|
endResize() {
|
|
74
75
|
this.resizeSide = null;
|
|
@@ -215,4 +216,4 @@ function constrainRect(rect, model, side, minWidth, minHeight) {
|
|
|
215
216
|
height,
|
|
216
217
|
};
|
|
217
218
|
}
|
|
218
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/resizable/resizable.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/resizable/resizable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  computed,\n  ElementRef,\n  inject,\n  OnInit,\n  TemplateRef,\n  input,\n  viewChild,\n  effect,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { RootPointerDirective } from '../../directives/root-pointer.directive';\nimport { filter, tap } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ViewportService } from '../../services/viewport.service';\nimport { round } from '../../utils/round';\nimport { Microtask } from '../../decorators/microtask.decorator';\nimport { getNodesBounds } from '../../utils/nodes';\nimport { NodeAccessorService } from '../../services/node-accessor.service';\nimport { NodeModel } from '../../models/node.model';\nimport { Rect } from '../../interfaces/rect';\nimport { PointerEvent } from '../../directives/root-pointer.directive';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { PointerDirective } from '../../directives/pointer.directive';\n\ntype Side = 'top' | 'right' | 'bottom' | 'left' | 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';\n\n@Component({\n  standalone: true,\n  selector: '[resizable]',\n  templateUrl: './resizable.component.html',\n  styleUrls: ['./resizable.component.scss'],\n  imports: [PointerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ResizableComponent implements OnInit, AfterViewInit {\n  private nodeAccessor = inject(NodeAccessorService);\n  private rootPointer = inject(RootPointerDirective);\n  private viewportService = inject(ViewportService);\n  private spacePointContext = inject(SpacePointContextDirective);\n  private hostRef = inject<ElementRef<Element>>(ElementRef);\n\n  public resizable = input<boolean | ''>();\n\n  public resizerColor = input('#2e414c');\n\n  public gap = input(1.5);\n\n  private resizer = viewChild.required<TemplateRef<unknown>>('resizer');\n\n  protected get model() {\n    return this.nodeAccessor.model()!;\n  }\n\n  protected lineGap = 3;\n  protected handleSize = 6;\n\n  private resizeSide: Side | null = null;\n\n  private zoom = computed(() => this.viewportService.readableViewport().zoom ?? 0);\n\n  private minWidth = 0;\n  private minHeight = 0;\n\n  // TODO: allow reszie beside the flow\n  protected resizeOnGlobalMouseMove = this.rootPointer.pointerMovement$\n    .pipe(\n      filter(() => this.resizeSide !== null),\n      filter((event) => event.movementX !== 0 || event.movementY !== 0),\n      tap((event) => this.resize(event)),\n      takeUntilDestroyed(),\n    )\n    .subscribe();\n\n  protected endResizeOnGlobalMouseUp = this.rootPointer.documentPointerEnd$\n    .pipe(\n      tap(() => this.endResize()),\n      takeUntilDestroyed(),\n    )\n    .subscribe();\n\n  constructor() {\n    effect(\n      () => {\n        const resizable = this.resizable();\n\n        if (typeof resizable === 'boolean') {\n          this.model.resizable.set(resizable);\n        } else {\n          this.model.resizable.set(true);\n        }\n      },\n      { allowSignalWrites: true },\n    );\n  }\n\n  public ngOnInit(): void {\n    this.model.resizerTemplate.set(this.resizer());\n  }\n\n  @Microtask\n  public ngAfterViewInit() {\n    this.minWidth = +getComputedStyle(this.hostRef.nativeElement).minWidth.replace('px', '') || 0;\n    this.minHeight = +getComputedStyle(this.hostRef.nativeElement).minHeight.replace('px', '') || 0;\n  }\n\n  protected startResize(side: Side, event: Event) {\n    event.stopPropagation();\n    this.resizeSide = side;\n    this.model.resizing.set(true);\n  }\n\n  protected resize(event: PointerEvent) {\n    if (!this.resizeSide) return;\n    if (this.isResizeConstrained(event)) return;\n\n    const offset = calcOffset(event.movementX, event.movementY, this.zoom());\n    const { x, y, width, height } = constrainRect(\n      applyResize(this.resizeSide, this.model, offset),\n      this.model,\n      this.resizeSide,\n      this.minWidth,\n      this.minHeight,\n    );\n\n    this.model.setPoint({ x, y }, false);\n    this.model.size.set({ width, height });\n  }\n\n  protected endResize() {\n    this.resizeSide = null;\n    this.model.resizing.set(false);\n  }\n\n  private isResizeConstrained({ x, y, movementX, movementY }: PointerEvent): boolean {\n    const flowPoint = this.spacePointContext.documentPointToFlowPoint({ x, y });\n\n    if (this.resizeSide?.includes('right')) {\n      if (movementX > 0 && flowPoint.x < this.model.point().x + this.model.size().width) {\n        return true;\n      }\n\n      if (movementX < 0 && flowPoint.x > this.model.point().x + this.model.size().width) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('left')) {\n      if (movementX < 0 && flowPoint.x > this.model.point().x) {\n        return true;\n      }\n\n      if (movementX > 0 && flowPoint.x < this.model.point().x) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('bottom')) {\n      if (movementY > 0 && flowPoint.y < this.model.point().y + this.model.size().height) {\n        return true;\n      }\n\n      if (movementY < 0 && flowPoint.y > this.model.point().y + this.model.size().height) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('top')) {\n      if (movementY < 0 && flowPoint.y > this.model.point().y) {\n        return true;\n      }\n\n      if (movementY > 0 && flowPoint.y < this.model.point().y) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n}\n\nfunction calcOffset(movementX: number, movementY: number, zoom: number) {\n  return {\n    offsetX: round(movementX / zoom),\n    offsetY: round(movementY / zoom),\n  };\n}\n\nfunction applyResize(side: Side, model: NodeModel, offset: { offsetX: number; offsetY: number }): Rect {\n  const { offsetX, offsetY } = offset;\n  const { x, y } = model.point();\n  const { width, height } = model.size();\n\n  // Handle each case of resizing (top, bottom, left, right, corners)\n  switch (side) {\n    case 'left':\n      return { x: x + offsetX, y, width: width - offsetX, height };\n    case 'right':\n      return { x, y, width: width + offsetX, height };\n    case 'top':\n      return { x, y: y + offsetY, width, height: height - offsetY };\n    case 'bottom':\n      return { x, y, width, height: height + offsetY };\n    case 'top-left':\n      return {\n        x: x + offsetX,\n        y: y + offsetY,\n        width: width - offsetX,\n        height: height - offsetY,\n      };\n    case 'top-right':\n      return {\n        x,\n        y: y + offsetY,\n        width: width + offsetX,\n        height: height - offsetY,\n      };\n    case 'bottom-left':\n      return {\n        x: x + offsetX,\n        y,\n        width: width - offsetX,\n        height: height + offsetY,\n      };\n    case 'bottom-right':\n      return { x, y, width: width + offsetX, height: height + offsetY };\n  }\n}\n\nfunction constrainRect(rect: Rect, model: NodeModel, side: Side, minWidth: number, minHeight: number) {\n  let { x, y, width, height } = rect;\n\n  // 1. Prevent negative dimensions\n  width = Math.max(width, 0);\n  height = Math.max(height, 0);\n\n  // 2. Apply minimum size constraints\n  width = Math.max(minWidth, width);\n  height = Math.max(minHeight, height);\n\n  // Apply left/top constraints based on minimum size\n  x = Math.min(x, model.point().x + model.size().width - minWidth);\n  y = Math.min(y, model.point().y + model.size().height - minHeight);\n\n  const parent = model.parent();\n  // 3. Apply maximum size constraints based on parent size (if exists)\n  if (parent) {\n    x = Math.max(x, 0); // Left boundary of the parent\n    y = Math.max(y, 0); // Top boundary of the parent\n\n    if (x === 0) {\n      width = model.point().x + model.size().width;\n    }\n\n    if (y === 0) {\n      height = model.point().y + model.size().height;\n    }\n\n    width = Math.min(width, parent.size().width - model.point().x);\n    height = Math.min(height, parent.size().height - model.point().y);\n  }\n\n  const bounds = getNodesBounds(model.children());\n  // 4. Apply child node constraints (if children exist)\n  if (bounds) {\n    if (side.includes('left')) {\n      x = Math.min(x, model.point().x + model.size().width - (bounds.x + bounds.width));\n      width = Math.max(width, bounds.x + bounds.width);\n    }\n\n    if (side.includes('right')) {\n      width = Math.max(width, bounds.x + bounds.width);\n    }\n\n    if (side.includes('bottom')) {\n      height = Math.max(height, bounds.y + bounds.height);\n    }\n\n    if (side.includes('top')) {\n      y = Math.min(y, model.point().y + model.size().height - (bounds.y + bounds.height));\n      height = Math.max(height, bounds.y + bounds.height);\n    }\n  }\n\n  return {\n    x,\n    y,\n    width,\n    height,\n  };\n}\n","<ng-template #resizer>\n  <svg:g>\n    <!-- top line -->\n    <svg:line\n      class=\"top\"\n      stroke-width=\"2\"\n      [attr.x1]=\"lineGap\"\n      [attr.y1]=\"-gap()\"\n      [attr.x2]=\"model.size().width - lineGap\"\n      [attr.y2]=\"-gap()\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top', $event)\" />\n    <!-- Left line -->\n    <svg:line\n      class=\"left\"\n      stroke-width=\"2\"\n      [attr.x1]=\"-gap()\"\n      [attr.y1]=\"lineGap\"\n      [attr.x2]=\"-gap()\"\n      [attr.y2]=\"model.size().height - lineGap\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('left', $event)\" />\n    <!-- Bottom line -->\n    <svg:line\n      class=\"bottom\"\n      stroke-width=\"2\"\n      [attr.x1]=\"lineGap\"\n      [attr.y1]=\"model.size().height + gap()\"\n      [attr.x2]=\"model.size().width - lineGap\"\n      [attr.y2]=\"model.size().height + gap()\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom', $event)\" />\n    <!-- Right line -->\n    <svg:line\n      class=\"right\"\n      stroke-width=\"2\"\n      [attr.x1]=\"model.size().width + gap()\"\n      [attr.y1]=\"lineGap\"\n      [attr.x2]=\"model.size().width + gap()\"\n      [attr.y2]=\"model.size().height - lineGap\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('right', $event)\" />\n\n    <!-- Top Left -->\n    <svg:rect\n      class=\"top-left\"\n      [attr.x]=\"-(handleSize / 2) - gap()\"\n      [attr.y]=\"-(handleSize / 2) - gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top-left', $event)\" />\n\n    <!-- Top right -->\n    <svg:rect\n      class=\"top-right\"\n      [attr.x]=\"model.size().width - handleSize / 2 + gap()\"\n      [attr.y]=\"-(handleSize / 2) - gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top-right', $event)\" />\n\n    <!-- Bottom left -->\n    <svg:rect\n      class=\"bottom-left\"\n      [attr.x]=\"-(handleSize / 2) - gap()\"\n      [attr.y]=\"model.size().height - handleSize / 2 + gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom-left', $event)\" />\n\n    <!-- Bottom right -->\n    <svg:rect\n      class=\"bottom-right\"\n      [attr.x]=\"model.size().width - handleSize / 2 + gap()\"\n      [attr.y]=\"model.size().height - handleSize / 2 + gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom-right', $event)\" />\n  </svg:g>\n</ng-template>\n\n<ng-content />\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/resizable/resizable.component.ts","../../../../../../../projects/ngx-vflow-lib/src/lib/vflow/public-components/resizable/resizable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  computed,\n  ElementRef,\n  inject,\n  OnInit,\n  TemplateRef,\n  input,\n  viewChild,\n  effect,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { RootPointerDirective } from '../../directives/root-pointer.directive';\nimport { filter, tap } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ViewportService } from '../../services/viewport.service';\nimport { round } from '../../utils/round';\nimport { Microtask } from '../../decorators/microtask.decorator';\nimport { getNodesBounds } from '../../utils/nodes';\nimport { NodeAccessorService } from '../../services/node-accessor.service';\nimport { NodeModel } from '../../models/node.model';\nimport { Rect } from '../../interfaces/rect';\nimport { PointerEvent } from '../../directives/root-pointer.directive';\nimport { SpacePointContextDirective } from '../../directives/space-point-context.directive';\nimport { PointerDirective } from '../../directives/pointer.directive';\n\ntype Side = 'top' | 'right' | 'bottom' | 'left' | 'top-right' | 'top-left' | 'bottom-right' | 'bottom-left';\n\n@Component({\n  standalone: true,\n  selector: '[resizable]',\n  templateUrl: './resizable.component.html',\n  styleUrls: ['./resizable.component.scss'],\n  imports: [PointerDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ResizableComponent implements OnInit, AfterViewInit {\n  private nodeAccessor = inject(NodeAccessorService);\n  private rootPointer = inject(RootPointerDirective);\n  private viewportService = inject(ViewportService);\n  private spacePointContext = inject(SpacePointContextDirective);\n  private hostRef = inject<ElementRef<Element>>(ElementRef);\n\n  public resizable = input<boolean | ''>();\n\n  public resizerColor = input('#2e414c');\n\n  public gap = input(1.5);\n\n  private resizer = viewChild.required<TemplateRef<unknown>>('resizer');\n\n  protected get model() {\n    return this.nodeAccessor.model()!;\n  }\n\n  protected lineGap = 3;\n  protected handleSize = 6;\n\n  private resizeSide: Side | null = null;\n\n  private zoom = computed(() => this.viewportService.readableViewport().zoom ?? 0);\n\n  private minWidth = 0;\n  private minHeight = 0;\n\n  // TODO: allow reszie beside the flow\n  protected resizeOnGlobalMouseMove = this.rootPointer.pointerMovement$\n    .pipe(\n      filter(() => this.resizeSide !== null),\n      filter((event) => event.movementX !== 0 || event.movementY !== 0),\n      tap((event) => this.resize(event)),\n      takeUntilDestroyed(),\n    )\n    .subscribe();\n\n  protected endResizeOnGlobalMouseUp = this.rootPointer.documentPointerEnd$\n    .pipe(\n      tap(() => this.endResize()),\n      takeUntilDestroyed(),\n    )\n    .subscribe();\n\n  constructor() {\n    effect(\n      () => {\n        const resizable = this.resizable();\n\n        if (typeof resizable === 'boolean') {\n          this.model.resizable.set(resizable);\n        } else {\n          this.model.resizable.set(true);\n        }\n      },\n      { allowSignalWrites: true },\n    );\n  }\n\n  public ngOnInit(): void {\n    this.model.resizerTemplate.set(this.resizer());\n  }\n\n  @Microtask\n  public ngAfterViewInit() {\n    this.minWidth = +getComputedStyle(this.hostRef.nativeElement).minWidth.replace('px', '') || 0;\n    this.minHeight = +getComputedStyle(this.hostRef.nativeElement).minHeight.replace('px', '') || 0;\n  }\n\n  protected startResize(side: Side, event: Event) {\n    event.stopPropagation();\n    this.resizeSide = side;\n    this.model.resizing.set(true);\n  }\n\n  protected resize(event: PointerEvent) {\n    if (!this.resizeSide) return;\n    if (this.isResizeConstrained(event)) return;\n\n    const offset = calcOffset(event.movementX, event.movementY, this.zoom());\n    const { x, y, width, height } = constrainRect(\n      applyResize(this.resizeSide, this.model, offset),\n      this.model,\n      this.resizeSide,\n      this.minWidth,\n      this.minHeight,\n    );\n\n    this.model.setPoint({ x, y });\n    this.model.width.set(width);\n    this.model.height.set(height);\n  }\n\n  protected endResize() {\n    this.resizeSide = null;\n    this.model.resizing.set(false);\n  }\n\n  private isResizeConstrained({ x, y, movementX, movementY }: PointerEvent): boolean {\n    const flowPoint = this.spacePointContext.documentPointToFlowPoint({ x, y });\n\n    if (this.resizeSide?.includes('right')) {\n      if (movementX > 0 && flowPoint.x < this.model.point().x + this.model.size().width) {\n        return true;\n      }\n\n      if (movementX < 0 && flowPoint.x > this.model.point().x + this.model.size().width) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('left')) {\n      if (movementX < 0 && flowPoint.x > this.model.point().x) {\n        return true;\n      }\n\n      if (movementX > 0 && flowPoint.x < this.model.point().x) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('bottom')) {\n      if (movementY > 0 && flowPoint.y < this.model.point().y + this.model.size().height) {\n        return true;\n      }\n\n      if (movementY < 0 && flowPoint.y > this.model.point().y + this.model.size().height) {\n        return true;\n      }\n    }\n\n    if (this.resizeSide?.includes('top')) {\n      if (movementY < 0 && flowPoint.y > this.model.point().y) {\n        return true;\n      }\n\n      if (movementY > 0 && flowPoint.y < this.model.point().y) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n}\n\nfunction calcOffset(movementX: number, movementY: number, zoom: number) {\n  return {\n    offsetX: round(movementX / zoom),\n    offsetY: round(movementY / zoom),\n  };\n}\n\nfunction applyResize(side: Side, model: NodeModel, offset: { offsetX: number; offsetY: number }): Rect {\n  const { offsetX, offsetY } = offset;\n  const { x, y } = model.point();\n  const { width, height } = model.size();\n\n  // Handle each case of resizing (top, bottom, left, right, corners)\n  switch (side) {\n    case 'left':\n      return { x: x + offsetX, y, width: width - offsetX, height };\n    case 'right':\n      return { x, y, width: width + offsetX, height };\n    case 'top':\n      return { x, y: y + offsetY, width, height: height - offsetY };\n    case 'bottom':\n      return { x, y, width, height: height + offsetY };\n    case 'top-left':\n      return {\n        x: x + offsetX,\n        y: y + offsetY,\n        width: width - offsetX,\n        height: height - offsetY,\n      };\n    case 'top-right':\n      return {\n        x,\n        y: y + offsetY,\n        width: width + offsetX,\n        height: height - offsetY,\n      };\n    case 'bottom-left':\n      return {\n        x: x + offsetX,\n        y,\n        width: width - offsetX,\n        height: height + offsetY,\n      };\n    case 'bottom-right':\n      return { x, y, width: width + offsetX, height: height + offsetY };\n  }\n}\n\nfunction constrainRect(rect: Rect, model: NodeModel, side: Side, minWidth: number, minHeight: number) {\n  let { x, y, width, height } = rect;\n\n  // 1. Prevent negative dimensions\n  width = Math.max(width, 0);\n  height = Math.max(height, 0);\n\n  // 2. Apply minimum size constraints\n  width = Math.max(minWidth, width);\n  height = Math.max(minHeight, height);\n\n  // Apply left/top constraints based on minimum size\n  x = Math.min(x, model.point().x + model.size().width - minWidth);\n  y = Math.min(y, model.point().y + model.size().height - minHeight);\n\n  const parent = model.parent();\n  // 3. Apply maximum size constraints based on parent size (if exists)\n  if (parent) {\n    x = Math.max(x, 0); // Left boundary of the parent\n    y = Math.max(y, 0); // Top boundary of the parent\n\n    if (x === 0) {\n      width = model.point().x + model.size().width;\n    }\n\n    if (y === 0) {\n      height = model.point().y + model.size().height;\n    }\n\n    width = Math.min(width, parent.size().width - model.point().x);\n    height = Math.min(height, parent.size().height - model.point().y);\n  }\n\n  const bounds = getNodesBounds(model.children());\n  // 4. Apply child node constraints (if children exist)\n  if (bounds) {\n    if (side.includes('left')) {\n      x = Math.min(x, model.point().x + model.size().width - (bounds.x + bounds.width));\n      width = Math.max(width, bounds.x + bounds.width);\n    }\n\n    if (side.includes('right')) {\n      width = Math.max(width, bounds.x + bounds.width);\n    }\n\n    if (side.includes('bottom')) {\n      height = Math.max(height, bounds.y + bounds.height);\n    }\n\n    if (side.includes('top')) {\n      y = Math.min(y, model.point().y + model.size().height - (bounds.y + bounds.height));\n      height = Math.max(height, bounds.y + bounds.height);\n    }\n  }\n\n  return {\n    x,\n    y,\n    width,\n    height,\n  };\n}\n","<ng-template #resizer>\n  <svg:g>\n    <!-- top line -->\n    <svg:line\n      class=\"top\"\n      stroke-width=\"2\"\n      [attr.x1]=\"lineGap\"\n      [attr.y1]=\"-gap()\"\n      [attr.x2]=\"model.size().width - lineGap\"\n      [attr.y2]=\"-gap()\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top', $event)\" />\n    <!-- Left line -->\n    <svg:line\n      class=\"left\"\n      stroke-width=\"2\"\n      [attr.x1]=\"-gap()\"\n      [attr.y1]=\"lineGap\"\n      [attr.x2]=\"-gap()\"\n      [attr.y2]=\"model.size().height - lineGap\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('left', $event)\" />\n    <!-- Bottom line -->\n    <svg:line\n      class=\"bottom\"\n      stroke-width=\"2\"\n      [attr.x1]=\"lineGap\"\n      [attr.y1]=\"model.size().height + gap()\"\n      [attr.x2]=\"model.size().width - lineGap\"\n      [attr.y2]=\"model.size().height + gap()\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom', $event)\" />\n    <!-- Right line -->\n    <svg:line\n      class=\"right\"\n      stroke-width=\"2\"\n      [attr.x1]=\"model.size().width + gap()\"\n      [attr.y1]=\"lineGap\"\n      [attr.x2]=\"model.size().width + gap()\"\n      [attr.y2]=\"model.size().height - lineGap\"\n      [attr.stroke]=\"resizerColor()\"\n      (pointerStart)=\"startResize('right', $event)\" />\n\n    <!-- Top Left -->\n    <svg:rect\n      class=\"top-left\"\n      [attr.x]=\"-(handleSize / 2) - gap()\"\n      [attr.y]=\"-(handleSize / 2) - gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top-left', $event)\" />\n\n    <!-- Top right -->\n    <svg:rect\n      class=\"top-right\"\n      [attr.x]=\"model.size().width - handleSize / 2 + gap()\"\n      [attr.y]=\"-(handleSize / 2) - gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('top-right', $event)\" />\n\n    <!-- Bottom left -->\n    <svg:rect\n      class=\"bottom-left\"\n      [attr.x]=\"-(handleSize / 2) - gap()\"\n      [attr.y]=\"model.size().height - handleSize / 2 + gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom-left', $event)\" />\n\n    <!-- Bottom right -->\n    <svg:rect\n      class=\"bottom-right\"\n      [attr.x]=\"model.size().width - handleSize / 2 + gap()\"\n      [attr.y]=\"model.size().height - handleSize / 2 + gap()\"\n      [attr.width]=\"handleSize\"\n      [attr.height]=\"handleSize\"\n      [attr.fill]=\"resizerColor()\"\n      (pointerStart)=\"startResize('bottom-right', $event)\" />\n  </svg:g>\n</ng-template>\n\n<ng-content />\n"]}
|
|
@@ -93,6 +93,6 @@ function moveNode(model, point) {
|
|
|
93
93
|
point.y = Math.min(parent.size().height - model.size().height, point.y);
|
|
94
94
|
point.y = Math.max(0, point.y);
|
|
95
95
|
}
|
|
96
|
-
model.setPoint(point
|
|
96
|
+
model.setPoint(point);
|
|
97
97
|
}
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/services/draggable.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { select } from 'd3-selection';\nimport { D3DragEvent, drag } from 'd3-drag';\nimport { NodeModel } from '../models/node.model';\nimport { round } from '../utils/round';\nimport { FlowEntitiesService } from './flow-entities.service';\nimport { Point } from '../interfaces/point.interface';\n\ntype DragEvent = D3DragEvent<Element, unknown, unknown>;\n\n@Injectable()\nexport class DraggableService {\n  private entitiesService = inject(FlowEntitiesService);\n\n  /**\n   * Enable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public enable(element: Element, model: NodeModel) {\n    select(element).call(this.getDragBehavior(model));\n  }\n\n  /**\n   * Disable draggable behavior for element.\n   *\n   * @param element target element for toggling draggable\n   * @param model model with data for this element\n   */\n  public disable(element: Element) {\n    select(element).call(drag().on('drag', null));\n  }\n\n  /**\n   * TODO: not shure if this work, need to check\n   *\n   * @param element\n   */\n  public destroy(element: Element) {\n    select(element).on('.drag', null);\n  }\n\n  /**\n   * Node drag behavior. Updated node's coordinate according to dragging\n   *\n   * @param model\n   * @returns\n   */\n  private getDragBehavior(model: NodeModel) {\n    let dragNodes: NodeModel[] = [];\n    let initialPositions: Point[] = [];\n\n    const filterCondition = (event: Event) => {\n      // if there is at least one drag handle, we should check if we are dragging it\n      if (model.dragHandlesCount()) {\n        return !!(event.target as Element).closest('.vflow-drag-handle');\n      }\n\n      return true;\n    };\n\n    return drag()\n      .filter(filterCondition)\n      .on('start', (event: DragEvent) => {\n        dragNodes = this.getDragNodes(model);\n\n        initialPositions = dragNodes.map((node) => ({\n          x: node.point().x - event.x,\n          y: node.point().y - event.y,\n        }));\n      })\n\n      .on('drag', (event: DragEvent) => {\n        dragNodes.forEach((model, index) => {\n          const point = {\n            x: round(event.x + initialPositions[index].x),\n            y: round(event.y + initialPositions[index].y),\n          };\n\n          moveNode(model, point);\n        });\n      });\n  }\n\n  private getDragNodes(model: NodeModel) {\n    return model.selected()\n      ? this.entitiesService\n          .nodes()\n          // selected draggable nodes (with current node)\n          .filter((node) => node.selected() && node.draggable())\n      : // we only can move current node if it's not selected\n        [model];\n  }\n}\n\nfunction moveNode(model: NodeModel, point: Point) {\n  const parent = model.parent();\n  // keep node in bounds of parent\n  if (parent) {\n    point.x = Math.min(parent.size().width - model.size().width, point.x);\n    point.x = Math.max(0, point.x);\n\n    point.y = Math.min(parent.size().height - model.size().height, point.y);\n    point.y = Math.max(0, point.y);\n  }\n\n  model.setPoint(point);\n}\n"]}
|
|
@@ -22,18 +22,4 @@ export class FlowStatusService {
|
|
|
22
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FlowStatusService, decorators: [{
|
|
23
23
|
type: Injectable
|
|
24
24
|
}] });
|
|
25
|
-
|
|
26
|
-
* Batch status changes together to call them one after another
|
|
27
|
-
*
|
|
28
|
-
* @param changes list of set[FlowStatus.state]Status() calls
|
|
29
|
-
*/
|
|
30
|
-
export function batchStatusChanges(...changes) {
|
|
31
|
-
if (changes.length) {
|
|
32
|
-
const [firstChange, ...restChanges] = changes;
|
|
33
|
-
// first change is sync
|
|
34
|
-
firstChange();
|
|
35
|
-
// without timer, subscribed effects/comuted signals only get latest value
|
|
36
|
-
restChanges.forEach((change) => setTimeout(() => change()));
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zdGF0dXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9zZXJ2aWNlcy9mbG93LXN0YXR1cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWtDbkQsTUFBTSxPQUFPLGlCQUFpQjtJQUQ5QjtRQUVrQixXQUFNLEdBQUcsTUFBTSxDQUFhLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztLQTRCL0U7SUExQlEsYUFBYTtRQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLE1BQWlCLEVBQUUsWUFBeUI7UUFDMUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLEVBQUUsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNwRixDQUFDO0lBRU0sNkJBQTZCLENBQ2xDLEtBQWMsRUFDZCxNQUFpQixFQUNqQixNQUFpQixFQUNqQixZQUF5QixFQUN6QixZQUF5QjtRQUV6QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSx1QkFBdUIsRUFBRSxPQUFPLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RILENBQUM7SUFFTSxzQkFBc0IsQ0FDM0IsTUFBaUIsRUFDakIsTUFBaUIsRUFDakIsWUFBeUIsRUFDekIsWUFBeUI7UUFFekIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hHLENBQUM7K0dBNUJVLGlCQUFpQjttSEFBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUQ3QixVQUFVOztBQWdDWDs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEdBQUcsT0FBdUI7SUFDM0QsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbkIsTUFBTSxDQUFDLFdBQVcsRUFBRSxHQUFHLFdBQVcsQ0FBQyxHQUFHLE9BQU8sQ0FBQztRQUM5Qyx1QkFBdUI7UUFDdkIsV0FBVyxFQUFFLENBQUM7UUFDZCwwRUFBMEU7UUFDMUUsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTm9kZU1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzL25vZGUubW9kZWwnO1xuaW1wb3J0IHsgSGFuZGxlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvaGFuZGxlLm1vZGVsJztcbmltcG9ydCB7IENvbm5lY3Rpb25JbnRlcm5hbCB9IGZyb20gJy4uL2ludGVyZmFjZXMvY29ubmVjdGlvbi5pbnRlcm5hbC5pbnRlcmZhY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dTdGF0dXNJZGxlIHtcbiAgc3RhdGU6ICdpZGxlJztcbiAgcGF5bG9hZDogbnVsbDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG93U3RhdHVzQ29ubmVjdGlvblN0YXJ0IHtcbiAgc3RhdGU6ICdjb25uZWN0aW9uLXN0YXJ0JztcbiAgcGF5bG9hZDogT21pdDxDb25uZWN0aW9uSW50ZXJuYWwsICd0YXJnZXQnIHwgJ3RhcmdldEhhbmRsZSc+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dTdGF0dXNDb25uZWN0aW9uVmFsaWRhdGlvbiB7XG4gIHN0YXRlOiAnY29ubmVjdGlvbi12YWxpZGF0aW9uJztcbiAgcGF5bG9hZDogQ29ubmVjdGlvbkludGVybmFsICYge1xuICAgIHZhbGlkOiBib29sZWFuO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dTdGF0dXNDb25uZWN0aW9uRW5kIHtcbiAgc3RhdGU6ICdjb25uZWN0aW9uLWVuZCc7XG4gIHBheWxvYWQ6IENvbm5lY3Rpb25JbnRlcm5hbDtcbn1cblxuZXhwb3J0IHR5cGUgRmxvd1N0YXR1cyA9XG4gIHwgRmxvd1N0YXR1c0lkbGVcbiAgfCBGbG93U3RhdHVzQ29ubmVjdGlvblN0YXJ0XG4gIHwgRmxvd1N0YXR1c0Nvbm5lY3Rpb25WYWxpZGF0aW9uXG4gIHwgRmxvd1N0YXR1c0Nvbm5lY3Rpb25FbmQ7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBGbG93U3RhdHVzU2VydmljZSB7XG4gIHB1YmxpYyByZWFkb25seSBzdGF0dXMgPSBzaWduYWw8Rmxvd1N0YXR1cz4oeyBzdGF0ZTogJ2lkbGUnLCBwYXlsb2FkOiBudWxsIH0pO1xuXG4gIHB1YmxpYyBzZXRJZGxlU3RhdHVzKCkge1xuICAgIHRoaXMuc3RhdHVzLnNldCh7IHN0YXRlOiAnaWRsZScsIHBheWxvYWQ6IG51bGwgfSk7XG4gIH1cblxuICBwdWJsaWMgc2V0Q29ubmVjdGlvblN0YXJ0U3RhdHVzKHNvdXJjZTogTm9kZU1vZGVsLCBzb3VyY2VIYW5kbGU6IEhhbmRsZU1vZGVsKSB7XG4gICAgdGhpcy5zdGF0dXMuc2V0KHsgc3RhdGU6ICdjb25uZWN0aW9uLXN0YXJ0JywgcGF5bG9hZDogeyBzb3VyY2UsIHNvdXJjZUhhbmRsZSB9IH0pO1xuICB9XG5cbiAgcHVibGljIHNldENvbm5lY3Rpb25WYWxpZGF0aW9uU3RhdHVzKFxuICAgIHZhbGlkOiBib29sZWFuLFxuICAgIHNvdXJjZTogTm9kZU1vZGVsLFxuICAgIHRhcmdldDogTm9kZU1vZGVsLFxuICAgIHNvdXJjZUhhbmRsZTogSGFuZGxlTW9kZWwsXG4gICAgdGFyZ2V0SGFuZGxlOiBIYW5kbGVNb2RlbCxcbiAgKSB7XG4gICAgdGhpcy5zdGF0dXMuc2V0KHsgc3RhdGU6ICdjb25uZWN0aW9uLXZhbGlkYXRpb24nLCBwYXlsb2FkOiB7IHNvdXJjZSwgdGFyZ2V0LCBzb3VyY2VIYW5kbGUsIHRhcmdldEhhbmRsZSwgdmFsaWQgfSB9KTtcbiAgfVxuXG4gIHB1YmxpYyBzZXRDb25uZWN0aW9uRW5kU3RhdHVzKFxuICAgIHNvdXJjZTogTm9kZU1vZGVsLFxuICAgIHRhcmdldDogTm9kZU1vZGVsLFxuICAgIHNvdXJjZUhhbmRsZTogSGFuZGxlTW9kZWwsXG4gICAgdGFyZ2V0SGFuZGxlOiBIYW5kbGVNb2RlbCxcbiAgKSB7XG4gICAgdGhpcy5zdGF0dXMuc2V0KHsgc3RhdGU6ICdjb25uZWN0aW9uLWVuZCcsIHBheWxvYWQ6IHsgc291cmNlLCB0YXJnZXQsIHNvdXJjZUhhbmRsZSwgdGFyZ2V0SGFuZGxlIH0gfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBCYXRjaCBzdGF0dXMgY2hhbmdlcyB0b2dldGhlciB0byBjYWxsIHRoZW0gb25lIGFmdGVyIGFub3RoZXJcbiAqXG4gKiBAcGFyYW0gY2hhbmdlcyBsaXN0IG9mIHNldFtGbG93U3RhdHVzLnN0YXRlXVN0YXR1cygpIGNhbGxzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBiYXRjaFN0YXR1c0NoYW5nZXMoLi4uY2hhbmdlczogKCgpID0+IHZvaWQpW10pIHtcbiAgaWYgKGNoYW5nZXMubGVuZ3RoKSB7XG4gICAgY29uc3QgW2ZpcnN0Q2hhbmdlLCAuLi5yZXN0Q2hhbmdlc10gPSBjaGFuZ2VzO1xuICAgIC8vIGZpcnN0IGNoYW5nZSBpcyBzeW5jXG4gICAgZmlyc3RDaGFuZ2UoKTtcbiAgICAvLyB3aXRob3V0IHRpbWVyLCBzdWJzY3JpYmVkIGVmZmVjdHMvY29tdXRlZCBzaWduYWxzIG9ubHkgZ2V0IGxhdGVzdCB2YWx1ZVxuICAgIHJlc3RDaGFuZ2VzLmZvckVhY2goKGNoYW5nZSkgPT4gc2V0VGltZW91dCgoKSA9PiBjaGFuZ2UoKSkpO1xuICB9XG59XG4iXX0=
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxvdy1zdGF0dXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9zZXJ2aWNlcy9mbG93LXN0YXR1cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWtDbkQsTUFBTSxPQUFPLGlCQUFpQjtJQUQ5QjtRQUVrQixXQUFNLEdBQUcsTUFBTSxDQUFhLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztLQTRCL0U7SUExQlEsYUFBYTtRQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVNLHdCQUF3QixDQUFDLE1BQWlCLEVBQUUsWUFBeUI7UUFDMUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLEVBQUUsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNwRixDQUFDO0lBRU0sNkJBQTZCLENBQ2xDLEtBQWMsRUFDZCxNQUFpQixFQUNqQixNQUFpQixFQUNqQixZQUF5QixFQUN6QixZQUF5QjtRQUV6QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSx1QkFBdUIsRUFBRSxPQUFPLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RILENBQUM7SUFFTSxzQkFBc0IsQ0FDM0IsTUFBaUIsRUFDakIsTUFBaUIsRUFDakIsWUFBeUIsRUFDekIsWUFBeUI7UUFFekIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3hHLENBQUM7K0dBNUJVLGlCQUFpQjttSEFBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUQ3QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlTW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvbm9kZS5tb2RlbCc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuaW1wb3J0IHsgQ29ubmVjdGlvbkludGVybmFsIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9jb25uZWN0aW9uLmludGVybmFsLmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvd1N0YXR1c0lkbGUge1xuICBzdGF0ZTogJ2lkbGUnO1xuICBwYXlsb2FkOiBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dTdGF0dXNDb25uZWN0aW9uU3RhcnQge1xuICBzdGF0ZTogJ2Nvbm5lY3Rpb24tc3RhcnQnO1xuICBwYXlsb2FkOiBPbWl0PENvbm5lY3Rpb25JbnRlcm5hbCwgJ3RhcmdldCcgfCAndGFyZ2V0SGFuZGxlJz47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvd1N0YXR1c0Nvbm5lY3Rpb25WYWxpZGF0aW9uIHtcbiAgc3RhdGU6ICdjb25uZWN0aW9uLXZhbGlkYXRpb24nO1xuICBwYXlsb2FkOiBDb25uZWN0aW9uSW50ZXJuYWwgJiB7XG4gICAgdmFsaWQ6IGJvb2xlYW47XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvd1N0YXR1c0Nvbm5lY3Rpb25FbmQge1xuICBzdGF0ZTogJ2Nvbm5lY3Rpb24tZW5kJztcbiAgcGF5bG9hZDogQ29ubmVjdGlvbkludGVybmFsO1xufVxuXG5leHBvcnQgdHlwZSBGbG93U3RhdHVzID1cbiAgfCBGbG93U3RhdHVzSWRsZVxuICB8IEZsb3dTdGF0dXNDb25uZWN0aW9uU3RhcnRcbiAgfCBGbG93U3RhdHVzQ29ubmVjdGlvblZhbGlkYXRpb25cbiAgfCBGbG93U3RhdHVzQ29ubmVjdGlvbkVuZDtcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEZsb3dTdGF0dXNTZXJ2aWNlIHtcbiAgcHVibGljIHJlYWRvbmx5IHN0YXR1cyA9IHNpZ25hbDxGbG93U3RhdHVzPih7IHN0YXRlOiAnaWRsZScsIHBheWxvYWQ6IG51bGwgfSk7XG5cbiAgcHVibGljIHNldElkbGVTdGF0dXMoKSB7XG4gICAgdGhpcy5zdGF0dXMuc2V0KHsgc3RhdGU6ICdpZGxlJywgcGF5bG9hZDogbnVsbCB9KTtcbiAgfVxuXG4gIHB1YmxpYyBzZXRDb25uZWN0aW9uU3RhcnRTdGF0dXMoc291cmNlOiBOb2RlTW9kZWwsIHNvdXJjZUhhbmRsZTogSGFuZGxlTW9kZWwpIHtcbiAgICB0aGlzLnN0YXR1cy5zZXQoeyBzdGF0ZTogJ2Nvbm5lY3Rpb24tc3RhcnQnLCBwYXlsb2FkOiB7IHNvdXJjZSwgc291cmNlSGFuZGxlIH0gfSk7XG4gIH1cblxuICBwdWJsaWMgc2V0Q29ubmVjdGlvblZhbGlkYXRpb25TdGF0dXMoXG4gICAgdmFsaWQ6IGJvb2xlYW4sXG4gICAgc291cmNlOiBOb2RlTW9kZWwsXG4gICAgdGFyZ2V0OiBOb2RlTW9kZWwsXG4gICAgc291cmNlSGFuZGxlOiBIYW5kbGVNb2RlbCxcbiAgICB0YXJnZXRIYW5kbGU6IEhhbmRsZU1vZGVsLFxuICApIHtcbiAgICB0aGlzLnN0YXR1cy5zZXQoeyBzdGF0ZTogJ2Nvbm5lY3Rpb24tdmFsaWRhdGlvbicsIHBheWxvYWQ6IHsgc291cmNlLCB0YXJnZXQsIHNvdXJjZUhhbmRsZSwgdGFyZ2V0SGFuZGxlLCB2YWxpZCB9IH0pO1xuICB9XG5cbiAgcHVibGljIHNldENvbm5lY3Rpb25FbmRTdGF0dXMoXG4gICAgc291cmNlOiBOb2RlTW9kZWwsXG4gICAgdGFyZ2V0OiBOb2RlTW9kZWwsXG4gICAgc291cmNlSGFuZGxlOiBIYW5kbGVNb2RlbCxcbiAgICB0YXJnZXRIYW5kbGU6IEhhbmRsZU1vZGVsLFxuICApIHtcbiAgICB0aGlzLnN0YXR1cy5zZXQoeyBzdGF0ZTogJ2Nvbm5lY3Rpb24tZW5kJywgcGF5bG9hZDogeyBzb3VyY2UsIHRhcmdldCwgc291cmNlSGFuZGxlLCB0YXJnZXRIYW5kbGUgfSB9KTtcbiAgfVxufVxuIl19
|