ngx-vflow 1.16.3 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (181) hide show
  1. package/README.md +35 -69
  2. package/fesm2022/ngx-vflow-testing.mjs +77 -67
  3. package/fesm2022/ngx-vflow-testing.mjs.map +1 -1
  4. package/fesm2022/ngx-vflow.mjs +926 -559
  5. package/fesm2022/ngx-vflow.mjs.map +1 -1
  6. package/lib/vflow/components/custom-node-base/custom-node-base.component.d.ts +1 -1
  7. package/lib/vflow/components/vflow/vflow.component.d.ts +18 -9
  8. package/lib/vflow/directives/auto-pan.directive.d.ts +16 -0
  9. package/lib/vflow/directives/changes-controller.directive.d.ts +13 -87
  10. package/lib/vflow/directives/connection-controller.directive.d.ts +8 -10
  11. package/lib/vflow/directives/space-point-context.directive.d.ts +2 -1
  12. package/lib/vflow/interfaces/component-node-event.interface.d.ts +1 -2
  13. package/lib/vflow/interfaces/connection-events.interface.d.ts +66 -0
  14. package/lib/vflow/interfaces/connection-settings.interface.d.ts +7 -1
  15. package/lib/vflow/interfaces/connection.interface.d.ts +0 -5
  16. package/lib/vflow/interfaces/curve-factory.interface.d.ts +2 -2
  17. package/lib/vflow/interfaces/edge-label.interface.d.ts +0 -4
  18. package/lib/vflow/interfaces/edge.interface.d.ts +36 -8
  19. package/lib/vflow/interfaces/node.interface.d.ts +44 -63
  20. package/lib/vflow/interfaces/selection-strategy.interface.d.ts +16 -0
  21. package/lib/vflow/interfaces/template-context.interface.d.ts +8 -3
  22. package/lib/vflow/models/connection.model.d.ts +1 -1
  23. package/lib/vflow/models/edge.model.d.ts +20 -23
  24. package/lib/vflow/models/handle.model.d.ts +1 -1
  25. package/lib/vflow/models/node.model.d.ts +4 -7
  26. package/lib/vflow/public-components/custom-node/custom-node.component.d.ts +1 -1
  27. package/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.d.ts +2 -1
  28. package/lib/vflow/public-components/minimap/minimap.component.d.ts +1 -1
  29. package/lib/vflow/services/draggable.service.d.ts +3 -0
  30. package/lib/vflow/services/flow-entities.service.d.ts +2 -2
  31. package/lib/vflow/services/flow-settings.service.d.ts +3 -0
  32. package/lib/vflow/services/flow-status.service.d.ts +35 -7
  33. package/lib/vflow/services/selection.service.d.ts +4 -1
  34. package/lib/vflow/strategies/default-selection.strategy.d.ts +6 -0
  35. package/lib/vflow/strategies/manual-selection.strategy.d.ts +5 -0
  36. package/lib/vflow/types/selection-mode.type.d.ts +1 -0
  37. package/lib/vflow/types/unwrap-signal.type.d.ts +4 -0
  38. package/lib/vflow/utils/adjust-direction.d.ts +2 -6
  39. package/lib/vflow/utils/identity-checker/reference-identity-checker.d.ts +2 -2
  40. package/lib/vflow/utils/is-vflow-component.d.ts +0 -2
  41. package/lib/vflow/utils/signals/to-lazy-signal.d.ts +4 -4
  42. package/package.json +3 -7
  43. package/public-api.d.ts +3 -2
  44. package/testing/component-mocks/vflow-mock.component.d.ts +8 -6
  45. package/testing/directive-mocks/connection-controller-mock.directive.d.ts +8 -6
  46. package/esm2022/lib/vflow/components/alignment-helper/alignment-helper.component.mjs +0 -103
  47. package/esm2022/lib/vflow/components/background/background.component.mjs +0 -121
  48. package/esm2022/lib/vflow/components/connection/connection.component.mjs +0 -157
  49. package/esm2022/lib/vflow/components/custom-node-base/custom-node-base.component.mjs +0 -57
  50. package/esm2022/lib/vflow/components/default-node/default-node.component.mjs +0 -16
  51. package/esm2022/lib/vflow/components/defs/defs.component.mjs +0 -16
  52. package/esm2022/lib/vflow/components/edge/edge.component.mjs +0 -54
  53. package/esm2022/lib/vflow/components/edge-label/edge-label.component.mjs +0 -76
  54. package/esm2022/lib/vflow/components/node/node.component.mjs +0 -107
  55. package/esm2022/lib/vflow/components/preview-flow/draw-node.mjs +0 -100
  56. package/esm2022/lib/vflow/components/preview-flow/preview-flow.component.mjs +0 -62
  57. package/esm2022/lib/vflow/components/vflow/vflow.component.mjs +0 -437
  58. package/esm2022/lib/vflow/constants/magic-number-to-fix-glitch-in-chrome.constant.mjs +0 -4
  59. package/esm2022/lib/vflow/decorators/microtask.decorator.mjs +0 -11
  60. package/esm2022/lib/vflow/directives/changes-controller.directive.mjs +0 -165
  61. package/esm2022/lib/vflow/directives/connection-controller.directive.mjs +0 -145
  62. package/esm2022/lib/vflow/directives/drag-handle.directive.mjs +0 -28
  63. package/esm2022/lib/vflow/directives/flow-size-controller.directive.mjs +0 -40
  64. package/esm2022/lib/vflow/directives/handle-size-controller.directive.mjs +0 -41
  65. package/esm2022/lib/vflow/directives/map-context.directive.mjs +0 -116
  66. package/esm2022/lib/vflow/directives/node-handles-controller.directive.mjs +0 -33
  67. package/esm2022/lib/vflow/directives/node-resize-controller.directive.mjs +0 -37
  68. package/esm2022/lib/vflow/directives/pointer.directive.mjs +0 -84
  69. package/esm2022/lib/vflow/directives/reference.directive.mjs +0 -17
  70. package/esm2022/lib/vflow/directives/root-pointer.directive.mjs +0 -58
  71. package/esm2022/lib/vflow/directives/root-svg-context.directive.mjs +0 -35
  72. package/esm2022/lib/vflow/directives/selectable.directive.mjs +0 -48
  73. package/esm2022/lib/vflow/directives/space-point-context.directive.mjs +0 -42
  74. package/esm2022/lib/vflow/directives/template.directive.mjs +0 -119
  75. package/esm2022/lib/vflow/interfaces/alignment-helper-settings.interface.mjs +0 -2
  76. package/esm2022/lib/vflow/interfaces/box.mjs +0 -2
  77. package/esm2022/lib/vflow/interfaces/component-node-event.interface.mjs +0 -2
  78. package/esm2022/lib/vflow/interfaces/connection-settings.interface.mjs +0 -2
  79. package/esm2022/lib/vflow/interfaces/connection.interface.mjs +0 -2
  80. package/esm2022/lib/vflow/interfaces/connection.internal.interface.mjs +0 -2
  81. package/esm2022/lib/vflow/interfaces/contextable.interface.mjs +0 -2
  82. package/esm2022/lib/vflow/interfaces/curve-factory.interface.mjs +0 -2
  83. package/esm2022/lib/vflow/interfaces/edge-label.interface.mjs +0 -2
  84. package/esm2022/lib/vflow/interfaces/edge.interface.mjs +0 -2
  85. package/esm2022/lib/vflow/interfaces/fit-view-options.interface.mjs +0 -2
  86. package/esm2022/lib/vflow/interfaces/flow-entity.interface.mjs +0 -2
  87. package/esm2022/lib/vflow/interfaces/intersecting-nodes-options.interface.mjs +0 -2
  88. package/esm2022/lib/vflow/interfaces/marker.interface.mjs +0 -2
  89. package/esm2022/lib/vflow/interfaces/node-preview.interface.mjs +0 -2
  90. package/esm2022/lib/vflow/interfaces/node.interface.mjs +0 -53
  91. package/esm2022/lib/vflow/interfaces/optimization.interface.mjs +0 -7
  92. package/esm2022/lib/vflow/interfaces/point.interface.mjs +0 -2
  93. package/esm2022/lib/vflow/interfaces/rect.mjs +0 -10
  94. package/esm2022/lib/vflow/interfaces/template-context.interface.mjs +0 -2
  95. package/esm2022/lib/vflow/interfaces/viewport.interface.mjs +0 -2
  96. package/esm2022/lib/vflow/math/edge-path/bezier-path.mjs +0 -66
  97. package/esm2022/lib/vflow/math/edge-path/smooth-step-path.mjs +0 -226
  98. package/esm2022/lib/vflow/math/edge-path/straigh-path.mjs +0 -12
  99. package/esm2022/lib/vflow/math/point-on-line-by-ratio.mjs +0 -12
  100. package/esm2022/lib/vflow/models/connection.model.mjs +0 -31
  101. package/esm2022/lib/vflow/models/edge-label.model.mjs +0 -8
  102. package/esm2022/lib/vflow/models/edge.model.mjs +0 -208
  103. package/esm2022/lib/vflow/models/handle.model.mjs +0 -98
  104. package/esm2022/lib/vflow/models/minimap.model.mjs +0 -7
  105. package/esm2022/lib/vflow/models/node.model.mjs +0 -181
  106. package/esm2022/lib/vflow/models/toolbar.model.mjs +0 -36
  107. package/esm2022/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.mjs +0 -25
  108. package/esm2022/lib/vflow/public-components/custom-node/custom-node.component.mjs +0 -24
  109. package/esm2022/lib/vflow/public-components/custom-template-edge/custom-template-edge.component.mjs +0 -29
  110. package/esm2022/lib/vflow/public-components/handle/handle.component.mjs +0 -53
  111. package/esm2022/lib/vflow/public-components/minimap/minimap.component.mjs +0 -108
  112. package/esm2022/lib/vflow/public-components/node-toolbar/node-toolbar.component.mjs +0 -73
  113. package/esm2022/lib/vflow/public-components/resizable/resizable.component.mjs +0 -272
  114. package/esm2022/lib/vflow/services/component-event-bus.service.mjs +0 -18
  115. package/esm2022/lib/vflow/services/draggable.service.mjs +0 -124
  116. package/esm2022/lib/vflow/services/edge-changes.service.mjs +0 -43
  117. package/esm2022/lib/vflow/services/edge-rendering.service.mjs +0 -40
  118. package/esm2022/lib/vflow/services/flow-entities.service.mjs +0 -56
  119. package/esm2022/lib/vflow/services/flow-rendering.service.mjs +0 -41
  120. package/esm2022/lib/vflow/services/flow-settings.service.mjs +0 -33
  121. package/esm2022/lib/vflow/services/flow-status.service.mjs +0 -49
  122. package/esm2022/lib/vflow/services/handle.service.mjs +0 -30
  123. package/esm2022/lib/vflow/services/keyboard.service.mjs +0 -47
  124. package/esm2022/lib/vflow/services/node-accessor.service.mjs +0 -16
  125. package/esm2022/lib/vflow/services/node-changes.service.mjs +0 -41
  126. package/esm2022/lib/vflow/services/node-rendering.service.mjs +0 -66
  127. package/esm2022/lib/vflow/services/overlays.service.mjs +0 -35
  128. package/esm2022/lib/vflow/services/preview-flow-render-strategy.service.mjs +0 -21
  129. package/esm2022/lib/vflow/services/selection.service.mjs +0 -54
  130. package/esm2022/lib/vflow/services/viewport.service.mjs +0 -64
  131. package/esm2022/lib/vflow/types/background.type.mjs +0 -2
  132. package/esm2022/lib/vflow/types/connection-mode.type.mjs +0 -2
  133. package/esm2022/lib/vflow/types/edge-change.type.mjs +0 -2
  134. package/esm2022/lib/vflow/types/handle-type.type.mjs +0 -2
  135. package/esm2022/lib/vflow/types/keyboard-action.type.mjs +0 -2
  136. package/esm2022/lib/vflow/types/node-change.type.mjs +0 -2
  137. package/esm2022/lib/vflow/types/position.type.mjs +0 -2
  138. package/esm2022/lib/vflow/types/viewport-change-type.type.mjs +0 -2
  139. package/esm2022/lib/vflow/utils/add-nodes-to-edges.mjs +0 -11
  140. package/esm2022/lib/vflow/utils/adjust-direction.mjs +0 -30
  141. package/esm2022/lib/vflow/utils/align-number.mjs +0 -4
  142. package/esm2022/lib/vflow/utils/assert-injector.mjs +0 -27
  143. package/esm2022/lib/vflow/utils/event.mjs +0 -4
  144. package/esm2022/lib/vflow/utils/get-os.mjs +0 -24
  145. package/esm2022/lib/vflow/utils/get-overlapping-area.mjs +0 -6
  146. package/esm2022/lib/vflow/utils/get-space-points.mjs +0 -25
  147. package/esm2022/lib/vflow/utils/hash.mjs +0 -7
  148. package/esm2022/lib/vflow/utils/id.mjs +0 -5
  149. package/esm2022/lib/vflow/utils/identity-checker/reference-identity-checker.mjs +0 -28
  150. package/esm2022/lib/vflow/utils/is-callable.mjs +0 -10
  151. package/esm2022/lib/vflow/utils/is-defined.mjs +0 -4
  152. package/esm2022/lib/vflow/utils/is-group-node.mjs +0 -4
  153. package/esm2022/lib/vflow/utils/is-vflow-component.mjs +0 -9
  154. package/esm2022/lib/vflow/utils/nodes.mjs +0 -60
  155. package/esm2022/lib/vflow/utils/resizable.mjs +0 -11
  156. package/esm2022/lib/vflow/utils/round.mjs +0 -2
  157. package/esm2022/lib/vflow/utils/signals/extended-computed.mjs +0 -15
  158. package/esm2022/lib/vflow/utils/signals/to-lazy-signal.mjs +0 -35
  159. package/esm2022/lib/vflow/utils/to-unified-node.mjs +0 -24
  160. package/esm2022/lib/vflow/utils/transform-background.mjs +0 -4
  161. package/esm2022/lib/vflow/utils/viewport.mjs +0 -51
  162. package/esm2022/lib/vflow/vflow.mjs +0 -29
  163. package/esm2022/ngx-vflow.mjs +0 -5
  164. package/esm2022/public-api.mjs +0 -55
  165. package/esm2022/testing/component-mocks/custom-template-edge-mock.component.mjs +0 -16
  166. package/esm2022/testing/component-mocks/handle-mock.component.mjs +0 -26
  167. package/esm2022/testing/component-mocks/minimap-mock.component.mjs +0 -24
  168. package/esm2022/testing/component-mocks/node-toolbar-mock.component.mjs +0 -23
  169. package/esm2022/testing/component-mocks/resizable-mock.component.mjs +0 -27
  170. package/esm2022/testing/component-mocks/vflow-mock.component.mjs +0 -299
  171. package/esm2022/testing/directive-mocks/connection-controller-mock.directive.mjs +0 -29
  172. package/esm2022/testing/directive-mocks/drag-handle-mock.directive.mjs +0 -11
  173. package/esm2022/testing/directive-mocks/selectable-mock.directive.mjs +0 -14
  174. package/esm2022/testing/directive-mocks/template-mock.directive.mjs +0 -101
  175. package/esm2022/testing/ngx-vflow-testing.mjs +0 -5
  176. package/esm2022/testing/provide-custom-node-mocks.mjs +0 -60
  177. package/esm2022/testing/public-api.mjs +0 -13
  178. package/esm2022/testing/types.mjs +0 -2
  179. package/esm2022/testing/vflow-mocks.mjs +0 -28
  180. package/lib/vflow/public-components/custom-dynamic-node/custom-dynamic-node.component.d.ts +0 -13
  181. package/lib/vflow/utils/to-unified-node.d.ts +0 -2
@@ -1,98 +0,0 @@
1
- import { computed, signal } from '@angular/core';
2
- import { Subject, map } from 'rxjs';
3
- import { toSignal } from '@angular/core/rxjs-interop';
4
- export class HandleModel {
5
- constructor(rawHandle, parentNode) {
6
- this.rawHandle = rawHandle;
7
- this.parentNode = parentNode;
8
- this.strokeWidth = 2;
9
- /**
10
- * Pre-computed size for default handle, changed dynamically
11
- * for custom handles
12
- */
13
- this.size = signal({
14
- width: 10 + 2 * this.strokeWidth,
15
- height: 10 + 2 * this.strokeWidth,
16
- });
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
- // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here
26
- this.hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {
27
- initialValue: { width: 0, height: 0 },
28
- });
29
- // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here
30
- this.hostPosition = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => ({
31
- x: this.hostReference instanceof HTMLElement ? this.hostReference.offsetLeft : 0, // for now just 0 for group nodes
32
- y: this.hostReference instanceof HTMLElement ? this.hostReference.offsetTop : 0, // for now just 0 for group nodes
33
- }))), {
34
- initialValue: { x: 0, y: 0 },
35
- });
36
- this.hostOffset = computed(() => {
37
- switch (this.rawHandle.position) {
38
- case 'left':
39
- return {
40
- x: -this.rawHandle.userOffsetX,
41
- y: -this.rawHandle.userOffsetY + this.hostPosition().y + this.hostSize().height / 2,
42
- };
43
- case 'right':
44
- return {
45
- x: -this.rawHandle.userOffsetX + this.parentNode.size().width,
46
- y: -this.rawHandle.userOffsetY + this.hostPosition().y + this.hostSize().height / 2,
47
- };
48
- case 'top':
49
- return {
50
- x: -this.rawHandle.userOffsetX + this.hostPosition().x + this.hostSize().width / 2,
51
- y: -this.rawHandle.userOffsetY,
52
- };
53
- case 'bottom':
54
- return {
55
- x: -this.rawHandle.userOffsetX + this.hostPosition().x + this.hostSize().width / 2,
56
- y: -this.rawHandle.userOffsetY + this.parentNode.size().height,
57
- };
58
- }
59
- });
60
- this.sizeOffset = computed(() => {
61
- switch (this.rawHandle.position) {
62
- case 'left':
63
- return { x: -(this.size().width / 2), y: 0 };
64
- case 'right':
65
- return { x: this.size().width / 2, y: 0 };
66
- case 'top':
67
- return { x: 0, y: -(this.size().height / 2) };
68
- case 'bottom':
69
- return { x: 0, y: this.size().height / 2 };
70
- }
71
- });
72
- this.hostReference = this.rawHandle.hostReference;
73
- this.template = this.rawHandle.template;
74
- this.templateContext = {
75
- $implicit: {
76
- point: this.hostOffset,
77
- state: this.state,
78
- node: this.parentNode.rawNode,
79
- },
80
- };
81
- }
82
- updateHost() {
83
- this.updateHostSizeAndPosition$.next();
84
- }
85
- getHostSize() {
86
- if (this.hostReference instanceof HTMLElement) {
87
- return {
88
- width: this.hostReference.offsetWidth,
89
- height: this.hostReference.offsetHeight,
90
- };
91
- }
92
- else if (this.hostReference instanceof SVGGraphicsElement) {
93
- return this.hostReference.getBBox();
94
- }
95
- return { width: 0, height: 0 };
96
- }
97
- }
98
- //# 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  // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here\n  private hostSize = toSignal(this.updateHostSizeAndPosition$.pipe(map(() => this.getHostSize())), {\n    initialValue: { width: 0, height: 0 },\n  });\n\n  // TODO: for some reason toLazySignal breaks unit tests, so we use toSignal here\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: -this.rawHandle.userOffsetX,\n          y: -this.rawHandle.userOffsetY + this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'right':\n        return {\n          x: -this.rawHandle.userOffsetX + this.parentNode.size().width,\n          y: -this.rawHandle.userOffsetY + this.hostPosition().y + this.hostSize().height / 2,\n        };\n      case 'top':\n        return {\n          x: -this.rawHandle.userOffsetX + this.hostPosition().x + this.hostSize().width / 2,\n          y: -this.rawHandle.userOffsetY,\n        };\n      case 'bottom':\n        return {\n          x: -this.rawHandle.userOffsetX + this.hostPosition().x + this.hostSize().width / 2,\n          y: -this.rawHandle.userOffsetY + 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.rawNode,\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,7 +0,0 @@
1
- import { signal } from '@angular/core';
2
- export class MinimapModel {
3
- constructor() {
4
- this.template = signal(null);
5
- }
6
- }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluaW1hcC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9tb2RlbHMvbWluaW1hcC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBRXBELE1BQU0sT0FBTyxZQUFZO0lBQXpCO1FBQ1MsYUFBUSxHQUFHLE1BQU0sQ0FBOEIsSUFBSSxDQUFDLENBQUM7SUFDOUQsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2lnbmFsLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgTWluaW1hcE1vZGVsIHtcbiAgcHVibGljIHRlbXBsYXRlID0gc2lnbmFsPFRlbXBsYXRlUmVmPHVua25vd24+IHwgbnVsbD4obnVsbCk7XG59XG4iXX0=
@@ -1,181 +0,0 @@
1
- import { computed, inject, signal } from '@angular/core';
2
- import { isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';
3
- import { toObservable } from '@angular/core/rxjs-interop';
4
- import { FlowEntitiesService } from '../services/flow-entities.service';
5
- import { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';
6
- import { toUnifiedNode } from '../utils/to-unified-node';
7
- import { catchError, filter, of, shareReplay, switchMap } from 'rxjs';
8
- import { FlowSettingsService } from '../services/flow-settings.service';
9
- import { NodeRenderingService } from '../services/node-rendering.service';
10
- import { extendedComputed } from '../utils/signals/extended-computed';
11
- import { isCustomDynamicNodeComponent, isCustomNodeComponent } from '../utils/is-vflow-component';
12
- import { isCallable } from '../utils/is-callable';
13
- export class NodeModel {
14
- static { this.defaultWidth = 100; }
15
- static { this.defaultHeight = 50; }
16
- static { this.defaultColor = '#1b262c'; }
17
- constructor(rawNode) {
18
- this.rawNode = rawNode;
19
- this.entitiesService = inject(FlowEntitiesService);
20
- this.settingsService = inject(FlowSettingsService);
21
- this.nodeRenderingService = inject(NodeRenderingService);
22
- this.isVisible = signal(false);
23
- this.point = signal({ x: 0, y: 0 });
24
- this.width = signal(NodeModel.defaultWidth);
25
- this.height = signal(NodeModel.defaultHeight);
26
- /**
27
- * @deprecated use width or height signals
28
- */
29
- this.size = computed(() => ({ width: this.width(), height: this.height() }));
30
- /**
31
- * If resizer is used, the node size fully depends on the resizer
32
- * Otherwise it calculates the size based on the content
33
- */
34
- this.styleWidth = computed(() => (this.controlledByResizer() ? `${this.width()}px` : '100%'));
35
- this.styleHeight = computed(() => (this.controlledByResizer() ? `${this.height()}px` : '100%'));
36
- this.foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
37
- this.foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);
38
- this.renderOrder = signal(0);
39
- this.selected = signal(false);
40
- this.preview = signal({ style: {} });
41
- this.globalPoint = computed(() => {
42
- let parent = this.parent();
43
- let x = this.point().x;
44
- let y = this.point().y;
45
- while (parent !== null) {
46
- x += parent.point().x;
47
- y += parent.point().y;
48
- parent = parent.parent();
49
- }
50
- return { x, y };
51
- });
52
- this.pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);
53
- this.handles = signal([]);
54
- this.draggable = signal(true);
55
- this.dragHandlesCount = signal(0);
56
- // disabled for configuration for now
57
- this.magnetRadius = 20;
58
- // TODO: not sure if we need to statically store it
59
- this.isComponentType = isComponentStaticNode(this.rawNode) || isComponentDynamicNode(this.rawNode);
60
- this.shouldLoad = extendedComputed((previousShouldLoad) => {
61
- if (previousShouldLoad) {
62
- return true;
63
- }
64
- if (this.settingsService.optimization().lazyLoadTrigger === 'immediate') {
65
- return true;
66
- }
67
- else if (this.settingsService.optimization().lazyLoadTrigger === 'viewport') {
68
- // Immediately load component if it's a plain class
69
- if (isCustomNodeComponent(this.rawNode.type)) {
70
- return true;
71
- }
72
- // Immediately load component if it's a plain class
73
- if (isCustomDynamicNodeComponent(this.rawNode.type)) {
74
- return true;
75
- }
76
- // For cases
77
- // - if it's a factory with dynamic import
78
- // - if it's a template (html, svg, group)
79
- // check if it's in the viewport
80
- if (isCallable(this.rawNode.type) ||
81
- this.rawNode.type === 'html-template' ||
82
- this.rawNode.type === 'svg-template' ||
83
- this.rawNode.type === 'template-group') {
84
- return this.nodeRenderingService.viewportNodes().includes(this);
85
- }
86
- }
87
- // For each other case, we want to load the component immediately
88
- return true;
89
- });
90
- this.componentInstance$ = toObservable(this.shouldLoad).pipe(filter(Boolean),
91
- // @ts-expect-error we assume it's a function with dynamic import
92
- switchMap(() => this.rawNode.type()), catchError(() => of(this.rawNode.type)), shareReplay(1));
93
- // Default node specific thing
94
- this.text = signal('');
95
- // Component node specific thing
96
- this.componentTypeInputs = {
97
- node: this.rawNode,
98
- };
99
- this.parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);
100
- this.children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.id));
101
- this.color = signal(NodeModel.defaultColor);
102
- this.controlledByResizer = signal(false);
103
- this.resizable = signal(false);
104
- this.resizing = signal(false);
105
- this.resizerTemplate = signal(null);
106
- this.context = {
107
- $implicit: {},
108
- };
109
- this.parentId = signal(null);
110
- const internalNode = toUnifiedNode(rawNode);
111
- if (internalNode.point) {
112
- this.point = internalNode.point;
113
- }
114
- if (internalNode.width) {
115
- this.width = internalNode.width;
116
- }
117
- if (internalNode.height) {
118
- this.height = internalNode.height;
119
- }
120
- if (internalNode.draggable) {
121
- this.draggable = internalNode.draggable;
122
- }
123
- if (internalNode.parentId) {
124
- this.parentId = internalNode.parentId;
125
- }
126
- if (internalNode.preview) {
127
- this.preview = internalNode.preview;
128
- }
129
- if (internalNode.type === 'default-group' && internalNode.color) {
130
- this.color = internalNode.color;
131
- }
132
- if (internalNode.type === 'default-group' && internalNode.resizable) {
133
- this.resizable = internalNode.resizable;
134
- }
135
- if (internalNode.type === 'default' && internalNode.text) {
136
- this.text = internalNode.text;
137
- }
138
- if (internalNode.type === 'html-template') {
139
- this.context = {
140
- $implicit: {
141
- node: rawNode,
142
- selected: this.selected.asReadonly(),
143
- shouldLoad: this.shouldLoad,
144
- },
145
- };
146
- }
147
- if (internalNode.type === 'svg-template') {
148
- this.context = {
149
- $implicit: {
150
- node: rawNode,
151
- selected: this.selected.asReadonly(),
152
- width: this.width.asReadonly(),
153
- height: this.height.asReadonly(),
154
- shouldLoad: this.shouldLoad,
155
- },
156
- };
157
- }
158
- if (internalNode.type === 'template-group') {
159
- this.context = {
160
- $implicit: {
161
- node: rawNode,
162
- selected: this.selected.asReadonly(),
163
- width: this.width.asReadonly(),
164
- height: this.height.asReadonly(),
165
- shouldLoad: this.shouldLoad,
166
- },
167
- };
168
- }
169
- // Initialize Observables after all signal assignments
170
- this.point$ = toObservable(this.point);
171
- this.width$ = toObservable(this.width);
172
- this.height$ = toObservable(this.height);
173
- this.size$ = toObservable(this.size);
174
- this.selected$ = toObservable(this.selected);
175
- this.handles$ = toObservable(this.handles);
176
- }
177
- setPoint(point) {
178
- this.point.set(point);
179
- }
180
- }
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.model.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vflow-lib/src/lib/vflow/models/node.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TemplateRef, computed, inject, signal } from '@angular/core';\nimport { DynamicNode, Node, isComponentDynamicNode, isComponentStaticNode } from '../interfaces/node.interface';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { HandleModel } from './handle.model';\nimport { FlowEntity } from '../interfaces/flow-entity.interface';\nimport { Point } from '../interfaces/point.interface';\nimport { FlowEntitiesService } from '../services/flow-entities.service';\nimport { MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME } from '../constants/magic-number-to-fix-glitch-in-chrome.constant';\nimport { Contextable } from '../interfaces/contextable.interface';\nimport { GroupNodeContext, NodeContext } from '../interfaces/template-context.interface';\nimport { toUnifiedNode } from '../utils/to-unified-node';\nimport { catchError, filter, Observable, of, shareReplay, switchMap } from 'rxjs';\nimport { NodePreview } from '../interfaces/node-preview.interface';\nimport { FlowSettingsService } from '../services/flow-settings.service';\nimport { NodeRenderingService } from '../services/node-rendering.service';\nimport { extendedComputed } from '../utils/signals/extended-computed';\nimport { isCustomDynamicNodeComponent, isCustomNodeComponent } from '../utils/is-vflow-component';\nimport { isCallable } from '../utils/is-callable';\n\nexport class NodeModel<T = unknown>\n  implements FlowEntity, Contextable<NodeContext | GroupNodeContext | { $implicit: object }>\n{\n  private static defaultWidth = 100;\n  private static defaultHeight = 50;\n  private static defaultColor = '#1b262c';\n\n  private entitiesService = inject(FlowEntitiesService);\n  private settingsService = inject(FlowSettingsService);\n  private nodeRenderingService = inject(NodeRenderingService);\n\n  public isVisible = signal(false);\n\n  public point = signal<Point>({ x: 0, y: 0 });\n  public point$: Observable<Point>;\n\n  public width = signal(NodeModel.defaultWidth);\n  public width$: Observable<number>;\n\n  public height = signal(NodeModel.defaultHeight);\n  public height$: Observable<number>;\n\n  /**\n   * @deprecated use width or height signals\n   */\n  public size = computed(() => ({ width: this.width(), height: this.height() }));\n  /**\n   * @deprecated use width$ or height$\n   */\n  public size$: Observable<{ width: number; height: number }>;\n\n  /**\n   * If resizer is used, the node size fully depends on the resizer\n   * Otherwise it calculates the size based on the content\n   */\n  public styleWidth = computed(() => (this.controlledByResizer() ? `${this.width()}px` : '100%'));\n  public styleHeight = computed(() => (this.controlledByResizer() ? `${this.height()}px` : '100%'));\n\n  public foWidth = computed(() => this.width() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n  public foHeight = computed(() => this.height() + MAGIC_NUMBER_TO_FIX_GLITCH_IN_CHROME);\n\n  public renderOrder = signal(0);\n\n  public selected = signal(false);\n  public selected$: Observable<boolean>;\n\n  public preview = signal<NodePreview>({ style: {} });\n\n  public globalPoint = computed(() => {\n    let parent = this.parent();\n    let x = this.point().x;\n    let y = this.point().y;\n\n    while (parent !== null) {\n      x += parent.point().x;\n      y += parent.point().y;\n\n      parent = parent.parent();\n    }\n\n    return { x, y };\n  });\n\n  public pointTransform = computed(() => `translate(${this.globalPoint().x}, ${this.globalPoint().y})`);\n\n  public handles = signal<HandleModel[]>([]);\n  public handles$: Observable<HandleModel[]>;\n\n  public draggable = signal(true);\n\n  public dragHandlesCount = signal(0);\n\n  // disabled for configuration for now\n  public readonly magnetRadius = 20;\n\n  // TODO: not sure if we need to statically store it\n  public isComponentType =\n    isComponentStaticNode(this.rawNode as Node) || isComponentDynamicNode(this.rawNode as DynamicNode);\n\n  public shouldLoad = extendedComputed<boolean>((previousShouldLoad) => {\n    if (previousShouldLoad) {\n      return true;\n    }\n\n    if (this.settingsService.optimization().lazyLoadTrigger === 'immediate') {\n      return true;\n    } else if (this.settingsService.optimization().lazyLoadTrigger === 'viewport') {\n      // Immediately load component if it's a plain class\n      if (isCustomNodeComponent(this.rawNode.type)) {\n        return true;\n      }\n\n      // Immediately load component if it's a plain class\n      if (isCustomDynamicNodeComponent(this.rawNode.type)) {\n        return true;\n      }\n\n      // For cases\n      // - if it's a factory with dynamic import\n      // - if it's a template (html, svg, group)\n      // check if it's in the viewport\n      if (\n        isCallable(this.rawNode.type) ||\n        this.rawNode.type === 'html-template' ||\n        this.rawNode.type === 'svg-template' ||\n        this.rawNode.type === 'template-group'\n      ) {\n        return this.nodeRenderingService.viewportNodes().includes(this as NodeModel);\n      }\n    }\n\n    // For each other case, we want to load the component immediately\n    return true;\n  });\n\n  public componentInstance$ = toObservable(this.shouldLoad).pipe(\n    filter(Boolean),\n    // @ts-expect-error we assume it's a function with dynamic import\n    switchMap(() => this.rawNode.type()),\n    catchError(() => of(this.rawNode.type)),\n    shareReplay(1),\n  );\n\n  // Default node specific thing\n  public text = signal('');\n\n  // Component node specific thing\n  public componentTypeInputs = {\n    node: this.rawNode,\n  };\n\n  public parent = computed(() => this.entitiesService.nodes().find((n) => n.rawNode.id === this.parentId()) ?? null);\n\n  public children = computed(() => this.entitiesService.nodes().filter((n) => n.parentId() === this.rawNode.id));\n\n  public color = signal(NodeModel.defaultColor);\n\n  public controlledByResizer = signal(false);\n  public resizable = signal(false);\n  public resizing = signal(false);\n  public resizerTemplate = signal<TemplateRef<unknown> | null>(null);\n\n  public context = {\n    $implicit: {},\n  };\n\n  private parentId = signal<string | null>(null);\n\n  constructor(public rawNode: Node<T> | DynamicNode<T>) {\n    const internalNode = toUnifiedNode(rawNode);\n\n    if (internalNode.point) {\n      this.point = internalNode.point;\n    }\n\n    if (internalNode.width) {\n      this.width = internalNode.width;\n    }\n\n    if (internalNode.height) {\n      this.height = internalNode.height;\n    }\n\n    if (internalNode.draggable) {\n      this.draggable = internalNode.draggable;\n    }\n\n    if (internalNode.parentId) {\n      this.parentId = internalNode.parentId;\n    }\n\n    if (internalNode.preview) {\n      this.preview = internalNode.preview;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.color) {\n      this.color = internalNode.color;\n    }\n\n    if (internalNode.type === 'default-group' && internalNode.resizable) {\n      this.resizable = internalNode.resizable;\n    }\n\n    if (internalNode.type === 'default' && internalNode.text) {\n      this.text = internalNode.text;\n    }\n\n    if (internalNode.type === 'html-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          shouldLoad: this.shouldLoad,\n        },\n      };\n    }\n\n    if (internalNode.type === 'svg-template') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width.asReadonly(),\n          height: this.height.asReadonly(),\n          shouldLoad: this.shouldLoad,\n        },\n      };\n    }\n\n    if (internalNode.type === 'template-group') {\n      this.context = {\n        $implicit: {\n          node: rawNode,\n          selected: this.selected.asReadonly(),\n          width: this.width.asReadonly(),\n          height: this.height.asReadonly(),\n          shouldLoad: this.shouldLoad,\n        },\n      };\n    }\n\n    // Initialize Observables after all signal assignments\n    this.point$ = toObservable(this.point);\n    this.width$ = toObservable(this.width);\n    this.height$ = toObservable(this.height);\n    this.size$ = toObservable(this.size);\n    this.selected$ = toObservable(this.selected);\n    this.handles$ = toObservable(this.handles);\n  }\n\n  public setPoint(point: Point) {\n    this.point.set(point);\n  }\n}\n"]}
@@ -1,36 +0,0 @@
1
- import { computed, signal } from '@angular/core';
2
- export class ToolbarModel {
3
- constructor(node) {
4
- this.node = node;
5
- this.position = signal('top');
6
- this.template = signal(null);
7
- this.offset = signal(10);
8
- this.point = computed(() => {
9
- switch (this.position()) {
10
- case 'top':
11
- return {
12
- x: this.node.size().width / 2 - this.size().width / 2,
13
- y: -this.size().height - this.offset(),
14
- };
15
- case 'bottom':
16
- return {
17
- x: this.node.size().width / 2 - this.size().width / 2,
18
- y: this.node.size().height + this.offset(),
19
- };
20
- case 'left':
21
- return {
22
- x: -this.size().width - this.offset(),
23
- y: this.node.size().height / 2 - this.size().height / 2,
24
- };
25
- case 'right':
26
- return {
27
- x: this.node.size().width + this.offset(),
28
- y: this.node.size().height / 2 - this.size().height / 2,
29
- };
30
- }
31
- });
32
- this.transform = computed(() => `translate(${this.point().x}, ${this.point().y})`);
33
- this.size = signal({ width: 0, height: 0 });
34
- }
35
- }
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9tb2RlbHMvdG9vbGJhci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUk5RCxNQUFNLE9BQU8sWUFBWTtJQW1DdkIsWUFBbUIsSUFBZTtRQUFmLFNBQUksR0FBSixJQUFJLENBQVc7UUFsQzNCLGFBQVEsR0FBRyxNQUFNLENBQVcsS0FBSyxDQUFDLENBQUM7UUFDbkMsYUFBUSxHQUFHLE1BQU0sQ0FBOEIsSUFBSSxDQUFDLENBQUM7UUFFckQsV0FBTSxHQUFHLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUVwQixVQUFLLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMzQixRQUFRLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO2dCQUN4QixLQUFLLEtBQUs7b0JBQ1IsT0FBTzt3QkFDTCxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxLQUFLLEdBQUcsQ0FBQzt3QkFDckQsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFO3FCQUN2QyxDQUFDO2dCQUNKLEtBQUssUUFBUTtvQkFDWCxPQUFPO3dCQUNMLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxDQUFDO3dCQUNyRCxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRTtxQkFDM0MsQ0FBQztnQkFDSixLQUFLLE1BQU07b0JBQ1QsT0FBTzt3QkFDTCxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUU7d0JBQ3JDLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE1BQU0sR0FBRyxDQUFDO3FCQUN4RCxDQUFDO2dCQUNKLEtBQUssT0FBTztvQkFDVixPQUFPO3dCQUNMLENBQUMsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFO3dCQUN6QyxDQUFDLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQztxQkFDeEQsQ0FBQztZQUNOLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVJLGNBQVMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsYUFBYSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRTlFLFNBQUksR0FBRyxNQUFNLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBRVQsQ0FBQztDQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbXB1dGVkLCBzaWduYWwsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQb3NpdGlvbiB9IGZyb20gJy4uL3R5cGVzL3Bvc2l0aW9uLnR5cGUnO1xuaW1wb3J0IHsgTm9kZU1vZGVsIH0gZnJvbSAnLi9ub2RlLm1vZGVsJztcblxuZXhwb3J0IGNsYXNzIFRvb2xiYXJNb2RlbCB7XG4gIHB1YmxpYyBwb3NpdGlvbiA9IHNpZ25hbDxQb3NpdGlvbj4oJ3RvcCcpO1xuICBwdWJsaWMgdGVtcGxhdGUgPSBzaWduYWw8VGVtcGxhdGVSZWY8dW5rbm93bj4gfCBudWxsPihudWxsKTtcblxuICBwdWJsaWMgb2Zmc2V0ID0gc2lnbmFsKDEwKTtcblxuICBwdWJsaWMgcG9pbnQgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgc3dpdGNoICh0aGlzLnBvc2l0aW9uKCkpIHtcbiAgICAgIGNhc2UgJ3RvcCc6XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgeDogdGhpcy5ub2RlLnNpemUoKS53aWR0aCAvIDIgLSB0aGlzLnNpemUoKS53aWR0aCAvIDIsXG4gICAgICAgICAgeTogLXRoaXMuc2l6ZSgpLmhlaWdodCAtIHRoaXMub2Zmc2V0KCksXG4gICAgICAgIH07XG4gICAgICBjYXNlICdib3R0b20nOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHg6IHRoaXMubm9kZS5zaXplKCkud2lkdGggLyAyIC0gdGhpcy5zaXplKCkud2lkdGggLyAyLFxuICAgICAgICAgIHk6IHRoaXMubm9kZS5zaXplKCkuaGVpZ2h0ICsgdGhpcy5vZmZzZXQoKSxcbiAgICAgICAgfTtcbiAgICAgIGNhc2UgJ2xlZnQnOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHg6IC10aGlzLnNpemUoKS53aWR0aCAtIHRoaXMub2Zmc2V0KCksXG4gICAgICAgICAgeTogdGhpcy5ub2RlLnNpemUoKS5oZWlnaHQgLyAyIC0gdGhpcy5zaXplKCkuaGVpZ2h0IC8gMixcbiAgICAgICAgfTtcbiAgICAgIGNhc2UgJ3JpZ2h0JzpcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICB4OiB0aGlzLm5vZGUuc2l6ZSgpLndpZHRoICsgdGhpcy5vZmZzZXQoKSxcbiAgICAgICAgICB5OiB0aGlzLm5vZGUuc2l6ZSgpLmhlaWdodCAvIDIgLSB0aGlzLnNpemUoKS5oZWlnaHQgLyAyLFxuICAgICAgICB9O1xuICAgIH1cbiAgfSk7XG5cbiAgcHVibGljIHRyYW5zZm9ybSA9IGNvbXB1dGVkKCgpID0+IGB0cmFuc2xhdGUoJHt0aGlzLnBvaW50KCkueH0sICR7dGhpcy5wb2ludCgpLnl9KWApO1xuXG4gIHB1YmxpYyBzaXplID0gc2lnbmFsKHsgd2lkdGg6IDAsIGhlaWdodDogMCB9KTtcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgbm9kZTogTm9kZU1vZGVsKSB7fVxufVxuIl19
@@ -1,25 +0,0 @@
1
- import { Directive, input } from '@angular/core';
2
- import { CustomNodeBaseComponent } from '../../components/custom-node-base/custom-node-base.component';
3
- import * as i0 from "@angular/core";
4
- export class CustomDynamicNodeComponent extends CustomNodeBaseComponent {
5
- constructor() {
6
- super(...arguments);
7
- /**
8
- * Reference to node bound to this component
9
- */
10
- this.node = input.required();
11
- }
12
- ngOnInit() {
13
- const data = this.node().data;
14
- if (data) {
15
- this.data = data;
16
- }
17
- super.ngOnInit();
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomDynamicNodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
20
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: CustomDynamicNodeComponent, inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
21
- }
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomDynamicNodeComponent, decorators: [{
23
- type: Directive
24
- }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWR5bmFtaWMtbm9kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmZsb3ctbGliL3NyYy9saWIvdmZsb3cvcHVibGljLWNvbXBvbmVudHMvY3VzdG9tLWR5bmFtaWMtbm9kZS9jdXN0b20tZHluYW1pYy1ub2RlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7QUFHdkcsTUFBTSxPQUFnQiwwQkFBb0MsU0FBUSx1QkFBMEI7SUFENUY7O1FBRUU7O1dBRUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBMkIsQ0FBQztLQVd6RDtJQVRpQixRQUFRO1FBQ3RCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUM7UUFFOUIsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ25CLENBQUM7UUFFRCxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkIsQ0FBQzsrR0FkbUIsMEJBQTBCO21HQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBRC9DLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudER5bmFtaWNOb2RlIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9ub2RlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvY3VzdG9tLW5vZGUtYmFzZS9jdXN0b20tbm9kZS1iYXNlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbUR5bmFtaWNOb2RlQ29tcG9uZW50PFQgPSBhbnk+IGV4dGVuZHMgQ3VzdG9tTm9kZUJhc2VDb21wb25lbnQ8VD4gaW1wbGVtZW50cyBPbkluaXQge1xuICAvKipcbiAgICogUmVmZXJlbmNlIHRvIG5vZGUgYm91bmQgdG8gdGhpcyBjb21wb25lbnRcbiAgICovXG4gIHB1YmxpYyBub2RlID0gaW5wdXQucmVxdWlyZWQ8Q29tcG9uZW50RHluYW1pY05vZGU8VD4+KCk7XG5cbiAgcHVibGljIG92ZXJyaWRlIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGRhdGEgPSB0aGlzLm5vZGUoKS5kYXRhO1xuXG4gICAgaWYgKGRhdGEpIHtcbiAgICAgIHRoaXMuZGF0YSA9IGRhdGE7XG4gICAgfVxuXG4gICAgc3VwZXIubmdPbkluaXQoKTtcbiAgfVxufVxuIl19
@@ -1,24 +0,0 @@
1
- import { Directive, input } from '@angular/core';
2
- import { CustomNodeBaseComponent } from '../../components/custom-node-base/custom-node-base.component';
3
- import * as i0 from "@angular/core";
4
- export class CustomNodeComponent extends CustomNodeBaseComponent {
5
- constructor() {
6
- super(...arguments);
7
- /**
8
- * Reference to node bound to this component
9
- */
10
- this.node = input.required();
11
- }
12
- ngOnInit() {
13
- if (this.node().data) {
14
- this.data.set(this.node().data);
15
- }
16
- super.ngOnInit();
17
- }
18
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomNodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
19
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: CustomNodeComponent, inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null } }, usesInheritance: true, ngImport: i0 }); }
20
- }
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomNodeComponent, decorators: [{
22
- type: Directive
23
- }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW5vZGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL2N1c3RvbS1ub2RlL2N1c3RvbS1ub2RlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7QUFHdkcsTUFBTSxPQUFnQixtQkFBNkIsU0FBUSx1QkFBMEI7SUFEckY7O1FBRUU7O1dBRUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBb0IsQ0FBQztLQVNsRDtJQVBpQixRQUFRO1FBQ3RCLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsQyxDQUFDO1FBRUQsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ25CLENBQUM7K0dBWm1CLG1CQUFtQjttR0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUR4QyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnROb2RlIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9ub2RlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvY3VzdG9tLW5vZGUtYmFzZS9jdXN0b20tbm9kZS1iYXNlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEN1c3RvbU5vZGVDb21wb25lbnQ8VCA9IGFueT4gZXh0ZW5kcyBDdXN0b21Ob2RlQmFzZUNvbXBvbmVudDxUPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIC8qKlxuICAgKiBSZWZlcmVuY2UgdG8gbm9kZSBib3VuZCB0byB0aGlzIGNvbXBvbmVudFxuICAgKi9cbiAgcHVibGljIG5vZGUgPSBpbnB1dC5yZXF1aXJlZDxDb21wb25lbnROb2RlPFQ+PigpO1xuXG4gIHB1YmxpYyBvdmVycmlkZSBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5ub2RlKCkuZGF0YSkge1xuICAgICAgdGhpcy5kYXRhLnNldCh0aGlzLm5vZGUoKS5kYXRhKTtcbiAgICB9XG5cbiAgICBzdXBlci5uZ09uSW5pdCgpO1xuICB9XG59XG4iXX0=
@@ -1,29 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
2
- import { EdgeComponent } from '../../components/edge/edge.component';
3
- import { FlowSettingsService } from '../../services/flow-settings.service';
4
- import { EdgeRenderingService } from '../../services/edge-rendering.service';
5
- import * as i0 from "@angular/core";
6
- export class CustomTemplateEdgeComponent {
7
- constructor() {
8
- this.edge = inject(EdgeComponent);
9
- this.flowSettingsService = inject(FlowSettingsService);
10
- this.edgeRenderingService = inject(EdgeRenderingService);
11
- this.model = this.edge.model();
12
- this.context = this.model.context.$implicit;
13
- }
14
- pull() {
15
- if (this.flowSettingsService.elevateEdgesOnSelect()) {
16
- this.edgeRenderingService.pull(this.model);
17
- }
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomTemplateEdgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CustomTemplateEdgeComponent, isStandalone: true, selector: "g[customTemplateEdge]", host: { listeners: { "mousedown": "pull()", "touchstart": "pull()" } }, ngImport: i0, template: "<ng-content />\n\n<svg:path #interactiveEdge class=\"interactive-edge\" [attr.d]=\"context.path()\" />\n", styles: [".interactive-edge{fill:none;stroke-width:20;stroke:transparent}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
21
- }
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomTemplateEdgeComponent, decorators: [{
23
- type: Component,
24
- args: [{ selector: 'g[customTemplateEdge]', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, host: {
25
- '(mousedown)': 'pull()',
26
- '(touchstart)': 'pull()',
27
- }, template: "<ng-content />\n\n<svg:path #interactiveEdge class=\"interactive-edge\" [attr.d]=\"context.path()\" />\n", styles: [".interactive-edge{fill:none;stroke-width:20;stroke:transparent}\n"] }]
28
- }] });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXRlbXBsYXRlLWVkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZmbG93LWxpYi9zcmMvbGliL3ZmbG93L3B1YmxpYy1jb21wb25lbnRzL2N1c3RvbS10ZW1wbGF0ZS1lZGdlL2N1c3RvbS10ZW1wbGF0ZS1lZGdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9jdXN0b20tdGVtcGxhdGUtZWRnZS9jdXN0b20tdGVtcGxhdGUtZWRnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDckUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBYTdFLE1BQU0sT0FBTywyQkFBMkI7SUFYeEM7UUFZVSxTQUFJLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzdCLHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2xELHlCQUFvQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRWxELFVBQUssR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzFCLFlBQU8sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUM7S0FPbEQ7SUFMVyxJQUFJO1FBQ1osSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsb0JBQW9CLEVBQUUsRUFBRSxDQUFDO1lBQ3BELElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzdDLENBQUM7SUFDSCxDQUFDOytHQVpVLDJCQUEyQjttR0FBM0IsMkJBQTJCLHlKQ2hCeEMsMEdBR0E7OzRGRGFhLDJCQUEyQjtrQkFYdkMsU0FBUzsrQkFDRSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxRQUNWO3dCQUNKLGFBQWEsRUFBRSxRQUFRO3dCQUN2QixjQUFjLEVBQUUsUUFBUTtxQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEVkZ2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL2VkZ2UvZWRnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmxvd1NldHRpbmdzU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2Zsb3ctc2V0dGluZ3Muc2VydmljZSc7XG5pbXBvcnQgeyBFZGdlUmVuZGVyaW5nU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2VkZ2UtcmVuZGVyaW5nLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnW2N1c3RvbVRlbXBsYXRlRWRnZV0nLFxuICB0ZW1wbGF0ZVVybDogJy4vY3VzdG9tLXRlbXBsYXRlLWVkZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jdXN0b20tdGVtcGxhdGUtZWRnZS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaG9zdDoge1xuICAgICcobW91c2Vkb3duKSc6ICdwdWxsKCknLFxuICAgICcodG91Y2hzdGFydCknOiAncHVsbCgpJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tVGVtcGxhdGVFZGdlQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBlZGdlID0gaW5qZWN0KEVkZ2VDb21wb25lbnQpO1xuICBwcml2YXRlIGZsb3dTZXR0aW5nc1NlcnZpY2UgPSBpbmplY3QoRmxvd1NldHRpbmdzU2VydmljZSk7XG4gIHByaXZhdGUgZWRnZVJlbmRlcmluZ1NlcnZpY2UgPSBpbmplY3QoRWRnZVJlbmRlcmluZ1NlcnZpY2UpO1xuXG4gIHByb3RlY3RlZCBtb2RlbCA9IHRoaXMuZWRnZS5tb2RlbCgpO1xuICBwcm90ZWN0ZWQgY29udGV4dCA9IHRoaXMubW9kZWwuY29udGV4dC4kaW1wbGljaXQ7XG5cbiAgcHJvdGVjdGVkIHB1bGwoKSB7XG4gICAgaWYgKHRoaXMuZmxvd1NldHRpbmdzU2VydmljZS5lbGV2YXRlRWRnZXNPblNlbGVjdCgpKSB7XG4gICAgICB0aGlzLmVkZ2VSZW5kZXJpbmdTZXJ2aWNlLnB1bGwodGhpcy5tb2RlbCk7XG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGVudCAvPlxuXG48c3ZnOnBhdGggI2ludGVyYWN0aXZlRWRnZSBjbGFzcz1cImludGVyYWN0aXZlLWVkZ2VcIiBbYXR0ci5kXT1cImNvbnRleHQucGF0aCgpXCIgLz5cbiJdfQ==
@@ -1,53 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, Injector, inject, input, runInInjectionContext, } from '@angular/core';
2
- import { HandleService } from '../../services/handle.service';
3
- import { HandleModel } from '../../models/handle.model';
4
- import * as i0 from "@angular/core";
5
- export class HandleComponent {
6
- constructor() {
7
- this.injector = inject(Injector);
8
- this.handleService = inject(HandleService);
9
- this.element = inject(ElementRef).nativeElement;
10
- this.destroyRef = inject(DestroyRef);
11
- /**
12
- * At what side of node this component should be placed
13
- */
14
- this.position = input.required();
15
- /**
16
- * Source or target
17
- */
18
- this.type = input.required();
19
- /**
20
- * Should be used if node has more than one source/target
21
- */
22
- this.id = input();
23
- this.template = input();
24
- this.offsetX = input(0);
25
- this.offsetY = input(0);
26
- }
27
- ngOnInit() {
28
- runInInjectionContext(this.injector, () => {
29
- const node = this.handleService.node();
30
- if (node) {
31
- const model = new HandleModel({
32
- position: this.position(),
33
- type: this.type(),
34
- id: this.id(),
35
- hostReference: this.element.parentElement,
36
- template: this.template(),
37
- userOffsetX: this.offsetX(),
38
- userOffsetY: this.offsetY(),
39
- }, node);
40
- this.handleService.createHandle(model);
41
- requestAnimationFrame(() => model.updateHost());
42
- this.destroyRef.onDestroy(() => this.handleService.destroyHandle(model));
43
- }
44
- });
45
- }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: HandleComponent, isStandalone: true, selector: "handle", inputs: { position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: true, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: true, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, template: { classPropertyName: "template", publicName: "template", isSignal: true, isRequired: false, transformFunction: null }, offsetX: { classPropertyName: "offsetX", publicName: "offsetX", isSignal: true, isRequired: false, transformFunction: null }, offsetY: { classPropertyName: "offsetY", publicName: "offsetY", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
48
- }
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HandleComponent, decorators: [{
50
- type: Component,
51
- args: [{ standalone: true, selector: 'handle', changeDetection: ChangeDetectionStrategy.OnPush, template: "" }]
52
- }] });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFuZGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12Zmxvdy1saWIvc3JjL2xpYi92Zmxvdy9wdWJsaWMtY29tcG9uZW50cy9oYW5kbGUvaGFuZGxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixVQUFVLEVBQ1YsUUFBUSxFQUdSLE1BQU0sRUFDTixLQUFLLEVBQ0wscUJBQXFCLEdBQ3RCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBUXhELE1BQU0sT0FBTyxlQUFlO0lBTjVCO1FBT1UsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM1QixrQkFBYSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN0QyxZQUFPLEdBQUcsTUFBTSxDQUEwQixVQUFVLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDcEUsZUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUV4Qzs7V0FFRztRQUNJLGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFZLENBQUM7UUFFN0M7O1dBRUc7UUFDSSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBdUIsQ0FBQztRQUVwRDs7V0FFRztRQUNJLE9BQUUsR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUVyQixhQUFRLEdBQUcsS0FBSyxFQUEyQixDQUFDO1FBRTVDLFlBQU8sR0FBRyxLQUFLLENBQVMsQ0FBQyxDQUFDLENBQUM7UUFDM0IsWUFBTyxHQUFHLEtBQUssQ0FBUyxDQUFDLENBQUMsQ0FBQztLQTRCbkM7SUExQlEsUUFBUTtRQUNiLHFCQUFxQixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsR0FBRyxFQUFFO1lBQ3hDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7WUFFdkMsSUFBSSxJQUFJLEVBQUUsQ0FBQztnQkFDVCxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQVcsQ0FDM0I7b0JBQ0UsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7b0JBQ3pCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFO29CQUNqQixFQUFFLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRTtvQkFDYixhQUFhLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFjO29CQUMxQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRTtvQkFDekIsV0FBVyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUU7b0JBQzNCLFdBQVcsRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO2lCQUM1QixFQUNELElBQUksQ0FDTCxDQUFDO2dCQUVGLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUV2QyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztnQkFFaEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUMzRSxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOytHQW5EVSxlQUFlO21HQUFmLGVBQWUsOHlCQ3RCNUIsRUFBQTs7NEZEc0JhLGVBQWU7a0JBTjNCLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLFFBQVEsbUJBRUQsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIERlc3Ryb3lSZWYsXG4gIEVsZW1lbnRSZWYsXG4gIEluamVjdG9yLFxuICBPbkluaXQsXG4gIFRlbXBsYXRlUmVmLFxuICBpbmplY3QsXG4gIGlucHV0LFxuICBydW5JbkluamVjdGlvbkNvbnRleHQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUG9zaXRpb24gfSBmcm9tICcuLi8uLi90eXBlcy9wb3NpdGlvbi50eXBlJztcbmltcG9ydCB7IEhhbmRsZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9oYW5kbGUuc2VydmljZSc7XG5pbXBvcnQgeyBIYW5kbGVNb2RlbCB9IGZyb20gJy4uLy4uL21vZGVscy9oYW5kbGUubW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdoYW5kbGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vaGFuZGxlLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIEhhbmRsZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHByaXZhdGUgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuICBwcml2YXRlIGhhbmRsZVNlcnZpY2UgPSBpbmplY3QoSGFuZGxlU2VydmljZSk7XG4gIHByaXZhdGUgZWxlbWVudCA9IGluamVjdDxFbGVtZW50UmVmPEhUTUxFbGVtZW50Pj4oRWxlbWVudFJlZikubmF0aXZlRWxlbWVudDtcbiAgcHJpdmF0ZSBkZXN0cm95UmVmID0gaW5qZWN0KERlc3Ryb3lSZWYpO1xuXG4gIC8qKlxuICAgKiBBdCB3aGF0IHNpZGUgb2Ygbm9kZSB0aGlzIGNvbXBvbmVudCBzaG91bGQgYmUgcGxhY2VkXG4gICAqL1xuICBwdWJsaWMgcG9zaXRpb24gPSBpbnB1dC5yZXF1aXJlZDxQb3NpdGlvbj4oKTtcblxuICAvKipcbiAgICogU291cmNlIG9yIHRhcmdldFxuICAgKi9cbiAgcHVibGljIHR5cGUgPSBpbnB1dC5yZXF1aXJlZDwnc291cmNlJyB8ICd0YXJnZXQnPigpO1xuXG4gIC8qKlxuICAgKiBTaG91bGQgYmUgdXNlZCBpZiBub2RlIGhhcyBtb3JlIHRoYW4gb25lIHNvdXJjZS90YXJnZXRcbiAgICovXG4gIHB1YmxpYyBpZCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBwdWJsaWMgdGVtcGxhdGUgPSBpbnB1dDxUZW1wbGF0ZVJlZjxhbnk+IHwgbnVsbD4oKTtcblxuICBwdWJsaWMgb2Zmc2V0WCA9IGlucHV0PG51bWJlcj4oMCk7XG4gIHB1YmxpYyBvZmZzZXRZID0gaW5wdXQ8bnVtYmVyPigwKTtcblxuICBwdWJsaWMgbmdPbkluaXQoKSB7XG4gICAgcnVuSW5JbmplY3Rpb25Db250ZXh0KHRoaXMuaW5qZWN0b3IsICgpID0+IHtcbiAgICAgIGNvbnN0IG5vZGUgPSB0aGlzLmhhbmRsZVNlcnZpY2Uubm9kZSgpO1xuXG4gICAgICBpZiAobm9kZSkge1xuICAgICAgICBjb25zdCBtb2RlbCA9IG5ldyBIYW5kbGVNb2RlbChcbiAgICAgICAgICB7XG4gICAgICAgICAgICBwb3NpdGlvbjogdGhpcy5wb3NpdGlvbigpLFxuICAgICAgICAgICAgdHlwZTogdGhpcy50eXBlKCksXG4gICAgICAgICAgICBpZDogdGhpcy5pZCgpLFxuICAgICAgICAgICAgaG9zdFJlZmVyZW5jZTogdGhpcy5lbGVtZW50LnBhcmVudEVsZW1lbnQhLFxuICAgICAgICAgICAgdGVtcGxhdGU6IHRoaXMudGVtcGxhdGUoKSxcbiAgICAgICAgICAgIHVzZXJPZmZzZXRYOiB0aGlzLm9mZnNldFgoKSxcbiAgICAgICAgICAgIHVzZXJPZmZzZXRZOiB0aGlzLm9mZnNldFkoKSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIG5vZGUsXG4gICAgICAgICk7XG5cbiAgICAgICAgdGhpcy5oYW5kbGVTZXJ2aWNlLmNyZWF0ZUhhbmRsZShtb2RlbCk7XG5cbiAgICAgICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IG1vZGVsLnVwZGF0ZUhvc3QoKSk7XG5cbiAgICAgICAgdGhpcy5kZXN0cm95UmVmLm9uRGVzdHJveSgoKSA9PiB0aGlzLmhhbmRsZVNlcnZpY2UuZGVzdHJveUhhbmRsZShtb2RlbCkpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG59XG4iLCIiXX0=