windmill-components 1.60.4 → 1.75.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (549) hide show
  1. package/assets/app.css +15 -1
  2. package/common.d.ts +5 -1
  3. package/components/ApiConnectForm.svelte +66 -5
  4. package/components/AppConnect.svelte +26 -10
  5. package/components/ArgInput.svelte +1 -1
  6. package/components/CliHelpBox.svelte +49 -0
  7. package/components/CliHelpBox.svelte.d.ts +14 -0
  8. package/components/DisplayResult.svelte +78 -10
  9. package/components/DisplayResult.svelte.d.ts +1 -0
  10. package/components/Editor.svelte +17 -7
  11. package/components/EditorBar.svelte +129 -111
  12. package/components/FieldHeader.svelte +12 -8
  13. package/components/FlowBuilder.svelte +107 -39
  14. package/components/FlowBuilder.svelte.d.ts +5 -0
  15. package/components/FlowGraphViewer.svelte +5 -4
  16. package/components/FlowJobResult.svelte +13 -5
  17. package/components/FlowJobResult.svelte.d.ts +1 -0
  18. package/components/FlowMetadata.svelte +24 -8
  19. package/components/FlowPreviewContent.svelte +5 -11
  20. package/components/FlowStatusViewer.svelte +62 -17
  21. package/components/FolderEditor.svelte +3 -2
  22. package/components/GroupEditor.svelte +8 -0
  23. package/components/HighlightCode.svelte +7 -1
  24. package/components/InlineCodeCopy.svelte +11 -0
  25. package/components/InlineCodeCopy.svelte.d.ts +16 -0
  26. package/components/InputTransformForm.svelte +22 -25
  27. package/components/InputTransformSchemaForm.svelte +103 -0
  28. package/components/InputTransformSchemaForm.svelte.d.ts +24 -0
  29. package/components/LogViewer.svelte +7 -1
  30. package/components/LogViewer.svelte.d.ts +1 -0
  31. package/components/ModulePreview.svelte +13 -3
  32. package/components/MoveDrawer.svelte +1 -1
  33. package/components/Multiselect.svelte +1 -1
  34. package/components/Multiselect.svelte.d.ts +2 -2
  35. package/components/ObjectResourceInput.svelte +6 -1
  36. package/components/Path.svelte +29 -16
  37. package/components/Popover.svelte +10 -15
  38. package/components/Popover.svelte.d.ts +1 -0
  39. package/components/Range.svelte.d.ts +2 -2
  40. package/components/ResourceEditor.svelte +39 -16
  41. package/components/ResourcePicker.svelte +33 -15
  42. package/components/RunChart.svelte +24 -5
  43. package/components/RunForm.svelte +26 -3
  44. package/components/RunForm.svelte.d.ts +2 -0
  45. package/components/ScheduleEditor.svelte +1 -1
  46. package/components/SchemaEditor.svelte +2 -2
  47. package/components/SchemaForm.svelte +72 -60
  48. package/components/SchemaForm.svelte.d.ts +1 -5
  49. package/components/ScriptBuilder.svelte +69 -30
  50. package/components/ScriptBuilder.svelte.d.ts +1 -0
  51. package/components/ScriptEditor.svelte +1 -0
  52. package/components/ScriptPicker.svelte +3 -0
  53. package/components/SharedBadge.svelte +5 -5
  54. package/components/SimpleEditor.svelte +4 -1
  55. package/components/SimpleEditor.svelte.d.ts +2 -0
  56. package/components/Slider.svelte +19 -0
  57. package/components/Slider.svelte.d.ts +20 -0
  58. package/components/StringTypeNarrowing.svelte +0 -1
  59. package/components/SuperadminSettings.svelte +11 -3
  60. package/components/SuperadminSettings.svelte.d.ts +2 -0
  61. package/components/TemplateEditor.svelte +1 -1
  62. package/components/TemplateEditor.svelte.d.ts +204 -0
  63. package/components/TestJobLoader.svelte +5 -5
  64. package/components/Toggle.svelte +18 -6
  65. package/components/Toggle.svelte.d.ts +2 -0
  66. package/components/Tooltip.svelte +1 -1
  67. package/components/UserSettings.svelte +13 -3
  68. package/components/UserSettings.svelte.d.ts +2 -0
  69. package/components/VariableEditor.svelte +1 -1
  70. package/components/WhitelistIp.svelte +23 -0
  71. package/components/WhitelistIp.svelte.d.ts +14 -0
  72. package/components/apps/components/buttons/AppButton.svelte +79 -17
  73. package/components/apps/components/buttons/AppButton.svelte.d.ts +4 -0
  74. package/components/apps/components/{form → buttons}/AppForm.svelte +19 -7
  75. package/components/apps/components/{form → buttons}/AppForm.svelte.d.ts +3 -0
  76. package/components/apps/components/buttons/AppFormButton.svelte +145 -0
  77. package/components/apps/components/buttons/AppFormButton.svelte.d.ts +28 -0
  78. package/components/apps/components/buttons/index.d.ts +3 -0
  79. package/components/apps/components/buttons/index.js +3 -0
  80. package/components/apps/components/{dataDisplay → display}/AppBarChart.svelte +27 -8
  81. package/components/apps/components/{dataDisplay → display}/AppBarChart.svelte.d.ts +4 -0
  82. package/components/apps/components/display/AppDisplayComponent.svelte +36 -0
  83. package/components/apps/components/display/AppDisplayComponent.svelte.d.ts +24 -0
  84. package/components/apps/components/display/AppHtml.svelte +46 -0
  85. package/components/apps/components/{dataDisplay → display}/AppHtml.svelte.d.ts +4 -1
  86. package/components/apps/components/display/AppIcon.svelte +47 -0
  87. package/components/apps/components/display/AppIcon.svelte.d.ts +25 -0
  88. package/components/apps/components/display/AppImage.svelte +34 -0
  89. package/components/apps/components/display/AppImage.svelte.d.ts +25 -0
  90. package/components/apps/components/display/AppMap.svelte +214 -0
  91. package/components/apps/components/display/AppMap.svelte.d.ts +23 -0
  92. package/components/apps/components/display/AppPdf.svelte +304 -0
  93. package/components/apps/components/display/AppPdf.svelte.d.ts +24 -0
  94. package/components/apps/components/{dataDisplay → display}/AppPieChart.svelte +16 -7
  95. package/components/apps/components/{dataDisplay → display}/AppPieChart.svelte.d.ts +4 -0
  96. package/components/apps/components/{dataDisplay → display}/AppScatterChart.svelte +13 -4
  97. package/components/apps/components/{dataDisplay → display}/AppScatterChart.svelte.d.ts +4 -0
  98. package/components/apps/components/{dataDisplay → display}/AppText.svelte +42 -34
  99. package/components/apps/components/{dataDisplay → display}/AppText.svelte.d.ts +4 -0
  100. package/components/apps/components/{dataDisplay → display}/AppTimeseries.svelte +14 -5
  101. package/components/apps/components/{dataDisplay → display}/AppTimeseries.svelte.d.ts +4 -0
  102. package/components/apps/components/display/PlotlyHtml.svelte +32 -0
  103. package/components/apps/components/display/PlotlyHtml.svelte.d.ts +24 -0
  104. package/components/apps/components/{dataDisplay → display}/VegaLiteHtml.svelte +4 -10
  105. package/components/apps/components/{dataDisplay → display}/VegaLiteHtml.svelte.d.ts +2 -0
  106. package/components/apps/components/display/index.d.ts +15 -0
  107. package/components/apps/components/display/index.js +15 -0
  108. package/components/apps/components/display/table/AppAggridTable.svelte +92 -0
  109. package/components/apps/components/display/table/AppAggridTable.svelte.d.ts +25 -0
  110. package/components/apps/components/{table → display/table}/AppTable.svelte +85 -29
  111. package/components/apps/components/{table → display/table}/AppTable.svelte.d.ts +6 -2
  112. package/components/apps/components/{table → display/table}/AppTableFooter.svelte +9 -2
  113. package/components/apps/components/{table → display/table}/AppTableFooter.svelte.d.ts +2 -0
  114. package/components/apps/components/helpers/AlignWrapper.svelte +29 -23
  115. package/components/apps/components/helpers/AlignWrapper.svelte.d.ts +6 -2
  116. package/components/apps/components/helpers/HiddenComponent.svelte +23 -0
  117. package/components/apps/components/helpers/HiddenComponent.svelte.d.ts +25 -0
  118. package/components/apps/components/helpers/InputDefaultValue.svelte +17 -0
  119. package/components/apps/components/helpers/InputDefaultValue.svelte.d.ts +17 -0
  120. package/components/apps/components/helpers/InputValue.svelte +39 -18
  121. package/components/apps/components/helpers/InputValue.svelte.d.ts +0 -1
  122. package/components/apps/components/helpers/NonRunnableComponent.svelte +18 -3
  123. package/components/apps/components/helpers/NonRunnableComponent.svelte.d.ts +1 -0
  124. package/components/apps/components/helpers/RefreshButton.svelte +1 -1
  125. package/components/apps/components/helpers/ResizeWrapper.svelte +24 -0
  126. package/components/apps/components/helpers/ResizeWrapper.svelte.d.ts +19 -0
  127. package/components/apps/components/helpers/RunnableComponent.svelte +99 -102
  128. package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +5 -2
  129. package/components/apps/components/helpers/RunnableWrapper.svelte +16 -7
  130. package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +5 -2
  131. package/components/apps/components/helpers/index.d.ts +10 -0
  132. package/components/apps/components/helpers/index.js +10 -0
  133. package/components/apps/components/icon.d.ts +1 -0
  134. package/components/apps/components/icon.js +18 -0
  135. package/components/apps/components/index.d.ts +5 -0
  136. package/components/apps/components/index.js +5 -0
  137. package/components/apps/components/{selectInputs → inputs}/AppCheckbox.svelte +12 -4
  138. package/components/apps/components/{selectInputs → inputs}/AppCheckbox.svelte.d.ts +3 -0
  139. package/components/apps/components/inputs/AppDateInput.svelte +47 -0
  140. package/components/apps/components/{dateInputs → inputs}/AppDateInput.svelte.d.ts +6 -1
  141. package/components/apps/components/inputs/AppFileInput.svelte +42 -0
  142. package/components/apps/components/inputs/AppFileInput.svelte.d.ts +23 -0
  143. package/components/apps/components/inputs/AppMultiSelect.svelte +82 -0
  144. package/components/apps/components/inputs/AppMultiSelect.svelte.d.ts +27 -0
  145. package/components/apps/components/inputs/AppNumberInput.svelte +52 -0
  146. package/components/apps/components/{numberInputs → inputs}/AppNumberInput.svelte.d.ts +5 -0
  147. package/components/apps/components/inputs/AppRangeInput.svelte +85 -0
  148. package/components/apps/components/inputs/AppRangeInput.svelte.d.ts +26 -0
  149. package/components/apps/components/inputs/AppSelect.svelte +127 -0
  150. package/components/apps/components/{selectInputs → inputs}/AppSelect.svelte.d.ts +5 -0
  151. package/components/apps/components/inputs/AppSliderInputs.svelte +73 -0
  152. package/components/apps/components/{numberInputs → inputs}/AppSliderInputs.svelte.d.ts +3 -0
  153. package/components/apps/components/inputs/AppTextInput.svelte +71 -0
  154. package/components/apps/components/{textInputs → inputs}/AppTextInput.svelte.d.ts +6 -0
  155. package/components/apps/components/inputs/currency/AppCurrencyInput.svelte +59 -0
  156. package/components/apps/components/inputs/currency/AppCurrencyInput.svelte.d.ts +24 -0
  157. package/components/apps/components/inputs/currency/CurrencyInput.svelte +183 -0
  158. package/components/apps/components/inputs/currency/CurrencyInput.svelte.d.ts +33 -0
  159. package/components/apps/components/inputs/index.d.ts +9 -0
  160. package/components/apps/components/inputs/index.js +9 -0
  161. package/components/apps/components/layout/AppContainer.svelte +40 -0
  162. package/components/apps/components/layout/AppContainer.svelte.d.ts +24 -0
  163. package/components/apps/components/layout/AppDivider.svelte +40 -0
  164. package/components/apps/components/layout/AppDivider.svelte.d.ts +24 -0
  165. package/components/apps/components/layout/AppDrawer.svelte +89 -0
  166. package/components/apps/components/layout/AppDrawer.svelte.d.ts +24 -0
  167. package/components/apps/components/layout/AppSplitpanes.svelte +88 -0
  168. package/components/apps/components/layout/AppSplitpanes.svelte.d.ts +26 -0
  169. package/components/apps/components/layout/AppTabs.svelte +99 -0
  170. package/components/apps/components/layout/AppTabs.svelte.d.ts +27 -0
  171. package/components/apps/components/layout/index.d.ts +5 -0
  172. package/components/apps/components/layout/index.js +5 -0
  173. package/components/apps/editor/AppComponentInput.svelte +33 -0
  174. package/components/apps/editor/AppComponentInput.svelte.d.ts +18 -0
  175. package/components/apps/editor/AppComponentInputs.svelte +13 -0
  176. package/components/apps/editor/AppComponentInputs.svelte.d.ts +20 -0
  177. package/components/apps/editor/AppEditor.svelte +134 -35
  178. package/components/apps/editor/AppEditor.svelte.d.ts +4 -1
  179. package/components/apps/editor/AppEditorHeader.svelte +178 -47
  180. package/components/apps/editor/AppEditorHeader.svelte.d.ts +1 -0
  181. package/components/apps/editor/AppInputs.svelte +60 -0
  182. package/components/apps/editor/AppInputs.svelte.d.ts +14 -0
  183. package/components/apps/editor/AppPreview.svelte +30 -12
  184. package/components/apps/editor/ComponentHeader.svelte +52 -3
  185. package/components/apps/editor/ComponentHeader.svelte.d.ts +2 -1
  186. package/components/apps/editor/GridEditor.svelte +134 -77
  187. package/components/apps/editor/GridEditor.svelte.d.ts +2 -0
  188. package/components/apps/editor/GridPanel.svelte +29 -0
  189. package/components/apps/editor/GridPanel.svelte.d.ts +18 -0
  190. package/components/apps/editor/RecomputeAllComponents.svelte +8 -6
  191. package/components/apps/editor/SettingsPanel.svelte +26 -8
  192. package/components/apps/editor/SubGridEditor.svelte +139 -0
  193. package/components/apps/editor/SubGridEditor.svelte.d.ts +29 -0
  194. package/components/apps/editor/appUtils.d.ts +19 -0
  195. package/components/apps/editor/appUtils.js +241 -0
  196. package/components/apps/editor/component/Component.svelte +434 -0
  197. package/components/apps/editor/{ComponentEditor.svelte.d.ts → component/Component.svelte.d.ts} +7 -5
  198. package/components/apps/editor/component/ComponentNavigation.svelte +125 -0
  199. package/components/apps/editor/component/ComponentNavigation.svelte.d.ts +14 -0
  200. package/components/apps/editor/component/README.md +15 -0
  201. package/components/apps/editor/component/components.d.ts +77 -0
  202. package/components/apps/editor/component/components.js +1476 -0
  203. package/components/apps/editor/component/default-codes.d.ts +3 -0
  204. package/components/apps/editor/component/default-codes.js +322 -0
  205. package/components/apps/editor/component/index.d.ts +4 -0
  206. package/components/apps/editor/component/index.js +4 -0
  207. package/components/apps/editor/component/sets.d.ts +2 -0
  208. package/components/apps/editor/component/sets.js +55 -0
  209. package/components/apps/editor/componentsPanel/ComponentList.svelte +75 -108
  210. package/components/apps/editor/componentsPanel/CssProperty.svelte +67 -0
  211. package/components/apps/editor/componentsPanel/CssProperty.svelte.d.ts +21 -0
  212. package/components/apps/editor/componentsPanel/CssSettings.svelte +188 -0
  213. package/components/apps/editor/componentsPanel/CssSettings.svelte.d.ts +14 -0
  214. package/components/apps/editor/componentsPanel/ListItem.svelte +39 -0
  215. package/components/apps/editor/componentsPanel/ListItem.svelte.d.ts +20 -0
  216. package/components/apps/editor/componentsPanel/componentStaticValues.d.ts +5 -1
  217. package/components/apps/editor/componentsPanel/componentStaticValues.js +16 -1
  218. package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +1 -1
  219. package/components/apps/editor/contextPanel/ContextPanel.svelte +115 -67
  220. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +109 -10
  221. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte.d.ts +1 -0
  222. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +88 -41
  223. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte.d.ts +5 -0
  224. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte +32 -6
  225. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte.d.ts +1 -0
  226. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanel.svelte +75 -8
  227. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanelList.svelte +128 -72
  228. package/components/apps/editor/inlineScriptsPanel/utils.d.ts +5 -5
  229. package/components/apps/editor/inlineScriptsPanel/utils.js +48 -7
  230. package/components/apps/editor/settingsPanel/AlignmentEditor.svelte +1 -1
  231. package/components/apps/editor/settingsPanel/AlignmentEditor.svelte.d.ts +1 -1
  232. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte +14 -10
  233. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte.d.ts +68 -1
  234. package/components/apps/editor/settingsPanel/ComponentInputTypeEditor.svelte +1 -1
  235. package/components/apps/editor/settingsPanel/ComponentPanel.svelte +130 -61
  236. package/components/apps/editor/settingsPanel/ComponentPanel.svelte.d.ts +6 -3
  237. package/components/apps/editor/settingsPanel/GridPane.svelte +75 -0
  238. package/components/apps/editor/settingsPanel/GridPane.svelte.d.ts +20 -0
  239. package/components/apps/editor/settingsPanel/GridTab.svelte +73 -0
  240. package/components/apps/editor/settingsPanel/GridTab.svelte.d.ts +20 -0
  241. package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +5 -1
  242. package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte.d.ts +2 -2
  243. package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte +93 -78
  244. package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte.d.ts +1 -0
  245. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte +92 -0
  246. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte.d.ts +18 -0
  247. package/components/apps/editor/settingsPanel/Recompute.svelte +5 -2
  248. package/components/apps/editor/settingsPanel/SelectedRunnable.svelte +1 -1
  249. package/components/apps/editor/settingsPanel/TableActions.svelte +45 -7
  250. package/components/apps/editor/settingsPanel/TableActions.svelte.d.ts +2 -1
  251. package/components/apps/editor/settingsPanel/common/PanelSection.svelte +6 -4
  252. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte +48 -0
  253. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte.d.ts +19 -0
  254. package/components/apps/editor/settingsPanel/inputEditor/ConnectedInputEditor.svelte +1 -1
  255. package/components/apps/editor/settingsPanel/inputEditor/EvalInputEditor.svelte +1 -1
  256. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte +107 -0
  257. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte.d.ts +21 -0
  258. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte +2 -2
  259. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte.d.ts +2 -1
  260. package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte +59 -6
  261. package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte.d.ts +3 -0
  262. package/components/apps/editor/settingsPanel/inputEditor/UploadInputEditor.svelte +21 -0
  263. package/components/apps/editor/settingsPanel/inputEditor/UploadInputEditor.svelte.d.ts +17 -0
  264. package/components/apps/editor/settingsPanel/mainInput/InlineScriptList.svelte +1 -0
  265. package/components/apps/editor/settingsPanel/mainInput/InlineScriptList.svelte.d.ts +1 -0
  266. package/components/apps/editor/settingsPanel/mainInput/RunnableSelector.svelte +4 -21
  267. package/components/apps/gridUtils.d.ts +3 -1
  268. package/components/apps/gridUtils.js +5 -3
  269. package/components/apps/inputType.d.ts +34 -6
  270. package/components/apps/rx.js +2 -1
  271. package/components/apps/store.d.ts +6 -1
  272. package/components/apps/types.d.ts +47 -42
  273. package/components/apps/types.js +1 -1
  274. package/components/apps/utils.d.ts +6 -5
  275. package/components/apps/utils.js +63 -95
  276. package/components/common/button/Button.svelte +12 -5
  277. package/components/common/button/Button.svelte.d.ts +3 -1
  278. package/components/common/button/ButtonPopup.svelte +2 -0
  279. package/components/common/button/ButtonPopup.svelte.d.ts +2 -1
  280. package/components/common/button/UndoRedo.svelte +32 -0
  281. package/components/common/button/UndoRedo.svelte.d.ts +20 -0
  282. package/components/common/button/model.d.ts +2 -2
  283. package/components/common/button/model.js +21 -6
  284. package/components/common/confirmationModal/ConfirmationModal.svelte +8 -1
  285. package/components/common/confirmationModal/UnsavedConfirmationModal.svelte +4 -4
  286. package/components/common/drawer/Drawer.svelte +13 -5
  287. package/components/common/drawer/Drawer.svelte.d.ts +3 -1
  288. package/components/common/drawer/DrawerContent.svelte +0 -1
  289. package/components/common/fileInput/FileInput.svelte +138 -0
  290. package/components/common/fileInput/FileInput.svelte.d.ts +29 -0
  291. package/components/common/fileInput/model.d.ts +1 -0
  292. package/components/common/fileInput/model.js +1 -0
  293. package/components/common/index.d.ts +2 -0
  294. package/components/common/index.js +2 -0
  295. package/components/common/kbd/Kbd.svelte.d.ts +2 -2
  296. package/components/common/menu/Menu.svelte +3 -2
  297. package/components/common/menu/Menu.svelte.d.ts +2 -1
  298. package/components/common/modal/Modal.svelte +79 -0
  299. package/components/common/modal/Modal.svelte.d.ts +24 -0
  300. package/components/common/popup/Popup.svelte +34 -17
  301. package/components/common/popup/Popup.svelte.d.ts +11 -4
  302. package/components/common/table/AppRow.svelte +13 -4
  303. package/components/common/table/AppRow.svelte.d.ts +1 -0
  304. package/components/common/table/FlowRow.svelte +40 -8
  305. package/components/common/table/FlowRow.svelte.d.ts +1 -0
  306. package/components/common/table/LanguageBadge.svelte +10 -4
  307. package/components/common/table/Row.svelte +1 -1
  308. package/components/common/table/ScriptRow.svelte +44 -12
  309. package/components/common/table/ScriptRow.svelte.d.ts +1 -0
  310. package/components/common/tabs/Tab.svelte +12 -5
  311. package/components/common/tabs/Tab.svelte.d.ts +4 -1
  312. package/components/common/tabs/Tabs.svelte +12 -8
  313. package/components/common/tabs/Tabs.svelte.d.ts +6 -2
  314. package/components/flows/CreateActionsFlow.svelte +2 -3
  315. package/components/flows/FlowEditor.svelte +6 -4
  316. package/components/flows/common/FlowCardHeader.svelte +4 -1
  317. package/components/flows/content/BranchPredicateEditor.svelte +13 -12
  318. package/components/flows/content/CapturePayload.svelte +1 -2
  319. package/components/flows/content/FlowBranchesAllWrapper.svelte +1 -1
  320. package/components/flows/content/FlowConstants.svelte +7 -13
  321. package/components/flows/content/FlowEditorPanel.svelte +4 -3
  322. package/components/flows/content/FlowFailureModule.svelte +2 -1
  323. package/components/flows/content/FlowInput.svelte +4 -2
  324. package/components/flows/content/FlowInputs.svelte +109 -99
  325. package/components/flows/content/FlowLoop.svelte +4 -5
  326. package/components/flows/content/FlowModuleComponent.svelte +26 -13
  327. package/components/flows/content/FlowModuleEarlyStop.svelte +3 -1
  328. package/components/flows/content/FlowModuleHeader.svelte +26 -3
  329. package/components/flows/content/FlowModuleHeader.svelte.d.ts +1 -0
  330. package/components/flows/content/FlowModuleSleep.svelte +2 -2
  331. package/components/flows/content/FlowModuleWrapper.svelte +2 -8
  332. package/components/flows/content/FlowRetries.svelte +8 -6
  333. package/components/flows/content/FlowSchedules.svelte +1 -2
  334. package/components/flows/content/FlowSettings.svelte +77 -51
  335. package/components/flows/content/ScriptEditorDrawer.svelte +98 -0
  336. package/components/flows/content/ScriptEditorDrawer.svelte.d.ts +19 -0
  337. package/components/flows/flowState.d.ts +2 -2
  338. package/components/flows/flowState.js +1 -3
  339. package/components/flows/flowStateUtils.d.ts +7 -6
  340. package/components/flows/flowStateUtils.js +9 -11
  341. package/components/flows/flowStore.d.ts +5 -3
  342. package/components/flows/flowStore.js +6 -17
  343. package/components/flows/header/FlowImportExportMenu.svelte +2 -1
  344. package/components/flows/map/FlowConstantsItem.svelte +2 -2
  345. package/components/flows/map/FlowErrorHandlerItem.svelte +12 -13
  346. package/components/flows/map/FlowInputsItem.svelte +2 -3
  347. package/components/flows/map/FlowModuleSchemaItem.svelte +88 -91
  348. package/components/flows/map/FlowModuleSchemaItem.svelte.d.ts +3 -3
  349. package/components/flows/map/FlowModuleSchemaMap.svelte +163 -130
  350. package/components/flows/map/FlowModuleSchemaMap.svelte.d.ts +1 -1
  351. package/components/flows/map/FlowSettingsItem.svelte +5 -4
  352. package/components/flows/map/InsertModuleButton.svelte +34 -18
  353. package/components/flows/map/InsertModuleButton.svelte.d.ts +2 -0
  354. package/components/flows/map/MapItem.svelte +176 -101
  355. package/components/flows/map/MapItem.svelte.d.ts +20 -2
  356. package/components/flows/map/VirtualItem.svelte +129 -0
  357. package/components/flows/map/VirtualItem.svelte.d.ts +44 -0
  358. package/components/flows/pickers/WorkspaceScriptPicker.svelte +1 -1
  359. package/components/flows/previousResults.d.ts +1 -1
  360. package/components/flows/previousResults.js +32 -17
  361. package/components/flows/types.d.ts +13 -1
  362. package/components/flows/utils.js +17 -11
  363. package/components/graph/FlowGraph.svelte +247 -164
  364. package/components/graph/FlowGraph.svelte.d.ts +15 -1
  365. package/components/graph/model.d.ts +6 -36
  366. package/components/graph/model.js +1 -1
  367. package/components/graph/svelvet/LICENSE +21 -0
  368. package/components/graph/svelvet/collapsible/controllers/util.d.ts +15 -0
  369. package/components/graph/svelvet/collapsible/controllers/util.js +144 -0
  370. package/components/graph/svelvet/collapsible/models/Collapsible.d.ts +17 -0
  371. package/components/graph/svelvet/collapsible/models/Collapsible.js +25 -0
  372. package/components/graph/svelvet/collapsible/types/types.d.ts +8 -0
  373. package/components/graph/svelvet/collapsible/types/types.js +1 -0
  374. package/components/graph/svelvet/container/README.md +7 -0
  375. package/components/graph/svelvet/container/controllers/middleware.d.ts +18 -0
  376. package/components/graph/svelvet/container/controllers/middleware.js +101 -0
  377. package/components/graph/svelvet/container/views/GraphView.svelte +252 -0
  378. package/components/graph/svelvet/container/views/GraphView.svelte.d.ts +25 -0
  379. package/components/graph/svelvet/container/views/Svelvet.svelte +131 -0
  380. package/components/graph/svelvet/container/views/Svelvet.svelte.d.ts +41 -0
  381. package/components/graph/svelvet/customCss/controllers/getCss.d.ts +2 -0
  382. package/components/graph/svelvet/customCss/controllers/getCss.js +57 -0
  383. package/components/graph/svelvet/d3/controllers/README.md +3 -0
  384. package/components/graph/svelvet/d3/controllers/d3.d.ts +5 -0
  385. package/components/graph/svelvet/d3/controllers/d3.js +59 -0
  386. package/components/graph/svelvet/d3/controllers/d3Old.d.ts +1 -0
  387. package/components/graph/svelvet/d3/controllers/d3Old.js +43 -0
  388. package/components/graph/svelvet/docs/CHANGELOG.md +145 -0
  389. package/components/graph/svelvet/docs/DESIGN_PATTERNS.md +44 -0
  390. package/components/graph/svelvet/docs/DOCUMENTATION.md +5 -0
  391. package/components/graph/svelvet/docs/README.md +34 -0
  392. package/components/graph/svelvet/docs/TODO.md +14 -0
  393. package/components/graph/svelvet/docs/Tutorials.md +25 -0
  394. package/components/graph/svelvet/docs/images/css-background-after.png +0 -0
  395. package/components/graph/svelvet/docs/images/css-background-before.png +0 -0
  396. package/components/graph/svelvet/docs/images/custom-edges-after.png +0 -0
  397. package/components/graph/svelvet/docs/images/custom-edges-before.png +0 -0
  398. package/components/graph/svelvet/docs/images/custom-nodes-after.png +0 -0
  399. package/components/graph/svelvet/docs/images/custom-nodes-before.png +0 -0
  400. package/components/graph/svelvet/docs/images/custom-svelte-components-after.png +0 -0
  401. package/components/graph/svelvet/docs/images/custom-svelte-components-before.png +0 -0
  402. package/components/graph/svelvet/docs/images/html-docs-after.png +0 -0
  403. package/components/graph/svelvet/docs/images/html-docs-before.png +0 -0
  404. package/components/graph/svelvet/docs/images/minimap-after.png +0 -0
  405. package/components/graph/svelvet/docs/images/minimap-before.png +0 -0
  406. package/components/graph/svelvet/docs/images/node-classes-after.png +0 -0
  407. package/components/graph/svelvet/docs/images/node-classes-before.png +0 -0
  408. package/components/graph/svelvet/docs/images/node-create-after.png +0 -0
  409. package/components/graph/svelvet/docs/images/node-create-before.png +0 -0
  410. package/components/graph/svelvet/edges/controllers/anchorCbDev.d.ts +4 -0
  411. package/components/graph/svelvet/edges/controllers/anchorCbDev.js +92 -0
  412. package/components/graph/svelvet/edges/controllers/anchorCbUser.d.ts +57 -0
  413. package/components/graph/svelvet/edges/controllers/anchorCbUser.js +73 -0
  414. package/components/graph/svelvet/edges/controllers/util.d.ts +37 -0
  415. package/components/graph/svelvet/edges/controllers/util.js +72 -0
  416. package/components/graph/svelvet/edges/models/Anchor.d.ts +48 -0
  417. package/components/graph/svelvet/edges/models/Anchor.js +122 -0
  418. package/components/graph/svelvet/edges/models/Edge.d.ts +47 -0
  419. package/components/graph/svelvet/edges/models/Edge.js +107 -0
  420. package/components/graph/svelvet/edges/types/types.d.ts +18 -0
  421. package/components/graph/svelvet/edges/types/types.js +1 -0
  422. package/components/graph/svelvet/edges/views/Edges/BaseEdge.svelte +105 -0
  423. package/components/graph/svelvet/edges/views/Edges/BaseEdge.svelte.d.ts +18 -0
  424. package/components/graph/svelvet/edges/views/Edges/EdgeAnchor.svelte +12 -0
  425. package/components/graph/svelvet/edges/views/Edges/EdgeAnchor.svelte.d.ts +17 -0
  426. package/components/graph/svelvet/edges/views/Edges/EdgeText.svelte +43 -0
  427. package/components/graph/svelvet/edges/views/Edges/EdgeText.svelte.d.ts +17 -0
  428. package/components/graph/svelvet/edges/views/Edges/SimpleBezierEdge.svelte +137 -0
  429. package/components/graph/svelvet/edges/views/Edges/SimpleBezierEdge.svelte.d.ts +17 -0
  430. package/components/graph/svelvet/edges/views/Edges/SmoothStepEdge.svelte +176 -0
  431. package/components/graph/svelvet/edges/views/Edges/SmoothStepEdge.svelte.d.ts +60 -0
  432. package/components/graph/svelvet/edges/views/Edges/StepEdge.svelte +8 -0
  433. package/components/graph/svelvet/edges/views/Edges/StepEdge.svelte.d.ts +25 -0
  434. package/components/graph/svelvet/edges/views/Edges/types.d.ts +52 -0
  435. package/components/graph/svelvet/edges/views/Edges/types.js +1 -0
  436. package/components/graph/svelvet/edges/views/Edges/utils.d.ts +33 -0
  437. package/components/graph/svelvet/edges/views/Edges/utils.js +31 -0
  438. package/components/graph/svelvet/editEdges/views/EditEdge.svelte +151 -0
  439. package/components/graph/svelvet/editEdges/views/EditEdge.svelte.d.ts +20 -0
  440. package/components/graph/svelvet/nodes/controllers/util.d.ts +9 -0
  441. package/components/graph/svelvet/nodes/controllers/util.js +13 -0
  442. package/components/graph/svelvet/nodes/models/Node.d.ts +78 -0
  443. package/components/graph/svelvet/nodes/models/Node.js +195 -0
  444. package/components/graph/svelvet/nodes/views/EditNode.svelte +147 -0
  445. package/components/graph/svelvet/nodes/views/EditNode.svelte.d.ts +33 -0
  446. package/components/graph/svelvet/nodes/views/Node.svelte +85 -0
  447. package/components/graph/svelvet/nodes/views/Node.svelte.d.ts +22 -0
  448. package/components/graph/svelvet/resizableNodes/controllers/util.d.ts +11 -0
  449. package/components/graph/svelvet/resizableNodes/controllers/util.js +24 -0
  450. package/components/graph/svelvet/resizableNodes/models/ResizeNode.d.ts +33 -0
  451. package/components/graph/svelvet/resizableNodes/models/ResizeNode.js +71 -0
  452. package/components/graph/svelvet/resizableNodes/views/ResizeNode.svelte +81 -0
  453. package/components/graph/svelvet/resizableNodes/views/ResizeNode.svelte.d.ts +20 -0
  454. package/components/graph/svelvet/store/controllers/storeApi.d.ts +32 -0
  455. package/components/graph/svelvet/store/controllers/storeApi.js +111 -0
  456. package/components/graph/svelvet/store/controllers/userApi.d.ts +3 -0
  457. package/components/graph/svelvet/store/controllers/userApi.js +18 -0
  458. package/components/graph/svelvet/store/controllers/util.d.ts +31 -0
  459. package/components/graph/svelvet/store/controllers/util.js +180 -0
  460. package/components/graph/svelvet/store/models/store.d.ts +12 -0
  461. package/components/graph/svelvet/store/models/store.js +9 -0
  462. package/components/graph/svelvet/store/types/types.d.ts +134 -0
  463. package/components/graph/svelvet/store/types/types.js +1 -0
  464. package/components/graph/svelvet/types/README.md +3 -0
  465. package/components/graph/svelvet/types/index.d.ts +2 -0
  466. package/components/graph/svelvet/types/index.js +1 -0
  467. package/components/graph/svelvet/types/types.d.ts +49 -0
  468. package/components/graph/svelvet/types/types.js +18 -0
  469. package/components/graph/util.js +2 -2
  470. package/components/home/ItemsList.svelte +53 -5
  471. package/components/home/ItemsList.svelte.d.ts +1 -0
  472. package/components/home/ListFilters.svelte +7 -2
  473. package/components/icons/SquareIcon.svelte +9 -0
  474. package/components/icons/SquareIcon.svelte.d.ts +17 -0
  475. package/components/icons/index.d.ts +2 -0
  476. package/components/icons/index.js +2 -0
  477. package/components/jobs/JobDetail.svelte +40 -5
  478. package/components/propertyPicker/ObjectViewer.svelte +14 -9
  479. package/components/propertyPicker/ObjectViewer.svelte.d.ts +1 -0
  480. package/components/propertyPicker/PropPicker.svelte +8 -1
  481. package/components/propertyPicker/PropPickerResult.svelte +1 -1
  482. package/components/random_positive_adjetive.d.ts +1 -0
  483. package/components/random_positive_adjetive.js +961 -0
  484. package/components/scriptEditor/LogPanel.svelte +2 -1
  485. package/components/sidebar/SidebarContent.svelte +1 -1
  486. package/components/sidebar/UserMenu.svelte +46 -16
  487. package/components/sidebar/UserMenu.svelte.d.ts +0 -3
  488. package/components/sidebar/WorkspaceMenu.svelte +3 -1
  489. package/components/sidebar/settings.d.ts +2 -0
  490. package/components/sidebar/settings.js +2 -0
  491. package/consts.d.ts +1 -0
  492. package/consts.js +1 -0
  493. package/defaults.d.ts +4 -0
  494. package/defaults.js +4 -0
  495. package/gen/core/OpenAPI.js +1 -1
  496. package/gen/models/CompletedJob.d.ts +1 -0
  497. package/gen/models/FlowModule.d.ts +0 -1
  498. package/gen/models/QueuedJob.d.ts +1 -0
  499. package/gen/models/WorkerPing.d.ts +1 -1
  500. package/gen/services/FlowService.d.ts +9 -0
  501. package/gen/services/FlowService.js +15 -0
  502. package/gen/services/JobService.d.ts +97 -15
  503. package/gen/services/JobService.js +74 -15
  504. package/gen/services/ScriptService.d.ts +10 -1
  505. package/gen/services/ScriptService.js +16 -1
  506. package/gen/services/VariableService.d.ts +4 -2
  507. package/gen/services/VariableService.js +8 -2
  508. package/gen/services/WorkspaceService.d.ts +17 -0
  509. package/gen/services/WorkspaceService.js +16 -0
  510. package/history.d.ts +9 -0
  511. package/history.js +56 -0
  512. package/infer.js +3 -0
  513. package/init_scripts/python_failure_module.py +10 -0
  514. package/init_scripts/python_init_code.py +37 -0
  515. package/init_scripts/python_init_code_clear.py +5 -0
  516. package/init_scripts/python_init_code_trigger.py +14 -0
  517. package/logout.js +2 -1
  518. package/package.json +661 -522
  519. package/script_helpers.d.ts +6 -5
  520. package/script_helpers.js +8 -73
  521. package/scripts.d.ts +1 -1
  522. package/scripts.js +8 -1
  523. package/stores.d.ts +5 -1
  524. package/stores.js +8 -1
  525. package/user.d.ts +1 -1
  526. package/user.js +14 -8
  527. package/utils.d.ts +10 -5
  528. package/utils.js +51 -14
  529. package/components/apps/components/DisplayComponent.svelte +0 -16
  530. package/components/apps/components/DisplayComponent.svelte.d.ts +0 -20
  531. package/components/apps/components/dataDisplay/AppHtml.svelte +0 -31
  532. package/components/apps/components/dateInputs/AppDateInput.svelte +0 -34
  533. package/components/apps/components/numberInputs/AppNumberInput.svelte +0 -33
  534. package/components/apps/components/numberInputs/AppSliderInputs.svelte +0 -37
  535. package/components/apps/components/selectInputs/AppSelect.svelte +0 -47
  536. package/components/apps/components/textInputs/AppTextInput.svelte +0 -31
  537. package/components/apps/editor/ComponentEditor.svelte +0 -145
  538. package/components/apps/editor/TablePanel.svelte +0 -17
  539. package/components/apps/editor/TablePanel.svelte.d.ts +0 -17
  540. package/components/apps/editor/componentsPanel/data.d.ts +0 -3
  541. package/components/apps/editor/componentsPanel/data.js +0 -499
  542. package/components/apps/editorUtils.d.ts +0 -1
  543. package/components/apps/editorUtils.js +0 -292
  544. package/components/flows/map/FlowBranchAllMap.svelte +0 -100
  545. package/components/flows/map/FlowBranchAllMap.svelte.d.ts +0 -17
  546. package/components/flows/map/FlowBranchOneMap.svelte +0 -124
  547. package/components/flows/map/FlowBranchOneMap.svelte.d.ts +0 -17
  548. /package/components/apps/components/{table → display/table}/tableOptions.d.ts +0 -0
  549. /package/components/apps/components/{table → display/table}/tableOptions.js +0 -0
@@ -1,66 +1,44 @@
1
1
  import type { Schema } from '../../common';
2
2
  import type { Preview } from '../../gen';
3
- import type { FilledItem } from 'svelte-grid';
3
+ import type { History } from '../../history';
4
+ import type { FilledItem } from '@windmill-labs/svelte-grid';
4
5
  import type { Writable } from 'svelte/store';
5
- import type { AppInput, ConnectedAppInput, ConnectedInput, EvalAppInput, RowAppInput, StaticAppInput, UserAppInput } from './inputType';
6
+ import type { AppComponent } from './editor/component/components';
7
+ import type { AppInput, ConnectedAppInput, ConnectedInput, EvalAppInput, RowAppInput, StaticAppInput, UploadAppInput, UserAppInput } from './inputType';
6
8
  import type { World } from './rx';
7
- type BaseComponent<T extends string> = {
8
- type: T;
9
- };
10
- export type TextComponent = BaseComponent<'textcomponent'>;
11
- export type TextInputComponent = BaseComponent<'textinputcomponent'>;
12
- export type PasswordInputComponent = BaseComponent<'passwordinputcomponent'>;
13
- export type DateInputComponent = BaseComponent<'dateinputcomponent'>;
14
- export type NumberInputComponent = BaseComponent<'numberinputcomponent'>;
15
- export type SliderComponent = BaseComponent<'slidercomponent'>;
16
- export type HtmlComponent = BaseComponent<'htmlcomponent'>;
17
- export type VegaLiteComponent = BaseComponent<'vegalitecomponent'>;
18
- export type TimeseriesComponent = BaseComponent<'timeseriescomponent'>;
19
- export type ButtonComponent = BaseComponent<'buttoncomponent'> & {
20
- recomputeIds: string[] | undefined;
21
- };
22
- export type FormComponent = BaseComponent<'formcomponent'> & {
23
- recomputeIds: string[] | undefined;
24
- };
25
- export type RunFormComponent = BaseComponent<'runformcomponent'>;
26
- export type BarChartComponent = BaseComponent<'barchartcomponent'>;
27
- export type PieChartComponent = BaseComponent<'piechartcomponent'>;
28
- export type ScatterChartComponent = BaseComponent<'scatterchartcomponent'>;
29
- export type TableComponent = BaseComponent<'tablecomponent'> & {
30
- actionButtons: (BaseAppComponent & ButtonComponent)[];
31
- };
32
- export type DisplayComponent = BaseComponent<'displaycomponent'>;
33
- export type ImageComponent = BaseComponent<'imagecomponent'>;
34
- export type InputComponent = BaseComponent<'inputcomponent'>;
35
- export type SelectComponent = BaseComponent<'selectcomponent'>;
36
- export type CheckboxComponent = BaseComponent<'checkboxcomponent'>;
37
- export type RadioComponent = BaseComponent<'radiocomponent'>;
38
9
  export type HorizontalAlignment = 'left' | 'center' | 'right';
39
10
  export type VerticalAlignment = 'top' | 'center' | 'bottom';
40
11
  export type Aligned = {
41
12
  horizontalAlignment: HorizontalAlignment;
42
13
  verticalAlignment: VerticalAlignment;
43
14
  };
15
+ export interface GeneralAppInput {
16
+ onlyStatic?: boolean;
17
+ evaluatedValue?: boolean;
18
+ tooltip?: string;
19
+ }
20
+ export type ComponentCssProperty = {
21
+ class?: string;
22
+ style?: string;
23
+ };
24
+ export type ComponentCustomCSS<T extends string = string> = Record<T, ComponentCssProperty>;
44
25
  export interface BaseAppComponent extends Partial<Aligned> {
45
26
  id: ComponentID;
46
27
  componentInput: AppInput | undefined;
47
- configuration: Record<string, (StaticAppInput | ConnectedAppInput | UserAppInput | RowAppInput | EvalAppInput) & {
48
- onlyStatic?: boolean;
49
- evaluatedValue?: boolean;
50
- tooltip?: string;
51
- }>;
28
+ configuration: Record<string, GeneralAppInput & (StaticAppInput | ConnectedAppInput | UserAppInput | RowAppInput | EvalAppInput | UploadAppInput)>;
52
29
  card: boolean | undefined;
30
+ customCss?: ComponentCustomCSS;
53
31
  /**
54
32
  * If `true` then the wrapper will allow items to flow outside of it's borders.
55
33
  *
56
34
  * *For example when the component has a popup like `Select`*
57
35
  */
58
36
  softWrap?: boolean;
37
+ numberOfSubgrids?: number;
59
38
  }
60
- export type AppComponent = BaseAppComponent & (RunFormComponent | DisplayComponent | TextInputComponent | PasswordInputComponent | DateInputComponent | NumberInputComponent | SliderComponent | BarChartComponent | TimeseriesComponent | HtmlComponent | TableComponent | TextComponent | TableComponent | ButtonComponent | PieChartComponent | ScatterChartComponent | ImageComponent | InputComponent | SelectComponent | CheckboxComponent | RadioComponent | FormComponent | VegaLiteComponent);
61
39
  export type ComponentSet = {
62
40
  title: string;
63
- components: AppComponent[];
41
+ components: Readonly<AppComponent['type'][]>;
64
42
  };
65
43
  type SectionID = string;
66
44
  export type AppSection = {
@@ -84,6 +62,13 @@ export type App = {
84
62
  name: string;
85
63
  inlineScript: InlineScript;
86
64
  }>;
65
+ hiddenInlineScripts: Array<{
66
+ name: string;
67
+ inlineScript: InlineScript | undefined;
68
+ fields: Record<string, StaticAppInput | ConnectedAppInput | RowAppInput | UserAppInput>;
69
+ }>;
70
+ css?: Record<'viewer' | 'grid' | AppComponent['type'], ComponentCustomCSS>;
71
+ subgrids?: Record<string, GridItem[]>;
87
72
  };
88
73
  export type ConnectingInput = {
89
74
  opened: boolean;
@@ -91,10 +76,9 @@ export type ConnectingInput = {
91
76
  sourceName?: string;
92
77
  hoveredComponent: string | undefined;
93
78
  };
94
- export type AppEditorContext = {
79
+ export type AppViewerContext = {
95
80
  worldStore: Writable<World | undefined>;
96
81
  staticOutputs: Writable<Record<string, string[]>>;
97
- lazyGrid: Writable<GridItem[]>;
98
82
  app: Writable<App>;
99
83
  summary: Writable<string>;
100
84
  selectedComponent: Writable<string | undefined>;
@@ -112,8 +96,29 @@ export type AppEditorContext = {
112
96
  component: string;
113
97
  }[]>;
114
98
  noBackend: boolean;
99
+ errorByComponent: Writable<Record<string, {
100
+ error: string;
101
+ componentId: string;
102
+ }>>;
103
+ openDebugRun: Writable<((componentID: string) => void) | undefined>;
104
+ focusedGrid: Writable<FocusedGrid | undefined>;
105
+ stateId: Writable<number>;
106
+ parentWidth: Writable<number>;
107
+ };
108
+ export type AppEditorContext = {
109
+ history: History<App> | undefined;
110
+ componentControl: Writable<Record<string, {
111
+ left?: () => boolean;
112
+ right?: () => boolean;
113
+ }>>;
114
+ pickVariableCallback: Writable<((path: string) => void) | undefined>;
115
+ };
116
+ export type FocusedGrid = {
117
+ parentComponentId: string;
118
+ subGridIndex: number;
115
119
  };
116
120
  export type EditorMode = 'dnd' | 'preview';
117
121
  export type EditorBreakpoint = 'sm' | 'lg';
122
+ export declare const IS_APP_PUBLIC_CONTEXT_KEY: "isAppPublicContext";
118
123
  type ComponentID = string;
119
124
  export {};
@@ -1 +1 @@
1
- export {};
1
+ export const IS_APP_PUBLIC_CONTEXT_KEY = 'isAppPublicContext';
@@ -1,13 +1,10 @@
1
1
  import type { Schema } from '../../common';
2
+ import type { App, ComponentCssProperty, ComponentCustomCSS, GridItem } from './types';
2
3
  import type { AppInput, InputType, ResultAppInput, StaticAppInput } from './inputType';
3
4
  import type { Output } from './rx';
4
- import type { App, AppComponent } from './types';
5
+ export declare function allItems(grid: GridItem[], subgrids: Record<string, GridItem[]> | undefined): GridItem[];
5
6
  export declare function loadSchema(workspace: string, path: string, runType: 'script' | 'flow' | 'hubscript'): Promise<Schema>;
6
7
  export declare function schemaToInputsSpec(schema: Schema, defaultUserInput: boolean): Record<string, StaticAppInput>;
7
- export declare const displayData: Record<AppComponent['type'], {
8
- name: string;
9
- icon: any;
10
- }>;
11
8
  export declare function accessPropertyByPath<T>(object: T, path: string): T | undefined;
12
9
  export declare function fieldTypeToTsType(inputType: InputType): string;
13
10
  export declare function isScriptByNameDefined(appInput: AppInput | undefined): boolean;
@@ -18,3 +15,7 @@ export declare function toStatic(app: App, staticExporter: Record<string, () =>
18
15
  summary: string;
19
16
  };
20
17
  export declare function buildExtraLib(components: Record<string, Record<string, Output<any>>>, idToExclude: string, hasRows: boolean): string;
18
+ export declare function getAllScriptNames(app: App): string[];
19
+ export declare function toPascalCase(text: string): string;
20
+ export declare function toKebabCase(text: string): string;
21
+ export declare function concatCustomCss<T extends string = string>(appCss?: ComponentCustomCSS<T>, componentCss?: ComponentCustomCSS<T>): Record<T, ComponentCssProperty> | undefined;
@@ -1,7 +1,13 @@
1
1
  import { FlowService, ScriptService } from '../../gen';
2
2
  import { inferArgs } from '../../infer';
3
3
  import { emptySchema } from '../../utils';
4
- import { BarChart4, Binary, CircleDot, FormInput, Inspect, List, Monitor, PieChart, Play, Table2, Image, TextCursorInput, Type, Lock, Calendar, ToggleLeft, GripHorizontal, Code2, SlidersHorizontal } from 'lucide-svelte';
4
+ import { twMerge } from 'tailwind-merge';
5
+ export function allItems(grid, subgrids) {
6
+ if (subgrids == undefined) {
7
+ return grid;
8
+ }
9
+ return [...grid, ...Object.values(subgrids).flat()];
10
+ }
5
11
  export async function loadSchema(workspace, path, runType) {
6
12
  if (runType === 'script') {
7
13
  const script = await ScriptService.getScriptByPath({
@@ -21,7 +27,9 @@ export async function loadSchema(workspace, path, runType) {
21
27
  const script = await ScriptService.getHubScriptByPath({
22
28
  path
23
29
  });
24
- if (script.schema == undefined || Object.keys(script.schema).length == 0 || typeof script.schema != 'object') {
30
+ if (script.schema == undefined ||
31
+ Object.keys(script.schema).length == 0 ||
32
+ typeof script.schema != 'object') {
25
33
  script.schema = emptySchema();
26
34
  }
27
35
  await inferArgs(script.language, script.content, script.schema);
@@ -43,96 +51,6 @@ export function schemaToInputsSpec(schema, defaultUserInput) {
43
51
  return accu;
44
52
  }, {});
45
53
  }
46
- export const displayData = {
47
- displaycomponent: {
48
- name: 'Result',
49
- icon: Monitor
50
- },
51
- textcomponent: {
52
- name: 'Text',
53
- icon: Type
54
- },
55
- buttoncomponent: {
56
- name: 'Button',
57
- icon: Inspect
58
- },
59
- formcomponent: {
60
- name: 'Form',
61
- icon: FormInput
62
- },
63
- piechartcomponent: {
64
- name: 'Pie Chart',
65
- icon: PieChart
66
- },
67
- barchartcomponent: {
68
- name: 'Bar/Line Chart',
69
- icon: BarChart4
70
- },
71
- htmlcomponent: {
72
- name: 'Html',
73
- icon: Code2
74
- },
75
- vegalitecomponent: {
76
- name: 'Vega Lite',
77
- icon: PieChart
78
- },
79
- timeseriescomponent: {
80
- name: 'Timeseries',
81
- icon: GripHorizontal
82
- },
83
- scatterchartcomponent: {
84
- name: 'Scatter Chart',
85
- icon: GripHorizontal
86
- },
87
- tablecomponent: {
88
- name: 'Table',
89
- icon: Table2
90
- },
91
- checkboxcomponent: {
92
- name: 'Toggle',
93
- icon: ToggleLeft
94
- },
95
- textinputcomponent: {
96
- name: 'Text input',
97
- icon: TextCursorInput
98
- },
99
- imagecomponent: {
100
- name: 'Image',
101
- icon: Image
102
- },
103
- inputcomponent: {
104
- name: 'Input',
105
- icon: FormInput
106
- },
107
- radiocomponent: {
108
- name: 'Radio button',
109
- icon: CircleDot
110
- },
111
- runformcomponent: {
112
- name: 'Run form',
113
- icon: Play
114
- },
115
- selectcomponent: {
116
- name: 'Select',
117
- icon: List
118
- },
119
- numberinputcomponent: {
120
- name: 'Number',
121
- icon: Binary
122
- },
123
- slidercomponent: {
124
- name: 'Slider',
125
- icon: SlidersHorizontal
126
- },
127
- passwordinputcomponent: {
128
- name: 'Password',
129
- icon: Lock
130
- },
131
- dateinputcomponent: {
132
- name: 'Date input',
133
- icon: Calendar
134
- }
135
- };
136
54
  export function accessPropertyByPath(object, path) {
137
55
  // convert indexes to properties
138
56
  path = path.replace(/\[(\w+)\]/g, '.$1');
@@ -141,7 +59,7 @@ export function accessPropertyByPath(object, path) {
141
59
  let a = path.split('.');
142
60
  for (let i = 0, depth = a.length; i < depth; ++i) {
143
61
  let key = a[i];
144
- if (object[key]) {
62
+ if (object[key] != undefined) {
145
63
  object = object[key];
146
64
  }
147
65
  else {
@@ -203,7 +121,7 @@ export function toStatic(app, staticExporter, summary) {
203
121
  return { app: newApp, summary };
204
122
  }
205
123
  export function buildExtraLib(components, idToExclude, hasRows) {
206
- return Object.entries(components)
124
+ return (Object.entries(components)
207
125
  .filter(([k, v]) => k != idToExclude)
208
126
  .map(([k, v]) => [k, Object.fromEntries(Object.entries(v).map(([k, v]) => [k, v.peak()]))])
209
127
  .map(([k, v]) => `
@@ -211,5 +129,55 @@ export function buildExtraLib(components, idToExclude, hasRows) {
211
129
  declare const ${k} = ${JSON.stringify(v)};
212
130
 
213
131
  `)
214
- .join('\n') + (hasRows ? 'declare const row: Record<string, any>;' : '');
132
+ .join('\n') + (hasRows ? 'declare const row: Record<string, any>;' : ''));
133
+ }
134
+ export function getAllScriptNames(app) {
135
+ const names = app.grid.reduce((acc, gridItem) => {
136
+ const { componentInput } = gridItem.data;
137
+ if (componentInput?.type === 'runnable' &&
138
+ componentInput?.runnable?.type === 'runnableByName') {
139
+ acc.push(componentInput.runnable.name);
140
+ }
141
+ if (componentInput?.type === 'tablecomponent') {
142
+ componentInput.actionButtons.forEach((actionButton) => {
143
+ if (actionButton.componentInput?.type === 'runnable') {
144
+ if (actionButton.componentInput.runnable?.type === 'runnableByName') {
145
+ acc.push(actionButton.componentInput.runnable.name);
146
+ }
147
+ }
148
+ });
149
+ }
150
+ return acc;
151
+ }, []);
152
+ const unusedNames = app.unusedInlineScripts.map((x) => x.name);
153
+ const backgroundNames = app.hiddenInlineScripts?.map((x) => x.name) ?? [];
154
+ return [...names, ...unusedNames, ...backgroundNames];
155
+ }
156
+ function clearAndUpper(text) {
157
+ return text.replace(/-/, '').toUpperCase();
158
+ }
159
+ export function toPascalCase(text) {
160
+ return text.replace(/(^\w|-\w)/g, clearAndUpper);
161
+ }
162
+ export function toKebabCase(text) {
163
+ return text.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();
164
+ }
165
+ export function concatCustomCss(appCss, componentCss) {
166
+ if (!componentCss)
167
+ return undefined;
168
+ const customStyle = {};
169
+ Object.keys(componentCss).forEach((key) => {
170
+ const k = key;
171
+ // This is the general style of the component type
172
+ const appStyle = appCss?.[k]?.style?.trim() || '';
173
+ const appEnding = appStyle?.endsWith(';') || !appStyle ? ' ' : '; ';
174
+ // This is the custom style of the component instance
175
+ const compStyle = componentCss[k]?.style?.trim() || '';
176
+ const compEnding = compStyle?.endsWith(';') || !compStyle ? ' ' : ';';
177
+ customStyle[k] = {
178
+ style: (appStyle + appEnding + compStyle + compEnding).trim(),
179
+ class: twMerge(appCss?.[k]?.class, componentCss[k]?.class)
180
+ };
181
+ });
182
+ return customStyle;
215
183
  }
@@ -1,9 +1,9 @@
1
1
  <script>import { createEventDispatcher } from 'svelte';
2
- import { classNames } from '../../../utils';
3
2
  import Icon from 'svelte-awesome';
4
3
  import { ButtonType } from './model';
5
4
  import { goto } from '$app/navigation';
6
5
  import { Loader2 } from 'lucide-svelte';
6
+ import { twMerge } from 'tailwind-merge';
7
7
  export let size = 'md';
8
8
  export let spacingSize = size;
9
9
  export let color = 'blue';
@@ -21,9 +21,14 @@ export let nonCaptureEvent = false;
21
21
  export let buttonType = 'button';
22
22
  export let loading = false;
23
23
  export let title = undefined;
24
+ export let style = '';
24
25
  const dispatch = createEventDispatcher();
25
26
  // Order of classes: border, border modifier, bg, bg modifier, text, text modifier, everything else
26
27
  const colorVariants = {
28
+ none: {
29
+ border: '',
30
+ contained: ''
31
+ },
27
32
  blue: {
28
33
  border: 'border-frost-500 hover:border-frost-700 focus:border-frost-700 bg-white hover:bg-frost-100 focus:bg-frost-100 text-frost-500 hover:text-frost-700 focus:text-frost-700 focus:ring-frost-300',
29
34
  contained: 'bg-frost-500 hover:bg-frost-700 focus:bg-frost-700 text-white focus:ring-frost-300'
@@ -51,12 +56,13 @@ const colorVariants = {
51
56
  };
52
57
  $: buttonProps = {
53
58
  id,
54
- class: classNames(colorVariants?.[color]?.[variant], variant === 'border' ? 'border' : '', ButtonType.FontSizeClasses[size], ButtonType.SpacingClasses[spacingSize], 'focus:ring-2 font-semibold', 'duration-200 rounded-md', 'justify-center items-center text-center whitespace-nowrap inline-flex', btnClasses, disabled ? '!bg-gray-300 !text-gray-600 !cursor-not-allowed' : ''),
59
+ class: twMerge(colorVariants?.[color]?.[variant], variant === 'border' ? 'border' : '', ButtonType.FontSizeClasses[size], ButtonType.SpacingClasses[spacingSize][variant], 'focus:ring-2 font-semibold', 'rounded-md', 'justify-center items-center text-center whitespace-nowrap inline-flex', btnClasses, disabled ? '!bg-gray-300 !text-gray-600 !cursor-not-allowed' : ''),
55
60
  href,
56
61
  target,
57
62
  tabindex: disabled ? -1 : 0,
58
63
  type: buttonType,
59
- title
64
+ title,
65
+ ...$$restProps
60
66
  };
61
67
  async function onClick(event) {
62
68
  if (!nonCaptureEvent) {
@@ -76,8 +82,8 @@ async function onClick(event) {
76
82
  }
77
83
  }
78
84
  $: isSmall = size === 'xs' || size === 'sm';
79
- $: startIconClass = classNames(iconOnly ? undefined : isSmall ? 'mr-1' : 'mr-2', startIcon?.classes);
80
- $: endIconClass = classNames(iconOnly ? undefined : isSmall ? 'ml-1' : 'ml-2', endIcon?.classes);
85
+ $: startIconClass = twMerge(iconOnly ? undefined : isSmall ? 'mr-1' : 'mr-2', startIcon?.classes);
86
+ $: endIconClass = twMerge(iconOnly ? undefined : isSmall ? 'ml-1' : 'ml-2', endIcon?.classes);
81
87
  </script>
82
88
 
83
89
  <svelte:element
@@ -90,6 +96,7 @@ $: endIconClass = classNames(iconOnly ? undefined : isSmall ? 'ml-1' : 'ml-2', e
90
96
  {...buttonProps}
91
97
  disabled={disabled || loading}
92
98
  type="submit"
99
+ {style}
93
100
  >
94
101
  {#if loading}
95
102
  <Loader2 class="animate-spin mr-1" size={14} />
@@ -3,9 +3,10 @@ import Icon from 'svelte-awesome';
3
3
  import { ButtonType } from './model';
4
4
  declare const __propDef: {
5
5
  props: {
6
+ [x: string]: any;
6
7
  size?: ButtonType.Size | undefined;
7
8
  spacingSize?: ButtonType.Size | undefined;
8
- color?: "blue" | "gray" | "red" | "green" | "dark" | "light" | undefined;
9
+ color?: "none" | "blue" | "gray" | "red" | "green" | "dark" | "light" | undefined;
9
10
  variant?: ButtonType.Variant | undefined;
10
11
  btnClasses?: string | undefined;
11
12
  disabled?: boolean | undefined;
@@ -20,6 +21,7 @@ declare const __propDef: {
20
21
  buttonType?: "reset" | "submit" | "button" | undefined;
21
22
  loading?: boolean | undefined;
22
23
  title?: string | undefined;
24
+ style?: string | undefined;
23
25
  };
24
26
  events: {
25
27
  pointerdown: PointerEvent;
@@ -13,6 +13,7 @@ export let target = '_self';
13
13
  export let startIcon = undefined;
14
14
  export let endIcon = undefined;
15
15
  export let spacingSize = size;
16
+ export let loading = false;
16
17
  let ref;
17
18
  setContext(ButtonType.ItemContextKey, { size, color });
18
19
  $: separator = color === 'red' || color === 'blue' ? 'border-gray-200' : 'border-gray-400';
@@ -28,6 +29,7 @@ $: commonProps = {
28
29
  <div class="flex justy-start items-center">
29
30
  {#if $$slots.main}
30
31
  <Button
32
+ {loading}
31
33
  {...commonProps}
32
34
  {href}
33
35
  {target}
@@ -4,7 +4,7 @@ import { ButtonType } from '..';
4
4
  declare const __propDef: {
5
5
  props: {
6
6
  size?: ButtonType.Size | undefined;
7
- color?: "blue" | "gray" | "red" | "green" | "dark" | "light" | undefined;
7
+ color?: "none" | "blue" | "gray" | "red" | "green" | "dark" | "light" | undefined;
8
8
  variant?: ButtonType.Variant | undefined;
9
9
  mainClasses?: string | undefined;
10
10
  toggleClasses?: string | undefined;
@@ -14,6 +14,7 @@ declare const __propDef: {
14
14
  startIcon?: ButtonType.Icon | undefined;
15
15
  endIcon?: ButtonType.Icon | undefined;
16
16
  spacingSize?: ButtonType.Size | undefined;
17
+ loading?: boolean | undefined;
17
18
  };
18
19
  events: {
19
20
  click: CustomEvent<any>;
@@ -0,0 +1,32 @@
1
+ <script>import { Redo, Undo } from 'lucide-svelte';
2
+ import { createEventDispatcher } from 'svelte';
3
+ import { Button } from '..';
4
+ export let undoProps = {};
5
+ export let redoProps = {};
6
+ const dispatch = createEventDispatcher();
7
+ </script>
8
+
9
+ <div class="flex">
10
+ <Button
11
+ title="Undo"
12
+ variant="border"
13
+ color="light"
14
+ size="xs"
15
+ btnClasses="!min-h-[30px] !rounded-r-none"
16
+ on:click={() => dispatch('undo')}
17
+ {...undoProps}
18
+ >
19
+ <Undo size={14} />
20
+ </Button>
21
+ <Button
22
+ title="Redo"
23
+ variant="border"
24
+ color="light"
25
+ size="xs"
26
+ btnClasses="!min-h-[30px] !rounded-l-none !border-l-0"
27
+ on:click={() => dispatch('redo')}
28
+ {...redoProps}
29
+ >
30
+ <Redo size={14} />
31
+ </Button>
32
+ </div>
@@ -0,0 +1,20 @@
1
+ import { SvelteComponentTyped } from "svelte";
2
+ declare const __propDef: {
3
+ props: {
4
+ undoProps?: Record<string, any> | undefined;
5
+ redoProps?: Record<string, any> | undefined;
6
+ };
7
+ events: {
8
+ undo: CustomEvent<any>;
9
+ redo: CustomEvent<any>;
10
+ } & {
11
+ [evt: string]: CustomEvent<any>;
12
+ };
13
+ slots: {};
14
+ };
15
+ export type UndoRedoProps = typeof __propDef.props;
16
+ export type UndoRedoEvents = typeof __propDef.events;
17
+ export type UndoRedoSlots = typeof __propDef.slots;
18
+ export default class UndoRedo extends SvelteComponentTyped<UndoRedoProps, UndoRedoEvents, UndoRedoSlots> {
19
+ }
20
+ export {};
@@ -1,4 +1,4 @@
1
- export declare const BUTTON_COLORS: readonly ["blue", "red", "dark", "light", "green", "gray"];
1
+ export declare const BUTTON_COLORS: readonly ["blue", "red", "dark", "light", "green", "gray", "none"];
2
2
  export declare namespace ButtonType {
3
3
  type Size = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
4
4
  type Color = typeof BUTTON_COLORS[number];
@@ -10,7 +10,7 @@ export declare namespace ButtonType {
10
10
  classes?: string;
11
11
  }
12
12
  const FontSizeClasses: Record<ButtonType.Size, string>;
13
- const SpacingClasses: Record<ButtonType.Size, string>;
13
+ const SpacingClasses: Record<ButtonType.Size, Record<ButtonType.Variant, string>>;
14
14
  const IconScale: Record<ButtonType.Size, number>;
15
15
  const ItemContextKey: "popupItemProps";
16
16
  interface ItemProps {
@@ -1,4 +1,4 @@
1
- export const BUTTON_COLORS = ['blue', 'red', 'dark', 'light', 'green', 'gray'];
1
+ export const BUTTON_COLORS = ['blue', 'red', 'dark', 'light', 'green', 'gray', 'none'];
2
2
  export var ButtonType;
3
3
  (function (ButtonType) {
4
4
  ButtonType.FontSizeClasses = {
@@ -9,11 +9,26 @@ export var ButtonType;
9
9
  xl: 'text-xl'
10
10
  };
11
11
  ButtonType.SpacingClasses = {
12
- xs: 'px-3 py-1.5',
13
- sm: 'px-3 py-1.5',
14
- md: 'px-3 py-1.5',
15
- lg: 'px-4 py-2',
16
- xl: 'px-4 py-2'
12
+ xs: {
13
+ border: 'px-3 py-[6px]',
14
+ contained: 'px-3 py-[7px]'
15
+ },
16
+ sm: {
17
+ border: 'px-3 py-[6px]',
18
+ contained: 'px-3 py-[7px]'
19
+ },
20
+ md: {
21
+ border: 'px-3 py-[6px]',
22
+ contained: 'px-3 py-[7px]'
23
+ },
24
+ lg: {
25
+ border: 'px-4 py-[8px]',
26
+ contained: 'px-4 py-[9px]'
27
+ },
28
+ xl: {
29
+ border: 'px-4 py-[8px]',
30
+ contained: 'px-4 py-[9px]'
31
+ },
17
32
  };
18
33
  ButtonType.IconScale = {
19
34
  xs: 0.7,
@@ -23,12 +23,19 @@ function onKeyDown(event) {
23
23
  }
24
24
  }
25
25
  }
26
+ function fadeFast(node) {
27
+ return fade(node, { duration: 100 });
28
+ }
26
29
  </script>
27
30
 
28
31
  <svelte:window on:keydown={onKeyDown} />
29
32
 
30
33
  {#if open}
31
- <div transition:fade={{ duration: 100 }} class={'relative z-50'} role="dialog">
34
+ <div
35
+ transition:fadeFast|local
36
+ class={'absolute top-0 bottom-0 left-0 right-0 z-50'}
37
+ role="dialog"
38
+ >
32
39
  <div
33
40
  class={classNames(
34
41
  'fixed inset-0 bg-gray-500 bg-opacity-75 transition-opacity',
@@ -41,9 +41,9 @@ onDestroy(() => {
41
41
  }}
42
42
  >
43
43
  <div class="flex flex-col w-full space-y-4">
44
- <span
45
- >Are you sure you want to discard change you have made? (A draft has been temporarily and
46
- locally saved)</span
47
- >
44
+ <span>
45
+ Are you sure you want to discard change you have made? (A draft has been temporarily and
46
+ locally saved)
47
+ </span>
48
48
  </div>
49
49
  </ConfirmationModal>
@@ -42,8 +42,10 @@ function onKeyDown(event) {
42
42
  if (open) {
43
43
  switch (event.key) {
44
44
  case 'Escape':
45
- open = false;
46
45
  event.preventDefault();
46
+ event.stopPropagation();
47
+ event.stopImmediatePropagation();
48
+ open = false;
47
49
  break;
48
50
  }
49
51
  }
@@ -59,11 +61,17 @@ onMount(() => {
59
61
 
60
62
  <svelte:window on:keydown={onKeyDown} />
61
63
 
62
- <aside class="drawer {$$props.class}" class:open class:close={!open && timeout} {style}>
63
- <div class="overlay" on:click={handleClickAway} />
64
- <div class="panel {placement}" class:size>
64
+ <aside
65
+ class="drawer {$$props.class} {$$props.positionClass}"
66
+ class:open
67
+ class:close={!open && timeout}
68
+ {style}
69
+ >
70
+ <!-- svelte-ignore a11y-click-events-have-key-events -->
71
+ <div class="overlay {$$props.positionClass}" on:click={handleClickAway} />
72
+ <div class="panel {placement} {$$props.positionClass}" class:size>
65
73
  {#if open || !timeout || alwaysOpen}
66
- <slot />
74
+ <slot {open} />
67
75
  {/if}
68
76
  </div>
69
77
  </aside>
@@ -20,7 +20,9 @@ declare const __propDef: {
20
20
  [evt: string]: CustomEvent<any>;
21
21
  };
22
22
  slots: {
23
- default: {};
23
+ default: {
24
+ open: boolean;
25
+ };
24
26
  };
25
27
  };
26
28
  export type DrawerProps = typeof __propDef.props;