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
@@ -28,16 +28,14 @@ function validate(values, dbSchema) {
28
28
  }
29
29
  </script>
30
30
 
31
- <script lang="ts">import { ArrowRight, ClipboardCopy, Info, Plus, Settings, X } from 'lucide-svelte';
31
+ <script lang="ts">import { ArrowRight, ClipboardCopy, Plus, Settings, X } from 'lucide-svelte';
32
32
  import { Button } from './common';
33
33
  import { Cell } from './table';
34
34
  import DataTable from './table/DataTable.svelte';
35
35
  import Head from './table/Head.svelte';
36
- import { datatypeHasLength, dbSupportsSchemas } from './apps/components/display/dbtable/utils';
36
+ import { datatypeHasLength } from './apps/components/display/dbtable/utils';
37
37
  import { DB_TYPES } from '../consts';
38
38
  import Popover from './meltComponents/Popover.svelte';
39
- import Tooltip from './meltComponents/Tooltip.svelte';
40
- import { datatypeDefaultLength } from './apps/components/display/dbtable/queries/createTable';
41
39
  import ConfirmationModal from './common/confirmationModal/ConfirmationModal.svelte';
42
40
  import { sendUserToast } from '../toast';
43
41
  import { copyToClipboard } from '../utils';
@@ -48,7 +46,11 @@ import Select from './select/Select.svelte';
48
46
  import { safeSelectItems } from './select/utils.svelte';
49
47
  import TextInput from './text_input/TextInput.svelte';
50
48
  import Portal from './Portal.svelte';
51
- const { onConfirm, dbType, previewSql, dbSchema, currentSchema } = $props();
49
+ import { Debounced } from 'runed';
50
+ import { datatypeDefaultLength } from './apps/components/display/dbtable/tableEditor';
51
+ import Alert from './common/alert/Alert.svelte';
52
+ import Label from './Label.svelte';
53
+ const { dbType, dbSchema, currentSchema, initialValues, features, onConfirm, computeBtnProps, computePreview } = $props();
52
54
  const columnTypes = DB_TYPES[dbType];
53
55
  const defaultColumnType = {
54
56
  postgresql: 'BIGSERIAL',
@@ -58,7 +60,7 @@ const defaultColumnType = {
58
60
  mysql: 'varchar',
59
61
  duckdb: 'string'
60
62
  }[dbType];
61
- const values = $state({
63
+ const values = $state($state.snapshot(initialValues) ?? {
62
64
  name: '',
63
65
  columns: [],
64
66
  foreignKeys: []
@@ -73,10 +75,13 @@ function addColumn({ name, primaryKey }) {
73
75
  ...(primaryKey && { primaryKey })
74
76
  });
75
77
  }
76
- addColumn({ name: 'id', primaryKey: dbType !== 'duckdb' });
78
+ if (!initialValues) {
79
+ addColumn({ name: 'id', primaryKey: features?.primaryKeys });
80
+ }
77
81
  const errors = $derived(validate(values, dbSchema));
78
82
  let askingForConfirmation = $state();
79
83
  let darkMode = $state(false);
84
+ let btnProps = new Debounced(() => computeBtnProps({ values }), 500);
80
85
  </script>
81
86
 
82
87
  <DarkModeObserver bind:darkMode />
@@ -87,12 +92,12 @@ let darkMode = $state(false);
87
92
  Name
88
93
  <TextInput
89
94
  inputProps={{ type: 'text', placeholder: 'my_table' }}
90
- class={errors?.name ? 'border !border-red-600/60' : ''}
95
+ error={errors?.name}
91
96
  bind:value={values.name}
92
97
  />
93
98
  </label>
94
99
 
95
- <div class="flex flex-col">
100
+ <div class="flex flex-col" id="columns-section">
96
101
  <!-- svelte-ignore a11y_label_has_associated_control -->
97
102
  <label>Columns</label>
98
103
  <DataTable>
@@ -100,18 +105,39 @@ let darkMode = $state(false);
100
105
  <tr>
101
106
  <Cell head first>Name</Cell>
102
107
  <Cell head>Type</Cell>
103
- <Cell head last>Primary</Cell>
108
+ <Cell head last>{features?.primaryKeys ? 'Primary' : ''}</Cell>
104
109
  </tr>
105
110
  </Head>
106
111
  <tbody class="divide-y bg-surface">
107
112
  {#each values.columns as column, i}
108
113
  <tr>
109
114
  <Cell first>
110
- <TextInput
111
- error={errors?.columns?.includes(column.name)}
112
- inputProps={{ type: 'text', placeholder: 'column_name' }}
113
- bind:value={column.name}
114
- />
115
+ <div class="flex flex-col">
116
+ <TextInput
117
+ error={errors?.columns?.includes(column.name)}
118
+ inputProps={{ type: 'text', placeholder: 'column_name' }}
119
+ bind:value={
120
+ () => column.name,
121
+ (newName) => {
122
+ const oldName = column.name
123
+ column.name = newName
124
+ // Update all foreign keys that reference this column
125
+ if (oldName && oldName !== newName) {
126
+ values.foreignKeys.forEach((fk) => {
127
+ fk.columns.forEach((fkCol) => {
128
+ if (fkCol.sourceColumn === oldName) {
129
+ fkCol.sourceColumn = newName
130
+ }
131
+ })
132
+ })
133
+ }
134
+ }
135
+ }
136
+ />
137
+ {#if column.initialName && column.name !== column.initialName}
138
+ <span class="text-xs text-hint">Old name: {column.initialName}</span>
139
+ {/if}
140
+ </div>
115
141
  </Cell>
116
142
  <Cell>
117
143
  <Select
@@ -129,12 +155,25 @@ let darkMode = $state(false);
129
155
  items={safeSelectItems(columnTypes)}
130
156
  class="w-48"
131
157
  />
158
+ {#if column.initialName && column.name !== column.initialName}
159
+ <span class="text-xs">&nbsp;</span>
160
+ {/if}
132
161
  </Cell>
133
162
  <Cell last class="flex items-center mt-1.5">
134
- <input type="checkbox" class="!w-4 !h-4" bind:checked={column.primaryKey} />
135
- <Popover class="ml-8" contentClasses="py-3 px-5 flex flex-col gap-6">
163
+ {#if features?.primaryKeys}
164
+ <input
165
+ type="checkbox"
166
+ class="!w-4 !h-4 primary-key-checkbox"
167
+ bind:checked={column.primaryKey}
168
+ />
169
+ {/if}
170
+ <Popover
171
+ class="ml-8"
172
+ contentClasses="py-3 px-5 flex flex-col gap-6"
173
+ enableFlyTransition
174
+ >
136
175
  {#snippet trigger()}
137
- <Settings size={18} />
176
+ <Settings size={18} class="settings-menu-btn" />
138
177
  {/snippet}
139
178
  {#snippet content()}
140
179
  {#if datatypeHasLength(column.datatype)}
@@ -143,26 +182,27 @@ let darkMode = $state(false);
143
182
  <input type="number" placeholder="0" bind:value={column.datatype_length} />
144
183
  </label>
145
184
  {/if}
146
- <label class="text-xs">
147
- <span class="flex gap-1 mb-1">
148
- Default value
149
- <Tooltip>
150
- <Info size={14} />
151
- {#snippet text()}
152
- Surround your expressions with curly brackets:
153
- <code>
154
- {'{NOW()}'}
155
- </code>.
156
- <br />
157
- By default, it will be parsed as a literal
158
- {/snippet}
159
- </Tooltip>
160
- </span>
161
- <input type="text" placeholder="NULL" bind:value={column.defaultValue} />
162
- </label>
185
+ {#if features?.defaultValues}
186
+ <Label
187
+ class="flex gap-1 mb-1"
188
+ label="Default Value"
189
+ tooltip="Parsed as literal by default. Use curly brackets for expressions (e.g. {'{NOW()}'} )."
190
+ >
191
+ <input
192
+ class="default-value"
193
+ type="text"
194
+ placeholder="NULL"
195
+ bind:value={column.defaultValue}
196
+ />
197
+ </Label>
198
+ {/if}
163
199
  {#if !column.primaryKey}
164
200
  <label class="flex gap-2 items-center text-xs">
165
- <input type="checkbox" class="!w-4 !h-4" bind:checked={column.nullable} />
201
+ <input
202
+ type="checkbox"
203
+ class="nullable-checkbox !w-4 !h-4"
204
+ bind:checked={column.nullable}
205
+ />
166
206
  Nullable
167
207
  </label>
168
208
  {/if}
@@ -172,7 +212,7 @@ let darkMode = $state(false);
172
212
  color="light"
173
213
  startIcon={{ icon: X }}
174
214
  wrapperClasses="w-fit ml-2"
175
- btnClasses="p-0"
215
+ btnClasses="delete-column-btn p-0"
176
216
  on:click={() => values.columns.splice(i, 1)}
177
217
  />
178
218
  </Cell>
@@ -193,156 +233,163 @@ let darkMode = $state(false);
193
233
  </tbody>
194
234
  </DataTable>
195
235
  </div>
196
- <div class="flex flex-col">
197
- <!-- svelte-ignore a11y_label_has_associated_control -->
198
- <label>Foreign Keys</label>
199
- <DataTable>
200
- <Head>
201
- <tr>
202
- <Cell head first>Table</Cell>
203
- <Cell head last>Columns</Cell>
204
- </tr>
205
- </Head>
206
- <tbody class="divide-y bg-surface">
207
- {#each values.foreignKeys as foreignKey, foreignKeyIndex}
208
- {@const fkErrors = errors?.foreignKeys?.[foreignKeyIndex]}
236
+ {#if features?.foreignKeys}
237
+ <div class="flex flex-col" id="foreign-keys-section">
238
+ <!-- svelte-ignore a11y_label_has_associated_control -->
239
+ <label>Foreign Keys</label>
240
+ <DataTable>
241
+ <Head>
209
242
  <tr>
210
- <Cell first class="flex">
211
- <Select
212
- inputClass={twMerge(
213
- '!w-48',
214
- fkErrors?.emptyTarget ? 'border !border-red-600/60' : ''
215
- )}
216
- placeholder=""
217
- bind:value={foreignKey.targetTable}
218
- items={getFlatTableNamesFromSchema(dbSchema).map((o) => ({
219
- value: o,
220
- label:
221
- (currentSchema && o.startsWith(currentSchema)) || !dbSupportsSchemas(dbType)
222
- ? o.split('.')[1]
223
- : o
224
- }))}
225
- />
226
- </Cell>
227
- <Cell>
228
- <div class="flex flex-col gap-2">
229
- {#each foreignKey.columns as column, columnIndex}
230
- <div class="flex">
231
- <div class="flex items-center gap-1 w-60">
232
- <!-- Div wrappers with absolute select are to prevent the Select content
243
+ <Cell head first>Table</Cell>
244
+ <Cell head last>Columns</Cell>
245
+ </tr>
246
+ </Head>
247
+ <tbody class="divide-y bg-surface">
248
+ {#each values.foreignKeys as foreignKey, foreignKeyIndex}
249
+ {@const fkErrors = errors?.foreignKeys?.[foreignKeyIndex]}
250
+ <tr>
251
+ <Cell first class="flex">
252
+ <Select
253
+ inputClass={twMerge('fk-table-select !w-48')}
254
+ error={fkErrors?.emptyTarget}
255
+ placeholder=""
256
+ bind:value={foreignKey.targetTable}
257
+ items={getFlatTableNamesFromSchema(dbSchema).map((o) => ({
258
+ value: o,
259
+ label:
260
+ !features?.schemas ||
261
+ (currentSchema && o.toLowerCase().startsWith(currentSchema.toLowerCase()))
262
+ ? o.split('.')[1]
263
+ : o
264
+ }))}
265
+ />
266
+ </Cell>
267
+ <Cell>
268
+ <div class="flex flex-col gap-2">
269
+ {#each foreignKey.columns as column, columnIndex}
270
+ <div class="flex">
271
+ <div class="flex items-center gap-1 w-60">
272
+ <!-- Div wrappers with absolute select are to prevent the Select content
233
273
  from x-overflowing -->
234
- <div class="grow h-[2rem] relative">
235
- <Select
236
- class="!absolute inset-0"
237
- inputClass={twMerge(
238
- fkErrors?.nonExistingSourceColumns.includes(column.sourceColumn)
239
- ? 'border !border-red-600/60'
240
- : ''
241
- )}
242
- placeholder=""
243
- bind:value={column.sourceColumn}
244
- items={values.columns
245
- .filter((c) => c.name.length)
246
- .map((c) => ({ value: c.name }))}
247
- clearable={false}
248
- />
274
+ <div class="grow h-[2rem] relative">
275
+ <Select
276
+ class="fk-source-col-select !absolute inset-0"
277
+ error={fkErrors?.nonExistingSourceColumns.includes(
278
+ column.sourceColumn
279
+ )}
280
+ placeholder=""
281
+ bind:value={column.sourceColumn}
282
+ items={values.columns
283
+ .filter((c) => c.name.length)
284
+ .map((c) => ({ value: c.name }))}
285
+ clearable={false}
286
+ />
287
+ </div>
288
+ <ArrowRight size={16} class="h-fit shrink-0" />
289
+ <div class="grow h-[2rem] relative">
290
+ <Select
291
+ class="fk-target-col-select !absolute inset-0"
292
+ error={fkErrors?.nonExistingTargetColumns.includes(
293
+ column.targetColumn
294
+ )}
295
+ placeholder=""
296
+ bind:value={column.targetColumn}
297
+ items={Object.keys(
298
+ dbSchema?.schema?.[foreignKey.targetTable?.split('.')?.[0] ?? '']?.[
299
+ foreignKey.targetTable?.split('.')[1]
300
+ ] ?? {}
301
+ ).map((value) => ({ value }))}
302
+ clearable={false}
303
+ />
304
+ </div>
249
305
  </div>
250
- <ArrowRight size={16} class="h-fit shrink-0" />
251
- <div class="grow h-[2rem] relative">
252
- <Select
253
- class="!absolute inset-0"
254
- inputClass={twMerge(
255
- fkErrors?.nonExistingTargetColumns.includes(column.targetColumn)
256
- ? 'border !border-red-600/60'
257
- : ''
258
- )}
259
- placeholder=""
260
- bind:value={column.targetColumn}
261
- items={Object.keys(
262
- dbSchema?.schema?.[foreignKey.targetTable?.split('.')?.[0] ?? '']?.[
263
- foreignKey.targetTable?.split('.')[1]
264
- ] ?? {}
265
- ).map((value) => ({ value }))}
266
- clearable={false}
306
+ <div class="ml-auto flex">
307
+ {#if columnIndex === 0 && features.enforcedForeignKeys}
308
+ <Popover
309
+ contentClasses="py-3 px-5 w-52 flex flex-col gap-4"
310
+ enableFlyTransition
311
+ >
312
+ {#snippet trigger()}
313
+ <Settings class="fk-settings-btn" size={18} />
314
+ {/snippet}
315
+ {#snippet content()}
316
+ <Label label="On delete">
317
+ <select
318
+ class="fk-on-delete-select"
319
+ bind:value={foreignKey.onDelete}
320
+ >
321
+ <option value="NO ACTION" selected>No action</option>
322
+ <option value="CASCADE" selected>Cascade</option>
323
+ <option value="SET NULL" selected>Set null</option>
324
+ </select>
325
+ </Label>
326
+ <Label label="On update">
327
+ <select
328
+ class="fk-on-update-select"
329
+ bind:value={foreignKey.onUpdate}
330
+ >
331
+ <option value="NO ACTION" selected>No action</option>
332
+ <option value="CASCADE" selected>Cascade</option>
333
+ <option value="SET NULL" selected>Set null</option>
334
+ </select>
335
+ </Label>
336
+ {/snippet}
337
+ </Popover>
338
+ {/if}
339
+ <Button
340
+ color="light"
341
+ startIcon={{ icon: X }}
342
+ wrapperClasses="w-fit ml-2"
343
+ btnClasses="fk-delete-btn p-0"
344
+ on:click={foreignKey.columns.length > 1
345
+ ? () => foreignKey.columns.splice(columnIndex, 1)
346
+ : () => values.foreignKeys.splice(foreignKeyIndex, 1)}
267
347
  />
268
348
  </div>
269
349
  </div>
270
- <div class="ml-auto flex">
271
- {#if columnIndex === 0}
272
- <Popover contentClasses="py-3 px-5 w-52 flex flex-col gap-6">
273
- {#snippet trigger()}
274
- <Settings size={18} />
275
- {/snippet}
276
- {#snippet content()}
277
- <span>
278
- ON DELETE <select bind:value={foreignKey.onDelete}>
279
- <option value="NO ACTION" selected>NO ACTION</option>
280
- <option value="CASCADE" selected>CASCADE</option>
281
- <option value="SET NULL" selected>SET NULL</option>
282
- </select>
283
- </span>
284
- <span>
285
- ON UPDATE <select bind:value={foreignKey.onUpdate}>
286
- <option value="NO ACTION" selected>NO ACTION</option>
287
- <option value="CASCADE" selected>CASCADE</option>
288
- <option value="SET NULL" selected>SET NULL</option>
289
- </select>
290
- </span>
291
- {/snippet}
292
- </Popover>
293
- {/if}
294
- <Button
295
- color="light"
296
- startIcon={{ icon: X }}
297
- wrapperClasses="w-fit ml-2"
298
- btnClasses="p-0"
299
- on:click={foreignKey.columns.length > 1
300
- ? () => foreignKey.columns.splice(columnIndex, 1)
301
- : () => values.foreignKeys.splice(foreignKeyIndex, 1)}
302
- />
303
- </div>
304
- </div>
305
- {/each}
306
- <button
307
- class="w-60 border-dashed dark:border-gray-600 border-2 rounded-md flex justify-center items-center py-1 gap-2 text-primary-500 font-normal"
308
- onclick={() => foreignKey.columns.push({})}
309
- >
310
- <Plus class="h-fit" size={12} /> Add
311
- </button>
312
- </div></Cell
313
- >
350
+ {/each}
351
+ <button
352
+ class="w-60 border-dashed dark:border-gray-600 border-2 rounded-md flex justify-center items-center py-1 gap-2 text-primary-500 font-normal"
353
+ onclick={() => foreignKey.columns.push({})}
354
+ >
355
+ <Plus class="h-fit" size={12} /> Add
356
+ </button>
357
+ </div></Cell
358
+ >
359
+ </tr>
360
+ {/each}
361
+ <tr class="w-full">
362
+ <td colspan={99} class="p-1">
363
+ <Button
364
+ wrapperClasses="mx-auto"
365
+ startIcon={{ icon: Plus }}
366
+ color="light"
367
+ on:click={() =>
368
+ values.foreignKeys.push({
369
+ columns: [{}],
370
+ onDelete: 'NO ACTION',
371
+ onUpdate: 'NO ACTION'
372
+ })}
373
+ >
374
+ Add
375
+ </Button>
376
+ </td>
314
377
  </tr>
315
- {/each}
316
- <tr class="w-full">
317
- <td colspan={99} class="p-1">
318
- <Button
319
- wrapperClasses="mx-auto"
320
- startIcon={{ icon: Plus }}
321
- color="light"
322
- on:click={() =>
323
- values.foreignKeys.push({
324
- columns: [{}],
325
- onDelete: 'NO ACTION',
326
- onUpdate: 'NO ACTION'
327
- })}
328
- >
329
- Add
330
- </Button>
331
- </td>
332
- </tr>
333
- </tbody>
334
- </DataTable>
335
- </div>
378
+ </tbody>
379
+ </DataTable>
380
+ </div>
381
+ {/if}
336
382
  </div>
337
383
  <Button
338
- disabled={!!errors}
339
- on:click={() =>
340
- (askingForConfirmation = {
384
+ disabled={!!errors || btnProps.current.disabled}
385
+ loading={btnProps.pending}
386
+ on:click={() => {
387
+ let preview = computePreview?.({ values })
388
+ askingForConfirmation = {
341
389
  onConfirm: async () => {
342
390
  try {
343
391
  askingForConfirmation && (askingForConfirmation.loading = true)
344
- await onConfirm(values)
345
- sendUserToast(values.name + ' created!')
392
+ await onConfirm({ values })
346
393
  } catch (e) {
347
394
  let msg: string | undefined = (e as Error)?.message
348
395
  if (typeof msg !== 'string') msg = e ? JSON.stringify(e) : 'An error occurred'
@@ -351,19 +398,28 @@ let darkMode = $state(false);
351
398
  askingForConfirmation = undefined
352
399
  },
353
400
  title: 'Confirm running the following:',
354
- confirmationText: 'Create ' + values.name,
401
+ confirmationText: btnProps.current.text,
355
402
  open: true,
356
- ...(previewSql && { codeContent: previewSql(values) })
357
- })}>Create table</Button
403
+ ...(preview && { codeContent: preview.sql, alert: preview.alert })
404
+ }
405
+ }}
358
406
  >
407
+ {btnProps.current.text}
408
+ </Button>
359
409
  </div>
360
410
 
361
411
  <Portal>
362
412
  <ConfirmationModal
413
+ id="db-table-editor-confirmation-modal"
363
414
  {...askingForConfirmation ?? { confirmationText: '', title: '' }}
364
415
  on:canceled={() => (askingForConfirmation = undefined)}
365
416
  on:confirmed={askingForConfirmation?.onConfirm ?? (() => {})}
366
417
  >
418
+ {#if askingForConfirmation?.alert}
419
+ <Alert title={askingForConfirmation.alert.title} type="error" class="mb-2">
420
+ {askingForConfirmation.alert.body}
421
+ </Alert>
422
+ {/if}
367
423
  {#if askingForConfirmation?.codeContent}
368
424
  <div class="bg-surface-secondary border border-surface-selected rounded-md p-2 relative">
369
425
  <code class="whitespace-pre-wrap">
@@ -1,12 +1,31 @@
1
- import { type CreateTableValues } from './apps/components/display/dbtable/queries/createTable';
2
1
  import { type DBSchema } from '../stores';
3
2
  import type { DbType } from './dbTypes';
3
+ import { type TableEditorValues } from './apps/components/display/dbtable/tableEditor';
4
+ import type { DbFeatures } from './apps/components/display/dbtable/dbFeatures';
4
5
  type Props = {
5
- onConfirm: (values: CreateTableValues) => void | Promise<void>;
6
- previewSql?: (values: CreateTableValues) => string;
7
6
  dbType: DbType;
8
7
  dbSchema?: DBSchema;
9
8
  currentSchema?: string;
9
+ initialValues?: TableEditorValues;
10
+ features?: DbFeatures;
11
+ onConfirm: (params: {
12
+ values: TableEditorValues;
13
+ }) => void | Promise<void>;
14
+ computePreview: (params: {
15
+ values: TableEditorValues;
16
+ }) => {
17
+ sql: string;
18
+ alert?: {
19
+ title: string;
20
+ body?: string;
21
+ };
22
+ };
23
+ computeBtnProps: (params: {
24
+ values: TableEditorValues;
25
+ }) => {
26
+ text: string;
27
+ disabled?: boolean;
28
+ };
10
29
  };
11
30
  declare const DBTableEditor: import("svelte").Component<Props, {}, "">;
12
31
  type DBTableEditor = ReturnType<typeof DBTableEditor>;