@uipath/apollo-react 4.13.0 → 4.13.1-pr581.30f7035
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/canvas/components/AddNodePanel/AddNodeManager.cjs +26 -7
- package/dist/canvas/components/AddNodePanel/AddNodeManager.d.ts.map +1 -1
- package/dist/canvas/components/AddNodePanel/AddNodeManager.js +26 -7
- package/dist/canvas/components/AddNodePanel/AddNodePanel.types.d.ts +1 -1
- package/dist/canvas/components/AddNodePanel/AddNodePanel.types.d.ts.map +1 -1
- package/dist/canvas/components/AddNodePanel/index.cjs +2 -6
- package/dist/canvas/components/AddNodePanel/index.d.ts +0 -1
- package/dist/canvas/components/AddNodePanel/index.d.ts.map +1 -1
- package/dist/canvas/components/AddNodePanel/index.js +1 -2
- package/dist/canvas/components/AgentCanvas/agent-flow.manifest.d.ts +1 -0
- package/dist/canvas/components/AgentCanvas/agent-flow.manifest.d.ts.map +1 -1
- package/dist/canvas/components/BaseNode/BaseNode.cjs +25 -10
- package/dist/canvas/components/BaseNode/BaseNode.d.ts +2 -1
- package/dist/canvas/components/BaseNode/BaseNode.d.ts.map +1 -1
- package/dist/canvas/components/BaseNode/BaseNode.js +22 -10
- package/dist/canvas/components/BaseNode/BaseNode.types.d.ts +2 -0
- package/dist/canvas/components/BaseNode/BaseNode.types.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/ButtonHandle.cjs +115 -34
- package/dist/canvas/components/ButtonHandle/ButtonHandle.d.ts +4 -2
- package/dist/canvas/components/ButtonHandle/ButtonHandle.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/ButtonHandle.js +117 -36
- package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.cjs +65 -5
- package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.d.ts +4 -0
- package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/ButtonHandleStyleUtils.js +53 -5
- package/dist/canvas/components/ButtonHandle/HandleButton.cjs +9 -3
- package/dist/canvas/components/ButtonHandle/HandleButton.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/HandleButton.js +9 -3
- package/dist/canvas/components/ButtonHandle/HandleLabel.cjs +11 -4
- package/dist/canvas/components/ButtonHandle/HandleLabel.d.ts +4 -1
- package/dist/canvas/components/ButtonHandle/HandleLabel.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/HandleLabel.js +7 -3
- package/dist/canvas/components/ButtonHandle/SmartHandle.cjs +2 -2
- package/dist/canvas/components/ButtonHandle/SmartHandle.d.ts.map +1 -1
- package/dist/canvas/components/ButtonHandle/SmartHandle.js +2 -2
- package/dist/canvas/components/Edges/SequenceEdge.cjs +3 -2
- package/dist/canvas/components/Edges/SequenceEdge.d.ts +11 -2
- package/dist/canvas/components/Edges/SequenceEdge.d.ts.map +1 -1
- package/dist/canvas/components/Edges/SequenceEdge.js +4 -3
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.cjs +23 -15
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.d.ts +2 -0
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.d.ts.map +1 -1
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvas.js +24 -16
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.cjs +11 -8
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.d.ts.map +1 -1
- package/dist/canvas/components/HierarchicalCanvas/HierarchicalCanvasWithControls.js +11 -8
- package/dist/canvas/components/LoopNode/LoopCanvasNode.cjs +112 -0
- package/dist/canvas/components/LoopNode/LoopCanvasNode.d.ts +6 -0
- package/dist/canvas/components/LoopNode/LoopCanvasNode.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopCanvasNode.js +78 -0
- package/dist/canvas/components/LoopNode/LoopNode.cjs +435 -0
- package/dist/canvas/components/LoopNode/LoopNode.constants.cjs +77 -0
- package/dist/canvas/components/LoopNode/LoopNode.constants.d.ts +12 -0
- package/dist/canvas/components/LoopNode/LoopNode.constants.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopNode.constants.js +13 -0
- package/dist/canvas/components/LoopNode/LoopNode.d.ts +5 -0
- package/dist/canvas/components/LoopNode/LoopNode.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopNode.helpers.cjs +137 -0
- package/dist/canvas/components/LoopNode/LoopNode.helpers.d.ts +26 -0
- package/dist/canvas/components/LoopNode/LoopNode.helpers.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopNode.helpers.js +94 -0
- package/dist/canvas/components/LoopNode/LoopNode.js +401 -0
- package/dist/canvas/components/LoopNode/LoopNode.types.cjs +18 -0
- package/dist/canvas/components/LoopNode/LoopNode.types.d.ts +11 -0
- package/dist/canvas/components/LoopNode/LoopNode.types.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopNode.types.js +0 -0
- package/dist/canvas/components/LoopNode/LoopNodePreview.cjs +61 -0
- package/dist/canvas/components/LoopNode/LoopNodePreview.d.ts +9 -0
- package/dist/canvas/components/LoopNode/LoopNodePreview.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/LoopNodePreview.js +27 -0
- package/dist/canvas/components/LoopNode/index.cjs +72 -0
- package/dist/canvas/components/LoopNode/index.d.ts +4 -0
- package/dist/canvas/components/LoopNode/index.d.ts.map +1 -0
- package/dist/canvas/components/LoopNode/index.js +3 -0
- package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.cjs +34 -25
- package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.d.ts +2 -1
- package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.d.ts.map +1 -1
- package/dist/canvas/components/Toolbar/EdgeToolbar/useEdgeToolbarState.js +35 -26
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.cjs +15 -5
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.d.ts +1 -1
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.d.ts.map +1 -1
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.js +15 -5
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.types.d.ts +1 -0
- package/dist/canvas/components/Toolbar/NodeToolbar/NodeToolbar.types.d.ts.map +1 -1
- package/dist/canvas/components/index.cjs +27 -20
- package/dist/canvas/components/index.d.ts +1 -0
- package/dist/canvas/components/index.d.ts.map +1 -1
- package/dist/canvas/components/index.js +1 -0
- package/dist/canvas/constants.cjs +8 -0
- package/dist/canvas/constants.d.ts +2 -0
- package/dist/canvas/constants.d.ts.map +1 -1
- package/dist/canvas/constants.js +3 -1
- package/dist/canvas/core/CategoryTreeAdapter.cjs +1 -1
- package/dist/canvas/core/CategoryTreeAdapter.js +1 -1
- package/dist/canvas/core/NodeTypeRegistry.cjs +40 -24
- package/dist/canvas/core/NodeTypeRegistry.d.ts +8 -4
- package/dist/canvas/core/NodeTypeRegistry.d.ts.map +1 -1
- package/dist/canvas/core/NodeTypeRegistry.js +40 -24
- package/dist/canvas/core/useNodeTypeRegistry.cjs +4 -3
- package/dist/canvas/core/useNodeTypeRegistry.d.ts +1 -1
- package/dist/canvas/core/useNodeTypeRegistry.d.ts.map +1 -1
- package/dist/canvas/core/useNodeTypeRegistry.js +4 -3
- package/dist/canvas/hooks/useAddNodeOnConnectEnd.cjs +10 -3
- package/dist/canvas/hooks/useAddNodeOnConnectEnd.d.ts.map +1 -1
- package/dist/canvas/hooks/useAddNodeOnConnectEnd.js +10 -3
- package/dist/canvas/hooks/usePreviewNode.cjs +4 -2
- package/dist/canvas/hooks/usePreviewNode.d.ts.map +1 -1
- package/dist/canvas/hooks/usePreviewNode.js +4 -2
- package/dist/canvas/schema/node-definition/handle.cjs +10 -2
- package/dist/canvas/schema/node-definition/handle.d.ts +9 -0
- package/dist/canvas/schema/node-definition/handle.d.ts.map +1 -1
- package/dist/canvas/schema/node-definition/handle.js +6 -1
- package/dist/canvas/schema/node-definition/index.cjs +4 -1
- package/dist/canvas/schema/node-definition/index.d.ts +3 -3
- package/dist/canvas/schema/node-definition/index.d.ts.map +1 -1
- package/dist/canvas/schema/node-definition/index.js +2 -2
- package/dist/canvas/schema/node-definition/node-manifest.d.ts +4 -0
- package/dist/canvas/schema/node-definition/node-manifest.d.ts.map +1 -1
- package/dist/canvas/storybook-utils/manifests/index.d.ts +1 -0
- package/dist/canvas/storybook-utils/manifests/index.d.ts.map +1 -1
- package/dist/canvas/storybook-utils/manifests/node-definitions.d.ts.map +1 -1
- package/dist/canvas/styles/reactflow-reset.css +8 -0
- package/dist/canvas/styles/tailwind.canvas.css +1 -1
- package/dist/canvas/utils/{createPreviewNode.cjs → createPreviewGraph.cjs} +115 -41
- package/dist/canvas/utils/createPreviewGraph.d.ts +43 -0
- package/dist/canvas/utils/createPreviewGraph.d.ts.map +1 -0
- package/dist/canvas/utils/{createPreviewNode.js → createPreviewGraph.js} +95 -36
- package/dist/canvas/utils/index.cjs +10 -10
- package/dist/canvas/utils/index.d.ts +2 -2
- package/dist/canvas/utils/index.d.ts.map +1 -1
- package/dist/canvas/utils/index.js +2 -2
- package/package.json +3 -3
- package/dist/canvas/components/AddNodePanel/createAddNodePreview.cjs +0 -41
- package/dist/canvas/components/AddNodePanel/createAddNodePreview.d.ts +0 -3
- package/dist/canvas/components/AddNodePanel/createAddNodePreview.d.ts.map +0 -1
- package/dist/canvas/components/AddNodePanel/createAddNodePreview.js +0 -7
- package/dist/canvas/utils/createPreviewNode.d.ts +0 -17
- package/dist/canvas/utils/createPreviewNode.d.ts.map +0 -1
|
@@ -5,8 +5,8 @@ import { useCallback, useEffect, useState } from "react";
|
|
|
5
5
|
import { NodeRegistryProvider } from "../../core/index.js";
|
|
6
6
|
import { selectAddNode, selectCurrentCanvas, selectCurrentPathLength, selectRemoveEdge, selectRemoveNode, selectUpdateNodes, useCanvasStore } from "../../stores/canvasStore.js";
|
|
7
7
|
import { canvasEventBus } from "../../utils/CanvasEventBus.js";
|
|
8
|
+
import { showPreviewGraph } from "../../utils/createPreviewGraph.js";
|
|
8
9
|
import { CanvasIcon } from "../../utils/icon-registry.js";
|
|
9
|
-
import { createAddNodePreview } from "../AddNodePanel/createAddNodePreview.js";
|
|
10
10
|
import { HierarchicalCanvas } from "./HierarchicalCanvas.js";
|
|
11
11
|
const createDemoCanvases = ()=>{
|
|
12
12
|
const rootCanvas = {
|
|
@@ -304,13 +304,16 @@ const CanvasWithControlsContent = ({ initialCanvases, initialPath, onCanvasesCha
|
|
|
304
304
|
const removeEdge = useCanvasStore(selectRemoveEdge);
|
|
305
305
|
const updateNodes = useCanvasStore(selectUpdateNodes);
|
|
306
306
|
useEffect(()=>{
|
|
307
|
-
const
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
307
|
+
const unsubscribe = canvasEventBus.on('handle:action', (event)=>{
|
|
308
|
+
showPreviewGraph({
|
|
309
|
+
sourceNodeId: event.nodeId,
|
|
310
|
+
sourceHandleId: event.handleId,
|
|
311
|
+
reactFlowInstance,
|
|
312
|
+
sourceHandleType: 'input' === event.handleType ? 'target' : 'source',
|
|
313
|
+
handlePosition: event.position
|
|
314
|
+
});
|
|
315
|
+
});
|
|
316
|
+
return unsubscribe;
|
|
314
317
|
}, [
|
|
315
318
|
reactFlowInstance
|
|
316
319
|
]);
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
LoopCanvasNode: ()=>LoopCanvasNode
|
|
28
|
+
});
|
|
29
|
+
const jsx_runtime_namespaceObject = require("react/jsx-runtime");
|
|
30
|
+
const react_cjs_namespaceObject = require("../../xyflow/react.cjs");
|
|
31
|
+
const external_react_namespaceObject = require("react");
|
|
32
|
+
const index_cjs_namespaceObject = require("../../core/index.cjs");
|
|
33
|
+
const canvasStore_cjs_namespaceObject = require("../../stores/canvasStore.cjs");
|
|
34
|
+
const NodeUtils_cjs_namespaceObject = require("../../utils/NodeUtils.cjs");
|
|
35
|
+
const external_BaseNode_index_cjs_namespaceObject = require("../BaseNode/index.cjs");
|
|
36
|
+
const external_LoopNode_cjs_namespaceObject = require("./LoopNode.cjs");
|
|
37
|
+
const external_LoopNode_constants_cjs_namespaceObject = require("./LoopNode.constants.cjs");
|
|
38
|
+
const external_LoopNode_helpers_cjs_namespaceObject = require("./LoopNode.helpers.cjs");
|
|
39
|
+
const external_LoopNodePreview_cjs_namespaceObject = require("./LoopNodePreview.cjs");
|
|
40
|
+
function shouldRenderLoopContainer(manifest) {
|
|
41
|
+
return manifest?.handleConfiguration.some((group)=>'inner' === group.boundary) ?? false;
|
|
42
|
+
}
|
|
43
|
+
function LoopCanvasNodeComponent(props) {
|
|
44
|
+
const reactFlow = (0, react_cjs_namespaceObject.useReactFlow)();
|
|
45
|
+
const nodeTypeRegistry = (0, index_cjs_namespaceObject.useOptionalNodeTypeRegistry)();
|
|
46
|
+
const updateNodes = (0, canvasStore_cjs_namespaceObject.useCanvasStore)(canvasStore_cjs_namespaceObject.selectUpdateNodes);
|
|
47
|
+
const nodeVersion = 'string' == typeof props.data?.version ? props.data.version : void 0;
|
|
48
|
+
const loopManifest = (0, external_react_namespaceObject.useMemo)(()=>nodeTypeRegistry?.getManifest(props.type ?? external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_NODE_TYPE, nodeVersion), [
|
|
49
|
+
nodeTypeRegistry,
|
|
50
|
+
props.type,
|
|
51
|
+
nodeVersion
|
|
52
|
+
]);
|
|
53
|
+
const shouldUseLoopContainer = (0, external_react_namespaceObject.useMemo)(()=>shouldRenderLoopContainer(loopManifest), [
|
|
54
|
+
loopManifest
|
|
55
|
+
]);
|
|
56
|
+
const loopPreviewHandles = (0, external_react_namespaceObject.useMemo)(()=>shouldUseLoopContainer ? (0, external_LoopNode_helpers_cjs_namespaceObject.resolveLoopPreviewConnectionHandles)(loopManifest, {
|
|
57
|
+
...props.data ?? {},
|
|
58
|
+
nodeId: props.id
|
|
59
|
+
}) : null, [
|
|
60
|
+
shouldUseLoopContainer,
|
|
61
|
+
loopManifest,
|
|
62
|
+
props.data,
|
|
63
|
+
props.id
|
|
64
|
+
]);
|
|
65
|
+
const handleAddFirstChild = (0, external_react_namespaceObject.useCallback)(()=>{
|
|
66
|
+
if (!loopPreviewHandles) return;
|
|
67
|
+
(0, external_LoopNodePreview_cjs_namespaceObject.showCenteredContainerPreview)({
|
|
68
|
+
containerId: props.id,
|
|
69
|
+
reactFlowInstance: reactFlow,
|
|
70
|
+
previewHandles: loopPreviewHandles
|
|
71
|
+
});
|
|
72
|
+
}, [
|
|
73
|
+
loopPreviewHandles,
|
|
74
|
+
props.id,
|
|
75
|
+
reactFlow
|
|
76
|
+
]);
|
|
77
|
+
const handleResize = (0, external_react_namespaceObject.useCallback)(({ width, height })=>{
|
|
78
|
+
const currentCanvas = (0, canvasStore_cjs_namespaceObject.selectCurrentCanvas)(canvasStore_cjs_namespaceObject.useCanvasStore.getState());
|
|
79
|
+
if (!currentCanvas) return;
|
|
80
|
+
const nextWidth = (0, NodeUtils_cjs_namespaceObject.snapToGrid)(width);
|
|
81
|
+
const nextHeight = (0, NodeUtils_cjs_namespaceObject.snapToGrid)(height);
|
|
82
|
+
updateNodes(currentCanvas.nodes.map((node)=>node.id !== props.id ? node : {
|
|
83
|
+
...node,
|
|
84
|
+
width: nextWidth,
|
|
85
|
+
height: nextHeight,
|
|
86
|
+
style: {
|
|
87
|
+
...node.style ?? {},
|
|
88
|
+
width: nextWidth,
|
|
89
|
+
height: nextHeight
|
|
90
|
+
}
|
|
91
|
+
}));
|
|
92
|
+
}, [
|
|
93
|
+
props.id,
|
|
94
|
+
updateNodes
|
|
95
|
+
]);
|
|
96
|
+
if (loopManifest && !shouldUseLoopContainer) return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_BaseNode_index_cjs_namespaceObject.BaseNode, {
|
|
97
|
+
...props
|
|
98
|
+
});
|
|
99
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_LoopNode_cjs_namespaceObject.LoopNode, {
|
|
100
|
+
...props,
|
|
101
|
+
onAddFirstChild: loopPreviewHandles ? handleAddFirstChild : void 0,
|
|
102
|
+
onResize: handleResize
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
const LoopCanvasNode = /*#__PURE__*/ (0, external_react_namespaceObject.memo)(LoopCanvasNodeComponent);
|
|
106
|
+
exports.LoopCanvasNode = __webpack_exports__.LoopCanvasNode;
|
|
107
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
108
|
+
"LoopCanvasNode"
|
|
109
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
110
|
+
Object.defineProperty(exports, '__esModule', {
|
|
111
|
+
value: true
|
|
112
|
+
});
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Node, NodeProps } from '../../xyflow/react.ts';
|
|
2
|
+
import type { LoopNodeData } from './LoopNode.types';
|
|
3
|
+
declare function LoopCanvasNodeComponent(props: NodeProps<Node<LoopNodeData>>): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export declare const LoopCanvasNode: import("react").MemoExoticComponent<typeof LoopCanvasNodeComponent>;
|
|
5
|
+
export {};
|
|
6
|
+
//# sourceMappingURL=LoopCanvasNode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoopCanvasNode.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/LoopNode/LoopCanvasNode.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,0CAA0C,CAAC;AAWhF,OAAO,KAAK,EAAE,YAAY,EAAiB,MAAM,kBAAkB,CAAC;AAQpE,iBAAS,uBAAuB,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,2CA4EpE;AAED,eAAO,MAAM,cAAc,qEAAgC,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useReactFlow } from "../../xyflow/react.js";
|
|
3
|
+
import { memo, useCallback, useMemo } from "react";
|
|
4
|
+
import { useOptionalNodeTypeRegistry } from "../../core/index.js";
|
|
5
|
+
import { selectCurrentCanvas, selectUpdateNodes, useCanvasStore } from "../../stores/canvasStore.js";
|
|
6
|
+
import { snapToGrid } from "../../utils/NodeUtils.js";
|
|
7
|
+
import { BaseNode } from "../BaseNode/index.js";
|
|
8
|
+
import { LoopNode } from "./LoopNode.js";
|
|
9
|
+
import { DEFAULT_LOOP_NODE_TYPE } from "./LoopNode.constants.js";
|
|
10
|
+
import { resolveLoopPreviewConnectionHandles } from "./LoopNode.helpers.js";
|
|
11
|
+
import { showCenteredContainerPreview } from "./LoopNodePreview.js";
|
|
12
|
+
function shouldRenderLoopContainer(manifest) {
|
|
13
|
+
return manifest?.handleConfiguration.some((group)=>'inner' === group.boundary) ?? false;
|
|
14
|
+
}
|
|
15
|
+
function LoopCanvasNodeComponent(props) {
|
|
16
|
+
const reactFlow = useReactFlow();
|
|
17
|
+
const nodeTypeRegistry = useOptionalNodeTypeRegistry();
|
|
18
|
+
const updateNodes = useCanvasStore(selectUpdateNodes);
|
|
19
|
+
const nodeVersion = 'string' == typeof props.data?.version ? props.data.version : void 0;
|
|
20
|
+
const loopManifest = useMemo(()=>nodeTypeRegistry?.getManifest(props.type ?? DEFAULT_LOOP_NODE_TYPE, nodeVersion), [
|
|
21
|
+
nodeTypeRegistry,
|
|
22
|
+
props.type,
|
|
23
|
+
nodeVersion
|
|
24
|
+
]);
|
|
25
|
+
const shouldUseLoopContainer = useMemo(()=>shouldRenderLoopContainer(loopManifest), [
|
|
26
|
+
loopManifest
|
|
27
|
+
]);
|
|
28
|
+
const loopPreviewHandles = useMemo(()=>shouldUseLoopContainer ? resolveLoopPreviewConnectionHandles(loopManifest, {
|
|
29
|
+
...props.data ?? {},
|
|
30
|
+
nodeId: props.id
|
|
31
|
+
}) : null, [
|
|
32
|
+
shouldUseLoopContainer,
|
|
33
|
+
loopManifest,
|
|
34
|
+
props.data,
|
|
35
|
+
props.id
|
|
36
|
+
]);
|
|
37
|
+
const handleAddFirstChild = useCallback(()=>{
|
|
38
|
+
if (!loopPreviewHandles) return;
|
|
39
|
+
showCenteredContainerPreview({
|
|
40
|
+
containerId: props.id,
|
|
41
|
+
reactFlowInstance: reactFlow,
|
|
42
|
+
previewHandles: loopPreviewHandles
|
|
43
|
+
});
|
|
44
|
+
}, [
|
|
45
|
+
loopPreviewHandles,
|
|
46
|
+
props.id,
|
|
47
|
+
reactFlow
|
|
48
|
+
]);
|
|
49
|
+
const handleResize = useCallback(({ width, height })=>{
|
|
50
|
+
const currentCanvas = selectCurrentCanvas(useCanvasStore.getState());
|
|
51
|
+
if (!currentCanvas) return;
|
|
52
|
+
const nextWidth = snapToGrid(width);
|
|
53
|
+
const nextHeight = snapToGrid(height);
|
|
54
|
+
updateNodes(currentCanvas.nodes.map((node)=>node.id !== props.id ? node : {
|
|
55
|
+
...node,
|
|
56
|
+
width: nextWidth,
|
|
57
|
+
height: nextHeight,
|
|
58
|
+
style: {
|
|
59
|
+
...node.style ?? {},
|
|
60
|
+
width: nextWidth,
|
|
61
|
+
height: nextHeight
|
|
62
|
+
}
|
|
63
|
+
}));
|
|
64
|
+
}, [
|
|
65
|
+
props.id,
|
|
66
|
+
updateNodes
|
|
67
|
+
]);
|
|
68
|
+
if (loopManifest && !shouldUseLoopContainer) return /*#__PURE__*/ jsx(BaseNode, {
|
|
69
|
+
...props
|
|
70
|
+
});
|
|
71
|
+
return /*#__PURE__*/ jsx(LoopNode, {
|
|
72
|
+
...props,
|
|
73
|
+
onAddFirstChild: loopPreviewHandles ? handleAddFirstChild : void 0,
|
|
74
|
+
onResize: handleResize
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
const LoopCanvasNode = /*#__PURE__*/ memo(LoopCanvasNodeComponent);
|
|
78
|
+
export { LoopCanvasNode };
|
|
@@ -0,0 +1,435 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
LoopNode: ()=>LoopNode
|
|
28
|
+
});
|
|
29
|
+
const jsx_runtime_namespaceObject = require("react/jsx-runtime");
|
|
30
|
+
const react_cjs_namespaceObject = require("../../xyflow/react.cjs");
|
|
31
|
+
const apollo_wind_namespaceObject = require("@uipath/apollo-wind");
|
|
32
|
+
const external_react_namespaceObject = require("react");
|
|
33
|
+
const index_cjs_namespaceObject = require("../../core/index.cjs");
|
|
34
|
+
const external_hooks_index_cjs_namespaceObject = require("../../hooks/index.cjs");
|
|
35
|
+
const adornment_resolver_cjs_namespaceObject = require("../../utils/adornment-resolver.cjs");
|
|
36
|
+
const createPreviewGraph_cjs_namespaceObject = require("../../utils/createPreviewGraph.cjs");
|
|
37
|
+
const icon_registry_cjs_namespaceObject = require("../../utils/icon-registry.cjs");
|
|
38
|
+
const manifest_resolver_cjs_namespaceObject = require("../../utils/manifest-resolver.cjs");
|
|
39
|
+
const toolbar_resolver_cjs_namespaceObject = require("../../utils/toolbar-resolver.cjs");
|
|
40
|
+
const BaseCanvasModeProvider_cjs_namespaceObject = require("../BaseCanvas/BaseCanvasModeProvider.cjs");
|
|
41
|
+
const ConnectedHandlesContext_cjs_namespaceObject = require("../BaseCanvas/ConnectedHandlesContext.cjs");
|
|
42
|
+
const SelectionStateContext_cjs_namespaceObject = require("../BaseCanvas/SelectionStateContext.cjs");
|
|
43
|
+
const BaseNode_cjs_namespaceObject = require("../BaseNode/BaseNode.cjs");
|
|
44
|
+
const BaseNodeBadgeSlot_cjs_namespaceObject = require("../BaseNode/BaseNodeBadgeSlot.cjs");
|
|
45
|
+
const BaseNodeContainer_cjs_namespaceObject = require("../BaseNode/BaseNodeContainer.cjs");
|
|
46
|
+
const BaseNodeMissingManifest_cjs_namespaceObject = require("../BaseNode/BaseNodeMissingManifest.cjs");
|
|
47
|
+
const external_ButtonHandle_index_cjs_namespaceObject = require("../ButtonHandle/index.cjs");
|
|
48
|
+
const external_Toolbar_index_cjs_namespaceObject = require("../Toolbar/index.cjs");
|
|
49
|
+
const external_LoopNode_constants_cjs_namespaceObject = require("./LoopNode.constants.cjs");
|
|
50
|
+
const external_LoopNode_helpers_cjs_namespaceObject = require("./LoopNode.helpers.cjs");
|
|
51
|
+
const EMPTY_DATA = {};
|
|
52
|
+
const RESIZE_CONTROLS = [
|
|
53
|
+
{
|
|
54
|
+
position: 'top-left',
|
|
55
|
+
cursor: 'nwse-resize',
|
|
56
|
+
indicatorClassName: 'top-[-5px] left-[-5px]'
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
position: 'top-right',
|
|
60
|
+
cursor: 'nesw-resize',
|
|
61
|
+
indicatorClassName: 'top-[-5px] right-[-5px]'
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
position: 'bottom-left',
|
|
65
|
+
cursor: 'nesw-resize',
|
|
66
|
+
indicatorClassName: 'bottom-[-5px] left-[-5px]'
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
position: 'bottom-right',
|
|
70
|
+
cursor: 'nwse-resize',
|
|
71
|
+
indicatorClassName: 'bottom-[-5px] right-[-5px]'
|
|
72
|
+
}
|
|
73
|
+
];
|
|
74
|
+
const RESIZE_CONTROL_STYLE = {
|
|
75
|
+
background: 'transparent',
|
|
76
|
+
border: 'none',
|
|
77
|
+
zIndex: 100
|
|
78
|
+
};
|
|
79
|
+
const ADORNMENT_SLOT_POSITIONS = [
|
|
80
|
+
'topLeft',
|
|
81
|
+
'topRight',
|
|
82
|
+
'bottomLeft',
|
|
83
|
+
'bottomRight'
|
|
84
|
+
];
|
|
85
|
+
const ADORNMENT_SLOT_SHAPES = {
|
|
86
|
+
topLeft: 'top-left',
|
|
87
|
+
topRight: 'top-right',
|
|
88
|
+
bottomLeft: 'bottom-left',
|
|
89
|
+
bottomRight: 'bottom-right'
|
|
90
|
+
};
|
|
91
|
+
function resolveInteractionState(dragging, selected, isHovered) {
|
|
92
|
+
if (dragging) return 'drag';
|
|
93
|
+
if (selected) return 'selected';
|
|
94
|
+
if (isHovered) return 'hover';
|
|
95
|
+
return 'default';
|
|
96
|
+
}
|
|
97
|
+
function LoopNodeComponent(props) {
|
|
98
|
+
const { id, type = external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_NODE_TYPE, data, selected = false, dragging = false, width = 0, height = 0, onAddFirstChild, onResize: onResizeCallback } = props;
|
|
99
|
+
const updateNodeInternals = (0, react_cjs_namespaceObject.useUpdateNodeInternals)();
|
|
100
|
+
const nodeTypeRegistry = (0, index_cjs_namespaceObject.useOptionalNodeTypeRegistry)();
|
|
101
|
+
const headerRef = (0, external_react_namespaceObject.useRef)(null);
|
|
102
|
+
const [isHovered, setIsHovered] = (0, external_react_namespaceObject.useState)(false);
|
|
103
|
+
const resolvedData = data ?? EMPTY_DATA;
|
|
104
|
+
const nodeVersion = 'string' == typeof resolvedData.version ? resolvedData.version : void 0;
|
|
105
|
+
const suggestionType = resolvedData.suggestionType;
|
|
106
|
+
const manifest = (0, external_react_namespaceObject.useMemo)(()=>nodeTypeRegistry?.getManifest(type, nodeVersion), [
|
|
107
|
+
nodeTypeRegistry,
|
|
108
|
+
type,
|
|
109
|
+
nodeVersion
|
|
110
|
+
]);
|
|
111
|
+
const { mode } = (0, BaseCanvasModeProvider_cjs_namespaceObject.useBaseCanvasMode)();
|
|
112
|
+
const connectedHandleIds = (0, ConnectedHandlesContext_cjs_namespaceObject.useConnectedHandles)(id);
|
|
113
|
+
const { multipleNodesSelected } = (0, SelectionStateContext_cjs_namespaceObject.useSelectionState)();
|
|
114
|
+
const isConnecting = (0, react_cjs_namespaceObject.useStore)(BaseNode_cjs_namespaceObject.selectIsConnecting);
|
|
115
|
+
const needsChildCheck = 'design' === mode && !!onAddFirstChild;
|
|
116
|
+
const hasChildNodes = (0, react_cjs_namespaceObject.useStore)((0, external_react_namespaceObject.useCallback)((state)=>!needsChildCheck || state.nodes.some((node)=>node.parentId === id), [
|
|
117
|
+
id,
|
|
118
|
+
needsChildCheck
|
|
119
|
+
]));
|
|
120
|
+
const executionState = (0, external_hooks_index_cjs_namespaceObject.useNodeExecutionState)(id);
|
|
121
|
+
const validationState = (0, external_hooks_index_cjs_namespaceObject.useElementValidationStatus)(id);
|
|
122
|
+
const statusContext = (0, external_react_namespaceObject.useMemo)(()=>({
|
|
123
|
+
nodeId: id,
|
|
124
|
+
executionState,
|
|
125
|
+
validationState,
|
|
126
|
+
isConnecting,
|
|
127
|
+
isSelected: selected,
|
|
128
|
+
isDragging: dragging,
|
|
129
|
+
mode
|
|
130
|
+
}), [
|
|
131
|
+
dragging,
|
|
132
|
+
executionState,
|
|
133
|
+
id,
|
|
134
|
+
isConnecting,
|
|
135
|
+
mode,
|
|
136
|
+
selected,
|
|
137
|
+
validationState
|
|
138
|
+
]);
|
|
139
|
+
const executionStatus = 'string' == typeof executionState ? executionState : executionState?.status;
|
|
140
|
+
const display = (0, external_react_namespaceObject.useMemo)(()=>(0, manifest_resolver_cjs_namespaceObject.resolveDisplay)(manifest?.display, {
|
|
141
|
+
...resolvedData,
|
|
142
|
+
nodeId: id
|
|
143
|
+
}), [
|
|
144
|
+
manifest?.display,
|
|
145
|
+
id,
|
|
146
|
+
resolvedData
|
|
147
|
+
]);
|
|
148
|
+
const displayTitle = display.label ?? external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_TITLE;
|
|
149
|
+
const minWidth = external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_MIN_WIDTH;
|
|
150
|
+
const minHeight = external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_MIN_HEIGHT;
|
|
151
|
+
const headerIcon = (0, external_react_namespaceObject.useMemo)(()=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(icon_registry_cjs_namespaceObject.CanvasIcon, {
|
|
152
|
+
icon: display.icon ?? external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_ICON,
|
|
153
|
+
size: 16
|
|
154
|
+
}), [
|
|
155
|
+
display.icon
|
|
156
|
+
]);
|
|
157
|
+
const toolbarConfig = (0, external_react_namespaceObject.useMemo)(()=>manifest ? (0, toolbar_resolver_cjs_namespaceObject.resolveToolbar)(manifest, statusContext, data) : void 0, [
|
|
158
|
+
data,
|
|
159
|
+
manifest,
|
|
160
|
+
statusContext
|
|
161
|
+
]);
|
|
162
|
+
const adornments = (0, external_react_namespaceObject.useMemo)(()=>(0, adornment_resolver_cjs_namespaceObject.resolveAdornments)(statusContext), [
|
|
163
|
+
statusContext
|
|
164
|
+
]);
|
|
165
|
+
const resolvedHandleGroups = (0, external_react_namespaceObject.useMemo)(()=>manifest ? (0, manifest_resolver_cjs_namespaceObject.resolveHandles)(manifest.handleConfiguration, resolvedData) : [], [
|
|
166
|
+
manifest,
|
|
167
|
+
resolvedData
|
|
168
|
+
]);
|
|
169
|
+
const { outer: outerHandleGroups, inner: innerHandleGroups } = (0, external_react_namespaceObject.useMemo)(()=>(0, external_LoopNode_helpers_cjs_namespaceObject.partitionLoopHandleGroups)(resolvedHandleGroups), [
|
|
170
|
+
resolvedHandleGroups
|
|
171
|
+
]);
|
|
172
|
+
const handleGroupVariants = [
|
|
173
|
+
[
|
|
174
|
+
'outer',
|
|
175
|
+
outerHandleGroups
|
|
176
|
+
],
|
|
177
|
+
[
|
|
178
|
+
'inner',
|
|
179
|
+
innerHandleGroups
|
|
180
|
+
]
|
|
181
|
+
];
|
|
182
|
+
(0, external_react_namespaceObject.useEffect)(()=>{
|
|
183
|
+
const frameId = requestAnimationFrame(()=>{
|
|
184
|
+
updateNodeInternals(id);
|
|
185
|
+
});
|
|
186
|
+
return ()=>{
|
|
187
|
+
cancelAnimationFrame(frameId);
|
|
188
|
+
};
|
|
189
|
+
}, [
|
|
190
|
+
id,
|
|
191
|
+
innerHandleGroups,
|
|
192
|
+
outerHandleGroups,
|
|
193
|
+
updateNodeInternals,
|
|
194
|
+
width,
|
|
195
|
+
height
|
|
196
|
+
]);
|
|
197
|
+
const handleResize = (0, external_react_namespaceObject.useCallback)((_event, params)=>{
|
|
198
|
+
onResizeCallback?.({
|
|
199
|
+
width: params.width,
|
|
200
|
+
height: params.height
|
|
201
|
+
});
|
|
202
|
+
}, [
|
|
203
|
+
onResizeCallback
|
|
204
|
+
]);
|
|
205
|
+
const handleEmptyClick = (0, external_react_namespaceObject.useCallback)(()=>{
|
|
206
|
+
onAddFirstChild?.();
|
|
207
|
+
}, [
|
|
208
|
+
onAddFirstChild
|
|
209
|
+
]);
|
|
210
|
+
const handleMouseEnter = (0, external_react_namespaceObject.useCallback)(()=>setIsHovered(true), []);
|
|
211
|
+
const handleMouseLeave = (0, external_react_namespaceObject.useCallback)(()=>setIsHovered(false), []);
|
|
212
|
+
const handleOuterHandleAction = (0, external_react_namespaceObject.useCallback)((_event)=>{
|
|
213
|
+
setIsHovered(false);
|
|
214
|
+
}, []);
|
|
215
|
+
const shouldShowHandles = (isConnecting || selected || isHovered) && !dragging;
|
|
216
|
+
const showHandleAddButtons = 'design' === mode && !multipleNodesSelected && !isConnecting && !dragging;
|
|
217
|
+
const showResizeControls = selected && !dragging && 'design' === mode;
|
|
218
|
+
const showEmptyStateButton = 'design' === mode && !hasChildNodes && !!onAddFirstChild;
|
|
219
|
+
const interactionState = resolveInteractionState(dragging, selected, isHovered);
|
|
220
|
+
if (!manifest) return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
221
|
+
className: "relative",
|
|
222
|
+
style: {
|
|
223
|
+
width,
|
|
224
|
+
height,
|
|
225
|
+
minWidth,
|
|
226
|
+
minHeight
|
|
227
|
+
},
|
|
228
|
+
onMouseEnter: handleMouseEnter,
|
|
229
|
+
onMouseLeave: handleMouseLeave,
|
|
230
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(BaseNodeMissingManifest_cjs_namespaceObject.MissingManifestNode, {
|
|
231
|
+
type: type,
|
|
232
|
+
isSelected: selected,
|
|
233
|
+
isHovered: isHovered,
|
|
234
|
+
interactionState: interactionState
|
|
235
|
+
})
|
|
236
|
+
});
|
|
237
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)("div", {
|
|
238
|
+
"data-loop-container": true,
|
|
239
|
+
"data-selected": selected ? 'true' : 'false',
|
|
240
|
+
"data-execution-status": executionStatus,
|
|
241
|
+
"data-interaction-state": interactionState,
|
|
242
|
+
"data-suggestion-type": suggestionType,
|
|
243
|
+
"data-validation-status": validationState?.validationStatus,
|
|
244
|
+
"aria-busy": resolvedData.loading || void 0,
|
|
245
|
+
className: (0, apollo_wind_namespaceObject.cn)('group/loop-shell relative flex h-full w-full flex-col overflow-visible border bg-surface-overlay', 'transition-[border-color,box-shadow,opacity] shadow-(--canvas-node-shadow-rest)', 'border-border-subtle', (0, BaseNodeContainer_cjs_namespaceObject.getStatusBorder)(suggestionType ?? validationState?.validationStatus ?? executionStatus), isHovered && 'shadow-(--canvas-node-shadow-hover) border-border-hover', selected && 'outline outline-foreground-accent-muted', 'drag' === interactionState && 'cursor-grabbing shadow-(--canvas-node-shadow-lifted)'),
|
|
246
|
+
style: {
|
|
247
|
+
width,
|
|
248
|
+
height,
|
|
249
|
+
minWidth,
|
|
250
|
+
minHeight,
|
|
251
|
+
borderRadius: external_LoopNode_constants_cjs_namespaceObject.LOOP_SHELL_RADIUS_PX,
|
|
252
|
+
background: display.background ?? external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_SHELL_BACKGROUND
|
|
253
|
+
},
|
|
254
|
+
onMouseEnter: handleMouseEnter,
|
|
255
|
+
onMouseLeave: handleMouseLeave,
|
|
256
|
+
children: [
|
|
257
|
+
ADORNMENT_SLOT_POSITIONS.map((slot)=>adornments?.[slot] ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(BaseNodeBadgeSlot_cjs_namespaceObject.BaseBadgeSlot, {
|
|
258
|
+
position: ADORNMENT_SLOT_SHAPES[slot],
|
|
259
|
+
shape: "rectangle",
|
|
260
|
+
children: adornments[slot]
|
|
261
|
+
}, slot) : null),
|
|
262
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(ResizeCornerIndicators, {
|
|
263
|
+
selected: showResizeControls
|
|
264
|
+
}),
|
|
265
|
+
showResizeControls ? RESIZE_CONTROLS.map(({ position, cursor })=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(react_cjs_namespaceObject.NodeResizeControl, {
|
|
266
|
+
style: RESIZE_CONTROL_STYLE,
|
|
267
|
+
position: position,
|
|
268
|
+
minWidth: minWidth,
|
|
269
|
+
minHeight: minHeight,
|
|
270
|
+
onResize: handleResize,
|
|
271
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
272
|
+
className: "absolute bottom-0 right-0 h-5 w-5 pointer-events-auto",
|
|
273
|
+
style: {
|
|
274
|
+
cursor
|
|
275
|
+
}
|
|
276
|
+
})
|
|
277
|
+
}, position)) : null,
|
|
278
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(Header, {
|
|
279
|
+
headerRef: headerRef,
|
|
280
|
+
title: displayTitle,
|
|
281
|
+
icon: headerIcon,
|
|
282
|
+
loading: !!resolvedData.loading
|
|
283
|
+
}),
|
|
284
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(BodyFrame, {
|
|
285
|
+
isEmpty: showEmptyStateButton,
|
|
286
|
+
isLoading: !!resolvedData.loading,
|
|
287
|
+
onAddFirstChild: handleEmptyClick
|
|
288
|
+
}),
|
|
289
|
+
toolbarConfig && /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_Toolbar_index_cjs_namespaceObject.NodeToolbar, {
|
|
290
|
+
nodeId: id,
|
|
291
|
+
config: toolbarConfig,
|
|
292
|
+
expanded: selected || isHovered,
|
|
293
|
+
hidden: dragging || multipleNodesSelected
|
|
294
|
+
}),
|
|
295
|
+
handleGroupVariants.map(([variant, groups])=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(HandleGroups, {
|
|
296
|
+
nodeId: id,
|
|
297
|
+
groups: groups,
|
|
298
|
+
variant: variant,
|
|
299
|
+
selected: selected,
|
|
300
|
+
hovered: isHovered,
|
|
301
|
+
shouldShowHandles: shouldShowHandles,
|
|
302
|
+
showAddButton: showHandleAddButtons,
|
|
303
|
+
showNotches: shouldShowHandles,
|
|
304
|
+
nodeWidth: width,
|
|
305
|
+
nodeHeight: height,
|
|
306
|
+
connectedHandleIds: connectedHandleIds,
|
|
307
|
+
onOuterHandleAction: handleOuterHandleAction
|
|
308
|
+
}, variant))
|
|
309
|
+
]
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
const LoopNode = /*#__PURE__*/ (0, external_react_namespaceObject.memo)(LoopNodeComponent);
|
|
313
|
+
function Header({ headerRef, title, icon, loading }) {
|
|
314
|
+
const titleContent = loading ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
315
|
+
className: "h-5 w-28 animate-pulse rounded bg-(--canvas-background-overlay)"
|
|
316
|
+
}) : /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("span", {
|
|
317
|
+
className: "truncate text-[14px] font-semibold tracking-[-0.15px]",
|
|
318
|
+
children: title
|
|
319
|
+
});
|
|
320
|
+
let iconContent = null;
|
|
321
|
+
if (loading) iconContent = /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
322
|
+
className: "h-4 w-4 shrink-0 animate-pulse rounded bg-(--canvas-background-overlay)"
|
|
323
|
+
});
|
|
324
|
+
else if (icon) iconContent = /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("span", {
|
|
325
|
+
className: "shrink-0 text-foreground",
|
|
326
|
+
"aria-hidden": true,
|
|
327
|
+
children: icon
|
|
328
|
+
});
|
|
329
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
330
|
+
ref: headerRef,
|
|
331
|
+
className: "flex shrink-0 items-center justify-between gap-2.5 pl-4.5 pr-5 pt-3.5 text-foreground cursor-grab active:cursor-grabbing",
|
|
332
|
+
"data-testid": "loop-node-header",
|
|
333
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)("div", {
|
|
334
|
+
className: "flex min-w-0 items-center gap-2",
|
|
335
|
+
children: [
|
|
336
|
+
iconContent,
|
|
337
|
+
titleContent
|
|
338
|
+
]
|
|
339
|
+
})
|
|
340
|
+
});
|
|
341
|
+
}
|
|
342
|
+
function EmptyState({ onAddFirstChild }) {
|
|
343
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("button", {
|
|
344
|
+
type: "button",
|
|
345
|
+
onClick: onAddFirstChild,
|
|
346
|
+
"aria-label": "Add node to loop",
|
|
347
|
+
className: (0, apollo_wind_namespaceObject.cn)('nodrag nopan', 'pointer-events-auto flex h-8 w-8 items-center justify-center rounded-xl', 'border border-border bg-surface-overlay text-foreground', 'shadow-(--canvas-node-shadow-lifted)', 'transition-colors', 'hover:bg-surface-hover hover:border-brand'),
|
|
348
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(icon_registry_cjs_namespaceObject.CanvasIcon, {
|
|
349
|
+
icon: "plus",
|
|
350
|
+
size: 14
|
|
351
|
+
})
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
function BodyFrame({ isEmpty, isLoading, onAddFirstChild }) {
|
|
355
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)("div", {
|
|
356
|
+
"data-testid": "loop-body-frame",
|
|
357
|
+
"data-empty": isEmpty ? 'true' : 'false',
|
|
358
|
+
className: (0, apollo_wind_namespaceObject.cn)('relative flex flex-1 rounded-[26px] border border-dashed', 'pointer-events-none', isEmpty && 'items-center justify-center'),
|
|
359
|
+
style: {
|
|
360
|
+
margin: external_LoopNode_constants_cjs_namespaceObject.LOOP_FRAME_INSET_PX,
|
|
361
|
+
background: external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_FRAME_BACKGROUND,
|
|
362
|
+
borderColor: external_LoopNode_constants_cjs_namespaceObject.DEFAULT_LOOP_FRAME_BORDER
|
|
363
|
+
},
|
|
364
|
+
children: [
|
|
365
|
+
isLoading ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
366
|
+
className: "m-6 h-14 w-full animate-pulse rounded-[18px] bg-(--canvas-background-overlay)"
|
|
367
|
+
}) : null,
|
|
368
|
+
isEmpty ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(EmptyState, {
|
|
369
|
+
onAddFirstChild: onAddFirstChild
|
|
370
|
+
}) : null
|
|
371
|
+
]
|
|
372
|
+
});
|
|
373
|
+
}
|
|
374
|
+
function ResizeCornerIndicators({ selected }) {
|
|
375
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(jsx_runtime_namespaceObject.Fragment, {
|
|
376
|
+
children: RESIZE_CONTROLS.map(({ position, indicatorClassName })=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
377
|
+
"aria-hidden": true,
|
|
378
|
+
className: (0, apollo_wind_namespaceObject.cn)('pointer-events-none absolute h-1.5 w-1.5 rounded-[1px] border border-brand bg-background transition-opacity', indicatorClassName, selected ? 'opacity-100' : 'opacity-0')
|
|
379
|
+
}, position))
|
|
380
|
+
});
|
|
381
|
+
}
|
|
382
|
+
function HandleGroups({ nodeId, variant, groups, selected, hovered, shouldShowHandles, showAddButton, showNotches, nodeWidth, nodeHeight, connectedHandleIds, onOuterHandleAction }) {
|
|
383
|
+
if (0 === groups.length) return null;
|
|
384
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(jsx_runtime_namespaceObject.Fragment, {
|
|
385
|
+
children: groups.map((group, groupIndex)=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(HandleGroup, {
|
|
386
|
+
nodeId: nodeId,
|
|
387
|
+
variant: variant,
|
|
388
|
+
group: group,
|
|
389
|
+
selected: selected,
|
|
390
|
+
hovered: hovered,
|
|
391
|
+
shouldShowHandles: shouldShowHandles,
|
|
392
|
+
showAddButton: showAddButton,
|
|
393
|
+
showNotches: showNotches,
|
|
394
|
+
nodeWidth: nodeWidth,
|
|
395
|
+
nodeHeight: nodeHeight,
|
|
396
|
+
connectedHandleIds: connectedHandleIds,
|
|
397
|
+
onOuterHandleAction: onOuterHandleAction
|
|
398
|
+
}, `${variant}:${group.position}:${groupIndex}`))
|
|
399
|
+
});
|
|
400
|
+
}
|
|
401
|
+
function HandleGroup({ nodeId, variant, group, selected, hovered, shouldShowHandles, showAddButton, showNotches, nodeWidth, nodeHeight, connectedHandleIds, onOuterHandleAction }) {
|
|
402
|
+
const groupVisible = shouldShowHandles && (group.visible ?? true);
|
|
403
|
+
const enhancedHandles = (0, external_react_namespaceObject.useMemo)(()=>group.handles.map((handle)=>({
|
|
404
|
+
...handle,
|
|
405
|
+
showHandle: connectedHandleIds.has(handle.id) || groupVisible,
|
|
406
|
+
showButton: 'inner' === variant && 'source' === handle.type ? false : handle.showButton,
|
|
407
|
+
onAction: handle.onAction ?? ('inner' !== variant && 'source' === handle.type && handle.showButton ? onOuterHandleAction : void 0)
|
|
408
|
+
})), [
|
|
409
|
+
group.handles,
|
|
410
|
+
connectedHandleIds,
|
|
411
|
+
groupVisible,
|
|
412
|
+
onOuterHandleAction,
|
|
413
|
+
variant
|
|
414
|
+
]);
|
|
415
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_ButtonHandle_index_cjs_namespaceObject.ButtonHandles, {
|
|
416
|
+
nodeId: nodeId,
|
|
417
|
+
handles: enhancedHandles,
|
|
418
|
+
position: group.position,
|
|
419
|
+
connectionPosition: 'inner' === variant ? (0, createPreviewGraph_cjs_namespaceObject.getOppositePosition)(group.position) : group.position,
|
|
420
|
+
selected: selected,
|
|
421
|
+
hovered: hovered,
|
|
422
|
+
showAddButton: showAddButton,
|
|
423
|
+
showNotches: showNotches,
|
|
424
|
+
customPositionAndOffsets: group.customPositionAndOffsets,
|
|
425
|
+
nodeWidth: nodeWidth,
|
|
426
|
+
nodeHeight: nodeHeight
|
|
427
|
+
});
|
|
428
|
+
}
|
|
429
|
+
exports.LoopNode = __webpack_exports__.LoopNode;
|
|
430
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
431
|
+
"LoopNode"
|
|
432
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
433
|
+
Object.defineProperty(exports, '__esModule', {
|
|
434
|
+
value: true
|
|
435
|
+
});
|