windmill-components 1.542.5 → 1.555.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 (399) hide show
  1. package/package/aiStore.d.ts +13 -0
  2. package/package/aiStore.js +70 -0
  3. package/package/common.d.ts +6 -2
  4. package/package/components/AIAgentLogViewer.svelte +1 -1
  5. package/package/components/AIProviderPicker.svelte +25 -8
  6. package/package/components/ArgEnum.svelte +17 -7
  7. package/package/components/ArgEnum.svelte.d.ts +1 -0
  8. package/package/components/ArgInput.svelte +257 -188
  9. package/package/components/ArgInput.svelte.d.ts +4 -1
  10. package/package/components/ArrayTypeNarrowing.svelte +38 -32
  11. package/package/components/AutoscalingEvents.svelte +21 -5
  12. package/package/components/AutoscalingEvents.svelte.d.ts +4 -18
  13. package/package/components/ChannelSelector.svelte +92 -18
  14. package/package/components/ChannelSelector.svelte.d.ts +2 -0
  15. package/package/components/ConnectionSection.svelte +12 -1
  16. package/package/components/DateTimeInput.svelte +8 -6
  17. package/package/components/DeployButton.svelte +1 -1
  18. package/package/components/Dev.svelte +24 -9
  19. package/package/components/Dev.svelte.d.ts +23 -1
  20. package/package/components/DisplayResult.svelte +36 -23
  21. package/package/components/DropdownV2.svelte +8 -2
  22. package/package/components/DropdownV2.svelte.d.ts +1 -0
  23. package/package/components/DynamicInput.svelte +10 -10
  24. package/package/components/EditableSchemaForm.svelte +28 -13
  25. package/package/components/Editor.svelte +2 -1
  26. package/package/components/EditorSettings.svelte +5 -5
  27. package/package/components/EditorSettings.svelte.d.ts +4 -18
  28. package/package/components/ErrorOrRecoveryHandler.svelte +14 -20
  29. package/package/components/FakeMonacoPlaceHolder.svelte +4 -2
  30. package/package/components/FakeMonacoPlaceHolder.svelte.d.ts +1 -0
  31. package/package/components/FieldHeader.svelte +5 -7
  32. package/package/components/FirstStepInputs.svelte +1 -1
  33. package/package/components/FlowHistoryJobPicker.svelte +3 -0
  34. package/package/components/FlowHistoryJobPicker.svelte.d.ts +1 -0
  35. package/package/components/FlowJobResult.svelte +5 -5
  36. package/package/components/FlowLogRow.svelte +2 -2
  37. package/package/components/FlowLogViewer.svelte +228 -57
  38. package/package/components/FlowLogViewer.svelte.d.ts +16 -5
  39. package/package/components/FlowLogViewerWrapper.svelte +56 -3
  40. package/package/components/FlowLogViewerWrapper.svelte.d.ts +4 -3
  41. package/package/components/FlowLoopIterationPreview.svelte +4 -4
  42. package/package/components/FlowLoopIterationPreview.svelte.d.ts +1 -1
  43. package/package/components/FlowMetadata.svelte +3 -4
  44. package/package/components/FlowMetadata.svelte.d.ts +4 -18
  45. package/package/components/FlowPlugConnect.svelte +8 -2
  46. package/package/components/FlowPlugConnect.svelte.d.ts +1 -0
  47. package/package/components/FlowPreviewContent.svelte +121 -94
  48. package/package/components/FlowPreviewContent.svelte.d.ts +3 -3
  49. package/package/components/FlowStatusViewer.svelte +63 -59
  50. package/package/components/FlowStatusViewer.svelte.d.ts +2 -2
  51. package/package/components/FlowStatusViewerInner.svelte +186 -94
  52. package/package/components/FlowStatusViewerInner.svelte.d.ts +10 -3
  53. package/package/components/FlowTimeline.svelte +110 -131
  54. package/package/components/FlowTimeline.svelte.d.ts +13 -4
  55. package/package/components/FlowTimelineBar.svelte +227 -0
  56. package/package/components/FlowTimelineBar.svelte.d.ts +24 -0
  57. package/package/components/FolderEditor.svelte +6 -7
  58. package/package/components/GroupEditor.svelte +148 -141
  59. package/package/components/GroupEditor.svelte.d.ts +5 -4
  60. package/package/components/InputTransformForm.svelte +193 -71
  61. package/package/components/InputTransformForm.svelte.d.ts +3 -0
  62. package/package/components/InputTransformSchemaForm.svelte +10 -5
  63. package/package/components/InputTransformSchemaForm.svelte.d.ts +2 -0
  64. package/package/components/InstanceSetting.svelte +34 -51
  65. package/package/components/InstanceSettings.svelte +12 -21
  66. package/package/components/JobArgs.svelte +15 -16
  67. package/package/components/JobArgs.svelte.d.ts +4 -18
  68. package/package/components/JobLoader.svelte +23 -42
  69. package/package/components/JobLoader.svelte.d.ts +2 -0
  70. package/package/components/JobStatus.svelte +1 -1
  71. package/package/components/JobStatus.svelte.d.ts +4 -18
  72. package/package/components/JsonEditor.svelte +18 -9
  73. package/package/components/JsonEditor.svelte.d.ts +1 -1
  74. package/package/components/JsonInputs.svelte +1 -1
  75. package/package/components/ModulePreviewForm.svelte +23 -19
  76. package/package/components/ModulePreviewResultViewer.svelte +1 -7
  77. package/package/components/NextcloudSetting.svelte +6 -1
  78. package/package/components/NumberTypeNarrowing.svelte +32 -16
  79. package/package/components/ObjectStoreConfigSettings.svelte +27 -19
  80. package/package/components/Password.svelte +7 -11
  81. package/package/components/Password.svelte.d.ts +5 -20
  82. package/package/components/PasswordArgInput.svelte +35 -15
  83. package/package/components/PasswordArgInput.svelte.d.ts +4 -18
  84. package/package/components/Path.svelte +2 -8
  85. package/package/components/Path.svelte.d.ts +1 -1
  86. package/package/components/QueuePosition.svelte +6 -2
  87. package/package/components/ResourceEditor.svelte +3 -10
  88. package/package/components/ResourcePicker.svelte +85 -72
  89. package/package/components/ResourcePicker.svelte.d.ts +2 -0
  90. package/package/components/RunChart.svelte +1 -1
  91. package/package/components/RunForm.svelte +16 -21
  92. package/package/components/S3ArrayHelperButton.svelte +18 -0
  93. package/package/components/S3ArrayHelperButton.svelte.d.ts +9 -0
  94. package/package/components/S3FilePicker.svelte +1 -1
  95. package/package/components/SchemaForm.svelte +18 -10
  96. package/package/components/SchemaForm.svelte.d.ts +7 -1
  97. package/package/components/SchemaFormWithArgPicker.svelte +1 -1
  98. package/package/components/ScriptBuilder.svelte +2 -2
  99. package/package/components/ScriptEditor.svelte +9 -9
  100. package/package/components/ScriptEditor.svelte.d.ts +1 -1
  101. package/package/components/ShareModal.svelte +4 -4
  102. package/package/components/SimpleEditor.svelte +6 -2
  103. package/package/components/SimpleEditor.svelte.d.ts +3 -0
  104. package/package/components/StringTypeNarrowing.svelte +44 -25
  105. package/package/components/StringTypeNarrowing.svelte.d.ts +1 -1
  106. package/package/components/SuperadminSettingsInner.svelte +3 -3
  107. package/package/components/TeamSelector.svelte +83 -37
  108. package/package/components/TeamSelector.svelte.d.ts +0 -1
  109. package/package/components/TemplateEditor.svelte +18 -9
  110. package/package/components/Toast.svelte +2 -7
  111. package/package/components/Toast.svelte.d.ts +4 -18
  112. package/package/components/Toggle.svelte +17 -7
  113. package/package/components/ToggleHubWorkspaceQuick.svelte +3 -3
  114. package/package/components/WorkerGroup.svelte +2 -14
  115. package/package/components/apps/components/buttons/AppButton.svelte +66 -38
  116. package/package/components/apps/components/display/dbtable/InsertRow.svelte +32 -2
  117. package/package/components/apps/components/display/dbtable/queries/insert.js +2 -1
  118. package/package/components/apps/components/display/dbtable/utils.d.ts +8 -8
  119. package/package/components/apps/components/display/table/AppAggridInfiniteTable.svelte +13 -4
  120. package/package/components/apps/components/display/table/SyncColumnDefs.svelte +2 -2
  121. package/package/components/apps/components/display/table/utils.js +14 -4
  122. package/package/components/apps/components/helpers/RefreshButton.svelte +5 -1
  123. package/package/components/apps/components/helpers/RunnableComponent.svelte +3 -5
  124. package/package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +1 -0
  125. package/package/components/apps/components/inputs/currency/CurrencyInput.svelte +2 -1
  126. package/package/components/apps/components/layout/AppTabs.svelte +116 -71
  127. package/package/components/apps/components/layout/AppTabs.svelte.d.ts +1 -0
  128. package/package/components/apps/editor/AppEditorHeader.svelte +33 -271
  129. package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +233 -0
  130. package/package/components/apps/editor/AppEditorHeaderDeploy.svelte.d.ts +18 -0
  131. package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte +47 -0
  132. package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte.d.ts +8 -0
  133. package/package/components/apps/editor/GridEditor.svelte +7 -2
  134. package/package/components/apps/editor/appDeploy.svelte.d.ts +1 -0
  135. package/package/components/apps/editor/appDeploy.svelte.js +6 -0
  136. package/package/components/apps/editor/appUtils.d.ts +1 -0
  137. package/package/components/apps/editor/appUtils.js +30 -1
  138. package/package/components/apps/editor/component/ComponentInner.svelte +1 -0
  139. package/package/components/apps/editor/component/ComponentNavigation.svelte +3 -1
  140. package/package/components/apps/editor/component/components.d.ts +19 -4
  141. package/package/components/apps/editor/component/components.js +23 -3
  142. package/package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +1 -1
  143. package/package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +6 -4
  144. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte.d.ts +1 -1
  145. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte.d.ts +1 -1
  146. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte.d.ts +1 -1
  147. package/package/components/apps/editor/settingsPanel/ComponentPanel.svelte +2 -0
  148. package/package/components/apps/editor/settingsPanel/GridTab.svelte +19 -1
  149. package/package/components/apps/editor/settingsPanel/GridTab.svelte.d.ts +3 -1
  150. package/package/components/apps/editor/settingsPanel/GridTabHidden.svelte +52 -0
  151. package/package/components/apps/editor/settingsPanel/GridTabHidden.svelte.d.ts +9 -0
  152. package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +58 -8
  153. package/package/components/auditLogs/AuditLogsFilters.svelte +7 -1
  154. package/package/components/auditLogs/AuditLogsTable.svelte +17 -7
  155. package/package/components/auditLogs/AuditLogsTable.svelte.d.ts +1 -0
  156. package/package/components/common/CloseButton.svelte +2 -2
  157. package/package/components/common/CloseButton.svelte.d.ts +1 -0
  158. package/package/components/common/ResizeTransitionWrapper.svelte +39 -0
  159. package/package/components/common/ResizeTransitionWrapper.svelte.d.ts +12 -0
  160. package/package/components/common/badge/CountBadge.svelte +29 -0
  161. package/package/components/common/badge/CountBadge.svelte.d.ts +8 -0
  162. package/package/components/common/button/Button.svelte +1 -0
  163. package/package/components/common/button/ConnectionButton.svelte +6 -1
  164. package/package/components/common/button/ConnectionButton.svelte.d.ts +2 -0
  165. package/package/components/common/button/RefreshButton.svelte +8 -4
  166. package/package/components/common/button/RefreshButton.svelte.d.ts +3 -0
  167. package/package/components/common/calendarPicker/CalendarPicker.svelte +1 -1
  168. package/package/components/common/fileInput/FileInput.svelte +7 -6
  169. package/package/components/common/fileUpload/S3ArgInput.svelte +11 -9
  170. package/package/components/common/fileUpload/S3ArgInput.svelte.d.ts +1 -0
  171. package/package/components/common/layout/List.svelte +3 -7
  172. package/package/components/common/layout/List.svelte.d.ts +7 -29
  173. package/package/components/common/popup/PopupV2.svelte +14 -25
  174. package/package/components/common/popup/PopupV2.svelte.d.ts +4 -2
  175. package/package/components/common/table/ScriptRow.svelte +22 -2
  176. package/package/components/common/toggleButton-v2/ToggleButton.svelte +17 -26
  177. package/package/components/common/toggleButton-v2/ToggleButton.svelte.d.ts +16 -30
  178. package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte +1 -1
  179. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte +3 -3
  180. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte.d.ts +1 -0
  181. package/package/components/copilot/CodeCompletionStatus.svelte +2 -1
  182. package/package/components/copilot/CronGen.svelte +1 -1
  183. package/package/components/copilot/FlowCopilotInputsModal.svelte +26 -23
  184. package/package/components/copilot/FlowInlineScriptAIButton.svelte +2 -2
  185. package/package/components/copilot/IteratorGen.svelte +30 -25
  186. package/package/components/copilot/IteratorGen.svelte.d.ts +8 -7
  187. package/package/components/copilot/MetadataGen.svelte +4 -3
  188. package/package/components/copilot/PredicateGen.svelte +15 -12
  189. package/package/components/copilot/PredicateGen.svelte.d.ts +5 -4
  190. package/package/components/copilot/RegexGen.svelte +1 -1
  191. package/package/components/copilot/ScriptFix.svelte +1 -1
  192. package/package/components/copilot/ScriptGen.svelte +2 -1
  193. package/package/components/copilot/StepGenQuick.svelte +15 -16
  194. package/package/components/copilot/StepGenQuick.svelte.d.ts +14 -13
  195. package/package/components/copilot/StepInputGen.svelte +50 -36
  196. package/package/components/copilot/StepInputGen.svelte.d.ts +13 -10
  197. package/package/components/copilot/StepInputsGen.svelte +18 -19
  198. package/package/components/copilot/StepInputsGen.svelte.d.ts +4 -18
  199. package/package/components/copilot/autocomplete/Autocompletor.js +1 -1
  200. package/package/components/copilot/autocomplete/request.js +1 -1
  201. package/package/components/copilot/chat/AIChat.svelte +2 -1
  202. package/package/components/copilot/chat/AIChatManager.svelte.js +5 -3
  203. package/package/components/copilot/chat/AiChatLayout.svelte +2 -1
  204. package/package/components/copilot/chat/ProviderModelSelector.svelte +11 -10
  205. package/package/components/copilot/chat/ProviderModelSelector.svelte.d.ts +2 -17
  206. package/package/components/copilot/chat/flow/FlowAIButton.svelte +1 -1
  207. package/package/components/copilot/chat/flow/FlowAIChat.svelte +4 -2
  208. package/package/components/copilot/chat/script/core.d.ts +4 -4
  209. package/package/components/copilot/chat/script/core.js +95 -35
  210. package/package/components/copilot/chat/shared.js +2 -1
  211. package/package/components/copilot/lib.d.ts +1 -0
  212. package/package/components/copilot/lib.js +7 -3
  213. package/package/components/custom_ui.d.ts +1 -0
  214. package/package/components/details/DetailPageLayout.svelte +3 -2
  215. package/package/components/details/DetailPageLayout.svelte.d.ts +1 -0
  216. package/package/components/flows/CreateActionsFlow.svelte +1 -1
  217. package/package/components/flows/FlowChatInterface.svelte +404 -0
  218. package/package/components/flows/FlowChatInterface.svelte.d.ts +19 -0
  219. package/package/components/flows/FlowChatMessage.svelte +41 -0
  220. package/package/components/flows/FlowChatMessage.svelte.d.ts +9 -0
  221. package/package/components/flows/FlowConversationsSidebar.svelte +213 -0
  222. package/package/components/flows/FlowConversationsSidebar.svelte.d.ts +15 -0
  223. package/package/components/flows/FlowEditor.svelte.d.ts +1 -1
  224. package/package/components/flows/FlowModuleIcon.svelte +10 -10
  225. package/package/components/flows/FlowProgressBar.svelte +16 -16
  226. package/package/components/flows/FlowProgressBar.svelte.d.ts +7 -22
  227. package/package/components/flows/common/FlowCard.svelte +10 -2
  228. package/package/components/flows/common/FlowCard.svelte.d.ts +1 -0
  229. package/package/components/flows/common/FlowCardHeader.svelte +2 -1
  230. package/package/components/flows/common/FlowCardHeader.svelte.d.ts +1 -0
  231. package/package/components/flows/content/DynamicInputHelpBox.svelte +4 -4
  232. package/package/components/flows/content/FlowEditorPanel.svelte.d.ts +1 -1
  233. package/package/components/flows/content/FlowInput.svelte +381 -259
  234. package/package/components/flows/content/FlowInput.svelte.d.ts +1 -1
  235. package/package/components/flows/content/FlowInputsQuick.svelte +56 -34
  236. package/package/components/flows/content/FlowInputsQuick.svelte.d.ts +3 -2
  237. package/package/components/flows/content/FlowModuleComponent.svelte +29 -11
  238. package/package/components/flows/flowInfers.d.ts +60 -0
  239. package/package/components/flows/flowInfers.js +72 -40
  240. package/package/components/flows/{flowStore.d.ts → flowStore.svelte.d.ts} +5 -1
  241. package/package/components/flows/header/FlowPreviewButtons.svelte +1 -1
  242. package/package/components/flows/map/FlowErrorHandlerItem.svelte +4 -2
  243. package/package/components/flows/map/FlowErrorHandlerItem.svelte.d.ts +1 -0
  244. package/package/components/flows/map/FlowJobsMenu.svelte +3 -3
  245. package/package/components/flows/map/FlowJobsMenu.svelte.d.ts +1 -1
  246. package/package/components/flows/map/FlowModuleSchemaItem.svelte +1 -1
  247. package/package/components/flows/map/FlowModuleSchemaMap.svelte +5 -2
  248. package/package/components/flows/map/FlowStickyNode.svelte +2 -2
  249. package/package/components/flows/map/FlowStickyNode.svelte.d.ts +1 -0
  250. package/package/components/flows/map/InsertModuleButton.svelte +8 -15
  251. package/package/components/flows/map/InsertModuleButton.svelte.d.ts +4 -4
  252. package/package/components/flows/map/InsertModuleInner.svelte +19 -20
  253. package/package/components/flows/map/InsertModuleInner.svelte.d.ts +2 -2
  254. package/package/components/flows/map/MapItem.svelte +1 -1
  255. package/package/components/flows/map/VirtualItem.svelte +1 -2
  256. package/package/components/flows/pickers/PickHubScriptQuick.svelte +43 -52
  257. package/package/components/flows/pickers/PickHubScriptQuick.svelte.d.ts +2 -1
  258. package/package/components/flows/pickers/WorkspaceScriptPickerQuick.svelte +41 -26
  259. package/package/components/flows/pickers/WorkspaceScriptPickerQuick.svelte.d.ts +1 -0
  260. package/package/components/flows/propPicker/OutputPicker.svelte +2 -0
  261. package/package/components/flows/propPicker/PropPickerWrapper.svelte +1 -15
  262. package/package/components/git_sync/DetectionFlow.svelte +33 -44
  263. package/package/components/git_sync/DetectionFlow.svelte.d.ts +1 -0
  264. package/package/components/git_sync/GitSyncContext.svelte.d.ts +22 -0
  265. package/package/components/git_sync/GitSyncContext.svelte.js +145 -5
  266. package/package/components/git_sync/GitSyncModeDisplay.svelte +14 -0
  267. package/package/components/git_sync/GitSyncModeDisplay.svelte.d.ts +9 -0
  268. package/package/components/git_sync/GitSyncRepositoryCard.svelte +365 -253
  269. package/package/components/git_sync/GitSyncRepositoryCard.svelte.d.ts +10 -1
  270. package/package/components/git_sync/GitSyncSection.svelte +134 -14
  271. package/package/components/git_sync/PullWorkspaceModal.svelte +24 -32
  272. package/package/components/git_sync/PushWorkspaceModal.svelte +24 -32
  273. package/package/components/graph/FlowGraphV2.svelte +2 -1
  274. package/package/components/graph/FlowGraphV2.svelte.d.ts +1 -0
  275. package/package/components/graph/graphBuilder.svelte.d.ts +2 -0
  276. package/package/components/graph/graphBuilder.svelte.js +1 -0
  277. package/package/components/graph/model.d.ts +5 -5
  278. package/package/components/graph/renderers/edges/BaseEdge.svelte +1 -0
  279. package/package/components/graph/renderers/edges/EmptyEdge.svelte +3 -10
  280. package/package/components/graph/renderers/edges/EmptyEdge.svelte.d.ts +4 -18
  281. package/package/components/graph/renderers/nodes/AIToolNode.svelte +2 -2
  282. package/package/components/graph/renderers/nodes/InputNode.svelte +13 -2
  283. package/package/components/graph/renderers/nodes/NewAIToolNode.svelte +5 -10
  284. package/package/components/graph/renderers/triggers/TriggersBadge.svelte +2 -27
  285. package/package/components/home/ItemsList.svelte +1 -1
  286. package/package/components/instanceSettings.js +17 -0
  287. package/package/components/jobs/JobProgressBar.svelte +27 -21
  288. package/package/components/jobs/JobProgressBar.svelte.d.ts +9 -24
  289. package/package/components/meltComponents/MenuSingleItem.svelte +3 -8
  290. package/package/components/meltComponents/MenuSingleItem.svelte.d.ts +0 -3
  291. package/package/components/meltComponents/Popover.svelte +3 -2
  292. package/package/components/meltComponents/Popover.svelte.d.ts +1 -0
  293. package/package/components/meltComponents/Tooltip.svelte +1 -1
  294. package/package/components/progressBar/ProgressBar.svelte +39 -53
  295. package/package/components/progressBar/ProgressBar.svelte.d.ts +11 -26
  296. package/package/components/raw_apps/FileEditorIcon.svelte +1 -1
  297. package/package/components/raw_apps/FileEditorIcon.svelte.d.ts +4 -18
  298. package/package/components/raw_apps/RawAppBackgroundRunner.svelte +2 -8
  299. package/package/components/raw_apps/RawAppBackgroundRunner.svelte.d.ts +4 -18
  300. package/package/components/raw_apps/RawAppEditor.svelte +6 -7
  301. package/package/components/raw_apps/RawAppEditorHeader.svelte +48 -301
  302. package/package/components/raw_apps/RawAppEditorHeader.svelte.d.ts +18 -19
  303. package/package/components/raw_apps/RawAppInlineScriptEditor.svelte +10 -16
  304. package/package/components/raw_apps/RawAppInlineScriptEditor.svelte.d.ts +13 -13
  305. package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte +8 -11
  306. package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte.d.ts +1 -2
  307. package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte +0 -1
  308. package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte +7 -13
  309. package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte.d.ts +8 -8
  310. package/package/components/raw_apps/RawAppPreview.svelte +3 -7
  311. package/package/components/raw_apps/RawAppPreview.svelte.d.ts +5 -19
  312. package/package/components/raw_apps/utils.d.ts +1 -1
  313. package/package/components/raw_apps/utils.js +3 -3
  314. package/package/components/runs/JobsLoader.svelte +1 -1
  315. package/package/components/runs/NoWorkerWithTagWarning.svelte +3 -3
  316. package/package/components/runs/NoWorkerWithTagWarning.svelte.d.ts +1 -1
  317. package/package/components/runs/RunOption.svelte +2 -2
  318. package/package/components/runs/RunsFilter.svelte +15 -12
  319. package/package/components/runs/RunsFilter.svelte.d.ts +1 -1
  320. package/package/components/schema/AddPropertyV2.svelte +7 -4
  321. package/package/components/schema/EditableSchemaDrawer.svelte +19 -18
  322. package/package/components/schema/FlowPropertyEditor.svelte +9 -2
  323. package/package/components/schema/FlowPropertyEditor.svelte.d.ts +1 -1
  324. package/package/components/schema/PropertyEditor.svelte +22 -26
  325. package/package/components/schema/PropertyEditor.svelte.d.ts +1 -1
  326. package/package/components/schema/SchemaFormDND.svelte +3 -2
  327. package/package/components/schema/SchemaFormDND.svelte.d.ts +1 -0
  328. package/package/components/select/DraggableTags.svelte +2 -2
  329. package/package/components/select/MultiSelect.svelte +15 -9
  330. package/package/components/select/MultiSelect.svelte.d.ts +1 -0
  331. package/package/components/select/Select.svelte +12 -5
  332. package/package/components/select/Select.svelte.d.ts +11 -0
  333. package/package/components/select/SelectDropdown.svelte +98 -46
  334. package/package/components/select/SelectDropdown.svelte.d.ts +10 -0
  335. package/package/components/select/utils.svelte.js +2 -0
  336. package/package/components/settings/CreateToken.svelte +76 -49
  337. package/package/components/settings/WorkspaceUserSettings.svelte +111 -17
  338. package/package/components/sidebar/CriticalAlertTable.svelte +2 -1
  339. package/package/components/sidebar/Linkify.svelte +14 -0
  340. package/package/components/sidebar/Linkify.svelte.d.ts +5 -0
  341. package/package/components/sidebar/MenuLink.svelte +2 -1
  342. package/package/components/sidebar/MenuLink.svelte.d.ts +1 -0
  343. package/package/components/sidebar/SidebarContent.svelte +27 -27
  344. package/package/components/sidebar/WorkspaceMenu.svelte +8 -3
  345. package/package/components/table/Cell.svelte +7 -14
  346. package/package/components/table/Cell.svelte.d.ts +13 -35
  347. package/package/components/table/tableUtils.js +1 -1
  348. package/package/components/text_input/TextInput.svelte +30 -0
  349. package/package/components/text_input/TextInput.svelte.d.ts +17 -0
  350. package/package/components/triggers/AddTriggersButton.svelte +1 -0
  351. package/package/components/triggers/TriggersEditor.svelte +11 -1
  352. package/package/components/triggers/gcp/GcpTriggerEditorConfigSection.svelte +1 -1
  353. package/package/components/triggers/gcp/GcpTriggerEditorConfigSection.svelte.d.ts +2 -1
  354. package/package/components/triggers/gcp/GcpTriggerEditorInner.svelte +28 -5
  355. package/package/components/triggers/gcp/utils.js +1 -0
  356. package/package/components/triggers/schedules/ScheduleEditorInner.svelte +1 -0
  357. package/package/components/triggers/triggers.svelte.d.ts +1 -1
  358. package/package/components/triggers/triggers.svelte.js +8 -4
  359. package/package/components/triggers/webhook/WebhooksConfigSection.svelte +143 -63
  360. package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +22 -0
  361. package/package/components/triggers/websocket/utils.js +1 -0
  362. package/package/components/tutorials/FlowBuilderTutorialErrorHandler.svelte +2 -2
  363. package/package/components/tutorials/FlowBuilderTutorialForLoop.svelte +3 -0
  364. package/package/components/tutorials/FlowBuilderTutorialSimpleFlow.svelte +49 -17
  365. package/package/components/tutorials/Tutorial.svelte +9 -0
  366. package/package/components/tutorials/Tutorial.svelte.d.ts +1 -0
  367. package/package/components/tutorials/app/AppTutorial.svelte +41 -57
  368. package/package/components/tutorials/app/BackgroundRunnablesTutorial.svelte +3 -5
  369. package/package/components/tutorials/app/ConnectionTutorial.svelte +2 -2
  370. package/package/components/tutorials/utils.js +2 -154
  371. package/package/components/vscode.js +16 -8
  372. package/package/components/workspaceSettings/AISettings.svelte +12 -5
  373. package/package/components/workspaceSettings/AISettings.svelte.d.ts +2 -1
  374. package/package/components/workspaceSettings/CreateWorkspace.svelte +2 -2
  375. package/package/components/workspaceSettings/DucklakeSettings.svelte +64 -7
  376. package/package/components/workspaceSettings/ModelTokenLimits.svelte +165 -0
  377. package/package/components/workspaceSettings/ModelTokenLimits.svelte.d.ts +8 -0
  378. package/package/components/workspaceSettings/StorageSettings.svelte +147 -77
  379. package/package/editorUtils.d.ts +1 -1
  380. package/package/gen/core/OpenAPI.js +1 -1
  381. package/package/gen/schemas.gen.d.ts +223 -17
  382. package/package/gen/schemas.gen.js +226 -17
  383. package/package/gen/services.gen.d.ts +221 -27
  384. package/package/gen/services.gen.js +440 -48
  385. package/package/gen/types.gen.d.ts +1067 -218
  386. package/package/hubPaths.json +2 -1
  387. package/package/script_helpers.js +5 -5
  388. package/package/services/JobManager.js +14 -9
  389. package/package/stores.d.ts +4 -12
  390. package/package/stores.js +5 -65
  391. package/package/timelineCompute.svelte.d.ts +21 -0
  392. package/package/timelineCompute.svelte.js +113 -0
  393. package/package/toast.js +2 -1
  394. package/package/utils.d.ts +16 -8
  395. package/package/utils.js +65 -12
  396. package/package/workspace_settings.d.ts +13 -8
  397. package/package/workspace_settings.js +46 -11
  398. package/package.json +4 -4
  399. /package/package/components/flows/{flowStore.js → flowStore.svelte.js} +0 -0
@@ -8,9 +8,8 @@ import { workspaceStore } from '../stores';
8
8
  import Tooltip from './Tooltip.svelte';
9
9
  import { Clock, MemoryStick, Calendar, Bot, User, Code2 } from 'lucide-svelte';
10
10
  import BarsStaggered from './icons/BarsStaggered.svelte';
11
- export let job;
12
11
  const SMALL_ICON_SIZE = 14;
13
- export let scheduleEditor;
12
+ let { job, scheduleEditor } = $props();
14
13
  </script>
15
14
 
16
15
  <div
@@ -72,11 +71,11 @@ export let scheduleEditor;
72
71
  <Calendar size={SMALL_ICON_SIZE} class="text-secondary min-w-3.5" />
73
72
  <span class="whitespace-nowrap">
74
73
  Schedule:
75
- <!-- svelte-ignore a11y-invalid-attribute -->
74
+ <!-- svelte-ignore a11y_invalid_attribute -->
76
75
  <a
77
76
  href="#"
78
77
  class="break-words text-blue-600 font-normal"
79
- on:click={() =>
78
+ onclick={() =>
80
79
  scheduleEditor?.openEdit(job.schedule_path ?? '', job.job_kind == 'flow')}
81
80
  >
82
81
  {truncateRev(job.schedule_path, 40)}
@@ -1,23 +1,9 @@
1
1
  import { type Job } from '../gen';
2
2
  import ScheduleEditor from './triggers/schedules/ScheduleEditor.svelte';
3
- interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
4
- new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
5
- $$bindings?: Bindings;
6
- } & Exports;
7
- (internal: unknown, props: Props & {
8
- $$events?: Events;
9
- $$slots?: Slots;
10
- }): Exports & {
11
- $set?: any;
12
- $on?: any;
13
- };
14
- z_$$bindings?: Bindings;
15
- }
16
- declare const FlowMetadata: $$__sveltets_2_IsomorphicComponent<{
3
+ interface Props {
17
4
  job: Job;
18
5
  scheduleEditor: ScheduleEditor;
19
- }, {
20
- [evt: string]: CustomEvent<any>;
21
- }, {}, {}, string>;
22
- type FlowMetadata = InstanceType<typeof FlowMetadata>;
6
+ }
7
+ declare const FlowMetadata: import("svelte").Component<Props, {}, "">;
8
+ type FlowMetadata = ReturnType<typeof FlowMetadata>;
23
9
  export default FlowMetadata;
@@ -1,8 +1,10 @@
1
1
  <script lang="ts">import { Plug } from 'lucide-svelte';
2
2
  import { Button } from './common';
3
3
  import AnimatedButton from './common/button/AnimatedButton.svelte';
4
+ import { twMerge } from 'tailwind-merge';
4
5
  export let connecting;
5
6
  export let id = undefined;
7
+ export let wrapperClasses = '';
6
8
  </script>
7
9
 
8
10
  <AnimatedButton animate={connecting} baseRadius="6px" animationDuration="2s" marginWidth="2px">
@@ -10,10 +12,14 @@ export let id = undefined;
10
12
  variant="border"
11
13
  color="light"
12
14
  size="xs2"
13
- btnClasses={connecting ? 'text-blue-500' : 'text-primary'}
15
+ btnClasses={twMerge(
16
+ connecting ? 'text-blue-500' : 'text-tertiary',
17
+ 'group/plug-btn overflow-clip flex p-0'
18
+ )}
14
19
  on:click
15
20
  {...id ? { id } : {}}
21
+ {wrapperClasses}
16
22
  >
17
- <Plug size={16} /> &rightarrow;
23
+ <Plug size={14} />
18
24
  </Button>
19
25
  </AnimatedButton>
@@ -14,6 +14,7 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
14
14
  declare const FlowPlugConnect: $$__sveltets_2_IsomorphicComponent<{
15
15
  connecting: boolean;
16
16
  id?: undefined | string;
17
+ wrapperClasses?: string;
17
18
  }, {
18
19
  click: CustomEvent<any>;
19
20
  } & {
@@ -9,7 +9,7 @@ import SchemaForm from './SchemaForm.svelte';
9
9
  import SchemaFormWithArgPicker from './SchemaFormWithArgPicker.svelte';
10
10
  import FlowStatusViewer from '../components/FlowStatusViewer.svelte';
11
11
  import FlowProgressBar from './flows/FlowProgressBar.svelte';
12
- import { AlertTriangle, ArrowRight, CornerDownLeft, Play, RefreshCw, X } from 'lucide-svelte';
12
+ import { AlertTriangle, ArrowRight, CornerDownLeft, Loader2, Play, RefreshCw, X } from 'lucide-svelte';
13
13
  import { emptyString, sendUserToast } from '../utils';
14
14
  import { dfs } from './flows/dfs';
15
15
  import { sliceModules } from './flows/flowStateUtils.svelte';
@@ -20,6 +20,7 @@ import FlowHistoryJobPicker from './FlowHistoryJobPicker.svelte';
20
20
  import { getStepHistoryLoaderContext } from './stepHistoryLoader.svelte';
21
21
  import { aiChatManager } from './copilot/chat/AIChatManager.svelte';
22
22
  import { stateSnapshot } from '../svelte5Utils.svelte';
23
+ import FlowChatInterface from './flows/FlowChatInterface.svelte';
23
24
  let { previewMode = $bindable(), open, preventEscape = $bindable(false), jobId = $bindable(undefined), job = $bindable(undefined), initial = $bindable(false), selectedJobStep = $bindable(undefined), selectedJobStepIsTopLevel = $bindable(undefined), selectedJobStepType = $bindable('single'), rightColumnSelect = $bindable('timeline'), branchOrIterationN = $bindable(0), scrollTop = $bindable(0), localModuleStates = $bindable({}), localDurationStatuses = $bindable({}), onRunPreview, render = false, onJobDone, upToId = undefined } = $props();
24
25
  let restartBranchNames = [];
25
26
  let isRunning = $state(false);
@@ -29,9 +30,9 @@ let schemaHeight = $state(0);
29
30
  let isValid = $state(true);
30
31
  let suspendStatus = $state({ val: {} });
31
32
  let isOwner = $state(false);
32
- export function test() {
33
+ export async function test() {
33
34
  renderCount++;
34
- runPreview(previewArgs.val, undefined);
35
+ return await runPreview(previewArgs.val, undefined);
35
36
  }
36
37
  const { selectedId, previewArgs, flowStateStore, flowStore, pathStore, initialPathStore, fakeInitialPath, customUi, executionCount } = $state(getContext('FlowEditorContext'));
37
38
  const dispatch = createEventDispatcher();
@@ -40,6 +41,7 @@ let schemaFormWithArgPicker = $state(undefined);
40
41
  let currentJobId = $state(undefined);
41
42
  let stepHistoryLoader = getStepHistoryLoaderContext();
42
43
  let flowProgressBar = $state(undefined);
44
+ let loadingHistory = $state(false);
43
45
  function extractFlow(previewMode) {
44
46
  const previewFlow = aiChatManager.flowAiChatHelpers?.getPreviewFlow();
45
47
  if (previewMode === 'whole') {
@@ -57,6 +59,7 @@ function extractFlow(previewMode) {
57
59
  }
58
60
  let lastPreviewFlow = $state(undefined);
59
61
  export async function runPreview(args, restartedFrom) {
62
+ let newJobId = undefined;
60
63
  if (stepHistoryLoader?.flowJobInitial !== false) {
61
64
  stepHistoryLoader?.setFlowJobInitial(false);
62
65
  }
@@ -64,7 +67,8 @@ export async function runPreview(args, restartedFrom) {
64
67
  lastPreviewFlow = JSON.stringify(flowStore.val);
65
68
  flowProgressBar?.reset();
66
69
  const newFlow = extractFlow(previewMode);
67
- jobId = await runFlowPreview(args, newFlow, $pathStore, restartedFrom);
70
+ newJobId = await runFlowPreview(args, newFlow, $pathStore, restartedFrom);
71
+ jobId = newJobId;
68
72
  isRunning = true;
69
73
  if (inputSelected) {
70
74
  savedArgs = $state.snapshot(previewArgs.val);
@@ -78,6 +82,7 @@ export async function runPreview(args, restartedFrom) {
78
82
  jobId = undefined;
79
83
  }
80
84
  schemaFormWithArgPicker?.refreshHistory();
85
+ return newJobId;
81
86
  }
82
87
  function onKeyDown(event) {
83
88
  if (open) {
@@ -322,25 +327,27 @@ export function flowHasChanged() {
322
327
  </Popover>
323
328
  {/if}
324
329
  {/if}
325
- <Button
326
- variant="contained"
327
- startIcon={{ icon: isRunning ? RefreshCw : Play }}
328
- color="dark"
329
- size="sm"
330
- btnClasses="w-full max-w-lg"
331
- on:click={() => runPreview(previewArgs.val, undefined)}
332
- id="flow-editor-test-flow-drawer"
333
- shortCut={{ Icon: CornerDownLeft }}
334
- >
335
- {#if previewMode == 'upTo'}
336
- Test up to
337
- <Badge baseClass="ml-1" color="indigo">
338
- {$selectedId}
339
- </Badge>
340
- {:else}
341
- Test flow
342
- {/if}
343
- </Button>
330
+ {#if !flowStore.val.value?.chat_input_enabled}
331
+ <Button
332
+ variant="contained"
333
+ startIcon={{ icon: isRunning ? RefreshCw : Play }}
334
+ color="dark"
335
+ size="sm"
336
+ btnClasses="w-full max-w-lg"
337
+ on:click={() => runPreview(previewArgs.val, undefined)}
338
+ id="flow-editor-test-flow-drawer"
339
+ shortCut={{ Icon: CornerDownLeft }}
340
+ >
341
+ {#if previewMode == 'upTo'}
342
+ Test up to
343
+ <Badge baseClass="ml-1" color="indigo">
344
+ {$selectedId}
345
+ </Badge>
346
+ {:else}
347
+ Test flow
348
+ {/if}
349
+ </Button>
350
+ {/if}
344
351
  </div>
345
352
  {/if}
346
353
  </div>
@@ -365,81 +372,96 @@ export function flowHasChanged() {
365
372
  onscroll={(e) => handleScroll()}
366
373
  >
367
374
  {#if render}
368
- <div class="border-b">
369
- <SchemaFormWithArgPicker
370
- bind:this={schemaFormWithArgPicker}
371
- runnableId={$initialPathStore}
372
- stablePathForCaptures={$initialPathStore || fakeInitialPath}
373
- runnableType={'FlowPath'}
374
- previewArgs={previewArgs.val}
375
- on:openTriggers
376
- on:select={(e) => {
377
- selectInput(e.detail.payload, e.detail?.type)
378
- }}
379
- {isValid}
380
- {jsonView}
381
- >
382
- <div class="w-full flex flex-row justify-between">
383
- <InputSelectedBadge
384
- onReject={() => schemaFormWithArgPicker?.resetSelected()}
385
- {inputSelected}
386
- />
387
- <div class="flex flex-row gap-2">
388
- <Toggle
389
- bind:checked={jsonView}
390
- label="JSON View"
391
- size="xs"
392
- options={{
393
- right: 'JSON',
394
- rightTooltip: 'Fill args from JSON'
395
- }}
396
- lightMode
397
- on:change={(e) => {
398
- jsonEditor?.setCode(JSON.stringify(previewArgs.val ?? {}, null, '\t'))
399
- refresh()
400
- }}
401
- />
402
- </div>
403
- </div>
404
- {#if jsonView}
405
- <div class="py-2" style="height: {Math.max(schemaHeight, 100)}px" data-schema-picker>
406
- <JsonInputs
407
- bind:this={jsonEditor}
408
- on:select={(e) => {
409
- if (e.detail) {
410
- previewArgs.val = e.detail
411
- }
412
- }}
413
- updateOnBlur={false}
414
- placeholder={`Write args as JSON.<br/><br/>Example:<br/><br/>{<br/>&nbsp;&nbsp;"foo": "12"<br/>}`}
375
+ {#if flowStore.val.value?.chat_input_enabled}
376
+ <div class="flex flex-row justify-center w-full">
377
+ <FlowChatInterface
378
+ onRunFlow={async (userMessage, _conversationId) => {
379
+ await runPreview({ user_message: userMessage }, undefined)
380
+ return jobId ?? ''
381
+ }}
382
+ createConversation={async () => {
383
+ const newConversationId = crypto.randomUUID()
384
+ return newConversationId
385
+ }}
386
+ />
387
+ </div>
388
+ {:else}
389
+ <div class="border-b">
390
+ <SchemaFormWithArgPicker
391
+ bind:this={schemaFormWithArgPicker}
392
+ runnableId={$initialPathStore}
393
+ stablePathForCaptures={$initialPathStore || fakeInitialPath}
394
+ runnableType={'FlowPath'}
395
+ previewArgs={previewArgs.val}
396
+ on:openTriggers
397
+ on:select={(e) => {
398
+ selectInput(e.detail.payload, e.detail?.type)
399
+ }}
400
+ {isValid}
401
+ {jsonView}
402
+ >
403
+ <div class="w-full flex flex-row justify-between">
404
+ <InputSelectedBadge
405
+ onReject={() => schemaFormWithArgPicker?.resetSelected()}
406
+ {inputSelected}
415
407
  />
408
+ <div class="flex flex-row gap-2">
409
+ <Toggle
410
+ bind:checked={jsonView}
411
+ label="JSON View"
412
+ size="xs"
413
+ options={{
414
+ right: 'JSON',
415
+ rightTooltip: 'Fill args from JSON'
416
+ }}
417
+ lightMode
418
+ on:change={(e) => {
419
+ jsonEditor?.setCode(JSON.stringify(previewArgs.val ?? {}, null, '\t'))
420
+ refresh()
421
+ }}
422
+ />
423
+ </div>
416
424
  </div>
417
- {:else}
418
- {#key renderCount}
419
- <div bind:clientHeight={schemaHeight} class="min-h-[40vh]">
420
- <SchemaForm
421
- noVariablePicker
422
- compact
423
- schema={flowStore.val.schema}
424
- bind:args={previewArgs.val}
425
- on:change={() => {
426
- savedArgs = $state.snapshot(previewArgs.val)
425
+ {#if jsonView}
426
+ <div class="py-2" style="height: {Math.max(schemaHeight, 100)}px" data-schema-picker>
427
+ <JsonInputs
428
+ bind:this={jsonEditor}
429
+ on:select={(e) => {
430
+ if (e.detail) {
431
+ previewArgs.val = e.detail
432
+ }
427
433
  }}
428
- bind:isValid
429
- helperScript={flowStore.val.schema?.['x-windmill-dyn-select-code'] &&
430
- flowStore.val.schema?.['x-windmill-dyn-select-lang']
431
- ? {
432
- type: 'inline',
433
- code: flowStore.val.schema['x-windmill-dyn-select-code'] as string,
434
- lang: flowStore.val.schema['x-windmill-dyn-select-lang'] as ScriptLang
435
- }
436
- : undefined}
434
+ updateOnBlur={false}
435
+ placeholder={`Write args as JSON.<br/><br/>Example:<br/><br/>{<br/>&nbsp;&nbsp;"foo": "12"<br/>}`}
437
436
  />
438
437
  </div>
439
- {/key}
440
- {/if}
441
- </SchemaFormWithArgPicker>
442
- </div>
438
+ {:else}
439
+ {#key renderCount}
440
+ <div bind:clientHeight={schemaHeight} class="min-h-[40vh]">
441
+ <SchemaForm
442
+ noVariablePicker
443
+ compact
444
+ schema={flowStore.val.schema}
445
+ bind:args={previewArgs.val}
446
+ on:change={() => {
447
+ savedArgs = $state.snapshot(previewArgs.val)
448
+ }}
449
+ bind:isValid
450
+ helperScript={flowStore.val.schema?.['x-windmill-dyn-select-code'] &&
451
+ flowStore.val.schema?.['x-windmill-dyn-select-lang']
452
+ ? {
453
+ source: 'inline',
454
+ code: flowStore.val.schema['x-windmill-dyn-select-code'] as string,
455
+ lang: flowStore.val.schema['x-windmill-dyn-select-lang'] as ScriptLang
456
+ }
457
+ : undefined}
458
+ />
459
+ </div>
460
+ {/key}
461
+ {/if}
462
+ </SchemaFormWithArgPicker>
463
+ </div>
464
+ {/if}
443
465
  {/if}
444
466
  <div class="pt-4 flex flex-col grow relative">
445
467
  <div
@@ -463,6 +485,7 @@ export function flowHasChanged() {
463
485
  currentJobId = undefined
464
486
  }}
465
487
  path={$initialPathStore == '' ? $pathStore : $initialPathStore}
488
+ bind:loading={loadingHistory}
466
489
  />
467
490
  {/if}
468
491
  </div>
@@ -490,7 +513,7 @@ export function flowHasChanged() {
490
513
  bind:suspendStatus
491
514
  hideDownloadInGraph={customUi?.downloadLogs === false}
492
515
  wideResults
493
- bind:flowStateStore={flowStateStore.val}
516
+ bind:flowState={flowStateStore.val}
494
517
  {jobId}
495
518
  onDone={() => {
496
519
  isRunning = false
@@ -503,6 +526,10 @@ export function flowHasChanged() {
503
526
  {render}
504
527
  {customUi}
505
528
  />
529
+ {:else if loadingHistory}
530
+ <div class="italic text-tertiary h-full grow mx-auto flex flex-row items-center gap-2">
531
+ <Loader2 class="animate-spin" /> <span> Loading history... </span>
532
+ </div>
506
533
  {:else}
507
534
  <div class="italic text-tertiary h-full grow"> Flow status will be displayed here </div>
508
535
  {/if}
@@ -43,8 +43,8 @@ declare const FlowPreviewContent: $$__sveltets_2_IsomorphicComponent<Props, {
43
43
  } & {
44
44
  [evt: string]: CustomEvent<any>;
45
45
  }, {}, {
46
- test: () => void;
47
- runPreview: (args: Record<string, any>, restartedFrom: RestartedFrom | undefined) => Promise<void>;
46
+ test: () => Promise<string | undefined>;
47
+ runPreview: (args: Record<string, any>, restartedFrom: RestartedFrom | undefined) => Promise<string | undefined>;
48
48
  refresh: () => void;
49
49
  cancelTest: () => Promise<void>;
50
50
  getLocalModuleStates: () => Record<string, GraphModuleState>;
@@ -57,6 +57,6 @@ declare const FlowPreviewContent: $$__sveltets_2_IsomorphicComponent<Props, {
57
57
  getIsOwner: () => boolean;
58
58
  getJob: () => Job | undefined;
59
59
  flowHasChanged: () => boolean;
60
- }, "initial" | "preventEscape" | "job" | "scrollTop" | "jobId" | "localModuleStates" | "rightColumnSelect" | "localDurationStatuses" | "selectedJobStep" | "previewMode" | "selectedJobStepIsTopLevel" | "selectedJobStepType" | "branchOrIterationN">;
60
+ }, "initial" | "preventEscape" | "job" | "jobId" | "scrollTop" | "localModuleStates" | "localDurationStatuses" | "rightColumnSelect" | "selectedJobStep" | "previewMode" | "selectedJobStepIsTopLevel" | "selectedJobStepType" | "branchOrIterationN">;
61
61
  type FlowPreviewContent = InstanceType<typeof FlowPreviewContent>;
62
62
  export default FlowPreviewContent;
@@ -2,13 +2,12 @@
2
2
  import { setContext, untrack } from 'svelte';
3
3
  import { isOwner as loadIsOwner } from '../utils';
4
4
  import { userStore, workspaceStore } from '../stores';
5
- let { jobId, initialJob = undefined, workspaceId = undefined, flowStateStore = $bindable({}), selectedJobStep = $bindable(undefined), hideFlowResult = false, hideTimeline = false, hideDownloadInGraph = false, hideNodeDefinition = false, hideJobId = false, hideDownloadLogs = false, rightColumnSelect = $bindable('timeline'), isOwner = $bindable(false), wideResults = false, localModuleStates = $bindable({}), localDurationStatuses = $bindable({}), job = $bindable(undefined), render = true, suspendStatus = $bindable({ val: {} }), customUi, onStart, onJobsLoaded, onDone } = $props();
5
+ let { jobId, initialJob = undefined, workspaceId = undefined, flowState = $bindable({}), selectedJobStep = $bindable(undefined), hideFlowResult = false, hideTimeline = false, hideDownloadInGraph = false, hideNodeDefinition = false, hideJobId = false, hideDownloadLogs = false, rightColumnSelect = $bindable('timeline'), isOwner = $bindable(false), wideResults = false, localModuleStates = $bindable({}), localDurationStatuses = $bindable({}), job = $bindable(undefined), render = true, suspendStatus = $bindable({ val: {} }), customUi, onStart, onJobsLoaded, onDone } = $props();
6
6
  let lastJobId = jobId;
7
7
  let retryStatus = $state({ val: {} });
8
8
  let globalRefreshes = $state({});
9
- let globalIterationBounds = $state({});
10
9
  setContext('FlowStatusViewer', {
11
- flowStateStore,
10
+ flowState,
12
11
  suspendStatus,
13
12
  retryStatus,
14
13
  hideDownloadInGraph,
@@ -22,11 +21,15 @@ function loadOwner(path) {
22
21
  }
23
22
  async function updateJobId() {
24
23
  if (jobId !== lastJobId) {
24
+ console.log('updateJobId 3', jobId);
25
25
  lastJobId = jobId;
26
26
  retryStatus.val = {};
27
27
  suspendStatus.val = {};
28
28
  globalRefreshes = {};
29
- globalIterationBounds = {};
29
+ for (let key in localModuleStates)
30
+ delete flowState[key];
31
+ localDurationStatuses = {};
32
+ localModuleStates = {};
30
33
  }
31
34
  }
32
35
  let lastScriptPath = $state(undefined);
@@ -47,59 +50,60 @@ let storedToolCallJobs = $state({});
47
50
  let toolCallIndicesToLoad = $state([]);
48
51
  </script>
49
52
 
50
- <FlowStatusViewerInner
51
- {hideFlowResult}
52
- onJobsLoaded={({ job, force }) => {
53
- if (job.script_path != lastScriptPath && job.script_path) {
54
- lastScriptPath = job.script_path
55
- loadOwner(lastScriptPath ?? '')
56
- }
57
- onJobsLoaded?.({ job, force })
58
- }}
59
- globalModuleStates={[]}
60
- {globalIterationBounds}
61
- bind:localModuleStates
62
- bind:selectedNode={selectedJobStep}
63
- bind:localDurationStatuses
64
- {onStart}
65
- {onDone}
66
- bind:job
67
- {initialJob}
68
- {jobId}
69
- {workspaceId}
70
- {isOwner}
71
- {wideResults}
72
- bind:rightColumnSelect
73
- {render}
74
- {customUi}
75
- graphTabOpen={true}
76
- isNodeSelected={true}
77
- {refreshGlobal}
78
- {updateGlobalRefresh}
79
- toolCallStore={{
80
- getStoredToolCallJob: (storeKey: string) => storedToolCallJobs[storeKey],
81
- setStoredToolCallJob: (storeKey: string, job: Job) => {
82
- storedToolCallJobs[storeKey] = job
83
- },
84
- getLocalToolCallJobs: (prefix: string) => {
85
- // we return a map from tool call index to job
86
- // to do so, we filter the storedToolCallJobs object by the prefix and we make sure what's left in the key is a tool call index: 2 part of format agentModuleId-toolCallIndex
87
- // and not a further nested tool call index
88
- return Object.fromEntries(
89
- Object.entries(storedToolCallJobs)
90
- .filter(
91
- ([key]) => key.startsWith(prefix) && key.replace(prefix, '').split('-').length === 2
92
- )
93
- .map(([key, job]) => [Number(key.replace(prefix, '').split('-').pop()), job])
94
- )
95
- },
96
- isToolCallToBeLoaded: (storeKey: string) => {
97
- return toolCallIndicesToLoad.includes(storeKey)
98
- },
99
- addToolCallToLoad: (storeKey: string) => {
100
- if (!toolCallIndicesToLoad.includes(storeKey)) {
101
- toolCallIndicesToLoad.push(storeKey)
53
+ {#key jobId}
54
+ <FlowStatusViewerInner
55
+ {hideFlowResult}
56
+ onJobsLoaded={({ job, force }) => {
57
+ if (job.script_path != lastScriptPath && job.script_path) {
58
+ lastScriptPath = job.script_path
59
+ loadOwner(lastScriptPath ?? '')
102
60
  }
103
- }
104
- }}
105
- />
61
+ onJobsLoaded?.({ job, force })
62
+ }}
63
+ globalModuleStates={[]}
64
+ bind:localModuleStates
65
+ bind:selectedNode={selectedJobStep}
66
+ bind:localDurationStatuses
67
+ {onStart}
68
+ {onDone}
69
+ bind:job
70
+ {initialJob}
71
+ {jobId}
72
+ {workspaceId}
73
+ {isOwner}
74
+ {wideResults}
75
+ bind:rightColumnSelect
76
+ {render}
77
+ {customUi}
78
+ graphTabOpen={true}
79
+ isNodeSelected={true}
80
+ {refreshGlobal}
81
+ {updateGlobalRefresh}
82
+ toolCallStore={{
83
+ getStoredToolCallJob: (storeKey: string) => storedToolCallJobs[storeKey],
84
+ setStoredToolCallJob: (storeKey: string, job: Job) => {
85
+ storedToolCallJobs[storeKey] = job
86
+ },
87
+ getLocalToolCallJobs: (prefix: string) => {
88
+ // we return a map from tool call index to job
89
+ // to do so, we filter the storedToolCallJobs object by the prefix and we make sure what's left in the key is a tool call index: 2 part of format agentModuleId-toolCallIndex
90
+ // and not a further nested tool call index
91
+ return Object.fromEntries(
92
+ Object.entries(storedToolCallJobs)
93
+ .filter(
94
+ ([key]) => key.startsWith(prefix) && key.replace(prefix, '').split('-').length === 2
95
+ )
96
+ .map(([key, job]) => [Number(key.replace(prefix, '').split('-').pop()), job])
97
+ )
98
+ },
99
+ isToolCallToBeLoaded: (storeKey: string) => {
100
+ return toolCallIndicesToLoad.includes(storeKey)
101
+ },
102
+ addToolCallToLoad: (storeKey: string) => {
103
+ if (!toolCallIndicesToLoad.includes(storeKey)) {
104
+ toolCallIndicesToLoad.push(storeKey)
105
+ }
106
+ }
107
+ }}
108
+ />
109
+ {/key}
@@ -6,7 +6,7 @@ interface Props {
6
6
  jobId: string;
7
7
  initialJob?: Job | undefined;
8
8
  workspaceId?: string | undefined;
9
- flowStateStore?: FlowState;
9
+ flowState?: FlowState;
10
10
  selectedJobStep?: string | undefined;
11
11
  hideFlowResult?: boolean;
12
12
  hideTimeline?: boolean;
@@ -37,6 +37,6 @@ interface Props {
37
37
  job: CompletedJob;
38
38
  }) => void;
39
39
  }
40
- declare const FlowStatusViewer: import("svelte").Component<Props, {}, "job" | "isOwner" | "suspendStatus" | "localModuleStates" | "flowStateStore" | "rightColumnSelect" | "localDurationStatuses" | "selectedJobStep">;
40
+ declare const FlowStatusViewer: import("svelte").Component<Props, {}, "job" | "isOwner" | "suspendStatus" | "localModuleStates" | "localDurationStatuses" | "flowState" | "rightColumnSelect" | "selectedJobStep">;
41
41
  type FlowStatusViewer = ReturnType<typeof FlowStatusViewer>;
42
42
  export default FlowStatusViewer;