windmill-components 1.522.0 → 1.531.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 (271) hide show
  1. package/package/components/AIAgentLogViewer.svelte +123 -0
  2. package/package/components/AIAgentLogViewer.svelte.d.ts +13 -0
  3. package/package/components/AppConnectInner.svelte +10 -10
  4. package/package/components/AutoscalingConfigEditor.svelte +76 -2
  5. package/package/components/Dev.svelte +12 -28
  6. package/package/components/DiffEditor.svelte +6 -3
  7. package/package/components/DiffEditor.svelte.d.ts +1 -0
  8. package/package/components/DisplayResult.svelte +16 -10
  9. package/package/components/DisplayResult.svelte.d.ts +1 -0
  10. package/package/components/EditableSchemaForm.svelte +5 -2
  11. package/package/components/Editor.svelte +26 -8
  12. package/package/components/Editor.svelte.d.ts +1 -1
  13. package/package/components/EditorBar.svelte +25 -5
  14. package/package/components/EditorSettings.svelte +6 -0
  15. package/package/components/FirstStepInputs.svelte +2 -2
  16. package/package/components/FlowBuilder.svelte +18 -36
  17. package/package/components/FlowGraphViewerStep.svelte +7 -0
  18. package/package/components/FlowJobResult.svelte +15 -63
  19. package/package/components/FlowJobResult.svelte.d.ts +10 -4
  20. package/package/components/FlowLogViewer.svelte +660 -0
  21. package/package/components/FlowLogViewer.svelte.d.ts +34 -0
  22. package/package/components/FlowLogViewerWrapper.svelte +52 -0
  23. package/package/components/FlowLogViewerWrapper.svelte.d.ts +21 -0
  24. package/package/components/FlowLoopIterationPreview.svelte +3 -3
  25. package/package/components/FlowPreviewContent.svelte +4 -5
  26. package/package/components/FlowPreviewContent.svelte.d.ts +7 -7
  27. package/package/components/FlowPreviewResult.svelte +4 -5
  28. package/package/components/FlowPreviewResult.svelte.d.ts +3 -5
  29. package/package/components/FlowStatusViewer.svelte +28 -16
  30. package/package/components/FlowStatusViewer.svelte.d.ts +19 -27
  31. package/package/components/FlowStatusViewerInner.svelte +483 -296
  32. package/package/components/FlowStatusViewerInner.svelte.d.ts +27 -33
  33. package/package/components/FlowTimeline.svelte +11 -13
  34. package/package/components/FlowTimeline.svelte.d.ts +6 -5
  35. package/package/components/HighlightCode.svelte +4 -1
  36. package/package/components/IconedResourceType.svelte +9 -5
  37. package/package/components/JobLoader.svelte +61 -8
  38. package/package/components/JobLoader.svelte.d.ts +9 -1
  39. package/package/components/LogViewer.svelte +8 -2
  40. package/package/components/LogViewer.svelte.d.ts +1 -0
  41. package/package/components/LogViewerHeader.svelte +32 -0
  42. package/package/components/LogViewerHeader.svelte.d.ts +8 -0
  43. package/package/components/ModulePreviewForm.svelte +10 -6
  44. package/package/components/ModulePreviewResultViewer.svelte +16 -0
  45. package/package/components/ModulePreviewResultViewer.svelte.d.ts +1 -1
  46. package/package/components/ModuleTest.svelte +59 -16
  47. package/package/components/RelativeLineNumbers.svelte +16 -0
  48. package/package/components/RelativeLineNumbers.svelte.d.ts +18 -0
  49. package/package/components/ResourceEditor.svelte +9 -4
  50. package/package/components/ScriptBuilder.svelte +13 -11
  51. package/package/components/ScriptEditor.svelte +2 -2
  52. package/package/components/SimpleEditor.svelte +10 -4
  53. package/package/components/SimpleEditor.svelte.d.ts +1 -0
  54. package/package/components/TemplateEditor.svelte +1 -1
  55. package/package/components/UserSettings.svelte +4 -4
  56. package/package/components/apps/components/display/AppAccordionList.svelte +1 -1
  57. package/package/components/apps/components/display/AppCarouselList.svelte +10 -8
  58. package/package/components/apps/components/display/AppJobIdFlowStatus.svelte +3 -3
  59. package/package/components/apps/components/display/table/AppAggridTable.svelte +2 -2
  60. package/package/components/apps/components/helpers/HiddenComponent.svelte +0 -1
  61. package/package/components/apps/components/helpers/InputValue.svelte +6 -1
  62. package/package/components/apps/components/helpers/NonRunnableComponent.svelte +8 -4
  63. package/package/components/apps/components/helpers/NonRunnableComponent.svelte.d.ts +1 -1
  64. package/package/components/apps/components/helpers/RunnableComponent.svelte +7 -8
  65. package/package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +1 -1
  66. package/package/components/apps/components/helpers/RunnableWrapper.svelte +12 -3
  67. package/package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +1 -1
  68. package/package/components/apps/components/inputs/AppCodeInputComponent.svelte +0 -5
  69. package/package/components/apps/components/layout/AppConditionalWrapper.svelte +1 -1
  70. package/package/components/apps/components/layout/AppContainer.svelte +1 -1
  71. package/package/components/apps/components/layout/AppDecisionTree.svelte +31 -20
  72. package/package/components/apps/components/layout/AppDrawer.svelte +1 -1
  73. package/package/components/apps/components/layout/AppList.svelte +9 -8
  74. package/package/components/apps/components/layout/AppModal.svelte +1 -1
  75. package/package/components/apps/components/layout/AppSplitpanes.svelte +5 -2
  76. package/package/components/apps/components/layout/AppStepper.svelte +9 -5
  77. package/package/components/apps/components/layout/AppTabs.svelte +2 -2
  78. package/package/components/apps/editor/AppJobsDrawer.svelte +2 -2
  79. package/package/components/apps/editor/GridEditor.svelte +24 -19
  80. package/package/components/apps/editor/GridEditor.svelte.d.ts +4 -1
  81. package/package/components/apps/editor/GridViewer.svelte +1 -1
  82. package/package/components/apps/editor/SubGridEditor.svelte +7 -11
  83. package/package/components/apps/editor/SubGridEditor.svelte.d.ts +3 -19
  84. package/package/components/apps/editor/appUtils.js +17 -68
  85. package/package/components/apps/editor/component/ComponentInner.svelte +845 -694
  86. package/package/components/apps/editor/component/componentCallbacks.svelte.js +8 -1
  87. package/package/components/apps/editor/contextPanel/components/OutputHeader.svelte +9 -46
  88. package/package/components/apps/editor/settingsPanel/DecisionTreeGraphEditor.svelte +29 -43
  89. package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +2 -1
  90. package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte.d.ts +1 -0
  91. package/package/components/apps/editor/settingsPanel/inputEditor/EvalV2InputEditor.svelte +2 -2
  92. package/package/components/apps/editor/settingsPanel/inputEditor/EvalV2InputEditor.svelte.d.ts +1 -0
  93. package/package/components/apps/svelte-grid/Grid.svelte +23 -25
  94. package/package/components/apps/svelte-grid/Grid.svelte.d.ts +21 -9
  95. package/package/components/apps/svelte-grid/MoveResize.svelte +13 -15
  96. package/package/components/apps/svelte-grid/MoveResize.svelte.d.ts +17 -24
  97. package/package/components/apps/utils.d.ts +2 -0
  98. package/package/components/apps/utils.js +22 -0
  99. package/package/components/auditLogs/AuditLogsFilters.svelte.d.ts +1 -1
  100. package/package/components/common/fileDownload/FileDownload.svelte +1 -3
  101. package/package/components/common/fileDownload/FileDownload.svelte.d.ts +4 -18
  102. package/package/components/common/languageIcons/LanguageIcon.svelte +5 -2
  103. package/package/components/copilot/FlowInlineScriptAIButton.svelte +58 -0
  104. package/package/components/copilot/FlowInlineScriptAIButton.svelte.d.ts +3 -0
  105. package/package/components/copilot/MetadataGen.svelte +19 -1
  106. package/package/components/copilot/MetadataGen.svelte.d.ts +1 -1
  107. package/package/components/copilot/ScriptGen.svelte +23 -31
  108. package/package/components/copilot/ScriptGen.svelte.d.ts +0 -1
  109. package/package/components/copilot/autocomplete/Autocompletor.js +2 -0
  110. package/package/components/copilot/chat/AIChatDisplay.svelte +4 -4
  111. package/package/components/copilot/chat/AIChatInput.svelte +29 -6
  112. package/package/components/copilot/chat/AIChatManager.svelte.js +110 -26
  113. package/package/components/copilot/chat/AIChatMessage.svelte +3 -0
  114. package/package/components/copilot/chat/ToolContentDisplay.svelte +84 -0
  115. package/package/components/copilot/chat/ToolContentDisplay.svelte.d.ts +11 -0
  116. package/package/components/copilot/chat/ToolExecutionDisplay.svelte +105 -0
  117. package/package/components/copilot/chat/ToolExecutionDisplay.svelte.d.ts +7 -0
  118. package/package/components/copilot/chat/api/apiTools.d.ts +7 -0
  119. package/package/components/copilot/chat/api/apiTools.js +192 -0
  120. package/package/components/copilot/chat/api/core.d.ts +7 -0
  121. package/package/components/copilot/chat/api/core.js +61 -0
  122. package/package/components/copilot/chat/flow/FlowAIChat.svelte +4 -6
  123. package/package/components/copilot/chat/flow/core.js +213 -42
  124. package/package/components/copilot/chat/flow/utils.js +3 -0
  125. package/package/components/copilot/chat/monaco-adapter.d.ts +1 -1
  126. package/package/components/copilot/chat/monaco-adapter.js +10 -4
  127. package/package/components/copilot/chat/navigator/core.d.ts +1 -1
  128. package/package/components/copilot/chat/navigator/core.js +20 -22
  129. package/package/components/copilot/chat/script/core.d.ts +11 -3
  130. package/package/components/copilot/chat/script/core.js +92 -15
  131. package/package/components/copilot/chat/shared.d.ts +30 -3
  132. package/package/components/copilot/chat/shared.js +228 -9
  133. package/package/components/copilot/lib.d.ts +1 -1
  134. package/package/components/copilot/lib.js +15 -6
  135. package/package/components/custom_ui.d.ts +2 -0
  136. package/package/components/details/DetailPageLayout.svelte +34 -33
  137. package/package/components/flow_builder.d.ts +1 -2
  138. package/package/components/flows/FlowEditor.svelte +3 -3
  139. package/package/components/flows/FlowEditor.svelte.d.ts +7 -6
  140. package/package/components/flows/common/FlowCard.svelte +2 -2
  141. package/package/components/flows/common/FlowCard.svelte.d.ts +1 -0
  142. package/package/components/flows/common/FlowCardHeader.svelte +13 -4
  143. package/package/components/flows/common/FlowCardHeader.svelte.d.ts +1 -0
  144. package/package/components/flows/content/BranchPredicateEditor.svelte +4 -7
  145. package/package/components/flows/content/BranchPredicateEditor.svelte.d.ts +12 -11
  146. package/package/components/flows/content/FlowConstants.svelte +3 -3
  147. package/package/components/flows/content/FlowEditorPanel.svelte +3 -3
  148. package/package/components/flows/content/FlowEditorPanel.svelte.d.ts +2 -4
  149. package/package/components/flows/content/FlowInputsQuick.svelte +2 -1
  150. package/package/components/flows/content/FlowLoop.svelte +2 -2
  151. package/package/components/flows/content/FlowModuleComponent.svelte +130 -108
  152. package/package/components/flows/content/FlowModuleComponent.svelte.d.ts +1 -0
  153. package/package/components/flows/content/FlowModuleEarlyStop.svelte +2 -2
  154. package/package/components/flows/content/FlowModuleSkip.svelte +1 -1
  155. package/package/components/flows/content/FlowModuleSleep.svelte +1 -1
  156. package/package/components/flows/content/FlowModuleSuspend.svelte +1 -1
  157. package/package/components/flows/content/FlowModuleWrapper.svelte +15 -5
  158. package/package/components/flows/content/FlowModuleWrapper.svelte.d.ts +1 -0
  159. package/package/components/flows/content/FlowResult.svelte +2 -3
  160. package/package/components/flows/content/FlowResult.svelte.d.ts +2 -4
  161. package/package/components/flows/content/FlowWhileLoop.svelte +1 -1
  162. package/package/components/flows/dfs.d.ts +3 -1
  163. package/package/components/flows/dfs.js +5 -1
  164. package/package/components/flows/flowInfers.js +78 -0
  165. package/package/components/flows/flowState.d.ts +2 -3
  166. package/package/components/flows/flowState.js +2 -2
  167. package/package/components/flows/flowStateUtils.svelte.d.ts +4 -4
  168. package/package/components/flows/flowStateUtils.svelte.js +14 -13
  169. package/package/components/flows/flowStore.d.ts +3 -4
  170. package/package/components/flows/header/FlowPreviewButtons.svelte +2 -1
  171. package/package/components/flows/header/FlowYamlEditor.svelte +10 -1
  172. package/package/components/flows/map/FlowGraphPreviewButton.svelte +1 -1
  173. package/package/components/flows/map/FlowJobsMenu.svelte +7 -3
  174. package/package/components/flows/map/FlowJobsMenu.svelte.d.ts +1 -0
  175. package/package/components/flows/map/FlowModuleSchemaItem.svelte +12 -12
  176. package/package/components/flows/map/FlowModuleSchemaMap.svelte +26 -19
  177. package/package/components/flows/map/FlowModuleSchemaMap.svelte.d.ts +6 -4
  178. package/package/components/flows/map/InsertModuleInner.svelte +9 -1
  179. package/package/components/flows/map/InsertModuleInner.svelte.d.ts +1 -0
  180. package/package/components/flows/map/MapItem.svelte +4 -2
  181. package/package/components/flows/pickers/TopLevelNode.svelte +4 -1
  182. package/package/components/flows/propPicker/InputPickerInner.svelte +5 -4
  183. package/package/components/flows/propPicker/OutputBadge.svelte +11 -9
  184. package/package/components/flows/propPicker/OutputPickerInner.svelte +10 -1
  185. package/package/components/flows/propPicker/OutputPickerInner.svelte.d.ts +1 -1
  186. package/package/components/flows/testSteps.svelte.d.ts +3 -2
  187. package/package/components/flows/testSteps.svelte.js +26 -23
  188. package/package/components/flows/types.d.ts +1 -1
  189. package/package/components/flows/utils.d.ts +3 -5
  190. package/package/components/flows/utils.js +3 -4
  191. package/package/components/git_sync/GitSyncContext.svelte.js +2 -1
  192. package/package/components/graph/FlowGraphV2.svelte +44 -24
  193. package/package/components/graph/FlowGraphV2.svelte.d.ts +5 -2
  194. package/package/components/graph/graphBuilder.svelte.d.ts +49 -17
  195. package/package/components/graph/graphBuilder.svelte.js +30 -14
  196. package/package/components/graph/model.d.ts +9 -6
  197. package/package/components/graph/renderers/edges/BaseEdge.svelte +3 -3
  198. package/package/components/graph/renderers/edges/BaseEdge.svelte.d.ts +2 -3
  199. package/package/components/graph/renderers/nodes/AIToolNode.svelte +234 -0
  200. package/package/components/graph/renderers/nodes/AIToolNode.svelte.d.ts +24 -0
  201. package/package/components/graph/renderers/nodes/AssetNode.svelte +15 -10
  202. package/package/components/graph/renderers/nodes/AssetNode.svelte.d.ts +18 -1
  203. package/package/components/graph/renderers/nodes/BranchAllEndNode.svelte +1 -1
  204. package/package/components/graph/renderers/nodes/BranchAllStart.svelte +1 -1
  205. package/package/components/graph/renderers/nodes/BranchOneStart.svelte +1 -1
  206. package/package/components/graph/renderers/nodes/ForLoopEndNode.svelte +2 -2
  207. package/package/components/graph/renderers/nodes/ForLoopStartNode.svelte +1 -1
  208. package/package/components/graph/renderers/nodes/ModuleNode.svelte +21 -21
  209. package/package/components/graph/renderers/nodes/NewAIToolNode.svelte +64 -0
  210. package/package/components/graph/renderers/nodes/NewAIToolNode.svelte.d.ts +7 -0
  211. package/package/components/graph/renderers/nodes/branchOneEndNode.svelte +1 -1
  212. package/package/components/icons/RubyIcon.svelte +656 -0
  213. package/package/components/icons/RubyIcon.svelte.d.ts +7 -0
  214. package/package/components/instanceSettings.js +9 -0
  215. package/package/components/modulesTest.svelte.d.ts +6 -3
  216. package/package/components/modulesTest.svelte.js +32 -0
  217. package/package/components/preview/FlowPreviewStatus.svelte +3 -1
  218. package/package/components/raw_apps/RawAppEditor.svelte +27 -26
  219. package/package/components/raw_apps/RawAppEditor.svelte.d.ts +17 -17
  220. package/package/components/runs/{JobPreview.svelte → JobRunsPreview.svelte} +1 -4
  221. package/package/components/runs/{JobPreview.svelte.d.ts → JobRunsPreview.svelte.d.ts} +3 -3
  222. package/package/components/runs/RunRow.svelte +5 -1
  223. package/package/components/schema/AddProperty.svelte +41 -36
  224. package/package/components/schema/AddProperty.svelte.d.ts +2 -2
  225. package/package/components/schema/AddPropertyV2.svelte +41 -37
  226. package/package/components/schema/AddPropertyV2.svelte.d.ts +1 -1
  227. package/package/components/schema/FlowPropertyEditor.svelte +8 -6
  228. package/package/components/search/RunsSearch.svelte +1 -1
  229. package/package/components/settings/CreateToken.svelte +132 -12
  230. package/package/components/settings/CreateToken.svelte.d.ts +3 -20
  231. package/package/components/settings/TokenDisplay.svelte +18 -42
  232. package/package/components/settings/TokenDisplay.svelte.d.ts +0 -1
  233. package/package/components/settings/TokensTable.svelte +2 -4
  234. package/package/components/settings/TokensTable.svelte.d.ts +3 -19
  235. package/package/components/settings/WorkspaceUserSettings.svelte +428 -69
  236. package/package/components/sidebar/MenuButton.svelte +12 -10
  237. package/package/components/stepHistoryLoader.svelte.d.ts +2 -2
  238. package/package/components/stepHistoryLoader.svelte.js +7 -12
  239. package/package/components/triggers/http/OpenAPISpecGenerator.svelte +2 -2
  240. package/package/components/tutorials/FlowBuilderTutorialBranchOne.svelte +1 -1
  241. package/package/components/tutorials/FlowBuilderTutorialForLoop.svelte +4 -4
  242. package/package/components/tutorials/utils.js +3 -0
  243. package/package/components/worker_group.d.ts +4 -1
  244. package/package/components/worker_group.js +3 -2
  245. package/package/editorLangUtils.d.ts +1 -1
  246. package/package/editorLangUtils.js +2 -0
  247. package/package/editorUtils.d.ts +2 -1
  248. package/package/editorUtils.js +2 -1
  249. package/package/gen/core/OpenAPI.js +1 -1
  250. package/package/gen/schemas.gen.d.ts +296 -8
  251. package/package/gen/schemas.gen.js +364 -70
  252. package/package/gen/services.gen.d.ts +118 -16
  253. package/package/gen/services.gen.js +226 -19
  254. package/package/gen/types.gen.d.ts +660 -16
  255. package/package/hubPaths.json +7 -4
  256. package/package/infer.js +10 -1
  257. package/package/monaco_workers/graphql.worker.bundle.js +144 -110
  258. package/package/script_helpers.d.ts +3 -0
  259. package/package/script_helpers.js +58 -3
  260. package/package/scripts.d.ts +1 -1
  261. package/package/scripts.js +3 -2
  262. package/package/stores.d.ts +2 -0
  263. package/package/stores.js +2 -0
  264. package/package/svelte5Utils.svelte.d.ts +16 -0
  265. package/package/svelte5Utils.svelte.js +26 -0
  266. package/package/utils.d.ts +1 -1
  267. package/package.json +20 -19
  268. package/package/components/AllFlowLogs.svelte +0 -31
  269. package/package/components/AllFlowLogs.svelte.d.ts +0 -8
  270. package/package/components/copilot/chat/navigator/apiTools.d.ts +0 -68
  271. package/package/components/copilot/chat/navigator/apiTools.js +0 -258
@@ -5,18 +5,19 @@ export const WRITE_ASSET_Y_OFFSET = 64;
5
5
  export const assetDisplaysAsInputInFlowGraph = (a) => !getAccessType(a) || getAccessType(a) === 'r' || getAccessType(a) === 'rw';
6
6
  export const assetDisplaysAsOutputInFlowGraph = (a) => getAccessType(a) === 'w' || getAccessType(a) === 'rw';
7
7
  let computeAssetNodesCache;
8
- export function computeAssetNodes(nodes, edges) {
9
- if (nodes === computeAssetNodesCache?.[0])
8
+ export function computeAssetNodes(nodes) {
9
+ if (computeAssetNodesCache && deepEqual(nodes, computeAssetNodesCache[0])) {
10
10
  return computeAssetNodesCache[1];
11
+ }
11
12
  const MAX_ASSET_ROW_WIDTH = 300;
12
13
  const ASSETS_OVERFLOWED_NODE_WIDTH = 25;
13
14
  const allAssetNodes = [];
14
15
  const allAssetEdges = [];
15
16
  const yPosMap = {};
16
17
  for (const node of nodes) {
17
- if (node.type !== 'module' && node.type !== 'input2')
18
- continue;
19
18
  const assets = node.data.assets ?? [];
19
+ if (!assets.length)
20
+ continue;
20
21
  // Each asset can be displayed at the top and bottom
21
22
  // i.e once (R or W) or twice (RW)
22
23
  const inputAssets = assets.filter(assetDisplaysAsInputInFlowGraph);
@@ -152,7 +153,9 @@ export function computeAssetNodes(nodes, edges) {
152
153
  });
153
154
  }
154
155
  // Shift all nodes to make space for the new asset nodes
155
- const sortedNewNodes = clone(nodes.sort((a, b) => a.position.y - b.position.y));
156
+ const sortedNewNodes = nodes
157
+ .map((n) => ({ position: { ...n.position }, id: n.id }))
158
+ .sort((a, b) => a.position.y - b.position.y);
156
159
  let currentYOffset = 0;
157
160
  let prevYPos = NaN;
158
161
  for (const node of sortedNewNodes) {
@@ -165,10 +168,11 @@ export function computeAssetNodes(nodes, edges) {
165
168
  }
166
169
  node.position.y += currentYOffset;
167
170
  }
168
- let ret = [
169
- [...sortedNewNodes, ...allAssetNodes],
170
- [...edges, ...allAssetEdges]
171
- ];
171
+ let ret = {
172
+ newAssetNodes: allAssetNodes,
173
+ newAssetEdges: allAssetEdges,
174
+ newNodePositions: Object.fromEntries(sortedNewNodes.map((n) => [n.id, n.position]))
175
+ };
172
176
  computeAssetNodesCache = [nodes, ret];
173
177
  return ret;
174
178
  }
@@ -181,10 +185,11 @@ import { twMerge } from 'tailwind-merge';
181
185
  import { getContext } from 'svelte';
182
186
  import ExploreAssetButton, { assetCanBeExplored } from '../../../ExploreAssetButton.svelte';
183
187
  import { Tooltip } from '../../../meltComponents';
184
- import { clone, pluralize } from '../../../../utils';
188
+ import { pluralize } from '../../../../utils';
185
189
  import AssetGenericIcon from '../../../icons/AssetGenericIcon.svelte';
186
190
  import { NODE } from '../../util';
187
191
  import { userStore } from '../../../../stores';
192
+ import { deepEqual } from 'fast-equals';
188
193
  const flowGraphAssetsCtx = getContext('FlowGraphAssetContext');
189
194
  let { data } = $props();
190
195
  const isSelected = $derived(assetEq(flowGraphAssetsCtx?.val.selectedAsset, data.asset));
@@ -4,7 +4,24 @@ export declare const READ_ASSET_Y_OFFSET = -45;
4
4
  export declare const WRITE_ASSET_Y_OFFSET = 64;
5
5
  export declare const assetDisplaysAsInputInFlowGraph: (a: AssetWithAltAccessType) => boolean;
6
6
  export declare const assetDisplaysAsOutputInFlowGraph: (a: AssetWithAltAccessType) => boolean;
7
- export declare function computeAssetNodes(nodes: (Node & NodeLayout)[], edges: Edge[]): [(Node & NodeLayout)[], Edge[]];
7
+ type NodeDep = {
8
+ data: object & {
9
+ assets?: AssetWithAltAccessType[] | undefined;
10
+ };
11
+ id: string;
12
+ position: {
13
+ x: number;
14
+ y: number;
15
+ };
16
+ };
17
+ export declare function computeAssetNodes(nodes: NodeDep[]): {
18
+ newAssetNodes: (Node & NodeLayout)[];
19
+ newAssetEdges: Edge[];
20
+ newNodePositions: Record<string, {
21
+ x: number;
22
+ y: number;
23
+ }>;
24
+ };
8
25
  import type { AssetN, NodeLayout } from '../../graphBuilder.svelte';
9
26
  import { type AssetWithAltAccessType } from '../../../assets/lib';
10
27
  import type { Edge, Node } from '@xyflow/svelte';
@@ -13,7 +13,7 @@ let { data } = $props();
13
13
  selected={false}
14
14
  bgColor={getStateColor(undefined, darkMode)}
15
15
  bgHoverColor={getStateHoverColor(undefined, darkMode)}
16
- borderColor={getStateColor(data?.flowModuleStates?.[data?.id]?.type, darkMode)}
16
+ borderColor={getStateColor(data?.flowModuleState?.type, darkMode)}
17
17
  on:select={(e) => {
18
18
  data?.eventHandlers?.select(e.detail)
19
19
  }}
@@ -5,7 +5,7 @@ import { X } from 'lucide-svelte';
5
5
  import { getStateColor, getStateHoverColor } from '../../util';
6
6
  import { computeBorderStatus } from '../utils';
7
7
  let { data } = $props();
8
- let borderStatus = $derived(computeBorderStatus(data.branchIndex, 'branchall', data.flowModuleStates?.[data.id]));
8
+ let borderStatus = $derived(computeBorderStatus(data.branchIndex, 'branchall', data.flowModuleState));
9
9
  </script>
10
10
 
11
11
  <NodeWrapper offset={data.offset}>
@@ -5,7 +5,7 @@ import { X } from 'lucide-svelte';
5
5
  import { getStateColor, getStateHoverColor } from '../../util';
6
6
  import { computeBorderStatus } from '../utils';
7
7
  let { data } = $props();
8
- let borderStatus = $derived(computeBorderStatus(data.branchIndex + 1, 'branchone', data.flowModuleStates?.[data.id]));
8
+ let borderStatus = $derived(computeBorderStatus(data.branchIndex + 1, 'branchone', data.flowModuleState));
9
9
  </script>
10
10
 
11
11
  <NodeWrapper offset={data.offset}>
@@ -14,7 +14,7 @@ let { data } = $props();
14
14
  id={data.id}
15
15
  hideId
16
16
  bgColor={getStateColor(undefined, darkMode)}
17
- borderColor={getStateColor(data.flowModuleStates?.[data.id]?.type, darkMode)}
17
+ borderColor={getStateColor(data.flowModuleState?.type, darkMode)}
18
18
  on:select={(e) => {
19
19
  setTimeout(() => data?.eventHandlers?.select(e.detail))
20
20
  }}
@@ -26,7 +26,7 @@ let { data } = $props();
26
26
  selected={false}
27
27
  id={data.id}
28
28
  bgColor={getStateColor(undefined, darkMode)}
29
- borderColor={getStateColor(data.flowModuleStates?.[data.id]?.type, darkMode)}
29
+ borderColor={getStateColor(data.flowModuleState?.type, darkMode)}
30
30
  on:select={(e) => {
31
31
  setTimeout(() => data?.eventHandlers?.select(e.detail))
32
32
  }}
@@ -54,7 +54,7 @@ let filteredInput = $derived(filterIterFromInput($pickablePropertiesFiltered?.fl
54
54
  hideId
55
55
  bgColor={getStateColor(undefined, darkMode)}
56
56
  bgHoverColor={getStateHoverColor(undefined, darkMode)}
57
- borderColor={getStateColor(computeStatus(data.flowModuleStates?.[data.id]), darkMode)}
57
+ borderColor={getStateColor(computeStatus(data.flowModuleState), darkMode)}
58
58
  on:select={(e) => {
59
59
  setTimeout(() => data?.eventHandlers?.select(e.detail))
60
60
  }}
@@ -3,18 +3,23 @@ import MapItem from '../../../flows/map/MapItem.svelte';
3
3
  import { GitBranchPlus, Maximize2 } from 'lucide-svelte';
4
4
  import NodeWrapper from './NodeWrapper.svelte';
5
5
  import { getStateColor, getStateHoverColor } from '../../util';
6
+ import { jobToGraphModuleState } from '../../../modulesTest.svelte';
6
7
  let { data } = $props();
7
- let moduleState = $derived(data.flowModuleStates?.[data.id]);
8
- let flowJobs = $derived(moduleState?.flow_jobs
8
+ let state = $derived.by(() => {
9
+ return data.testModuleState
10
+ ? (jobToGraphModuleState(data.testModuleState) ?? data.flowModuleState)
11
+ : data.flowModuleState;
12
+ });
13
+ let flowJobs = $derived(state?.flow_jobs
9
14
  ? {
10
- flowJobs: moduleState?.flow_jobs,
11
- selected: moduleState?.selectedForloopIndex ?? 0,
12
- selectedManually: moduleState?.selectedForLoopSetManually,
13
- flowJobsSuccess: moduleState?.flow_jobs_success
15
+ flowJobs: state?.flow_jobs,
16
+ selected: state?.selectedForloopIndex ?? 0,
17
+ selectedManually: state?.selectedForLoopSetManually,
18
+ flowJobsSuccess: state?.flow_jobs_success
14
19
  }
15
20
  : undefined);
16
21
  let type = $derived.by(() => {
17
- let typ = data.flowModuleStates?.[data.id]?.type;
22
+ let typ = state?.type;
18
23
  if (!typ && flowJobs) {
19
24
  return 'InProgress';
20
25
  }
@@ -47,27 +52,22 @@ let type = $derived.by(() => {
47
52
  annotation={flowJobs &&
48
53
  (data.module.value.type === 'forloopflow' || data.module.value.type === 'whileloopflow')
49
54
  ? 'Iteration: ' +
50
- ((moduleState?.selectedForloopIndex ?? 0) >= 0
51
- ? (moduleState?.selectedForloopIndex ?? 0) + 1
52
- : moduleState?.flow_jobs?.length) +
55
+ ((state?.selectedForloopIndex ?? 0) >= 0
56
+ ? (state?.selectedForloopIndex ?? 0) + 1
57
+ : state?.flow_jobs?.length) +
53
58
  '/' +
54
- (moduleState?.iteration_total ?? '?')
59
+ (state?.iteration_total ?? '?')
55
60
  : ''}
56
- bgColor={getStateColor(
57
- data.editMode ? undefined : type,
58
- darkMode,
59
- true,
60
- moduleState?.skipped
61
- )}
61
+ bgColor={getStateColor(data.editMode ? undefined : type, darkMode, true, state?.skipped)}
62
62
  bgHoverColor={getStateHoverColor(
63
63
  data.editMode ? undefined : type,
64
64
  darkMode,
65
65
  true,
66
- moduleState?.skipped
66
+ state?.skipped
67
67
  )}
68
68
  moving={data.moving}
69
- duration_ms={moduleState?.duration_ms}
70
- retries={moduleState?.retries}
69
+ duration_ms={state?.duration_ms}
70
+ retries={state?.retries}
71
71
  {flowJobs}
72
72
  on:delete={(e) => {
73
73
  data.eventHandlers.delete(e.detail, '')
@@ -96,7 +96,7 @@ let type = $derived.by(() => {
96
96
  isOwner={data.isOwner}
97
97
  {type}
98
98
  {darkMode}
99
- skipped={moduleState?.skipped}
99
+ skipped={state?.skipped}
100
100
  />
101
101
 
102
102
  <div class="absolute -bottom-10 left-1/2 transform -translate-x-1/2 z-10">
@@ -0,0 +1,64 @@
1
+ <script lang="ts">import { twMerge } from 'tailwind-merge';
2
+ import {} from '../../graphBuilder.svelte';
3
+ import NodeWrapper from './NodeWrapper.svelte';
4
+ import Popover from '../../../meltComponents/Popover.svelte';
5
+ import InsertModuleInner from '../../../flows/map/InsertModuleInner.svelte';
6
+ let funcDesc = $state('');
7
+ let { data } = $props();
8
+ </script>
9
+
10
+ <NodeWrapper>
11
+ {#snippet children({ darkMode })}
12
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
13
+ <Popover
14
+ portal={null}
15
+ usePointerDownOutside
16
+ class={twMerge(
17
+ '!w-full text-2xs font-normal bg-surface h-6 pr-0.5 flex justify-center items-center rounded-sm text-tertiary border',
18
+ 'hover:bg-surface-hover'
19
+ )}
20
+ placement="top"
21
+ >
22
+ <svelte:fragment slot="trigger">+tool</svelte:fragment>
23
+ <svelte:fragment slot="content" let:close>
24
+ <InsertModuleInner
25
+ bind:funcDesc
26
+ scriptOnly
27
+ on:close={() => {
28
+ close()
29
+ }}
30
+ on:new={(e) => {
31
+ data.eventHandlers.insert({
32
+ index: -1, // ignored when agentId is set
33
+ agentId: data.agentModuleId,
34
+ ...e.detail
35
+ })
36
+ close()
37
+ }}
38
+ on:insert={(e) => {
39
+ data.eventHandlers.insert({
40
+ index: -1, // ignored when agentId is set
41
+ agentId: data.agentModuleId,
42
+ ...e.detail
43
+ })
44
+ close()
45
+ }}
46
+ on:pickScript={(e) => {
47
+ data.eventHandlers.insert({
48
+ index: -1, // ignored when agentId is set
49
+ agentId: data.agentModuleId,
50
+ kind: e.detail.kind,
51
+ script: {
52
+ ...e.detail,
53
+ summary: e.detail.summary
54
+ ? e.detail.summary.replace(/\s/, '_').replace(/[^a-zA-Z0-9_]/g, '')
55
+ : e.detail.path.split('/').pop()
56
+ }
57
+ })
58
+ close()
59
+ }}
60
+ />
61
+ </svelte:fragment>
62
+ </Popover>
63
+ {/snippet}
64
+ </NodeWrapper>
@@ -0,0 +1,7 @@
1
+ import { type NewAiToolN } from '../../graphBuilder.svelte';
2
+ interface Props {
3
+ data: NewAiToolN['data'];
4
+ }
5
+ declare const NewAiToolNode: import("svelte").Component<Props, {}, "">;
6
+ type NewAiToolNode = ReturnType<typeof NewAiToolNode>;
7
+ export default NewAiToolNode;
@@ -13,7 +13,7 @@ let { data } = $props();
13
13
  selected={false}
14
14
  bgColor={getStateColor(undefined, darkMode)}
15
15
  bgHoverColor={getStateHoverColor(undefined, darkMode)}
16
- borderColor={getStateColor(data?.flowModuleStates?.[data?.id]?.type, darkMode)}
16
+ borderColor={getStateColor(data?.flowModuleState?.type, darkMode)}
17
17
  on:select={(e) => {
18
18
  setTimeout(() => data?.eventHandlers?.select(e.detail))
19
19
  }}