@flowdrop/flowdrop 1.4.0 → 1.6.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/README.md +94 -51
  2. package/dist/adapters/WorkflowAdapter.d.ts +1 -1
  3. package/dist/adapters/WorkflowAdapter.js +27 -47
  4. package/dist/adapters/agentspec/AgentSpecAdapter.d.ts +2 -2
  5. package/dist/adapters/agentspec/AgentSpecAdapter.js +122 -133
  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 +52 -6
  9. package/dist/adapters/agentspec/autoLayout.js +118 -23
  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 +20 -22
  18. package/dist/api/enhanced-client.d.ts +3 -3
  19. package/dist/api/enhanced-client.js +72 -73
  20. package/dist/chat/commandClassifier.d.ts +19 -0
  21. package/dist/chat/commandClassifier.js +30 -0
  22. package/dist/chat/index.d.ts +27 -0
  23. package/dist/chat/index.js +32 -0
  24. package/dist/chat/responseParser.d.ts +21 -0
  25. package/dist/chat/responseParser.js +91 -0
  26. package/dist/commands/batch.d.ts +18 -0
  27. package/dist/commands/batch.js +54 -0
  28. package/dist/commands/executor.d.ts +37 -0
  29. package/dist/commands/executor.js +1133 -0
  30. package/dist/commands/index.d.ts +14 -0
  31. package/dist/commands/index.js +17 -0
  32. package/dist/commands/parser.d.ts +16 -0
  33. package/dist/commands/parser.js +295 -0
  34. package/dist/commands/positioner.d.ts +19 -0
  35. package/dist/commands/positioner.js +33 -0
  36. package/dist/commands/storeIntegration.svelte.d.ts +16 -0
  37. package/dist/commands/storeIntegration.svelte.js +67 -0
  38. package/dist/commands/types.d.ts +343 -0
  39. package/dist/commands/types.js +45 -0
  40. package/dist/components/App.svelte +522 -237
  41. package/dist/components/App.svelte.d.ts +11 -8
  42. package/dist/components/CanvasBanner.stories.svelte +10 -16
  43. package/dist/components/CanvasBanner.stories.svelte.d.ts +1 -1
  44. package/dist/components/CanvasBanner.svelte +2 -2
  45. package/dist/components/CanvasBanner.svelte.d.ts +1 -1
  46. package/dist/components/CanvasController.svelte +37 -0
  47. package/dist/components/CanvasController.svelte.d.ts +32 -0
  48. package/dist/components/ConfigForm.svelte +118 -256
  49. package/dist/components/ConfigForm.svelte.d.ts +2 -2
  50. package/dist/components/ConfigMappingRow.svelte +128 -0
  51. package/dist/components/ConfigMappingRow.svelte.d.ts +8 -0
  52. package/dist/components/ConfigModal.svelte +3 -3
  53. package/dist/components/ConfigModal.svelte.d.ts +1 -1
  54. package/dist/components/ConfigPanel.stories.svelte +19 -19
  55. package/dist/components/ConfigPanel.stories.svelte.d.ts +1 -1
  56. package/dist/components/ConfigPanel.svelte +57 -19
  57. package/dist/components/ConfigPanel.svelte.d.ts +3 -1
  58. package/dist/components/ConnectionLine.svelte +4 -4
  59. package/dist/components/EdgeRefresher.svelte +1 -1
  60. package/dist/components/FlowDropEdge.stories.svelte +110 -110
  61. package/dist/components/FlowDropEdge.svelte +11 -19
  62. package/dist/components/FlowDropEdge.svelte.d.ts +1 -1
  63. package/dist/components/FlowDropZone.svelte +6 -9
  64. package/dist/components/FlowDropZone.svelte.d.ts +1 -1
  65. package/dist/components/LoadingSpinner.stories.svelte +13 -13
  66. package/dist/components/LoadingSpinner.stories.svelte.d.ts +1 -1
  67. package/dist/components/LoadingSpinner.svelte +3 -3
  68. package/dist/components/LoadingSpinner.svelte.d.ts +1 -1
  69. package/dist/components/Logo.stories.svelte +4 -4
  70. package/dist/components/Logo.stories.svelte.d.ts +1 -1
  71. package/dist/components/Logo.svelte +3 -9
  72. package/dist/components/LogsSidebar.svelte +46 -53
  73. package/dist/components/LogsSidebar.svelte.d.ts +1 -1
  74. package/dist/components/MarkdownDisplay.stories.svelte +10 -14
  75. package/dist/components/MarkdownDisplay.stories.svelte.d.ts +1 -1
  76. package/dist/components/MarkdownDisplay.svelte +4 -6
  77. package/dist/components/Navbar.stories.svelte +19 -19
  78. package/dist/components/Navbar.stories.svelte.d.ts +1 -1
  79. package/dist/components/Navbar.svelte +28 -49
  80. package/dist/components/Navbar.svelte.d.ts +2 -2
  81. package/dist/components/NodeSidebar.svelte +55 -135
  82. package/dist/components/NodeSidebar.svelte.d.ts +1 -1
  83. package/dist/components/NodeStatusOverlay.stories.svelte +19 -31
  84. package/dist/components/NodeStatusOverlay.stories.svelte.d.ts +1 -1
  85. package/dist/components/NodeStatusOverlay.svelte +40 -55
  86. package/dist/components/NodeStatusOverlay.svelte.d.ts +3 -3
  87. package/dist/components/NodeSwapPicker.svelte +493 -0
  88. package/dist/components/NodeSwapPicker.svelte.d.ts +16 -0
  89. package/dist/components/PipelineStatus.svelte +63 -89
  90. package/dist/components/PipelineStatus.svelte.d.ts +4 -4
  91. package/dist/components/PortCoordinateTracker.svelte +5 -7
  92. package/dist/components/PortCoordinateTracker.svelte.d.ts +1 -1
  93. package/dist/components/PortMappingRow.svelte +205 -0
  94. package/dist/components/PortMappingRow.svelte.d.ts +12 -0
  95. package/dist/components/ReadOnlyDetails.svelte +1 -1
  96. package/dist/components/SchemaForm.stories.svelte +53 -53
  97. package/dist/components/SchemaForm.stories.svelte.d.ts +1 -1
  98. package/dist/components/SchemaForm.svelte +24 -51
  99. package/dist/components/SchemaForm.svelte.d.ts +2 -2
  100. package/dist/components/SettingsModal.svelte +6 -9
  101. package/dist/components/SettingsModal.svelte.d.ts +1 -1
  102. package/dist/components/SettingsPanel.svelte +138 -158
  103. package/dist/components/SettingsPanel.svelte.d.ts +1 -1
  104. package/dist/components/StatusIcon.stories.svelte +16 -29
  105. package/dist/components/StatusIcon.stories.svelte.d.ts +1 -1
  106. package/dist/components/StatusIcon.svelte +19 -19
  107. package/dist/components/StatusIcon.svelte.d.ts +2 -2
  108. package/dist/components/StatusLabel.stories.svelte +8 -8
  109. package/dist/components/StatusLabel.stories.svelte.d.ts +1 -1
  110. package/dist/components/SwapMappingEditor.svelte +529 -0
  111. package/dist/components/SwapMappingEditor.svelte.d.ts +12 -0
  112. package/dist/components/ThemeToggle.stories.svelte +10 -10
  113. package/dist/components/ThemeToggle.stories.svelte.d.ts +1 -1
  114. package/dist/components/ThemeToggle.svelte +22 -33
  115. package/dist/components/ThemeToggle.svelte.d.ts +1 -1
  116. package/dist/components/UniversalNode.svelte +29 -41
  117. package/dist/components/UniversalNode.svelte.d.ts +3 -3
  118. package/dist/components/WorkflowEditor.svelte +210 -170
  119. package/dist/components/WorkflowEditor.svelte.d.ts +12 -4
  120. package/dist/components/chat/AIChatPanel.svelte +797 -0
  121. package/dist/components/chat/AIChatPanel.svelte.d.ts +13 -0
  122. package/dist/components/chat/CommandPreview.svelte +234 -0
  123. package/dist/components/chat/CommandPreview.svelte.d.ts +9 -0
  124. package/dist/components/console/CommandConsole.stories.svelte +111 -0
  125. package/dist/components/console/CommandConsole.stories.svelte.d.ts +27 -0
  126. package/dist/components/console/CommandConsole.svelte +263 -0
  127. package/dist/components/console/CommandConsole.svelte.d.ts +11 -0
  128. package/dist/components/console/ConsoleAutocomplete.svelte +142 -0
  129. package/dist/components/console/ConsoleAutocomplete.svelte.d.ts +21 -0
  130. package/dist/components/console/ConsoleInput.svelte +771 -0
  131. package/dist/components/console/ConsoleInput.svelte.d.ts +16 -0
  132. package/dist/components/console/ConsoleOutput.svelte +116 -0
  133. package/dist/components/console/ConsoleOutput.svelte.d.ts +11 -0
  134. package/dist/components/console/formatters.d.ts +26 -0
  135. package/dist/components/console/formatters.js +116 -0
  136. package/dist/components/form/FormArray.svelte +75 -132
  137. package/dist/components/form/FormArray.svelte.d.ts +1 -1
  138. package/dist/components/form/FormAutocomplete.svelte +65 -108
  139. package/dist/components/form/FormAutocomplete.svelte.d.ts +1 -1
  140. package/dist/components/form/FormCheckboxGroup.stories.svelte +13 -16
  141. package/dist/components/form/FormCheckboxGroup.stories.svelte.d.ts +1 -1
  142. package/dist/components/form/FormCheckboxGroup.svelte +2 -2
  143. package/dist/components/form/FormCodeEditor.svelte +42 -56
  144. package/dist/components/form/FormField.svelte +79 -90
  145. package/dist/components/form/FormField.svelte.d.ts +2 -2
  146. package/dist/components/form/FormFieldLight.svelte +72 -88
  147. package/dist/components/form/FormFieldLight.svelte.d.ts +1 -1
  148. package/dist/components/form/FormFieldWrapper.stories.svelte +14 -14
  149. package/dist/components/form/FormFieldWrapper.stories.svelte.d.ts +1 -1
  150. package/dist/components/form/FormFieldWrapper.svelte +2 -9
  151. package/dist/components/form/FormFieldWrapper.svelte.d.ts +1 -1
  152. package/dist/components/form/FormFieldset.svelte +3 -3
  153. package/dist/components/form/FormFieldset.svelte.d.ts +2 -2
  154. package/dist/components/form/FormMarkdownEditor.svelte +123 -156
  155. package/dist/components/form/FormNumberField.stories.svelte +18 -18
  156. package/dist/components/form/FormNumberField.stories.svelte.d.ts +1 -1
  157. package/dist/components/form/FormNumberField.svelte +6 -6
  158. package/dist/components/form/FormRangeField.stories.svelte +13 -13
  159. package/dist/components/form/FormRangeField.stories.svelte.d.ts +1 -1
  160. package/dist/components/form/FormRangeField.svelte +4 -12
  161. package/dist/components/form/FormSelect.stories.svelte +21 -21
  162. package/dist/components/form/FormSelect.stories.svelte.d.ts +1 -1
  163. package/dist/components/form/FormSelect.svelte +5 -5
  164. package/dist/components/form/FormSelect.svelte.d.ts +1 -1
  165. package/dist/components/form/FormTemplateEditor.svelte +126 -175
  166. package/dist/components/form/FormTemplateEditor.svelte.d.ts +1 -1
  167. package/dist/components/form/FormTextField.stories.svelte +17 -23
  168. package/dist/components/form/FormTextField.stories.svelte.d.ts +1 -1
  169. package/dist/components/form/FormTextField.svelte +4 -4
  170. package/dist/components/form/FormTextarea.stories.svelte +18 -21
  171. package/dist/components/form/FormTextarea.stories.svelte.d.ts +1 -1
  172. package/dist/components/form/FormTextarea.svelte +4 -4
  173. package/dist/components/form/FormToggle.stories.svelte +13 -16
  174. package/dist/components/form/FormToggle.stories.svelte.d.ts +1 -1
  175. package/dist/components/form/FormToggle.svelte +3 -3
  176. package/dist/components/form/FormUISchemaRenderer.svelte +12 -19
  177. package/dist/components/form/FormUISchemaRenderer.svelte.d.ts +3 -3
  178. package/dist/components/form/index.d.ts +19 -19
  179. package/dist/components/form/index.js +18 -18
  180. package/dist/components/form/templateAutocomplete.d.ts +2 -2
  181. package/dist/components/form/templateAutocomplete.js +55 -64
  182. package/dist/components/form/types.d.ts +6 -6
  183. package/dist/components/form/types.js +4 -9
  184. package/dist/components/icons/AlertCircleIcon.svelte +1 -6
  185. package/dist/components/icons/CogIcon.svelte +1 -6
  186. package/dist/components/interrupt/ChoicePrompt.stories.svelte +27 -27
  187. package/dist/components/interrupt/ChoicePrompt.stories.svelte.d.ts +1 -1
  188. package/dist/components/interrupt/ChoicePrompt.svelte +17 -41
  189. package/dist/components/interrupt/ChoicePrompt.svelte.d.ts +1 -1
  190. package/dist/components/interrupt/ConfirmationPrompt.stories.svelte +17 -17
  191. package/dist/components/interrupt/ConfirmationPrompt.stories.svelte.d.ts +1 -1
  192. package/dist/components/interrupt/ConfirmationPrompt.svelte +10 -16
  193. package/dist/components/interrupt/ConfirmationPrompt.svelte.d.ts +1 -1
  194. package/dist/components/interrupt/FormPrompt.svelte +10 -15
  195. package/dist/components/interrupt/FormPrompt.svelte.d.ts +1 -1
  196. package/dist/components/interrupt/InterruptBubble.svelte +87 -121
  197. package/dist/components/interrupt/InterruptBubble.svelte.d.ts +2 -2
  198. package/dist/components/interrupt/ReviewPrompt.stories.svelte +37 -37
  199. package/dist/components/interrupt/ReviewPrompt.stories.svelte.d.ts +1 -1
  200. package/dist/components/interrupt/ReviewPrompt.svelte +55 -75
  201. package/dist/components/interrupt/ReviewPrompt.svelte.d.ts +1 -1
  202. package/dist/components/interrupt/TextInputPrompt.stories.svelte +16 -17
  203. package/dist/components/interrupt/TextInputPrompt.stories.svelte.d.ts +1 -1
  204. package/dist/components/interrupt/TextInputPrompt.svelte +13 -18
  205. package/dist/components/interrupt/TextInputPrompt.svelte.d.ts +1 -1
  206. package/dist/components/interrupt/index.d.ts +6 -5
  207. package/dist/components/interrupt/index.js +6 -5
  208. package/dist/components/layouts/MainLayout.svelte +46 -84
  209. package/dist/components/layouts/MainLayout.svelte.d.ts +6 -6
  210. package/dist/components/nodes/GatewayNode.stories.svelte +64 -65
  211. package/dist/components/nodes/GatewayNode.svelte +37 -70
  212. package/dist/components/nodes/GatewayNode.svelte.d.ts +3 -3
  213. package/dist/components/nodes/IdeaNode.stories.svelte +25 -26
  214. package/dist/components/nodes/IdeaNode.svelte +22 -36
  215. package/dist/components/nodes/IdeaNode.svelte.d.ts +1 -1
  216. package/dist/components/nodes/NotesNode.stories.svelte +37 -38
  217. package/dist/components/nodes/NotesNode.svelte +28 -39
  218. package/dist/components/nodes/NotesNode.svelte.d.ts +1 -1
  219. package/dist/components/nodes/SimpleNode.stories.svelte +137 -138
  220. package/dist/components/nodes/SimpleNode.svelte +44 -74
  221. package/dist/components/nodes/SimpleNode.svelte.d.ts +1 -1
  222. package/dist/components/nodes/SquareNode.stories.svelte +75 -75
  223. package/dist/components/nodes/SquareNode.svelte +42 -68
  224. package/dist/components/nodes/SquareNode.svelte.d.ts +1 -1
  225. package/dist/components/nodes/TerminalNode.stories.svelte +10 -10
  226. package/dist/components/nodes/TerminalNode.svelte +74 -112
  227. package/dist/components/nodes/TerminalNode.svelte.d.ts +1 -1
  228. package/dist/components/nodes/ToolNode.stories.svelte +115 -116
  229. package/dist/components/nodes/ToolNode.svelte +31 -64
  230. package/dist/components/nodes/ToolNode.svelte.d.ts +1 -1
  231. package/dist/components/nodes/WorkflowNode.stories.svelte +84 -89
  232. package/dist/components/nodes/WorkflowNode.svelte +50 -103
  233. package/dist/components/nodes/WorkflowNode.svelte.d.ts +3 -3
  234. package/dist/components/playground/ChatPanel.svelte +47 -103
  235. package/dist/components/playground/ExecutionLogs.svelte +45 -68
  236. package/dist/components/playground/InputCollector.svelte +32 -51
  237. package/dist/components/playground/MessageBubble.stories.svelte +25 -25
  238. package/dist/components/playground/MessageBubble.stories.svelte.d.ts +1 -1
  239. package/dist/components/playground/MessageBubble.svelte +54 -70
  240. package/dist/components/playground/MessageBubble.svelte.d.ts +1 -1
  241. package/dist/components/playground/Playground.svelte +60 -91
  242. package/dist/components/playground/Playground.svelte.d.ts +3 -3
  243. package/dist/components/playground/PlaygroundModal.svelte +8 -12
  244. package/dist/components/playground/PlaygroundModal.svelte.d.ts +3 -3
  245. package/dist/components/playground/SessionManager.svelte +34 -40
  246. package/dist/components/playground/SessionManager.svelte.d.ts +1 -1
  247. package/dist/config/agentSpecEndpoints.d.ts +1 -1
  248. package/dist/config/agentSpecEndpoints.js +20 -20
  249. package/dist/config/constants.js +2 -2
  250. package/dist/config/defaultCategories.d.ts +1 -1
  251. package/dist/config/defaultCategories.js +86 -86
  252. package/dist/config/defaultPortConfig.d.ts +1 -1
  253. package/dist/config/defaultPortConfig.js +144 -144
  254. package/dist/config/endpoints.d.ts +12 -4
  255. package/dist/config/endpoints.js +70 -65
  256. package/dist/config/runtimeConfig.d.ts +2 -2
  257. package/dist/config/runtimeConfig.js +8 -8
  258. package/dist/core/index.d.ts +68 -63
  259. package/dist/core/index.js +44 -35
  260. package/dist/display/index.d.ts +2 -2
  261. package/dist/display/index.js +2 -2
  262. package/dist/editor/index.d.ts +64 -62
  263. package/dist/editor/index.js +57 -55
  264. package/dist/form/code.d.ts +5 -5
  265. package/dist/form/code.js +14 -14
  266. package/dist/form/fieldRegistry.d.ts +3 -3
  267. package/dist/form/fieldRegistry.js +9 -11
  268. package/dist/form/full.d.ts +8 -8
  269. package/dist/form/full.js +9 -9
  270. package/dist/form/index.d.ts +18 -18
  271. package/dist/form/index.js +16 -16
  272. package/dist/form/markdown.d.ts +4 -4
  273. package/dist/form/markdown.js +8 -8
  274. package/dist/helpers/proximityConnect.d.ts +3 -3
  275. package/dist/helpers/proximityConnect.js +40 -35
  276. package/dist/helpers/workflowEditorHelper.d.ts +8 -58
  277. package/dist/helpers/workflowEditorHelper.js +73 -292
  278. package/dist/index.d.ts +6 -6
  279. package/dist/index.js +6 -6
  280. package/dist/mocks/app-environment.js +2 -2
  281. package/dist/mocks/app-forms.js +1 -1
  282. package/dist/mocks/app-navigation.js +2 -2
  283. package/dist/mocks/app-stores.js +3 -3
  284. package/dist/playground/index.d.ts +19 -19
  285. package/dist/playground/index.js +16 -16
  286. package/dist/playground/mount.d.ts +3 -3
  287. package/dist/playground/mount.js +24 -24
  288. package/dist/registry/builtinFormats.js +13 -13
  289. package/dist/registry/builtinNodes.d.ts +2 -2
  290. package/dist/registry/builtinNodes.js +77 -77
  291. package/dist/registry/index.d.ts +4 -4
  292. package/dist/registry/index.js +4 -4
  293. package/dist/registry/nodeComponentRegistry.d.ts +8 -8
  294. package/dist/registry/nodeComponentRegistry.js +9 -11
  295. package/dist/registry/plugin.d.ts +2 -2
  296. package/dist/registry/plugin.js +11 -11
  297. package/dist/registry/workflowFormatRegistry.d.ts +3 -3
  298. package/dist/registry/workflowFormatRegistry.js +2 -2
  299. package/dist/schema/index.d.ts +1 -1
  300. package/dist/schema/index.js +2 -2
  301. package/dist/schemas/v1/workflow.schema.json +107 -22
  302. package/dist/services/agentSpecExecutionService.d.ts +3 -3
  303. package/dist/services/agentSpecExecutionService.js +55 -56
  304. package/dist/services/api.d.ts +2 -2
  305. package/dist/services/api.js +37 -37
  306. package/dist/services/apiVariableService.d.ts +1 -1
  307. package/dist/services/apiVariableService.js +34 -41
  308. package/dist/services/autoSaveService.js +8 -8
  309. package/dist/services/categoriesApi.d.ts +2 -2
  310. package/dist/services/categoriesApi.js +8 -8
  311. package/dist/services/chatService.d.ts +65 -0
  312. package/dist/services/chatService.js +131 -0
  313. package/dist/services/draftStorage.d.ts +1 -1
  314. package/dist/services/draftStorage.js +11 -11
  315. package/dist/services/dynamicSchemaService.d.ts +1 -1
  316. package/dist/services/dynamicSchemaService.js +39 -41
  317. package/dist/services/globalSave.d.ts +2 -2
  318. package/dist/services/globalSave.js +38 -41
  319. package/dist/services/historyService.d.ts +7 -5
  320. package/dist/services/historyService.js +29 -14
  321. package/dist/services/interruptService.d.ts +1 -1
  322. package/dist/services/interruptService.js +29 -35
  323. package/dist/services/nodeExecutionService.d.ts +1 -1
  324. package/dist/services/nodeExecutionService.js +44 -45
  325. package/dist/services/playgroundService.d.ts +1 -1
  326. package/dist/services/playgroundService.js +29 -29
  327. package/dist/services/portConfigApi.d.ts +2 -2
  328. package/dist/services/portConfigApi.js +8 -8
  329. package/dist/services/settingsService.d.ts +2 -2
  330. package/dist/services/settingsService.js +19 -25
  331. package/dist/services/toastService.d.ts +4 -4
  332. package/dist/services/toastService.js +33 -33
  333. package/dist/services/variableService.d.ts +1 -1
  334. package/dist/services/variableService.js +36 -36
  335. package/dist/services/workflowStorage.d.ts +2 -2
  336. package/dist/services/workflowStorage.js +13 -13
  337. package/dist/settings/index.d.ts +7 -7
  338. package/dist/settings/index.js +6 -6
  339. package/dist/skins/default.d.ts +1 -1
  340. package/dist/skins/default.js +1 -1
  341. package/dist/skins/index.d.ts +3 -3
  342. package/dist/skins/index.js +7 -7
  343. package/dist/skins/slate.d.ts +1 -1
  344. package/dist/skins/slate.js +69 -69
  345. package/dist/stores/categoriesStore.svelte.d.ts +1 -1
  346. package/dist/stores/categoriesStore.svelte.js +5 -5
  347. package/dist/stores/editorStateMachine.svelte.d.ts +2 -2
  348. package/dist/stores/editorStateMachine.svelte.js +34 -34
  349. package/dist/stores/historyStore.svelte.d.ts +4 -4
  350. package/dist/stores/historyStore.svelte.js +4 -4
  351. package/dist/stores/interruptStore.svelte.d.ts +3 -3
  352. package/dist/stores/interruptStore.svelte.js +27 -22
  353. package/dist/stores/playgroundStore.svelte.d.ts +3 -3
  354. package/dist/stores/playgroundStore.svelte.js +29 -23
  355. package/dist/stores/portCoordinateStore.svelte.d.ts +6 -2
  356. package/dist/stores/portCoordinateStore.svelte.js +30 -39
  357. package/dist/stores/settingsStore.svelte.d.ts +2 -2
  358. package/dist/stores/settingsStore.svelte.js +57 -62
  359. package/dist/stores/workflowStore.svelte.d.ts +34 -5
  360. package/dist/stores/workflowStore.svelte.js +127 -108
  361. package/dist/stories/CanvasDecorator.svelte +7 -10
  362. package/dist/stories/CanvasDecorator.svelte.d.ts +2 -2
  363. package/dist/stories/EdgeDecorator.svelte +28 -31
  364. package/dist/stories/EdgeDecorator.svelte.d.ts +1 -1
  365. package/dist/stories/NodeDecorator.svelte +14 -20
  366. package/dist/stories/NodeDecorator.svelte.d.ts +1 -1
  367. package/dist/stories/utils.d.ts +2 -2
  368. package/dist/stories/utils.js +89 -93
  369. package/dist/styles/base.css +16 -50
  370. package/dist/styles/tokens.css +10 -28
  371. package/dist/svelte-app.d.ts +10 -10
  372. package/dist/svelte-app.js +39 -39
  373. package/dist/themes/default.d.ts +1 -1
  374. package/dist/themes/default.js +4 -4
  375. package/dist/themes/index.d.ts +3 -3
  376. package/dist/themes/index.js +11 -11
  377. package/dist/themes/minimal.d.ts +1 -1
  378. package/dist/themes/minimal.js +5 -5
  379. package/dist/types/agentspec.d.ts +18 -18
  380. package/dist/types/agentspec.js +2 -2
  381. package/dist/types/auth.d.ts +1 -1
  382. package/dist/types/auth.js +6 -6
  383. package/dist/types/chat.d.ts +63 -0
  384. package/dist/types/chat.js +9 -0
  385. package/dist/types/config.d.ts +6 -6
  386. package/dist/types/events.d.ts +28 -2
  387. package/dist/types/events.js +2 -1
  388. package/dist/types/index.d.ts +40 -32
  389. package/dist/types/index.js +6 -6
  390. package/dist/types/interrupt.d.ts +6 -6
  391. package/dist/types/interrupt.js +21 -21
  392. package/dist/types/interruptState.d.ts +12 -12
  393. package/dist/types/interruptState.js +66 -66
  394. package/dist/types/playground.d.ts +7 -7
  395. package/dist/types/playground.js +14 -14
  396. package/dist/types/settings.d.ts +12 -4
  397. package/dist/types/settings.js +21 -23
  398. package/dist/types/skin.d.ts +1 -1
  399. package/dist/types/theme.d.ts +2 -2
  400. package/dist/types/uischema.d.ts +4 -4
  401. package/dist/types/uischema.js +3 -3
  402. package/dist/utils/colors.d.ts +1 -1
  403. package/dist/utils/colors.js +95 -97
  404. package/dist/utils/config.d.ts +2 -2
  405. package/dist/utils/config.js +48 -48
  406. package/dist/utils/connections.d.ts +2 -2
  407. package/dist/utils/connections.js +15 -15
  408. package/dist/utils/edgeStyling.d.ts +42 -0
  409. package/dist/utils/edgeStyling.js +173 -0
  410. package/dist/utils/errors.js +3 -3
  411. package/dist/utils/fetchWithAuth.d.ts +1 -1
  412. package/dist/utils/fetchWithAuth.js +2 -2
  413. package/dist/utils/handleIds.d.ts +2 -2
  414. package/dist/utils/handleIds.js +8 -8
  415. package/dist/utils/handlePositioning.d.ts +1 -1
  416. package/dist/utils/handlePositioning.js +2 -2
  417. package/dist/utils/icons.d.ts +1 -1
  418. package/dist/utils/icons.js +74 -74
  419. package/dist/utils/logger.d.ts +1 -1
  420. package/dist/utils/logger.js +7 -7
  421. package/dist/utils/nodeIds.d.ts +31 -0
  422. package/dist/utils/nodeIds.js +42 -0
  423. package/dist/utils/nodeStatus.d.ts +1 -1
  424. package/dist/utils/nodeStatus.js +48 -48
  425. package/dist/utils/nodeSwap.d.ts +221 -0
  426. package/dist/utils/nodeSwap.js +680 -0
  427. package/dist/utils/nodeTypes.d.ts +1 -1
  428. package/dist/utils/nodeTypes.js +20 -21
  429. package/dist/utils/nodeWrapper.d.ts +7 -7
  430. package/dist/utils/nodeWrapper.js +19 -21
  431. package/dist/utils/performanceUtils.d.ts +1 -1
  432. package/dist/utils/performanceUtils.js +1 -2
  433. package/dist/utils/portUtils.d.ts +2 -2
  434. package/dist/utils/portUtils.js +1 -1
  435. package/dist/utils/sanitize.js +1 -1
  436. package/dist/utils/uischema.d.ts +2 -2
  437. package/dist/utils/uischema.js +8 -8
  438. package/dist/utils/validation.js +8 -8
  439. package/package.json +12 -11
  440. package/dist/helpers/nodeLayoutHelper.d.ts +0 -14
  441. package/dist/helpers/nodeLayoutHelper.js +0 -19
@@ -1,9 +1,9 @@
1
- import type { NodeExecutionInfo } from "../types/index.js";
1
+ import type { NodeExecutionInfo } from '../types/index.js';
2
2
  interface Props {
3
3
  nodeId?: string;
4
4
  executionInfo?: NodeExecutionInfo;
5
- position?: "top-left" | "top-right" | "bottom-left" | "bottom-right";
6
- size?: "sm" | "md" | "lg";
5
+ position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
6
+ size?: 'sm' | 'md' | 'lg';
7
7
  showDetails?: boolean;
8
8
  }
9
9
  declare const NodeStatusOverlay: import("svelte").Component<Props, {}, "">;
@@ -0,0 +1,493 @@
1
+ <!--
2
+ NodeSwapPicker Component
3
+ Displays available node types for swapping, with search/filter and version upgrade badge.
4
+ Reuses patterns from NodeSidebar.
5
+ Styled with BEM syntax.
6
+ -->
7
+
8
+ <script lang="ts">
9
+ import type { NodeMetadata, NodeCategory, WorkflowFormat, WorkflowNode } from '../types/index.js';
10
+ import Icon from '@iconify/svelte';
11
+ import { getNodeIcon, getCategoryIcon } from '../utils/icons.js';
12
+ import { getCategoryColorToken } from '../utils/colors.js';
13
+ import { getCategoryLabel } from '../stores/categoriesStore.svelte.js';
14
+ import { getVersionUpgrade } from '../utils/nodeSwap.js';
15
+
16
+ interface Props {
17
+ /** The node being swapped */
18
+ currentNode: WorkflowNode;
19
+ /** All available node types */
20
+ availableNodes: NodeMetadata[];
21
+ /** Active workflow format for filtering */
22
+ activeFormat?: WorkflowFormat;
23
+ /** Callback when a node type is selected */
24
+ onSelect: (metadata: NodeMetadata) => void;
25
+ /** Callback to cancel swap */
26
+ onCancel: () => void;
27
+ }
28
+
29
+ const { currentNode, availableNodes, activeFormat, onSelect, onCancel }: Props = $props();
30
+
31
+ let searchInput = $state('');
32
+
33
+ /** Check version upgrade availability */
34
+ let versionUpgrade = $derived(getVersionUpgrade(currentNode.data.metadata, availableNodes));
35
+
36
+ /** Filter nodes compatible with active format */
37
+ function isNodeCompatibleWithFormat(node: NodeMetadata): boolean {
38
+ if (!activeFormat) return true;
39
+ if (!node.formats || node.formats.length === 0) return true;
40
+ return node.formats.includes(activeFormat);
41
+ }
42
+
43
+ /** Nodes filtered by format compatibility */
44
+ let formatCompatibleNodes = $derived(availableNodes.filter((n) => isNodeCompatibleWithFormat(n)));
45
+
46
+ /** Apply search filter */
47
+ let filteredNodes = $derived.by(() => {
48
+ let nodes = formatCompatibleNodes;
49
+ if (searchInput.trim()) {
50
+ const query = searchInput.toLowerCase();
51
+ nodes = nodes.filter(
52
+ (node) =>
53
+ node.name.toLowerCase().includes(query) ||
54
+ node.description.toLowerCase().includes(query) ||
55
+ node.tags?.some((tag) => tag.toLowerCase().includes(query))
56
+ );
57
+ }
58
+ return nodes;
59
+ });
60
+
61
+ /** Get unique categories preserving API order */
62
+ let categories = $derived.by(() => {
63
+ const seen = new Set<NodeCategory>();
64
+ const ordered: NodeCategory[] = [];
65
+ for (const node of filteredNodes) {
66
+ if (!seen.has(node.category)) {
67
+ seen.add(node.category);
68
+ ordered.push(node.category);
69
+ }
70
+ }
71
+ return ordered;
72
+ });
73
+
74
+ /** Get filtered nodes for a specific category */
75
+ function getNodesForCategory(category: NodeCategory): NodeMetadata[] {
76
+ return filteredNodes.filter((n) => n.category === category);
77
+ }
78
+ </script>
79
+
80
+ <div class="swap-picker">
81
+ <!-- Header -->
82
+ <div class="swap-picker__header">
83
+ <button class="swap-picker__back" onclick={onCancel} aria-label="Back to configuration">
84
+ <Icon icon="heroicons:arrow-left" />
85
+ </button>
86
+ <h2 class="swap-picker__title">Swap Node</h2>
87
+ </div>
88
+
89
+ <!-- Current node info -->
90
+ <div class="swap-picker__current">
91
+ <span class="swap-picker__current-label">Current:</span>
92
+ <span class="swap-picker__current-name">{currentNode.data.label}</span>
93
+ </div>
94
+
95
+ <!-- Version upgrade banner -->
96
+ {#if versionUpgrade}
97
+ <button class="swap-picker__upgrade" onclick={() => onSelect(versionUpgrade!)}>
98
+ <Icon icon="heroicons:arrow-up-circle" />
99
+ <div class="swap-picker__upgrade-info">
100
+ <span class="swap-picker__upgrade-title">Upgrade Available</span>
101
+ <span class="swap-picker__upgrade-detail">
102
+ v{currentNode.data.metadata.version} &rarr; v{versionUpgrade.version}
103
+ </span>
104
+ </div>
105
+ <Icon icon="heroicons:chevron-right" />
106
+ </button>
107
+ {/if}
108
+
109
+ <!-- Search (hidden in minimal via --fd-sidebar-search-display) -->
110
+ <div class="swap-picker__search">
111
+ <input
112
+ type="text"
113
+ placeholder="Search node types..."
114
+ class="swap-picker__input"
115
+ bind:value={searchInput}
116
+ />
117
+ </div>
118
+
119
+ <!-- Node list -->
120
+ <div class="swap-picker__list">
121
+ {#if filteredNodes.length === 0}
122
+ <div class="swap-picker__empty">
123
+ <p>No matching node types found</p>
124
+ </div>
125
+ {:else}
126
+ {#each categories as category (category)}
127
+ {@const categoryNodes = getNodesForCategory(category)}
128
+ {#if categoryNodes.length > 0}
129
+ <!-- Flat style: dot + name rows (shown in minimal skin) -->
130
+ <div class="swap-picker__flat-section">
131
+ <div class="swap-picker__flat-category">
132
+ {getCategoryLabel(category).toUpperCase()}
133
+ </div>
134
+ <div class="swap-picker__flat-list">
135
+ {#each categoryNodes as nodeType (nodeType.id)}
136
+ <button class="swap-picker__flat-item" onclick={() => onSelect(nodeType)}>
137
+ <span
138
+ class="swap-picker__flat-dot"
139
+ style="background: {getCategoryColorToken(nodeType.category)}"
140
+ ></span>
141
+ <span class="swap-picker__flat-name">{nodeType.name}</span>
142
+ </button>
143
+ {/each}
144
+ </div>
145
+ </div>
146
+
147
+ <!-- Card style: icon + name + desc rows (shown in default skin) -->
148
+ <div class="swap-picker__card-section">
149
+ <div class="swap-picker__category-header">
150
+ <span
151
+ class="swap-picker__category-icon"
152
+ style="--_icon-color: {getCategoryColorToken(category)}"
153
+ >
154
+ <Icon icon={getCategoryIcon(category)} />
155
+ </span>
156
+ <span class="swap-picker__category-name">
157
+ {getCategoryLabel(category)}
158
+ </span>
159
+ <span class="swap-picker__category-count">
160
+ {categoryNodes.length}
161
+ </span>
162
+ </div>
163
+ <div class="swap-picker__category-items">
164
+ {#each categoryNodes as nodeType (nodeType.id)}
165
+ <button class="swap-picker__item" onclick={() => onSelect(nodeType)}>
166
+ <span
167
+ class="swap-picker__item-icon"
168
+ style="--_icon-color: {getCategoryColorToken(nodeType.category)}"
169
+ >
170
+ <Icon icon={getNodeIcon(nodeType.icon, nodeType.category)} />
171
+ </span>
172
+ <div class="swap-picker__item-info">
173
+ <span class="swap-picker__item-name">{nodeType.name}</span>
174
+ <span class="swap-picker__item-desc">
175
+ {nodeType.description}
176
+ </span>
177
+ </div>
178
+ <Icon icon="heroicons:chevron-right" class="swap-picker__item-arrow" />
179
+ </button>
180
+ {/each}
181
+ </div>
182
+ </div>
183
+ {/if}
184
+ {/each}
185
+ {/if}
186
+ </div>
187
+ </div>
188
+
189
+ <style>
190
+ .swap-picker {
191
+ height: 100%;
192
+ display: flex;
193
+ flex-direction: column;
194
+ background-color: var(--fd-background);
195
+ }
196
+
197
+ .swap-picker__header {
198
+ display: flex;
199
+ align-items: center;
200
+ gap: 0.5rem;
201
+ padding: 0.875rem 1rem;
202
+ border-bottom: 1px solid var(--fd-border);
203
+ background-color: var(--fd-muted);
204
+ flex-shrink: 0;
205
+ }
206
+
207
+ .swap-picker__back {
208
+ background: none;
209
+ border: none;
210
+ cursor: pointer;
211
+ color: var(--fd-muted-foreground);
212
+ padding: 0.25rem;
213
+ border-radius: var(--fd-radius-sm);
214
+ display: flex;
215
+ align-items: center;
216
+ transition:
217
+ color var(--fd-transition-fast),
218
+ background-color var(--fd-transition-fast);
219
+ }
220
+
221
+ .swap-picker__back:hover {
222
+ color: var(--fd-foreground);
223
+ background-color: var(--fd-subtle);
224
+ }
225
+
226
+ .swap-picker__title {
227
+ margin: 0;
228
+ font-size: 1rem;
229
+ font-weight: 600;
230
+ color: var(--fd-foreground);
231
+ }
232
+
233
+ .swap-picker__current {
234
+ padding: 0.5rem 1rem;
235
+ border-bottom: 1px solid var(--fd-border-muted);
236
+ background-color: var(--fd-muted);
237
+ font-size: var(--fd-text-xs);
238
+ display: flex;
239
+ gap: 0.375rem;
240
+ align-items: center;
241
+ }
242
+
243
+ .swap-picker__current-label {
244
+ color: var(--fd-muted-foreground);
245
+ }
246
+
247
+ .swap-picker__current-name {
248
+ color: var(--fd-foreground);
249
+ font-weight: 500;
250
+ }
251
+
252
+ .swap-picker__upgrade {
253
+ display: flex;
254
+ align-items: center;
255
+ gap: 0.5rem;
256
+ padding: 0.625rem 1rem;
257
+ border: none;
258
+ border-bottom: 1px solid var(--fd-border-muted);
259
+ background-color: color-mix(in srgb, var(--fd-primary) 8%, transparent);
260
+ color: var(--fd-primary);
261
+ cursor: pointer;
262
+ width: 100%;
263
+ text-align: left;
264
+ transition: background-color var(--fd-transition-fast);
265
+ }
266
+
267
+ .swap-picker__upgrade:hover {
268
+ background-color: color-mix(in srgb, var(--fd-primary) 15%, transparent);
269
+ }
270
+
271
+ .swap-picker__upgrade-info {
272
+ flex: 1;
273
+ display: flex;
274
+ flex-direction: column;
275
+ }
276
+
277
+ .swap-picker__upgrade-title {
278
+ font-size: var(--fd-text-sm);
279
+ font-weight: 600;
280
+ }
281
+
282
+ .swap-picker__upgrade-detail {
283
+ font-size: var(--fd-text-xs);
284
+ opacity: 0.8;
285
+ }
286
+
287
+ .swap-picker__search {
288
+ display: var(--fd-sidebar-search-display, flex);
289
+ padding: 0.75rem 1rem;
290
+ border-bottom: 1px solid var(--fd-border);
291
+ flex-shrink: 0;
292
+ }
293
+
294
+ .swap-picker__input {
295
+ width: 100%;
296
+ padding: 0.5rem 0.75rem;
297
+ border: 1px solid var(--fd-border-strong);
298
+ border-radius: var(--fd-radius-md);
299
+ font-size: var(--fd-text-sm);
300
+ color: var(--fd-foreground);
301
+ background-color: var(--fd-background);
302
+ box-sizing: border-box;
303
+ transition:
304
+ border-color var(--fd-transition-normal),
305
+ box-shadow var(--fd-transition-normal);
306
+ }
307
+
308
+ .swap-picker__input:focus {
309
+ outline: none;
310
+ border-color: var(--fd-ring);
311
+ box-shadow: 0 0 0 3px color-mix(in srgb, var(--fd-ring) 20%, transparent);
312
+ }
313
+
314
+ .swap-picker__input::placeholder {
315
+ color: var(--fd-muted-foreground);
316
+ }
317
+
318
+ .swap-picker__list {
319
+ flex: 1;
320
+ overflow-y: auto;
321
+ padding: 0.75rem;
322
+ scrollbar-width: thin;
323
+ scrollbar-color: var(--fd-scrollbar-thumb) var(--fd-scrollbar-track);
324
+ }
325
+
326
+ .swap-picker__empty {
327
+ padding: 2rem 1rem;
328
+ text-align: center;
329
+ color: var(--fd-muted-foreground);
330
+ font-size: var(--fd-text-sm);
331
+ }
332
+
333
+ /* Display-control token wiring for skin variants */
334
+ .swap-picker__flat-section {
335
+ display: var(--fd-sidebar-flat-display, none);
336
+ }
337
+
338
+ .swap-picker__card-section {
339
+ display: var(--fd-sidebar-card-display, block);
340
+ margin-bottom: 0.75rem;
341
+ }
342
+
343
+ /* Flat style (minimal skin) */
344
+ .swap-picker__flat-category {
345
+ font-size: var(--fd-text-xs);
346
+ font-weight: 600;
347
+ color: var(--fd-sidebar-category-color, var(--fd-muted-foreground));
348
+ letter-spacing: 0.08em;
349
+ padding: 1.25rem 0.75rem 0.375rem 0.75rem;
350
+ text-transform: uppercase;
351
+ }
352
+
353
+ .swap-picker__flat-list {
354
+ display: flex;
355
+ flex-direction: column;
356
+ gap: 1px;
357
+ margin-bottom: 0.25rem;
358
+ }
359
+
360
+ .swap-picker__flat-item {
361
+ display: flex;
362
+ align-items: center;
363
+ gap: 0.625rem;
364
+ padding: 0.5rem 0.75rem;
365
+ border: none;
366
+ border-radius: var(--fd-radius-sm);
367
+ background: none;
368
+ cursor: pointer;
369
+ width: 100%;
370
+ text-align: left;
371
+ transition: background-color var(--fd-transition-fast);
372
+ }
373
+
374
+ .swap-picker__flat-item:hover {
375
+ background-color: var(--fd-muted);
376
+ }
377
+
378
+ .swap-picker__flat-dot {
379
+ width: 8px;
380
+ height: 8px;
381
+ border-radius: 50%;
382
+ flex-shrink: 0;
383
+ display: inline-block;
384
+ }
385
+
386
+ .swap-picker__flat-name {
387
+ font-size: var(--fd-text-sm);
388
+ color: var(--fd-sidebar-flat-item-color, var(--fd-foreground));
389
+ white-space: nowrap;
390
+ overflow: hidden;
391
+ text-overflow: ellipsis;
392
+ }
393
+
394
+ .swap-picker__category-header {
395
+ display: flex;
396
+ align-items: center;
397
+ gap: 0.5rem;
398
+ padding: 0.375rem 0.25rem;
399
+ margin-bottom: 0.25rem;
400
+ }
401
+
402
+ .swap-picker__category-icon {
403
+ width: 1.25rem;
404
+ height: 1.25rem;
405
+ border-radius: 0.25rem;
406
+ background: color-mix(in srgb, var(--_icon-color) var(--fd-node-icon-bg-opacity), transparent);
407
+ color: var(--fd-node-icon);
408
+ font-size: 0.625rem;
409
+ display: flex;
410
+ align-items: center;
411
+ justify-content: center;
412
+ flex-shrink: 0;
413
+ }
414
+
415
+ .swap-picker__category-name {
416
+ font-size: var(--fd-text-xs);
417
+ font-weight: 600;
418
+ color: var(--fd-muted-foreground);
419
+ text-transform: uppercase;
420
+ letter-spacing: 0.05em;
421
+ flex: 1;
422
+ }
423
+
424
+ .swap-picker__category-count {
425
+ font-size: var(--fd-text-xs);
426
+ color: var(--fd-muted-foreground);
427
+ background-color: var(--fd-subtle);
428
+ padding: 0.125rem 0.375rem;
429
+ border-radius: var(--fd-radius-sm);
430
+ }
431
+
432
+ .swap-picker__category-items {
433
+ display: flex;
434
+ flex-direction: column;
435
+ gap: 2px;
436
+ }
437
+
438
+ .swap-picker__item {
439
+ display: flex;
440
+ align-items: center;
441
+ gap: 0.5rem;
442
+ padding: 0.5rem;
443
+ border: 1px solid transparent;
444
+ border-radius: var(--fd-radius-md);
445
+ background: none;
446
+ cursor: pointer;
447
+ width: 100%;
448
+ text-align: left;
449
+ transition: all var(--fd-transition-fast);
450
+ }
451
+
452
+ .swap-picker__item:hover {
453
+ background-color: var(--fd-muted);
454
+ border-color: var(--fd-border);
455
+ }
456
+
457
+ .swap-picker__item-icon {
458
+ width: 1.75rem;
459
+ height: 1.75rem;
460
+ border-radius: 0.375rem;
461
+ background: color-mix(in srgb, var(--_icon-color) var(--fd-node-icon-bg-opacity), transparent);
462
+ color: var(--fd-node-icon);
463
+ font-size: var(--fd-text-xs);
464
+ display: flex;
465
+ align-items: center;
466
+ justify-content: center;
467
+ flex-shrink: 0;
468
+ }
469
+
470
+ .swap-picker__item-info {
471
+ flex: 1;
472
+ min-width: 0;
473
+ }
474
+
475
+ .swap-picker__item-name {
476
+ display: block;
477
+ font-size: var(--fd-text-sm);
478
+ font-weight: 500;
479
+ color: var(--fd-foreground);
480
+ overflow: hidden;
481
+ text-overflow: ellipsis;
482
+ white-space: nowrap;
483
+ }
484
+
485
+ .swap-picker__item-desc {
486
+ display: block;
487
+ font-size: var(--fd-text-xs);
488
+ color: var(--fd-muted-foreground);
489
+ overflow: hidden;
490
+ text-overflow: ellipsis;
491
+ white-space: nowrap;
492
+ }
493
+ </style>
@@ -0,0 +1,16 @@
1
+ import type { NodeMetadata, WorkflowFormat, WorkflowNode } from '../types/index.js';
2
+ interface Props {
3
+ /** The node being swapped */
4
+ currentNode: WorkflowNode;
5
+ /** All available node types */
6
+ availableNodes: NodeMetadata[];
7
+ /** Active workflow format for filtering */
8
+ activeFormat?: WorkflowFormat;
9
+ /** Callback when a node type is selected */
10
+ onSelect: (metadata: NodeMetadata) => void;
11
+ /** Callback to cancel swap */
12
+ onCancel: () => void;
13
+ }
14
+ declare const NodeSwapPicker: import("svelte").Component<Props, {}, "">;
15
+ type NodeSwapPicker = ReturnType<typeof NodeSwapPicker>;
16
+ export default NodeSwapPicker;