windmill-components 1.309.7 → 1.352.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 (509) hide show
  1. package/package/assets/app.css +22 -13
  2. package/package/ata/index.js +1 -0
  3. package/package/autosize.js +2 -2
  4. package/package/common.d.ts +14 -2
  5. package/package/common.js +6 -1
  6. package/package/components/AllFlowLogs.svelte +30 -0
  7. package/package/components/AllFlowLogs.svelte.d.ts +18 -0
  8. package/package/components/ApiConnectForm.svelte +10 -4
  9. package/package/components/AppConnectDrawer.svelte +74 -0
  10. package/package/components/AppConnectDrawer.svelte.d.ts +20 -0
  11. package/package/components/AppConnectInner.svelte +507 -0
  12. package/package/components/AppConnectInner.svelte.d.ts +28 -0
  13. package/package/components/ArgEnum.svelte +4 -1
  14. package/package/components/ArgEnum.svelte.d.ts +3 -1
  15. package/package/components/ArgInfo.svelte +19 -3
  16. package/package/components/ArgInput.svelte +222 -122
  17. package/package/components/ArgInput.svelte.d.ts +11 -7
  18. package/package/components/ArrayTypeNarrowing.svelte +29 -27
  19. package/package/components/CenteredPage.svelte +2 -2
  20. package/package/components/ConcurrentJobsChart.svelte +212 -0
  21. package/package/components/ConcurrentJobsChart.svelte.d.ts +23 -0
  22. package/package/components/CustomOauth.svelte +2 -2
  23. package/package/components/DateInput.svelte +47 -0
  24. package/package/components/DateInput.svelte.d.ts +24 -0
  25. package/package/components/DateTimeInput.svelte +25 -3
  26. package/package/components/DefaultScripts.svelte +5 -8
  27. package/package/components/DefaultTags.svelte +3 -2
  28. package/package/components/DefaultTags.svelte.d.ts +3 -1
  29. package/package/components/DefaultTagsInner.svelte +2 -11
  30. package/package/components/DefaultTagsInner.svelte.d.ts +3 -1
  31. package/package/components/Dev.svelte +72 -10
  32. package/package/components/DiffDrawer.svelte +1 -2
  33. package/package/components/DiffEditor.svelte +3 -0
  34. package/package/components/DisplayResult.svelte +467 -344
  35. package/package/components/DisplayResult.svelte.d.ts +1 -0
  36. package/package/components/DropdownV2.svelte.d.ts +2 -2
  37. package/package/components/DurationMs.svelte +11 -3
  38. package/package/components/DurationMs.svelte.d.ts +2 -0
  39. package/package/components/EditableSchemaForm.svelte +447 -100
  40. package/package/components/EditableSchemaForm.svelte.d.ts +16 -6
  41. package/package/components/Editor.svelte +112 -93
  42. package/package/components/Editor.svelte.d.ts +4 -2
  43. package/package/components/EditorBar.svelte +101 -10
  44. package/package/components/EditorBar.svelte.d.ts +0 -1
  45. package/package/components/ErrorOrRecoveryHandler.svelte +0 -1
  46. package/package/components/FlowBuilder.svelte +14 -6
  47. package/package/components/FlowGraphViewer.svelte +2 -1
  48. package/package/components/FlowGraphViewerStep.svelte +56 -10
  49. package/package/components/FlowGraphViewerStep.svelte.d.ts +2 -7
  50. package/package/components/FlowJobResult.svelte +14 -3
  51. package/package/components/FlowJobResult.svelte.d.ts +3 -0
  52. package/package/components/FlowMetadata.svelte +41 -36
  53. package/package/components/FlowMetadata.svelte.d.ts +3 -1
  54. package/package/components/FlowPreviewContent.svelte +18 -9
  55. package/package/components/FlowStatusViewer.svelte +4 -0
  56. package/package/components/FlowStatusViewer.svelte.d.ts +3 -0
  57. package/package/components/FlowStatusViewerInner.svelte +96 -19
  58. package/package/components/FlowStatusViewerInner.svelte.d.ts +3 -0
  59. package/package/components/FlowTimeline.svelte +13 -0
  60. package/package/components/FlowTimeline.svelte.d.ts +2 -0
  61. package/package/components/FlowViewer.svelte +0 -5
  62. package/package/components/FolderEditor.svelte +25 -0
  63. package/package/components/FolderEditor.svelte.d.ts +2 -0
  64. package/package/components/GroupEditor.svelte +36 -91
  65. package/package/components/GroupInfo.svelte +1 -1
  66. package/package/components/HighlightCode.svelte +3 -0
  67. package/package/components/InputTransformForm.svelte +19 -1
  68. package/package/components/InputTransformForm.svelte.d.ts +2 -0
  69. package/package/components/InputTransformSchemaForm.svelte +6 -0
  70. package/package/components/InputTransformSchemaForm.svelte.d.ts +2 -0
  71. package/package/components/InstanceSettings.svelte +196 -16
  72. package/package/components/InstanceSettings.svelte.d.ts +4 -0
  73. package/package/components/JobLogs.svelte +12 -0
  74. package/package/components/JobLogs.svelte.d.ts +16 -0
  75. package/package/components/JobStatus.svelte +3 -3
  76. package/package/components/Label.svelte +1 -1
  77. package/package/components/Label.svelte.d.ts +1 -0
  78. package/package/components/LightweightArgInput.svelte +342 -264
  79. package/package/components/LightweightArgInput.svelte.d.ts +6 -2
  80. package/package/components/LightweightResourcePicker.svelte +74 -26
  81. package/package/components/LightweightSchemaForm.svelte +49 -39
  82. package/package/components/LogViewer.svelte +52 -15
  83. package/package/components/LogViewer.svelte.d.ts +1 -0
  84. package/package/components/Login.svelte +288 -0
  85. package/package/components/Login.svelte.d.ts +19 -0
  86. package/package/components/ModulePreviewForm.svelte +4 -0
  87. package/package/components/NoMainFuncBadge.svelte +8 -0
  88. package/package/components/NoMainFuncBadge.svelte.d.ts +14 -0
  89. package/package/components/NumberTypeNarrowing.svelte +71 -44
  90. package/package/components/OauthExtraParams.svelte +1 -1
  91. package/package/components/OauthScopes.svelte +1 -1
  92. package/package/components/ObjectResourceInput.svelte +2 -0
  93. package/package/components/ObjectResourceInput.svelte.d.ts +1 -0
  94. package/package/components/ObjectStoreConfigSettings.svelte +12 -1
  95. package/package/components/ObjectStoreConfigSettings.svelte.d.ts +1 -0
  96. package/package/components/ObjectTypeNarrowing.svelte +0 -1
  97. package/package/components/ParqetCsvTableRenderer.svelte +181 -0
  98. package/package/components/ParqetCsvTableRenderer.svelte.d.ts +21 -0
  99. package/package/components/Password.svelte +1 -0
  100. package/package/components/Password.svelte.d.ts +2 -0
  101. package/package/components/PasswordArgInput.svelte +49 -0
  102. package/package/components/PasswordArgInput.svelte.d.ts +17 -0
  103. package/package/components/Path.svelte +2 -2
  104. package/package/components/PersistentScriptDrawer.svelte +6 -3
  105. package/package/components/QueueMetricsDrawer.svelte +225 -0
  106. package/package/components/QueueMetricsDrawer.svelte.d.ts +18 -0
  107. package/package/components/Range.svelte +88 -286
  108. package/package/components/Range.svelte.d.ts +9 -23
  109. package/package/components/ResourceEditor.svelte +138 -140
  110. package/package/components/ResourceEditor.svelte.d.ts +9 -2
  111. package/package/components/ResourceEditorDrawer.svelte +45 -0
  112. package/package/components/ResourceEditorDrawer.svelte.d.ts +21 -0
  113. package/package/components/ResourcePicker.svelte +8 -9
  114. package/package/components/ResourceTypePicker.svelte +88 -36
  115. package/package/components/ResultJobLoader.svelte +2 -2
  116. package/package/components/ResultJobLoader.svelte.d.ts +9 -9
  117. package/package/components/RunChart.svelte +55 -5
  118. package/package/components/RunChart.svelte.d.ts +1 -0
  119. package/package/components/RunForm.svelte +1 -1
  120. package/package/components/S3FilePicker.svelte +21 -9
  121. package/package/components/S3FilePicker.svelte.d.ts +2 -0
  122. package/package/components/SavedInputs.svelte +49 -13
  123. package/package/components/ScheduleEditorInner.svelte +294 -264
  124. package/package/components/SchemaForm.svelte +193 -99
  125. package/package/components/SchemaForm.svelte.d.ts +17 -2
  126. package/package/components/ScriptBuilder.svelte +23 -14
  127. package/package/components/ScriptEditor.svelte +1 -2
  128. package/package/components/ScriptEditor.svelte.d.ts +1 -1
  129. package/package/components/ScriptSchedules.svelte +11 -8
  130. package/package/components/ScriptSchema.svelte +3 -21
  131. package/package/components/ScriptVersionHistory.svelte +1 -1
  132. package/package/components/SimpleEditor.svelte +4 -1
  133. package/package/components/StringTypeNarrowing.svelte +229 -167
  134. package/package/components/StringTypeNarrowing.svelte.d.ts +6 -1
  135. package/package/components/TemplateEditor.svelte +1 -0
  136. package/package/components/TestJobLoader.svelte +14 -5
  137. package/package/components/TestJobLoader.svelte.d.ts +1 -1
  138. package/package/components/Toggle.svelte +6 -3
  139. package/package/components/Toggle.svelte.d.ts +1 -0
  140. package/package/components/Tooltip.svelte +8 -2
  141. package/package/components/Tooltip.svelte.d.ts +1 -0
  142. package/package/components/UserSettings.svelte +24 -1
  143. package/package/components/WorkspaceGroup.svelte +84 -21
  144. package/package/components/WorkspaceGroup.svelte.d.ts +1 -0
  145. package/package/components/app_connect.d.ts +7 -0
  146. package/package/components/app_connect.js +78 -0
  147. package/package/components/apps/components/buttons/AppButton.svelte +2 -1
  148. package/package/components/apps/components/buttons/AppButton.svelte.d.ts +1 -0
  149. package/package/components/apps/components/display/AppAlert.svelte +1 -1
  150. package/package/components/apps/components/display/AppCustomComponent.svelte +1 -1
  151. package/package/components/apps/components/display/AppDisplayComponent.svelte +2 -2
  152. package/package/components/apps/components/display/AppDownload.svelte +1 -1
  153. package/package/components/apps/components/display/AppFlowStatusComponent.svelte +13 -70
  154. package/package/components/apps/components/display/AppFlowStatusComponent.svelte.d.ts +1 -9
  155. package/package/components/apps/components/display/AppIcon.svelte +1 -1
  156. package/package/components/apps/components/display/AppJobIdFlowStatus.svelte +23 -10
  157. package/package/components/apps/components/display/AppJobIdFlowStatus.svelte.d.ts +1 -3
  158. package/package/components/apps/components/display/AppJobIdLogComponent.svelte +22 -10
  159. package/package/components/apps/components/display/AppJobIdLogComponent.svelte.d.ts +1 -3
  160. package/package/components/apps/components/display/AppLogsComponent.svelte +13 -70
  161. package/package/components/apps/components/display/AppLogsComponent.svelte.d.ts +1 -9
  162. package/package/components/apps/components/display/AppMap.svelte +3 -2
  163. package/package/components/apps/components/display/AppMenu.svelte +1 -1
  164. package/package/components/apps/components/display/AppPdf.svelte +3 -11
  165. package/package/components/apps/components/display/AppText.svelte +7 -2
  166. package/package/components/apps/components/display/charts/AppAgCharts.svelte +31 -18
  167. package/package/components/apps/components/display/dbtable/AppDbExplorer.svelte +32 -30
  168. package/package/components/apps/components/display/dbtable/InsertRow.svelte +3 -6
  169. package/package/components/apps/components/display/dbtable/queries/delete.js +1 -1
  170. package/package/components/apps/components/display/dbtable/queries/insert.js +1 -12
  171. package/package/components/apps/components/display/dbtable/queries/select.js +1 -1
  172. package/package/components/apps/components/display/dbtable/queries/update.js +2 -2
  173. package/package/components/apps/components/display/dbtable/utils.d.ts +0 -1
  174. package/package/components/apps/components/display/dbtable/utils.js +0 -83
  175. package/package/components/apps/components/display/table/AppAggridExplorerTable.svelte +75 -44
  176. package/package/components/apps/components/display/table/AppAggridExplorerTable.svelte.d.ts +5 -1
  177. package/package/components/apps/components/display/table/AppAggridInfiniteTable.svelte +172 -0
  178. package/package/components/apps/components/display/table/AppAggridInfiniteTable.svelte.d.ts +27 -0
  179. package/package/components/apps/components/display/table/AppAggridInfiniteTableEe.svelte +38 -0
  180. package/package/components/apps/components/display/table/AppAggridInfiniteTableEe.svelte.d.ts +28 -0
  181. package/package/components/apps/components/display/table/AppAggridTable.svelte +189 -56
  182. package/package/components/apps/components/display/table/AppAggridTable.svelte.d.ts +1 -1
  183. package/package/components/apps/components/display/table/AppAggridTableActions.svelte +13 -2
  184. package/package/components/apps/components/display/table/AppAggridTableActions.svelte.d.ts +1 -0
  185. package/package/components/apps/components/display/table/AppCell.svelte +1 -3
  186. package/package/components/apps/components/display/table/AppTable.svelte +320 -281
  187. package/package/components/apps/components/display/table/AppTableFooter.svelte +42 -23
  188. package/package/components/apps/components/display/table/AppTableFooter.svelte.d.ts +2 -2
  189. package/package/components/apps/components/display/table/SyncColumnDefs.svelte +119 -0
  190. package/package/components/apps/components/display/table/SyncColumnDefs.svelte.d.ts +21 -0
  191. package/package/components/apps/components/display/table/theme/windmill-theme.css +656 -0
  192. package/package/components/apps/components/display/table/utils.js +22 -0
  193. package/package/components/apps/components/helpers/DebouncedInput.svelte +3 -2
  194. package/package/components/apps/components/helpers/HiddenComponent.svelte +2 -1
  195. package/package/components/apps/components/helpers/NonRunnableComponent.svelte +35 -0
  196. package/package/components/apps/components/helpers/RefreshButton.svelte +30 -12
  197. package/package/components/apps/components/helpers/RefreshButton.svelte.d.ts +1 -3
  198. package/package/components/apps/components/helpers/RefreshIndicator.svelte +19 -0
  199. package/package/components/apps/components/helpers/RefreshIndicator.svelte.d.ts +16 -0
  200. package/package/components/apps/components/helpers/ResolveConfig.svelte +1 -1
  201. package/package/components/apps/components/helpers/RunnableComponent.svelte +102 -41
  202. package/package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +9 -5
  203. package/package/components/apps/components/helpers/RunnableWrapper.svelte +9 -1
  204. package/package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +6 -0
  205. package/package/components/apps/components/helpers/eval.js +1 -36
  206. package/package/components/apps/components/inputs/AppDateInput.svelte +5 -1
  207. package/package/components/apps/components/inputs/AppFileInput.svelte +13 -2
  208. package/package/components/apps/components/inputs/AppFileInput.svelte.d.ts +1 -0
  209. package/package/components/apps/components/inputs/AppMultiSelect.svelte +56 -50
  210. package/package/components/apps/components/inputs/AppMultiSelect.svelte.d.ts +1 -0
  211. package/package/components/apps/components/inputs/AppMultiSelectV2.svelte +178 -0
  212. package/package/components/apps/components/inputs/AppMultiSelectV2.svelte.d.ts +24 -0
  213. package/package/components/apps/components/inputs/AppNumberInput.svelte +1 -1
  214. package/package/components/apps/components/inputs/AppQuillEditor.svelte +26 -0
  215. package/package/components/apps/components/inputs/AppRangeInput.svelte +38 -37
  216. package/package/components/apps/components/inputs/AppS3FileInput.svelte +3 -1
  217. package/package/components/apps/components/inputs/AppS3FileInput.svelte.d.ts +1 -0
  218. package/package/components/apps/components/inputs/AppSelect.svelte +21 -10
  219. package/package/components/apps/components/inputs/AppSliderInputs.svelte +26 -31
  220. package/package/components/apps/components/inputs/AppTextInput.svelte +1 -1
  221. package/package/components/apps/components/inputs/currency/AppCurrencyInput.svelte +1 -1
  222. package/package/components/apps/components/layout/AppConditionalWrapper.svelte +10 -3
  223. package/package/components/apps/components/layout/AppConditionalWrapper.svelte.d.ts +1 -0
  224. package/package/components/apps/components/layout/AppContainer.svelte +1 -1
  225. package/package/components/apps/components/layout/AppDecisionTree.svelte +1 -1
  226. package/package/components/apps/components/layout/AppDrawer.svelte +16 -3
  227. package/package/components/apps/components/layout/AppDrawer.svelte.d.ts +2 -0
  228. package/package/components/apps/components/layout/AppModal.svelte +85 -79
  229. package/package/components/apps/components/layout/AppModal.svelte.d.ts +2 -0
  230. package/package/components/apps/components/layout/AppStepper.svelte +7 -2
  231. package/package/components/apps/components/layout/AppStepper.svelte.d.ts +2 -0
  232. package/package/components/apps/components/layout/AppTabs.svelte +4 -2
  233. package/package/components/apps/components/layout/AppTabs.svelte.d.ts +1 -0
  234. package/package/components/apps/editor/AppEditor.svelte +3 -2
  235. package/package/components/apps/editor/AppEditorHeader.svelte +68 -38
  236. package/package/components/apps/editor/AppInputs.svelte +1 -1
  237. package/package/components/apps/editor/AppPreview.svelte +18 -7
  238. package/package/components/apps/editor/ComponentHeader.svelte +37 -1
  239. package/package/components/apps/editor/ComponentHeader.svelte.d.ts +2 -0
  240. package/package/components/apps/editor/GridEditor.svelte +15 -6
  241. package/package/components/apps/editor/GridEditorMenu.svelte +120 -49
  242. package/package/components/apps/editor/GridViewer.svelte +14 -5
  243. package/package/components/apps/editor/GridViewer.svelte.d.ts +5 -1
  244. package/package/components/apps/editor/RecomputeAllComponents.svelte +17 -3
  245. package/package/components/apps/editor/RunnableJobPanel.svelte +9 -5
  246. package/package/components/apps/editor/SettingsPanel.svelte +19 -5
  247. package/package/components/apps/editor/SubGridEditor.svelte +44 -27
  248. package/package/components/apps/editor/appUtils.d.ts +6 -1
  249. package/package/components/apps/editor/appUtils.js +85 -7
  250. package/package/components/apps/editor/component/Component.svelte +86 -18
  251. package/package/components/apps/editor/component/Component.svelte.d.ts +3 -0
  252. package/package/components/apps/editor/component/components.d.ts +285 -23
  253. package/package/components/apps/editor/component/components.js +178 -13
  254. package/package/components/apps/editor/component/default-codes.d.ts +1 -1
  255. package/package/components/apps/editor/component/default-codes.js +241 -9
  256. package/package/components/apps/editor/component/sets.d.ts +3 -0
  257. package/package/components/apps/editor/component/sets.js +12 -2
  258. package/package/components/apps/editor/componentsPanel/ComponentList.svelte +15 -2
  259. package/package/components/apps/editor/componentsPanel/componentControlUtils.js +4 -2
  260. package/package/components/apps/editor/componentsPanel/cssUtils.js +1 -1
  261. package/package/components/apps/editor/componentsPanel/quickStyleProperties.js +5 -0
  262. package/package/components/apps/editor/contextPanel/components/OutputHeader.svelte +9 -5
  263. package/package/components/apps/editor/contextPanel/components/TableActionsOutput.svelte +1 -1
  264. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +46 -6
  265. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte +1 -1
  266. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanelWithTable.svelte +1 -1
  267. package/package/components/apps/editor/inlineScriptsPanel/utils.js +3 -1
  268. package/package/components/apps/editor/settingsPanel/AlignmentEditor.svelte +1 -1
  269. package/package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte +5 -34
  270. package/package/components/apps/editor/settingsPanel/ComponentControl.svelte +1 -1
  271. package/package/components/apps/editor/settingsPanel/ComponentInputTypeEditor.svelte +8 -5
  272. package/package/components/apps/editor/settingsPanel/ComponentPanel.svelte +41 -29
  273. package/package/components/apps/editor/settingsPanel/ContextVariables.svelte +61 -0
  274. package/package/components/apps/editor/settingsPanel/ContextVariables.svelte.d.ts +16 -0
  275. package/package/components/apps/editor/settingsPanel/DecisionTreeGraphEditor.svelte +12 -10
  276. package/package/components/apps/editor/settingsPanel/DeleteComponent.svelte +29 -32
  277. package/package/components/apps/editor/settingsPanel/DeleteComponent.svelte.d.ts +0 -5
  278. package/package/components/apps/editor/settingsPanel/EventHandlerItem.svelte +33 -0
  279. package/package/components/apps/editor/settingsPanel/EventHandlerItem.svelte.d.ts +19 -0
  280. package/package/components/apps/editor/settingsPanel/EventHandlers.svelte +103 -0
  281. package/package/components/apps/editor/settingsPanel/EventHandlers.svelte.d.ts +18 -0
  282. package/package/components/apps/editor/settingsPanel/GridCondition.svelte +14 -36
  283. package/package/components/apps/editor/settingsPanel/GridTab.svelte +4 -24
  284. package/package/components/apps/editor/settingsPanel/GridTabDisabled.svelte +2 -1
  285. package/package/components/apps/editor/settingsPanel/GridTabDisabled.svelte.d.ts +1 -0
  286. package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +24 -3
  287. package/package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte +32 -2
  288. package/package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte.d.ts +1 -0
  289. package/package/components/apps/editor/settingsPanel/StylePanel.svelte +4 -3
  290. package/package/components/apps/editor/settingsPanel/SubTypeEditor.svelte +0 -2
  291. package/package/components/apps/editor/settingsPanel/SubTypeEditor.svelte.d.ts +0 -1
  292. package/package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte +3 -2
  293. package/package/components/apps/editor/settingsPanel/inputEditor/EvalV2InputEditor.svelte +8 -1
  294. package/package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte +7 -14
  295. package/package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte.d.ts +0 -1
  296. package/package/components/apps/editor/settingsPanel/mainInput/RunnableSelector.svelte +4 -4
  297. package/package/components/apps/editor/settingsPanel/secondaryMenu/SecondaryMenu.svelte +6 -3
  298. package/package/components/apps/inputType.d.ts +4 -0
  299. package/package/components/apps/rx.d.ts +1 -1
  300. package/package/components/apps/rx.js +7 -0
  301. package/package/components/apps/svelte-grid/Grid.svelte +13 -4
  302. package/package/components/apps/svelte-grid/Grid.svelte.d.ts +2 -1
  303. package/package/components/apps/svelte-grid/types.d.ts +1 -0
  304. package/package/components/apps/svelte-grid/utils/helper.js +1 -0
  305. package/package/components/apps/svelte-grid/utils/overlap.d.ts +3 -0
  306. package/package/components/apps/svelte-grid/utils/overlap.js +21 -0
  307. package/package/components/apps/svelte-select/lib/Select.svelte.d.ts +2 -2
  308. package/package/components/apps/svelte-select/lib/tailwind.css +1 -1
  309. package/package/components/apps/types.d.ts +1 -0
  310. package/package/components/apps/utils.js +13 -3
  311. package/package/components/auditLogs/AuditLogsTable.svelte +5 -2
  312. package/package/components/build_workers.js +1 -0
  313. package/package/components/common/alert/Alert.svelte +17 -17
  314. package/package/components/common/badge/Badge.svelte +6 -3
  315. package/package/components/common/badge/model.d.ts +1 -1
  316. package/package/components/common/button/Button.svelte +22 -14
  317. package/package/components/common/button/ButtonDropdown.svelte +1 -0
  318. package/package/components/common/calendarPicker/CalendarPicker.svelte +2 -0
  319. package/package/components/common/calendarPicker/CalendarPicker.svelte.d.ts +1 -0
  320. package/package/components/common/drawer/ConditionalPortal.svelte +9 -0
  321. package/package/components/common/drawer/ConditionalPortal.svelte.d.ts +18 -0
  322. package/package/components/common/drawer/Disposable.svelte +67 -0
  323. package/package/components/common/drawer/Disposable.svelte.d.ts +37 -0
  324. package/package/components/common/drawer/Drawer.svelte +40 -56
  325. package/package/components/common/drawer/Drawer.svelte.d.ts +2 -1
  326. package/package/components/common/fileDownload/FileDownload.svelte +4 -2
  327. package/package/components/common/fileInput/FileInput.svelte +3 -3
  328. package/package/components/common/fileInput/FileInput.svelte.d.ts +1 -0
  329. package/package/components/common/fileUpload/FileUpload.svelte +5 -4
  330. package/package/components/common/languageIcons/LanguageIcon.svelte +5 -2
  331. package/package/components/common/modal/Modal.svelte +4 -1
  332. package/package/components/common/modal/Modal.svelte.d.ts +1 -0
  333. package/package/components/common/popup/Popup.svelte +1 -1
  334. package/package/components/common/table/RowIcon.svelte +4 -4
  335. package/package/components/common/table/ScriptRow.svelte +12 -1
  336. package/package/components/common/table/ScriptRow.svelte.d.ts +1 -0
  337. package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte +4 -1
  338. package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte.d.ts +1 -0
  339. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte +45 -0
  340. package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte.d.ts +24 -0
  341. package/package/components/common/waitTimeWarning/WaitTimeWarning.svelte +79 -0
  342. package/package/components/common/waitTimeWarning/WaitTimeWarning.svelte.d.ts +18 -0
  343. package/package/components/copilot/CronGen.svelte +2 -2
  344. package/package/components/copilot/FlowCopilotStatus.svelte +1 -1
  345. package/package/components/copilot/RegexGen.svelte +17 -39
  346. package/package/components/copilot/ScriptGen.svelte +14 -5
  347. package/package/components/copilot/StepInputGen.svelte +2 -1
  348. package/package/components/copilot/StepInputsGen.svelte +2 -1
  349. package/package/components/copilot/completion.js +60 -9
  350. package/package/components/copilot/lib.js +5 -3
  351. package/package/components/copilot/prompts/edit.yaml +24 -0
  352. package/package/components/copilot/prompts/editPrompt.d.ts +3 -0
  353. package/package/components/copilot/prompts/editPrompt.js +3 -0
  354. package/package/components/copilot/prompts/fix.yaml +25 -0
  355. package/package/components/copilot/prompts/fixPrompt.d.ts +3 -0
  356. package/package/components/copilot/prompts/fixPrompt.js +3 -0
  357. package/package/components/copilot/prompts/gen.yaml +20 -0
  358. package/package/components/copilot/prompts/genPrompt.d.ts +3 -0
  359. package/package/components/copilot/prompts/genPrompt.js +3 -0
  360. package/package/components/copilot/utils.d.ts +2 -1
  361. package/package/components/copilot/utils.js +38 -0
  362. package/package/components/details/createAppFromScript.d.ts +26 -0
  363. package/package/components/details/createAppFromScript.js +50 -24
  364. package/package/components/flows/CreateActionsApp.svelte +1 -0
  365. package/package/components/flows/CreateActionsFlow.svelte +1 -0
  366. package/package/components/flows/content/FlowEditorPanel.svelte +16 -2
  367. package/package/components/flows/content/FlowInput.svelte +63 -53
  368. package/package/components/flows/content/FlowInputs.svelte +2 -2
  369. package/package/components/flows/content/FlowModuleComponent.svelte +41 -9
  370. package/package/components/flows/content/FlowModuleScript.svelte +40 -1
  371. package/package/components/flows/content/FlowModuleScript.svelte.d.ts +2 -0
  372. package/package/components/flows/content/FlowModuleSuspend.svelte +99 -59
  373. package/package/components/flows/content/FlowModuleWrapper.svelte +16 -1
  374. package/package/components/flows/content/FlowSchedules.svelte +11 -8
  375. package/package/components/flows/content/ScriptEditorDrawer.svelte +6 -6
  376. package/package/components/flows/flowExplorer.js +4 -1
  377. package/package/components/flows/flowStateUtils.js +4 -1
  378. package/package/components/flows/map/FlowConstantsItem.svelte +1 -1
  379. package/package/components/flows/map/FlowErrorHandlerItem.svelte +1 -1
  380. package/package/components/flows/map/FlowModuleSchemaItem.svelte +19 -1
  381. package/package/components/flows/map/FlowModuleSchemaItem.svelte.d.ts +1 -0
  382. package/package/components/flows/map/FlowModuleSchemaMap.svelte +6 -1
  383. package/package/components/flows/map/FlowSettingsItem.svelte +1 -1
  384. package/package/components/flows/map/MapItem.svelte +2 -0
  385. package/package/components/flows/map/MapItem.svelte.d.ts +1 -0
  386. package/package/components/flows/types.d.ts +4 -0
  387. package/package/components/flows/utils.d.ts +5 -1
  388. package/package/components/flows/utils.js +36 -0
  389. package/package/components/graph/FlowGraph.svelte +6 -2
  390. package/package/components/graph/FlowGraph.svelte.d.ts +2 -0
  391. package/package/components/graph/svelvet/container/models/index.d.ts +0 -5
  392. package/package/components/graph/svelvet/container/models/index.js +1 -1
  393. package/package/components/graph/svelvet/container/views/Svelvet.svelte +2 -5
  394. package/package/components/graph/svelvet/edges/views/Edges/SimpleBezierEdge.svelte +41 -16
  395. package/package/components/graph/util.d.ts +1 -37
  396. package/package/components/graph/util.js +0 -34
  397. package/package/components/home/ItemsList.svelte +44 -9
  398. package/package/components/home/TreeView.svelte +2 -0
  399. package/package/components/icons/AzureIcon.svelte +25 -1
  400. package/package/components/icons/PHPIcon.svelte +117 -0
  401. package/package/components/icons/PHPIcon.svelte.d.ts +17 -0
  402. package/package/components/instanceSettings.d.ts +1 -1
  403. package/package/components/instanceSettings.js +20 -3
  404. package/package/components/jobs/JobPreview.svelte +6 -1
  405. package/package/components/multiselect/MultiSelect.svelte +783 -0
  406. package/package/components/multiselect/MultiSelect.svelte.d.ts +98 -0
  407. package/package/components/multiselect/MultiSelectWrapper.svelte +89 -0
  408. package/package/components/multiselect/MultiSelectWrapper.svelte.d.ts +20 -0
  409. package/package/components/multiselect/types.d.ts +56 -0
  410. package/package/components/multiselect/types.js +1 -0
  411. package/package/components/multiselect/utils.d.ts +7 -0
  412. package/package/components/multiselect/utils.js +54 -0
  413. package/package/components/propertyPicker/ObjectViewer.svelte +19 -2
  414. package/package/components/runs/JobLoader.svelte +135 -17
  415. package/package/components/runs/JobLoader.svelte.d.ts +7 -2
  416. package/package/components/runs/JobPreview.svelte +44 -4
  417. package/package/components/runs/JobPreview.svelte.d.ts +2 -0
  418. package/package/components/runs/RunRow.svelte +99 -33
  419. package/package/components/runs/RunRow.svelte.d.ts +5 -1
  420. package/package/components/runs/RunsFilter.svelte +125 -9
  421. package/package/components/runs/RunsFilter.svelte.d.ts +4 -2
  422. package/package/components/runs/RunsTable.svelte +71 -10
  423. package/package/components/runs/RunsTable.svelte.d.ts +8 -1
  424. package/package/components/schema/AddProperty.svelte +149 -0
  425. package/package/components/schema/AddProperty.svelte.d.ts +23 -0
  426. package/package/components/schema/AddPropertyForm.svelte +33 -0
  427. package/package/components/schema/AddPropertyForm.svelte.d.ts +16 -0
  428. package/package/components/schema/EditableSchemaDrawer.svelte +198 -0
  429. package/package/components/schema/EditableSchemaDrawer.svelte.d.ts +21 -0
  430. package/package/components/schema/EditableSchemaWrapper.svelte +31 -0
  431. package/package/components/schema/EditableSchemaWrapper.svelte.d.ts +22 -0
  432. package/package/components/schema/FlowPropertyEditor.svelte +393 -0
  433. package/package/components/schema/FlowPropertyEditor.svelte.d.ts +47 -0
  434. package/package/components/schema/PropertyEditor.svelte +185 -0
  435. package/package/components/schema/PropertyEditor.svelte.d.ts +46 -0
  436. package/package/components/schema/SchemaFormDND.svelte +75 -0
  437. package/package/components/schema/SchemaFormDND.svelte.d.ts +28 -0
  438. package/package/components/scriptEditor/LogPanel.svelte +46 -33
  439. package/package/components/scriptEditor/LogPanel.svelte.d.ts +1 -0
  440. package/package/components/scripts/CreateActionsScript.svelte +1 -1
  441. package/package/components/settings/WorkspaceUserSettings.svelte +246 -226
  442. package/package/components/sidebar/MenuButton.svelte +1 -1
  443. package/package/components/sidebar/MenuLink.svelte +1 -1
  444. package/package/components/sidebar/changelogs.js +40 -0
  445. package/package/components/table/AutoDataTable.svelte +124 -163
  446. package/package/components/table/Cell.svelte +4 -1
  447. package/package/components/table/Cell.svelte.d.ts +1 -0
  448. package/package/components/table/DataTable.svelte +13 -5
  449. package/package/components/table/DataTable.svelte.d.ts +1 -0
  450. package/package/components/table/DownloadCsv.svelte +30 -0
  451. package/package/components/table/DownloadCsv.svelte.d.ts +17 -0
  452. package/package/components/table/tableUtils.d.ts +8 -0
  453. package/package/components/table/tableUtils.js +37 -0
  454. package/package/components/vscode.js +1 -1
  455. package/package/components/wizards/AgGridWizard.svelte +27 -2
  456. package/package/components/wizards/AgGridWizard.svelte.d.ts +1 -0
  457. package/package/consts.js +7 -1
  458. package/package/defaults.d.ts +2 -2
  459. package/package/defaults.js +2 -2
  460. package/package/deno_fetch.d.ts.txt +36 -0
  461. package/package/editorUtils.js +2 -0
  462. package/package/gen/core/OpenAPI.js +5 -6
  463. package/package/gen/core/request.js +4 -1
  464. package/package/gen/index.d.ts +0 -1
  465. package/package/gen/index.js +0 -1
  466. package/package/gen/schemas.gen.d.ts +173 -428
  467. package/package/gen/schemas.gen.js +173 -433
  468. package/package/gen/services.gen.d.ts +3182 -1840
  469. package/package/gen/services.gen.js +3652 -2368
  470. package/package/gen/types.gen.d.ts +5445 -1529
  471. package/package/infer.d.ts +1 -1
  472. package/package/infer.js +6 -2
  473. package/package/inferArgSig.d.ts +10 -0
  474. package/package/inferArgSig.js +64 -4
  475. package/package/init_scripts/python_init_code.d.ts +1 -1
  476. package/package/init_scripts/python_init_code.js +1 -1
  477. package/package/process.d.ts.txt +1770 -0
  478. package/package/script_helpers.d.ts +3 -2
  479. package/package/script_helpers.js +28 -3
  480. package/package/scripts.d.ts +3 -1
  481. package/package/scripts.js +10 -3
  482. package/package/utils.d.ts +5 -1
  483. package/package/utils.js +53 -5
  484. package/package/windmill_fetch.d.ts.txt +16966 -0
  485. package/package/workspace_settings.d.ts +15 -0
  486. package/package/workspace_settings.js +81 -0
  487. package/package/zIndexes.d.ts +12 -0
  488. package/package/zIndexes.js +12 -0
  489. package/package.json +19 -10
  490. package/package/components/AppConnect.svelte +0 -566
  491. package/package/components/AppConnect.svelte.d.ts +0 -23
  492. package/package/components/ContextMenu.svelte +0 -89
  493. package/package/components/ContextMenu.svelte.d.ts +0 -28
  494. package/package/components/ParqetTableRenderer.svelte +0 -121
  495. package/package/components/ParqetTableRenderer.svelte.d.ts +0 -18
  496. package/package/components/PropertyRow.svelte +0 -80
  497. package/package/components/PropertyRow.svelte.d.ts +0 -23
  498. package/package/components/SchemaEditor.svelte +0 -344
  499. package/package/components/SchemaEditor.svelte.d.ts +0 -23
  500. package/package/components/SchemaModal.svelte +0 -350
  501. package/package/components/SchemaModal.svelte.d.ts +0 -31
  502. package/package/components/apps/components/display/index.d.ts +0 -17
  503. package/package/components/apps/components/display/index.js +0 -17
  504. package/package/components/apps/components/helpers/index.d.ts +0 -10
  505. package/package/components/apps/components/helpers/index.js +0 -10
  506. package/package/components/apps/components/index.d.ts +0 -5
  507. package/package/components/apps/components/index.js +0 -5
  508. package/package/components/apps/editor/settingsPanel/Recompute.svelte +0 -55
  509. package/package/components/apps/editor/settingsPanel/Recompute.svelte.d.ts +0 -20
@@ -0,0 +1,181 @@
1
+ <script>import { GridApi, createGrid } from 'ag-grid-community';
2
+ import 'ag-grid-community/styles/ag-grid.css';
3
+ import 'ag-grid-community/styles/ag-theme-alpine.css';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import DarkModeObserver from './DarkModeObserver.svelte';
6
+ import { HelpersService } from '../gen';
7
+ import { enterpriseLicense, workspaceStore } from '../stores';
8
+ import { Download } from 'lucide-svelte';
9
+ // import 'ag-grid-community/dist/styles/ag-theme-alpine-dark.css'
10
+ let selectedRowIndex = -1;
11
+ export let s3resource;
12
+ export let storage;
13
+ export let workspaceId;
14
+ export let disable_download = false;
15
+ let csvSeparatorChar = ',';
16
+ let datasource = {
17
+ rowCount: 0,
18
+ getRows: async function (params) {
19
+ try {
20
+ const searchCol = params.filterModel ? Object.keys(params.filterModel)?.[0] : undefined;
21
+ const csv = s3resource.endsWith('.csv');
22
+ const requestBody = {
23
+ workspace: workspaceId ?? $workspaceStore,
24
+ path: s3resource,
25
+ offset: params.startRow,
26
+ limit: params.endRow - params.startRow,
27
+ sortCol: params.sortModel?.[0]?.colId,
28
+ sortDesc: params.sortModel?.[0]?.sort == 'desc',
29
+ searchCol: searchCol,
30
+ searchTerm: searchCol ? params.filterModel?.[searchCol]?.filter : undefined,
31
+ storage: storage,
32
+ csvSeparator: csv ? csvSeparatorChar : undefined
33
+ };
34
+ const res = (csv
35
+ ? await HelpersService.loadCsvPreview(requestBody)
36
+ : await HelpersService.loadParquetPreview(requestBody));
37
+ for (let i = 0; i < res.rows.length; i++) {
38
+ res.rows[i]['__index'] = i + params.startRow;
39
+ if (!$enterpriseLicense) {
40
+ Object.keys(res.rows[i]).forEach((key) => {
41
+ if (key != '__index') {
42
+ res.rows[i][key] = 'Require EE';
43
+ }
44
+ });
45
+ }
46
+ }
47
+ params.successCallback(res.rows);
48
+ }
49
+ catch (e) {
50
+ console.error(e);
51
+ params.failCallback();
52
+ }
53
+ }
54
+ };
55
+ function toggleRow(row) {
56
+ if (row) {
57
+ let rowIndex = row.rowIndex;
58
+ let data = { ...row.data };
59
+ delete data['__index'];
60
+ if (selectedRowIndex !== rowIndex) {
61
+ selectedRowIndex = rowIndex;
62
+ }
63
+ }
64
+ }
65
+ function toggleRows(rows) {
66
+ toggleRow(rows[0]);
67
+ }
68
+ let eGui;
69
+ $: eGui && mountGrid();
70
+ let error = undefined;
71
+ async function mountGrid() {
72
+ if (eGui) {
73
+ try {
74
+ const csv = s3resource.endsWith('.csv');
75
+ const res = csv
76
+ ? await HelpersService.loadCsvPreview({
77
+ workspace: $workspaceStore,
78
+ path: s3resource,
79
+ limit: 0,
80
+ storage: storage,
81
+ csvSeparator: csvSeparatorChar
82
+ })
83
+ : await HelpersService.loadParquetPreview({
84
+ workspace: $workspaceStore,
85
+ path: s3resource,
86
+ limit: 0,
87
+ storage: storage
88
+ });
89
+ createGrid(eGui, {
90
+ rowModelType: 'infinite',
91
+ datasource,
92
+ // @ts-ignore
93
+ columnDefs: res.columns.map((c) => {
94
+ return {
95
+ field: c,
96
+ sortable: true,
97
+ filter: true,
98
+ filterParams: {
99
+ filterOptions: ['contains'],
100
+ maxNumConditions: 1
101
+ }
102
+ };
103
+ }),
104
+ pagination: false,
105
+ // defaultColDef: {
106
+ // flex: 1
107
+ // },
108
+ suppressColumnMoveAnimation: true,
109
+ rowSelection: 'multiple',
110
+ rowMultiSelectWithClick: true,
111
+ suppressRowDeselection: true,
112
+ onSelectionChanged: (e) => {
113
+ onSelectionChanged(e.api);
114
+ },
115
+ getRowId: (data) => {
116
+ return data.data['__index'];
117
+ }
118
+ }, {});
119
+ error = undefined;
120
+ }
121
+ catch (e) {
122
+ error = e.body;
123
+ console.error(e);
124
+ }
125
+ }
126
+ }
127
+ function onSelectionChanged(api) {
128
+ const rows = api.getSelectedNodes();
129
+ if (rows != undefined) {
130
+ toggleRows(rows);
131
+ }
132
+ }
133
+ let darkMode = false;
134
+ </script>
135
+
136
+ <DarkModeObserver bind:darkMode />
137
+
138
+ <div class={twMerge('mt-2 flex flex-col h-full min-h-[600px]')}>
139
+ {#if s3resource.endsWith('.csv')}
140
+ <div class="flex flex-row-reverse w-full">
141
+ <div class="flex items-baseline">
142
+ <label for="csvSeparatorChar" class="text-2xs text-secondary">Separator</label>
143
+
144
+ <div class="w-12 ml-2 mr-2">
145
+ <select class="h-8" bind:value={csvSeparatorChar} on:change={(e) => mountGrid()}>
146
+ <option value=",">,</option>
147
+ <option value=";">;</option>
148
+ <option value="\t">\t</option>
149
+ <option value="|">|</option>
150
+ </select>
151
+ </div>
152
+ </div>
153
+ </div>
154
+ {/if}
155
+ {#if !disable_download && !s3resource.endsWith('.csv')}
156
+ <a
157
+ target="_blank"
158
+ href="/api/w/{workspaceId}/job_helpers/download_s3_parquet_file_as_csv?file_key={s3resource}{storage
159
+ ? `&storage=${storage}`
160
+ : ''}"
161
+ class="text-secondary w-full text-right underline text-2xs whitespace-nowrap"
162
+ ><div class="flex flex-row-reverse gap-2 items-center"><Download size={12} /> CSV</div></a
163
+ >
164
+ {/if}
165
+
166
+ <div
167
+ class="ag-theme-alpine shadow-sm h-full"
168
+ class:ag-theme-alpine-dark={darkMode}
169
+ style="height: 600px;"
170
+ >
171
+ {#if error}
172
+ <div class="text-red-500">{error}</div>
173
+ <div>Try changing separator to fix it</div>
174
+ {/if}
175
+ <div bind:this={eGui} style="height:100%; " />
176
+ </div>
177
+ </div>
178
+
179
+ <!-- <div class="flex gap-1 absolute bottom-1 right-2 text-sm text-secondary"
180
+ >{firstRow}{'->'}{lastRow + 1} of {datasource?.rowCount} rows</div
181
+ > -->
@@ -0,0 +1,21 @@
1
+ import { SvelteComponent } from "svelte";
2
+ import 'ag-grid-community/styles/ag-grid.css';
3
+ import 'ag-grid-community/styles/ag-theme-alpine.css';
4
+ declare const __propDef: {
5
+ props: {
6
+ s3resource: string;
7
+ storage: string | undefined;
8
+ workspaceId: string | undefined;
9
+ disable_download?: boolean | undefined;
10
+ };
11
+ events: {
12
+ [evt: string]: CustomEvent<any>;
13
+ };
14
+ slots: {};
15
+ };
16
+ export type ParqetCsvTableRendererProps = typeof __propDef.props;
17
+ export type ParqetCsvTableRendererEvents = typeof __propDef.events;
18
+ export type ParqetCsvTableRendererSlots = typeof __propDef.slots;
19
+ export default class ParqetCsvTableRenderer extends SvelteComponent<ParqetCsvTableRendererProps, ParqetCsvTableRendererEvents, ParqetCsvTableRendererSlots> {
20
+ }
21
+ export {};
@@ -43,6 +43,7 @@ $: red = required && (password == '' || password == undefined);
43
43
  id="password"
44
44
  type="password"
45
45
  bind:value={password}
46
+ on:keydown
46
47
  autocomplete="off"
47
48
  {placeholder}
48
49
  {disabled}
@@ -8,6 +8,8 @@ declare const __propDef: {
8
8
  small?: boolean | undefined;
9
9
  };
10
10
  events: {
11
+ keydown: KeyboardEvent;
12
+ } & {
11
13
  [evt: string]: CustomEvent<any>;
12
14
  };
13
15
  slots: {};
@@ -0,0 +1,49 @@
1
+ <script>import { VariableService } from '../gen';
2
+ import { userStore, workspaceStore } from '../stores';
3
+ import { generateRandomString } from '../utils';
4
+ import Password from './Password.svelte';
5
+ export let value = undefined;
6
+ export let disabled;
7
+ let path = '';
8
+ let password = value && !value.startsWith('$var:') ? value : '';
9
+ async function generateValue() {
10
+ let npath = 'u/' +
11
+ ($userStore?.username ?? $userStore?.email)?.split('@')[0] +
12
+ '/secret_arg/' +
13
+ generateRandomString(12);
14
+ let nvalue = '$var:' + npath;
15
+ await VariableService.createVariable({
16
+ workspace: $workspaceStore,
17
+ requestBody: {
18
+ value: password,
19
+ is_secret: true,
20
+ path: npath,
21
+ description: ''
22
+ }
23
+ });
24
+ path = npath;
25
+ value = nvalue;
26
+ }
27
+ async function updateValue() {
28
+ await VariableService.updateVariable({
29
+ workspace: $workspaceStore,
30
+ path: path,
31
+ requestBody: {
32
+ value: password
33
+ }
34
+ });
35
+ }
36
+ let timeout = undefined;
37
+ function debouncedUpdate() {
38
+ timeout && clearTimeout(timeout);
39
+ setTimeout(updateValue, 500);
40
+ }
41
+ $: password && debouncedUpdate();
42
+ $: $workspaceStore &&
43
+ ($userStore?.username || $userStore?.email) &&
44
+ path == '' &&
45
+ password != '' &&
46
+ generateValue();
47
+ </script>
48
+
49
+ <Password {disabled} bind:password />
@@ -0,0 +1,17 @@
1
+ import { SvelteComponent } from "svelte";
2
+ declare const __propDef: {
3
+ props: {
4
+ value?: string | undefined;
5
+ disabled: boolean;
6
+ };
7
+ events: {
8
+ [evt: string]: CustomEvent<any>;
9
+ };
10
+ slots: {};
11
+ };
12
+ export type PasswordArgInputProps = typeof __propDef.props;
13
+ export type PasswordArgInputEvents = typeof __propDef.events;
14
+ export type PasswordArgInputSlots = typeof __propDef.slots;
15
+ export default class PasswordArgInput extends SvelteComponent<PasswordArgInputProps, PasswordArgInputEvents, PasswordArgInputSlots> {
16
+ }
17
+ export {};
@@ -249,8 +249,8 @@ let contentSearch;
249
249
  }}
250
250
  >
251
251
  {#if !folderCreated}
252
- <div class="flex flex-row">
253
- <input class="mr-2" placeholder="New folder name" bind:value={newFolderName} />
252
+ <div class="flex flex-col gap-2">
253
+ <input placeholder="New folder name" bind:value={newFolderName} />
254
254
  <Button size="md" startIcon={{ icon: Plus }} disabled={!newFolderName} on:click={addFolder}>
255
255
  New&nbsp;folder
256
256
  </Button>
@@ -1,7 +1,7 @@
1
1
  <script>import { JobService } from '../gen';
2
2
  import { Badge, Button, Drawer } from './common';
3
3
  import DrawerContent from './common/drawer/DrawerContent.svelte';
4
- import { createEventDispatcher } from 'svelte';
4
+ import { createEventDispatcher, onDestroy } from 'svelte';
5
5
  import { workspaceStore } from '../stores';
6
6
  import { displayDate, sleep, sendUserToast } from '../utils';
7
7
  import TableCustom from './TableCustom.svelte';
@@ -44,7 +44,7 @@ async function loadQueuedJobsOnce() {
44
44
  // toggle queuedJobsLoading to false in 1 secs to let some time for the animation to play
45
45
  setTimeout(() => {
46
46
  queuedJobsLoading = false;
47
- }, 1000 - (endStart - timeStart));
47
+ }, 3000 - (endStart - timeStart));
48
48
  }
49
49
  async function scaleToZero() {
50
50
  cancellingInProgress = true;
@@ -72,6 +72,9 @@ async function exit() {
72
72
  loadQueuedJobs = false;
73
73
  drawer.closeDrawer?.();
74
74
  }
75
+ onDestroy(() => {
76
+ loadQueuedJobs = false;
77
+ });
75
78
  </script>
76
79
 
77
80
  <Drawer
@@ -99,7 +102,7 @@ async function exit() {
99
102
  variant="border"
100
103
  on:click={loadQueuedJobsOnce}
101
104
  >
102
- <RefreshCw class={queuedJobsLoading ? 'animate-spin' : ''} size="xs" />Refresh
105
+ <RefreshCw class={queuedJobsLoading ? 'animate-spin' : ''} size={14} />
103
106
  </Button>
104
107
  </div>
105
108
  <TableCustom>
@@ -0,0 +1,225 @@
1
+ <script>import { Drawer, DrawerContent } from './common';
2
+ import 'chartjs-adapter-date-fns';
3
+ import { Line } from 'svelte-chartjs';
4
+ import { Chart as ChartJS, Title, Tooltip, Legend, LineElement, CategoryScale, LinearScale, PointElement, LogarithmicScale, TimeScale } from 'chart.js';
5
+ import { WorkerService } from '../gen';
6
+ import { superadmin } from '../stores';
7
+ import Skeleton from './common/skeleton/Skeleton.svelte';
8
+ import DarkModeObserver from './DarkModeObserver.svelte';
9
+ import Alert from './common/alert/Alert.svelte';
10
+ export let drawer;
11
+ let isOpen = false;
12
+ let loading = true;
13
+ const colorTuples = [
14
+ ['#7EB26D', 'rgba(126, 178, 109, 0.2)'],
15
+ ['#EAB839', 'rgba(234, 184, 57, 0.2)'],
16
+ ['#6ED0E0', 'rgba(110, 208, 224, 0.2)'],
17
+ ['#EF843C', 'rgba(239, 132, 60, 0.2)'],
18
+ ['#E24D42', 'rgba(226, 77, 66, 0.2)'],
19
+ ['#1F78C1', 'rgba(31, 120, 193, 0.2)'],
20
+ ['#BA43A9', 'rgba(186, 67, 169, 0.2)'],
21
+ ['#705DA0', 'rgba(112, 93, 160, 0.2)'],
22
+ ['#508642', 'rgba(80, 134, 66, 0.2)'],
23
+ ['#CCA300', 'rgba(204, 163, 0, 0.2)'],
24
+ ['#447EBC', 'rgba(68, 126, 188, 0.2)'],
25
+ ['#C15C17', 'rgba(193, 92, 23, 0.2)'],
26
+ ['#890F02', 'rgba(137, 15, 2, 0.2)'],
27
+ ['#666666', 'rgba(102, 102, 102, 0.2)'],
28
+ ['#44AA99', 'rgba(68, 170, 153, 0.2)'],
29
+ ['#6D8764', 'rgba(109, 135, 100, 0.2)'],
30
+ ['#555555', 'rgba(85, 85, 85, 0.2)'],
31
+ ['#B3B3B3', 'rgba(179, 179, 179, 0.2)'],
32
+ ['#008C9E', 'rgba(0, 140, 158, 0.2)'],
33
+ ['#6BBA70', 'rgba(107, 186, 112, 0.2)']
34
+ ];
35
+ function getColors(labels) {
36
+ const colors = labels.map((_, i) => colorTuples[i % colorTuples.length]);
37
+ return Object.fromEntries(colors.map((c, i) => [labels[i], c]));
38
+ }
39
+ ChartJS.register(Title, Tooltip, Legend, LineElement, LinearScale, PointElement, CategoryScale, TimeScale, LogarithmicScale);
40
+ let countData = undefined;
41
+ let delayData = undefined;
42
+ let minDate = new Date();
43
+ let noMetrics = false;
44
+ function fillData(data, zero = 0) {
45
+ // fill holes with 0
46
+ const sorted = [];
47
+ for (const el of [
48
+ ...data,
49
+ {
50
+ created_at: new Date().toISOString(),
51
+ value: zero
52
+ }
53
+ ]) {
54
+ const last = sorted.length > 0 ? new Date(sorted[sorted.length - 1].created_at).getTime() : undefined;
55
+ const currentTs = new Date(el.created_at).getTime();
56
+ if (last && currentTs - last > 1000 * 60 * 2) {
57
+ const numElements = Math.floor((currentTs - last) / (1000 * 30));
58
+ for (let i = 1; i < numElements; i++) {
59
+ sorted.push({
60
+ created_at: new Date(last + i * (1000 * 30)).toISOString(),
61
+ value: zero
62
+ });
63
+ }
64
+ }
65
+ sorted.push(el);
66
+ }
67
+ // remove high frequency data points for similar values
68
+ const light = [];
69
+ for (const el of sorted) {
70
+ const last = light.length > 0 ? light[light.length - 1] : undefined;
71
+ if (!last ||
72
+ Math.abs((el.value - last.value) / last.value) > 0.1 ||
73
+ new Date(el.created_at).getTime() - new Date(last.created_at).getTime() > 1000 * 60 * 15) {
74
+ light.push(el);
75
+ }
76
+ }
77
+ return light;
78
+ }
79
+ async function loadMetrics() {
80
+ loading = true;
81
+ let metrics = await WorkerService.getQueueMetrics();
82
+ if (metrics.length == 0) {
83
+ noMetrics = true;
84
+ loading = false;
85
+ return;
86
+ }
87
+ const labels = metrics
88
+ .map((m) => m.id.slice(12))
89
+ .filter((v, i, a) => a.indexOf(v) === i)
90
+ .sort();
91
+ const labelColors = getColors(labels);
92
+ countData = {
93
+ datasets: metrics
94
+ .filter((m) => m.id.startsWith('queue_count_'))
95
+ .map((m) => {
96
+ const [color, bgColor] = labelColors[m.id.slice(12)];
97
+ return {
98
+ label: m.id.slice(12),
99
+ backgroundColor: bgColor,
100
+ borderColor: color,
101
+ data: fillData(m.values).map((v) => ({ x: v.created_at, y: v.value }))
102
+ };
103
+ })
104
+ };
105
+ delayData = {
106
+ datasets: metrics
107
+ .filter((m) => m.id.startsWith('queue_delay_'))
108
+ .map((m) => {
109
+ const [color, bgColor] = labelColors[m.id.slice(12)];
110
+ return {
111
+ label: m.id.slice(12),
112
+ borderColor: color,
113
+ backgroundColor: bgColor,
114
+ data: fillData(m.values, 1).map((v) => ({
115
+ x: v.created_at,
116
+ y: v.value
117
+ }))
118
+ };
119
+ })
120
+ };
121
+ minDate = new Date(Math.min(...countData.datasets.map((d) => new Date(d.data[0].x).getTime())));
122
+ loading = false;
123
+ }
124
+ $: if ($superadmin && isOpen) {
125
+ loadMetrics();
126
+ }
127
+ else {
128
+ countData = undefined;
129
+ delayData = undefined;
130
+ }
131
+ let darkMode = false;
132
+ $: ChartJS.defaults.color = darkMode ? '#ccc' : '#666';
133
+ $: ChartJS.defaults.borderColor = darkMode ? 'rgba(255, 255, 255, 0.1)' : 'rgba(0, 0, 0, 0.1)';
134
+ </script>
135
+
136
+ <DarkModeObserver bind:darkMode />
137
+
138
+ <Drawer bind:this={drawer} bind:open={isOpen}>
139
+ <DrawerContent title="Queue Metrics" on:close={drawer.closeDrawer}>
140
+ {#if loading}
141
+ <Skeleton layout={[[20]]} />
142
+ {:else if noMetrics}
143
+ <p class="text-secondary">No jobs delayed by more than 3 seconds in the last 14 days</p>
144
+ {:else}
145
+ <div class="flex flex-col gap-4">
146
+ {#if countData}
147
+ <Line
148
+ data={countData}
149
+ options={{
150
+ animation: false,
151
+ plugins: {
152
+ title: {
153
+ display: true,
154
+ text: 'Number of delayed jobs per tag (> 3s)'
155
+ }
156
+ },
157
+ scales: {
158
+ x: {
159
+ type: 'time',
160
+ min: minDate.toISOString(),
161
+ max: new Date().toISOString()
162
+ },
163
+ y: {
164
+ title: {
165
+ display: true,
166
+ text: 'count'
167
+ }
168
+ }
169
+ }
170
+ }}
171
+ />
172
+ {/if}
173
+ {#if delayData}
174
+ <Line
175
+ data={delayData}
176
+ options={{
177
+ animation: false,
178
+ plugins: {
179
+ title: {
180
+ display: true,
181
+ text: 'Queue delay per tag (> 3s)'
182
+ },
183
+ tooltip: {
184
+ callbacks: {
185
+ label: function (context) {
186
+ // @ts-ignore
187
+ if (context.raw.y === 1) {
188
+ return context.dataset.label + ': 0'
189
+ } else {
190
+ // @ts-ignore
191
+ return context.dataset.label + ': ' + context.raw.y
192
+ }
193
+ }
194
+ }
195
+ }
196
+ },
197
+ scales: {
198
+ x: {
199
+ type: 'time',
200
+ min: minDate.toISOString(),
201
+ max: new Date().toISOString()
202
+ },
203
+
204
+ y: {
205
+ type: 'logarithmic',
206
+ title: {
207
+ display: true,
208
+ text: 'delay (s)'
209
+ },
210
+ ticks: {
211
+ callback: (value, _) => (value === 1 ? '0' : value)
212
+ }
213
+ }
214
+ }
215
+ }}
216
+ />
217
+ {/if}
218
+ <Alert title="Info">
219
+ Only tags for jobs that have been delayed by more than 3 seconds in the last 14 days are
220
+ included in the graph.
221
+ </Alert>
222
+ </div>
223
+ {/if}
224
+ </DrawerContent>
225
+ </Drawer>
@@ -0,0 +1,18 @@
1
+ import { SvelteComponent } from "svelte";
2
+ import { Drawer } from './common';
3
+ import 'chartjs-adapter-date-fns';
4
+ declare const __propDef: {
5
+ props: {
6
+ drawer: Drawer;
7
+ };
8
+ events: {
9
+ [evt: string]: CustomEvent<any>;
10
+ };
11
+ slots: {};
12
+ };
13
+ export type QueueMetricsDrawerProps = typeof __propDef.props;
14
+ export type QueueMetricsDrawerEvents = typeof __propDef.events;
15
+ export type QueueMetricsDrawerSlots = typeof __propDef.slots;
16
+ export default class QueueMetricsDrawer extends SvelteComponent<QueueMetricsDrawerProps, QueueMetricsDrawerEvents, QueueMetricsDrawerSlots> {
17
+ }
18
+ export {};