@flowdrop/flowdrop 1.0.1 → 1.2.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 (385) hide show
  1. package/README.md +50 -50
  2. package/dist/adapters/WorkflowAdapter.d.ts +1 -1
  3. package/dist/adapters/WorkflowAdapter.js +25 -25
  4. package/dist/adapters/agentspec/AgentSpecAdapter.d.ts +2 -2
  5. package/dist/adapters/agentspec/AgentSpecAdapter.js +133 -122
  6. package/dist/adapters/agentspec/agentAdapter.d.ts +2 -2
  7. package/dist/adapters/agentspec/agentAdapter.js +10 -10
  8. package/dist/adapters/agentspec/autoLayout.d.ts +1 -1
  9. package/dist/adapters/agentspec/autoLayout.js +2 -2
  10. package/dist/adapters/agentspec/componentTypeDefaults.d.ts +1 -1
  11. package/dist/adapters/agentspec/componentTypeDefaults.js +120 -120
  12. package/dist/adapters/agentspec/defaultNodeTypes.d.ts +2 -2
  13. package/dist/adapters/agentspec/defaultNodeTypes.js +307 -307
  14. package/dist/adapters/agentspec/index.d.ts +10 -10
  15. package/dist/adapters/agentspec/index.js +6 -6
  16. package/dist/adapters/agentspec/validator.d.ts +2 -2
  17. package/dist/adapters/agentspec/validator.js +22 -20
  18. package/dist/api/enhanced-client.d.ts +3 -3
  19. package/dist/api/enhanced-client.js +73 -72
  20. package/dist/components/App.svelte +1090 -961
  21. package/dist/components/App.svelte.d.ts +9 -6
  22. package/dist/components/CanvasBanner.stories.svelte +23 -20
  23. package/dist/components/CanvasBanner.stories.svelte.d.ts +1 -1
  24. package/dist/components/CanvasBanner.svelte +52 -46
  25. package/dist/components/ConfigForm.svelte +1164 -1065
  26. package/dist/components/ConfigForm.svelte.d.ts +2 -2
  27. package/dist/components/ConfigModal.svelte +180 -180
  28. package/dist/components/ConfigModal.svelte.d.ts +1 -1
  29. package/dist/components/ConfigPanel.stories.svelte +35 -35
  30. package/dist/components/ConfigPanel.stories.svelte.d.ts +1 -1
  31. package/dist/components/ConfigPanel.svelte +178 -167
  32. package/dist/components/ConfigPanel.svelte.d.ts +1 -1
  33. package/dist/components/ConnectionLine.svelte +25 -25
  34. package/dist/components/EdgeRefresher.svelte +26 -26
  35. package/dist/components/FlowDropEdge.stories.svelte +179 -143
  36. package/dist/components/FlowDropEdge.svelte +147 -147
  37. package/dist/components/FlowDropEdge.svelte.d.ts +1 -1
  38. package/dist/components/FlowDropZone.svelte +63 -60
  39. package/dist/components/FlowDropZone.svelte.d.ts +1 -1
  40. package/dist/components/LoadingSpinner.stories.svelte +19 -19
  41. package/dist/components/LoadingSpinner.stories.svelte.d.ts +1 -1
  42. package/dist/components/LoadingSpinner.svelte +21 -21
  43. package/dist/components/LoadingSpinner.svelte.d.ts +1 -1
  44. package/dist/components/Logo.stories.svelte +13 -13
  45. package/dist/components/Logo.stories.svelte.d.ts +1 -1
  46. package/dist/components/Logo.svelte +101 -95
  47. package/dist/components/LogsSidebar.svelte +553 -546
  48. package/dist/components/LogsSidebar.svelte.d.ts +1 -1
  49. package/dist/components/MarkdownDisplay.stories.svelte +29 -23
  50. package/dist/components/MarkdownDisplay.stories.svelte.d.ts +1 -1
  51. package/dist/components/MarkdownDisplay.svelte +16 -14
  52. package/dist/components/Navbar.stories.svelte +43 -38
  53. package/dist/components/Navbar.stories.svelte.d.ts +1 -1
  54. package/dist/components/Navbar.svelte +760 -706
  55. package/dist/components/Navbar.svelte.d.ts +1 -1
  56. package/dist/components/NodeSidebar.svelte +905 -746
  57. package/dist/components/NodeSidebar.svelte.d.ts +5 -1
  58. package/dist/components/NodeStatusOverlay.stories.svelte +82 -70
  59. package/dist/components/NodeStatusOverlay.stories.svelte.d.ts +1 -1
  60. package/dist/components/NodeStatusOverlay.svelte +295 -280
  61. package/dist/components/NodeStatusOverlay.svelte.d.ts +3 -3
  62. package/dist/components/PipelineStatus.svelte +326 -300
  63. package/dist/components/PipelineStatus.svelte.d.ts +4 -4
  64. package/dist/components/PortCoordinateTracker.svelte +49 -47
  65. package/dist/components/PortCoordinateTracker.svelte.d.ts +1 -1
  66. package/dist/components/ReadOnlyDetails.svelte +156 -156
  67. package/dist/components/SchemaForm.stories.svelte +106 -98
  68. package/dist/components/SchemaForm.stories.svelte.d.ts +1 -1
  69. package/dist/components/SchemaForm.svelte +490 -463
  70. package/dist/components/SchemaForm.svelte.d.ts +2 -2
  71. package/dist/components/SettingsModal.svelte +226 -223
  72. package/dist/components/SettingsModal.svelte.d.ts +1 -1
  73. package/dist/components/SettingsPanel.svelte +637 -601
  74. package/dist/components/SettingsPanel.svelte.d.ts +1 -1
  75. package/dist/components/StatusIcon.stories.svelte +62 -49
  76. package/dist/components/StatusIcon.stories.svelte.d.ts +1 -1
  77. package/dist/components/StatusIcon.svelte +87 -87
  78. package/dist/components/StatusIcon.svelte.d.ts +2 -2
  79. package/dist/components/StatusLabel.stories.svelte +12 -12
  80. package/dist/components/StatusLabel.stories.svelte.d.ts +1 -1
  81. package/dist/components/StatusLabel.svelte +19 -19
  82. package/dist/components/ThemeToggle.stories.svelte +16 -16
  83. package/dist/components/ThemeToggle.stories.svelte.d.ts +1 -1
  84. package/dist/components/ThemeToggle.svelte +180 -169
  85. package/dist/components/ThemeToggle.svelte.d.ts +1 -1
  86. package/dist/components/UniversalNode.svelte +150 -138
  87. package/dist/components/UniversalNode.svelte.d.ts +3 -3
  88. package/dist/components/WorkflowEditor.svelte +1069 -1014
  89. package/dist/components/WorkflowEditor.svelte.d.ts +4 -4
  90. package/dist/components/form/FormArray.svelte +1034 -973
  91. package/dist/components/form/FormArray.svelte.d.ts +1 -1
  92. package/dist/components/form/FormAutocomplete.svelte +1021 -978
  93. package/dist/components/form/FormAutocomplete.svelte.d.ts +1 -1
  94. package/dist/components/form/FormCheckboxGroup.stories.svelte +23 -20
  95. package/dist/components/form/FormCheckboxGroup.stories.svelte.d.ts +1 -1
  96. package/dist/components/form/FormCheckboxGroup.svelte +136 -136
  97. package/dist/components/form/FormCodeEditor.svelte +452 -434
  98. package/dist/components/form/FormField.svelte +366 -355
  99. package/dist/components/form/FormField.svelte.d.ts +2 -2
  100. package/dist/components/form/FormFieldLight.svelte +400 -384
  101. package/dist/components/form/FormFieldLight.svelte.d.ts +1 -1
  102. package/dist/components/form/FormFieldWrapper.stories.svelte +42 -42
  103. package/dist/components/form/FormFieldWrapper.stories.svelte.d.ts +1 -1
  104. package/dist/components/form/FormFieldWrapper.svelte +100 -93
  105. package/dist/components/form/FormFieldWrapper.svelte.d.ts +1 -1
  106. package/dist/components/form/FormFieldset.svelte +108 -108
  107. package/dist/components/form/FormFieldset.svelte.d.ts +2 -2
  108. package/dist/components/form/FormMarkdownEditor.svelte +758 -725
  109. package/dist/components/form/FormNumberField.stories.svelte +25 -25
  110. package/dist/components/form/FormNumberField.stories.svelte.d.ts +1 -1
  111. package/dist/components/form/FormNumberField.svelte +88 -88
  112. package/dist/components/form/FormRangeField.stories.svelte +20 -20
  113. package/dist/components/form/FormRangeField.stories.svelte.d.ts +1 -1
  114. package/dist/components/form/FormRangeField.svelte +234 -226
  115. package/dist/components/form/FormSelect.stories.svelte +38 -38
  116. package/dist/components/form/FormSelect.stories.svelte.d.ts +1 -1
  117. package/dist/components/form/FormSelect.svelte +101 -101
  118. package/dist/components/form/FormSelect.svelte.d.ts +1 -1
  119. package/dist/components/form/FormTemplateEditor.svelte +847 -798
  120. package/dist/components/form/FormTemplateEditor.svelte.d.ts +1 -1
  121. package/dist/components/form/FormTextField.stories.svelte +29 -23
  122. package/dist/components/form/FormTextField.stories.svelte.d.ts +1 -1
  123. package/dist/components/form/FormTextField.svelte +68 -68
  124. package/dist/components/form/FormTextarea.stories.svelte +28 -25
  125. package/dist/components/form/FormTextarea.stories.svelte.d.ts +1 -1
  126. package/dist/components/form/FormTextarea.svelte +74 -74
  127. package/dist/components/form/FormToggle.stories.svelte +23 -20
  128. package/dist/components/form/FormToggle.stories.svelte.d.ts +1 -1
  129. package/dist/components/form/FormToggle.svelte +98 -98
  130. package/dist/components/form/FormUISchemaRenderer.svelte +120 -113
  131. package/dist/components/form/FormUISchemaRenderer.svelte.d.ts +3 -3
  132. package/dist/components/form/index.d.ts +19 -19
  133. package/dist/components/form/index.js +18 -18
  134. package/dist/components/form/templateAutocomplete.d.ts +2 -2
  135. package/dist/components/form/templateAutocomplete.js +64 -55
  136. package/dist/components/form/types.d.ts +6 -6
  137. package/dist/components/form/types.js +9 -4
  138. package/dist/components/icons/AlertCircleIcon.svelte +11 -0
  139. package/dist/components/icons/AlertCircleIcon.svelte.d.ts +26 -0
  140. package/dist/components/icons/CogIcon.svelte +11 -0
  141. package/dist/components/icons/CogIcon.svelte.d.ts +26 -0
  142. package/dist/components/interrupt/ChoicePrompt.stories.svelte +54 -38
  143. package/dist/components/interrupt/ChoicePrompt.stories.svelte.d.ts +1 -1
  144. package/dist/components/interrupt/ChoicePrompt.svelte +407 -383
  145. package/dist/components/interrupt/ChoicePrompt.svelte.d.ts +1 -1
  146. package/dist/components/interrupt/ConfirmationPrompt.stories.svelte +48 -48
  147. package/dist/components/interrupt/ConfirmationPrompt.stories.svelte.d.ts +1 -1
  148. package/dist/components/interrupt/ConfirmationPrompt.svelte +280 -274
  149. package/dist/components/interrupt/ConfirmationPrompt.svelte.d.ts +1 -1
  150. package/dist/components/interrupt/FormPrompt.svelte +223 -218
  151. package/dist/components/interrupt/FormPrompt.svelte.d.ts +1 -1
  152. package/dist/components/interrupt/InterruptBubble.svelte +617 -583
  153. package/dist/components/interrupt/InterruptBubble.svelte.d.ts +2 -2
  154. package/dist/components/interrupt/ReviewPrompt.stories.svelte +66 -56
  155. package/dist/components/interrupt/ReviewPrompt.stories.svelte.d.ts +1 -1
  156. package/dist/components/interrupt/ReviewPrompt.svelte +861 -841
  157. package/dist/components/interrupt/ReviewPrompt.svelte.d.ts +1 -1
  158. package/dist/components/interrupt/TextInputPrompt.stories.svelte +38 -33
  159. package/dist/components/interrupt/TextInputPrompt.stories.svelte.d.ts +1 -1
  160. package/dist/components/interrupt/TextInputPrompt.svelte +333 -328
  161. package/dist/components/interrupt/TextInputPrompt.svelte.d.ts +1 -1
  162. package/dist/components/interrupt/index.d.ts +5 -5
  163. package/dist/components/interrupt/index.js +5 -5
  164. package/dist/components/layouts/MainLayout.svelte +724 -691
  165. package/dist/components/layouts/MainLayout.svelte.d.ts +6 -6
  166. package/dist/components/nodes/GatewayNode.stories.svelte +100 -99
  167. package/dist/components/nodes/GatewayNode.svelte +605 -571
  168. package/dist/components/nodes/GatewayNode.svelte.d.ts +3 -3
  169. package/dist/components/nodes/IdeaNode.stories.svelte +44 -43
  170. package/dist/components/nodes/IdeaNode.svelte +451 -437
  171. package/dist/components/nodes/IdeaNode.svelte.d.ts +1 -1
  172. package/dist/components/nodes/NotesNode.stories.svelte +65 -64
  173. package/dist/components/nodes/NotesNode.svelte +380 -369
  174. package/dist/components/nodes/NotesNode.svelte.d.ts +1 -1
  175. package/dist/components/nodes/SimpleNode.stories.svelte +145 -144
  176. package/dist/components/nodes/SimpleNode.svelte +486 -424
  177. package/dist/components/nodes/SimpleNode.svelte.d.ts +1 -1
  178. package/dist/components/nodes/SquareNode.stories.svelte +73 -73
  179. package/dist/components/nodes/SquareNode.svelte +439 -380
  180. package/dist/components/nodes/SquareNode.svelte.d.ts +1 -1
  181. package/dist/components/nodes/TerminalNode.stories.svelte +13 -13
  182. package/dist/components/nodes/TerminalNode.svelte +709 -670
  183. package/dist/components/nodes/TerminalNode.svelte.d.ts +1 -1
  184. package/dist/components/nodes/ToolNode.stories.svelte +181 -180
  185. package/dist/components/nodes/ToolNode.svelte +505 -447
  186. package/dist/components/nodes/ToolNode.svelte.d.ts +1 -1
  187. package/dist/components/nodes/WorkflowNode.stories.svelte +70 -46
  188. package/dist/components/nodes/WorkflowNode.svelte +621 -551
  189. package/dist/components/nodes/WorkflowNode.svelte.d.ts +3 -3
  190. package/dist/components/playground/ChatPanel.svelte +945 -889
  191. package/dist/components/playground/ExecutionLogs.svelte +495 -472
  192. package/dist/components/playground/InputCollector.svelte +449 -428
  193. package/dist/components/playground/MessageBubble.stories.svelte +47 -47
  194. package/dist/components/playground/MessageBubble.stories.svelte.d.ts +1 -1
  195. package/dist/components/playground/MessageBubble.svelte +626 -610
  196. package/dist/components/playground/MessageBubble.svelte.d.ts +1 -1
  197. package/dist/components/playground/Playground.svelte +1088 -1057
  198. package/dist/components/playground/Playground.svelte.d.ts +3 -3
  199. package/dist/components/playground/PlaygroundModal.svelte +208 -204
  200. package/dist/components/playground/PlaygroundModal.svelte.d.ts +3 -3
  201. package/dist/components/playground/SessionManager.svelte +527 -521
  202. package/dist/components/playground/SessionManager.svelte.d.ts +1 -1
  203. package/dist/config/agentSpecEndpoints.d.ts +1 -1
  204. package/dist/config/agentSpecEndpoints.js +20 -20
  205. package/dist/config/constants.js +2 -2
  206. package/dist/config/defaultCategories.d.ts +1 -1
  207. package/dist/config/defaultCategories.js +86 -86
  208. package/dist/config/defaultPortConfig.d.ts +1 -1
  209. package/dist/config/defaultPortConfig.js +144 -144
  210. package/dist/config/endpoints.d.ts +4 -4
  211. package/dist/config/endpoints.js +65 -65
  212. package/dist/config/runtimeConfig.d.ts +2 -2
  213. package/dist/config/runtimeConfig.js +8 -8
  214. package/dist/core/index.d.ts +63 -59
  215. package/dist/core/index.js +35 -33
  216. package/dist/display/index.d.ts +2 -2
  217. package/dist/display/index.js +2 -2
  218. package/dist/editor/index.d.ts +62 -62
  219. package/dist/editor/index.js +53 -53
  220. package/dist/form/code.d.ts +5 -5
  221. package/dist/form/code.js +14 -14
  222. package/dist/form/fieldRegistry.d.ts +3 -3
  223. package/dist/form/fieldRegistry.js +11 -9
  224. package/dist/form/full.d.ts +8 -8
  225. package/dist/form/full.js +9 -9
  226. package/dist/form/index.d.ts +18 -18
  227. package/dist/form/index.js +16 -16
  228. package/dist/form/markdown.d.ts +4 -4
  229. package/dist/form/markdown.js +8 -8
  230. package/dist/helpers/proximityConnect.d.ts +3 -3
  231. package/dist/helpers/proximityConnect.js +34 -32
  232. package/dist/helpers/workflowEditorHelper.d.ts +5 -5
  233. package/dist/helpers/workflowEditorHelper.js +108 -96
  234. package/dist/index.d.ts +6 -6
  235. package/dist/index.js +6 -6
  236. package/dist/mocks/app-environment.js +2 -2
  237. package/dist/mocks/app-forms.js +9 -9
  238. package/dist/mocks/app-navigation.js +11 -11
  239. package/dist/mocks/app-stores.js +8 -8
  240. package/dist/playground/index.d.ts +19 -19
  241. package/dist/playground/index.js +16 -16
  242. package/dist/playground/mount.d.ts +3 -3
  243. package/dist/playground/mount.js +24 -24
  244. package/dist/registry/builtinFormats.js +13 -13
  245. package/dist/registry/builtinNodes.d.ts +2 -2
  246. package/dist/registry/builtinNodes.js +77 -77
  247. package/dist/registry/index.d.ts +4 -4
  248. package/dist/registry/index.js +4 -4
  249. package/dist/registry/nodeComponentRegistry.d.ts +8 -8
  250. package/dist/registry/nodeComponentRegistry.js +11 -9
  251. package/dist/registry/plugin.d.ts +2 -2
  252. package/dist/registry/plugin.js +11 -11
  253. package/dist/registry/workflowFormatRegistry.d.ts +3 -3
  254. package/dist/registry/workflowFormatRegistry.js +2 -2
  255. package/dist/schema/index.d.ts +1 -1
  256. package/dist/schema/index.js +2 -2
  257. package/dist/services/agentSpecExecutionService.d.ts +3 -3
  258. package/dist/services/agentSpecExecutionService.js +59 -55
  259. package/dist/services/api.d.ts +2 -2
  260. package/dist/services/api.js +37 -37
  261. package/dist/services/apiVariableService.d.ts +1 -1
  262. package/dist/services/apiVariableService.js +41 -34
  263. package/dist/services/autoSaveService.js +8 -8
  264. package/dist/services/categoriesApi.d.ts +2 -2
  265. package/dist/services/categoriesApi.js +8 -8
  266. package/dist/services/draftStorage.d.ts +1 -1
  267. package/dist/services/draftStorage.js +11 -11
  268. package/dist/services/dynamicSchemaService.d.ts +1 -1
  269. package/dist/services/dynamicSchemaService.js +41 -39
  270. package/dist/services/globalSave.d.ts +2 -2
  271. package/dist/services/globalSave.js +41 -38
  272. package/dist/services/historyService.d.ts +1 -1
  273. package/dist/services/historyService.js +8 -8
  274. package/dist/services/interruptService.d.ts +1 -1
  275. package/dist/services/interruptService.js +35 -29
  276. package/dist/services/nodeExecutionService.d.ts +1 -1
  277. package/dist/services/nodeExecutionService.js +45 -44
  278. package/dist/services/playgroundService.d.ts +1 -1
  279. package/dist/services/playgroundService.js +29 -29
  280. package/dist/services/portConfigApi.d.ts +2 -2
  281. package/dist/services/portConfigApi.js +8 -8
  282. package/dist/services/settingsService.d.ts +2 -2
  283. package/dist/services/settingsService.js +25 -19
  284. package/dist/services/toastService.d.ts +4 -4
  285. package/dist/services/toastService.js +33 -33
  286. package/dist/services/variableService.d.ts +1 -1
  287. package/dist/services/variableService.js +36 -36
  288. package/dist/services/workflowStorage.d.ts +2 -2
  289. package/dist/services/workflowStorage.js +13 -13
  290. package/dist/settings/index.d.ts +7 -7
  291. package/dist/settings/index.js +6 -6
  292. package/dist/skins/default.d.ts +2 -0
  293. package/dist/skins/default.js +1 -0
  294. package/dist/skins/index.d.ts +13 -0
  295. package/dist/skins/index.js +30 -0
  296. package/dist/skins/slate.d.ts +2 -0
  297. package/dist/skins/slate.js +78 -0
  298. package/dist/stores/categoriesStore.svelte.d.ts +1 -1
  299. package/dist/stores/categoriesStore.svelte.js +5 -5
  300. package/dist/stores/editorStateMachine.svelte.d.ts +2 -2
  301. package/dist/stores/editorStateMachine.svelte.js +65 -33
  302. package/dist/stores/historyStore.svelte.d.ts +4 -4
  303. package/dist/stores/historyStore.svelte.js +4 -4
  304. package/dist/stores/interruptStore.svelte.d.ts +3 -3
  305. package/dist/stores/interruptStore.svelte.js +21 -21
  306. package/dist/stores/playgroundStore.svelte.d.ts +2 -2
  307. package/dist/stores/playgroundStore.svelte.js +25 -18
  308. package/dist/stores/portCoordinateStore.svelte.d.ts +2 -2
  309. package/dist/stores/portCoordinateStore.svelte.js +15 -8
  310. package/dist/stores/settingsStore.svelte.d.ts +2 -2
  311. package/dist/stores/settingsStore.svelte.js +62 -57
  312. package/dist/stores/workflowStore.svelte.d.ts +3 -3
  313. package/dist/stores/workflowStore.svelte.js +50 -47
  314. package/dist/stories/CanvasDecorator.svelte +35 -32
  315. package/dist/stories/CanvasDecorator.svelte.d.ts +2 -2
  316. package/dist/stories/EdgeDecorator.svelte +102 -99
  317. package/dist/stories/EdgeDecorator.svelte.d.ts +1 -1
  318. package/dist/stories/NodeDecorator.svelte +59 -53
  319. package/dist/stories/NodeDecorator.svelte.d.ts +1 -1
  320. package/dist/stories/utils.d.ts +2 -2
  321. package/dist/stories/utils.js +105 -67
  322. package/dist/styles/base.css +599 -595
  323. package/dist/styles/toast.css +14 -14
  324. package/dist/styles/tokens.css +409 -378
  325. package/dist/svelte-app.d.ts +12 -9
  326. package/dist/svelte-app.js +40 -39
  327. package/dist/themes/default.d.ts +2 -0
  328. package/dist/themes/default.js +9 -0
  329. package/dist/themes/index.d.ts +13 -0
  330. package/dist/themes/index.js +44 -0
  331. package/dist/themes/minimal.d.ts +2 -0
  332. package/dist/themes/minimal.js +11 -0
  333. package/dist/types/agentspec.d.ts +18 -18
  334. package/dist/types/agentspec.js +2 -2
  335. package/dist/types/auth.d.ts +1 -1
  336. package/dist/types/auth.js +6 -6
  337. package/dist/types/config.d.ts +6 -6
  338. package/dist/types/events.d.ts +2 -2
  339. package/dist/types/events.js +2 -2
  340. package/dist/types/index.d.ts +32 -32
  341. package/dist/types/index.js +6 -6
  342. package/dist/types/interrupt.d.ts +6 -6
  343. package/dist/types/interrupt.js +21 -21
  344. package/dist/types/interruptState.d.ts +12 -12
  345. package/dist/types/interruptState.js +66 -66
  346. package/dist/types/playground.d.ts +7 -7
  347. package/dist/types/playground.js +14 -14
  348. package/dist/types/settings.d.ts +5 -3
  349. package/dist/types/settings.js +25 -18
  350. package/dist/types/skin.d.ts +31 -0
  351. package/dist/types/skin.js +1 -0
  352. package/dist/types/theme.d.ts +35 -0
  353. package/dist/types/theme.js +1 -0
  354. package/dist/types/uischema.d.ts +4 -4
  355. package/dist/types/uischema.js +3 -3
  356. package/dist/utils/colors.d.ts +1 -1
  357. package/dist/utils/colors.js +97 -95
  358. package/dist/utils/config.d.ts +2 -2
  359. package/dist/utils/config.js +48 -48
  360. package/dist/utils/connections.d.ts +2 -2
  361. package/dist/utils/connections.js +15 -15
  362. package/dist/utils/errors.js +3 -3
  363. package/dist/utils/fetchWithAuth.d.ts +1 -1
  364. package/dist/utils/fetchWithAuth.js +2 -2
  365. package/dist/utils/handleIds.d.ts +2 -2
  366. package/dist/utils/handleIds.js +8 -8
  367. package/dist/utils/handlePositioning.d.ts +1 -1
  368. package/dist/utils/handlePositioning.js +2 -2
  369. package/dist/utils/icons.d.ts +1 -1
  370. package/dist/utils/icons.js +74 -74
  371. package/dist/utils/logger.d.ts +1 -1
  372. package/dist/utils/logger.js +7 -7
  373. package/dist/utils/nodeStatus.d.ts +1 -1
  374. package/dist/utils/nodeStatus.js +48 -48
  375. package/dist/utils/nodeTypes.d.ts +1 -1
  376. package/dist/utils/nodeTypes.js +21 -20
  377. package/dist/utils/nodeWrapper.d.ts +7 -7
  378. package/dist/utils/nodeWrapper.js +21 -19
  379. package/dist/utils/performanceUtils.d.ts +1 -1
  380. package/dist/utils/performanceUtils.js +2 -1
  381. package/dist/utils/sanitize.js +1 -1
  382. package/dist/utils/uischema.d.ts +2 -2
  383. package/dist/utils/uischema.js +8 -8
  384. package/dist/utils/validation.js +20 -8
  385. package/package.json +1 -1
@@ -8,51 +8,53 @@
8
8
  -->
9
9
 
10
10
  <script lang="ts">
11
- import { useSvelteFlow, type InternalNode } from '@xyflow/svelte';
12
- import type { WorkflowNode as WorkflowNodeType } from '../types/index.js';
13
- import {
14
- rebuildAllPortCoordinates,
15
- updateNodePortCoordinates
16
- } from '../stores/portCoordinateStore.svelte.js';
17
-
18
- interface Props {
19
- /** Node to update coordinates for (e.g., during drag). Set to null when not dragging. */
20
- nodeToUpdate: WorkflowNodeType | null;
21
- /** Set to trigger a full rebuild of all port coordinates */
22
- rebuildTrigger: number;
23
- /** All workflow nodes - used for full rebuild */
24
- nodes: WorkflowNodeType[];
25
- }
26
-
27
- let { nodeToUpdate, rebuildTrigger, nodes }: Props = $props();
28
-
29
- const { getInternalNode } = useSvelteFlow();
30
-
31
- // Cast the getInternalNode function for our use
32
- const getInternal = getInternalNode as (id: string) => InternalNode | undefined;
33
-
34
- /**
35
- * Rebuild all port coordinates when rebuildTrigger changes.
36
- * Debounced to batch rapid position updates (e.g., animated auto-layout,
37
- * magnetic child nodes following a parent drag).
38
- */
39
- $effect(() => {
40
- const _trigger = rebuildTrigger;
41
- if (_trigger > 0) {
42
- const timeout = setTimeout(() => {
43
- rebuildAllPortCoordinates(nodes, getInternal);
44
- }, 150);
45
- return () => clearTimeout(timeout);
46
- }
47
- });
48
-
49
- /**
50
- * Update a single node's coordinates when nodeToUpdate changes.
51
- * This is used during drag for efficient per-node updates.
52
- */
53
- $effect(() => {
54
- if (nodeToUpdate) {
55
- updateNodePortCoordinates(nodeToUpdate, getInternal);
56
- }
57
- });
11
+ import { useSvelteFlow, type InternalNode } from "@xyflow/svelte";
12
+ import type { WorkflowNode as WorkflowNodeType } from "../types/index.js";
13
+ import {
14
+ rebuildAllPortCoordinates,
15
+ updateNodePortCoordinates,
16
+ } from "../stores/portCoordinateStore.svelte.js";
17
+
18
+ interface Props {
19
+ /** Node to update coordinates for (e.g., during drag). Set to null when not dragging. */
20
+ nodeToUpdate: WorkflowNodeType | null;
21
+ /** Set to trigger a full rebuild of all port coordinates */
22
+ rebuildTrigger: number;
23
+ /** All workflow nodes - used for full rebuild */
24
+ nodes: WorkflowNodeType[];
25
+ }
26
+
27
+ let { nodeToUpdate, rebuildTrigger, nodes }: Props = $props();
28
+
29
+ const { getInternalNode } = useSvelteFlow();
30
+
31
+ // Cast the getInternalNode function for our use
32
+ const getInternal = getInternalNode as (
33
+ id: string,
34
+ ) => InternalNode | undefined;
35
+
36
+ /**
37
+ * Rebuild all port coordinates when rebuildTrigger changes.
38
+ * Debounced to batch rapid position updates (e.g., animated auto-layout,
39
+ * magnetic child nodes following a parent drag).
40
+ */
41
+ $effect(() => {
42
+ const _trigger = rebuildTrigger;
43
+ if (_trigger > 0) {
44
+ const timeout = setTimeout(() => {
45
+ rebuildAllPortCoordinates(nodes, getInternal);
46
+ }, 150);
47
+ return () => clearTimeout(timeout);
48
+ }
49
+ });
50
+
51
+ /**
52
+ * Update a single node's coordinates when nodeToUpdate changes.
53
+ * This is used during drag for efficient per-node updates.
54
+ */
55
+ $effect(() => {
56
+ if (nodeToUpdate) {
57
+ updateNodePortCoordinates(nodeToUpdate, getInternal);
58
+ }
59
+ });
58
60
  </script>
@@ -1,4 +1,4 @@
1
- import type { WorkflowNode as WorkflowNodeType } from '../types/index.js';
1
+ import type { WorkflowNode as WorkflowNodeType } from "../types/index.js";
2
2
  interface Props {
3
3
  /** Node to update coordinates for (e.g., during drag). Set to null when not dragging. */
4
4
  nodeToUpdate: WorkflowNodeType | null;
@@ -5,166 +5,166 @@
5
5
  -->
6
6
 
7
7
  <script lang="ts">
8
- /**
9
- * A single detail item with label and value
10
- */
11
- interface DetailItem {
12
- /** The label to display */
13
- label: string;
14
- /** The value to display */
15
- value: string;
16
- }
17
-
18
- /**
19
- * Props interface for ReadOnlyDetails component
20
- */
21
- interface Props {
22
- /** The unique identifier to display with a copy button */
23
- id: string;
24
- /** Optional section title */
25
- title?: string;
26
- /** Optional description text */
27
- description?: string;
28
- /** Array of label-value pairs to display */
29
- details: DetailItem[];
30
- }
31
-
32
- const { id, title, description, details }: Props = $props();
33
-
34
- /**
35
- * Copy the ID to clipboard
36
- */
37
- function copyId(): void {
38
- navigator.clipboard.writeText(id);
39
- }
8
+ /**
9
+ * A single detail item with label and value
10
+ */
11
+ interface DetailItem {
12
+ /** The label to display */
13
+ label: string;
14
+ /** The value to display */
15
+ value: string;
16
+ }
17
+
18
+ /**
19
+ * Props interface for ReadOnlyDetails component
20
+ */
21
+ interface Props {
22
+ /** The unique identifier to display with a copy button */
23
+ id: string;
24
+ /** Optional section title */
25
+ title?: string;
26
+ /** Optional description text */
27
+ description?: string;
28
+ /** Array of label-value pairs to display */
29
+ details: DetailItem[];
30
+ }
31
+
32
+ const { id, title, description, details }: Props = $props();
33
+
34
+ /**
35
+ * Copy the ID to clipboard
36
+ */
37
+ function copyId(): void {
38
+ navigator.clipboard.writeText(id);
39
+ }
40
40
  </script>
41
41
 
42
42
  <div class="readonly-details">
43
- {#if title}
44
- <h3 class="readonly-details__title">{title}</h3>
45
- {/if}
46
-
47
- <div class="readonly-details__grid">
48
- <!-- ID row -->
49
- <span class="readonly-details__label">ID</span>
50
- <div class="readonly-details__id-row">
51
- <code class="readonly-details__id">{id}</code>
52
- <button
53
- class="readonly-details__copy-btn"
54
- onclick={copyId}
55
- title="Copy ID"
56
- aria-label="Copy ID to clipboard"
57
- >
58
- <svg
59
- xmlns="http://www.w3.org/2000/svg"
60
- fill="none"
61
- width="12"
62
- height="12"
63
- viewBox="0 0 24 24"
64
- stroke-width="2"
65
- stroke="currentColor"
66
- >
67
- <path
68
- stroke-linecap="round"
69
- stroke-linejoin="round"
70
- d="M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 0 1-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 0 1 1.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 0 0-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 0 1-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 0 0-3.375-3.375h-1.5a1.125 1.125 0 0 1-1.125-1.125v-1.5a3.375 3.375 0 0 0-3.375-3.375H9.75"
71
- />
72
- </svg>
73
- </button>
74
- </div>
75
-
76
- <!-- Dynamic label-value pairs -->
77
- {#each details as detail (detail.label)}
78
- <span class="readonly-details__label">{detail.label}</span>
79
- <span class="readonly-details__value">{detail.value}</span>
80
- {/each}
81
- </div>
82
-
83
- <!-- Description (if provided) -->
84
- {#if description}
85
- <p class="readonly-details__description">{description}</p>
86
- {/if}
43
+ {#if title}
44
+ <h3 class="readonly-details__title">{title}</h3>
45
+ {/if}
46
+
47
+ <div class="readonly-details__grid">
48
+ <!-- ID row -->
49
+ <span class="readonly-details__label">ID</span>
50
+ <div class="readonly-details__id-row">
51
+ <code class="readonly-details__id">{id}</code>
52
+ <button
53
+ class="readonly-details__copy-btn"
54
+ onclick={copyId}
55
+ title="Copy ID"
56
+ aria-label="Copy ID to clipboard"
57
+ >
58
+ <svg
59
+ xmlns="http://www.w3.org/2000/svg"
60
+ fill="none"
61
+ width="12"
62
+ height="12"
63
+ viewBox="0 0 24 24"
64
+ stroke-width="2"
65
+ stroke="currentColor"
66
+ >
67
+ <path
68
+ stroke-linecap="round"
69
+ stroke-linejoin="round"
70
+ d="M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 0 1-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 0 1 1.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 0 0-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 0 1-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 0 0-3.375-3.375h-1.5a1.125 1.125 0 0 1-1.125-1.125v-1.5a3.375 3.375 0 0 0-3.375-3.375H9.75"
71
+ />
72
+ </svg>
73
+ </button>
74
+ </div>
75
+
76
+ <!-- Dynamic label-value pairs -->
77
+ {#each details as detail (detail.label)}
78
+ <span class="readonly-details__label">{detail.label}</span>
79
+ <span class="readonly-details__value">{detail.value}</span>
80
+ {/each}
81
+ </div>
82
+
83
+ <!-- Description (if provided) -->
84
+ {#if description}
85
+ <p class="readonly-details__description">{description}</p>
86
+ {/if}
87
87
  </div>
88
88
 
89
89
  <style>
90
- .readonly-details {
91
- display: flex;
92
- flex-direction: column;
93
- gap: 0.5rem;
94
- }
95
-
96
- .readonly-details__title {
97
- margin: 0;
98
- font-size: 0.75rem;
99
- font-weight: 600;
100
- color: var(--fd-muted-foreground);
101
- text-transform: uppercase;
102
- letter-spacing: 0.05em;
103
- }
104
-
105
- .readonly-details__grid {
106
- display: grid;
107
- grid-template-columns: auto 1fr;
108
- gap: 0.25rem 0.75rem;
109
- align-items: center;
110
- }
111
-
112
- .readonly-details__label {
113
- font-size: 0.75rem;
114
- font-weight: 500;
115
- color: var(--fd-muted-foreground);
116
- }
117
-
118
- .readonly-details__value {
119
- font-size: 0.8125rem;
120
- color: var(--fd-foreground);
121
- font-weight: 500;
122
- }
123
-
124
- .readonly-details__id-row {
125
- display: flex;
126
- align-items: center;
127
- gap: 0.375rem;
128
- }
129
-
130
- .readonly-details__id {
131
- font-size: 0.75rem;
132
- font-family: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, monospace;
133
- color: var(--fd-muted-foreground);
134
- background-color: var(--fd-subtle);
135
- padding: 0.125rem 0.375rem;
136
- border-radius: var(--fd-radius-sm);
137
- word-break: break-all;
138
- }
139
-
140
- .readonly-details__copy-btn {
141
- background: transparent;
142
- border: none;
143
- padding: 0.25rem;
144
- cursor: pointer;
145
- color: var(--fd-muted-foreground);
146
- border-radius: var(--fd-radius-sm);
147
- display: flex;
148
- align-items: center;
149
- justify-content: center;
150
- transition:
151
- color var(--fd-transition-fast),
152
- background-color var(--fd-transition-fast);
153
- }
154
-
155
- .readonly-details__copy-btn:hover {
156
- color: var(--fd-foreground);
157
- background-color: var(--fd-subtle);
158
- }
159
-
160
- .readonly-details__copy-btn:active {
161
- color: var(--fd-foreground);
162
- }
163
-
164
- .readonly-details__description {
165
- margin: 0;
166
- font-size: 0.8125rem;
167
- color: var(--fd-muted-foreground);
168
- line-height: 1.5;
169
- }
90
+ .readonly-details {
91
+ display: flex;
92
+ flex-direction: column;
93
+ gap: 0.5rem;
94
+ }
95
+
96
+ .readonly-details__title {
97
+ margin: 0;
98
+ font-size: 0.75rem;
99
+ font-weight: 600;
100
+ color: var(--fd-muted-foreground);
101
+ text-transform: uppercase;
102
+ letter-spacing: 0.05em;
103
+ }
104
+
105
+ .readonly-details__grid {
106
+ display: grid;
107
+ grid-template-columns: auto 1fr;
108
+ gap: 0.25rem 0.75rem;
109
+ align-items: center;
110
+ }
111
+
112
+ .readonly-details__label {
113
+ font-size: 0.75rem;
114
+ font-weight: 500;
115
+ color: var(--fd-muted-foreground);
116
+ }
117
+
118
+ .readonly-details__value {
119
+ font-size: 0.8125rem;
120
+ color: var(--fd-foreground);
121
+ font-weight: 500;
122
+ }
123
+
124
+ .readonly-details__id-row {
125
+ display: flex;
126
+ align-items: center;
127
+ gap: 0.375rem;
128
+ }
129
+
130
+ .readonly-details__id {
131
+ font-size: 0.75rem;
132
+ font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
133
+ color: var(--fd-muted-foreground);
134
+ background-color: var(--fd-subtle);
135
+ padding: 0.125rem 0.375rem;
136
+ border-radius: var(--fd-radius-sm);
137
+ word-break: break-all;
138
+ }
139
+
140
+ .readonly-details__copy-btn {
141
+ background: transparent;
142
+ border: none;
143
+ padding: 0.25rem;
144
+ cursor: pointer;
145
+ color: var(--fd-muted-foreground);
146
+ border-radius: var(--fd-radius-sm);
147
+ display: flex;
148
+ align-items: center;
149
+ justify-content: center;
150
+ transition:
151
+ color var(--fd-transition-fast),
152
+ background-color var(--fd-transition-fast);
153
+ }
154
+
155
+ .readonly-details__copy-btn:hover {
156
+ color: var(--fd-foreground);
157
+ background-color: var(--fd-subtle);
158
+ }
159
+
160
+ .readonly-details__copy-btn:active {
161
+ color: var(--fd-foreground);
162
+ }
163
+
164
+ .readonly-details__description {
165
+ margin: 0;
166
+ font-size: 0.8125rem;
167
+ color: var(--fd-muted-foreground);
168
+ line-height: 1.5;
169
+ }
170
170
  </style>
@@ -1,116 +1,124 @@
1
1
  <script module>
2
- import { defineMeta } from '@storybook/addon-svelte-csf';
3
- import SchemaForm from './SchemaForm.svelte';
4
- import { fn } from 'storybook/test';
2
+ import { defineMeta } from "@storybook/addon-svelte-csf";
3
+ import SchemaForm from "./SchemaForm.svelte";
4
+ import { fn } from "storybook/test";
5
5
 
6
- const { Story } = defineMeta({
7
- title: 'Form/SchemaForm',
8
- component: SchemaForm,
9
- tags: ['autodocs'],
10
- args: {
11
- onChange: fn(),
12
- onSave: fn(),
13
- onCancel: fn()
14
- }
15
- });
6
+ const { Story } = defineMeta({
7
+ title: "Form/SchemaForm",
8
+ component: SchemaForm,
9
+ tags: ["autodocs"],
10
+ args: {
11
+ onChange: fn(),
12
+ onSave: fn(),
13
+ onCancel: fn(),
14
+ },
15
+ });
16
16
  </script>
17
17
 
18
18
  <Story
19
- name="Simple Form"
20
- args={{
21
- schema: {
22
- type: 'object',
23
- properties: {
24
- name: { type: 'string', title: 'Name', description: 'Enter your full name' },
25
- age: { type: 'number', title: 'Age', minimum: 0, maximum: 120 },
26
- active: { type: 'boolean', title: 'Active', default: true }
27
- },
28
- required: ['name']
29
- },
30
- values: { name: 'Alice', age: 30, active: true }
31
- }}
19
+ name="Simple Form"
20
+ args={{
21
+ schema: {
22
+ type: "object",
23
+ properties: {
24
+ name: {
25
+ type: "string",
26
+ title: "Name",
27
+ description: "Enter your full name",
28
+ },
29
+ age: { type: "number", title: "Age", minimum: 0, maximum: 120 },
30
+ active: { type: "boolean", title: "Active", default: true },
31
+ },
32
+ required: ["name"],
33
+ },
34
+ values: { name: "Alice", age: 30, active: true },
35
+ }}
32
36
  />
33
37
 
34
38
  <Story
35
- name="Select Fields"
36
- args={{
37
- schema: {
38
- type: 'object',
39
- properties: {
40
- model: {
41
- type: 'string',
42
- title: 'AI Model',
43
- oneOf: [
44
- { const: 'gpt-4', title: 'GPT-4' },
45
- { const: 'gpt-3.5', title: 'GPT-3.5 Turbo' },
46
- { const: 'claude-3', title: 'Claude 3' }
47
- ]
48
- },
49
- temperature: {
50
- type: 'number',
51
- title: 'Temperature',
52
- format: 'range',
53
- minimum: 0,
54
- maximum: 2,
55
- step: 0.1,
56
- default: 0.7
57
- },
58
- prompt: {
59
- type: 'string',
60
- title: 'System Prompt',
61
- format: 'multiline',
62
- description: 'The system prompt for the AI model'
63
- }
64
- }
65
- },
66
- values: { model: 'gpt-4', temperature: 0.7, prompt: 'You are a helpful assistant.' }
67
- }}
39
+ name="Select Fields"
40
+ args={{
41
+ schema: {
42
+ type: "object",
43
+ properties: {
44
+ model: {
45
+ type: "string",
46
+ title: "AI Model",
47
+ oneOf: [
48
+ { const: "gpt-4", title: "GPT-4" },
49
+ { const: "gpt-3.5", title: "GPT-3.5 Turbo" },
50
+ { const: "claude-3", title: "Claude 3" },
51
+ ],
52
+ },
53
+ temperature: {
54
+ type: "number",
55
+ title: "Temperature",
56
+ format: "range",
57
+ minimum: 0,
58
+ maximum: 2,
59
+ step: 0.1,
60
+ default: 0.7,
61
+ },
62
+ prompt: {
63
+ type: "string",
64
+ title: "System Prompt",
65
+ format: "multiline",
66
+ description: "The system prompt for the AI model",
67
+ },
68
+ },
69
+ },
70
+ values: {
71
+ model: "gpt-4",
72
+ temperature: 0.7,
73
+ prompt: "You are a helpful assistant.",
74
+ },
75
+ }}
68
76
  />
69
77
 
70
78
  <Story
71
- name="With Actions"
72
- args={{
73
- schema: {
74
- type: 'object',
75
- properties: {
76
- email: { type: 'string', title: 'Email' },
77
- notifications: { type: 'boolean', title: 'Enable Notifications' }
78
- },
79
- required: ['email']
80
- },
81
- values: { email: '', notifications: true },
82
- showActions: true,
83
- saveLabel: 'Save Settings',
84
- cancelLabel: 'Reset'
85
- }}
79
+ name="With Actions"
80
+ args={{
81
+ schema: {
82
+ type: "object",
83
+ properties: {
84
+ email: { type: "string", title: "Email" },
85
+ notifications: { type: "boolean", title: "Enable Notifications" },
86
+ },
87
+ required: ["email"],
88
+ },
89
+ values: { email: "", notifications: true },
90
+ showActions: true,
91
+ saveLabel: "Save Settings",
92
+ cancelLabel: "Reset",
93
+ }}
86
94
  />
87
95
 
88
96
  <Story
89
- name="Loading"
90
- args={{
91
- schema: {
92
- type: 'object',
93
- properties: {
94
- name: { type: 'string', title: 'Name' }
95
- }
96
- },
97
- values: { name: 'Test' },
98
- showActions: true,
99
- loading: true
100
- }}
97
+ name="Loading"
98
+ args={{
99
+ schema: {
100
+ type: "object",
101
+ properties: {
102
+ name: { type: "string", title: "Name" },
103
+ },
104
+ },
105
+ values: { name: "Test" },
106
+ showActions: true,
107
+ loading: true,
108
+ }}
101
109
  />
102
110
 
103
111
  <Story
104
- name="Disabled"
105
- args={{
106
- schema: {
107
- type: 'object',
108
- properties: {
109
- name: { type: 'string', title: 'Name' },
110
- role: { type: 'string', title: 'Role' }
111
- }
112
- },
113
- values: { name: 'Admin', role: 'Super User' },
114
- disabled: true
115
- }}
112
+ name="Disabled"
113
+ args={{
114
+ schema: {
115
+ type: "object",
116
+ properties: {
117
+ name: { type: "string", title: "Name" },
118
+ role: { type: "string", title: "Role" },
119
+ },
120
+ },
121
+ values: { name: "Admin", role: "Super User" },
122
+ disabled: true,
123
+ }}
116
124
  />