windmill-components 1.623.1 → 1.623.2

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 (480) hide show
  1. package/package/assets/tokens/tokens.json +11 -1
  2. package/package/ata/apis.js +78 -5
  3. package/package/cancelable-promise-utils.js +4 -2
  4. package/package/components/AddUser.svelte +1 -1
  5. package/package/components/ApiConnectForm.svelte +6 -0
  6. package/package/components/AppConnectDrawer.svelte +1 -0
  7. package/package/components/AppConnectInner.svelte +1 -0
  8. package/package/components/AuthSettings.svelte +3 -1
  9. package/package/components/BedrockCredentialsCheck.svelte +241 -0
  10. package/package/components/BedrockCredentialsCheck.svelte.d.ts +3 -0
  11. package/package/components/CenteredModal.svelte +32 -24
  12. package/package/components/CenteredModal.svelte.d.ts +7 -27
  13. package/package/components/CenteredPage.svelte +6 -2
  14. package/package/components/CenteredPage.svelte.d.ts +3 -0
  15. package/package/components/CompareWorkspaces.svelte +74 -16
  16. package/package/components/ConcurrentJobsChart.svelte +3 -2
  17. package/package/components/ConcurrentJobsChart.svelte.d.ts +2 -2
  18. package/package/components/CustomPopover.svelte +20 -23
  19. package/package/components/CustomPopover.svelte.d.ts +14 -39
  20. package/package/components/DBManager.svelte +134 -42
  21. package/package/components/DBManager.svelte.d.ts +13 -2
  22. package/package/components/DBManagerContent.svelte +25 -63
  23. package/package/components/DBManagerContent.svelte.d.ts +38 -4
  24. package/package/components/DBManagerDrawer.svelte +7 -9
  25. package/package/components/DBTable.svelte +1 -1
  26. package/package/components/DBTable.svelte.d.ts +3 -1
  27. package/package/components/DBTableEditor.svelte +234 -178
  28. package/package/components/DBTableEditor.svelte.d.ts +22 -3
  29. package/package/components/DateInput.svelte +29 -35
  30. package/package/components/DateInput.svelte.d.ts +10 -11
  31. package/package/components/DedicatedWorkersSelector.svelte +569 -0
  32. package/package/components/DedicatedWorkersSelector.svelte.d.ts +8 -0
  33. package/package/components/DeployWorkspace.svelte +106 -29
  34. package/package/components/Description.svelte +3 -2
  35. package/package/components/Dev.svelte +36 -2
  36. package/package/components/DiffDrawer.svelte +8 -29
  37. package/package/components/DiffEditor.svelte +32 -2
  38. package/package/components/DisplayResult.svelte +32 -24
  39. package/package/components/DropdownV2.svelte +2 -1
  40. package/package/components/DropdownV2.svelte.d.ts +1 -0
  41. package/package/components/Editor.svelte +71 -26
  42. package/package/components/Editor.svelte.d.ts +3 -0
  43. package/package/components/EditorBar.svelte +1 -1
  44. package/package/components/FakeMonacoPlaceHolder.svelte +1 -1
  45. package/package/components/FlowBuilder.svelte +17 -11
  46. package/package/components/FlowDiffViewer.svelte +37 -0
  47. package/package/components/FlowDiffViewer.svelte.d.ts +7 -0
  48. package/package/components/FlowGraphViewer.svelte +5 -2
  49. package/package/components/FlowGraphViewer.svelte.d.ts +2 -0
  50. package/package/components/FlowLoopIterationPreview.svelte.d.ts +1 -1
  51. package/package/components/FlowPreviewContent.svelte +3 -2
  52. package/package/components/FlowPreviewContent.svelte.d.ts +1 -1
  53. package/package/components/FlowPreviewResult.svelte +0 -4
  54. package/package/components/FlowRestartButton.svelte +2 -3
  55. package/package/components/FlowRestartButton.svelte.d.ts +3 -0
  56. package/package/components/FlowStatusViewerInner.svelte +55 -35
  57. package/package/components/FlowStatusViewerInner.svelte.d.ts +1 -1
  58. package/package/components/FlowStatusWaitingForEvents.svelte +27 -23
  59. package/package/components/FlowStatusWaitingForEvents.svelte.d.ts +4 -18
  60. package/package/components/FlowViewer.svelte +103 -2
  61. package/package/components/FlowViewer.svelte.d.ts +9 -3
  62. package/package/components/ForkWorkspaceBanner.svelte +32 -13
  63. package/package/components/GraphqlSchemaViewer.svelte +8 -1
  64. package/package/components/HistoricInputs.svelte +25 -27
  65. package/package/components/HistoricInputs.svelte.d.ts +2 -2
  66. package/package/components/InfiniteList.svelte +27 -20
  67. package/package/components/InfiniteList.svelte.d.ts +2 -0
  68. package/package/components/InstanceSetting.svelte +38 -0
  69. package/package/components/InviteUser.svelte +16 -42
  70. package/package/components/InviteUser.svelte.d.ts +4 -18
  71. package/package/components/JobLoader.svelte.d.ts +1 -1
  72. package/package/components/JobOtelTraces.svelte +287 -0
  73. package/package/components/JobOtelTraces.svelte.d.ts +6 -0
  74. package/package/components/JsonInputs.svelte +6 -8
  75. package/package/components/JsonInputs.svelte.d.ts +7 -8
  76. package/package/components/LogViewer.svelte +91 -33
  77. package/package/components/Login.svelte +27 -0
  78. package/package/components/ManualPopover.svelte +5 -6
  79. package/package/components/ManualPopover.svelte.d.ts +9 -35
  80. package/package/components/MemoryFootprintViewer.svelte +2 -6
  81. package/package/components/ModulePreview.svelte +23 -21
  82. package/package/components/ModulePreview.svelte.d.ts +1 -0
  83. package/package/components/NextcloudSetting.svelte +1 -1
  84. package/package/components/OAuthSetting.svelte +1 -0
  85. package/package/components/Path.svelte +2 -2
  86. package/package/components/Path.svelte.d.ts +1 -1
  87. package/package/components/PocketIdSetting.svelte +82 -0
  88. package/package/components/PocketIdSetting.svelte.d.ts +6 -0
  89. package/package/components/ResourceEditor.svelte +4 -4
  90. package/package/components/ResourcePicker.svelte +4 -0
  91. package/package/components/ResourcePicker.svelte.d.ts +1 -0
  92. package/package/components/RunButton.svelte +5 -15
  93. package/package/components/RunButton.svelte.d.ts +7 -19
  94. package/package/components/RunChart.svelte +8 -4
  95. package/package/components/RunChart.svelte.d.ts +2 -2
  96. package/package/components/RunForm.svelte +9 -17
  97. package/package/components/RunForm.svelte.d.ts +0 -1
  98. package/package/components/RunFormAdvancedPopup.svelte +1 -1
  99. package/package/components/RunsPage.svelte +202 -537
  100. package/package/components/RunsPage.svelte.d.ts +5 -5
  101. package/package/components/S3FilePicker.svelte +7 -11
  102. package/package/components/S3FilePickerInner.svelte +2 -3
  103. package/package/components/S3FilePickerInner.svelte.d.ts +2 -2
  104. package/package/components/SavedInputsPicker.svelte +1 -1
  105. package/package/components/SavedInputsV2.svelte +35 -36
  106. package/package/components/SchemaForm.svelte +26 -19
  107. package/package/components/SchemaFormWithArgPicker.svelte +4 -3
  108. package/package/components/ScriptBuilder.svelte +1 -1
  109. package/package/components/ScriptEditor.svelte +575 -101
  110. package/package/components/Section.svelte +4 -2
  111. package/package/components/ServiceLogsInner.svelte +4 -4
  112. package/package/components/ShareModal.svelte.d.ts +1 -1
  113. package/package/components/SimpleEditor.svelte +46 -2
  114. package/package/components/Star.svelte +8 -12
  115. package/package/components/Star.svelte.d.ts +6 -19
  116. package/package/components/StringTypeNarrowing.svelte.d.ts +1 -1
  117. package/package/components/SuperadminSettingsInner.svelte +1 -1
  118. package/package/components/TemplateEditor.svelte +54 -29
  119. package/package/components/TemplateEditor.svelte.d.ts +13 -102
  120. package/package/components/TimeAgo.svelte +49 -7
  121. package/package/components/TimeAgo.svelte.d.ts +1 -0
  122. package/package/components/Toast.svelte +5 -1
  123. package/package/components/UserSettings.svelte +1 -1
  124. package/package/components/WorkerGroup.svelte +35 -20
  125. package/package/components/WorkerGroup.svelte.d.ts +1 -0
  126. package/package/components/WorkerTagPicker.svelte +1 -1
  127. package/package/components/WorkerTagSelect.svelte +5 -2
  128. package/package/components/WorkspaceTutorials.svelte +5 -0
  129. package/package/components/apps/components/buttons/AppButton.svelte +21 -6
  130. package/package/components/apps/components/buttons/AppForm.svelte +2 -1
  131. package/package/components/apps/components/buttons/AppFormButton.svelte +2 -1
  132. package/package/components/apps/components/display/InsertRowDrawerButton.svelte +1 -1
  133. package/package/components/apps/components/display/dbtable/AppDbExplorer.svelte +2 -5
  134. package/package/components/apps/components/display/dbtable/dbFeatures.d.ts +9 -0
  135. package/package/components/apps/components/display/dbtable/dbFeatures.js +32 -0
  136. package/package/components/apps/components/display/dbtable/metadata.d.ts +3 -3
  137. package/package/components/apps/components/display/dbtable/metadata.js +177 -148
  138. package/package/components/apps/components/display/dbtable/queries/alterTable.d.ts +46 -0
  139. package/package/components/apps/components/display/dbtable/queries/alterTable.js +322 -0
  140. package/package/components/apps/components/display/dbtable/queries/alterTable.test.d.ts +1 -0
  141. package/package/components/apps/components/display/dbtable/queries/alterTable.test.js +867 -0
  142. package/package/components/apps/components/display/dbtable/queries/createTable.d.ts +2 -24
  143. package/package/components/apps/components/display/dbtable/queries/createTable.js +13 -25
  144. package/package/components/apps/components/display/dbtable/queries/dbQueriesUtils.d.ts +9 -0
  145. package/package/components/apps/components/display/dbtable/queries/dbQueriesUtils.js +45 -0
  146. package/package/components/apps/components/display/dbtable/queries/relationalKeys.d.ts +45 -0
  147. package/package/components/apps/components/display/dbtable/queries/relationalKeys.js +401 -0
  148. package/package/components/apps/components/display/dbtable/queries/select.d.ts +2 -0
  149. package/package/components/apps/components/display/dbtable/queries/select.js +37 -6
  150. package/package/components/apps/components/display/dbtable/tableEditor.d.ts +35 -0
  151. package/package/components/apps/components/display/dbtable/tableEditor.js +67 -0
  152. package/package/components/apps/components/display/dbtable/utils.d.ts +2 -0
  153. package/package/components/apps/components/display/dbtable/utils.js +61 -36
  154. package/package/components/apps/components/display/table/AppAggridTable.svelte +8 -0
  155. package/package/components/apps/components/display/table/AppAggridTableActions.svelte +9 -9
  156. package/package/components/apps/components/display/table/AppAggridTableActions.svelte.d.ts +1 -1
  157. package/package/components/apps/components/helpers/HiddenComponent.svelte +1 -1
  158. package/package/components/apps/components/helpers/InputValue.svelte +1 -1
  159. package/package/components/apps/components/helpers/ResolveConfig.svelte +1 -1
  160. package/package/components/apps/components/helpers/RunnableComponent.svelte +3 -2
  161. package/package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +1 -1
  162. package/package/components/apps/components/helpers/RunnableWrapper.svelte +2 -2
  163. package/package/components/apps/components/inputs/AppMultiSelectV2.svelte +2 -4
  164. package/package/components/apps/editor/AppEditorHeader.svelte +8 -1
  165. package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +32 -29
  166. package/package/components/apps/editor/AppEditorHeaderDeploy.svelte.d.ts +2 -2
  167. package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte +4 -4
  168. package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte.d.ts +3 -3
  169. package/package/components/apps/editor/PublicApp.svelte +49 -30
  170. package/package/components/apps/editor/PublicApp.svelte.d.ts +1 -0
  171. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte +77 -7
  172. package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte.d.ts +2 -2
  173. package/package/components/apps/editor/inlineScriptsPanel/utils.d.ts +2 -2
  174. package/package/components/apps/editor/inlineScriptsPanel/utils.js +10 -1
  175. package/package/components/apps/inputType.d.ts +6 -1
  176. package/package/components/assets/AssetsDropdownButton.svelte +1 -1
  177. package/package/components/assets/AssetsUsageDrawer.svelte +98 -27
  178. package/package/components/assets/AssetsUsageDrawer.svelte.d.ts +5 -6
  179. package/package/components/assets/lib.d.ts +3 -2
  180. package/package/components/assets/lib.js +3 -1
  181. package/package/components/auditLogs/AuditLogsFilters.svelte +9 -17
  182. package/package/components/auditLogs/AuditLogsFilters.svelte.d.ts +1 -1
  183. package/package/components/common/CloseButton.svelte +2 -1
  184. package/package/components/common/CloseButton.svelte.d.ts +1 -0
  185. package/package/components/common/badge/CountBadge.svelte +4 -3
  186. package/package/components/common/badge/CountBadge.svelte.d.ts +1 -0
  187. package/package/components/common/button/Button.svelte +1 -1
  188. package/package/components/common/button/model.js +1 -1
  189. package/package/components/common/calendarPicker/CalendarPicker.svelte.d.ts +1 -1
  190. package/package/components/common/confirmationModal/ConfirmationModal.svelte +2 -1
  191. package/package/components/common/confirmationModal/ConfirmationModal.svelte.d.ts +1 -0
  192. package/package/components/common/drawer/Drawer.svelte +4 -1
  193. package/package/components/common/drawer/DrawerContent.svelte +6 -3
  194. package/package/components/common/drawer/DrawerContent.svelte.d.ts +1 -0
  195. package/package/components/common/languageIcons/TypeScript.svelte +5 -3
  196. package/package/components/common/languageIcons/TypeScript.svelte.d.ts +1 -0
  197. package/package/components/common/modal/Modal.svelte +3 -3
  198. package/package/components/common/modal/Modal2.svelte +1 -0
  199. package/package/components/common/table/AppRow.svelte +4 -1
  200. package/package/components/common/table/FlowRow.svelte +4 -1
  201. package/package/components/common/table/RawAppRow.svelte +4 -1
  202. package/package/components/common/table/Row.svelte +11 -21
  203. package/package/components/common/table/Row.svelte.d.ts +4 -20
  204. package/package/components/common/table/RowIcon.svelte +6 -2
  205. package/package/components/common/table/RowIcon.svelte.d.ts +1 -1
  206. package/package/components/common/table/ScriptRow.svelte +4 -1
  207. package/package/components/copilot/autocomplete/Autocompletor.d.ts +1 -1
  208. package/package/components/copilot/autocomplete/Autocompletor.js +7 -6
  209. package/package/components/copilot/autocomplete/request.js +13 -9
  210. package/package/components/copilot/chat/AIButtonStyle.d.ts +1 -1
  211. package/package/components/copilot/chat/AIButtonStyle.js +2 -1
  212. package/package/components/copilot/chat/AIChat.svelte +3 -1
  213. package/package/components/copilot/chat/AIChatDisplay.svelte +89 -4
  214. package/package/components/copilot/chat/AIChatInput.svelte +275 -0
  215. package/package/components/copilot/chat/AIChatManager.svelte.js +107 -1
  216. package/package/components/copilot/chat/AiChatLayout.svelte +15 -30
  217. package/package/components/copilot/chat/AppAvailableContextList.svelte +263 -0
  218. package/package/components/copilot/chat/AppAvailableContextList.svelte.d.ts +13 -0
  219. package/package/components/copilot/chat/ContextElementBadge.svelte +44 -0
  220. package/package/components/copilot/chat/DatatableCreationPolicy.svelte +32 -33
  221. package/package/components/copilot/chat/ProviderModelSelector.svelte +1 -1
  222. package/package/components/copilot/chat/__tests__/app/appEvalHelpers.js +3 -0
  223. package/package/components/copilot/chat/__tests__/flow/flowEvalHelpers.js +4 -0
  224. package/package/components/copilot/chat/app/core.d.ts +56 -15
  225. package/package/components/copilot/chat/app/core.js +141 -22
  226. package/package/components/copilot/chat/context.d.ts +59 -2
  227. package/package/components/copilot/chat/context.js +6 -2
  228. package/package/components/copilot/chat/flow/FlowAIChat.svelte +22 -0
  229. package/package/components/copilot/chat/flow/core.d.ts +3 -1
  230. package/package/components/copilot/chat/flow/core.js +29 -2
  231. package/package/components/copilot/chat/flow/openFlow.json +1 -1
  232. package/package/components/copilot/chat/flow/openFlowZod.d.ts +1 -0
  233. package/package/components/copilot/chat/flow/openFlowZod.js +14 -2
  234. package/package/components/copilot/chat/script/core.d.ts +4 -1
  235. package/package/components/copilot/chat/script/core.js +43 -6
  236. package/package/components/copilot/chat/shared.d.ts +10 -0
  237. package/package/components/copilot/chat/shared.js +24 -0
  238. package/package/components/copilot/lib.d.ts +1 -1
  239. package/package/components/copilot/lib.js +2 -9
  240. package/package/components/copilot/utils.d.ts +5 -0
  241. package/package/components/copilot/utils.js +8 -0
  242. package/package/components/custom_ui.d.ts +2 -0
  243. package/package/components/dbOps.d.ts +18 -4
  244. package/package/components/dbOps.js +25 -3
  245. package/package/components/debug/DebugConsole.svelte +277 -0
  246. package/package/components/debug/DebugConsole.svelte.d.ts +13 -0
  247. package/package/components/debug/DebugPanel.svelte +97 -0
  248. package/package/components/debug/DebugPanel.svelte.d.ts +11 -0
  249. package/package/components/debug/DebugToolbar.svelte +148 -0
  250. package/package/components/debug/DebugToolbar.svelte.d.ts +17 -0
  251. package/package/components/debug/DebugVariableViewer.svelte +115 -0
  252. package/package/components/debug/DebugVariableViewer.svelte.d.ts +11 -0
  253. package/package/components/debug/MonacoDebugger.svelte +384 -0
  254. package/package/components/debug/MonacoDebugger.svelte.d.ts +15 -0
  255. package/package/components/debug/dapClient.d.ts +192 -0
  256. package/package/components/debug/dapClient.js +426 -0
  257. package/package/components/debug/debugUtils.d.ts +30 -0
  258. package/package/components/debug/debugUtils.js +131 -0
  259. package/package/components/debug/index.d.ts +75 -0
  260. package/package/components/debug/index.js +82 -0
  261. package/package/components/details/DetailPageHeader.svelte +21 -7
  262. package/package/components/details/DetailPageHeader.svelte.d.ts +2 -1
  263. package/package/components/details/DetailPageLayout.svelte +10 -1
  264. package/package/components/details/DetailPageLayout.svelte.d.ts +1 -0
  265. package/package/components/flows/CreateActionsApp.svelte +6 -4
  266. package/package/components/flows/DebounceLimit.svelte.d.ts +1 -1
  267. package/package/components/flows/FlowHistoryInner.svelte +15 -4
  268. package/package/components/flows/content/AgentToolWrapper.svelte +1 -1
  269. package/package/components/flows/content/FlowEditorDrawer.svelte +124 -0
  270. package/package/components/flows/content/FlowEditorDrawer.svelte.d.ts +22 -0
  271. package/package/components/flows/content/FlowInput.svelte +211 -37
  272. package/package/components/flows/content/FlowModuleComponent.svelte +553 -67
  273. package/package/components/flows/content/FlowModuleEarlyStop.svelte +8 -10
  274. package/package/components/flows/content/FlowModuleHeader.svelte +7 -4
  275. package/package/components/flows/content/FlowModuleWorkerTagSelect.svelte +1 -1
  276. package/package/components/flows/content/McpOAuthConnect.svelte +217 -0
  277. package/package/components/flows/content/McpOAuthConnect.svelte.d.ts +7 -0
  278. package/package/components/flows/content/McpToolEditor.svelte +50 -37
  279. package/package/components/flows/content/McpToolEditor.svelte.d.ts +0 -1
  280. package/package/components/flows/conversations/FlowChat.svelte +16 -2
  281. package/package/components/flows/conversations/FlowChat.svelte.d.ts +2 -1
  282. package/package/components/flows/conversations/FlowChatInterface.svelte +103 -6
  283. package/package/components/flows/conversations/FlowChatInterface.svelte.d.ts +2 -0
  284. package/package/components/flows/conversations/FlowChatManager.svelte.js +53 -21
  285. package/package/components/flows/conversations/FlowConversationsSidebar.svelte +79 -77
  286. package/package/components/flows/header/FlowImportExportMenu.svelte +1 -1
  287. package/package/components/flows/propPicker/OutputPickerInner.svelte.d.ts +1 -1
  288. package/package/components/flows/propPicker/PropPickerWrapper.svelte +3 -1
  289. package/package/components/flows/types.d.ts +2 -0
  290. package/package/components/git_sync/GitSyncRepositoryCard.svelte +16 -8
  291. package/package/components/graph/FlowGraphV2.svelte +7 -1
  292. package/package/components/graph/renderers/triggers/TriggersBadge.svelte +41 -24
  293. package/package/components/home/ItemsList.svelte +7 -6
  294. package/package/components/home/TutorialBanner.svelte +34 -18
  295. package/package/components/home/treeViewUtils.js +1 -1
  296. package/package/components/icons/CssIcon.svelte +20 -0
  297. package/package/components/icons/CssIcon.svelte.d.ts +7 -25
  298. package/package/components/icons/HtmlIcon.svelte +20 -0
  299. package/package/components/icons/HtmlIcon.svelte.d.ts +8 -0
  300. package/package/components/icons/JavaScriptIcon.svelte +10 -2
  301. package/package/components/icons/JavaScriptIcon.svelte.d.ts +1 -0
  302. package/package/components/icons/JsonIcon.svelte +8 -2
  303. package/package/components/icons/JsonIcon.svelte.d.ts +1 -0
  304. package/package/components/icons/LessIcon.svelte +16 -0
  305. package/package/components/icons/LessIcon.svelte.d.ts +8 -0
  306. package/package/components/icons/MarkdownIcon.svelte +20 -0
  307. package/package/components/icons/MarkdownIcon.svelte.d.ts +8 -0
  308. package/package/components/icons/NextcloudIcon.svelte +3 -2
  309. package/package/components/icons/NextcloudIcon.svelte.d.ts +2 -0
  310. package/package/components/icons/PocketIdIcon.svelte +9 -0
  311. package/package/components/icons/PocketIdIcon.svelte.d.ts +9 -0
  312. package/package/components/icons/ReactIcon.svelte +10 -2
  313. package/package/components/icons/ReactIcon.svelte.d.ts +1 -0
  314. package/package/components/icons/SassIcon.svelte +28 -0
  315. package/package/components/icons/SassIcon.svelte.d.ts +8 -0
  316. package/package/components/icons/SvelteIcon.svelte +10 -2
  317. package/package/components/icons/SvelteIcon.svelte.d.ts +1 -0
  318. package/package/components/icons/VueIcon.svelte +10 -2
  319. package/package/components/icons/VueIcon.svelte.d.ts +1 -0
  320. package/package/components/icons/YamlIcon.svelte +20 -0
  321. package/package/components/icons/YamlIcon.svelte.d.ts +8 -0
  322. package/package/components/icons/index.js +3 -1
  323. package/package/components/instanceSettings/SecretBackendConfig.svelte +514 -0
  324. package/package/components/instanceSettings/SecretBackendConfig.svelte.d.ts +8 -0
  325. package/package/components/instanceSettings.d.ts +2 -1
  326. package/package/components/instanceSettings.js +33 -1
  327. package/package/components/jobs/JobPreview.svelte +46 -39
  328. package/package/components/jobs/JobPreview.svelte.d.ts +1 -0
  329. package/package/components/monacoLanguagesOptions.js +16 -15
  330. package/package/components/propertyPicker/PropPicker.svelte +16 -2
  331. package/package/components/propertyPicker/PropPicker.svelte.d.ts +2 -0
  332. package/package/components/raw_apps/DefaultDatabaseSelector.svelte +9 -5
  333. package/package/components/raw_apps/FileEditorIcon.svelte +12 -7
  334. package/package/components/raw_apps/FileEditorIcon.svelte.d.ts +2 -0
  335. package/package/components/raw_apps/FileTreeNode.svelte +119 -83
  336. package/package/components/raw_apps/RawAppBackgroundRunner.svelte +88 -8
  337. package/package/components/raw_apps/RawAppDataTableDrawer.svelte +1 -3
  338. package/package/components/raw_apps/RawAppDataTableList.svelte +12 -9
  339. package/package/components/raw_apps/RawAppEditor.svelte +218 -68
  340. package/package/components/raw_apps/RawAppEditorHeader.svelte +33 -16
  341. package/package/components/raw_apps/RawAppHistoryList.svelte +264 -80
  342. package/package/components/raw_apps/RawAppHistoryList.svelte.d.ts +1 -0
  343. package/package/components/raw_apps/RawAppHistoryManager.svelte.d.ts +15 -1
  344. package/package/components/raw_apps/RawAppHistoryManager.svelte.js +46 -12
  345. package/package/components/raw_apps/RawAppInlineScriptEditor.svelte +549 -47
  346. package/package/components/raw_apps/RawAppInlineScriptEditor.svelte.d.ts +31 -5
  347. package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte +25 -18
  348. package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte.d.ts +1 -0
  349. package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte +141 -10
  350. package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte.d.ts +8 -0
  351. package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte +2 -1
  352. package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte.d.ts +9 -1
  353. package/package/components/raw_apps/RawAppInputsSpecEditor.svelte +47 -3
  354. package/package/components/raw_apps/RawAppInputsSpecEditor.svelte.d.ts +2 -2
  355. package/package/components/raw_apps/RawAppModules.svelte +13 -7
  356. package/package/components/raw_apps/RawAppPreview.svelte +48 -6
  357. package/package/components/raw_apps/RawAppSidebar.svelte +194 -125
  358. package/package/components/raw_apps/RawAppSidebar.svelte.d.ts +1 -0
  359. package/package/components/raw_apps/RunnableRow.svelte +41 -0
  360. package/package/components/raw_apps/RunnableRow.svelte.d.ts +11 -0
  361. package/package/components/raw_apps/datatableUtils.svelte.js +1 -1
  362. package/package/components/raw_apps/utils.d.ts +1 -1
  363. package/package/components/raw_apps/utils.js +76 -18
  364. package/package/components/runs/ManuelDatePicker.svelte +3 -3
  365. package/package/components/runs/ManuelDatePicker.svelte.d.ts +3 -3
  366. package/package/components/runs/NoWorkerWithTagWarning.svelte +5 -1
  367. package/package/components/runs/RunsFilter.svelte +75 -63
  368. package/package/components/runs/RunsFilter.svelte.d.ts +35 -4
  369. package/package/components/runs/RunsQueue.svelte.d.ts +1 -1
  370. package/package/components/runs/RunsTable.svelte +1 -1
  371. package/package/components/runs/RunsTable.svelte.d.ts +1 -1
  372. package/package/components/runs/useJobsLoader.svelte.d.ts +34 -0
  373. package/package/components/runs/useJobsLoader.svelte.js +507 -0
  374. package/package/components/schema/EditableSchemaWrapper.svelte +2 -2
  375. package/package/components/scriptEditor/LogPanel.svelte +17 -2
  376. package/package/components/scriptEditor/LogPanel.svelte.d.ts +2 -0
  377. package/package/components/select/MultiSelect.svelte +1 -1
  378. package/package/components/select/SelectDropdown.svelte +17 -5
  379. package/package/components/settings/AIPromptsModal.svelte +88 -0
  380. package/package/components/settings/AIPromptsModal.svelte.d.ts +11 -0
  381. package/package/components/settings/ChangeWorkspaceColor.svelte +4 -3
  382. package/package/components/settings/ChangeWorkspaceId.svelte +16 -11
  383. package/package/components/settings/ChangeWorkspaceName.svelte +7 -6
  384. package/package/components/settings/CreateToken.svelte +4 -4
  385. package/package/components/settings/UserAIPromptsSettings.svelte +56 -15
  386. package/package/components/settings/WorkspaceOperatorSettings.svelte +68 -85
  387. package/package/components/settings/WorkspaceUserSettings.svelte +537 -411
  388. package/package/components/sidebar/MenuButton.svelte +54 -24
  389. package/package/components/sidebar/MenuButton.svelte.d.ts +2 -0
  390. package/package/components/sidebar/MultiplayerMenu.svelte +4 -4
  391. package/package/components/sidebar/OperatorMenu.svelte +63 -88
  392. package/package/components/sidebar/SidebarContent.svelte +39 -6
  393. package/package/components/sidebar/UserMenu.svelte +3 -3
  394. package/package/components/sidebar/WorkspaceMenu.svelte +35 -85
  395. package/package/components/sqlTypeService.js +4 -3
  396. package/package/components/table/DataTable.svelte +8 -3
  397. package/package/components/table/DataTable.svelte.d.ts +2 -0
  398. package/package/components/text_input/TextInput.svelte +3 -0
  399. package/package/components/text_input/TextInput.svelte.d.ts +2 -0
  400. package/package/components/triggers/AddTriggersButton.svelte +17 -4
  401. package/package/components/triggers/TriggersEditor.svelte +4 -0
  402. package/package/components/triggers/TriggersWrapper.svelte +14 -0
  403. package/package/components/triggers/native/NativeTriggerEditor.svelte +379 -0
  404. package/package/components/triggers/native/NativeTriggerEditor.svelte.d.ts +26 -0
  405. package/package/components/triggers/native/NativeTriggerTable.svelte +155 -0
  406. package/package/components/triggers/native/NativeTriggerTable.svelte.d.ts +16 -0
  407. package/package/components/triggers/native/NativeTriggersPanel.svelte +40 -0
  408. package/package/components/triggers/native/NativeTriggersPanel.svelte.d.ts +15 -0
  409. package/package/components/triggers/native/services/nextcloud/NextcloudTriggerForm.svelte +104 -0
  410. package/package/components/triggers/native/services/nextcloud/NextcloudTriggerForm.svelte.d.ts +18 -0
  411. package/package/components/triggers/native/utils.d.ts +74 -0
  412. package/package/components/triggers/native/utils.js +152 -0
  413. package/package/components/triggers/triggers.svelte.d.ts +2 -1
  414. package/package/components/triggers/triggers.svelte.js +36 -8
  415. package/package/components/triggers/utils.js +18 -6
  416. package/package/components/triggers.d.ts +1 -1
  417. package/package/components/tutorials/FlowBuilderLiveTutorial.svelte +6 -35
  418. package/package/components/tutorials/RunsTutorial.svelte +399 -0
  419. package/package/components/{schema/SchemaPicker.svelte.d.ts → tutorials/RunsTutorial.svelte.d.ts} +11 -12
  420. package/package/components/tutorials/TroubleshootFlowTutorial.svelte +5 -20
  421. package/package/components/tutorials/utils.d.ts +16 -0
  422. package/package/components/tutorials/utils.js +96 -0
  423. package/package/components/tutorials/workspace/WorkspaceOnboardingOperatorTutorial.svelte +133 -0
  424. package/package/components/{SavedInputs.svelte.d.ts → tutorials/workspace/WorkspaceOnboardingOperatorTutorial.svelte.d.ts} +8 -11
  425. package/package/components/vscode.js +6 -6
  426. package/package/components/workspace/WorkspaceCard.svelte +184 -0
  427. package/package/components/workspace/WorkspaceCard.svelte.d.ts +24 -0
  428. package/package/components/workspace/WorkspaceIcon.svelte +21 -0
  429. package/package/components/workspace/WorkspaceIcon.svelte.d.ts +9 -0
  430. package/package/components/workspace/WorkspaceTreeView.svelte +331 -0
  431. package/package/components/workspace/WorkspaceTreeView.svelte.d.ts +15 -0
  432. package/package/components/workspaceSettings/AISettings.svelte +147 -108
  433. package/package/components/workspaceSettings/CreateWorkspace.svelte +26 -12
  434. package/package/components/workspaceSettings/CustomInstanceDbSelect.svelte +1 -0
  435. package/package/components/workspaceSettings/CustomInstanceDbWizardModal.svelte +3 -1
  436. package/package/components/workspaceSettings/DataTableSettings.svelte +2 -1
  437. package/package/components/workspaceSettings/DucklakeSettings.svelte +54 -26
  438. package/package/components/workspaceSettings/DucklakeSettings.svelte.d.ts +2 -1
  439. package/package/components/workspaceSettings/ModelTokenLimits.svelte +14 -18
  440. package/package/components/workspaceSettings/OAuthClientConfig.svelte +180 -0
  441. package/package/components/workspaceSettings/OAuthClientConfig.svelte.d.ts +14 -0
  442. package/package/components/workspaceSettings/StorageSettings.svelte +285 -241
  443. package/package/components/workspaceSettings/StorageSettings.svelte.d.ts +1 -0
  444. package/package/components/workspaceSettings/WorkspaceIntegrations.svelte +302 -0
  445. package/package/components/workspaceSettings/WorkspaceIntegrations.svelte.d.ts +3 -0
  446. package/package/consts.js +4 -3
  447. package/package/gen/core/OpenAPI.js +1 -1
  448. package/package/gen/schemas.gen.d.ts +517 -4
  449. package/package/gen/schemas.gen.js +523 -4
  450. package/package/gen/services.gen.d.ts +359 -22
  451. package/package/gen/services.gen.js +702 -44
  452. package/package/gen/types.gen.d.ts +1501 -121
  453. package/package/hub.js +2 -2
  454. package/package/hubPaths.json +3 -2
  455. package/package/infer.js +2 -0
  456. package/package/logout.d.ts +0 -2
  457. package/package/logout.js +2 -23
  458. package/package/logoutKit.d.ts +2 -0
  459. package/package/logoutKit.js +26 -0
  460. package/package/monaco_workers/graphql.worker.bundle.js +121 -121
  461. package/package/navigation.d.ts +1 -1
  462. package/package/rawAppWmillTs.d.ts +11 -0
  463. package/package/rawAppWmillTs.js +38 -1
  464. package/package/refreshUser.d.ts +5 -1
  465. package/package/refreshUser.js +20 -30
  466. package/package/storeUtils.js +2 -0
  467. package/package/svelte5Utils.svelte.d.ts +68 -1
  468. package/package/svelte5Utils.svelte.js +193 -2
  469. package/package/svelte5UtilsKit.svelte.d.ts +3 -0
  470. package/package/svelte5UtilsKit.svelte.js +30 -0
  471. package/package/tutorialUtils.js +0 -4
  472. package/package/tutorials/config.js +31 -3
  473. package/package/tutorials/roleUtils.d.ts +1 -1
  474. package/package/tutorials/roleUtils.js +6 -2
  475. package/package/utils.js +162 -1
  476. package/package.json +1 -1
  477. package/package/components/SavedInputs.svelte +0 -416
  478. package/package/components/runs/JobsLoader.svelte +0 -468
  479. package/package/components/runs/JobsLoader.svelte.d.ts +0 -49
  480. package/package/components/schema/SchemaPicker.svelte +0 -92
@@ -1,6 +1,7 @@
1
1
  <script module lang="ts">export const sidebarClasses = {
2
2
  text: 'text-primary-inverse dark:text-primary data-[light-mode=true]:text-primary text-xs font-normal',
3
3
  selectedText: 'text-emphasis-inverse dark:text-emphasis text-xs font-normal',
4
+ sublabelText: 'text-secondary-inverse dark:text-secondary text-2xs font-normal',
4
5
  hoverBg: 'transition-colors hover:bg-surface-hover-inverse dark:hover:bg-surface-hover data-[light-mode=true]:hover:bg-surface-hover'
5
6
  };
6
7
  </script>
@@ -11,7 +12,7 @@ import { createEventDispatcher } from 'svelte';
11
12
  import SideBarNotification from './SideBarNotification.svelte';
12
13
  import { conditionalMelt } from '../../utils';
13
14
  import { triggerableByAI } from '../../actions/triggerableByAI.svelte';
14
- let { aiId = undefined, aiDescription = undefined, label = undefined, icon = undefined, iconClasses = null, iconProps = null, isCollapsed, disabled = false, lightMode = false, stopPropagationOnClick = false, shortcut = '', notificationsCount = 0, color = null, trigger = undefined, href = undefined, class: classNames = undefined } = $props();
15
+ let { aiId = undefined, aiDescription = undefined, label = undefined, sublabel = undefined, icon = undefined, iconClasses = null, iconProps = null, isCollapsed, disabled = false, lightMode = false, stopPropagationOnClick = false, shortcut = '', notificationsCount = 0, color = null, trigger = undefined, href = undefined, class: classNames = undefined } = $props();
15
16
  let buttonRef = $state(undefined);
16
17
  let dispatch = createEventDispatcher();
17
18
  // Dynamic component based on whether href is provided
@@ -47,41 +48,70 @@ const Element = href ? 'a' : 'button';
47
48
  {href}
48
49
  data-light-mode={lightMode}
49
50
  class={twMerge(
50
- 'group flex items-center px-2 py-2 font-light rounded-md h-8 gap-3 w-full',
51
+ 'group flex items-center px-2 py-2 font-light rounded-md gap-2 w-full',
51
52
  sidebarClasses.hoverBg,
52
- color ? 'border-4' : '',
53
53
  'transition-all relative',
54
+ sublabel ? 'h-10' : 'h-8',
54
55
  classNames
55
56
  )}
56
- style={color ? `border-color: ${color}; padding: 0 calc(0.5rem - 4px);` : ''}
57
57
  use:conditionalMelt={trigger}
58
58
  title={isCollapsed ? undefined : label}
59
59
  {...$trigger}
60
60
  >
61
61
  {#if icon}
62
62
  {@const SvelteComponent = icon}
63
- <SvelteComponent
64
- size={16}
65
- class={twMerge('flex-shrink-0', sidebarClasses.text, 'transition-colors', iconClasses)}
66
- {...iconProps}
67
- />
63
+ {#if color}
64
+ <svg width="26" height="26" viewBox="0 0 26 26" class="flex-shrink-0 -ml-[5px]">
65
+ <circle cx="13" cy="13" r="13" fill={color} />
66
+ <foreignObject x="5" y="5" width="16" height="16">
67
+ <SvelteComponent
68
+ size={16}
69
+ class={twMerge(sidebarClasses.text, 'transition-colors', iconClasses)}
70
+ {...iconProps}
71
+ />
72
+ </foreignObject>
73
+ </svg>
74
+ {:else}
75
+ <SvelteComponent
76
+ size={16}
77
+ class={twMerge('flex-shrink-0', sidebarClasses.text, 'transition-colors', iconClasses)}
78
+ {...iconProps}
79
+ />
80
+ {/if}
68
81
  {/if}
69
82
 
70
- {#if !isCollapsed && label}
71
- <span
72
- class={twMerge(
73
- 'whitespace-pre truncate',
74
- sidebarClasses.text,
75
- 'transition-all',
76
- classNames
77
- )}
78
- >
79
- {label}
80
- <span class="pl-2 text-xs dark:text-secondary light:text-secondary-inverse font-semibold">
81
- {shortcut}
82
- </span>
83
- </span>
84
- {/if}
83
+ <div class="flex flex-col text-left grow min-w-0">
84
+ {#if !isCollapsed && label}
85
+ <div
86
+ class={twMerge(
87
+ 'whitespace-pre truncate w-full',
88
+ sidebarClasses.text,
89
+ 'transition-all',
90
+ classNames
91
+ )}
92
+ title={label}
93
+ >
94
+ {label}
95
+ <span
96
+ class="pl-2 text-xs dark:text-secondary light:text-secondary-inverse font-semibold"
97
+ >
98
+ {shortcut}
99
+ </span>
100
+ </div>
101
+ {/if}
102
+
103
+ {#if sublabel}
104
+ <div
105
+ class={twMerge(
106
+ 'whitespace-pre truncate w-full',
107
+ sidebarClasses.sublabelText,
108
+ 'transition-all',
109
+ classNames
110
+ )}
111
+ title={sublabel}>{sublabel}</div
112
+ >
113
+ {/if}
114
+ </div>
85
115
 
86
116
  {#if isCollapsed && notificationsCount > 0}
87
117
  <div class="absolute translate-x-1/2 translate-y-1/2 -top-2 right-1 flex h-fit w-fit">
@@ -1,6 +1,7 @@
1
1
  export declare const sidebarClasses: {
2
2
  text: string;
3
3
  selectedText: string;
4
+ sublabelText: string;
4
5
  hoverBg: string;
5
6
  };
6
7
  import type { MenubarMenuElements } from '@melt-ui/svelte';
@@ -8,6 +9,7 @@ interface Props {
8
9
  aiId?: string | undefined;
9
10
  aiDescription?: string | undefined;
10
11
  label?: string | undefined;
12
+ sublabel?: string | undefined;
11
13
  icon?: any | undefined;
12
14
  iconClasses?: string | null;
13
15
  iconProps?: any | null;
@@ -80,7 +80,7 @@ function showActivity(url) {
80
80
 
81
81
  {#if connected}
82
82
  <div class="divide-gray-100 border-t" role="none">
83
- <div class="px-2.5 text-xs font-semibold mt-1">Live activity</div>
83
+ <div class="px-2 text-xs text-secondary font-normal mt-1">Live activity</div>
84
84
  <div class="py-1 flex flex-col gap-y-1 max-h-48 overflow-auto" transition:slide>
85
85
  {#each Object.entries($awarenessStore ?? {}) as [user, url]}
86
86
  <div class="inline-flex gap-2 px-2 items-center">
@@ -89,12 +89,12 @@ function showActivity(url) {
89
89
  title={user}
90
90
  >
91
91
  <span class="text-sm font-medium leading-none text-white"
92
- >{user.substring(0, 2).toLocaleUpperCase()}</span
92
+ >{user?.substring(0, 2).toLocaleUpperCase()}</span
93
93
  >
94
94
  </span>
95
95
  <div class="flex flex-col">
96
- <span class="text-sm text-primary truncate">{user}</span>
97
- <span class="text-xs text-primary truncate">{showActivity(url)}</span>
96
+ <span class="text-xs text-primary truncate">{user}</span>
97
+ <span class="text-2xs text-secondary truncate">{showActivity(url ?? '')}</span>
98
98
  </div>
99
99
  </div>
100
100
  {/each}
@@ -4,13 +4,13 @@ import MultiplayerMenu from './MultiplayerMenu.svelte';
4
4
  import { clearWorkspaceFromStorage, enterpriseLicense, superadmin, userWorkspaces, workspaceStore, tutorialsToDo, skippedAll } from '../../stores';
5
5
  import { twMerge } from 'tailwind-merge';
6
6
  import { USER_SETTINGS_HASH } from './settings';
7
- import { logout } from '../../logout';
7
+ import { logout } from '../../logoutKit';
8
8
  import DarkModeObserver from '../DarkModeObserver.svelte';
9
9
  import BarsStaggered from '../icons/BarsStaggered.svelte';
10
10
  import { Menu, Menubar, MenuItem } from '../meltComponents';
11
11
  import MenuButton, { sidebarClasses } from './MenuButton.svelte';
12
12
  import MenuLink from './MenuLink.svelte';
13
- import { onDestroy } from 'svelte';
13
+ import ResizeTransitionWrapper from '../common/ResizeTransitionWrapper.svelte';
14
14
  let darkMode = $state(false);
15
15
  let { isCollapsed = false, favoriteLinks = [] } = $props();
16
16
  let mainMenuLinks = $derived([
@@ -34,6 +34,12 @@ let mainMenuLinks = $derived([
34
34
  $workspaceStore &&
35
35
  $userWorkspaces.find((_) => _.id === $workspaceStore)?.operator_settings?.[link.id] ===
36
36
  true)));
37
+ function filterLink(link) {
38
+ if (!$userWorkspaces || !$workspaceStore)
39
+ return false;
40
+ let userWorkspace = $userWorkspaces.find((_) => _.id === $workspaceStore);
41
+ return userWorkspace?.operator_settings?.[link.id] === true;
42
+ }
37
43
  let secondMenuLinks = $derived([
38
44
  {
39
45
  label: 'Resources',
@@ -50,6 +56,23 @@ let secondMenuLinks = $derived([
50
56
  id: 'assets',
51
57
  href: `${base}/assets`
52
58
  },
59
+ {
60
+ label: 'Groups',
61
+ id: 'groups',
62
+ href: `${base}/groups`
63
+ },
64
+ {
65
+ label: 'Folders',
66
+ id: 'folders',
67
+ href: `${base}/folders`
68
+ },
69
+ {
70
+ label: 'Workers',
71
+ id: 'workers',
72
+ href: `${base}/workers`
73
+ }
74
+ ].filter(filterLink));
75
+ let secondMenuTriggerLinks = $derived([
53
76
  {
54
77
  label: 'Custom HTTP routes',
55
78
  id: 'triggers',
@@ -99,47 +122,14 @@ let secondMenuLinks = $derived([
99
122
  label: 'Audit logs',
100
123
  id: 'audit_logs',
101
124
  href: `${base}/audit_logs`
102
- },
103
- {
104
- label: 'Groups',
105
- id: 'groups',
106
- href: `${base}/groups`
107
- },
108
- {
109
- label: 'Folders',
110
- id: 'folders',
111
- href: `${base}/folders`
112
- },
113
- {
114
- label: 'Workers',
115
- id: 'workers',
116
- href: `${base}/workers`
117
125
  }
118
- ].filter((link) => {
119
- if (!$userWorkspaces || !$workspaceStore)
120
- return false;
121
- return ($userWorkspaces.find((_) => _.id === $workspaceStore)?.operator_settings?.[link.id] === true);
122
- }));
123
- let moreOpen = $state(false);
124
- let moreOpenTimeout = $state();
125
- function debouncedSetMoreOpen(value) {
126
- if (moreOpenTimeout) {
127
- clearTimeout(moreOpenTimeout);
128
- }
129
- moreOpenTimeout = setTimeout(() => {
130
- moreOpen = value;
131
- }, 150); // 150ms debounce
132
- }
133
- onDestroy(() => {
134
- if (moreOpenTimeout) {
135
- clearTimeout(moreOpenTimeout);
136
- }
137
- });
126
+ ].filter(filterLink));
127
+ let showMore = $state(false);
138
128
  </script>
139
129
 
140
130
  <Menubar>
141
131
  {#snippet children({ createMenu })}
142
- <Menu {createMenu} usePointerDownOutside>
132
+ <Menu {createMenu} usePointerDownOutside on:close={() => (showMore = false)}>
143
133
  {#snippet triggr({ trigger })}
144
134
  <MenuButton
145
135
  class="!text-xs"
@@ -255,8 +245,8 @@ onDestroy(() => {
255
245
  onClick={() => logout()}
256
246
  class={twMerge(
257
247
  'flex flex-row gap-3.5 items-center px-2 py-2 w-full',
258
- 'text-secondary text-xs',
259
- 'hover:bg-surface-hover hover:text-primary cursor-pointer',
248
+ 'text-primary text-xs',
249
+ 'hover:bg-surface-hover cursor-pointer',
260
250
  'data-[highlighted]:bg-surface-hover data-[highlighted]:text-primary'
261
251
  )}
262
252
  {item}
@@ -265,57 +255,42 @@ onDestroy(() => {
265
255
  Sign out
266
256
  </MenuItem>
267
257
  </div>
268
- <div
269
- onmouseenter={() => debouncedSetMoreOpen(true)}
270
- onmouseleave={() => debouncedSetMoreOpen(false)}
271
- role="none"
272
- >
273
- <MenuItem
274
- onFocusIn={() => debouncedSetMoreOpen(true)}
275
- onFocusOut={() => debouncedSetMoreOpen(false)}
276
- {item}
277
- >
278
- {#if !moreOpen || secondMenuLinks.length === 0}
279
- <div class="px-2 py-2 text-primary text-2xs">More...</div>
280
- {/if}
281
- </MenuItem>
282
- {#if moreOpen && secondMenuLinks.length > 0}
283
- {#each secondMenuLinks as menuLink (menuLink.href ?? menuLink.label)}
284
- <div>
285
- <MenuItem
286
- href={menuLink.href}
287
- class={twMerge(
288
- 'flex flex-row gap-3.5 items-center px-2 py-2 text-secondary text-2xs hover:bg-surface-hover hover:text-primary cursor-pointer',
289
- 'data-[highlighted]:bg-surface-hover data-[highlighted]:text-primary'
290
- )}
291
- {item}
292
- onFocusIn={() => debouncedSetMoreOpen(true)}
293
- onFocusOut={() => debouncedSetMoreOpen(false)}
294
- >
295
- {menuLink.label}
296
- </MenuItem>
297
- </div>
298
- {/each}
258
+ <div onmouseleave={() => (showMore = false)} role="none">
259
+ {#if secondMenuLinks.length}
260
+ <ResizeTransitionWrapper vertical innerClass="w-full">
261
+ {#if !showMore}
262
+ <div onmouseenter={() => (showMore = true)} role="none">
263
+ <MenuItem {item}>
264
+ <div class="px-2 py-2 text-primary text-2xs">More...</div>
265
+ </MenuItem>
266
+ </div>
267
+ {:else}
268
+ {#snippet renderSecondMenuLinks(menuLinks: SecondMenuLink[])}
269
+ {#each menuLinks as menuLink (menuLink.href ?? menuLink.label)}
270
+ <MenuItem
271
+ href={menuLink.href}
272
+ class={twMerge(
273
+ 'flex flex-row gap-3.5 items-center px-2 py-2 text-secondary text-2xs hover:bg-surface-hover hover:text-primary cursor-pointer',
274
+ 'data-[highlighted]:bg-surface-hover data-[highlighted]:text-primary'
275
+ )}
276
+ {item}
277
+ >
278
+ {menuLink.label}
279
+ </MenuItem>
280
+ {/each}
281
+ {/snippet}
282
+ <div class="divide-y">
283
+ <div>{@render renderSecondMenuLinks(secondMenuLinks)}</div>
284
+ <div>{@render renderSecondMenuLinks(secondMenuTriggerLinks)}</div>
285
+ </div>
286
+ {/if}
287
+ </ResizeTransitionWrapper>
288
+ {/if}
289
+ {#if $enterpriseLicense}
290
+ <MultiplayerMenu />
299
291
  {/if}
300
292
  </div>
301
293
  </div>
302
- {#if $enterpriseLicense}
303
- <div
304
- onmouseenter={() => {
305
- if (moreOpenTimeout) {
306
- setTimeout(() => {
307
- clearTimeout(moreOpenTimeout)
308
- }, 15)
309
- }
310
- }}
311
- onmouseleave={() => {
312
- debouncedSetMoreOpen(false)
313
- }}
314
- role="none"
315
- >
316
- <MultiplayerMenu />
317
- </div>
318
- {/if}
319
294
  {/snippet}
320
295
  </Menu>
321
296
  {/snippet}
@@ -2,7 +2,7 @@
2
2
  import { superadmin, usedTriggerKinds, userStore, workspaceStore, isCriticalAlertsUIOpen, enterpriseLicense, devopsRole, tutorialsToDo, skippedAll } from '../../stores';
3
3
  import { syncTutorialsTodos } from '../../tutorialUtils';
4
4
  import { SIDEBAR_SHOW_SCHEDULES } from '../../consts';
5
- import { BookOpen, HardHat, Boxes, Calendar, DollarSign, Eye, Logs, FolderCog, FolderOpen, Github, GraduationCap, HelpCircle, Home, LogOut, Newspaper, Play, Route, ServerCog, Settings, UserCog, Plus, Unplug, AlertCircle, Database, Pyramid, Trash2, MailIcon } from 'lucide-svelte';
5
+ import { BookOpen, ServerCog, Boxes, Calendar, DollarSign, Eye, Logs, FolderCog, FolderOpen, Github, GraduationCap, HelpCircle, Home, LogOut, Newspaper, Play, Route, Settings, UserCog, Plus, Unplug, AlertCircle, Database, Pyramid, Trash2, MailIcon } from 'lucide-svelte';
6
6
  import UserMenu from './UserMenu.svelte';
7
7
  import DiscordIcon from '../icons/brands/Discord.svelte';
8
8
  import { WorkspaceService } from '../../gen';
@@ -20,6 +20,7 @@ import KafkaIcon from '../icons/KafkaIcon.svelte';
20
20
  import NatsIcon from '../icons/NatsIcon.svelte';
21
21
  import MqttIcon from '../icons/MqttIcon.svelte';
22
22
  import AwsIcon from '../icons/AwsIcon.svelte';
23
+ import { getAvailableNativeTriggerServices, getServiceConfig, getServiceIcon } from '../triggers/native/utils';
23
24
  import { Menubar, Menu, MenuSingleItem, MenuItem, MeltButton } from '../meltComponents';
24
25
  import MenuButton from './MenuButton.svelte';
25
26
  import GoogleCloudIcon from '../icons/GoogleCloudIcon.svelte';
@@ -38,6 +39,23 @@ async function deleteFork() {
38
39
  let hasNewChangelogs = $state(false);
39
40
  let recentChangelogs = $state([]);
40
41
  let lastOpened = localStorage.getItem('changelogsLastOpened');
42
+ let availableNativeServices = $state([]);
43
+ async function loadAvailableNativeTriggers() {
44
+ try {
45
+ const services = await getAvailableNativeTriggerServices($workspaceStore);
46
+ const serviceData = await Promise.all(services.map(async (service) => ({
47
+ service,
48
+ icon: await getServiceIcon(service),
49
+ config: getServiceConfig(service)
50
+ })));
51
+ availableNativeServices = serviceData;
52
+ }
53
+ catch (err) {
54
+ console.error('Failed to load available native trigger services:', err);
55
+ availableNativeServices = [];
56
+ }
57
+ }
58
+ loadAvailableNativeTriggers();
41
59
  onMount(async () => {
42
60
  if (lastOpened) {
43
61
  // @ts-ignore
@@ -255,6 +273,16 @@ let defaultExtraTriggerLinks = $derived([
255
273
  aiDescription: 'Button to navigate to Email triggers'
256
274
  }
257
275
  ]);
276
+ let nativeTriggerLinks = $derived(availableNativeServices.map(({ service, icon, config }) => ({
277
+ label: config?.serviceDisplayName || service,
278
+ href: `/native_triggers/${service}`,
279
+ icon: icon,
280
+ disabled: $userStore?.operator,
281
+ kind: service,
282
+ aiId: `sidebar-menu-link-${service}`,
283
+ aiDescription: `Button to navigate to ${config?.serviceDisplayName || service} triggers`
284
+ })));
285
+ let allTriggerLinks = $derived([...defaultExtraTriggerLinks, ...nativeTriggerLinks]);
258
286
  let triggerMenuLinks = $derived([
259
287
  {
260
288
  label: 'Schedules',
@@ -264,9 +292,9 @@ let triggerMenuLinks = $derived([
264
292
  aiId: 'sidebar-menu-link-schedules',
265
293
  aiDescription: 'Button to navigate to schedules'
266
294
  },
267
- ...defaultExtraTriggerLinks.filter((link) => $usedTriggerKinds.includes(link.kind) || $page.url.pathname.includes(link.href))
295
+ ...allTriggerLinks.filter((link) => $usedTriggerKinds.includes(link.kind) || $page.url.pathname.includes(link.href))
268
296
  ]);
269
- let extraTriggerLinks = $derived(defaultExtraTriggerLinks.filter((link) => {
297
+ let extraTriggerLinks = $derived(allTriggerLinks.filter((link) => {
270
298
  return !$page.url.pathname.includes(link.href) && !$usedTriggerKinds.includes(link.kind);
271
299
  }));
272
300
  let secondaryMenuLinks = $derived([
@@ -345,7 +373,7 @@ let secondaryMenuLinks = $derived([
345
373
  {
346
374
  label: 'Workers',
347
375
  href: `${base}/workers`,
348
- icon: HardHat,
376
+ icon: ServerCog,
349
377
  disabled: $userStore?.operator,
350
378
  aiId: 'sidebar-menu-link-workers',
351
379
  aiDescription: 'Button to navigate to workers'
@@ -582,7 +610,12 @@ let secondaryMenuLinks = $derived([
582
610
  {/snippet}
583
611
  {#snippet children({ item })}
584
612
  {#each menuLink.subItems as subItem (subItem.href ?? subItem.label)}
585
- <MenuItem href={subItem.href} class={itemClass} target={subItem.external !== false ? "_blank" : undefined} {item}>
613
+ <MenuItem
614
+ href={subItem.href}
615
+ class={itemClass}
616
+ target={subItem.external !== false ? '_blank' : undefined}
617
+ {item}
618
+ >
586
619
  <div class="flex flex-row items-center gap-2">
587
620
  {#if subItem.icon}
588
621
  <subItem.icon size={16} />
@@ -615,7 +648,7 @@ let secondaryMenuLinks = $derived([
615
648
  <ConfirmationModal
616
649
  open={leaveWorkspaceModal}
617
650
  title="Leave workspace"
618
- confirmationText="Remove"
651
+ confirmationText="Leave workspace"
619
652
  on:canceled={() => {
620
653
  leaveWorkspaceModal = false
621
654
  }}
@@ -1,10 +1,10 @@
1
1
  <script lang="ts">import { goto } from '../../navigation';
2
- import { logout } from '../../logout';
2
+ import { logout } from '../../logoutKit';
3
3
  import { userStore, usageStore, workspaceUsageStore, isPremiumStore, workspaceStore } from '../../stores';
4
4
  import { USER_SETTINGS_HASH } from './settings';
5
5
  import { isCloudHosted } from '../../cloud';
6
6
  import { twMerge } from 'tailwind-merge';
7
- import { Crown, HardHat, LogOut, Moon, Settings, Sun, User } from 'lucide-svelte';
7
+ import { Crown, ServerCog, LogOut, Moon, Settings, Sun, User } from 'lucide-svelte';
8
8
  import DarkModeObserver from '../DarkModeObserver.svelte';
9
9
  import MenuButton from './MenuButton.svelte';
10
10
  import { Menu, MenuItem } from '../meltComponents';
@@ -35,7 +35,7 @@ const itemClass = twMerge('text-secondary text-left font-normal text-xs ', 'flex
35
35
  {#if $userStore?.is_admin}
36
36
  Admin of this workspace <Crown size={14} />
37
37
  {:else if $userStore?.operator}
38
- Operator in this workspace <HardHat size={14} />
38
+ Operator in this workspace <ServerCog size={14} />
39
39
  {/if}
40
40
  </span>
41
41
  </div>