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
@@ -0,0 +1,188 @@
1
+ <script>import { onMount, getContext } from 'svelte';
2
+ import { LayoutDashboardIcon, MousePointer2, CurlyBraces } from 'lucide-svelte';
3
+ import SimpleEditor from '../../../SimpleEditor.svelte';
4
+ import { emptyString } from '../../../../utils';
5
+ import { Tab, TabContent, Tabs } from '../../../common';
6
+ import ListItem from './ListItem.svelte';
7
+ import { isOpenStore } from './store';
8
+ import CssProperty from './CssProperty.svelte';
9
+ import { components } from '../component';
10
+ import { slide } from 'svelte/transition';
11
+ const STATIC_ELEMENTS = ['app'];
12
+ const TITLE_PREFIX = 'Css.';
13
+ const SHOW_UNUSED_ID = 'Setting.ShowUnused';
14
+ const { app } = getContext('AppViewerContext');
15
+ let rawCode = '';
16
+ let viewJsonSchema = false;
17
+ $: rawCode && parseJson();
18
+ let jsonError = '';
19
+ function parseJson() {
20
+ try {
21
+ $app.css = JSON.parse(rawCode ?? '');
22
+ jsonError = '';
23
+ }
24
+ catch (e) {
25
+ jsonError = e.message;
26
+ }
27
+ }
28
+ function switchTab(asJson) {
29
+ viewJsonSchema = asJson;
30
+ if (asJson) {
31
+ rawCode = JSON.stringify($app.css, null, 2);
32
+ }
33
+ else {
34
+ parseJson();
35
+ }
36
+ }
37
+ const entries = [
38
+ {
39
+ type: 'app',
40
+ name: 'App',
41
+ icon: LayoutDashboardIcon,
42
+ ids: ['viewer', 'grid', 'component']
43
+ },
44
+ ...Object.values(components).map(({ name, icon, data: { type, customCss } }) => ({
45
+ type,
46
+ name,
47
+ icon,
48
+ ids: Object.keys(customCss ?? {}) ?? []
49
+ }))
50
+ ];
51
+ let isCustom = Object.fromEntries(Object.keys(entries).map((k) => [k, false]));
52
+ let newCss = $app.css ?? {};
53
+ entries.forEach((e) => {
54
+ if (!newCss[e.type]) {
55
+ isCustom[e.type] = true;
56
+ newCss[e.type] = {};
57
+ }
58
+ e.ids.forEach((id) => {
59
+ if (!newCss[e.type][id]) {
60
+ newCss[e.type][id] = components?.[e.type]?.data?.customCss?.[id] ?? { class: '', style: '' };
61
+ }
62
+ });
63
+ e.ids
64
+ .map((id) => newCss[e.type][id].class != '' || newCss[e.type][id].style != '')
65
+ .forEach((c) => {
66
+ if (c) {
67
+ isCustom[e.type] = true;
68
+ }
69
+ });
70
+ });
71
+ //@ts-ignore
72
+ $app.css = newCss;
73
+ $: staticComponents = entries.filter(({ type }) => STATIC_ELEMENTS.includes(type));
74
+ $: usedComponents = Object.keys($app.grid.reduce((acc, { data }) => {
75
+ acc[data.type] = true;
76
+ return acc;
77
+ }, {}))
78
+ .map((type) => entries.find((entry) => entry.type === type))
79
+ .filter(Boolean);
80
+ $: unusedComponents = entries.filter(({ type }) => {
81
+ return (!STATIC_ELEMENTS.includes(type) && !usedComponents.find((entry) => entry.type === type));
82
+ });
83
+ onMount(() => {
84
+ isOpenStore.addItems([{ name: 'App' }, ...Object.values(components)].map((component) => {
85
+ return { [TITLE_PREFIX + component.name]: false };
86
+ }));
87
+ isOpenStore.addItems([{ [SHOW_UNUSED_ID]: false }]);
88
+ });
89
+ </script>
90
+
91
+ <Tabs selected="ui" on:selected={(e) => switchTab(e.detail === 'json')} class="relative">
92
+ <Tab value="ui" size="xs" class="grow">
93
+ <div class="m-1 center-center">
94
+ <MousePointer2 size={16} />
95
+ <span class="pl-1">UI</span>
96
+ </div>
97
+ </Tab>
98
+ <Tab value="json" size="xs" class="grow">
99
+ <div class="m-1 center-center">
100
+ <CurlyBraces size={16} />
101
+ <span class="pl-1">JSON</span>
102
+ </div>
103
+ </Tab>
104
+ <div slot="content" class="h-full overflow-y-auto">
105
+ <TabContent value="ui">
106
+ {#each [...staticComponents, ...usedComponents] as { type, name, icon, ids }}
107
+ {#if ids.length > 0}
108
+ <ListItem title={name} prefix={TITLE_PREFIX}>
109
+ <div slot="title" class="flex items-center">
110
+ <svelte:component this={icon} size={18} />
111
+ <span class="ml-1">
112
+ {name}
113
+ </span>
114
+ </div>
115
+ <div class="pb-2">
116
+ {#each ids as id}
117
+ <div class="mb-3">
118
+ {#if $app?.css?.[type][id]}
119
+ <CssProperty
120
+ name={id}
121
+ bind:value={$app.css[type][id]}
122
+ on:focus={() => (isCustom[type] = true)}
123
+ />
124
+ {/if}
125
+ </div>
126
+ {/each}
127
+ </div>
128
+ </ListItem>
129
+ {/if}
130
+ {/each}
131
+ <div class="px-1 my-4">
132
+ <button
133
+ on:click|preventDefault|stopPropagation={() => isOpenStore.toggle(SHOW_UNUSED_ID)}
134
+ class="w-full text-xs text-gray-500 text-center font-medium hover:underline p-2"
135
+ >
136
+ {$isOpenStore[SHOW_UNUSED_ID] ? 'Hide' : 'Show'} unused components
137
+ </button>
138
+ </div>
139
+ {#if $isOpenStore[SHOW_UNUSED_ID]}
140
+ <div transition:slide|local={{ duration: 300 }}>
141
+ {#each unusedComponents as { type, name, icon, ids }}
142
+ {#if ids.length > 0}
143
+ <ListItem title={name} prefix={TITLE_PREFIX}>
144
+ <div slot="title" class="flex items-center">
145
+ <svelte:component this={icon} size={18} />
146
+ <span class="ml-1">
147
+ {name}
148
+ </span>
149
+ </div>
150
+ <div class="pb-2">
151
+ {#each ids as id}
152
+ <div class="mb-3">
153
+ {#if $app?.css?.[type][id]}
154
+ <CssProperty
155
+ name={id}
156
+ bind:value={$app.css[type][id]}
157
+ on:focus={() => (isCustom[type] = true)}
158
+ />
159
+ {/if}
160
+ </div>
161
+ {/each}
162
+ </div>
163
+ </ListItem>
164
+ {/if}
165
+ {/each}
166
+ </div>
167
+ {/if}
168
+ </TabContent>
169
+ <TabContent value="json">
170
+ {#if !emptyString(jsonError)}
171
+ <span class="text-red-400 text-xs mb-1 flex flex-row-reverse">
172
+ {jsonError}
173
+ </span>
174
+ {:else}
175
+ <div class="py-2" />
176
+ {/if}
177
+ <div class="h-full w-full py-1">
178
+ <SimpleEditor
179
+ autoHeight
180
+ class="editor"
181
+ lang="json"
182
+ bind:code={rawCode}
183
+ fixedOverflowWidgets={false}
184
+ />
185
+ </div>
186
+ </TabContent>
187
+ </div>
188
+ </Tabs>
@@ -0,0 +1,14 @@
1
+ import { SvelteComponentTyped } from "svelte";
2
+ declare const __propDef: {
3
+ props: Record<string, never>;
4
+ events: {
5
+ [evt: string]: CustomEvent<any>;
6
+ };
7
+ slots: {};
8
+ };
9
+ export type CssSettingsProps = typeof __propDef.props;
10
+ export type CssSettingsEvents = typeof __propDef.events;
11
+ export type CssSettingsSlots = typeof __propDef.slots;
12
+ export default class CssSettings extends SvelteComponentTyped<CssSettingsProps, CssSettingsEvents, CssSettingsSlots> {
13
+ }
14
+ export {};
@@ -0,0 +1,39 @@
1
+ <script>import { slide } from 'svelte/transition';
2
+ import { ChevronDown } from 'lucide-svelte';
3
+ import { isOpenStore } from './store';
4
+ export let title;
5
+ export let prefix = undefined;
6
+ $: storeTitle = prefix + title;
7
+ $: isOpen = prefix ? $isOpenStore[storeTitle] : true;
8
+ </script>
9
+
10
+ <section class="pt-1 pb-2 px-1">
11
+ {#if prefix !== undefined}
12
+ <button
13
+ on:click|preventDefault={() => isOpenStore.toggle(storeTitle)}
14
+ class="w-full flex justify-between items-center text-gray-700 px-2 py-1
15
+ rounded-sm duration-200 hover:bg-gray-100"
16
+ >
17
+ <h1 class="text-sm font-semibold text-left">
18
+ <slot name="title">
19
+ {title}
20
+ </slot>
21
+ </h1>
22
+ <ChevronDown class="rotate-0 duration-300 {isOpen ? '!rotate-180' : ''}" />
23
+ </button>
24
+ {#if isOpen}
25
+ <div transition:slide|local={{ duration: 300 }} class="px-2">
26
+ <slot />
27
+ </div>
28
+ {/if}
29
+ {:else}
30
+ <h1 class="text-sm font-semibold text-left px-2 py-1">
31
+ <slot name="title">
32
+ {title}
33
+ </slot>
34
+ </h1>
35
+ <div class="px-2">
36
+ <slot />
37
+ </div>
38
+ {/if}
39
+ </section>
@@ -0,0 +1,20 @@
1
+ import { SvelteComponentTyped } from "svelte";
2
+ declare const __propDef: {
3
+ props: {
4
+ title: string;
5
+ prefix?: string | undefined;
6
+ };
7
+ events: {
8
+ [evt: string]: CustomEvent<any>;
9
+ };
10
+ slots: {
11
+ title: {};
12
+ default: {};
13
+ };
14
+ };
15
+ export type ListItemProps = typeof __propDef.props;
16
+ export type ListItemEvents = typeof __propDef.events;
17
+ export type ListItemSlots = typeof __propDef.slots;
18
+ export default class ListItem extends SvelteComponentTyped<ListItemProps, ListItemEvents, ListItemSlots> {
19
+ }
20
+ export {};
@@ -1,7 +1,11 @@
1
1
  export declare const staticValues: {
2
- readonly buttonColorOptions: ("blue" | "gray" | "red" | "green" | "dark" | "light")[];
2
+ readonly buttonColorOptions: ("none" | "blue" | "gray" | "red" | "green" | "dark" | "light")[];
3
3
  readonly buttonSizeOptions: readonly ["xs", "sm", "md", "lg", "xl"];
4
4
  readonly tableSearchOptions: readonly ["By Component", "By Runnable", "Disabled"];
5
5
  readonly chartThemeOptions: readonly ["theme1", "theme2", "theme3"];
6
6
  readonly textStyleOptions: readonly ["Title", "Subtitle", "Body", "Label", "Caption"];
7
+ readonly currencyOptions: readonly ["USD", "EUR", "GBP", "CAD", "AUD", "JPY", "CNY", "INR", "BRL"];
8
+ readonly localeOptions: readonly ["en-US", "en-GB", "en-IE", "de-DE", "fr-FR", "br-FR", "ja-JP", "pt-TL", "fr-CA", "en-CA"];
9
+ readonly objectFitOptions: readonly ["contain", "cover", "fill"];
10
+ readonly splitPanelOptions: readonly ["2", "3", "4"];
7
11
  };
@@ -5,5 +5,20 @@ export const staticValues = {
5
5
  buttonSizeOptions: ['xs', 'sm', 'md', 'lg', 'xl'],
6
6
  tableSearchOptions: ['By Component', 'By Runnable', 'Disabled'],
7
7
  chartThemeOptions: ['theme1', 'theme2', 'theme3'],
8
- textStyleOptions: ['Title', 'Subtitle', 'Body', 'Label', 'Caption']
8
+ textStyleOptions: ['Title', 'Subtitle', 'Body', 'Label', 'Caption'],
9
+ currencyOptions: ['USD', 'EUR', 'GBP', 'CAD', 'AUD', 'JPY', 'CNY', 'INR', 'BRL'],
10
+ localeOptions: [
11
+ 'en-US',
12
+ 'en-GB',
13
+ 'en-IE',
14
+ 'de-DE',
15
+ 'fr-FR',
16
+ 'br-FR',
17
+ 'ja-JP',
18
+ 'pt-TL',
19
+ 'fr-CA',
20
+ 'en-CA'
21
+ ],
22
+ objectFitOptions: ['contain', 'cover', 'fill'],
23
+ splitPanelOptions: ['2', '3', '4']
9
24
  };
@@ -2,7 +2,7 @@
2
2
  import { getContext } from 'svelte';
3
3
  export let outputs = [];
4
4
  export let componentId;
5
- const { worldStore } = getContext('AppEditorContext');
5
+ const { worldStore } = getContext('AppViewerContext');
6
6
  let object = {};
7
7
  function subscribeToAllOutputs(observableOutputs) {
8
8
  if (observableOutputs) {
@@ -1,11 +1,13 @@
1
- <script>import { page } from '$app/stores';
2
- import { classNames } from '../../../../utils';
1
+ <script>import { classNames } from '../../../../utils';
2
+ import { X } from 'lucide-svelte';
3
3
  import { getContext } from 'svelte';
4
- import { key } from 'svelte-awesome/icons';
5
- import { displayData } from '../../utils';
4
+ import { flip } from 'svelte/animate';
5
+ import { fade } from 'svelte/transition';
6
+ import { findGridItem } from '../appUtils';
7
+ import { components } from '../component';
6
8
  import PanelSection from '../settingsPanel/common/PanelSection.svelte';
7
9
  import ComponentOutputViewer from './ComponentOutputViewer.svelte';
8
- const { connectingInput, staticOutputs, worldStore, selectedComponent, app } = getContext('AppEditorContext');
10
+ const { connectingInput, staticOutputs, worldStore, selectedComponent, app } = getContext('AppViewerContext');
9
11
  function connectInput(componentId, path) {
10
12
  if ($connectingInput) {
11
13
  $connectingInput = {
@@ -22,80 +24,126 @@ function connectInput(componentId, path) {
22
24
  }
23
25
  }
24
26
  function getComponentNameById(componentId) {
25
- const component = $app.grid.find((c) => c?.data?.id === componentId);
26
- if (component?.data.type) {
27
- return displayData[component?.data.type].name;
27
+ const component = findGridItem($app, componentId);
28
+ if (component?.data?.type) {
29
+ return components[component?.data.type].name;
28
30
  }
29
31
  else if (componentId == 'ctx') {
30
32
  return 'Context';
31
33
  }
34
+ else if (componentId.startsWith('bg_')) {
35
+ return 'Background';
36
+ }
32
37
  else {
33
38
  return 'Table action';
34
39
  }
35
40
  }
36
- $: panels = [['ctx', ['email', 'username', 'query']]].concat(Object.entries($staticOutputs));
41
+ $: panels = [['ctx', ['email', 'username', 'query', 'hash']]].concat(Object.entries($staticOutputs));
42
+ let search = '';
43
+ // filter out outputs that don't match the search by name (computed by getComponentNameById) and id
44
+ // The output should be [string, string[]][]
45
+ $: filteredPanels = panels.filter(([componentId, outputs]) => {
46
+ const name = getComponentNameById(componentId);
47
+ return (name.toLowerCase().includes(search.toLowerCase()) ||
48
+ componentId.toLowerCase().includes(search.toLowerCase()));
49
+ });
37
50
  </script>
38
51
 
39
- <PanelSection noPadding titlePadding="px-4 pt-2" title="Outputs">
40
- <div
41
- class="overflow-auto min-w-[150px] border-t w-full relative flex flex-col gap-4 px-2 pt-4 pb-2"
42
- >
43
- {#each panels as [componentId, outputs] (componentId)}
44
- {#if outputs.length > 0 && $worldStore?.outputsById[componentId]}
45
- <div>
46
- <div
47
- class="flex {$connectingInput?.opened
48
- ? 'bg-white z-50'
49
- : ''} flex-row justify-between w-full"
50
- >
51
- <button
52
- on:click|stopPropagation|preventDefault={$connectingInput.opened
53
- ? undefined
54
- : () => ($selectedComponent = componentId)}
55
- class={classNames(
56
- 'px-2 text-2xs py-0.5 border border-gray-300 font-bold rounded-t-sm w-fit',
57
- $selectedComponent === componentId
58
- ? ' bg-indigo-500 text-white'
59
- : 'bg-gray-200 text-gray-500'
60
- )}
61
- >
62
- {componentId}
63
- </button>
64
- <span
65
- class={classNames(
66
- 'px-1 text-2xs py-0.5 font-bold rounded-t-sm w-fit',
67
- 'bg-gray-500 text-white'
68
- )}
69
- >
70
- {getComponentNameById(componentId)}
71
- </span>
72
- </div>
73
-
74
- <!-- svelte-ignore a11y-click-events-have-key-events -->
75
- <div
76
- class={classNames(
77
- $connectingInput?.opened ? 'bg-white z-50' : '',
78
- `w-full py-2 grow border relative break-all `,
79
- $selectedComponent === componentId ? 'border border-blue-500 ' : '',
80
- $connectingInput.hoveredComponent === componentId ? 'outline outline-blue-500' : ''
81
- )}
52
+ <PanelSection noPadding titlePadding="px-4 pt-2 pb-0.5" title="Outputs">
53
+ <div class="overflow-auto h-full min-w-[150px] w-full relative flex flex-col">
54
+ <div class="sticky z-50 top-0 left-0 w-full bg-white px-2 pb-2">
55
+ <div class="relative">
56
+ <input
57
+ bind:value={search}
58
+ class="px-2 py-1 border border-gray-300 rounded-sm {search ? 'pr-8' : ''}"
59
+ placeholder="Search outputs..."
60
+ />
61
+ {#if search}
62
+ <button
63
+ class="absolute right-2 top-1/2 transform -translate-y-1/2 hover:bg-gray-200 rounded-full p-0.5"
64
+ on:click|stopPropagation|preventDefault={() => (search = '')}
82
65
  >
83
- {#key $selectedComponent}
84
- {#key $connectingInput?.opened}
85
- <ComponentOutputViewer
86
- outputs={$connectingInput?.opened && $selectedComponent === componentId
87
- ? ['search']
88
- : outputs}
66
+ <X size="14" />
67
+ </button>
68
+ {/if}
69
+ </div>
70
+ </div>
71
+ <div class="relative p-2">
72
+ {#each filteredPanels as [componentId, outputs] (componentId)}
73
+ <div
74
+ animate:flip={{ duration: 300 }}
75
+ in:fade|local={{ duration: 100, delay: 50 }}
76
+ out:fade|local={{ duration: 100 }}
77
+ class="pb-2"
78
+ >
79
+ {#if outputs.length > 0 && $worldStore?.outputsById[componentId]}
80
+ {@const name = getComponentNameById(componentId)}
81
+ <div>
82
+ <div
83
+ class="flex {$connectingInput?.opened
84
+ ? 'bg-white z-50'
85
+ : ''} flex-row justify-between w-full"
86
+ >
87
+ <button
88
+ on:click|stopPropagation|preventDefault={$connectingInput.opened
89
+ ? undefined
90
+ : () => ($selectedComponent = componentId)}
91
+ class={classNames(
92
+ 'px-2 text-2xs py-0.5 border-t border-x font-bold rounded-t-sm w-fit',
93
+ $selectedComponent === componentId
94
+ ? ' bg-indigo-500/90 text-white border-indigo-500/90'
95
+ : 'bg-gray-100 text-gray-500 border-gray-200'
96
+ )}
97
+ >
89
98
  {componentId}
90
- on:select={({ detail }) => {
91
- connectInput(componentId, detail)
92
- }}
93
- />
94
- {/key}
95
- {/key}
96
- </div>
99
+ </button>
100
+ <span
101
+ class={classNames(
102
+ 'px-1 text-2xs py-0.5 font-semibold rounded-t-sm w-fit',
103
+ 'bg-gray-700 text-white'
104
+ )}
105
+ >
106
+ {name}
107
+ </span>
108
+ </div>
109
+ <div
110
+ class={classNames(
111
+ $connectingInput?.opened ? 'bg-white z-50' : '',
112
+ `w-full py-2 grow border relative break-all `,
113
+ $selectedComponent === componentId ? 'border border-indigo-500/90 ' : '',
114
+ $connectingInput.hoveredComponent === componentId
115
+ ? 'outline outline-indigo-500/90'
116
+ : ''
117
+ )}
118
+ >
119
+ {#key $selectedComponent}
120
+ {#key $connectingInput?.opened}
121
+ <ComponentOutputViewer
122
+ outputs={$connectingInput?.opened && $selectedComponent === componentId
123
+ ? name == 'Table'
124
+ ? ['search']
125
+ : []
126
+ : outputs}
127
+ {componentId}
128
+ on:select={({ detail }) => {
129
+ connectInput(componentId, detail)
130
+ }}
131
+ />
132
+ {/key}
133
+ {/key}
134
+ </div>
135
+ </div>
136
+ {/if}
137
+ </div>
138
+ {:else}
139
+ <div
140
+ in:fade|local={{ duration: 50, delay: 100 }}
141
+ out:fade|local={{ duration: 50 }}
142
+ class="absolute left-0 top-0 w-full text-sm text-gray-500 text-center py-4 px-2"
143
+ >
144
+ No outputs found
97
145
  </div>
98
- {/if}
99
- {/each}
146
+ {/each}
147
+ </div>
100
148
  </div>
101
149
  </PanelSection>
@@ -1,14 +1,23 @@
1
- <script>import FlowScriptPicker from '../../../flows/pickers/FlowScriptPicker.svelte';
1
+ <script>import { Button, Drawer, DrawerContent, Tab, Tabs } from '../../../common';
2
+ import FlowScriptPicker from '../../../flows/pickers/FlowScriptPicker.svelte';
3
+ import PickHubScript from '../../../flows/pickers/PickHubScript.svelte';
2
4
  import { Script } from '../../../../gen';
3
5
  import { inferArgs } from '../../../../infer';
4
6
  import { initialCode } from '../../../../script_helpers';
5
- import { emptySchema } from '../../../../utils';
7
+ import { capitalize, emptySchema, getScriptByPath } from '../../../../utils';
8
+ import { faCodeBranch, faTrash } from '@fortawesome/free-solid-svg-icons';
9
+ import { Building, Globe2 } from 'lucide-svelte';
6
10
  import { createEventDispatcher, getContext } from 'svelte';
7
11
  import { fly } from 'svelte/transition';
8
- import { defaultCode } from '../../editorUtils';
12
+ import { defaultCode } from '../component';
13
+ import InlineScriptList from '../settingsPanel/mainInput/InlineScriptList.svelte';
14
+ import WorkspaceScriptList from '../settingsPanel/mainInput/WorkspaceScriptList.svelte';
9
15
  export let name;
10
16
  export let id;
11
- const { appPath, app } = getContext('AppEditorContext');
17
+ let tab = 'inlinescripts';
18
+ let filter = '';
19
+ let picker;
20
+ const { appPath, app } = getContext('AppViewerContext');
12
21
  const dispatch = createEventDispatcher();
13
22
  async function inferInlineScriptSchema(language, content, schema) {
14
23
  try {
@@ -21,9 +30,12 @@ async function inferInlineScriptSchema(language, content, schema) {
21
30
  }
22
31
  async function createInlineScriptByLanguage(language, path, subkind = undefined) {
23
32
  const componentType = $app.grid.find((c) => c.data.id === id)?.data?.type;
24
- const fullPath = `${appPath}/inline-script/${path}`;
25
33
  const content = defaultCode(componentType, language) ??
26
34
  initialCode(language, Script.kind.SCRIPT, subkind ?? 'flow');
35
+ return newInlineScript(content, language, path);
36
+ }
37
+ async function newInlineScript(content, language, path) {
38
+ const fullPath = `${appPath}/inline-script/${path}`;
27
39
  let schema = emptySchema();
28
40
  schema = await inferInlineScriptSchema(language, content, schema);
29
41
  const newInlineScript = {
@@ -34,15 +46,80 @@ async function createInlineScriptByLanguage(language, path, subkind = undefined)
34
46
  };
35
47
  dispatch('new', newInlineScript);
36
48
  }
49
+ async function pickScript(path) {
50
+ const script = await getScriptByPath(path);
51
+ newInlineScript(script.content, script.language, path);
52
+ }
53
+ async function pickHubScript(path) {
54
+ const script = await getScriptByPath(path);
55
+ newInlineScript(script.content, script.language, path);
56
+ }
57
+ function pickInlineScript(name) {
58
+ const unusedInlineScriptIndex = $app.unusedInlineScripts?.findIndex((script) => script.name === name);
59
+ const unusedInlineScript = $app.unusedInlineScripts?.[unusedInlineScriptIndex];
60
+ $app.unusedInlineScripts.splice(unusedInlineScriptIndex, 1);
61
+ $app = $app;
62
+ dispatch('new', unusedInlineScript.inlineScript);
63
+ }
37
64
  const langs = ['deno', 'python3', 'go', 'bash'];
65
+ function loadSchemaFromTriggerable(path, arg1) {
66
+ throw new Error('Function not implemented.');
67
+ }
38
68
  </script>
39
69
 
40
- <div class="flex flex-col p-4 gap-2 text-sm" in:fly={{ duration: 50 }}>
41
- Please choose a language:
70
+ <Drawer bind:this={picker} size="1000px">
71
+ <DrawerContent title="Script/Flow Picker" on:close={picker.closeDrawer}>
72
+ <div>
73
+ <div class="max-w-6xl">
74
+ <Tabs bind:selected={tab}>
75
+ <Tab size="sm" value="inlinescripts">
76
+ <div class="flex gap-2 items-center my-1">
77
+ <Building size={18} />
78
+ Detached Inline Scripts
79
+ </div>
80
+ </Tab>
81
+ <Tab size="sm" value="workspacescripts">
82
+ <div class="flex gap-2 items-center my-1">
83
+ <Building size={18} />
84
+ Workspace Scripts
85
+ </div>
86
+ </Tab>
87
+
88
+ <Tab size="sm" value="hubscripts">
89
+ <div class="flex gap-2 items-center my-1">
90
+ <Globe2 size={18} />
91
+ Hub Scripts
92
+ </div>
93
+ </Tab>
94
+ </Tabs>
95
+ <div class="my-2" />
96
+ <div class="flex flex-col gap-y-16">
97
+ <div class="flex flex-col">
98
+ {#if tab == 'inlinescripts'}
99
+ <InlineScriptList
100
+ on:pick={(e) => pickInlineScript(e.detail)}
101
+ inlineScripts={$app.unusedInlineScripts
102
+ ? $app.unusedInlineScripts.map((uis) => uis.name)
103
+ : []}
104
+ />
105
+ {:else if tab == 'workspacescripts'}
106
+ <WorkspaceScriptList on:pick={(e) => pickScript(e.detail)} />
107
+ {:else if tab == 'hubscripts'}
108
+ <PickHubScript bind:filter on:pick={(e) => pickHubScript(e.detail.path)} />
109
+ {/if}
110
+ </div>
111
+ </div>
112
+ </div>
113
+ </div>
114
+ </DrawerContent>
115
+ </Drawer>
116
+
117
+ <div class="flex flex-col px-4 py-2 gap-2 text-sm" in:fly={{ duration: 50 }}>
118
+ <div>Choose a language:</div>
42
119
  <div class="flex gap-2 flex-row flex-wrap">
43
120
  {#each langs as lang}
44
121
  <FlowScriptPicker
45
- label={lang}
122
+ label={capitalize(lang)}
46
123
  {lang}
47
124
  on:click={() => {
48
125
  createInlineScriptByLanguage(lang, name)
@@ -57,12 +134,34 @@ const langs = ['deno', 'python3', 'go', 'bash'];
57
134
  createInlineScriptByLanguage(Script.language.DENO, name, 'pgsql')
58
135
  }}
59
136
  />
60
- <FlowScriptPicker
137
+ <!-- <FlowScriptPicker
61
138
  label={`MySQL`}
62
139
  lang="mysql"
63
140
  on:click={() => {
64
141
  createInlineScriptByLanguage(Script.language.DENO, name, 'mysql')
65
142
  }}
66
- />
143
+ /> -->
144
+ </div>
145
+
146
+ <div class="mt-4">
147
+ <Button
148
+ on:click={() => picker?.openDrawer()}
149
+ size="xs"
150
+ color="blue"
151
+ startIcon={{ icon: faCodeBranch }}
152
+ btnClasses="truncate"
153
+ >
154
+ or fork a detached/Workspace/Hub script
155
+ </Button>
156
+ <Button
157
+ on:click={() => dispatch('delete')}
158
+ size="xs"
159
+ color="red"
160
+ variant="border"
161
+ startIcon={{ icon: faTrash }}
162
+ btnClasses="truncate"
163
+ >
164
+ Delete
165
+ </Button>
67
166
  </div>
68
167
  </div>