windmill-components 1.70.0 → 1.77.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 (441) hide show
  1. package/assets/app.css +12 -1
  2. package/components/AppConnect.svelte +4 -3
  3. package/components/DisplayResult.svelte +28 -10
  4. package/components/Dropdown.svelte +14 -4
  5. package/components/FieldHeader.svelte +12 -8
  6. package/components/FlowBuilder.svelte +107 -39
  7. package/components/FlowBuilder.svelte.d.ts +5 -0
  8. package/components/FlowGraphViewer.svelte +6 -5
  9. package/components/FlowJobResult.svelte +3 -3
  10. package/components/FlowPreviewContent.svelte +3 -8
  11. package/components/FlowStatusViewer.svelte +21 -8
  12. package/components/FolderUsageInfo.svelte +16 -6
  13. package/components/FolderUsageInfo.svelte.d.ts +2 -0
  14. package/components/GroupEditor.svelte +8 -0
  15. package/components/InputTransformForm.svelte +13 -20
  16. package/components/InputTransformSchemaForm.svelte +103 -0
  17. package/components/InputTransformSchemaForm.svelte.d.ts +24 -0
  18. package/components/LogViewer.svelte +1 -1
  19. package/components/ModulePreview.svelte +3 -2
  20. package/components/Multiselect.svelte +1 -1
  21. package/components/PageHeader.svelte +1 -1
  22. package/components/Path.svelte +35 -12
  23. package/components/Popover.svelte +2 -13
  24. package/components/ResourcePicker.svelte +33 -14
  25. package/components/RunChart.svelte +24 -5
  26. package/components/RunForm.svelte +5 -6
  27. package/components/RunForm.svelte.d.ts +1 -0
  28. package/components/SchemaForm.svelte +59 -57
  29. package/components/SchemaForm.svelte.d.ts +0 -5
  30. package/components/ScriptBuilder.svelte +151 -135
  31. package/components/ScriptPicker.svelte +3 -0
  32. package/components/SettingSection.svelte +44 -0
  33. package/components/SettingSection.svelte.d.ts +21 -0
  34. package/components/SimpleEditor.svelte +4 -1
  35. package/components/SimpleEditor.svelte.d.ts +2 -0
  36. package/components/Slider.svelte +6 -1
  37. package/components/Slider.svelte.d.ts +1 -0
  38. package/components/TemplateEditor.svelte +1 -1
  39. package/components/TestJobLoader.svelte +2 -2
  40. package/components/Toggle.svelte +17 -4
  41. package/components/Toggle.svelte.d.ts +2 -0
  42. package/components/Tooltip.svelte +4 -2
  43. package/components/UserSettings.svelte +2 -0
  44. package/components/WhitelistIp.svelte +1 -3
  45. package/components/apps/components/buttons/AppButton.svelte +45 -23
  46. package/components/apps/components/buttons/AppButton.svelte.d.ts +2 -0
  47. package/components/apps/components/buttons/AppForm.svelte +18 -12
  48. package/components/apps/components/buttons/AppForm.svelte.d.ts +3 -0
  49. package/components/apps/components/buttons/AppFormButton.svelte +14 -10
  50. package/components/apps/components/buttons/AppFormButton.svelte.d.ts +3 -0
  51. package/components/apps/components/display/AppBarChart.svelte +15 -7
  52. package/components/apps/components/display/AppBarChart.svelte.d.ts +3 -0
  53. package/components/apps/components/display/AppDisplayComponent.svelte +17 -12
  54. package/components/apps/components/display/AppDisplayComponent.svelte.d.ts +1 -0
  55. package/components/apps/components/display/AppHtml.svelte +18 -4
  56. package/components/apps/components/display/AppHtml.svelte.d.ts +3 -0
  57. package/components/apps/components/display/AppIcon.svelte +20 -8
  58. package/components/apps/components/display/AppIcon.svelte.d.ts +3 -0
  59. package/components/apps/components/display/AppImage.svelte +17 -10
  60. package/components/apps/components/display/AppImage.svelte.d.ts +3 -0
  61. package/components/apps/components/display/AppMap.svelte +214 -0
  62. package/components/apps/components/display/AppMap.svelte.d.ts +23 -0
  63. package/components/apps/components/display/AppPdf.svelte +304 -0
  64. package/components/apps/components/display/AppPdf.svelte.d.ts +24 -0
  65. package/components/apps/components/display/AppPieChart.svelte +15 -7
  66. package/components/apps/components/display/AppPieChart.svelte.d.ts +3 -0
  67. package/components/apps/components/display/AppScatterChart.svelte +12 -4
  68. package/components/apps/components/display/AppScatterChart.svelte.d.ts +3 -0
  69. package/components/apps/components/display/AppText.svelte +38 -32
  70. package/components/apps/components/display/AppText.svelte.d.ts +1 -0
  71. package/components/apps/components/display/AppTimeseries.svelte +12 -4
  72. package/components/apps/components/display/AppTimeseries.svelte.d.ts +3 -0
  73. package/components/apps/components/display/PlotlyHtml.svelte +8 -14
  74. package/components/apps/components/display/PlotlyHtml.svelte.d.ts +1 -1
  75. package/components/apps/components/display/VegaLiteHtml.svelte +3 -8
  76. package/components/apps/components/display/VegaLiteHtml.svelte.d.ts +1 -0
  77. package/components/apps/components/display/index.d.ts +3 -0
  78. package/components/apps/components/display/index.js +3 -0
  79. package/components/apps/components/display/table/AppAggridTable.svelte +20 -8
  80. package/components/apps/components/display/table/AppAggridTable.svelte.d.ts +1 -0
  81. package/components/apps/components/display/table/AppTable.svelte +69 -21
  82. package/components/apps/components/display/table/AppTable.svelte.d.ts +3 -1
  83. package/components/apps/components/display/table/AppTableFooter.svelte +8 -1
  84. package/components/apps/components/display/table/AppTableFooter.svelte.d.ts +2 -0
  85. package/components/apps/components/helpers/AlignWrapper.svelte +13 -7
  86. package/components/apps/components/helpers/AlignWrapper.svelte.d.ts +3 -1
  87. package/components/apps/components/helpers/HiddenComponent.svelte +5 -1
  88. package/components/apps/components/helpers/HiddenComponent.svelte.d.ts +1 -0
  89. package/components/apps/components/helpers/InputValue.svelte +58 -52
  90. package/components/apps/components/helpers/InputValue.svelte.d.ts +4 -3
  91. package/components/apps/components/helpers/NonRunnableComponent.svelte +18 -3
  92. package/components/apps/components/helpers/NonRunnableComponent.svelte.d.ts +1 -0
  93. package/components/apps/components/helpers/RefreshButton.svelte +3 -4
  94. package/components/apps/components/helpers/ResizeWrapper.svelte +24 -0
  95. package/components/apps/components/helpers/ResizeWrapper.svelte.d.ts +19 -0
  96. package/components/apps/components/helpers/RunnableComponent.svelte +126 -91
  97. package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +5 -1
  98. package/components/apps/components/helpers/RunnableWrapper.svelte +11 -5
  99. package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +4 -1
  100. package/components/apps/components/helpers/eval.d.ts +5 -0
  101. package/components/apps/components/helpers/eval.js +57 -0
  102. package/components/apps/components/inputs/AppCheckbox.svelte +8 -2
  103. package/components/apps/components/inputs/AppCheckbox.svelte.d.ts +3 -0
  104. package/components/apps/components/inputs/AppDateInput.svelte +25 -18
  105. package/components/apps/components/inputs/AppDateInput.svelte.d.ts +6 -1
  106. package/components/apps/components/inputs/AppFileInput.svelte +22 -14
  107. package/components/apps/components/inputs/AppFileInput.svelte.d.ts +3 -0
  108. package/components/apps/components/inputs/AppMultiSelect.svelte +82 -0
  109. package/components/apps/components/inputs/AppMultiSelect.svelte.d.ts +27 -0
  110. package/components/apps/components/inputs/AppNumberInput.svelte +20 -16
  111. package/components/apps/components/inputs/AppNumberInput.svelte.d.ts +5 -0
  112. package/components/apps/components/inputs/AppRangeInput.svelte +55 -14
  113. package/components/apps/components/inputs/AppRangeInput.svelte.d.ts +3 -0
  114. package/components/apps/components/inputs/AppSelect.svelte +58 -21
  115. package/components/apps/components/inputs/AppSelect.svelte.d.ts +3 -0
  116. package/components/apps/components/inputs/AppSliderInputs.svelte +41 -9
  117. package/components/apps/components/inputs/AppSliderInputs.svelte.d.ts +3 -0
  118. package/components/apps/components/inputs/AppTextInput.svelte +53 -19
  119. package/components/apps/components/inputs/AppTextInput.svelte.d.ts +6 -0
  120. package/components/apps/components/inputs/currency/AppCurrencyInput.svelte +13 -3
  121. package/components/apps/components/inputs/currency/AppCurrencyInput.svelte.d.ts +3 -0
  122. package/components/apps/components/inputs/currency/CurrencyInput.svelte +2 -0
  123. package/components/apps/components/inputs/currency/CurrencyInput.svelte.d.ts +1 -0
  124. package/components/apps/components/layout/AppContainer.svelte +20 -17
  125. package/components/apps/components/layout/AppContainer.svelte.d.ts +3 -0
  126. package/components/apps/components/layout/AppDivider.svelte +24 -4
  127. package/components/apps/components/layout/AppDivider.svelte.d.ts +3 -1
  128. package/components/apps/components/layout/AppDrawer.svelte +86 -0
  129. package/components/apps/components/layout/AppDrawer.svelte.d.ts +24 -0
  130. package/components/apps/components/layout/AppSplitpanes.svelte +83 -0
  131. package/components/apps/components/layout/AppSplitpanes.svelte.d.ts +26 -0
  132. package/components/apps/components/layout/AppTabs.svelte +112 -40
  133. package/components/apps/components/layout/AppTabs.svelte.d.ts +4 -0
  134. package/components/apps/components/layout/index.d.ts +2 -0
  135. package/components/apps/components/layout/index.js +2 -0
  136. package/components/apps/editor/AppEditor.svelte +201 -132
  137. package/components/apps/editor/AppEditor.svelte.d.ts +3 -1
  138. package/components/apps/editor/AppEditorHeader.svelte +149 -66
  139. package/components/apps/editor/AppInputs.svelte +3 -3
  140. package/components/apps/editor/AppPreview.svelte +21 -7
  141. package/components/apps/editor/ComponentHeader.svelte +17 -4
  142. package/components/apps/editor/ComponentHeader.svelte.d.ts +2 -0
  143. package/components/apps/editor/GridEditor.svelte +86 -70
  144. package/components/apps/editor/GridPanel.svelte +29 -0
  145. package/components/apps/editor/GridPanel.svelte.d.ts +18 -0
  146. package/components/apps/editor/RecomputeAllComponents.svelte +14 -6
  147. package/components/apps/editor/SettingsPanel.svelte +30 -27
  148. package/components/apps/editor/SubGridEditor.svelte +82 -50
  149. package/components/apps/editor/SubGridEditor.svelte.d.ts +8 -4
  150. package/components/apps/editor/appUtils.d.ts +22 -3
  151. package/components/apps/editor/appUtils.js +221 -47
  152. package/components/apps/editor/component/Component.svelte +281 -61
  153. package/components/apps/editor/component/Component.svelte.d.ts +3 -1
  154. package/components/apps/editor/component/ComponentNavigation.svelte +170 -0
  155. package/components/apps/editor/component/ComponentNavigation.svelte.d.ts +14 -0
  156. package/components/apps/editor/component/components.d.ts +15 -3
  157. package/components/apps/editor/component/components.js +409 -54
  158. package/components/apps/editor/component/default-codes.js +6 -6
  159. package/components/apps/editor/component/sets.js +11 -3
  160. package/components/apps/editor/componentsPanel/ComponentList.svelte +72 -29
  161. package/components/apps/editor/componentsPanel/CssProperty.svelte +59 -23
  162. package/components/apps/editor/componentsPanel/CssProperty.svelte.d.ts +2 -1
  163. package/components/apps/editor/componentsPanel/CssSettings.svelte +56 -9
  164. package/components/apps/editor/componentsPanel/ListItem.svelte +23 -12
  165. package/components/apps/editor/componentsPanel/componentStaticValues.d.ts +2 -0
  166. package/components/apps/editor/componentsPanel/componentStaticValues.js +15 -2
  167. package/components/apps/editor/contextPanel/ComponentOutput.svelte +77 -0
  168. package/components/apps/editor/contextPanel/ComponentOutput.svelte.d.ts +21 -0
  169. package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +10 -6
  170. package/components/apps/editor/contextPanel/ContextPanel.svelte +81 -91
  171. package/components/apps/editor/contextPanel/SubGridOutput.svelte +71 -0
  172. package/components/apps/editor/contextPanel/SubGridOutput.svelte.d.ts +19 -0
  173. package/components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte +38 -0
  174. package/components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte.d.ts +19 -0
  175. package/components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte +10 -0
  176. package/components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte.d.ts +16 -0
  177. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte +25 -0
  178. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte.d.ts +16 -0
  179. package/components/apps/editor/contextPanel/components/OutputHeader.svelte +78 -0
  180. package/components/apps/editor/contextPanel/components/OutputHeader.svelte.d.ts +26 -0
  181. package/components/apps/editor/contextPanel/components/TableActionOutput.svelte +19 -0
  182. package/components/apps/editor/contextPanel/components/TableActionOutput.svelte.d.ts +18 -0
  183. package/components/apps/editor/contextPanel/components/TableActionsOutput.svelte +14 -0
  184. package/components/apps/editor/contextPanel/components/TableActionsOutput.svelte.d.ts +18 -0
  185. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +55 -13
  186. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte.d.ts +1 -0
  187. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +126 -62
  188. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte.d.ts +5 -0
  189. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte +1 -1
  190. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte +11 -5
  191. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte.d.ts +1 -0
  192. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanel.svelte +26 -17
  193. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanelList.svelte +95 -85
  194. package/components/apps/editor/inlineScriptsPanel/utils.d.ts +5 -9
  195. package/components/apps/editor/inlineScriptsPanel/utils.js +19 -8
  196. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte +10 -9
  197. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte.d.ts +21 -12
  198. package/components/apps/editor/settingsPanel/ComponentInputTypeEditor.svelte +1 -1
  199. package/components/apps/editor/settingsPanel/ComponentPanel.svelte +119 -79
  200. package/components/apps/editor/settingsPanel/ComponentPanel.svelte.d.ts +1 -0
  201. package/components/apps/editor/settingsPanel/GridPane.svelte +75 -0
  202. package/components/apps/editor/settingsPanel/GridPane.svelte.d.ts +20 -0
  203. package/components/apps/editor/settingsPanel/GridTab.svelte +9 -17
  204. package/components/apps/editor/settingsPanel/GridTab.svelte.d.ts +2 -0
  205. package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +2 -1
  206. package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte +1 -1
  207. package/components/apps/editor/settingsPanel/Recompute.svelte +2 -1
  208. package/components/apps/editor/settingsPanel/SelectedRunnable.svelte +7 -1
  209. package/components/apps/editor/settingsPanel/TableActions.svelte +30 -2
  210. package/components/apps/editor/settingsPanel/common/PanelSection.svelte +2 -2
  211. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte +48 -0
  212. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte.d.ts +19 -0
  213. package/components/apps/editor/settingsPanel/inputEditor/ConnectedInputEditor.svelte +2 -8
  214. package/components/apps/editor/settingsPanel/inputEditor/EvalInputEditor.svelte +2 -2
  215. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte +77 -41
  216. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte.d.ts +2 -0
  217. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte +3 -3
  218. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte.d.ts +4 -1
  219. package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte +54 -6
  220. package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte.d.ts +1 -0
  221. package/components/apps/editor/settingsPanel/inputEditor/UploadInputEditor.svelte +7 -9
  222. package/components/apps/editor/settingsPanel/inputEditor/UploadInputEditor.svelte.d.ts +1 -1
  223. package/components/apps/editor/settingsPanel/mainInput/InlineScriptList.svelte +1 -0
  224. package/components/apps/editor/settingsPanel/mainInput/InlineScriptList.svelte.d.ts +1 -0
  225. package/components/apps/editor/settingsPanel/mainInput/RunnableSelector.svelte +1 -1
  226. package/components/apps/inputType.d.ts +6 -5
  227. package/components/apps/rx.d.ts +6 -4
  228. package/components/apps/rx.js +36 -15
  229. package/components/apps/store.d.ts +6 -1
  230. package/components/apps/svelte-grid/Grid.svelte +171 -0
  231. package/components/apps/svelte-grid/Grid.svelte.d.ts +47 -0
  232. package/components/apps/svelte-grid/LICENSE +23 -0
  233. package/components/apps/svelte-grid/MoveResize.svelte +328 -0
  234. package/components/apps/svelte-grid/MoveResize.svelte.d.ts +46 -0
  235. package/components/apps/svelte-grid/types.d.ts +25 -0
  236. package/components/apps/svelte-grid/utils/container.d.ts +1 -0
  237. package/components/apps/svelte-grid/utils/container.js +4 -0
  238. package/components/apps/svelte-grid/utils/helper.d.ts +14 -0
  239. package/components/apps/svelte-grid/utils/helper.js +36 -0
  240. package/components/apps/svelte-grid/utils/item.d.ts +14 -0
  241. package/components/apps/svelte-grid/utils/item.js +192 -0
  242. package/components/apps/svelte-grid/utils/matrix.d.ts +6 -0
  243. package/components/apps/svelte-grid/utils/matrix.js +53 -0
  244. package/components/apps/svelte-grid/utils/other.d.ts +3 -0
  245. package/components/apps/svelte-grid/utils/other.js +30 -0
  246. package/components/apps/types.d.ts +21 -8
  247. package/components/apps/utils.d.ts +3 -3
  248. package/components/apps/utils.js +34 -56
  249. package/components/common/CloseButton.svelte +18 -0
  250. package/components/common/CloseButton.svelte.d.ts +27 -0
  251. package/components/common/badge/Badge.svelte +6 -1
  252. package/components/common/badge/Badge.svelte.d.ts +1 -0
  253. package/components/common/button/ButtonPopup.svelte +2 -0
  254. package/components/common/button/ButtonPopup.svelte.d.ts +1 -0
  255. package/components/common/button/UndoRedo.svelte +32 -0
  256. package/components/common/button/UndoRedo.svelte.d.ts +20 -0
  257. package/components/common/drawer/Drawer.svelte +10 -4
  258. package/components/common/drawer/Drawer.svelte.d.ts +3 -1
  259. package/components/common/drawer/DrawerContent.svelte +2 -7
  260. package/components/common/fileInput/FileInput.svelte +47 -21
  261. package/components/common/fileInput/FileInput.svelte.d.ts +3 -1
  262. package/components/common/fileInput/model.d.ts +1 -0
  263. package/components/common/fileInput/model.js +1 -0
  264. package/components/common/index.d.ts +1 -0
  265. package/components/common/index.js +1 -0
  266. package/components/common/languageIcons/JavaScript.svelte +11 -0
  267. package/components/common/languageIcons/JavaScript.svelte.d.ts +25 -0
  268. package/components/common/languageIcons/LanguageIcon.svelte +3 -1
  269. package/components/common/languageIcons/LanguageIcon.svelte.d.ts +1 -1
  270. package/components/common/menu/Menu.svelte +3 -2
  271. package/components/common/menu/Menu.svelte.d.ts +2 -1
  272. package/components/common/modal/Modal.svelte +9 -4
  273. package/components/common/modal/Modal.svelte.d.ts +2 -0
  274. package/components/common/popup/Popup.svelte +2 -1
  275. package/components/common/popup/Popup.svelte.d.ts +9 -0
  276. package/components/common/table/AppRow.svelte +14 -8
  277. package/components/common/table/AppRow.svelte.d.ts +1 -0
  278. package/components/common/table/FlowRow.svelte +22 -12
  279. package/components/common/table/FlowRow.svelte.d.ts +1 -0
  280. package/components/common/table/ScriptRow.svelte +43 -14
  281. package/components/common/table/ScriptRow.svelte.d.ts +1 -0
  282. package/components/common/tabs/Tab.svelte +13 -5
  283. package/components/common/tabs/Tab.svelte.d.ts +6 -1
  284. package/components/common/tabs/Tabs.svelte +8 -6
  285. package/components/common/tabs/Tabs.svelte.d.ts +3 -1
  286. package/components/flows/FlowEditor.svelte +6 -4
  287. package/components/flows/common/FlowCardHeader.svelte +4 -1
  288. package/components/flows/content/BranchPredicateEditor.svelte +3 -4
  289. package/components/flows/content/CapturePayload.svelte +1 -2
  290. package/components/flows/content/FlowBranchesAllWrapper.svelte +1 -1
  291. package/components/flows/content/FlowConstants.svelte +7 -13
  292. package/components/flows/content/FlowEditorPanel.svelte +4 -3
  293. package/components/flows/content/FlowFailureModule.svelte +2 -1
  294. package/components/flows/content/FlowInput.svelte +4 -2
  295. package/components/flows/content/FlowLoop.svelte +3 -4
  296. package/components/flows/content/FlowModuleComponent.svelte +23 -11
  297. package/components/flows/content/FlowModuleEarlyStop.svelte +3 -1
  298. package/components/flows/content/FlowModuleHeader.svelte +26 -3
  299. package/components/flows/content/FlowModuleHeader.svelte.d.ts +1 -0
  300. package/components/flows/content/FlowModuleSleep.svelte +2 -2
  301. package/components/flows/content/FlowModuleWrapper.svelte +2 -8
  302. package/components/flows/content/FlowSchedules.svelte +1 -2
  303. package/components/flows/content/FlowSettings.svelte +17 -37
  304. package/components/flows/content/ScriptEditorDrawer.svelte +98 -0
  305. package/components/flows/content/ScriptEditorDrawer.svelte.d.ts +19 -0
  306. package/components/flows/flowState.d.ts +2 -3
  307. package/components/flows/flowState.js +1 -4
  308. package/components/flows/flowStateUtils.d.ts +7 -6
  309. package/components/flows/flowStateUtils.js +5 -9
  310. package/components/flows/flowStore.d.ts +5 -4
  311. package/components/flows/flowStore.js +5 -17
  312. package/components/flows/header/FlowImportExportMenu.svelte +2 -1
  313. package/components/flows/map/FlowConstantsItem.svelte +2 -2
  314. package/components/flows/map/FlowErrorHandlerItem.svelte +12 -13
  315. package/components/flows/map/FlowInputsItem.svelte +2 -3
  316. package/components/flows/map/FlowModuleSchemaItem.svelte +88 -91
  317. package/components/flows/map/FlowModuleSchemaItem.svelte.d.ts +3 -3
  318. package/components/flows/map/FlowModuleSchemaMap.svelte +164 -138
  319. package/components/flows/map/FlowModuleSchemaMap.svelte.d.ts +1 -2
  320. package/components/flows/map/FlowSettingsItem.svelte +5 -4
  321. package/components/flows/map/InsertModuleButton.svelte +12 -10
  322. package/components/flows/map/InsertModuleButton.svelte.d.ts +1 -0
  323. package/components/flows/map/MapItem.svelte +176 -103
  324. package/components/flows/map/MapItem.svelte.d.ts +20 -2
  325. package/components/flows/map/VirtualItem.svelte +129 -0
  326. package/components/flows/map/VirtualItem.svelte.d.ts +44 -0
  327. package/components/flows/pickers/FlowScriptPicker.svelte.d.ts +1 -1
  328. package/components/flows/pickers/WorkspaceScriptPicker.svelte +1 -1
  329. package/components/flows/previousResults.d.ts +1 -1
  330. package/components/flows/previousResults.js +32 -17
  331. package/components/flows/types.d.ts +13 -1
  332. package/components/flows/utils.js +1 -1
  333. package/components/graph/FlowGraph.svelte +227 -167
  334. package/components/graph/FlowGraph.svelte.d.ts +14 -1
  335. package/components/graph/model.d.ts +6 -36
  336. package/components/graph/model.js +1 -1
  337. package/components/graph/svelvet/LICENSE +21 -0
  338. package/components/graph/svelvet/collapsible/controllers/util.d.ts +15 -0
  339. package/components/graph/svelvet/collapsible/controllers/util.js +144 -0
  340. package/components/graph/svelvet/collapsible/models/Collapsible.d.ts +17 -0
  341. package/components/graph/svelvet/collapsible/models/Collapsible.js +25 -0
  342. package/components/graph/svelvet/collapsible/types/types.d.ts +8 -0
  343. package/components/graph/svelvet/collapsible/types/types.js +1 -0
  344. package/components/graph/svelvet/container/README.md +7 -0
  345. package/components/graph/svelvet/container/controllers/middleware.d.ts +18 -0
  346. package/components/graph/svelvet/container/controllers/middleware.js +101 -0
  347. package/components/graph/svelvet/container/views/GraphView.svelte +252 -0
  348. package/components/graph/svelvet/container/views/GraphView.svelte.d.ts +25 -0
  349. package/components/graph/svelvet/container/views/Svelvet.svelte +131 -0
  350. package/components/graph/svelvet/container/views/Svelvet.svelte.d.ts +41 -0
  351. package/components/graph/svelvet/customCss/controllers/getCss.d.ts +2 -0
  352. package/components/graph/svelvet/customCss/controllers/getCss.js +57 -0
  353. package/components/graph/svelvet/d3/controllers/d3.d.ts +5 -0
  354. package/components/graph/svelvet/d3/controllers/d3.js +59 -0
  355. package/components/graph/svelvet/edges/controllers/anchorCbDev.d.ts +4 -0
  356. package/components/graph/svelvet/edges/controllers/anchorCbDev.js +92 -0
  357. package/components/graph/svelvet/edges/controllers/anchorCbUser.d.ts +57 -0
  358. package/components/graph/svelvet/edges/controllers/anchorCbUser.js +73 -0
  359. package/components/graph/svelvet/edges/controllers/util.d.ts +37 -0
  360. package/components/graph/svelvet/edges/controllers/util.js +72 -0
  361. package/components/graph/svelvet/edges/models/Anchor.d.ts +48 -0
  362. package/components/graph/svelvet/edges/models/Anchor.js +122 -0
  363. package/components/graph/svelvet/edges/models/Edge.d.ts +47 -0
  364. package/components/graph/svelvet/edges/models/Edge.js +107 -0
  365. package/components/graph/svelvet/edges/types/types.d.ts +18 -0
  366. package/components/graph/svelvet/edges/types/types.js +1 -0
  367. package/components/graph/svelvet/edges/views/Edges/BaseEdge.svelte +105 -0
  368. package/components/graph/svelvet/edges/views/Edges/BaseEdge.svelte.d.ts +18 -0
  369. package/components/graph/svelvet/edges/views/Edges/EdgeAnchor.svelte +12 -0
  370. package/components/graph/svelvet/edges/views/Edges/EdgeAnchor.svelte.d.ts +17 -0
  371. package/components/graph/svelvet/edges/views/Edges/EdgeText.svelte +43 -0
  372. package/components/graph/svelvet/edges/views/Edges/EdgeText.svelte.d.ts +17 -0
  373. package/components/graph/svelvet/edges/views/Edges/SimpleBezierEdge.svelte +137 -0
  374. package/components/graph/svelvet/edges/views/Edges/SimpleBezierEdge.svelte.d.ts +17 -0
  375. package/components/graph/svelvet/edges/views/Edges/SmoothStepEdge.svelte +176 -0
  376. package/components/graph/svelvet/edges/views/Edges/SmoothStepEdge.svelte.d.ts +60 -0
  377. package/components/graph/svelvet/edges/views/Edges/StepEdge.svelte +8 -0
  378. package/components/graph/svelvet/edges/views/Edges/StepEdge.svelte.d.ts +25 -0
  379. package/components/graph/svelvet/edges/views/Edges/types.d.ts +52 -0
  380. package/components/graph/svelvet/edges/views/Edges/types.js +1 -0
  381. package/components/graph/svelvet/edges/views/Edges/utils.d.ts +33 -0
  382. package/components/graph/svelvet/edges/views/Edges/utils.js +31 -0
  383. package/components/graph/svelvet/editEdges/views/EditEdge.svelte +151 -0
  384. package/components/graph/svelvet/editEdges/views/EditEdge.svelte.d.ts +20 -0
  385. package/components/graph/svelvet/nodes/controllers/util.d.ts +9 -0
  386. package/components/graph/svelvet/nodes/controllers/util.js +13 -0
  387. package/components/graph/svelvet/nodes/models/Node.d.ts +78 -0
  388. package/components/graph/svelvet/nodes/models/Node.js +195 -0
  389. package/components/graph/svelvet/nodes/views/EditNode.svelte +147 -0
  390. package/components/graph/svelvet/nodes/views/EditNode.svelte.d.ts +33 -0
  391. package/components/graph/svelvet/nodes/views/Node.svelte +85 -0
  392. package/components/graph/svelvet/nodes/views/Node.svelte.d.ts +22 -0
  393. package/components/graph/svelvet/resizableNodes/controllers/util.d.ts +11 -0
  394. package/components/graph/svelvet/resizableNodes/controllers/util.js +24 -0
  395. package/components/graph/svelvet/resizableNodes/models/ResizeNode.d.ts +33 -0
  396. package/components/graph/svelvet/resizableNodes/models/ResizeNode.js +71 -0
  397. package/components/graph/svelvet/resizableNodes/views/ResizeNode.svelte +81 -0
  398. package/components/graph/svelvet/resizableNodes/views/ResizeNode.svelte.d.ts +20 -0
  399. package/components/graph/svelvet/store/controllers/storeApi.d.ts +32 -0
  400. package/components/graph/svelvet/store/controllers/storeApi.js +111 -0
  401. package/components/graph/svelvet/store/controllers/userApi.d.ts +3 -0
  402. package/components/graph/svelvet/store/controllers/userApi.js +18 -0
  403. package/components/graph/svelvet/store/controllers/util.d.ts +31 -0
  404. package/components/graph/svelvet/store/controllers/util.js +180 -0
  405. package/components/graph/svelvet/store/models/store.d.ts +12 -0
  406. package/components/graph/svelvet/store/models/store.js +9 -0
  407. package/components/graph/svelvet/store/types/types.d.ts +134 -0
  408. package/components/graph/svelvet/store/types/types.js +1 -0
  409. package/components/graph/svelvet/types/README.md +3 -0
  410. package/components/graph/svelvet/types/index.d.ts +2 -0
  411. package/components/graph/svelvet/types/index.js +1 -0
  412. package/components/graph/svelvet/types/types.d.ts +49 -0
  413. package/components/graph/svelvet/types/types.js +18 -0
  414. package/components/graph/util.js +2 -2
  415. package/components/home/ItemsList.svelte +53 -5
  416. package/components/home/ItemsList.svelte.d.ts +1 -0
  417. package/components/home/ListFilters.svelte +7 -2
  418. package/components/jobs/JobDetail.svelte +12 -1
  419. package/components/propertyPicker/ObjectViewer.svelte +6 -4
  420. package/components/sidebar/SidebarContent.svelte +2 -2
  421. package/consts.d.ts +1 -0
  422. package/consts.js +1 -0
  423. package/defaults.d.ts +4 -0
  424. package/defaults.js +4 -0
  425. package/history.d.ts +9 -0
  426. package/history.js +63 -0
  427. package/package.json +87 -9
  428. package/script_helpers.d.ts +1 -1
  429. package/script_helpers.js +1 -0
  430. package/scripts.d.ts +1 -1
  431. package/scripts.js +8 -1
  432. package/utils.d.ts +9 -4
  433. package/utils.js +43 -8
  434. package/components/apps/editor/TablePanel.svelte +0 -19
  435. package/components/apps/editor/TablePanel.svelte.d.ts +0 -17
  436. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte +0 -85
  437. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte.d.ts +0 -18
  438. package/components/flows/map/FlowBranchAllMap.svelte +0 -100
  439. package/components/flows/map/FlowBranchAllMap.svelte.d.ts +0 -17
  440. package/components/flows/map/FlowBranchOneMap.svelte +0 -124
  441. package/components/flows/map/FlowBranchOneMap.svelte.d.ts +0 -17
@@ -69,14 +69,14 @@ return {
69
69
  },
70
70
  displaycomponent: {
71
71
  deno: `export async function main() {
72
- return {
73
- "foo": 42
74
- }
72
+ return {
73
+ "foo": 42
74
+ }
75
75
  }`,
76
76
  python3: `def main():
77
- return {
78
- "foo": 42
79
- }`
77
+ return {
78
+ "foo": 42
79
+ }`
80
80
  },
81
81
  htmlcomponent: {
82
82
  deno: `export async function main() {
@@ -4,7 +4,10 @@ const layout = {
4
4
  'tabscomponent',
5
5
  'containercomponent',
6
6
  'horizontaldividercomponent',
7
- 'verticaldividercomponent'
7
+ 'verticaldividercomponent',
8
+ 'drawercomponent',
9
+ 'verticalsplitpanescomponent',
10
+ 'horizontalsplitpanescomponent'
8
11
  ]
9
12
  };
10
13
  const buttons = {
@@ -16,6 +19,7 @@ const inputs = {
16
19
  components: [
17
20
  'textinputcomponent',
18
21
  'passwordinputcomponent',
22
+ 'emailinputcomponent',
19
23
  'numberinputcomponent',
20
24
  'currencycomponent',
21
25
  'slidercomponent',
@@ -23,7 +27,9 @@ const inputs = {
23
27
  'dateinputcomponent',
24
28
  'fileinputcomponent',
25
29
  'checkboxcomponent',
26
- 'selectcomponent'
30
+ 'selectcomponent',
31
+ 'resourceselectcomponent',
32
+ 'multiselectcomponent',
27
33
  ]
28
34
  };
29
35
  const display = {
@@ -32,6 +38,7 @@ const display = {
32
38
  'textcomponent',
33
39
  'iconcomponent',
34
40
  'imagecomponent',
41
+ 'mapcomponent',
35
42
  'htmlcomponent',
36
43
  'tablecomponent',
37
44
  'aggridcomponent',
@@ -41,7 +48,8 @@ const display = {
41
48
  'plotlycomponent',
42
49
  'scatterchartcomponent',
43
50
  'timeseriescomponent',
44
- 'displaycomponent',
51
+ 'pdfcomponent',
52
+ 'displaycomponent'
45
53
  ]
46
54
  };
47
55
  export const COMPONENT_SETS = [layout, buttons, inputs, display];
@@ -1,42 +1,85 @@
1
- <script>import { getContext, onMount } from 'svelte';
2
- import { isOpenStore } from './store';
1
+ <script>import { getContext } from 'svelte';
2
+ import { fade, slide } from 'svelte/transition';
3
3
  import { dirtyStore } from '../../../common/confirmationModal/dirtyStore';
4
4
  import { components as componentsRecord, COMPONENT_SETS } from '../component';
5
5
  import ListItem from './ListItem.svelte';
6
6
  import { insertNewGridItem } from '../appUtils';
7
- const TITLE_PREFIX = 'Component.';
8
- const { app, selectedComponent, focusedGrid } = getContext('AppEditorContext');
7
+ import { X } from 'lucide-svelte';
8
+ import { push } from '../../../../history';
9
+ import { flip } from 'svelte/animate';
10
+ const { app, selectedComponent, focusedGrid } = getContext('AppViewerContext');
11
+ const { history } = getContext('AppEditorContext');
9
12
  function addComponent(appComponentType) {
13
+ push(history, $app);
10
14
  $dirtyStore = true;
11
15
  const data = componentsRecord[appComponentType].data;
12
16
  const id = insertNewGridItem($app, data, $focusedGrid);
13
17
  $selectedComponent = id;
14
18
  }
15
- onMount(() => {
16
- isOpenStore.addItems(COMPONENT_SETS.map((set) => ({ [TITLE_PREFIX + set.title]: true })));
17
- });
19
+ let search = '';
20
+ // Filter COMPONENT_SETS by search
21
+ $: componentsFiltered = COMPONENT_SETS.map((set) => ({
22
+ ...set,
23
+ components: set.components.filter((component) => {
24
+ const name = componentsRecord[component].name.toLowerCase();
25
+ return name.includes(search.toLowerCase());
26
+ })
27
+ }));
18
28
  </script>
19
29
 
20
- {#each COMPONENT_SETS as { title, components }, index (index)}
21
- <ListItem {title} prefix={TITLE_PREFIX}>
22
- {#if components.length}
23
- <div class="flex flex-wrap gap-2 py-2">
24
- {#each components as item}
25
- <button
26
- on:click={() => addComponent(item)}
27
- title={componentsRecord[item].name}
28
- class="border w-24 shadow-sm h-16 p-2 flex flex-col gap-2 items-center
29
- justify-center bg-white rounded-md hover:bg-gray-100 duration-200"
30
- >
31
- <svelte:component this={componentsRecord[item].icon} />
32
- <div class="text-xs w-full text-center ellipsize">
33
- {componentsRecord[item].name}
34
- </div>
35
- </button>
36
- {/each}
37
- </div>
38
- {:else}
39
- <div class="text-xs text-gray-500 py-1 px-2"> There are no components in this group yet </div>
30
+ <section class="p-2 sticky bg-white w-full z-20 top-0">
31
+ <div class="relative">
32
+ <input
33
+ bind:value={search}
34
+ class="px-2 py-1 border border-gray-300 rounded-sm {search ? 'pr-8' : ''}"
35
+ placeholder="Search components..."
36
+ />
37
+ {#if search}
38
+ <button
39
+ class="absolute right-2 top-1/2 transform -translate-y-1/2 hover:bg-gray-200 rounded-full p-0.5"
40
+ on:click|stopPropagation|preventDefault={() => (search = '')}
41
+ >
42
+ <X size="14" />
43
+ </button>
40
44
  {/if}
41
- </ListItem>
42
- {/each}
45
+ </div>
46
+ </section>
47
+
48
+ <div class="relative">
49
+ {#if componentsFiltered.reduce((acc, { components }) => acc + components.length, 0) === 0}
50
+ <div
51
+ in:fade|local={{ duration: 50, delay: 50 }}
52
+ out:fade|local={{ duration: 50 }}
53
+ class="absolute left-0 top-0 w-full text-sm text-gray-500 text-center py-6 px-2"
54
+ >
55
+ No components found
56
+ </div>
57
+ {:else}
58
+ <div in:fade|local={{ duration: 50, delay: 50 }} out:fade|local={{ duration: 50 }}>
59
+ {#each componentsFiltered as { title, components }, index (index)}
60
+ {#if components.length}
61
+ <div transition:slide|local={{ duration: 300 }}>
62
+ <ListItem title={`${title} (${components.length})`}>
63
+ <div class="flex flex-wrap gap-2 py-2">
64
+ {#each components as item (item)}
65
+ <button
66
+ animate:flip={{ duration: 300 }}
67
+ on:click={() => addComponent(item)}
68
+ title={componentsRecord[item].name}
69
+ class="border w-24 shadow-sm h-16 p-2 flex flex-col gap-2 items-center
70
+ justify-center bg-white rounded-md hover:bg-gray-100 duration-200"
71
+ >
72
+ <svelte:component this={componentsRecord[item].icon} />
73
+ <div class="text-xs w-full text-center ellipsize">
74
+ {componentsRecord[item].name}
75
+ </div>
76
+ </button>
77
+ {/each}
78
+ </div>
79
+ </ListItem>
80
+ </div>
81
+ {/if}
82
+ {/each}
83
+ </div>
84
+ {/if}
85
+ </div>
@@ -1,31 +1,67 @@
1
- <script>export let name;
1
+ <script>import { X } from 'lucide-svelte';
2
+ import { fade } from 'svelte/transition';
3
+ import { addWhitespaceBeforeCapitals } from '../../../../utils';
4
+ export let name;
2
5
  export let value;
6
+ function reset(property) {
7
+ if (value) {
8
+ value[property] = '';
9
+ }
10
+ }
3
11
  </script>
4
12
 
5
13
  <div class="text-sm font-semibold text-gray-500 capitalize pt-2">
6
- {name}
14
+ {addWhitespaceBeforeCapitals(name)}
7
15
  </div>
8
16
  {#if value}
9
17
  <div class="border-l border-gray-400/80 py-1 pl-3.5 mt-1 ml-0.5">
10
- <label class="block pb-2">
11
- <div class="text-xs font-medium pb-0.5">
12
- Style
13
- </div>
14
- <input
15
- type="text"
16
- bind:value={value.style}
17
- on:focus
18
- />
19
- </label>
20
- <label class="block">
21
- <div class="text-xs font-medium pb-0.5">
22
- Tailwind classes
23
- </div>
24
- <input
25
- type="text"
26
- bind:value={value.class}
27
- on:focus
28
- />
29
- </label>
18
+ {#if value.style !== undefined}
19
+ <label class="block pb-2">
20
+ <div class="text-xs font-medium pb-0.5"> Style </div>
21
+ <div class="relative">
22
+ <input
23
+ on:keydown|stopPropagation
24
+ type="text"
25
+ class="!pr-7"
26
+ bind:value={value.style}
27
+ on:focus
28
+ />
29
+ {#if value?.style}
30
+ <button
31
+ transition:fade|local={{ duration: 100 }}
32
+ class="absolute z-10 top-1.5 right-1 rounded-full p-1 duration-200 hover:bg-gray-200"
33
+ aria-label="Remove styles"
34
+ on:click|preventDefault|stopPropagation={() => reset('style')}
35
+ >
36
+ <X size={14} />
37
+ </button>
38
+ {/if}
39
+ </div>
40
+ </label>
41
+ {/if}
42
+ {#if value.class !== undefined}
43
+ <label class="block">
44
+ <div class="text-xs font-medium pb-0.5"> Tailwind classes </div>
45
+ <div class="relative">
46
+ <input
47
+ on:keydown|stopPropagation
48
+ type="text"
49
+ class="!pr-7"
50
+ bind:value={value.class}
51
+ on:focus
52
+ />
53
+ {#if value?.class}
54
+ <button
55
+ transition:fade|local={{ duration: 100 }}
56
+ class="absolute z-10 top-1.5 right-1 rounded-full p-1 duration-200 hover:bg-gray-200"
57
+ aria-label="Remove classes"
58
+ on:click|preventDefault|stopPropagation={() => reset('class')}
59
+ >
60
+ <X size={14} />
61
+ </button>
62
+ {/if}
63
+ </div>
64
+ </label>
65
+ {/if}
30
66
  </div>
31
- {/if}
67
+ {/if}
@@ -1,11 +1,12 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
- import type { ComponentCssProperty } from "../../types";
2
+ import type { ComponentCssProperty } from '../../types';
3
3
  declare const __propDef: {
4
4
  props: {
5
5
  name: string;
6
6
  value: ComponentCssProperty | undefined;
7
7
  };
8
8
  events: {
9
+ keydown: KeyboardEvent;
9
10
  focus: FocusEvent;
10
11
  } & {
11
12
  [evt: string]: CustomEvent<any>;
@@ -7,8 +7,11 @@ import ListItem from './ListItem.svelte';
7
7
  import { isOpenStore } from './store';
8
8
  import CssProperty from './CssProperty.svelte';
9
9
  import { components } from '../component';
10
+ import { slide } from 'svelte/transition';
11
+ const STATIC_ELEMENTS = ['app'];
10
12
  const TITLE_PREFIX = 'Css.';
11
- const { app } = getContext('AppEditorContext');
13
+ const SHOW_UNUSED_ID = 'Setting.ShowUnused';
14
+ const { app } = getContext('AppViewerContext');
12
15
  let rawCode = '';
13
16
  let viewJsonSchema = false;
14
17
  $: rawCode && parseJson();
@@ -54,7 +57,7 @@ entries.forEach((e) => {
54
57
  }
55
58
  e.ids.forEach((id) => {
56
59
  if (!newCss[e.type][id]) {
57
- newCss[e.type][id] = { style: '', class: '' };
60
+ newCss[e.type][id] = components?.[e.type]?.data?.customCss?.[id] ?? { class: '', style: '' };
58
61
  }
59
62
  });
60
63
  e.ids
@@ -67,18 +70,25 @@ entries.forEach((e) => {
67
70
  });
68
71
  //@ts-ignore
69
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
+ });
70
83
  onMount(() => {
71
- isOpenStore.addItems([{ name: 'App' }, ...Object.values(components)].map(component => {
84
+ isOpenStore.addItems([{ name: 'App' }, ...Object.values(components)].map((component) => {
72
85
  return { [TITLE_PREFIX + component.name]: false };
73
86
  }));
87
+ isOpenStore.addItems([{ [SHOW_UNUSED_ID]: false }]);
74
88
  });
75
89
  </script>
76
90
 
77
- <Tabs
78
- selected="ui"
79
- on:selected={(e) => switchTab(e.detail === 'json')}
80
- class="relative"
81
- >
91
+ <Tabs selected="ui" on:selected={(e) => switchTab(e.detail === 'json')} class="relative">
82
92
  <Tab value="ui" size="xs" class="grow">
83
93
  <div class="m-1 center-center">
84
94
  <MousePointer2 size={16} />
@@ -93,7 +103,7 @@ onMount(() => {
93
103
  </Tab>
94
104
  <div slot="content" class="h-full overflow-y-auto">
95
105
  <TabContent value="ui">
96
- {#each entries as { type, name, icon, ids }}
106
+ {#each [...staticComponents, ...usedComponents] as { type, name, icon, ids }}
97
107
  {#if ids.length > 0}
98
108
  <ListItem title={name} prefix={TITLE_PREFIX}>
99
109
  <div slot="title" class="flex items-center">
@@ -118,6 +128,43 @@ onMount(() => {
118
128
  </ListItem>
119
129
  {/if}
120
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}
121
168
  </TabContent>
122
169
  <TabContent value="json">
123
170
  {#if !emptyString(jsonError)}
@@ -2,26 +2,37 @@
2
2
  import { ChevronDown } from 'lucide-svelte';
3
3
  import { isOpenStore } from './store';
4
4
  export let title;
5
- export let prefix = '';
5
+ export let prefix = undefined;
6
6
  $: storeTitle = prefix + title;
7
- $: isOpen = $isOpenStore[storeTitle];
7
+ $: isOpen = prefix ? $isOpenStore[storeTitle] : true;
8
8
  </script>
9
9
 
10
- <section class="mt-1 mb-2 px-1">
11
- <button
12
- on:click|preventDefault={() => isOpenStore.toggle(storeTitle)}
13
- class="w-full flex justify-between items-center text-gray-700 px-2 py-1
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
14
15
  rounded-sm duration-200 hover:bg-gray-100"
15
- >
16
- <h1 class="text-sm font-semibold text-left">
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">
17
31
  <slot name="title">
18
32
  {title}
19
33
  </slot>
20
34
  </h1>
21
- <ChevronDown class="rotate-0 duration-300 {isOpen ? '!rotate-180' : ''}" />
22
- </button>
23
- {#if isOpen}
24
- <div transition:slide|local={{ duration: 300 }} class="px-2">
35
+ <div class="px-2">
25
36
  <slot />
26
37
  </div>
27
38
  {/if}
@@ -1,5 +1,6 @@
1
1
  export declare const staticValues: {
2
2
  readonly buttonColorOptions: ("none" | "blue" | "gray" | "red" | "green" | "dark" | "light")[];
3
+ readonly tabsKindOptions: readonly ["tabs", "sidebar", "invisibleOnView"];
3
4
  readonly buttonSizeOptions: readonly ["xs", "sm", "md", "lg", "xl"];
4
5
  readonly tableSearchOptions: readonly ["By Component", "By Runnable", "Disabled"];
5
6
  readonly chartThemeOptions: readonly ["theme1", "theme2", "theme3"];
@@ -7,4 +8,5 @@ export declare const staticValues: {
7
8
  readonly currencyOptions: readonly ["USD", "EUR", "GBP", "CAD", "AUD", "JPY", "CNY", "INR", "BRL"];
8
9
  readonly localeOptions: readonly ["en-US", "en-GB", "en-IE", "de-DE", "fr-FR", "br-FR", "ja-JP", "pt-TL", "fr-CA", "en-CA"];
9
10
  readonly objectFitOptions: readonly ["contain", "cover", "fill"];
11
+ readonly splitPanelOptions: readonly ["2", "3", "4"];
10
12
  };
@@ -2,11 +2,24 @@ import { BUTTON_COLORS } from '../../../common';
2
2
  const buttonColorOptions = [...BUTTON_COLORS];
3
3
  export const staticValues = {
4
4
  buttonColorOptions,
5
+ tabsKindOptions: ['tabs', 'sidebar', 'invisibleOnView'],
5
6
  buttonSizeOptions: ['xs', 'sm', 'md', 'lg', 'xl'],
6
7
  tableSearchOptions: ['By Component', 'By Runnable', 'Disabled'],
7
8
  chartThemeOptions: ['theme1', 'theme2', 'theme3'],
8
9
  textStyleOptions: ['Title', 'Subtitle', 'Body', 'Label', 'Caption'],
9
10
  currencyOptions: ['USD', 'EUR', 'GBP', 'CAD', 'AUD', 'JPY', 'CNY', 'INR', 'BRL'],
10
- localeOptions: ['en-US', 'en-GB', 'en-IE', 'de-DE', 'fr-FR', 'br-FR', 'ja-JP', 'pt-TL', 'fr-CA', 'en-CA'],
11
- objectFitOptions: ['contain', 'cover', 'fill']
11
+ localeOptions: [
12
+ 'en-US',
13
+ 'en-GB',
14
+ 'en-IE',
15
+ 'de-DE',
16
+ 'fr-FR',
17
+ 'br-FR',
18
+ 'ja-JP',
19
+ 'pt-TL',
20
+ 'fr-CA',
21
+ 'en-CA'
22
+ ],
23
+ objectFitOptions: ['contain', 'cover', 'fill'],
24
+ splitPanelOptions: ['2', '3', '4']
12
25
  };
@@ -0,0 +1,77 @@
1
+ <script>import { components } from '../component';
2
+ import { getContext } from 'svelte';
3
+ import ComponentOutputViewer from './ComponentOutputViewer.svelte';
4
+ import { connectInput, isIdInsideGriditem } from '../appUtils';
5
+ import SubGridOutput from './SubGridOutput.svelte';
6
+ import OutputHeader from './components/OutputHeader.svelte';
7
+ import TableActionsOutput from './components/TableActionsOutput.svelte';
8
+ export let gridItem;
9
+ export let first = false;
10
+ export let nested = false;
11
+ export let parentId = undefined;
12
+ export let expanded = false;
13
+ const { app, staticOutputs, selectedComponent, connectingInput } = getContext('AppViewerContext');
14
+ const name = getComponentNameById(gridItem.id);
15
+ function getComponentNameById(componentId) {
16
+ if (gridItem?.data?.type) {
17
+ return components[gridItem?.data.type].name;
18
+ }
19
+ else if (componentId == 'ctx') {
20
+ return 'Context';
21
+ }
22
+ else if (componentId.startsWith('bg_')) {
23
+ return 'Background';
24
+ }
25
+ else {
26
+ return 'Table action';
27
+ }
28
+ }
29
+ $: subGrids = Array.from({ length: gridItem.data.numberOfSubgrids }).map((_, i) => `${gridItem.id}-${i}`);
30
+ $: insideGrid = isIdInsideGriditem($app, gridItem, $selectedComponent);
31
+ $: isSelected = $selectedComponent === gridItem.id;
32
+ $: shouldOpen = insideGrid || isSelected;
33
+ function onHeaderClick(manuallyOpen) {
34
+ if (manuallyOpen) {
35
+ if (parentId) {
36
+ $selectedComponent = parentId;
37
+ }
38
+ else {
39
+ $selectedComponent = undefined;
40
+ }
41
+ }
42
+ else {
43
+ $selectedComponent = gridItem.id;
44
+ }
45
+ }
46
+ </script>
47
+
48
+ {#if $staticOutputs[gridItem.id] || gridItem.data.numberOfSubgrids > 1}
49
+ <OutputHeader
50
+ {shouldOpen}
51
+ on:handleClick={(e) => {
52
+ if (!$connectingInput.opened) {
53
+ onHeaderClick(e.detail.manuallyOpen)
54
+ }
55
+ }}
56
+ id={gridItem.id}
57
+ name={getComponentNameById(gridItem.id)}
58
+ {first}
59
+ {nested}
60
+ {expanded}
61
+ >
62
+ <div class="py-1">
63
+ <ComponentOutputViewer
64
+ componentId={gridItem.id}
65
+ outputs={$staticOutputs[gridItem.id]}
66
+ on:select={({ detail }) => {
67
+ if ($connectingInput.opened) {
68
+ $connectingInput = connectInput($connectingInput, gridItem.id, detail)
69
+ }
70
+ }}
71
+ />
72
+ </div>
73
+
74
+ <SubGridOutput {name} {expanded} {subGrids} parentId={gridItem.id} />
75
+ <TableActionsOutput {gridItem} {expanded} />
76
+ </OutputHeader>
77
+ {/if}
@@ -0,0 +1,21 @@
1
+ import { SvelteComponentTyped } from "svelte";
2
+ import type { GridItem } from '../../types';
3
+ declare const __propDef: {
4
+ props: {
5
+ gridItem: GridItem;
6
+ first?: boolean | undefined;
7
+ nested?: boolean | undefined;
8
+ parentId?: string | undefined;
9
+ expanded?: boolean | undefined;
10
+ };
11
+ events: {
12
+ [evt: string]: CustomEvent<any>;
13
+ };
14
+ slots: {};
15
+ };
16
+ export type ComponentOutputProps = typeof __propDef.props;
17
+ export type ComponentOutputEvents = typeof __propDef.events;
18
+ export type ComponentOutputSlots = typeof __propDef.slots;
19
+ export default class ComponentOutput extends SvelteComponentTyped<ComponentOutputProps, ComponentOutputEvents, ComponentOutputSlots> {
20
+ }
21
+ export {};
@@ -1,14 +1,17 @@
1
1
  <script>import ObjectViewer from '../../../propertyPicker/ObjectViewer.svelte';
2
2
  import { getContext } from 'svelte';
3
+ import { recursivelyFilterKeyInJSON } from '../appUtils';
3
4
  export let outputs = [];
4
5
  export let componentId;
5
- const { worldStore } = getContext('AppEditorContext');
6
+ const { worldStore } = getContext('AppViewerContext');
7
+ const { search } = getContext('searchCtx');
6
8
  let object = {};
7
9
  function subscribeToAllOutputs(observableOutputs) {
8
10
  if (observableOutputs) {
9
- outputs.forEach((output) => {
11
+ outputs?.forEach((output) => {
10
12
  object[output] = undefined;
11
13
  observableOutputs[output]?.subscribe({
14
+ id: 'alloutputs' + output,
12
15
  next: (value) => {
13
16
  object[output] = value;
14
17
  }
@@ -18,10 +21,11 @@ function subscribeToAllOutputs(observableOutputs) {
18
21
  }
19
22
  $: $worldStore?.outputsById[componentId] &&
20
23
  subscribeToAllOutputs($worldStore.outputsById[componentId]);
24
+ $: filtered = recursivelyFilterKeyInJSON(object, $search, componentId);
21
25
  </script>
22
26
 
23
- {#if Object.keys(object).length > 0}
24
- <ObjectViewer json={object} on:select topBrackets={false} />
25
- {:else}
26
- <div class="text-xs text-gray-500 px-4">No outputs</div>
27
+ {#if Object.keys(filtered).length > 0}
28
+ <ObjectViewer json={filtered} on:select topBrackets={false} />
29
+ {:else if $search.length > 0}
30
+ <div class="text-xs pl-2">No results</div>
27
31
  {/if}