ngx-vflow 1.0.7 → 1.1.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.
Files changed (47) hide show
  1. package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +15 -11
  2. package/esm2022/lib/vflow/components/node/node.component.mjs +18 -49
  3. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +3 -3
  4. package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +55 -1
  5. package/esm2022/lib/vflow/directives/node-handles-controller.directive.mjs +33 -0
  6. package/esm2022/lib/vflow/directives/node-resize-controller.directive.mjs +35 -0
  7. package/esm2022/lib/vflow/directives/selectable.directive.mjs +2 -2
  8. package/esm2022/lib/vflow/models/handle.model.mjs +33 -33
  9. package/esm2022/lib/vflow/models/node.model.mjs +30 -67
  10. package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +3 -3
  11. package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +4 -3
  12. package/esm2022/lib/vflow/services/draggable.service.mjs +2 -2
  13. package/esm2022/lib/vflow/services/handle.service.mjs +1 -1
  14. package/esm2022/lib/vflow/testing-utils/component-mocks/handle-mock.component.mjs +22 -0
  15. package/esm2022/lib/vflow/testing-utils/component-mocks/minimap-mock.component.mjs +22 -0
  16. package/esm2022/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.mjs +19 -0
  17. package/esm2022/lib/vflow/testing-utils/component-mocks/resizable-mock.component.mjs +21 -0
  18. package/esm2022/lib/vflow/testing-utils/component-mocks/vflow-mock.component.mjs +251 -0
  19. package/esm2022/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.mjs +15 -0
  20. package/esm2022/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.mjs +11 -0
  21. package/esm2022/lib/vflow/testing-utils/directive-mocks/selectable-mock.directive.mjs +14 -0
  22. package/esm2022/lib/vflow/testing-utils/directive-mocks/template-mock.directive.mjs +87 -0
  23. package/esm2022/lib/vflow/testing-utils/provide-custom-node-mocks.mjs +9 -8
  24. package/esm2022/lib/vflow/testing-utils/vflow-mocks.mjs +26 -0
  25. package/esm2022/public-api.mjs +11 -1
  26. package/fesm2022/ngx-vflow.mjs +699 -189
  27. package/fesm2022/ngx-vflow.mjs.map +1 -1
  28. package/lib/vflow/components/edge-label/edge-label.component.d.ts +2 -0
  29. package/lib/vflow/components/node/node.component.d.ts +5 -11
  30. package/lib/vflow/directives/changes-controller.directive.d.ts +54 -0
  31. package/lib/vflow/directives/node-handles-controller.directive.d.ts +11 -0
  32. package/lib/vflow/directives/node-resize-controller.directive.d.ts +11 -0
  33. package/lib/vflow/models/handle.model.d.ts +8 -23
  34. package/lib/vflow/models/node.model.d.ts +17 -13
  35. package/lib/vflow/services/handle.service.d.ts +1 -1
  36. package/lib/vflow/testing-utils/component-mocks/handle-mock.component.d.ts +11 -0
  37. package/lib/vflow/testing-utils/component-mocks/minimap-mock.component.d.ts +10 -0
  38. package/lib/vflow/testing-utils/component-mocks/node-toolbar-mock.component.d.ts +7 -0
  39. package/lib/vflow/testing-utils/component-mocks/resizable-mock.component.d.ts +8 -0
  40. package/lib/vflow/testing-utils/component-mocks/vflow-mock.component.d.ts +48 -0
  41. package/lib/vflow/testing-utils/directive-mocks/connection-controller-mock.directive.d.ts +7 -0
  42. package/lib/vflow/testing-utils/directive-mocks/drag-handle-mock.directive.d.ts +5 -0
  43. package/lib/vflow/testing-utils/directive-mocks/selectable-mock.directive.d.ts +5 -0
  44. package/lib/vflow/testing-utils/directive-mocks/template-mock.directive.d.ts +32 -0
  45. package/lib/vflow/testing-utils/vflow-mocks.d.ts +10 -0
  46. package/package.json +1 -1
  47. package/public-api.d.ts +10 -0
@@ -15,37 +15,67 @@ export class ChangesControllerDirective {
15
15
  this.onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {
16
16
  alias: 'onNodesChange.position',
17
17
  });
18
+ /**
19
+ * @deprecated use `onNodesChange.position` instead
20
+ */
18
21
  this.onNodesChangePositionSignle = outputFromObservable(this.singleChange(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.single' });
22
+ /**
23
+ * @deprecated use `onNodesChange.position` instead
24
+ */
19
25
  this.onNodesChangePositionMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('position')), { alias: 'onNodesChange.position.many' });
20
26
  this.onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {
21
27
  alias: 'onNodesChange.size',
22
28
  });
29
+ /**
30
+ * @deprecated use `onNodesChange.size` instead
31
+ */
23
32
  this.onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {
24
33
  alias: 'onNodesChange.size.single',
25
34
  });
35
+ /**
36
+ * @deprecated use `onNodesChange.size` instead
37
+ */
26
38
  this.onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {
27
39
  alias: 'onNodesChange.size.many',
28
40
  });
29
41
  this.onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {
30
42
  alias: 'onNodesChange.add',
31
43
  });
44
+ /**
45
+ * @deprecated use `onNodesChange.add` instead
46
+ */
32
47
  this.onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {
33
48
  alias: 'onNodesChange.add.single',
34
49
  });
50
+ /**
51
+ * @deprecated use `onNodesChange.add` instead
52
+ */
35
53
  this.onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {
36
54
  alias: 'onNodesChange.add.many',
37
55
  });
38
56
  this.onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {
39
57
  alias: 'onNodesChange.remove',
40
58
  });
59
+ /**
60
+ * @deprecated use `onNodesChange.remove` instead
61
+ */
41
62
  this.onNodesChangeRemoveSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('remove')), { alias: 'onNodesChange.remove.single' });
63
+ /**
64
+ * @deprecated use `onNodesChange.remove` instead
65
+ */
42
66
  this.onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {
43
67
  alias: 'onNodesChange.remove.many',
44
68
  });
45
69
  this.onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {
46
70
  alias: 'onNodesChange.select',
47
71
  });
72
+ /**
73
+ * @deprecated use `onNodesChange.select` instead
74
+ */
48
75
  this.onNodesChangeSelectSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('select')), { alias: 'onNodesChange.select.single' });
76
+ /**
77
+ * @deprecated use `onNodesChange.select` instead
78
+ */
49
79
  this.onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {
50
80
  alias: 'onNodesChange.select.many',
51
81
  });
@@ -56,32 +86,56 @@ export class ChangesControllerDirective {
56
86
  this.onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {
57
87
  alias: 'onEdgesChange.detached',
58
88
  });
89
+ /**
90
+ * @deprecated use `onEdgesChange.detached` instead
91
+ */
59
92
  this.onNodesChangeDetachedSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.single' });
93
+ /**
94
+ * @deprecated use `onEdgesChange.detached` instead
95
+ */
60
96
  this.onNodesChangeDetachedMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('detached')), { alias: 'onEdgesChange.detached.many' });
61
97
  this.onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {
62
98
  alias: 'onEdgesChange.add',
63
99
  });
100
+ /**
101
+ * @deprecated use `onEdgesChange.add` instead
102
+ */
64
103
  this.onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {
65
104
  alias: 'onEdgesChange.add.single',
66
105
  });
106
+ /**
107
+ * @deprecated use `onEdgesChange.add` instead
108
+ */
67
109
  this.onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {
68
110
  alias: 'onEdgesChange.add.many',
69
111
  });
70
112
  this.onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {
71
113
  alias: 'onEdgesChange.remove',
72
114
  });
115
+ /**
116
+ * @deprecated use `onEdgesChange.remove` instead
117
+ */
73
118
  this.onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {
74
119
  alias: 'onEdgesChange.remove.single',
75
120
  });
121
+ /**
122
+ * @deprecated use `onEdgesChange.remove` instead
123
+ */
76
124
  this.onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {
77
125
  alias: 'onEdgesChange.remove.many',
78
126
  });
79
127
  this.onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {
80
128
  alias: 'onEdgesChange.select',
81
129
  });
130
+ /**
131
+ * @deprecated use `onEdgesChange.select` instead
132
+ */
82
133
  this.onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {
83
134
  alias: 'onEdgesChange.select.single',
84
135
  });
136
+ /**
137
+ * @deprecated use `onEdgesChange.select` instead
138
+ */
85
139
  this.onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {
86
140
  alias: 'onEdgesChange.select.many',
87
141
  });
@@ -108,4 +162,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
108
162
  standalone: true,
109
163
  }]
110
164
  }] });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"changes-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/changes-controller.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AASlD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAc,MAAM,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAQ/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;;AAMlE,MAAM,OAAO,0BAA0B;IAJvC;QAKY,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChD,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAE1D;;WAEG;QACa,kBAAa,GAAG,oBAAoB,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAEvE,0BAAqB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE;YAC/F,KAAK,EAAE,wBAAwB;SAChC,CAAC,CAAC;QAEa,gCAA2B,GAAG,oBAAoB,CAChE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,EACrD,EAAE,KAAK,EAAE,+BAA+B,EAAE,CAC3C,CAAC;QAEc,8BAAyB,GAAG,oBAAoB,CAC9D,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,EACpD,EAAE,KAAK,EAAE,6BAA6B,EAAE,CACzC,CAAC;QAEc,sBAAiB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE;YACvF,KAAK,EAAE,oBAAoB;SAC5B,CAAC,CAAC;QAEa,4BAAuB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,EAAE;YAChH,KAAK,EAAE,2BAA2B;SACnC,CAAC,CAAC;QAEa,0BAAqB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,EAAE;YAC7G,KAAK,EAAE,yBAAyB;SACjC,CAAC,CAAC;QAEa,qBAAgB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE;YACrF,KAAK,EAAE,mBAAmB;SAC3B,CAAC,CAAC;QAEa,2BAAsB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE;YAC9G,KAAK,EAAE,0BAA0B;SAClC,CAAC,CAAC;QAEa,yBAAoB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE;YAC3G,KAAK,EAAE,wBAAwB;SAChC,CAAC,CAAC;QAEa,wBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE;YAC3F,KAAK,EAAE,sBAAsB;SAC9B,CAAC,CAAC;QAEa,8BAAyB,GAAG,oBAAoB,CAC9D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EACnD,EAAE,KAAK,EAAE,6BAA6B,EAAE,CACzC,CAAC;QAEc,4BAAuB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YACjH,KAAK,EAAE,2BAA2B;SACnC,CAAC,CAAC;QAEa,wBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE;YAC3F,KAAK,EAAE,sBAAsB;SAC9B,CAAC,CAAC;QAEa,8BAAyB,GAAG,oBAAoB,CAC9D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EACnD,EAAE,KAAK,EAAE,6BAA6B,EAAE,CACzC,CAAC;QAEc,4BAAuB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YACjH,KAAK,EAAE,2BAA2B;SACnC,CAAC,CAAC;QAEH;;WAEG;QACa,kBAAa,GAAG,oBAAoB,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAEvE,0BAAqB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE;YAC/F,KAAK,EAAE,wBAAwB;SAChC,CAAC,CAAC;QAEa,gCAA2B,GAAG,oBAAoB,CAChE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,EACrD,EAAE,KAAK,EAAE,+BAA+B,EAAE,CAC3C,CAAC;QAEc,8BAAyB,GAAG,oBAAoB,CAC9D,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,EACpD,EAAE,KAAK,EAAE,6BAA6B,EAAE,CACzC,CAAC;QAEc,qBAAgB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE;YACrF,KAAK,EAAE,mBAAmB;SAC3B,CAAC,CAAC;QAEa,0BAAqB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE;YAC7G,KAAK,EAAE,0BAA0B;SAClC,CAAC,CAAC;QAEa,wBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAAE;YAC1G,KAAK,EAAE,wBAAwB;SAChC,CAAC,CAAC;QAEa,uBAAkB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE;YAC1F,KAAK,EAAE,sBAAsB;SAC9B,CAAC,CAAC;QAEa,6BAAwB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YACnH,KAAK,EAAE,6BAA6B;SACrC,CAAC,CAAC;QAEa,2BAAsB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YAChH,KAAK,EAAE,2BAA2B;SACnC,CAAC,CAAC;QAEa,uBAAkB,GAAG,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE;YAC1F,KAAK,EAAE,sBAAsB;SAC9B,CAAC,CAAC;QAEa,6BAAwB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YACnH,KAAK,EAAE,6BAA6B;SACrC,CAAC,CAAC;QAEa,2BAAsB,GAAG,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,EAAE;YAChH,KAAK,EAAE,2BAA2B;SACnC,CAAC,CAAC;KA0BJ;IAxBS,iBAAiB,CAA+B,IAAO;QAC7D,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAC1C,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAyB,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,EAC/E,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CACtC,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAA+B,IAAO;QAC7D,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAC1C,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAyB,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,EAC/E,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CACtC,CAAC;IACJ,CAAC;IAEO,YAAY,CAAI,QAAyB;QAC/C,OAAO,QAAQ,CAAC,IAAI,CAClB,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,CAAC,EACzC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CACxB,CAAC;IACJ,CAAC;IAEO,WAAW,CAAI,QAAyB;QAC9C,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC;+GAvJU,0BAA0B;mGAA1B,0BAA0B;;4FAA1B,0BAA0B;kBAJtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,UAAU,EAAE,IAAI;iBACjB","sourcesContent":["import { Directive, inject } from '@angular/core';\nimport {\n  NodeAddChange,\n  NodeChange,\n  NodePositionChange,\n  NodeRemoveChange,\n  NodeSelectedChange,\n  NodeSizeChange,\n} from '../types/node-change.type';\nimport { EdgeChangesService } from '../services/edge-changes.service';\nimport { NodesChangeService } from '../services/node-changes.service';\nimport { Observable, filter, map } from 'rxjs';\nimport {\n  EdgeAddChange,\n  EdgeChange,\n  EdgeDetachedChange,\n  EdgeRemoveChange,\n  EdgeSelectChange,\n} from '../types/edge-change.type';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\n\n@Directive({\n  selector: '[changesController]',\n  standalone: true,\n})\nexport class ChangesControllerDirective {\n  protected nodesChangeService = inject(NodesChangeService);\n  protected edgesChangeService = inject(EdgeChangesService);\n\n  /**\n   * Watch nodes change\n   */\n  public readonly onNodesChange = outputFromObservable(this.nodesChangeService.changes$);\n\n  public readonly onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {\n    alias: 'onNodesChange.position',\n  });\n\n  public readonly onNodesChangePositionSignle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.single' },\n  );\n\n  public readonly onNodesChangePositionMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.many' },\n  );\n\n  public readonly onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {\n    alias: 'onNodesChange.size',\n  });\n\n  public readonly onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.single',\n  });\n\n  public readonly onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.many',\n  });\n\n  public readonly onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {\n    alias: 'onNodesChange.add',\n  });\n\n  public readonly onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.single',\n  });\n\n  public readonly onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.many',\n  });\n\n  public readonly onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {\n    alias: 'onNodesChange.remove',\n  });\n\n  public readonly onNodesChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.single' },\n  );\n\n  public readonly onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {\n    alias: 'onNodesChange.remove.many',\n  });\n\n  public readonly onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {\n    alias: 'onNodesChange.select',\n  });\n\n  public readonly onNodesChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.single' },\n  );\n\n  public readonly onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {\n    alias: 'onNodesChange.select.many',\n  });\n\n  /**\n   * Watch edges change\n   */\n  public readonly onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);\n\n  public readonly onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {\n    alias: 'onEdgesChange.detached',\n  });\n\n  public readonly onNodesChangeDetachedSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.single' },\n  );\n\n  public readonly onNodesChangeDetachedMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.many' },\n  );\n\n  public readonly onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {\n    alias: 'onEdgesChange.add',\n  });\n\n  public readonly onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.single',\n  });\n\n  public readonly onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.many',\n  });\n\n  public readonly onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {\n    alias: 'onEdgesChange.remove',\n  });\n\n  public readonly onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.single',\n  });\n\n  public readonly onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.many',\n  });\n\n  public readonly onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {\n    alias: 'onEdgesChange.select',\n  });\n\n  public readonly onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.single',\n  });\n\n  public readonly onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.many',\n  });\n\n  private nodeChangesOfType<T extends NodeChange['type']>(type: T) {\n    return this.nodesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is NodeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private edgeChangesOfType<T extends EdgeChange['type']>(type: T) {\n    return this.edgesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is EdgeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private singleChange<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter((changes) => changes.length === 1),\n      map(([first]) => first),\n    );\n  }\n\n  private manyChanges<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(filter((changes) => changes.length > 1));\n  }\n}\n\n// TODO: do not write this types manually\ntype NodeChangeMap = {\n  position: NodePositionChange;\n  size: NodeSizeChange;\n  add: NodeAddChange;\n  remove: NodeRemoveChange;\n  select: NodeSelectedChange;\n};\n\ntype EdgeChangeMap = {\n  detached: EdgeDetachedChange;\n  add: EdgeAddChange;\n  remove: EdgeRemoveChange;\n  select: EdgeSelectChange;\n};\n"]}
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"changes-controller.directive.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/directives/changes-controller.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, inject } from '@angular/core';\nimport {\n  NodeAddChange,\n  NodeChange,\n  NodePositionChange,\n  NodeRemoveChange,\n  NodeSelectedChange,\n  NodeSizeChange,\n} from '../types/node-change.type';\nimport { EdgeChangesService } from '../services/edge-changes.service';\nimport { NodesChangeService } from '../services/node-changes.service';\nimport { Observable, filter, map } from 'rxjs';\nimport {\n  EdgeAddChange,\n  EdgeChange,\n  EdgeDetachedChange,\n  EdgeRemoveChange,\n  EdgeSelectChange,\n} from '../types/edge-change.type';\nimport { outputFromObservable } from '@angular/core/rxjs-interop';\n\n@Directive({\n  selector: '[changesController]',\n  standalone: true,\n})\nexport class ChangesControllerDirective {\n  protected nodesChangeService = inject(NodesChangeService);\n  protected edgesChangeService = inject(EdgeChangesService);\n\n  /**\n   * Watch nodes change\n   */\n  public readonly onNodesChange = outputFromObservable(this.nodesChangeService.changes$);\n\n  public readonly onNodesChangePosition = outputFromObservable(this.nodeChangesOfType('position'), {\n    alias: 'onNodesChange.position',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.position` instead\n   */\n  public readonly onNodesChangePositionSignle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.position` instead\n   */\n  public readonly onNodesChangePositionMany = outputFromObservable(\n    this.manyChanges(this.nodeChangesOfType('position')),\n    { alias: 'onNodesChange.position.many' },\n  );\n\n  public readonly onNodesChangeSize = outputFromObservable(this.nodeChangesOfType('size'), {\n    alias: 'onNodesChange.size',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.size` instead\n   */\n  public readonly onNodesChangeSizeSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.single',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.size` instead\n   */\n  public readonly onNodesChangeSizeMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('size')), {\n    alias: 'onNodesChange.size.many',\n  });\n\n  public readonly onNodesChangeAdd = outputFromObservable(this.nodeChangesOfType('add'), {\n    alias: 'onNodesChange.add',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.add` instead\n   */\n  public readonly onNodesChangeAddSingle = outputFromObservable(this.singleChange(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.single',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.add` instead\n   */\n  public readonly onNodesChangeAddMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('add')), {\n    alias: 'onNodesChange.add.many',\n  });\n\n  public readonly onNodesChangeRemove = outputFromObservable(this.nodeChangesOfType('remove'), {\n    alias: 'onNodesChange.remove',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.remove` instead\n   */\n  public readonly onNodesChangeRemoveSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('remove')),\n    { alias: 'onNodesChange.remove.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.remove` instead\n   */\n  public readonly onNodesChangeRemoveMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('remove')), {\n    alias: 'onNodesChange.remove.many',\n  });\n\n  public readonly onNodesChangeSelect = outputFromObservable(this.nodeChangesOfType('select'), {\n    alias: 'onNodesChange.select',\n  });\n\n  /**\n   * @deprecated use `onNodesChange.select` instead\n   */\n  public readonly onNodesChangeSelectSingle = outputFromObservable(\n    this.singleChange(this.nodeChangesOfType('select')),\n    { alias: 'onNodesChange.select.single' },\n  );\n\n  /**\n   * @deprecated use `onNodesChange.select` instead\n   */\n  public readonly onNodesChangeSelectMany = outputFromObservable(this.manyChanges(this.nodeChangesOfType('select')), {\n    alias: 'onNodesChange.select.many',\n  });\n\n  /**\n   * Watch edges change\n   */\n  public readonly onEdgesChange = outputFromObservable(this.edgesChangeService.changes$);\n\n  public readonly onNodesChangeDetached = outputFromObservable(this.edgeChangesOfType('detached'), {\n    alias: 'onEdgesChange.detached',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.detached` instead\n   */\n  public readonly onNodesChangeDetachedSingle = outputFromObservable(\n    this.singleChange(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.single' },\n  );\n\n  /**\n   * @deprecated use `onEdgesChange.detached` instead\n   */\n  public readonly onNodesChangeDetachedMany = outputFromObservable(\n    this.manyChanges(this.edgeChangesOfType('detached')),\n    { alias: 'onEdgesChange.detached.many' },\n  );\n\n  public readonly onEdgesChangeAdd = outputFromObservable(this.edgeChangesOfType('add'), {\n    alias: 'onEdgesChange.add',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.add` instead\n   */\n  public readonly onEdgeChangeAddSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.add` instead\n   */\n  public readonly onEdgeChangeAddMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('add')), {\n    alias: 'onEdgesChange.add.many',\n  });\n\n  public readonly onEdgeChangeRemove = outputFromObservable(this.edgeChangesOfType('remove'), {\n    alias: 'onEdgesChange.remove',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.remove` instead\n   */\n  public readonly onEdgeChangeRemoveSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.remove` instead\n   */\n  public readonly onEdgeChangeRemoveMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('remove')), {\n    alias: 'onEdgesChange.remove.many',\n  });\n\n  public readonly onEdgeChangeSelect = outputFromObservable(this.edgeChangesOfType('select'), {\n    alias: 'onEdgesChange.select',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.select` instead\n   */\n  public readonly onEdgeChangeSelectSingle = outputFromObservable(this.singleChange(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.single',\n  });\n\n  /**\n   * @deprecated use `onEdgesChange.select` instead\n   */\n  public readonly onEdgeChangeSelectMany = outputFromObservable(this.manyChanges(this.edgeChangesOfType('select')), {\n    alias: 'onEdgesChange.select.many',\n  });\n\n  private nodeChangesOfType<T extends NodeChange['type']>(type: T) {\n    return this.nodesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is NodeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private edgeChangesOfType<T extends EdgeChange['type']>(type: T) {\n    return this.edgesChangeService.changes$.pipe(\n      map((changes) => changes.filter((c): c is EdgeChangeMap[T] => c.type === type)),\n      filter((changes) => !!changes.length),\n    );\n  }\n\n  private singleChange<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(\n      filter((changes) => changes.length === 1),\n      map(([first]) => first),\n    );\n  }\n\n  private manyChanges<T>(changes$: Observable<T[]>) {\n    return changes$.pipe(filter((changes) => changes.length > 1));\n  }\n}\n\n// TODO: do not write this types manually\ntype NodeChangeMap = {\n  position: NodePositionChange;\n  size: NodeSizeChange;\n  add: NodeAddChange;\n  remove: NodeRemoveChange;\n  select: NodeSelectedChange;\n};\n\ntype EdgeChangeMap = {\n  detached: EdgeDetachedChange;\n  add: EdgeAddChange;\n  remove: EdgeRemoveChange;\n  select: EdgeSelectChange;\n};\n"]}
@@ -0,0 +1,33 @@
1
+ import { DestroyRef, Directive, ElementRef, inject, NgZone } from '@angular/core';
2
+ import { NodeAccessorService } from '../services/node-accessor.service';
3
+ import { map, switchMap, tap } from 'rxjs';
4
+ import { resizable } from '../utils/resizable';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
+ import * as i0 from "@angular/core";
7
+ export class NodeHandlesControllerDirective {
8
+ constructor() {
9
+ this.nodeAccessor = inject(NodeAccessorService);
10
+ this.zone = inject(NgZone);
11
+ this.destroyRef = inject(DestroyRef);
12
+ this.hostElementRef = inject(ElementRef);
13
+ }
14
+ ngOnInit() {
15
+ const model = this.nodeAccessor.model();
16
+ model.handles$
17
+ .pipe(switchMap((handles) => resizable([...handles.map((h) => h.hostReference), this.hostElementRef.nativeElement], this.zone).pipe(map(() => handles))), tap((handles) => {
18
+ // TODO (performance) inspect how to avoid calls of this when flow initially rendered
19
+ handles.forEach((h) => h.updateHost());
20
+ }), takeUntilDestroyed(this.destroyRef))
21
+ .subscribe();
22
+ }
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeHandlesControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
24
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: NodeHandlesControllerDirective, isStandalone: true, selector: "[nodeHandlesController]", ngImport: i0 }); }
25
+ }
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeHandlesControllerDirective, decorators: [{
27
+ type: Directive,
28
+ args: [{
29
+ selector: '[nodeHandlesController]',
30
+ standalone: true,
31
+ }]
32
+ }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1oYW5kbGVzLWNvbnRyb2xsZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L2RpcmVjdGl2ZXMvbm9kZS1oYW5kbGVzLWNvbnRyb2xsZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMzQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBTWhFLE1BQU0sT0FBTyw4QkFBOEI7SUFKM0M7UUFLVSxpQkFBWSxHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQzNDLFNBQUksR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdEIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNoQyxtQkFBYyxHQUFHLE1BQU0sQ0FBc0IsVUFBVSxDQUFDLENBQUM7S0FvQmxFO0lBbEJRLFFBQVE7UUFDYixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRyxDQUFDO1FBRXpDLEtBQUssQ0FBQyxRQUFRO2FBQ1gsSUFBSSxDQUNILFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQ3BCLFNBQVMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWMsQ0FBQyxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FDckcsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUNuQixDQUNGLEVBQ0QsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDZCxxRkFBcUY7WUFDckYsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7UUFDekMsQ0FBQyxDQUFDLEVBQ0Ysa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUNwQzthQUNBLFNBQVMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7K0dBdkJVLDhCQUE4QjttR0FBOUIsOEJBQThCOzs0RkFBOUIsOEJBQThCO2tCQUoxQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0LCBOZ1pvbmUsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTm9kZUFjY2Vzc29yU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL25vZGUtYWNjZXNzb3Iuc2VydmljZSc7XG5pbXBvcnQgeyBtYXAsIHN3aXRjaE1hcCwgdGFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyByZXNpemFibGUgfSBmcm9tICcuLi91dGlscy9yZXNpemFibGUnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbbm9kZUhhbmRsZXNDb250cm9sbGVyXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVIYW5kbGVzQ29udHJvbGxlckRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHByaXZhdGUgbm9kZUFjY2Vzc29yID0gaW5qZWN0KE5vZGVBY2Nlc3NvclNlcnZpY2UpO1xuICBwcml2YXRlIHpvbmUgPSBpbmplY3QoTmdab25lKTtcbiAgcHJpdmF0ZSBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuICBwcml2YXRlIGhvc3RFbGVtZW50UmVmID0gaW5qZWN0PEVsZW1lbnRSZWY8RWxlbWVudD4+KEVsZW1lbnRSZWYpO1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBjb25zdCBtb2RlbCA9IHRoaXMubm9kZUFjY2Vzc29yLm1vZGVsKCkhO1xuXG4gICAgbW9kZWwuaGFuZGxlcyRcbiAgICAgIC5waXBlKFxuICAgICAgICBzd2l0Y2hNYXAoKGhhbmRsZXMpID0+XG4gICAgICAgICAgcmVzaXphYmxlKFsuLi5oYW5kbGVzLm1hcCgoaCkgPT4gaC5ob3N0UmVmZXJlbmNlISksIHRoaXMuaG9zdEVsZW1lbnRSZWYubmF0aXZlRWxlbWVudF0sIHRoaXMuem9uZSkucGlwZShcbiAgICAgICAgICAgIG1hcCgoKSA9PiBoYW5kbGVzKSxcbiAgICAgICAgICApLFxuICAgICAgICApLFxuICAgICAgICB0YXAoKGhhbmRsZXMpID0+IHtcbiAgICAgICAgICAvLyBUT0RPIChwZXJmb3JtYW5jZSkgaW5zcGVjdCBob3cgdG8gYXZvaWQgY2FsbHMgb2YgdGhpcyB3aGVuIGZsb3cgaW5pdGlhbGx5IHJlbmRlcmVkXG4gICAgICAgICAgaGFuZGxlcy5mb3JFYWNoKChoKSA9PiBoLnVwZGF0ZUhvc3QoKSk7XG4gICAgICAgIH0pLFxuICAgICAgICB0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKSxcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,35 @@
1
+ import { DestroyRef, Directive, ElementRef, inject, NgZone } from '@angular/core';
2
+ import { resizable } from '../utils/resizable';
3
+ import { NodeAccessorService } from '../services/node-accessor.service';
4
+ import { filter, startWith, tap } from 'rxjs';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
+ import * as i0 from "@angular/core";
7
+ export class NodeResizeControllerDirective {
8
+ constructor() {
9
+ this.nodeAccessor = inject(NodeAccessorService);
10
+ this.zone = inject(NgZone);
11
+ this.destroyRef = inject(DestroyRef);
12
+ this.hostElementRef = inject(ElementRef);
13
+ }
14
+ ngOnInit() {
15
+ const model = this.nodeAccessor.model();
16
+ resizable([this.hostElementRef.nativeElement], this.zone)
17
+ .pipe(startWith(null), filter(() => !model.resizing()), tap(() => {
18
+ const width = this.hostElementRef.nativeElement.clientWidth;
19
+ const height = this.hostElementRef.nativeElement.clientHeight;
20
+ model.width.set(width);
21
+ model.height.set(height);
22
+ }), takeUntilDestroyed(this.destroyRef))
23
+ .subscribe();
24
+ }
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeResizeControllerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: NodeResizeControllerDirective, isStandalone: true, selector: "[nodeResizeController]", ngImport: i0 }); }
27
+ }
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NodeResizeControllerDirective, decorators: [{
29
+ type: Directive,
30
+ args: [{
31
+ selector: '[nodeResizeController]',
32
+ standalone: true,
33
+ }]
34
+ }] });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1yZXNpemUtY29udHJvbGxlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9ub2RlLXJlc2l6ZS1jb250cm9sbGVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDeEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQU1oRSxNQUFNLE9BQU8sNkJBQTZCO0lBSjFDO1FBS1UsaUJBQVksR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUMzQyxTQUFJLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RCLGVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDaEMsbUJBQWMsR0FBRyxNQUFNLENBQXNCLFVBQVUsQ0FBQyxDQUFDO0tBb0JsRTtJQWxCUSxRQUFRO1FBQ2IsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUcsQ0FBQztRQUV6QyxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDdEQsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFDZixNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUMsRUFDL0IsR0FBRyxDQUFDLEdBQUcsRUFBRTtZQUNQLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLFdBQVcsQ0FBQztZQUM1RCxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7WUFFOUQsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDdkIsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDM0IsQ0FBQyxDQUFDLEVBQ0Ysa0JBQWtCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUNwQzthQUNBLFNBQVMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7K0dBdkJVLDZCQUE2QjttR0FBN0IsNkJBQTZCOzs0RkFBN0IsNkJBQTZCO2tCQUp6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc3Ryb3lSZWYsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0LCBOZ1pvbmUsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgcmVzaXphYmxlIH0gZnJvbSAnLi4vdXRpbHMvcmVzaXphYmxlJztcbmltcG9ydCB7IE5vZGVBY2Nlc3NvclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9ub2RlLWFjY2Vzc29yLnNlcnZpY2UnO1xuaW1wb3J0IHsgZmlsdGVyLCBzdGFydFdpdGgsIHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsRGVzdHJveWVkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbbm9kZVJlc2l6ZUNvbnRyb2xsZXJdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTm9kZVJlc2l6ZUNvbnRyb2xsZXJEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcml2YXRlIG5vZGVBY2Nlc3NvciA9IGluamVjdChOb2RlQWNjZXNzb3JTZXJ2aWNlKTtcbiAgcHJpdmF0ZSB6b25lID0gaW5qZWN0KE5nWm9uZSk7XG4gIHByaXZhdGUgZGVzdHJveVJlZiA9IGluamVjdChEZXN0cm95UmVmKTtcbiAgcHJpdmF0ZSBob3N0RWxlbWVudFJlZiA9IGluamVjdDxFbGVtZW50UmVmPEVsZW1lbnQ+PihFbGVtZW50UmVmKTtcblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgY29uc3QgbW9kZWwgPSB0aGlzLm5vZGVBY2Nlc3Nvci5tb2RlbCgpITtcblxuICAgIHJlc2l6YWJsZShbdGhpcy5ob3N0RWxlbWVudFJlZi5uYXRpdmVFbGVtZW50XSwgdGhpcy56b25lKVxuICAgICAgLnBpcGUoXG4gICAgICAgIHN0YXJ0V2l0aChudWxsKSxcbiAgICAgICAgZmlsdGVyKCgpID0+ICFtb2RlbC5yZXNpemluZygpKSxcbiAgICAgICAgdGFwKCgpID0+IHtcbiAgICAgICAgICBjb25zdCB3aWR0aCA9IHRoaXMuaG9zdEVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5jbGllbnRXaWR0aDtcbiAgICAgICAgICBjb25zdCBoZWlnaHQgPSB0aGlzLmhvc3RFbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY2xpZW50SGVpZ2h0O1xuXG4gICAgICAgICAgbW9kZWwud2lkdGguc2V0KHdpZHRoKTtcbiAgICAgICAgICBtb2RlbC5oZWlnaHQuc2V0KGhlaWdodCk7XG4gICAgICAgIH0pLFxuICAgICAgICB0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKSxcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
@@ -19,7 +19,7 @@ export class SelectableDirective {
19
19
  }
20
20
  entity() {
21
21
  if (this.parentNode) {
22
- return this.parentNode.nodeModel();
22
+ return this.parentNode.model();
23
23
  }
24
24
  else if (this.parentEdge) {
25
25
  return this.parentEdge.model();
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
42
42
  type: HostListener,
43
43
  args: ['touchstart']
44
44
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9zZWxlY3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBR2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFNeEUsTUFBTSxPQUFPLG1CQUFtQjtJQUpoQztRQUtVLHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2xELHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVDLGVBQVUsR0FBRyxNQUFNLENBQUMsYUFBYSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDdkQsZUFBVSxHQUFHLE1BQU0sQ0FBQyxhQUFhLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztLQW9CaEU7SUFoQlcsV0FBVztRQUNuQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsSUFBSSxNQUFNLElBQUksSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixFQUFFLEVBQUUsQ0FBQztZQUM1RCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7SUFDSCxDQUFDO0lBRU8sTUFBTTtRQUNaLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3BCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNyQyxDQUFDO2FBQU0sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDM0IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2pDLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7K0dBdkJVLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUovQixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsY0FBYztpQkFDekI7OEJBU1csV0FBVztzQkFGcEIsWUFBWTt1QkFBQyxXQUFXOztzQkFDeEIsWUFBWTt1QkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2VsZWN0aW9uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3NlbGVjdGlvbi5zZXJ2aWNlJztcbmltcG9ydCB7IEVkZ2VDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2VkZ2UvZWRnZS5jb21wb25lbnQnO1xuXG5pbXBvcnQgeyBGbG93RW50aXR5IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9mbG93LWVudGl0eS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgTm9kZUNvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvbm9kZS9ub2RlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGbG93U2V0dGluZ3NTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1zZXR0aW5ncy5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW3NlbGVjdGFibGVdJyxcbn0pXG5leHBvcnQgY2xhc3MgU2VsZWN0YWJsZURpcmVjdGl2ZSB7XG4gIHByaXZhdGUgZmxvd1NldHRpbmdzU2VydmljZSA9IGluamVjdChGbG93U2V0dGluZ3NTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBzZWxlY3Rpb25TZXJ2aWNlID0gaW5qZWN0KFNlbGVjdGlvblNlcnZpY2UpO1xuICBwcml2YXRlIHBhcmVudEVkZ2UgPSBpbmplY3QoRWRnZUNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBwYXJlbnROb2RlID0gaW5qZWN0KE5vZGVDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUgfSk7XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2Vkb3duJylcbiAgQEhvc3RMaXN0ZW5lcigndG91Y2hzdGFydCcpXG4gIHByb3RlY3RlZCBvbk1vdXNlZG93bigpIHtcbiAgICBjb25zdCBlbnRpdHkgPSB0aGlzLmVudGl0eSgpO1xuICAgIGlmIChlbnRpdHkgJiYgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmVudGl0aWVzU2VsZWN0YWJsZSgpKSB7XG4gICAgICB0aGlzLnNlbGVjdGlvblNlcnZpY2Uuc2VsZWN0KGVudGl0eSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBlbnRpdHkoKTogRmxvd0VudGl0eSB8IG51bGwge1xuICAgIGlmICh0aGlzLnBhcmVudE5vZGUpIHtcbiAgICAgIHJldHVybiB0aGlzLnBhcmVudE5vZGUubm9kZU1vZGVsKCk7XG4gICAgfSBlbHNlIGlmICh0aGlzLnBhcmVudEVkZ2UpIHtcbiAgICAgIHJldHVybiB0aGlzLnBhcmVudEVkZ2UubW9kZWwoKTtcbiAgICB9XG5cbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0YWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvZGlyZWN0aXZlcy9zZWxlY3RhYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDakUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBR2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFNeEUsTUFBTSxPQUFPLG1CQUFtQjtJQUpoQztRQUtVLHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2xELHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVDLGVBQVUsR0FBRyxNQUFNLENBQUMsYUFBYSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFDdkQsZUFBVSxHQUFHLE1BQU0sQ0FBQyxhQUFhLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztLQW9CaEU7SUFoQlcsV0FBVztRQUNuQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDN0IsSUFBSSxNQUFNLElBQUksSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixFQUFFLEVBQUUsQ0FBQztZQUM1RCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7SUFDSCxDQUFDO0lBRU8sTUFBTTtRQUNaLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3BCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNqQyxDQUFDO2FBQU0sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDM0IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2pDLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7K0dBdkJVLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUovQixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsY0FBYztpQkFDekI7OEJBU1csV0FBVztzQkFGcEIsWUFBWTt1QkFBQyxXQUFXOztzQkFDeEIsWUFBWTt1QkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2VsZWN0aW9uU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3NlbGVjdGlvbi5zZXJ2aWNlJztcbmltcG9ydCB7IEVkZ2VDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2VkZ2UvZWRnZS5jb21wb25lbnQnO1xuXG5pbXBvcnQgeyBGbG93RW50aXR5IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9mbG93LWVudGl0eS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgTm9kZUNvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvbm9kZS9ub2RlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGbG93U2V0dGluZ3NTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1zZXR0aW5ncy5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW3NlbGVjdGFibGVdJyxcbn0pXG5leHBvcnQgY2xhc3MgU2VsZWN0YWJsZURpcmVjdGl2ZSB7XG4gIHByaXZhdGUgZmxvd1NldHRpbmdzU2VydmljZSA9IGluamVjdChGbG93U2V0dGluZ3NTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBzZWxlY3Rpb25TZXJ2aWNlID0gaW5qZWN0KFNlbGVjdGlvblNlcnZpY2UpO1xuICBwcml2YXRlIHBhcmVudEVkZ2UgPSBpbmplY3QoRWRnZUNvbXBvbmVudCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSBwYXJlbnROb2RlID0gaW5qZWN0KE5vZGVDb21wb25lbnQsIHsgb3B0aW9uYWw6IHRydWUgfSk7XG5cbiAgQEhvc3RMaXN0ZW5lcignbW91c2Vkb3duJylcbiAgQEhvc3RMaXN0ZW5lcigndG91Y2hzdGFydCcpXG4gIHByb3RlY3RlZCBvbk1vdXNlZG93bigpIHtcbiAgICBjb25zdCBlbnRpdHkgPSB0aGlzLmVudGl0eSgpO1xuICAgIGlmIChlbnRpdHkgJiYgdGhpcy5mbG93U2V0dGluZ3NTZXJ2aWNlLmVudGl0aWVzU2VsZWN0YWJsZSgpKSB7XG4gICAgICB0aGlzLnNlbGVjdGlvblNlcnZpY2Uuc2VsZWN0KGVudGl0eSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBlbnRpdHkoKTogRmxvd0VudGl0eSB8IG51bGwge1xuICAgIGlmICh0aGlzLnBhcmVudE5vZGUpIHtcbiAgICAgIHJldHVybiB0aGlzLnBhcmVudE5vZGUubW9kZWwoKTtcbiAgICB9IGVsc2UgaWYgKHRoaXMucGFyZW50RWRnZSkge1xuICAgICAgcmV0dXJuIHRoaXMucGFyZW50RWRnZS5tb2RlbCgpO1xuICAgIH1cblxuICAgIHJldHVybiBudWxsO1xuICB9XG59XG4iXX0=
@@ -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.offset = computed(() => {
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.parentPosition().y + this.parentSize().height / 2,
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.parentPosition().y + this.parentSize().height / 2,
44
+ y: this.hostPosition().y + this.hostSize().height / 2,
28
45
  };
29
46
  case 'top':
30
47
  return {
31
- x: this.parentPosition().x + this.parentSize().width / 2,
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.parentPosition().x + this.parentSize().width / 2,
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.pointAbsolute = computed(() => {
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.offset,
74
+ point: this.hostOffset,
75
75
  state: this.state,
76
76
  node: this.parentNode.node,
77
77
  },
78
78
  };
79
79
  }
80
- updateParent() {
81
- this.updateParentSizeAndPosition$.next();
80
+ updateHost() {
81
+ this.updateHostSizeAndPosition$.next();
82
82
  }
83
- getParentSize() {
84
- if (this.parentReference instanceof HTMLElement) {
83
+ getHostSize() {
84
+ if (this.hostReference instanceof HTMLElement) {
85
85
  return {
86
- width: this.parentReference.offsetWidth,
87
- height: this.parentReference.offsetHeight,
86
+ width: this.hostReference.offsetWidth,
87
+ height: this.hostReference.offsetHeight,
88
88
  };
89
89
  }
90
- else if (this.parentReference instanceof SVGGraphicsElement) {
91
- return this.parentReference.getBBox();
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,{"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 offset = computed(() => {\n    switch (this.rawHandle.position) {\n      case 'left':\n        return {\n          x: 0,\n          y: this.parentPosition().y + this.parentSize().height / 2,\n        };\n      case 'right':\n        return {\n          x: this.parentNode.size().width,\n          y: this.parentPosition().y + this.parentSize().height / 2,\n        };\n      case 'top':\n        return {\n          x: this.parentPosition().x + this.parentSize().width / 2,\n          y: 0,\n        };\n      case 'bottom':\n        return {\n          x: this.parentPosition().x + this.parentSize().width / 2,\n          y: this.parentNode.size().height,\n        };\n    }\n  });\n\n  public 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 pointAbsolute = computed(() => {\n    return {\n      x: this.parentNode.globalPoint().x + this.offset().x + this.sizeOffset().x,\n      y: this.parentNode.globalPoint().y + this.offset().y + this.sizeOffset().y,\n    };\n  });\n\n  public state = signal<HandleState>('idle');\n\n  private updateParentSizeAndPosition$ = new Subject<void>();\n\n  public parentSize = toSignal(this.updateParentSizeAndPosition$.pipe(map(() => this.getParentSize())), {\n    initialValue: { width: 0, height: 0 },\n  });\n\n  public parentPosition = toSignal(\n    this.updateParentSizeAndPosition$.pipe(\n      map(() => ({\n        x: this.parentReference instanceof HTMLElement ? this.parentReference.offsetLeft : 0, // for now just 0 for group nodes\n        y: this.parentReference instanceof HTMLElement ? this.parentReference.offsetTop : 0, // for now just 0 for group nodes\n      })),\n    ),\n    {\n      initialValue: { x: 0, y: 0 },\n    },\n  );\n\n  public parentReference = this.rawHandle.parentReference!;\n\n  public template = this.rawHandle.template;\n\n  public templateContext = {\n    $implicit: {\n      point: this.offset,\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 updateParent() {\n    this.updateParentSizeAndPosition$.next();\n  }\n\n  private getParentSize(): { width: number; height: number } {\n    if (this.parentReference instanceof HTMLElement) {\n      return {\n        width: this.parentReference.offsetWidth,\n        height: this.parentReference.offsetHeight,\n      };\n    } else if (this.parentReference instanceof SVGGraphicsElement) {\n      return this.parentReference.getBBox();\n    }\n\n    return { width: 0, height: 0 };\n  }\n}\n"]}
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"]}