@uipath/apollo-react 4.12.0 → 4.12.1-pr556.9394355

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 (118) hide show
  1. package/dist/canvas/components/AddNodePanel/AddNodeManager.cjs +26 -7
  2. package/dist/canvas/components/AddNodePanel/AddNodeManager.d.ts.map +1 -1
  3. package/dist/canvas/components/AddNodePanel/AddNodeManager.js +26 -7
  4. package/dist/canvas/components/AddNodePanel/createAddNodePreview.cjs +2 -2
  5. package/dist/canvas/components/AddNodePanel/createAddNodePreview.d.ts +8 -1
  6. package/dist/canvas/components/AddNodePanel/createAddNodePreview.d.ts.map +1 -1
  7. package/dist/canvas/components/AddNodePanel/createAddNodePreview.js +2 -2
  8. package/dist/canvas/components/AgentCanvas/agent-flow.manifest.d.ts +1 -0
  9. package/dist/canvas/components/AgentCanvas/agent-flow.manifest.d.ts.map +1 -1
  10. package/dist/canvas/components/BaseNode/BaseNode.cjs +8 -3
  11. package/dist/canvas/components/BaseNode/BaseNode.d.ts +2 -1
  12. package/dist/canvas/components/BaseNode/BaseNode.d.ts.map +1 -1
  13. package/dist/canvas/components/BaseNode/BaseNode.js +5 -3
  14. package/dist/canvas/components/ButtonHandle/ButtonHandle.cjs +115 -34
  15. package/dist/canvas/components/ButtonHandle/ButtonHandle.d.ts +4 -2
  16. package/dist/canvas/components/ButtonHandle/ButtonHandle.d.ts.map +1 -1
  17. package/dist/canvas/components/ButtonHandle/ButtonHandle.js +117 -36
  18. package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.cjs +48 -1
  19. package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.d.ts +4 -0
  20. package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.d.ts.map +1 -1
  21. package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.js +36 -1
  22. package/dist/canvas/components/ButtonHandle/SmartHandle.cjs +1 -1
  23. package/dist/canvas/components/ButtonHandle/SmartHandle.js +1 -1
  24. package/dist/canvas/components/Edges/SequenceEdge.cjs +3 -2
  25. package/dist/canvas/components/Edges/SequenceEdge.d.ts +11 -2
  26. package/dist/canvas/components/Edges/SequenceEdge.d.ts.map +1 -1
  27. package/dist/canvas/components/Edges/SequenceEdge.js +4 -3
  28. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.cjs +20 -10
  29. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.d.ts +2 -0
  30. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.d.ts.map +1 -1
  31. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.js +21 -11
  32. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.cjs +5 -8
  33. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.d.ts.map +1 -1
  34. package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.js +5 -8
  35. package/dist/canvas/components/LoopNode/LoopCanvasNode.cjs +80 -0
  36. package/dist/canvas/components/LoopNode/LoopCanvasNode.d.ts +6 -0
  37. package/dist/canvas/components/LoopNode/LoopCanvasNode.d.ts.map +1 -0
  38. package/dist/canvas/components/LoopNode/LoopCanvasNode.js +46 -0
  39. package/dist/canvas/components/LoopNode/LoopNode.cjs +440 -0
  40. package/dist/canvas/components/LoopNode/LoopNode.constants.cjs +77 -0
  41. package/dist/canvas/components/LoopNode/LoopNode.constants.d.ts +12 -0
  42. package/dist/canvas/components/LoopNode/LoopNode.constants.d.ts.map +1 -0
  43. package/dist/canvas/components/LoopNode/LoopNode.constants.js +13 -0
  44. package/dist/canvas/components/LoopNode/LoopNode.d.ts +5 -0
  45. package/dist/canvas/components/LoopNode/LoopNode.d.ts.map +1 -0
  46. package/dist/canvas/components/LoopNode/LoopNode.helpers.cjs +110 -0
  47. package/dist/canvas/components/LoopNode/LoopNode.helpers.d.ts +19 -0
  48. package/dist/canvas/components/LoopNode/LoopNode.helpers.d.ts.map +1 -0
  49. package/dist/canvas/components/LoopNode/LoopNode.helpers.js +70 -0
  50. package/dist/canvas/components/LoopNode/LoopNode.js +406 -0
  51. package/dist/canvas/components/LoopNode/LoopNode.types.cjs +18 -0
  52. package/dist/canvas/components/LoopNode/LoopNode.types.d.ts +16 -0
  53. package/dist/canvas/components/LoopNode/LoopNode.types.d.ts.map +1 -0
  54. package/dist/canvas/components/LoopNode/LoopNode.types.js +0 -0
  55. package/dist/canvas/components/LoopNode/LoopNodePreview.cjs +81 -0
  56. package/dist/canvas/components/LoopNode/LoopNodePreview.d.ts +8 -0
  57. package/dist/canvas/components/LoopNode/LoopNodePreview.d.ts.map +1 -0
  58. package/dist/canvas/components/LoopNode/LoopNodePreview.js +44 -0
  59. package/dist/canvas/components/LoopNode/index.cjs +72 -0
  60. package/dist/canvas/components/LoopNode/index.d.ts +4 -0
  61. package/dist/canvas/components/LoopNode/index.d.ts.map +1 -0
  62. package/dist/canvas/components/LoopNode/index.js +3 -0
  63. package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.cjs +20 -18
  64. package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.d.ts +2 -1
  65. package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.d.ts.map +1 -1
  66. package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.js +21 -19
  67. package/dist/canvas/components/Toolbox/ListView.cjs +3 -2
  68. package/dist/canvas/components/Toolbox/ListView.d.ts +1 -0
  69. package/dist/canvas/components/Toolbox/ListView.d.ts.map +1 -1
  70. package/dist/canvas/components/Toolbox/ListView.js +3 -2
  71. package/dist/canvas/components/Toolbox/Toolbox.cjs +38 -9
  72. package/dist/canvas/components/Toolbox/Toolbox.d.ts.map +1 -1
  73. package/dist/canvas/components/Toolbox/Toolbox.js +38 -9
  74. package/dist/canvas/components/index.cjs +27 -20
  75. package/dist/canvas/components/index.d.ts +1 -0
  76. package/dist/canvas/components/index.d.ts.map +1 -1
  77. package/dist/canvas/components/index.js +1 -0
  78. package/dist/canvas/core/NodeTypeRegistry.cjs +41 -23
  79. package/dist/canvas/core/NodeTypeRegistry.d.ts +8 -4
  80. package/dist/canvas/core/NodeTypeRegistry.d.ts.map +1 -1
  81. package/dist/canvas/core/NodeTypeRegistry.js +41 -23
  82. package/dist/canvas/core/useNodeTypeRegistry.cjs +4 -3
  83. package/dist/canvas/core/useNodeTypeRegistry.d.ts +1 -1
  84. package/dist/canvas/core/useNodeTypeRegistry.d.ts.map +1 -1
  85. package/dist/canvas/core/useNodeTypeRegistry.js +4 -3
  86. package/dist/canvas/hooks/useAddNodeOnConnectEnd.cjs +4 -3
  87. package/dist/canvas/hooks/useAddNodeOnConnectEnd.d.ts.map +1 -1
  88. package/dist/canvas/hooks/useAddNodeOnConnectEnd.js +4 -3
  89. package/dist/canvas/hooks/usePreviewNode.cjs +4 -2
  90. package/dist/canvas/hooks/usePreviewNode.d.ts.map +1 -1
  91. package/dist/canvas/hooks/usePreviewNode.js +4 -2
  92. package/dist/canvas/schema/node-definition/handle.cjs +10 -2
  93. package/dist/canvas/schema/node-definition/handle.d.ts +9 -0
  94. package/dist/canvas/schema/node-definition/handle.d.ts.map +1 -1
  95. package/dist/canvas/schema/node-definition/handle.js +6 -1
  96. package/dist/canvas/schema/node-definition/index.cjs +4 -1
  97. package/dist/canvas/schema/node-definition/index.d.ts +3 -3
  98. package/dist/canvas/schema/node-definition/index.d.ts.map +1 -1
  99. package/dist/canvas/schema/node-definition/index.js +2 -2
  100. package/dist/canvas/schema/node-definition/node-manifest.d.ts +4 -0
  101. package/dist/canvas/schema/node-definition/node-manifest.d.ts.map +1 -1
  102. package/dist/canvas/storybook-utils/manifests/index.d.ts +1 -0
  103. package/dist/canvas/storybook-utils/manifests/index.d.ts.map +1 -1
  104. package/dist/canvas/storybook-utils/manifests/node-definitions.d.ts.map +1 -1
  105. package/dist/canvas/styles/tailwind.canvas.css +1 -1
  106. package/dist/canvas/utils/createPreviewGraph.cjs +94 -0
  107. package/dist/canvas/utils/createPreviewGraph.d.ts +24 -0
  108. package/dist/canvas/utils/createPreviewGraph.d.ts.map +1 -0
  109. package/dist/canvas/utils/createPreviewGraph.js +51 -0
  110. package/dist/canvas/utils/createPreviewNode.cjs +29 -13
  111. package/dist/canvas/utils/createPreviewNode.d.ts +5 -1
  112. package/dist/canvas/utils/createPreviewNode.d.ts.map +1 -1
  113. package/dist/canvas/utils/createPreviewNode.js +23 -13
  114. package/dist/canvas/utils/index.cjs +33 -26
  115. package/dist/canvas/utils/index.d.ts +2 -1
  116. package/dist/canvas/utils/index.d.ts.map +1 -1
  117. package/dist/canvas/utils/index.js +2 -1
  118. package/package.json +1 -1
@@ -1,14 +1,15 @@
1
1
  import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { Row } from "../../layouts/index.js";
2
3
  import { Handle, Position } from "../../xyflow/react.js";
3
- import { memo, useCallback, useMemo, useRef, useState } from "react";
4
+ import { forwardRef, memo, useCallback, useLayoutEffect, useMemo, useRef, useState } from "react";
4
5
  import { canvasEventBus } from "../../utils/CanvasEventBus.js";
5
6
  import { cx } from "../../utils/CssUtil.js";
6
- import { calculateGridAlignedHandlePositions, pixelToPercent } from "./ButtonHandleStyleUtils.js";
7
+ import { INWARD_LABEL_POSITION, calculateGridAlignedHandlePositions, getInwardHandleSize, getInwardHandleTransform, getInwardNotchLayout, pixelToPercent } from "./ButtonHandleStyleUtils.js";
7
8
  import { HandleButton, HandleHoverBridge } from "./HandleButton.js";
8
9
  import { HandleLabel } from "./HandleLabel.js";
9
10
  import { HandleNotch } from "./HandleNotch.js";
10
11
  import { useButtonHandleSizeAndPosition } from "./useButtonHandleSizeAndPosition.js";
11
- const ButtonHandleBase = ({ id, nodeId, type, position, handleType, label, labelIcon, labelBackgroundColor = 'var(--canvas-background-secondary)', visible = true, showButton = true, selected = false, index = 0, total = 1, onAction, showNotches = true, customPositionAndOffsets, nodeWidth, nodeHeight })=>{
12
+ const ButtonHandleBase = ({ id, nodeId, type, position, connectionPosition = position, handleType, label, labelIcon, labelBackgroundColor = 'var(--canvas-background-secondary)', visible = true, showButton = true, selected = false, index = 0, total = 1, onAction, showNotches = true, customPositionAndOffsets, nodeWidth, nodeHeight })=>{
12
13
  const handleRef = useRef(null);
13
14
  const [isHovered, setIsHovered] = useState(false);
14
15
  const isVertical = position === Position.Top || position === Position.Bottom;
@@ -33,7 +34,7 @@ const ButtonHandleBase = ({ id, nodeId, type, position, handleType, label, label
33
34
  handleId: id,
34
35
  nodeId,
35
36
  handleType,
36
- position,
37
+ position: connectionPosition,
37
38
  originalEvent: event
38
39
  };
39
40
  onAction?.(actionEvent);
@@ -41,13 +42,13 @@ const ButtonHandleBase = ({ id, nodeId, type, position, handleType, label, label
41
42
  handleId: id,
42
43
  nodeId,
43
44
  handleType,
44
- position
45
+ position: connectionPosition
45
46
  });
46
47
  }, [
48
+ connectionPosition,
47
49
  id,
48
50
  nodeId,
49
51
  handleType,
50
- position,
51
52
  onAction
52
53
  ]);
53
54
  const markAsHovered = useCallback(()=>setIsHovered(true), []);
@@ -58,52 +59,91 @@ const ButtonHandleBase = ({ id, nodeId, type, position, handleType, label, label
58
59
  numHandles: total,
59
60
  customPositionAndOffsets
60
61
  });
61
- return /*#__PURE__*/ jsxs(Handle, {
62
+ const hasInwardLabel = Boolean(label && connectionPosition !== position);
63
+ const { inwardLabelRef, rootWidth, rootHeight, rootTransform } = useInwardLabelLayout({
64
+ hasInwardLabel,
65
+ isVertical,
66
+ position,
67
+ handleType,
68
+ handleWidth,
69
+ handleHeight,
70
+ transform
71
+ });
72
+ return /*#__PURE__*/ jsx(Handle, {
62
73
  ref: handleRef,
63
74
  type: type,
64
- position: position,
75
+ position: connectionPosition,
65
76
  id: id,
66
77
  onMouseEnter: markAsHovered,
67
78
  onMouseLeave: unmarkAsHovered,
68
79
  onMouseDown: unmarkAsHovered,
69
80
  className: cx('flex! items-center! justify-center! border-0! rounded-none! bg-transparent!', visible ? 'cursor-crosshair! pointer-events-auto! opacity-100' : 'cursor-default! pointer-events-none! opacity-0'),
70
81
  style: {
71
- width: handleWidth,
72
- height: handleHeight,
82
+ width: rootWidth,
83
+ height: rootHeight,
73
84
  top,
74
85
  bottom,
75
86
  left,
76
87
  right,
77
- transform
88
+ transform: rootTransform
78
89
  },
79
- children: [
80
- /*#__PURE__*/ jsx(HandleNotch, {
81
- handleType: handleType,
82
- isVertical: isVertical,
83
- selected: selected,
84
- hovered: isHovered,
85
- showNotch: showNotches
86
- }),
87
- onAction && 'source' === type ? /*#__PURE__*/ jsx(HandleButton, {
88
- visible: showButton,
89
- labelVisible: visible,
90
- position: position,
91
- onAction: handleButtonClick,
92
- handleRef: handleRef,
93
- label: label,
94
- labelIcon: labelIcon,
95
- labelBackgroundColor: labelBackgroundColor
96
- }) : label && /*#__PURE__*/ jsx(HandleLabel, {
97
- position: position,
98
- backgroundColor: labelBackgroundColor,
99
- label: label,
100
- labelIcon: labelIcon
101
- })
102
- ]
90
+ children: hasInwardLabel ? /*#__PURE__*/ jsxs(Fragment, {
91
+ children: [
92
+ /*#__PURE__*/ jsx("div", {
93
+ className: cx('flex h-full w-full items-center', getInwardNotchLayout(position)),
94
+ children: /*#__PURE__*/ jsx(HandleNotch, {
95
+ handleType: handleType,
96
+ isVertical: isVertical,
97
+ selected: selected,
98
+ hovered: isHovered,
99
+ showNotch: showNotches
100
+ })
101
+ }),
102
+ /*#__PURE__*/ jsx(ButtonHandle_InwardHandleLabel, {
103
+ ref: inwardLabelRef,
104
+ connectionPosition: connectionPosition,
105
+ label: label,
106
+ labelIcon: labelIcon,
107
+ backgroundColor: labelBackgroundColor
108
+ }),
109
+ onAction && 'source' === type && showButton ? /*#__PURE__*/ jsx(HandleButton, {
110
+ visible: showButton,
111
+ labelVisible: visible,
112
+ position: position,
113
+ onAction: handleButtonClick,
114
+ handleRef: handleRef
115
+ }) : null
116
+ ]
117
+ }) : /*#__PURE__*/ jsxs(Fragment, {
118
+ children: [
119
+ /*#__PURE__*/ jsx(HandleNotch, {
120
+ handleType: handleType,
121
+ isVertical: isVertical,
122
+ selected: selected,
123
+ hovered: isHovered,
124
+ showNotch: showNotches
125
+ }),
126
+ onAction && 'source' === type && showButton ? /*#__PURE__*/ jsx(HandleButton, {
127
+ visible: showButton,
128
+ labelVisible: visible,
129
+ position: position,
130
+ onAction: handleButtonClick,
131
+ handleRef: handleRef,
132
+ label: label,
133
+ labelIcon: labelIcon,
134
+ labelBackgroundColor: labelBackgroundColor
135
+ }) : label && /*#__PURE__*/ jsx(HandleLabel, {
136
+ position: position,
137
+ backgroundColor: labelBackgroundColor,
138
+ label: label,
139
+ labelIcon: labelIcon
140
+ })
141
+ ]
142
+ })
103
143
  });
104
144
  };
105
145
  const ButtonHandle = /*#__PURE__*/ memo(ButtonHandleBase);
106
- const ButtonHandlesBase = ({ nodeId, handles, position, selected = false, hovered = false, visible = true, showAddButton = true, showNotches = true, customPositionAndOffsets, shouldShowAddButtonFn = ({ showAddButton, selected, hovered })=>showAddButton && (selected || hovered), nodeWidth, nodeHeight })=>{
146
+ const ButtonHandlesBase = ({ nodeId, handles, position, connectionPosition = position, selected = false, hovered = false, visible = true, showAddButton = true, showNotches = true, customPositionAndOffsets, shouldShowAddButtonFn = ({ showAddButton, selected, hovered })=>showAddButton && (selected || hovered), nodeWidth, nodeHeight })=>{
107
147
  const finalSelected = shouldShowAddButtonFn({
108
148
  showAddButton,
109
149
  selected,
@@ -122,6 +162,7 @@ const ButtonHandlesBase = ({ nodeId, handles, position, selected = false, hovere
122
162
  nodeId: nodeId,
123
163
  type: handle.type,
124
164
  position: position,
165
+ connectionPosition: connectionPosition,
125
166
  handleType: handle.handleType,
126
167
  label: handle.label,
127
168
  labelIcon: handle.labelIcon,
@@ -141,4 +182,44 @@ const ButtonHandlesBase = ({ nodeId, handles, position, selected = false, hovere
141
182
  });
142
183
  };
143
184
  const ButtonHandles = /*#__PURE__*/ memo(ButtonHandlesBase);
185
+ function useInwardLabelLayout({ hasInwardLabel, isVertical, position, handleType, handleWidth, handleHeight, transform }) {
186
+ const inwardLabelRef = useRef(null);
187
+ const [inwardLabelInset, setInwardLabelInset] = useState(0);
188
+ useLayoutEffect(()=>{
189
+ if (!hasInwardLabel) return void setInwardLabelInset((current)=>0 === current ? current : 0);
190
+ const rect = inwardLabelRef.current?.getBoundingClientRect();
191
+ const nextInset = isVertical ? rect?.height ?? 0 : rect?.width ?? 0;
192
+ setInwardLabelInset((current)=>current === nextInset ? current : nextInset);
193
+ }, [
194
+ hasInwardLabel,
195
+ isVertical
196
+ ]);
197
+ const inwardHandleSize = getInwardHandleSize(handleType);
198
+ return {
199
+ inwardLabelRef,
200
+ rootWidth: hasInwardLabel && !isVertical ? inwardHandleSize : handleWidth,
201
+ rootHeight: hasInwardLabel && isVertical ? inwardHandleSize : handleHeight,
202
+ rootTransform: hasInwardLabel ? getInwardHandleTransform(position, inwardLabelInset) : transform
203
+ };
204
+ }
205
+ const ButtonHandle_InwardHandleLabel = /*#__PURE__*/ forwardRef(function({ connectionPosition, label, labelIcon, backgroundColor }, ref) {
206
+ return /*#__PURE__*/ jsx("div", {
207
+ ref: ref,
208
+ className: cx('pointer-events-none absolute flex h-6 items-center whitespace-nowrap rounded-full border border-border-subtle px-2.5', INWARD_LABEL_POSITION[connectionPosition]),
209
+ style: {
210
+ backgroundColor
211
+ },
212
+ children: /*#__PURE__*/ jsxs(Row, {
213
+ align: "center",
214
+ gap: 3,
215
+ children: [
216
+ labelIcon,
217
+ /*#__PURE__*/ jsx("span", {
218
+ className: "text-xs font-medium text-foreground",
219
+ children: label
220
+ })
221
+ ]
222
+ })
223
+ });
224
+ });
144
225
  export { ButtonHandle, ButtonHandles };
@@ -25,14 +25,18 @@ var __webpack_exports__ = {};
25
25
  __webpack_require__.r(__webpack_exports__);
26
26
  __webpack_require__.d(__webpack_exports__, {
27
27
  leftPositionForHandle: ()=>leftPositionForHandle,
28
+ getInwardHandleSize: ()=>getInwardHandleSize,
28
29
  topPositionForHandle: ()=>topPositionForHandle,
29
30
  transformForHandle: ()=>transformForHandle,
30
- snapToGrid: ()=>snapToGrid,
31
+ getInwardNotchLayout: ()=>getInwardNotchLayout,
31
32
  heightForHandleWithPosition: ()=>heightForHandleWithPosition,
33
+ snapToGrid: ()=>snapToGrid,
34
+ INWARD_LABEL_POSITION: ()=>INWARD_LABEL_POSITION,
32
35
  bottomPositionForHandle: ()=>bottomPositionForHandle,
33
36
  calculateGridAlignedHandlePositions: ()=>calculateGridAlignedHandlePositions,
34
37
  pixelToPercent: ()=>pixelToPercent,
35
38
  rightPositionForHandle: ()=>rightPositionForHandle,
39
+ getInwardHandleTransform: ()=>getInwardHandleTransform,
36
40
  widthForHandleWithPosition: ()=>widthForHandleWithPosition
37
41
  });
38
42
  const react_cjs_namespaceObject = require("../../xyflow/react.cjs");
@@ -121,8 +125,47 @@ const transformForHandle = ({ position, customPositionAndOffsets })=>{
121
125
  const horizontalPercent = hasCustomHorizontal ? '0%' : position === react_cjs_namespaceObject.Position.Right ? '50%' : '-50%';
122
126
  return `translate(${horizontalPercent}, ${verticalPercent})`;
123
127
  };
128
+ const getInwardHandleSize = (handleType)=>{
129
+ if ('input' === handleType) return '14px';
130
+ if ('artifact' === handleType) return '16px';
131
+ return '18px';
132
+ };
133
+ const getInwardHandleTransform = (position, inset)=>{
134
+ switch(position){
135
+ case react_cjs_namespaceObject.Position.Left:
136
+ return `translate(${inset}px, -50%)`;
137
+ case react_cjs_namespaceObject.Position.Right:
138
+ return `translate(${-inset}px, -50%)`;
139
+ case react_cjs_namespaceObject.Position.Top:
140
+ return `translate(-50%, ${inset}px)`;
141
+ case react_cjs_namespaceObject.Position.Bottom:
142
+ return `translate(-50%, ${-inset}px)`;
143
+ }
144
+ };
145
+ const getInwardNotchLayout = (position)=>{
146
+ switch(position){
147
+ case react_cjs_namespaceObject.Position.Top:
148
+ return 'flex-col justify-start';
149
+ case react_cjs_namespaceObject.Position.Bottom:
150
+ return 'flex-col justify-end';
151
+ case react_cjs_namespaceObject.Position.Left:
152
+ return 'justify-start';
153
+ case react_cjs_namespaceObject.Position.Right:
154
+ return 'justify-end';
155
+ }
156
+ };
157
+ const INWARD_LABEL_POSITION = {
158
+ [react_cjs_namespaceObject.Position.Top]: 'top-full left-1/2 -translate-x-1/2',
159
+ [react_cjs_namespaceObject.Position.Bottom]: 'bottom-full left-1/2 -translate-x-1/2',
160
+ [react_cjs_namespaceObject.Position.Left]: 'left-full top-1/2 -translate-y-1/2',
161
+ [react_cjs_namespaceObject.Position.Right]: 'right-full top-1/2 -translate-y-1/2'
162
+ };
163
+ exports.INWARD_LABEL_POSITION = __webpack_exports__.INWARD_LABEL_POSITION;
124
164
  exports.bottomPositionForHandle = __webpack_exports__.bottomPositionForHandle;
125
165
  exports.calculateGridAlignedHandlePositions = __webpack_exports__.calculateGridAlignedHandlePositions;
166
+ exports.getInwardHandleSize = __webpack_exports__.getInwardHandleSize;
167
+ exports.getInwardHandleTransform = __webpack_exports__.getInwardHandleTransform;
168
+ exports.getInwardNotchLayout = __webpack_exports__.getInwardNotchLayout;
126
169
  exports.heightForHandleWithPosition = __webpack_exports__.heightForHandleWithPosition;
127
170
  exports.leftPositionForHandle = __webpack_exports__.leftPositionForHandle;
128
171
  exports.pixelToPercent = __webpack_exports__.pixelToPercent;
@@ -132,8 +175,12 @@ exports.topPositionForHandle = __webpack_exports__.topPositionForHandle;
132
175
  exports.transformForHandle = __webpack_exports__.transformForHandle;
133
176
  exports.widthForHandleWithPosition = __webpack_exports__.widthForHandleWithPosition;
134
177
  for(var __rspack_i in __webpack_exports__)if (-1 === [
178
+ "INWARD_LABEL_POSITION",
135
179
  "bottomPositionForHandle",
136
180
  "calculateGridAlignedHandlePositions",
181
+ "getInwardHandleSize",
182
+ "getInwardHandleTransform",
183
+ "getInwardNotchLayout",
137
184
  "heightForHandleWithPosition",
138
185
  "leftPositionForHandle",
139
186
  "pixelToPercent",
@@ -45,4 +45,8 @@ export declare const transformForHandle: ({ position, customPositionAndOffsets,
45
45
  position: Position;
46
46
  customPositionAndOffsets?: HandleConfigurationSpecificPosition;
47
47
  }) => string;
48
+ export declare const getInwardHandleSize: (handleType: "artifact" | "input" | "output") => string;
49
+ export declare const getInwardHandleTransform: (position: Position, inset: number) => string;
50
+ export declare const getInwardNotchLayout: (position: Position) => string;
51
+ export declare const INWARD_LABEL_POSITION: Record<Position, string>;
48
52
  //# sourceMappingURL=ButtonHandleStyleUtils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ButtonHandleStyleUtils.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/ButtonHandle/ButtonHandleStyleUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0CAA0C,CAAC;AAEpE,OAAO,KAAK,EAAE,mCAAmC,EAAE,MAAM,qCAAqC,CAAC;AAoB/F,eAAO,MAAM,UAAU,GAAI,OAAO,MAAM,EAAE,WAAU,MAAqB,KAAG,MAE3E,CAAC;AAmBF,eAAO,MAAM,mCAAmC,GAC9C,UAAU,MAAM,EAChB,YAAY,MAAM,EAClB,WAAU,MAAyB,KAClC,MAAM,EA4BR,CAAC;AAQF,eAAO,MAAM,cAAc,GAAI,eAAe,MAAM,EAAE,UAAU,MAAM,KAAG,MAGxE,CAAC;AAEF,eAAO,MAAM,0BAA0B,GAAI,wCAIxC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,KAAG,MAMH,CAAC;AAEF,eAAO,MAAM,2BAA2B,GAAI,yCAIzC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAMH,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,uEAMlC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAyBH,CAAC;AAEF,eAAO,MAAM,uBAAuB,GAAI,uEAMrC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAsBH,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,sEAMnC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,KAAG,MAyBH,CAAC;AAEF,eAAO,MAAM,sBAAsB,GAAI,sEAMpC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,KAAG,MAsBH,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,yCAGhC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,wBAAwB,CAAC,EAAE,mCAAmC,CAAC;CAChE,KAAG,MAgBH,CAAC"}
1
+ {"version":3,"file":"ButtonHandleStyleUtils.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/ButtonHandle/ButtonHandleStyleUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0CAA0C,CAAC;AAEpE,OAAO,KAAK,EAAE,mCAAmC,EAAE,MAAM,qCAAqC,CAAC;AAoB/F,eAAO,MAAM,UAAU,GAAI,OAAO,MAAM,EAAE,WAAU,MAAqB,KAAG,MAE3E,CAAC;AAmBF,eAAO,MAAM,mCAAmC,GAC9C,UAAU,MAAM,EAChB,YAAY,MAAM,EAClB,WAAU,MAAyB,KAClC,MAAM,EA4BR,CAAC;AAQF,eAAO,MAAM,cAAc,GAAI,eAAe,MAAM,EAAE,UAAU,MAAM,KAAG,MAGxE,CAAC;AAEF,eAAO,MAAM,0BAA0B,GAAI,wCAIxC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,KAAG,MAMH,CAAC;AAEF,eAAO,MAAM,2BAA2B,GAAI,yCAIzC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAMH,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,uEAMlC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAyBH,CAAC;AAEF,eAAO,MAAM,uBAAuB,GAAI,uEAMrC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KAAG,MAsBH,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,sEAMnC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,KAAG,MAyBH,CAAC;AAEF,eAAO,MAAM,sBAAsB,GAAI,sEAMpC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,KAAG,MAsBH,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,yCAGhC;IACD,QAAQ,EAAE,QAAQ,CAAC;IACnB,wBAAwB,CAAC,EAAE,mCAAmC,CAAC;CAChE,KAAG,MAgBH,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,YAAY,UAAU,GAAG,OAAO,GAAG,QAAQ,KAAG,MAIjF,CAAC;AAEF,eAAO,MAAM,wBAAwB,GAAI,UAAU,QAAQ,EAAE,OAAO,MAAM,KAAG,MAW5E,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,UAAU,QAAQ,KAAG,MAWzD,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAK1D,CAAC"}
@@ -84,4 +84,39 @@ const transformForHandle = ({ position, customPositionAndOffsets })=>{
84
84
  const horizontalPercent = hasCustomHorizontal ? '0%' : position === Position.Right ? '50%' : '-50%';
85
85
  return `translate(${horizontalPercent}, ${verticalPercent})`;
86
86
  };
87
- export { bottomPositionForHandle, calculateGridAlignedHandlePositions, heightForHandleWithPosition, leftPositionForHandle, pixelToPercent, rightPositionForHandle, snapToGrid, topPositionForHandle, transformForHandle, widthForHandleWithPosition };
87
+ const getInwardHandleSize = (handleType)=>{
88
+ if ('input' === handleType) return '14px';
89
+ if ('artifact' === handleType) return '16px';
90
+ return '18px';
91
+ };
92
+ const getInwardHandleTransform = (position, inset)=>{
93
+ switch(position){
94
+ case Position.Left:
95
+ return `translate(${inset}px, -50%)`;
96
+ case Position.Right:
97
+ return `translate(${-inset}px, -50%)`;
98
+ case Position.Top:
99
+ return `translate(-50%, ${inset}px)`;
100
+ case Position.Bottom:
101
+ return `translate(-50%, ${-inset}px)`;
102
+ }
103
+ };
104
+ const getInwardNotchLayout = (position)=>{
105
+ switch(position){
106
+ case Position.Top:
107
+ return 'flex-col justify-start';
108
+ case Position.Bottom:
109
+ return 'flex-col justify-end';
110
+ case Position.Left:
111
+ return 'justify-start';
112
+ case Position.Right:
113
+ return 'justify-end';
114
+ }
115
+ };
116
+ const INWARD_LABEL_POSITION = {
117
+ [Position.Top]: 'top-full left-1/2 -translate-x-1/2',
118
+ [Position.Bottom]: 'bottom-full left-1/2 -translate-x-1/2',
119
+ [Position.Left]: 'left-full top-1/2 -translate-y-1/2',
120
+ [Position.Right]: 'right-full top-1/2 -translate-y-1/2'
121
+ };
122
+ export { INWARD_LABEL_POSITION, bottomPositionForHandle, calculateGridAlignedHandlePositions, getInwardHandleSize, getInwardHandleTransform, getInwardNotchLayout, heightForHandleWithPosition, leftPositionForHandle, pixelToPercent, rightPositionForHandle, snapToGrid, topPositionForHandle, transformForHandle, widthForHandleWithPosition };
@@ -384,7 +384,7 @@ function SmartHandle({ type, id, defaultPosition = 'source' === type ? react_nam
384
384
  ...rest,
385
385
  children: visible && /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)(jsx_runtime_namespaceObject.Fragment, {
386
386
  children: [
387
- onAction && 'source' === type ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_HandleButton_cjs_namespaceObject.HandleButton, {
387
+ onAction && 'source' === type && showButton ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_HandleButton_cjs_namespaceObject.HandleButton, {
388
388
  visible: showButton,
389
389
  labelVisible: visible,
390
390
  position: computedPosition,
@@ -353,7 +353,7 @@ function SmartHandle({ type, id, defaultPosition = 'source' === type ? Position.
353
353
  ...rest,
354
354
  children: visible && /*#__PURE__*/ jsxs(Fragment, {
355
355
  children: [
356
- onAction && 'source' === type ? /*#__PURE__*/ jsx(HandleButton, {
356
+ onAction && 'source' === type && showButton ? /*#__PURE__*/ jsx(HandleButton, {
357
357
  visible: showButton,
358
358
  labelVisible: visible,
359
359
  position: computedPosition,
@@ -80,7 +80,7 @@ const SequenceEdge_SequenceEdge = /*#__PURE__*/ (0, external_react_namespaceObje
80
80
  const pathElementRef = (0, external_react_namespaceObject.useRef)(null);
81
81
  const { mode } = (0, BaseCanvasModeProvider_cjs_namespaceObject.useBaseCanvasMode)();
82
82
  const isReadOnly = 'readonly' === mode;
83
- const isPreviewEdge = id === external_constants_cjs_namespaceObject.PREVIEW_EDGE_ID;
83
+ const isPreviewEdge = id === external_constants_cjs_namespaceObject.PREVIEW_EDGE_ID || source === external_constants_cjs_namespaceObject.PREVIEW_NODE_ID || target === external_constants_cjs_namespaceObject.PREVIEW_NODE_ID;
84
84
  const executionStatus = (0, index_cjs_namespaceObject.useEdgeExecutionState)(id, target);
85
85
  const { validationStatus } = (0, index_cjs_namespaceObject.useElementValidationStatus)(id) ?? {
86
86
  validationStatus: void 0
@@ -111,7 +111,8 @@ const SequenceEdge_SequenceEdge = /*#__PURE__*/ (0, external_react_namespaceObje
111
111
  sourcePosition,
112
112
  targetPosition,
113
113
  source,
114
- target
114
+ target,
115
+ parentId: data?.parentId
115
116
  });
116
117
  const getEdgeColor = ()=>{
117
118
  if (isDiffAdded) return 'var(--canvas-success-icon)';
@@ -1,3 +1,12 @@
1
- import { type EdgeProps } from '../../xyflow/react.ts';
2
- export declare const SequenceEdge: import("react").NamedExoticComponent<EdgeProps>;
1
+ import { type Edge, type EdgeProps } from '../../xyflow/react.ts';
2
+ interface SequenceEdgeData extends Record<string, unknown> {
3
+ isDiffAdded?: boolean;
4
+ isDiffRemoved?: boolean;
5
+ label?: string;
6
+ parentId?: string;
7
+ }
8
+ type SequenceEdgeType = Edge<SequenceEdgeData>;
9
+ type SequenceEdgeProps = EdgeProps<SequenceEdgeType>;
10
+ export declare const SequenceEdge: import("react").NamedExoticComponent<SequenceEdgeProps>;
11
+ export {};
3
12
  //# sourceMappingURL=SequenceEdge.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SequenceEdge.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/Edges/SequenceEdge.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAY,MAAM,0CAA0C,CAAC;AAoDpF,eAAO,MAAM,YAAY,iDAuMJ,CAAC"}
1
+ {"version":3,"file":"SequenceEdge.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/Edges/SequenceEdge.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,IAAI,EAAE,KAAK,SAAS,EAAY,MAAM,0CAA0C,CAAC;AAW/F,UAAU,gBAAiB,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACxD,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,KAAK,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC;AAC/C,KAAK,iBAAiB,GAAG,SAAS,CAAC,gBAAgB,CAAC,CAAC;AA2CrD,eAAO,MAAM,YAAY,yDAyMJ,CAAC"}
@@ -1,7 +1,7 @@
1
1
  import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
2
  import { Position } from "../../xyflow/react.js";
3
3
  import { memo, useRef, useState } from "react";
4
- import { PREVIEW_EDGE_ID } from "../../constants.js";
4
+ import { PREVIEW_EDGE_ID, PREVIEW_NODE_ID } from "../../constants.js";
5
5
  import { useEdgeExecutionState, useEdgePath, useElementValidationStatus } from "../../hooks/index.js";
6
6
  import { useBaseCanvasMode } from "../BaseCanvas/BaseCanvasModeProvider.js";
7
7
  import { EdgeToolbar, useEdgeToolbarState } from "../Toolbar/index.js";
@@ -52,7 +52,7 @@ const SequenceEdge_SequenceEdge = /*#__PURE__*/ memo(function({ id, selected, so
52
52
  const pathElementRef = useRef(null);
53
53
  const { mode } = useBaseCanvasMode();
54
54
  const isReadOnly = 'readonly' === mode;
55
- const isPreviewEdge = id === PREVIEW_EDGE_ID;
55
+ const isPreviewEdge = id === PREVIEW_EDGE_ID || source === PREVIEW_NODE_ID || target === PREVIEW_NODE_ID;
56
56
  const executionStatus = useEdgeExecutionState(id, target);
57
57
  const { validationStatus } = useElementValidationStatus(id) ?? {
58
58
  validationStatus: void 0
@@ -83,7 +83,8 @@ const SequenceEdge_SequenceEdge = /*#__PURE__*/ memo(function({ id, selected, so
83
83
  sourcePosition,
84
84
  targetPosition,
85
85
  source,
86
- target
86
+ target,
87
+ parentId: data?.parentId
87
88
  });
88
89
  const getEdgeColor = ()=>{
89
90
  if (isDiffAdded) return 'var(--canvas-success-icon)';
@@ -38,6 +38,7 @@ const animatedViewportManager_cjs_namespaceObject = require("../../stores/animat
38
38
  const canvasStore_cjs_namespaceObject = require("../../stores/canvasStore.cjs");
39
39
  const viewportManager_cjs_namespaceObject = require("../../stores/viewportManager.cjs");
40
40
  const external_types_cjs_namespaceObject = require("../../types.cjs");
41
+ const createPreviewGraph_cjs_namespaceObject = require("../../utils/createPreviewGraph.cjs");
41
42
  const icon_registry_cjs_namespaceObject = require("../../utils/icon-registry.cjs");
42
43
  const transitions_cjs_namespaceObject = require("../../utils/transitions.cjs");
43
44
  const AddNodeManager_cjs_namespaceObject = require("../AddNodePanel/AddNodeManager.cjs");
@@ -52,7 +53,7 @@ const DEFAULT_NODE_TYPES = {
52
53
  'blank-canvas-node': external_BlankCanvasNode_index_cjs_namespaceObject.BlankCanvasNode,
53
54
  preview: AddNodePreview_cjs_namespaceObject.AddNodePreview
54
55
  };
55
- const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onCanvasesChange, onPathChange })=>{
56
+ const HierarchicalCanvas = ({ additionalNodeTypes, mode = 'design', initialCanvases, initialPath, onCanvasesChange, onPathChange })=>{
56
57
  const canvasRef = (0, external_react_namespaceObject.useRef)(null);
57
58
  const containerRef = (0, external_react_namespaceObject.useRef)(null);
58
59
  const [reactFlowInstance, setReactFlowInstance] = (0, external_react_namespaceObject.useState)(null);
@@ -65,14 +66,17 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
65
66
  const shouldAnimate = 'design' === mode && !(0, transitions_cjs_namespaceObject.prefersReducedMotion)();
66
67
  const nodeManifests = (0, external_core_index_cjs_namespaceObject.useNodeManifests)();
67
68
  const nodeTypes = (0, external_react_namespaceObject.useMemo)(()=>{
68
- const types = nodeManifests.reduce((acc, manifest)=>{
69
- if (!acc[manifest.nodeType]) acc[manifest.nodeType] = external_BaseNode_index_cjs_namespaceObject.BaseNode;
70
- return acc;
71
- }, {
72
- ...DEFAULT_NODE_TYPES
73
- });
74
- return types;
69
+ const manifestNodeTypes = Object.fromEntries(nodeManifests.map(({ nodeType })=>nodeType).filter((nodeType)=>!Object.hasOwn(DEFAULT_NODE_TYPES, nodeType)).map((nodeType)=>[
70
+ nodeType,
71
+ external_BaseNode_index_cjs_namespaceObject.BaseNode
72
+ ]));
73
+ return {
74
+ ...DEFAULT_NODE_TYPES,
75
+ ...manifestNodeTypes,
76
+ ...additionalNodeTypes
77
+ };
75
78
  }, [
79
+ additionalNodeTypes,
76
80
  nodeManifests
77
81
  ]);
78
82
  const currentCanvas = (0, canvasStore_cjs_namespaceObject.useCanvasStore)(canvasStore_cjs_namespaceObject.selectCurrentCanvas);
@@ -206,12 +210,18 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
206
210
  const canvas = currentCanvasRef.current;
207
211
  if (!connection.source || !connection.target || !canvas) return;
208
212
  if (connection.target === external_constants_cjs_namespaceObject.PREVIEW_NODE_ID || connection.source === external_constants_cjs_namespaceObject.PREVIEW_NODE_ID) return;
213
+ const parentId = (0, createPreviewGraph_cjs_namespaceObject.inferParentId)(connection.source, connection.target, canvas.nodes);
209
214
  const newEdge = {
210
215
  id: `${connection.source}-${connection.target}-${Date.now()}`,
211
216
  source: connection.source,
212
217
  target: connection.target,
213
218
  sourceHandle: connection.sourceHandle || void 0,
214
- targetHandle: connection.targetHandle || void 0
219
+ targetHandle: connection.targetHandle || void 0,
220
+ ...parentId ? {
221
+ data: {
222
+ parentId
223
+ }
224
+ } : {}
215
225
  };
216
226
  updateEdges([
217
227
  ...canvas.edges,
@@ -220,7 +230,7 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
220
230
  const hasPreview = canvas.nodes.some((n)=>n.id === external_constants_cjs_namespaceObject.PREVIEW_NODE_ID);
221
231
  if (hasPreview) {
222
232
  updateNodes(canvas.nodes.filter((n)=>n.id !== external_constants_cjs_namespaceObject.PREVIEW_NODE_ID));
223
- updateEdges(canvas.edges.filter((e)=>e.id !== external_constants_cjs_namespaceObject.PREVIEW_EDGE_ID));
233
+ updateEdges(canvas.edges.filter((edge)=>edge.source !== external_constants_cjs_namespaceObject.PREVIEW_NODE_ID && edge.target !== external_constants_cjs_namespaceObject.PREVIEW_NODE_ID));
224
234
  }
225
235
  }, [
226
236
  updateNodes,
@@ -1,6 +1,8 @@
1
+ import { type NodeTypes } from '../../xyflow/react.ts';
1
2
  import type React from 'react';
2
3
  import type { CanvasLevel } from '../../types/canvas.types';
3
4
  interface HierarchicalCanvasProps {
5
+ additionalNodeTypes?: NodeTypes;
4
6
  mode?: 'view' | 'design' | 'readonly';
5
7
  initialCanvases?: Record<string, CanvasLevel>;
6
8
  initialPath?: string[];
@@ -1 +1 @@
1
- {"version":3,"file":"HierarchicalCanvas.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/HierarchicalCanvas/HierarchicalCanvas.tsx"],"names":[],"mappings":"AAoBA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AA4B/B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAW5D,UAAU,uBAAuB;IAC/B,IAAI,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,UAAU,CAAC;IAKtC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAK9C,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IAMvB,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,KAAK,IAAI,CAAC;IAInE,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;CACzC;AASD,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,uBAAuB,CA2YhE,CAAC"}
1
+ {"version":3,"file":"HierarchicalCanvas.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/HierarchicalCanvas/HierarchicalCanvas.tsx"],"names":[],"mappings":"AAAA,OAAO,EAQL,KAAK,SAAS,EAUf,MAAM,0CAA0C,CAAC;AAElD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AA4B/B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAY5D,UAAU,uBAAuB;IAC/B,mBAAmB,CAAC,EAAE,SAAS,CAAC;IAChC,IAAI,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,UAAU,CAAC;IAKtC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAK9C,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IAMvB,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,KAAK,IAAI,CAAC;IAInE,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;CACzC;AASD,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,uBAAuB,CAqZhE,CAAC"}
@@ -2,7 +2,7 @@ import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import { Panel, applyEdgeChanges, applyNodeChanges } from "../../xyflow/react.js";
3
3
  import { Spinner } from "@uipath/apollo-wind";
4
4
  import { useCallback, useEffect, useMemo, useRef, useState } from "react";
5
- import { PREVIEW_EDGE_ID, PREVIEW_NODE_ID } from "../../constants.js";
5
+ import { PREVIEW_NODE_ID } from "../../constants.js";
6
6
  import { Breadcrumb } from "../../controls/index.js";
7
7
  import { useNodeManifests } from "../../core/index.js";
8
8
  import { useAddNodeOnConnectEnd } from "../../hooks/useAddNodeOnConnectEnd.js";
@@ -10,6 +10,7 @@ import { animatedViewportManager } from "../../stores/animatedViewportManager.js
10
10
  import { selectBreadcrumbs, selectCanvasStack, selectCurrentCanvas, selectCurrentPath, selectDrillIntoNode, selectInitializeCanvas, selectInitializeWithData, selectNavigateToDepth, selectNavigateToSiblingCanvas, selectPreviousCanvas, selectTransitionState, selectUpdateEdges, selectUpdateNodes, selectUpdateSelection, selectUpdateViewport, useCanvasStore } from "../../stores/canvasStore.js";
11
11
  import { viewportManager } from "../../stores/viewportManager.js";
12
12
  import { DefaultCanvasTranslations } from "../../types.js";
13
+ import { inferParentId } from "../../utils/createPreviewGraph.js";
13
14
  import { CanvasIcon } from "../../utils/icon-registry.js";
14
15
  import { prefersReducedMotion } from "../../utils/transitions.js";
15
16
  import { AddNodeManager } from "../AddNodePanel/AddNodeManager.js";
@@ -24,7 +25,7 @@ const DEFAULT_NODE_TYPES = {
24
25
  'blank-canvas-node': BlankCanvasNode,
25
26
  preview: AddNodePreview
26
27
  };
27
- const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onCanvasesChange, onPathChange })=>{
28
+ const HierarchicalCanvas = ({ additionalNodeTypes, mode = 'design', initialCanvases, initialPath, onCanvasesChange, onPathChange })=>{
28
29
  const canvasRef = useRef(null);
29
30
  const containerRef = useRef(null);
30
31
  const [reactFlowInstance, setReactFlowInstance] = useState(null);
@@ -37,14 +38,17 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
37
38
  const shouldAnimate = 'design' === mode && !prefersReducedMotion();
38
39
  const nodeManifests = useNodeManifests();
39
40
  const nodeTypes = useMemo(()=>{
40
- const types = nodeManifests.reduce((acc, manifest)=>{
41
- if (!acc[manifest.nodeType]) acc[manifest.nodeType] = BaseNode;
42
- return acc;
43
- }, {
44
- ...DEFAULT_NODE_TYPES
45
- });
46
- return types;
41
+ const manifestNodeTypes = Object.fromEntries(nodeManifests.map(({ nodeType })=>nodeType).filter((nodeType)=>!Object.hasOwn(DEFAULT_NODE_TYPES, nodeType)).map((nodeType)=>[
42
+ nodeType,
43
+ BaseNode
44
+ ]));
45
+ return {
46
+ ...DEFAULT_NODE_TYPES,
47
+ ...manifestNodeTypes,
48
+ ...additionalNodeTypes
49
+ };
47
50
  }, [
51
+ additionalNodeTypes,
48
52
  nodeManifests
49
53
  ]);
50
54
  const currentCanvas = useCanvasStore(selectCurrentCanvas);
@@ -178,12 +182,18 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
178
182
  const canvas = currentCanvasRef.current;
179
183
  if (!connection.source || !connection.target || !canvas) return;
180
184
  if (connection.target === PREVIEW_NODE_ID || connection.source === PREVIEW_NODE_ID) return;
185
+ const parentId = inferParentId(connection.source, connection.target, canvas.nodes);
181
186
  const newEdge = {
182
187
  id: `${connection.source}-${connection.target}-${Date.now()}`,
183
188
  source: connection.source,
184
189
  target: connection.target,
185
190
  sourceHandle: connection.sourceHandle || void 0,
186
- targetHandle: connection.targetHandle || void 0
191
+ targetHandle: connection.targetHandle || void 0,
192
+ ...parentId ? {
193
+ data: {
194
+ parentId
195
+ }
196
+ } : {}
187
197
  };
188
198
  updateEdges([
189
199
  ...canvas.edges,
@@ -192,7 +202,7 @@ const HierarchicalCanvas = ({ mode = 'design', initialCanvases, initialPath, onC
192
202
  const hasPreview = canvas.nodes.some((n)=>n.id === PREVIEW_NODE_ID);
193
203
  if (hasPreview) {
194
204
  updateNodes(canvas.nodes.filter((n)=>n.id !== PREVIEW_NODE_ID));
195
- updateEdges(canvas.edges.filter((e)=>e.id !== PREVIEW_EDGE_ID));
205
+ updateEdges(canvas.edges.filter((edge)=>edge.source !== PREVIEW_NODE_ID && edge.target !== PREVIEW_NODE_ID));
196
206
  }
197
207
  }, [
198
208
  updateNodes,