windmill-components 1.532.0 → 1.542.4

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 (371) hide show
  1. package/package/components/AIProviderPicker.svelte +181 -0
  2. package/package/components/AIProviderPicker.svelte.d.ts +15 -0
  3. package/package/components/ArgInfo.svelte +2 -2
  4. package/package/components/ArgInput.svelte +60 -27
  5. package/package/components/ArgInput.svelte.d.ts +3 -3
  6. package/package/components/AssignableTagsInner.svelte +89 -3
  7. package/package/components/Auth0Setting.svelte +8 -3
  8. package/package/components/ConcurrentJobsChart.svelte +36 -48
  9. package/package/components/ConcurrentJobsChart.svelte.d.ts +8 -20
  10. package/package/components/CustomPopover.svelte.d.ts +1 -1
  11. package/package/components/Dev.svelte +5 -4
  12. package/package/components/DiffDrawer.svelte +2 -2
  13. package/package/components/DiffEditor.svelte +34 -37
  14. package/package/components/DiffEditor.svelte.d.ts +23 -39
  15. package/package/components/DropdownSelect.svelte +26 -0
  16. package/package/components/DropdownSelect.svelte.d.ts +11 -0
  17. package/package/components/DropdownV2Inner.svelte +1 -1
  18. package/package/components/{DynSelect.svelte → DynamicInput.svelte} +47 -15
  19. package/package/components/DynamicInput.svelte.d.ts +11 -0
  20. package/package/components/EditableSchemaForm.svelte +155 -140
  21. package/package/components/EditableSchemaForm.svelte.d.ts +6 -7
  22. package/package/components/Editor.svelte +101 -87
  23. package/package/components/Editor.svelte.d.ts +7 -1
  24. package/package/components/EditorBar.svelte +2 -5
  25. package/package/components/FlowBuilder.svelte +10 -7
  26. package/package/components/FlowLogRow.svelte +64 -0
  27. package/package/components/FlowLogRow.svelte.d.ts +15 -0
  28. package/package/components/FlowLogViewer.svelte +406 -373
  29. package/package/components/FlowLogViewer.svelte.d.ts +5 -1
  30. package/package/components/FlowLogViewerWrapper.svelte +44 -1
  31. package/package/components/FlowLoopIterationPreview.svelte.d.ts +1 -1
  32. package/package/components/FlowPreviewContent.svelte +3 -3
  33. package/package/components/FlowPreviewContent.svelte.d.ts +1 -1
  34. package/package/components/FlowStatusViewer.svelte +28 -0
  35. package/package/components/FlowStatusViewerInner.svelte +106 -23
  36. package/package/components/FlowStatusViewerInner.svelte.d.ts +7 -0
  37. package/package/components/FolderPicker.svelte +1 -1
  38. package/package/components/InputTransformForm.svelte +20 -10
  39. package/package/components/JobArgs.svelte +1 -1
  40. package/package/components/JobLoader.svelte.d.ts +1 -1
  41. package/package/components/JobStatus.svelte +2 -0
  42. package/package/components/LogSnippetViewer.svelte +3 -3
  43. package/package/components/LogSnippetViewer.svelte.d.ts +1 -1
  44. package/package/components/LogViewer.svelte +87 -71
  45. package/package/components/LogViewer.svelte.d.ts +1 -0
  46. package/package/components/ModulePreview.svelte +2 -1
  47. package/package/components/ModulePreview.svelte.d.ts +1 -0
  48. package/package/components/ModulePreviewForm.svelte +72 -65
  49. package/package/components/ModulePreviewResultViewer.svelte +13 -18
  50. package/package/components/ModuleTest.svelte +6 -5
  51. package/package/components/ModuleTest.svelte.d.ts +1 -0
  52. package/package/components/OktaSetting.svelte +8 -3
  53. package/package/components/Path.svelte +7 -1
  54. package/package/components/Path.svelte.d.ts +1 -1
  55. package/package/components/Portal.svelte +11 -7
  56. package/package/components/Portal.svelte.d.ts +19 -39
  57. package/package/components/PrefixedInput.svelte +120 -0
  58. package/package/components/PrefixedInput.svelte.d.ts +8 -0
  59. package/package/components/QueuePosition.svelte +81 -0
  60. package/package/components/QueuePosition.svelte.d.ts +8 -0
  61. package/package/components/ResourceNarrowing.svelte +13 -0
  62. package/package/components/ResourceNarrowing.svelte.d.ts +6 -0
  63. package/package/components/ResourceTypePicker.svelte +49 -74
  64. package/package/components/RunChart.svelte +74 -89
  65. package/package/components/RunChart.svelte.d.ts +10 -22
  66. package/package/components/RunForm.svelte +2 -2
  67. package/package/components/RunForm.svelte.d.ts +1 -1
  68. package/package/components/RunFormAdvancedPopup.svelte +13 -1
  69. package/package/components/S3FilePicker.svelte +1 -1
  70. package/package/components/SchemaForm.svelte +1 -2
  71. package/package/components/SchemaForm.svelte.d.ts +2 -2
  72. package/package/components/ScriptBuilder.svelte +3 -2
  73. package/package/components/ScriptEditor.svelte +25 -10
  74. package/package/components/ScriptEditor.svelte.d.ts +2 -1
  75. package/package/components/ServiceLogsInner.svelte +1 -1
  76. package/package/components/ShareModal.svelte.d.ts +1 -1
  77. package/package/components/SimpleEditor.svelte +4 -68
  78. package/package/components/StringTypeNarrowing.svelte +5 -10
  79. package/package/components/TemplateEditor.svelte +2 -16
  80. package/package/components/TimeAgo.svelte +1 -1
  81. package/package/components/TimeAgo.svelte.d.ts +1 -0
  82. package/package/components/Toggle.svelte +2 -1
  83. package/package/components/Toggle.svelte.d.ts +2 -1
  84. package/package/components/WorkerRepl.svelte +1 -1
  85. package/package/components/apps/components/display/AppNavbarItem.svelte +2 -1
  86. package/package/components/apps/components/display/table/AppAggridTable.svelte +44 -48
  87. package/package/components/apps/components/display/table/SyncColumnDefs.svelte +101 -19
  88. package/package/components/apps/components/display/table/SyncColumnDefs.svelte.d.ts +5 -2
  89. package/package/components/apps/components/display/table/utils.js +36 -5
  90. package/package/components/apps/components/inputs/currency/CurrencyInput.svelte +10 -5
  91. package/package/components/apps/components/layout/AppModal.svelte +2 -2
  92. package/package/components/apps/editor/AppEditor.svelte +4 -3
  93. package/package/components/apps/editor/AppEditorHeader.svelte +0 -1
  94. package/package/components/apps/editor/GridViewer.svelte.d.ts +11 -4
  95. package/package/components/apps/editor/SettingsPanel.svelte +2 -2
  96. package/package/components/apps/editor/component/ComponentNavigation.svelte +3 -2
  97. package/package/components/apps/editor/componentsPanel/ListItem.svelte +2 -2
  98. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +1 -1
  99. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte.d.ts +1 -1
  100. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte.d.ts +1 -1
  101. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte +0 -1
  102. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte.d.ts +1 -1
  103. package/package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte +29 -4
  104. package/package/components/apps/editor/settingsPanel/GridCondition.svelte +3 -1
  105. package/package/components/apps/editor/settingsPanel/GridNavbar.svelte +3 -1
  106. package/package/components/apps/editor/settingsPanel/GridTab.svelte +3 -1
  107. package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +1 -1
  108. package/package/components/apps/editor/settingsPanel/OneOfInputSpecsEditor.svelte +55 -53
  109. package/package/components/apps/editor/settingsPanel/TableActions.svelte +3 -1
  110. package/package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte +13 -5
  111. package/package/components/apps/svelte-grid/Grid.svelte.d.ts +30 -11
  112. package/package/components/assets/JobAssetsViewer.svelte +28 -24
  113. package/package/components/auditLogs/AuditLogsTable.svelte +2 -6
  114. package/package/components/chartjs-wrappers/Chart.svelte.d.ts +14 -7
  115. package/package/components/common/OnChange.svelte.d.ts +11 -4
  116. package/package/components/common/badge/Badge.svelte +9 -2
  117. package/package/components/common/badge/Badge.svelte.d.ts +2 -1
  118. package/package/components/common/button/model.d.ts +1 -1
  119. package/package/components/common/calendarPicker/CalendarPicker.svelte +5 -1
  120. package/package/components/common/calendarPicker/CalendarPicker.svelte.d.ts +5 -4
  121. package/package/components/common/drawer/Disposable.svelte +45 -26
  122. package/package/components/common/drawer/Disposable.svelte.d.ts +12 -44
  123. package/package/components/common/drawer/Drawer.svelte +17 -14
  124. package/package/components/common/drawer/Drawer.svelte.d.ts +1 -0
  125. package/package/components/common/menu/MenuItem.svelte.d.ts +2 -2
  126. package/package/components/common/modal/Modal.svelte.d.ts +1 -1
  127. package/package/components/common/tabs/TabContent.svelte +2 -7
  128. package/package/components/common/tabs/TabContent.svelte.d.ts +5 -27
  129. package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte +9 -3
  130. package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte.d.ts +1 -0
  131. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte +8 -4
  132. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte.d.ts +1 -0
  133. package/package/components/copilot/MetadataGen.svelte +14 -3
  134. package/package/components/copilot/chat/AIChatInput.svelte +0 -1
  135. package/package/components/copilot/chat/AIChatManager.svelte.js +26 -104
  136. package/package/components/copilot/chat/AssistantMessage.svelte +0 -4
  137. package/package/components/copilot/chat/AvailableContextList.svelte +192 -66
  138. package/package/components/copilot/chat/AvailableContextList.svelte.d.ts +2 -2
  139. package/package/components/copilot/chat/ContextElementBadge.svelte +3 -3
  140. package/package/components/copilot/chat/ContextManager.svelte.js +36 -13
  141. package/package/components/copilot/chat/ContextTextarea.svelte +21 -48
  142. package/package/components/copilot/chat/ToolContentDisplay.svelte +10 -1
  143. package/package/components/copilot/chat/ToolExecutionDisplay.svelte +3 -3
  144. package/package/components/copilot/chat/anthropic.d.ts +15 -0
  145. package/package/components/copilot/chat/anthropic.js +208 -0
  146. package/package/components/copilot/chat/api/apiTools.d.ts +2 -2
  147. package/package/components/copilot/chat/api/apiTools.js +10 -7
  148. package/package/components/copilot/chat/api/core.d.ts +1 -1
  149. package/package/components/copilot/chat/api/core.js +7 -2
  150. package/package/components/copilot/chat/ask/core.d.ts +1 -1
  151. package/package/components/copilot/chat/ask/core.js +7 -2
  152. package/package/components/copilot/chat/context.d.ts +7 -2
  153. package/package/components/copilot/chat/flow/FlowAIChat.svelte +110 -8
  154. package/package/components/copilot/chat/flow/core.d.ts +12 -1
  155. package/package/components/copilot/chat/flow/core.js +133 -5
  156. package/package/components/copilot/chat/flow/uiIntents.d.ts +8 -0
  157. package/package/components/copilot/chat/flow/uiIntents.js +5 -0
  158. package/package/components/copilot/chat/flow/useUiIntent.d.ts +5 -0
  159. package/package/components/copilot/chat/flow/useUiIntent.js +12 -0
  160. package/package/components/copilot/chat/monaco-adapter.d.ts +23 -4
  161. package/package/components/copilot/chat/monaco-adapter.js +55 -16
  162. package/package/components/copilot/chat/navigator/core.d.ts +1 -1
  163. package/package/components/copilot/chat/navigator/core.js +7 -2
  164. package/package/components/copilot/chat/script/CodeDisplay.svelte +10 -111
  165. package/package/components/copilot/chat/script/core.d.ts +5 -4
  166. package/package/components/copilot/chat/script/core.js +134 -21
  167. package/package/components/copilot/chat/shared.d.ts +10 -9
  168. package/package/components/copilot/chat/shared.js +24 -12
  169. package/package/components/copilot/lib.d.ts +29 -8
  170. package/package/components/copilot/lib.js +211 -31
  171. package/package/components/copilot/shared.d.ts +1 -1
  172. package/package/components/copilot/shared.js +16 -10
  173. package/package/components/flows/FlowEditor.svelte +4 -2
  174. package/package/components/flows/FlowEditor.svelte.d.ts +1 -0
  175. package/package/components/flows/FlowModuleIcon.svelte +8 -8
  176. package/package/components/flows/common/FlowCardHeader.svelte +4 -1
  177. package/package/components/flows/content/FlowBranchesAllWrapper.svelte +6 -0
  178. package/package/components/flows/content/FlowBranchesOneWrapper.svelte +6 -0
  179. package/package/components/flows/content/FlowEditorPanel.svelte +2 -1
  180. package/package/components/flows/content/FlowEditorPanel.svelte.d.ts +1 -0
  181. package/package/components/flows/content/FlowInput.svelte +36 -39
  182. package/package/components/flows/content/FlowInput.svelte.d.ts +1 -0
  183. package/package/components/flows/content/FlowLoop.svelte +7 -0
  184. package/package/components/flows/content/FlowModuleComponent.svelte +42 -46
  185. package/package/components/flows/content/FlowModuleEarlyStop.svelte +47 -17
  186. package/package/components/flows/content/FlowModuleScript.svelte +1 -1
  187. package/package/components/flows/content/FlowModuleSleep.svelte +4 -1
  188. package/package/components/flows/content/FlowModuleSuspend.svelte +15 -18
  189. package/package/components/flows/content/FlowModuleTimeout.svelte +50 -10
  190. package/package/components/flows/content/FlowModuleTimeout.svelte.d.ts +1 -0
  191. package/package/components/flows/content/FlowRetries.svelte +108 -3
  192. package/package/components/flows/content/FlowRetries.svelte.d.ts +3 -2
  193. package/package/components/flows/content/FlowWhileLoop.svelte +6 -0
  194. package/package/components/flows/content/ScriptEditorDrawer.svelte +9 -11
  195. package/package/components/flows/dfs.d.ts +1 -1
  196. package/package/components/flows/dfs.js +6 -6
  197. package/package/components/flows/flowInfers.js +15 -42
  198. package/package/components/flows/flowStateUtils.svelte.js +1 -2
  199. package/package/components/flows/flowStore.d.ts +45 -1
  200. package/package/components/flows/flowStore.js +1 -1
  201. package/package/components/flows/map/FlowJobsMenu.svelte +3 -3
  202. package/package/components/flows/map/FlowModuleSchemaItem.svelte +73 -80
  203. package/package/components/flows/map/FlowModuleSchemaItem.svelte.d.ts +1 -1
  204. package/package/components/flows/map/FlowModuleSchemaItemViewer.svelte +1 -1
  205. package/package/components/flows/map/InsertModuleButton.svelte +1 -0
  206. package/package/components/flows/map/InsertModuleInner.svelte +12 -15
  207. package/package/components/flows/map/InsertModuleInner.svelte.d.ts +10 -9
  208. package/package/components/flows/map/MapItem.svelte +8 -4
  209. package/package/components/flows/map/VirtualItem.svelte +1 -1
  210. package/package/components/flows/pickers/TopLevelNode.svelte +1 -1
  211. package/package/components/flows/propPicker/InputPickerInner.svelte +5 -5
  212. package/package/components/flows/propPicker/OutputPickerInner.svelte +143 -118
  213. package/package/components/flows/propPicker/OutputPickerInner.svelte.d.ts +7 -16
  214. package/package/components/flows/{testSteps.svelte.d.ts → stepsInputArgs.svelte.d.ts} +2 -1
  215. package/package/components/flows/{testSteps.svelte.js → stepsInputArgs.svelte.js} +15 -3
  216. package/package/components/flows/types.d.ts +16 -3
  217. package/package/components/flows/utils.js +3 -0
  218. package/package/components/git_sync/DetectionFlow.svelte +15 -17
  219. package/package/components/git_sync/GitSyncContext.svelte.js +1 -1
  220. package/package/components/git_sync/GitSyncRepositoryCard.svelte +0 -1
  221. package/package/components/graph/FlowGraphV2.svelte +1 -1
  222. package/package/components/graph/graphBuilder.svelte.d.ts +5 -1
  223. package/package/components/graph/renderers/edges/BaseEdge.svelte +9 -1
  224. package/package/components/graph/renderers/edges/BaseEdge.svelte.d.ts +4 -1
  225. package/package/components/graph/renderers/nodes/AIToolNode.svelte +4 -4
  226. package/package/components/graph/renderers/nodes/BranchAllStart.svelte +2 -3
  227. package/package/components/graph/renderers/nodes/BranchOneStart.svelte +2 -3
  228. package/package/components/graph/renderers/nodes/NewAIToolNode.svelte +71 -54
  229. package/package/components/graph/renderers/triggers/TriggerButton.svelte.d.ts +1 -1
  230. package/package/components/graph/renderers/triggers/TriggersBadge.svelte +3 -1
  231. package/package/components/graph/renderers/triggers/TriggersWrapper.svelte +34 -24
  232. package/package/components/graph/renderers/triggers/TriggersWrapper.svelte.d.ts +1 -2
  233. package/package/components/home/ItemsList.svelte +17 -13
  234. package/package/components/home/TreeView.svelte +21 -27
  235. package/package/components/home/TreeView.svelte.d.ts +2 -29
  236. package/package/components/home/TreeViewRoot.svelte +11 -23
  237. package/package/components/home/TreeViewRoot.svelte.d.ts +15 -13
  238. package/package/components/icons/GitIcon.svelte +10 -2
  239. package/package/components/icons/GitIcon.svelte.d.ts +1 -0
  240. package/package/components/meltComponents/MeltButton.svelte.d.ts +1 -1
  241. package/package/components/meltComponents/Popover.svelte +23 -3
  242. package/package/components/meltComponents/Popover.svelte.d.ts +2 -1
  243. package/package/components/monacoLanguagesOptions.d.ts +3 -0
  244. package/package/components/monacoLanguagesOptions.js +109 -0
  245. package/package/components/propertyPicker/ObjectViewer.svelte +18 -5
  246. package/package/components/propertyPicker/PropPicker.svelte +1 -1
  247. package/package/components/propertyPicker/utils.js +14 -7
  248. package/package/components/raw_apps/RawAppInlineScriptEditor.svelte +1 -1
  249. package/package/components/runs/JobRunsPreview.svelte +212 -177
  250. package/package/components/runs/JobsLoader.svelte +2 -2
  251. package/package/components/runs/JobsLoader.svelte.d.ts +1 -1
  252. package/package/components/runs/NoWorkerWithTagWarning.svelte +18 -5
  253. package/package/components/runs/RunBadges.svelte +100 -0
  254. package/package/components/runs/RunBadges.svelte.d.ts +12 -0
  255. package/package/components/runs/RunLabels.svelte +86 -0
  256. package/package/components/runs/RunLabels.svelte.d.ts +10 -0
  257. package/package/components/runs/RunOption.svelte +20 -0
  258. package/package/components/runs/RunOption.svelte.d.ts +10 -0
  259. package/package/components/runs/RunRow.svelte +239 -151
  260. package/package/components/runs/RunRow.svelte.d.ts +12 -9
  261. package/package/components/runs/RunsBatchActionsDropdown.svelte +13 -17
  262. package/package/components/runs/RunsBatchActionsDropdown.svelte.d.ts +5 -18
  263. package/package/components/runs/RunsFilter.svelte +369 -243
  264. package/package/components/runs/RunsFilter.svelte.d.ts +2 -0
  265. package/package/components/runs/RunsQueue.svelte +96 -25
  266. package/package/components/runs/RunsQueue.svelte.d.ts +7 -21
  267. package/package/components/runs/RunsTable.svelte +62 -71
  268. package/package/components/runs/RunsTable.svelte.d.ts +2 -1
  269. package/package/components/runs/runs-grid.css +95 -0
  270. package/package/components/schema/AddPropertyV2.svelte +2 -7
  271. package/package/components/schema/AddPropertyV2.svelte.d.ts +3 -20
  272. package/package/components/schema/EditableSchemaDrawer.svelte +121 -127
  273. package/package/components/schema/EditableSchemaDrawer.svelte.d.ts +2 -1
  274. package/package/components/schema/EditableSchemaSdkWrapper.svelte +16 -3
  275. package/package/components/schema/EditableSchemaSdkWrapper.svelte.d.ts +4 -1
  276. package/package/components/schema/EditableSchemaWrapper.svelte +3 -10
  277. package/package/components/schema/FlowPropertyEditor.svelte +195 -236
  278. package/package/components/schema/FlowPropertyEditor.svelte.d.ts +1 -1
  279. package/package/components/schema/PropertyEditor.svelte +33 -35
  280. package/package/components/schema/SchemaFormDND.svelte +11 -10
  281. package/package/components/schema/SchemaFormDND.svelte.d.ts +4 -3
  282. package/package/components/schema/editable_schema_wrapper.d.ts +0 -3
  283. package/package/components/search/GlobalSearchModal.svelte +8 -1
  284. package/package/components/select/DraggableTags.svelte.d.ts +17 -7
  285. package/package/components/select/MultiSelect.svelte.d.ts +21 -11
  286. package/package/components/select/Select.svelte +2 -1
  287. package/package/components/select/Select.svelte.d.ts +25 -13
  288. package/package/components/select/SelectDropdown.svelte.d.ts +14 -7
  289. package/package/components/settings/PremiumInfo.svelte +7 -2
  290. package/package/components/settings/TokenDisplay.svelte +1 -1
  291. package/package/components/sidebar/OperatorMenu.svelte +5 -0
  292. package/package/components/sidebar/SidebarContent.svelte +48 -2
  293. package/package/components/sidebar/WorkspaceMenu.svelte +116 -17
  294. package/package/components/toast.js +6 -3
  295. package/package/components/triggers/AddTriggersButton.svelte +7 -6
  296. package/package/components/triggers/CaptureWrapper.svelte +21 -16
  297. package/package/components/triggers/CaptureWrapper.svelte.d.ts +1 -1
  298. package/package/components/triggers/TriggerLabel.svelte +8 -0
  299. package/package/components/triggers/TriggerTokens.svelte +1 -1
  300. package/package/components/triggers/TriggersEditor.svelte +9 -5
  301. package/package/components/triggers/TriggersTable.svelte +2 -2
  302. package/package/components/triggers/TriggersWrapper.svelte +17 -5
  303. package/package/components/triggers/TriggersWrapper.svelte.d.ts +3 -19
  304. package/package/components/{details/EmailTriggerCaptures.svelte → triggers/email/DefaultEmailCapture.svelte} +5 -5
  305. package/package/components/{details/EmailTriggerCaptures.svelte.d.ts → triggers/email/DefaultEmailCapture.svelte.d.ts} +4 -4
  306. package/package/components/{details/EmailTriggerConfigSection.svelte → triggers/email/DefaultEmailConfigSection.svelte} +24 -14
  307. package/package/components/triggers/email/DefaultEmailConfigSection.svelte.d.ts +13 -0
  308. package/package/components/triggers/email/DefaultEmailPanel.svelte +71 -0
  309. package/package/components/triggers/email/DefaultEmailPanel.svelte.d.ts +11 -0
  310. package/package/components/triggers/email/EmailCapture.svelte +39 -0
  311. package/package/components/triggers/email/EmailCapture.svelte.d.ts +43 -0
  312. package/package/components/triggers/email/EmailTriggerEditor.svelte +20 -0
  313. package/package/components/triggers/email/EmailTriggerEditor.svelte.d.ts +11 -0
  314. package/package/components/triggers/email/EmailTriggerEditorConfigSection.svelte +133 -0
  315. package/package/components/triggers/email/EmailTriggerEditorConfigSection.svelte.d.ts +14 -0
  316. package/package/components/triggers/email/EmailTriggerEditorInner.svelte +335 -0
  317. package/package/components/triggers/email/EmailTriggerEditorInner.svelte.d.ts +22 -0
  318. package/package/components/triggers/email/EmailTriggerPanel.svelte +61 -0
  319. package/package/components/triggers/email/EmailTriggerPanel.svelte.d.ts +14 -0
  320. package/package/components/triggers/email/utils.d.ts +4 -0
  321. package/package/components/triggers/email/utils.js +52 -0
  322. package/package/components/triggers/http/RouteEditorConfigSection.svelte +1 -1
  323. package/package/components/triggers/http/RouteEditorInner.svelte +1 -1
  324. package/package/components/triggers/http/utils.js +1 -1
  325. package/package/components/triggers/nats/NatsTriggerEditorInner.svelte +23 -20
  326. package/package/components/triggers/nats/NatsTriggersConfigSection.svelte +15 -27
  327. package/package/components/triggers/nats/NatsTriggersConfigSection.svelte.d.ts +7 -5
  328. package/package/components/triggers/triggers.svelte.d.ts +1 -0
  329. package/package/components/triggers/triggers.svelte.js +24 -2
  330. package/package/components/triggers/utils.js +19 -5
  331. package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +16 -16
  332. package/package/components/triggers.d.ts +1 -1
  333. package/package/components/triggers.js +2 -0
  334. package/package/components/wizards/AgGridWizard.svelte +85 -80
  335. package/package/components/workspaceSettings/AISettings.svelte +74 -22
  336. package/package/components/workspaceSettings/AISettings.svelte.d.ts +2 -1
  337. package/package/components/workspaceSettings/CreateWorkspace.svelte +395 -0
  338. package/package/components/workspaceSettings/CreateWorkspace.svelte.d.ts +6 -0
  339. package/package/components/workspaceSettings/DucklakeSettings.svelte +3 -1
  340. package/package/components/workspaceSettings/GitSyncFilterSettings.svelte +1 -1
  341. package/package/components/workspaceSettings/StorageSettings.svelte +69 -48
  342. package/package/gen/core/OpenAPI.js +1 -1
  343. package/package/gen/schemas.gen.d.ts +142 -3
  344. package/package/gen/schemas.gen.js +144 -3
  345. package/package/gen/services.gen.d.ts +129 -1
  346. package/package/gen/services.gen.js +267 -1
  347. package/package/gen/types.gen.d.ts +434 -8
  348. package/package/hubPaths.json +6 -2
  349. package/package/infer.js +1 -1
  350. package/package/keyboardChain.d.ts +5 -0
  351. package/package/keyboardChain.js +40 -0
  352. package/package/script_helpers.d.ts +2 -2
  353. package/package/script_helpers.js +2 -0
  354. package/package/services/JobManager.js +2 -2
  355. package/package/stores.d.ts +4 -1
  356. package/package/stores.js +16 -6
  357. package/package/utils/workspaceHierarchy.d.ts +27 -0
  358. package/package/utils/workspaceHierarchy.js +101 -0
  359. package/package/utils.d.ts +6 -3
  360. package/package/utils.js +30 -15
  361. package/package/workspace_settings.js +2 -3
  362. package/package.json +10 -12
  363. package/package/components/DynSelect.svelte.d.ts +0 -11
  364. package/package/components/ModulePreviewResultViewer.svelte.d.ts +0 -28
  365. package/package/components/ObjectTypeNarrowing.svelte +0 -18
  366. package/package/components/ObjectTypeNarrowing.svelte.d.ts +0 -22
  367. package/package/components/details/DetailPageTriggerPanel.svelte +0 -121
  368. package/package/components/details/DetailPageTriggerPanel.svelte.d.ts +0 -20
  369. package/package/components/details/EmailTriggerConfigSection.svelte.d.ts +0 -12
  370. package/package/components/details/EmailTriggerPanel.svelte +0 -76
  371. package/package/components/details/EmailTriggerPanel.svelte.d.ts +0 -26
@@ -11,13 +11,13 @@ import { twMerge } from 'tailwind-merge';
11
11
  import FlowPropertyEditor from './schema/FlowPropertyEditor.svelte';
12
12
  import PropertyEditor from './schema/PropertyEditor.svelte';
13
13
  import SimpleEditor from './SimpleEditor.svelte';
14
- import { createEventDispatcher, tick, untrack } from 'svelte';
14
+ import { createEventDispatcher, untrack } from 'svelte';
15
15
  import ToggleButton from './common/toggleButton-v2/ToggleButton.svelte';
16
16
  import ToggleButtonGroup from './common/toggleButton-v2/ToggleButtonGroup.svelte';
17
17
  import Label from './Label.svelte';
18
18
  import { sendUserToast } from '../toast';
19
19
  import Toggle from './Toggle.svelte';
20
- import { DynamicSelect, emptyString } from '../utils';
20
+ import { DynamicInput, emptyString, generateRandomString, readFieldsRecursively } from '../utils';
21
21
  import Popover from './meltComponents/Popover.svelte';
22
22
  import SchemaFormDnd from './schema/SchemaFormDND.svelte';
23
23
  import { deepEqual } from 'fast-equals';
@@ -27,23 +27,29 @@ import Editor from './Editor.svelte';
27
27
  import AddPropertyV2 from './schema/AddPropertyV2.svelte';
28
28
  // export let openEditTab: () => void = () => {}
29
29
  const dispatch = createEventDispatcher();
30
- let { schema = $bindable(), hiddenArgs = [], args = $bindable(undefined), shouldHideNoInputs = false, noVariablePicker = false, flexWrap = false, uiOnly = false, isFlowInput = false, noPreview = false, jsonEnabled = true, isAppInput = false, displayWebhookWarning = false, onlyMaskPassword = false, dndType = undefined, editTab, previewSchema = undefined, editPanelInitialSize = undefined, editPanelSize = $bindable(0), diff = {}, disableDnd = false, shouldDispatchChanges = false, isValid = $bindable(true), customUi = undefined, pannelExtraButtonWidth = 0, class: clazz = '', dynSelectCode = $bindable(), dynSelectLang = $bindable(), showDynSelectOpt = false, addPropertyInEditorTab = false, openEditTab, addProperty, runButton, extraTab } = $props();
30
+ let { schema = $bindable(), hiddenArgs = [], args = $bindable(undefined), shouldHideNoInputs = false, noVariablePicker = false, flexWrap = false, uiOnly = false, isFlowInput = false, noPreview = false, jsonEnabled = true, isAppInput = false, displayWebhookWarning = false, onlyMaskPassword = false, editTab, previewSchema = undefined, editPanelInitialSize = undefined, editPanelSize = $bindable(0), diff = {}, disableDnd = false, shouldDispatchChanges = false, isValid = $bindable(true), customUi = undefined, pannelExtraButtonWidth = 0, class: clazz = '', dynCode = $bindable(), dynLang = $bindable(), showDynOpt = false, addPropertyInEditorTab = false, openEditTab, addProperty, runButton, extraTab, schemaFormClassName = undefined, onChange = undefined } = $props();
31
31
  $effect.pre(() => {
32
32
  if (args == undefined) {
33
33
  args = {};
34
34
  }
35
- if (dynSelectLang === undefined) {
36
- dynSelectLang = schema?.['x-windmill-dyn-select-lang'] || 'bun';
35
+ if (dynLang === undefined) {
36
+ dynLang = schema?.['x-windmill-dyn-select-lang'] || 'bun';
37
37
  }
38
- if (dynSelectCode === undefined) {
39
- dynSelectCode = schema?.['x-windmill-dyn-select-code'] || '';
38
+ if (dynCode === undefined) {
39
+ dynCode = schema?.['x-windmill-dyn-select-code'] || '';
40
40
  }
41
41
  });
42
42
  $effect(() => {
43
- if (schema && dynSelectCode !== undefined && dynSelectLang !== undefined) {
44
- if (dynSelectCode && dynSelectCode.trim()) {
45
- schema['x-windmill-dyn-select-code'] = dynSelectCode.trim();
46
- schema['x-windmill-dyn-select-lang'] = dynSelectLang;
43
+ if (onChange) {
44
+ readFieldsRecursively(args);
45
+ onChange(args ?? {});
46
+ }
47
+ });
48
+ $effect(() => {
49
+ if (schema && dynCode !== undefined && dynLang !== undefined) {
50
+ if (dynCode && dynCode.trim()) {
51
+ schema['x-windmill-dyn-select-code'] = dynCode.trim();
52
+ schema['x-windmill-dyn-select-lang'] = dynLang;
47
53
  }
48
54
  else {
49
55
  delete schema['x-windmill-dyn-select-code'];
@@ -64,9 +70,9 @@ export function setDefaults() {
64
70
  let pickForField;
65
71
  let itemPicker = $state(undefined);
66
72
  let variableEditor = $state(undefined);
67
- let keys = $state(Array.isArray(schema?.order)
73
+ let keys = $state((Array.isArray(schema?.order)
68
74
  ? [...schema.order]
69
- : (Object.keys(schema?.properties ?? {}) ?? Object.keys(schema?.properties ?? {})));
75
+ : (Object.keys(schema?.properties ?? {}) ?? Object.keys(schema?.properties ?? {}))).filter((x) => !hiddenArgs?.includes(x)));
70
76
  function alignOrderWithProperties(schema) {
71
77
  if (schema.order == undefined && !Array.isArray(schema.order)) {
72
78
  schema.order = [];
@@ -92,36 +98,34 @@ function alignOrderWithProperties(schema) {
92
98
  return hasChanged;
93
99
  }
94
100
  function onSchemaChange() {
95
- let editSchema = false;
96
101
  if (alignOrderWithProperties(schema)) {
97
- console.log('alignOrderWithProperties', JSON.stringify(schema, null, 2));
98
- editSchema = true;
102
+ // console.log('alignOrderWithProperties', JSON.stringify(schema, null, 2))
99
103
  }
100
- let lkeys = schema?.order ?? Object.keys(schema?.properties ?? {});
104
+ let lkeys = (schema?.order ?? Object.keys(schema?.properties ?? {})).filter((x) => !hiddenArgs?.includes(x));
101
105
  if (schema?.properties && !deepEqual(lkeys, keys)) {
102
106
  keys = [...lkeys];
103
- editSchema = true;
104
107
  if (opened == undefined) {
105
108
  opened = keys[0];
106
109
  }
107
110
  }
108
- if (editSchema) {
109
- schema = schema;
110
- }
111
111
  }
112
112
  let opened = $state(untrack(() => keys[0]));
113
113
  function computeSelected(property) {
114
114
  if (!opened)
115
115
  return '';
116
- return property.type !== 'object'
117
- ? property.type
118
- : property.format === 'resource-s3_object'
119
- ? 'S3'
120
- : property.format?.startsWith('dynselect-')
121
- ? 'dynselect'
122
- : property.oneOf && property.oneOf.length >= 2
123
- ? 'oneOf'
124
- : 'object';
116
+ if (property.type !== 'object')
117
+ return property.type;
118
+ if (property.format === 'resource-s3_object')
119
+ return 'S3';
120
+ if (property.format?.startsWith('dynselect-'))
121
+ return 'dynselect';
122
+ if (property.format?.startsWith('dynmultiselect-'))
123
+ return 'dynmultiselect';
124
+ if (property.oneOf && property.oneOf.length >= 2)
125
+ return 'oneOf';
126
+ if (property.format?.startsWith('resource-'))
127
+ return 'resource';
128
+ return 'object';
125
129
  }
126
130
  export function openField(key) {
127
131
  opened = key;
@@ -148,25 +152,25 @@ function renameProperty(oldName, key) {
148
152
  el.value = oldName;
149
153
  }
150
154
  else {
155
+ let newSchema = $state.snapshot(schema);
151
156
  if (args) {
152
157
  args[newName] = args[oldName];
153
158
  delete args[oldName];
154
159
  }
155
- schema.properties[newName] = schema.properties[oldName];
156
- delete schema.properties[oldName];
157
- if (schema.required?.includes(oldName)) {
158
- schema.required = schema.required?.map((x) => (x === oldName ? newName : x));
160
+ newSchema.properties[newName] = newSchema.properties[oldName];
161
+ delete newSchema.properties[oldName];
162
+ if (newSchema.required?.includes(oldName)) {
163
+ newSchema.required = newSchema.required?.map((x) => (x === oldName ? newName : x));
159
164
  }
160
165
  // Replace the old name with the new name in the order array
161
- if (schema.order) {
162
- const index = schema.order.indexOf(oldName);
166
+ if (newSchema.order) {
167
+ const index = newSchema.order.indexOf(oldName);
163
168
  if (index !== -1) {
164
- schema.order[index] = newName;
169
+ newSchema.order[index] = newName;
165
170
  }
166
171
  }
167
172
  opened = newName;
168
- schema = $state.snapshot(schema);
169
- dispatch('change', schema);
173
+ schema = newSchema;
170
174
  sendUserToast('Argument renamed');
171
175
  }
172
176
  }
@@ -216,37 +220,37 @@ $effect(() => {
216
220
  $effect(() => {
217
221
  !!editTab ? openEditTabFn() : closeEditTab();
218
222
  });
219
- let dynSelectFunctions = $derived(Object.entries(schema?.properties ?? {})
223
+ let dynamicFunctions = $derived(Object.entries(schema?.properties ?? {})
220
224
  .filter(([_, property]) => {
221
225
  const props = property;
222
- return (props.type === 'object' &&
223
- (props.format?.startsWith('dynselect-') || props.format?.startsWith('dynselect_')));
226
+ return props.type === 'object' && DynamicInput.isDynInputFormat(props.format);
224
227
  })
225
228
  .map(([fieldName, _]) => fieldName.replace(/\s+/g, '_')));
226
- let typeOptions = [
229
+ const DYNAMIC_OPTIONS = [
230
+ ['DynSelect', 'dynselect'],
231
+ ['DynMultiselect', 'dynmultiselect']
232
+ ];
233
+ let typeOptions = $state([
227
234
  ['String', 'string'],
228
235
  ['Number', 'number'],
229
236
  ['Integer', 'integer'],
230
237
  ['Object', 'object'],
238
+ ['Resource', 'resource'],
231
239
  ['OneOf', 'oneOf'],
232
240
  ['Array', 'array'],
233
241
  ['Boolean', 'boolean'],
234
- ['S3 Object', 'S3']
235
- ];
236
- if (showDynSelectOpt) {
237
- typeOptions.push(['DynSelect', 'dynselect']);
238
- }
239
- function initDynSelectFn(lang) {
240
- const generateFn = DynamicSelect.getGenerateTemplateFn(lang);
241
- return Object.entries(schema?.properties ?? {})
242
- .map(([functionName]) => generateFn(functionName))
243
- .join('');
242
+ ['S3', 'S3']
243
+ ]);
244
+ function initDynFn(lang) {
245
+ const generateFn = DynamicInput.getGenerateTemplateFn(lang);
246
+ return dynamicFunctions.map((functionName) => generateFn(functionName)).join('');
244
247
  }
245
- function updateDynSelectCode(functionName, lang = 'bun') {
246
- const generateFn = DynamicSelect.getGenerateTemplateFn(lang);
248
+ function updateDynCode(functionName, lang = 'bun') {
249
+ const generateFn = DynamicInput.getGenerateTemplateFn(lang);
247
250
  const code = generateFn(functionName);
248
- dynSelectCode = dynSelectCode ? dynSelectCode.concat(code) : code;
251
+ dynCode = dynCode ? dynCode.concat(code) : code;
249
252
  }
253
+ let dndType = $state(generateRandomString());
250
254
  </script>
251
255
 
252
256
  <div class="w-full h-full">
@@ -283,15 +287,15 @@ function updateDynSelectCode(functionName, lang = 'bun') {
283
287
  class="min-h-0 overflow-y-auto grow rounded-md {runButton ? 'flex flex-col gap-2' : ''}"
284
288
  >
285
289
  <SchemaFormDnd
286
- nestedClasses={'flex flex-col gap-1'}
290
+ {dndType}
291
+ nestedClasses={'flex flex-col gap-1 ' + (schemaFormClassName ?? '')}
287
292
  bind:schema={
288
293
  () => (previewSchema ? previewSchema : schema),
289
294
  (newSchema) => {
290
295
  schema = newSchema
291
- tick().then(() => dispatch('change', schema))
292
296
  }
293
297
  }
294
- {dndType}
298
+ {hiddenArgs}
295
299
  {disableDnd}
296
300
  {onlyMaskPassword}
297
301
  bind:args
@@ -299,25 +303,27 @@ function updateDynSelectCode(functionName, lang = 'bun') {
299
303
  opened = e.detail
300
304
  }}
301
305
  on:reorder={(e) => {
306
+ let order = e.detail
307
+ let newProperties = {}
308
+ for (let key of order) {
309
+ newProperties[key] = schema.properties[key]
310
+ }
302
311
  schema = {
303
312
  ...schema,
313
+ properties: newProperties,
304
314
  order: e.detail
305
315
  }
306
- tick().then(() => dispatch('change', schema))
307
316
  }}
308
317
  helperScript={{
309
318
  type: 'inline',
310
- code: dynSelectCode!,
311
- lang: dynSelectLang!
319
+ code: dynCode!,
320
+ lang: dynLang!
312
321
  }}
313
322
  prettifyHeader={isAppInput}
314
323
  disabled={!!previewSchema}
315
324
  {diff}
316
325
  on:acceptChange
317
326
  on:rejectChange
318
- on:nestedChange={() => {
319
- dispatch('change', schema)
320
- }}
321
327
  {shouldDispatchChanges}
322
328
  bind:isValid
323
329
  noVariablePicker={noVariablePicker || customUi?.disableVariablePicker === true}
@@ -325,56 +331,54 @@ function updateDynSelectCode(functionName, lang = 'bun') {
325
331
 
326
332
  {@render runButton?.()}
327
333
 
328
- <div class="h-full">
329
- {#if dynSelectFunctions.length > 0}
330
- <Section
331
- label="Dynamic select functions"
332
- collapsable={true}
333
- collapsed={false}
334
- class="text-sm"
335
- >
336
- <div class="flex flex-col gap-2 h-full">
337
- {#if dynSelectFunctions.length > 0}
338
- <div class="bg-blue-50 dark:bg-blue-900/20 p-3 rounded-md">
339
- <div class="text-sm font-medium text-blue-800 dark:text-blue-200 mb-2">
340
- Expected Functions for Dynamic Select Fields:
341
- </div>
342
- <ul class="text-xs text-blue-700 dark:text-blue-300 space-y-1">
343
- {#each dynSelectFunctions as functionName}
344
- <li class="font-mono bg-blue-100 dark:bg-blue-800/30 px-2 py-1 rounded">
345
- {functionName}()
346
- </li>
347
- {/each}
348
- </ul>
349
- </div>
350
- {/if}
351
- <ToggleButtonGroup
352
- bind:selected={dynSelectLang}
353
- on:selected={({ detail }) => {
354
- dynSelectCode = initDynSelectFn(detail)
355
- }}
356
- >
357
- {#snippet children({ item })}
358
- <ToggleButton value="bun" label="Typescript (Bun)" {item} />
359
- <ToggleButton value="python3" label="Python" {item} />
360
- {/snippet}
361
- </ToggleButtonGroup>
362
- {#key dynSelectLang}
363
- <div class="border w-full h-full">
364
- <Editor
365
- bind:this={dynamicSelectEditor}
366
- class="flex flex-1 grow h-80 w-full"
367
- scriptLang={dynSelectLang}
368
- useWebsockets={false}
369
- automaticLayout
370
- bind:code={dynSelectCode}
371
- />
334
+ {#if dynamicFunctions.length > 0}
335
+ <Section
336
+ label="Dynamic input functions"
337
+ collapsable={true}
338
+ collapsed={false}
339
+ class="text-sm"
340
+ >
341
+ <div class="flex flex-col gap-2 h-full">
342
+ {#if dynamicFunctions.length > 0}
343
+ <div class="bg-blue-50 dark:bg-blue-900/20 p-3 rounded-md">
344
+ <div class="text-sm font-medium text-blue-800 dark:text-blue-200 mb-2">
345
+ Expected Functions for Dynamic Input Fields:
372
346
  </div>
373
- {/key}
374
- </div>
375
- </Section>
376
- {/if}
377
- </div>
347
+ <ul class="text-xs text-blue-700 dark:text-blue-300 space-y-1">
348
+ {#each dynamicFunctions as functionName}
349
+ <li class="font-mono bg-blue-100 dark:bg-blue-800/30 px-2 py-1 rounded">
350
+ {functionName}()
351
+ </li>
352
+ {/each}
353
+ </ul>
354
+ </div>
355
+ {/if}
356
+ <ToggleButtonGroup
357
+ bind:selected={dynLang}
358
+ on:selected={({ detail }) => {
359
+ dynCode = initDynFn(detail)
360
+ }}
361
+ >
362
+ {#snippet children({ item })}
363
+ <ToggleButton value="bun" label="Typescript (Bun)" {item} />
364
+ <ToggleButton value="python3" label="Python" {item} />
365
+ {/snippet}
366
+ </ToggleButtonGroup>
367
+ {#key dynLang}
368
+ <div class="border w-full h-full">
369
+ <Editor
370
+ bind:this={dynamicSelectEditor}
371
+ class="flex flex-1 grow h-80 w-full"
372
+ scriptLang={dynLang}
373
+ useWebsockets={false}
374
+ automaticLayout
375
+ bind:code={dynCode}
376
+ />
377
+ </div>
378
+ {/key}
379
+ </div>
380
+ </Section>
381
+ {/if}
378
382
  </div>
379
383
  </div>
380
384
  </Pane>
@@ -393,7 +397,12 @@ function updateDynSelectCode(functionName, lang = 'bun') {
393
397
  {#if jsonEnabled && customUi?.jsonOnly != true}
394
398
  <div class="w-full p-3 flex gap-4 justify-end items-center">
395
399
  {#if addPropertyInEditorTab}
396
- <AddPropertyV2 bind:schema on:change>
400
+ <AddPropertyV2
401
+ bind:schema
402
+ onAddNew={(propertyName) => {
403
+ openField(propertyName)
404
+ }}
405
+ >
397
406
  {#snippet trigger()}
398
407
  <Button color="light" size="xs" iconOnly startIcon={{ icon: Plus }} />
399
408
  {/snippet}
@@ -410,9 +419,13 @@ function updateDynSelectCode(functionName, lang = 'bun') {
410
419
  'Arguments can be edited either using the wizard, or by editing their JSON Schema.'
411
420
  }}
412
421
  lightMode
413
- on:change={() => {
414
- schemaString = JSON.stringify(schema, null, '\t')
415
- editor?.setCode(schemaString)
422
+ on:change={(e) => {
423
+ if (e.detail) {
424
+ schemaString = JSON.stringify(schema, null, '\t')
425
+ editor?.setCode(schemaString)
426
+ } else {
427
+ schema = JSON.parse(schemaString)
428
+ }
416
429
  }}
417
430
  />
418
431
  </div>
@@ -508,7 +521,7 @@ function updateDynSelectCode(functionName, lang = 'bun') {
508
521
  </div>
509
522
  {#if opened === argName}
510
523
  <div class="p-4 border-t">
511
- {#if !hiddenArgs.includes(argName) && Object.keys(schema?.properties ?? {}).includes(argName)}
524
+ {#if Object.keys(schema?.properties ?? {}).includes(argName)}
512
525
  {#if typeof args == 'object' && schema?.properties[argName]}
513
526
  <PropertyEditor
514
527
  bind:description={schema.properties[argName].description}
@@ -529,10 +542,6 @@ function updateDynSelectCode(functionName, lang = 'bun') {
529
542
  bind:order={schema.properties[argName].order}
530
543
  {isFlowInput}
531
544
  {isAppInput}
532
- on:change={() => {
533
- schema = $state.snapshot(schema)
534
- dispatch('change', schema)
535
- }}
536
545
  >
537
546
  {#snippet typeeditor()}
538
547
  {#if isFlowInput || isAppInput}
@@ -543,9 +552,11 @@ function updateDynSelectCode(functionName, lang = 'bun') {
543
552
  bind:selected={
544
553
  () => computeSelected(schema.properties[opened ?? '']),
545
554
  (v) => {
555
+ const isResource = v == 'resource'
546
556
  const isS3 = v == 'S3'
547
557
  const isOneOf = v == 'oneOf'
548
558
  const isDynSelect = v == 'dynselect'
559
+ const isDynMultiselect = v == 'dynmultiselect'
549
560
  const emptyProperty = {
550
561
  contentEncoding: undefined,
551
562
  enum_: undefined,
@@ -563,22 +574,29 @@ function updateDynSelectCode(functionName, lang = 'bun') {
563
574
  nullable: undefined,
564
575
  required: undefined
565
576
  }
566
-
567
577
  if (isS3) {
568
578
  schema.properties[argName] = {
569
579
  ...emptyProperty,
570
580
  type: 'object',
571
581
  format: 'resource-s3_object'
572
582
  }
573
- } else if (isDynSelect) {
583
+ } else if (isResource) {
584
+ schema.properties[argName] = {
585
+ ...emptyProperty,
586
+ type: 'object',
587
+ format: 'resource-'
588
+ }
589
+ } else if (isDynSelect || isDynMultiselect) {
574
590
  const functionName = argName.replace(/\s+/g, '_')
575
591
  schema.properties[argName] = {
576
592
  ...emptyProperty,
577
593
  type: 'object',
578
- format: 'dynselect-' + functionName
594
+ format:
595
+ (isDynSelect ? 'dynselect-' : 'dynmultiselect-') +
596
+ functionName
579
597
  }
580
- updateDynSelectCode(argName, dynSelectLang)
581
- dynamicSelectEditor?.setCode(dynSelectCode || '')
598
+ updateDynCode(argName, dynLang)
599
+ dynamicSelectEditor?.setCode(dynCode || '')
582
600
  } else if (isOneOf) {
583
601
  schema.properties[argName] = {
584
602
  ...emptyProperty,
@@ -621,18 +639,19 @@ function updateDynSelectCode(functionName, lang = 'bun') {
621
639
  type: v
622
640
  }
623
641
  }
642
+ schema.properties = schema.properties
624
643
  }
625
644
  }
626
- on:selected={(e) => {
627
- schema = schema
628
- dispatch('change', schema)
629
- dispatch('schemaChange')
630
- }}
631
645
  >
632
646
  {#snippet children({ item })}
633
647
  {#each typeOptions as x}
634
648
  <ToggleButton value={x[1]} label={x[0]} {item} />
635
649
  {/each}
650
+ {#if showDynOpt}
651
+ {#each DYNAMIC_OPTIONS as x}
652
+ <ToggleButton value={x[1]} label={x[0]} {item} />
653
+ {/each}
654
+ {/if}
636
655
  {/snippet}
637
656
  </ToggleButtonGroup>
638
657
  </Label>
@@ -641,6 +660,9 @@ function updateDynSelectCode(functionName, lang = 'bun') {
641
660
 
642
661
  {#if isFlowInput || isAppInput}
643
662
  <FlowPropertyEditor
663
+ onDrawerClose={() => {
664
+ dndType = generateRandomString()
665
+ }}
644
666
  bind:defaultValue={schema.properties[argName].default}
645
667
  {variableEditor}
646
668
  {itemPicker}
@@ -671,12 +693,6 @@ function updateDynSelectCode(functionName, lang = 'bun') {
671
693
  (x) => x !== argName
672
694
  )
673
695
  }
674
- dispatch('change', schema)
675
- }}
676
- on:schemaChange={(e) => {
677
- schema = $state.snapshot(schema)
678
- dispatch('change', schema)
679
- dispatch('schemaChange')
680
696
  }}
681
697
  />
682
698
  {/if}
@@ -701,7 +717,6 @@ function updateDynSelectCode(functionName, lang = 'bun') {
701
717
  on:change={() => {
702
718
  try {
703
719
  schema = JSON.parse(schemaString)
704
- dispatch('change', schema)
705
720
  error = ''
706
721
  } catch (err) {
707
722
  error = err.message
@@ -16,7 +16,6 @@ interface Props {
16
16
  isAppInput?: boolean;
17
17
  displayWebhookWarning?: boolean;
18
18
  onlyMaskPassword?: boolean;
19
- dndType?: string | undefined;
20
19
  editTab: 'inputEditor' | 'history' | 'savedInputs' | 'json' | 'captures' | 'firstStepInputs' | undefined;
21
20
  previewSchema?: Record<string, any> | undefined;
22
21
  editPanelInitialSize?: number | undefined;
@@ -28,14 +27,16 @@ interface Props {
28
27
  customUi?: EditableSchemaFormUi | undefined;
29
28
  pannelExtraButtonWidth?: number;
30
29
  class?: string;
31
- dynSelectCode?: string | undefined;
32
- dynSelectLang?: ScriptLang | undefined;
33
- showDynSelectOpt?: boolean;
30
+ dynCode?: string | undefined;
31
+ dynLang?: ScriptLang | undefined;
32
+ showDynOpt?: boolean;
34
33
  addPropertyInEditorTab?: boolean;
35
34
  openEditTab?: import('svelte').Snippet;
36
35
  addProperty?: import('svelte').Snippet;
37
36
  runButton?: import('svelte').Snippet;
38
37
  extraTab?: import('svelte').Snippet;
38
+ schemaFormClassName?: string;
39
+ onChange?: (args: Record<string, any>) => void;
39
40
  }
40
41
  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> {
41
42
  new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
@@ -53,9 +54,7 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
53
54
  declare const EditableSchemaForm: $$__sveltets_2_IsomorphicComponent<Props, {
54
55
  acceptChange: CustomEvent<any>;
55
56
  rejectChange: CustomEvent<any>;
56
- change: CustomEvent<any>;
57
57
  delete: CustomEvent<any>;
58
- schemaChange: CustomEvent<any>;
59
58
  editPanelSizeChanged: CustomEvent<any>;
60
59
  } & {
61
60
  [evt: string]: CustomEvent<any>;
@@ -64,6 +63,6 @@ declare const EditableSchemaForm: $$__sveltets_2_IsomorphicComponent<Props, {
64
63
  openField: (key: string) => void;
65
64
  deleteField: (key: string) => void;
66
65
  updateJson: () => void;
67
- }, "args" | "schema" | "isValid" | "editPanelSize" | "dynSelectCode" | "dynSelectLang">;
66
+ }, "args" | "schema" | "isValid" | "editPanelSize" | "dynCode" | "dynLang">;
68
67
  type EditableSchemaForm = InstanceType<typeof EditableSchemaForm>;
69
68
  export default EditableSchemaForm;