@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
@@ -1,378 +1,389 @@
1
1
  <script lang="ts">
2
- import type { ConfigValues, NodeMetadata } from '../../types/index.js';
3
- import Icon from '@iconify/svelte';
4
- import MarkdownDisplay from '../MarkdownDisplay.svelte';
5
-
6
- /**
7
- * NotesNode component props
8
- * Displays a styled note with markdown content
9
- */
10
- const props = $props<{
11
- data: {
12
- label: string;
13
- config: ConfigValues;
14
- metadata: NodeMetadata;
15
- nodeId?: string;
16
- onConfigOpen?: (node: {
17
- id: string;
18
- type: string;
19
- data: { label: string; config: ConfigValues; metadata: NodeMetadata };
20
- }) => void;
21
- };
22
- selected?: boolean;
23
- isProcessing?: boolean;
24
- isError?: boolean;
25
- }>();
26
-
27
- /** Note content derived from config */
28
- const noteContent = $derived((props.data.config?.content as string) || 'Add your notes here...');
29
-
30
- /** Note type derived from config */
31
- const noteType = $derived((props.data.config?.noteType as string) || 'info');
32
-
33
- /** Note type configuration with styling for each type */
34
- const noteTypes = {
35
- info: {
36
- name: 'Info',
37
- typeClass: 'flowdrop-notes-node--info',
38
- icon: 'mdi:information'
39
- },
40
- warning: {
41
- name: 'Warning',
42
- typeClass: 'flowdrop-notes-node--warning',
43
- icon: 'mdi:alert'
44
- },
45
- success: {
46
- name: 'Success',
47
- typeClass: 'flowdrop-notes-node--success',
48
- icon: 'mdi:check-circle'
49
- },
50
- error: {
51
- name: 'Error',
52
- typeClass: 'flowdrop-notes-node--error',
53
- icon: 'mdi:close-circle'
54
- },
55
- note: {
56
- name: 'Note',
57
- typeClass: 'flowdrop-notes-node--note',
58
- icon: 'mdi:note-text'
59
- }
60
- };
61
-
62
- /** Current note type configuration based on selected type */
63
- const currentType = $derived(noteTypes[noteType as keyof typeof noteTypes] || noteTypes.info);
64
-
65
- /**
66
- * Opens the configuration sidebar for editing note properties
67
- */
68
- function openConfigSidebar(): void {
69
- if (props.data.onConfigOpen) {
70
- const nodeForConfig = {
71
- id: props.data.nodeId || 'unknown',
72
- type: 'note',
73
- data: props.data
74
- };
75
- props.data.onConfigOpen(nodeForConfig);
76
- }
77
- }
78
-
79
- /**
80
- * Handles double-click to open config sidebar
81
- */
82
- function handleDoubleClick(): void {
83
- openConfigSidebar();
84
- }
85
-
86
- /**
87
- * Handles keyboard events for accessibility
88
- * @param event - The keyboard event
89
- */
90
- function handleKeydown(event: KeyboardEvent): void {
91
- if (event.key === 'Enter' || event.key === ' ') {
92
- event.preventDefault();
93
- handleDoubleClick();
94
- }
95
- }
2
+ import type { ConfigValues, NodeMetadata } from "../../types/index.js";
3
+ import Icon from "@iconify/svelte";
4
+ import MarkdownDisplay from "../MarkdownDisplay.svelte";
5
+
6
+ /**
7
+ * NotesNode component props
8
+ * Displays a styled note with markdown content
9
+ */
10
+ const props = $props<{
11
+ data: {
12
+ label: string;
13
+ config: ConfigValues;
14
+ metadata: NodeMetadata;
15
+ nodeId?: string;
16
+ onConfigOpen?: (node: {
17
+ id: string;
18
+ type: string;
19
+ data: { label: string; config: ConfigValues; metadata: NodeMetadata };
20
+ }) => void;
21
+ };
22
+ selected?: boolean;
23
+ isProcessing?: boolean;
24
+ isError?: boolean;
25
+ }>();
26
+
27
+ /** Note content derived from config */
28
+ const noteContent = $derived(
29
+ (props.data.config?.content as string) || "Add your notes here...",
30
+ );
31
+
32
+ /** Note type derived from config */
33
+ const noteType = $derived((props.data.config?.noteType as string) || "info");
34
+
35
+ /** Note type configuration with styling for each type */
36
+ const noteTypes = {
37
+ info: {
38
+ name: "Info",
39
+ typeClass: "flowdrop-notes-node--info",
40
+ icon: "mdi:information",
41
+ },
42
+ warning: {
43
+ name: "Warning",
44
+ typeClass: "flowdrop-notes-node--warning",
45
+ icon: "mdi:alert",
46
+ },
47
+ success: {
48
+ name: "Success",
49
+ typeClass: "flowdrop-notes-node--success",
50
+ icon: "mdi:check-circle",
51
+ },
52
+ error: {
53
+ name: "Error",
54
+ typeClass: "flowdrop-notes-node--error",
55
+ icon: "mdi:close-circle",
56
+ },
57
+ note: {
58
+ name: "Note",
59
+ typeClass: "flowdrop-notes-node--note",
60
+ icon: "mdi:note-text",
61
+ },
62
+ };
63
+
64
+ /** Current note type configuration based on selected type */
65
+ const currentType = $derived(
66
+ noteTypes[noteType as keyof typeof noteTypes] || noteTypes.info,
67
+ );
68
+
69
+ /**
70
+ * Opens the configuration sidebar for editing note properties
71
+ */
72
+ function openConfigSidebar(): void {
73
+ if (props.data.onConfigOpen) {
74
+ const nodeForConfig = {
75
+ id: props.data.nodeId || "unknown",
76
+ type: "note",
77
+ data: props.data,
78
+ };
79
+ props.data.onConfigOpen(nodeForConfig);
80
+ }
81
+ }
82
+
83
+ /**
84
+ * Handles double-click to open config sidebar
85
+ */
86
+ function handleDoubleClick(): void {
87
+ openConfigSidebar();
88
+ }
89
+
90
+ /**
91
+ * Handles keyboard events for accessibility
92
+ * @param event - The keyboard event
93
+ */
94
+ function handleKeydown(event: KeyboardEvent): void {
95
+ if (event.key === "Enter" || event.key === " ") {
96
+ event.preventDefault();
97
+ handleDoubleClick();
98
+ }
99
+ }
96
100
  </script>
97
101
 
98
102
  <div
99
- class="flowdrop-notes-node {currentType.typeClass}"
100
- class:flowdrop-notes-node--selected={props.selected}
101
- class:flowdrop-notes-node--processing={props.isProcessing}
102
- class:flowdrop-notes-node--has-error={props.isError}
103
- ondblclick={handleDoubleClick}
104
- onkeydown={handleKeydown}
105
- role="button"
106
- tabindex="0"
103
+ class="flowdrop-notes-node {currentType.typeClass}"
104
+ class:flowdrop-notes-node--selected={props.selected}
105
+ class:flowdrop-notes-node--processing={props.isProcessing}
106
+ class:flowdrop-notes-node--has-error={props.isError}
107
+ ondblclick={handleDoubleClick}
108
+ onkeydown={handleKeydown}
109
+ role="button"
110
+ tabindex="0"
107
111
  >
108
- <!-- Display Mode -->
109
- <div class="flowdrop-notes-node__content">
110
- <!-- Header with icon and type -->
111
- <div class="flowdrop-notes-node__header">
112
- <div class="flowdrop-notes-node__header-left">
113
- <div class="flowdrop-notes-node__icon-wrapper">
114
- <Icon icon={currentType.icon} class="flowdrop-notes-node__icon" />
115
- </div>
116
- <span class="flowdrop-notes-node__type">{currentType.name}</span>
117
- </div>
118
- </div>
119
-
120
- <!-- Rendered markdown content -->
121
- <div class="flowdrop-notes-node__body">
122
- <MarkdownDisplay content={noteContent} className="flowdrop-notes-node__markdown" />
123
- </div>
124
-
125
- <!-- Processing indicator -->
126
- {#if props.isProcessing}
127
- <div class="flowdrop-notes-node__processing">
128
- <div class="flowdrop-notes-node__spinner"></div>
129
- <span>Processing...</span>
130
- </div>
131
- {/if}
132
-
133
- <!-- Error indicator -->
134
- {#if props.isError}
135
- <div class="flowdrop-notes-node__error-indicator">
136
- <Icon icon="mdi:alert-circle" class="flowdrop-notes-node__error-icon" />
137
- <span>Error occurred</span>
138
- </div>
139
- {/if}
140
- </div>
141
-
142
- <!-- Config button -->
143
- <button
144
- class="flowdrop-notes-node__config-btn"
145
- onclick={openConfigSidebar}
146
- title="Configure note"
147
- >
148
- <Icon icon="mdi:cog" />
149
- </button>
112
+ <!-- Display Mode -->
113
+ <div class="flowdrop-notes-node__content">
114
+ <!-- Header with icon and type -->
115
+ <div class="flowdrop-notes-node__header">
116
+ <div class="flowdrop-notes-node__header-left">
117
+ <div class="flowdrop-notes-node__icon-wrapper">
118
+ <Icon icon={currentType.icon} class="flowdrop-notes-node__icon" />
119
+ </div>
120
+ <span class="flowdrop-notes-node__type">{currentType.name}</span>
121
+ </div>
122
+ </div>
123
+
124
+ <!-- Rendered markdown content -->
125
+ <div class="flowdrop-notes-node__body">
126
+ <MarkdownDisplay
127
+ content={noteContent}
128
+ className="flowdrop-notes-node__markdown"
129
+ />
130
+ </div>
131
+
132
+ <!-- Processing indicator -->
133
+ {#if props.isProcessing}
134
+ <div class="flowdrop-notes-node__processing">
135
+ <div class="flowdrop-notes-node__spinner"></div>
136
+ <span>Processing...</span>
137
+ </div>
138
+ {/if}
139
+
140
+ <!-- Error indicator -->
141
+ {#if props.isError}
142
+ <div class="flowdrop-notes-node__error-indicator">
143
+ <Icon icon="mdi:alert-circle" class="flowdrop-notes-node__error-icon" />
144
+ <span>Error occurred</span>
145
+ </div>
146
+ {/if}
147
+ </div>
148
+
149
+ <!-- Config button -->
150
+ <button
151
+ class="flowdrop-notes-node__config-btn"
152
+ onclick={openConfigSidebar}
153
+ title="Configure note"
154
+ >
155
+ <Icon icon="mdi:cog" />
156
+ </button>
150
157
  </div>
151
158
 
152
159
  <style>
153
- .flowdrop-notes-node {
154
- min-width: var(--fd-notes-node-min-width);
155
- max-width: var(--fd-notes-node-max-width);
156
- width: var(--fd-notes-node-width);
157
- border-radius: var(--fd-radius-xl);
158
- border: 1.5px solid var(--fd-node-border);
159
- background: var(--fd-card);
160
- backdrop-filter: var(--fd-notes-node-backdrop-filter);
161
- box-shadow: var(--fd-shadow-md);
162
- color: var(--fd-foreground);
163
- transition: all var(--fd-transition-fast);
164
- overflow: hidden;
165
- z-index: 5;
166
- }
167
-
168
- /* Note type: Info (blue) - subtle background tint, neutral border */
169
- .flowdrop-notes-node--info {
170
- background-color: var(--fd-info-muted);
171
- --_notes-icon: var(--fd-primary);
172
- }
173
-
174
- /* Note type: Warning (yellow/amber) - subtle background tint */
175
- .flowdrop-notes-node--warning {
176
- background-color: var(--fd-warning-muted);
177
- --_notes-icon: var(--fd-warning);
178
- }
179
-
180
- /* Note type: Success (green) - subtle background tint */
181
- .flowdrop-notes-node--success {
182
- background-color: var(--fd-success-muted);
183
- --_notes-icon: var(--fd-success);
184
- }
185
-
186
- /* Note type: Error (red) - subtle background tint */
187
- .flowdrop-notes-node--error {
188
- background-color: var(--fd-error-muted);
189
- --_notes-icon: var(--fd-error);
190
- }
191
-
192
- /* Note type: Note (gray/neutral) - subtle background tint */
193
- .flowdrop-notes-node--note {
194
- background-color: var(--fd-muted);
195
- --_notes-icon: var(--fd-muted-foreground);
196
- }
197
-
198
- .flowdrop-notes-node:hover {
199
- box-shadow: var(--fd-shadow-lg);
200
- border-color: var(--fd-node-border-hover);
201
- }
202
-
203
- /* Selected state - matches other node components */
204
- .flowdrop-notes-node--selected {
205
- box-shadow:
206
- 0 0 0 2px var(--fd-primary-muted),
207
- var(--fd-shadow-lg);
208
- border-color: var(--fd-primary);
209
- }
210
-
211
- .flowdrop-notes-node--selected:hover {
212
- box-shadow:
213
- 0 0 0 2px var(--fd-primary-muted),
214
- var(--fd-shadow-lg);
215
- border-color: var(--fd-primary);
216
- }
217
-
218
- .flowdrop-notes-node:focus-visible {
219
- outline: 2px solid var(--fd-ring);
220
- outline-offset: 2px;
221
- }
222
-
223
- .flowdrop-notes-node--processing {
224
- opacity: 0.7;
225
- }
226
-
227
- .flowdrop-notes-node--has-error {
228
- border-color: var(--fd-error) !important;
229
- background-color: var(--fd-error-muted) !important;
230
- }
231
-
232
- /* Display Mode Styles */
233
- .flowdrop-notes-node__content {
234
- padding: var(--fd-space-xl);
235
- height: 100%;
236
- display: flex;
237
- flex-direction: column;
238
- }
239
-
240
- .flowdrop-notes-node__header {
241
- display: flex;
242
- align-items: center;
243
- justify-content: space-between;
244
- margin-bottom: 0.75rem;
245
- flex-shrink: 0;
246
- }
247
-
248
- .flowdrop-notes-node__header-left {
249
- display: flex;
250
- align-items: center;
251
- gap: var(--fd-space-md);
252
- }
253
-
254
- /* Squircle icon wrapper - Apple-style rounded square background */
255
- .flowdrop-notes-node__icon-wrapper {
256
- display: flex;
257
- align-items: center;
258
- justify-content: center;
259
- width: 2.25rem;
260
- height: 2.25rem;
261
- border-radius: 0.5rem;
262
- background: color-mix(in srgb, var(--_notes-icon) var(--fd-node-icon-bg-opacity), transparent);
263
- flex-shrink: 0;
264
- transition: all var(--fd-transition-normal);
265
- }
266
-
267
- .flowdrop-notes-node:hover .flowdrop-notes-node__icon-wrapper {
268
- background: color-mix(
269
- in srgb,
270
- var(--_notes-icon) var(--fd-node-icon-bg-opacity-hover),
271
- transparent
272
- );
273
- transform: scale(1.05);
274
- }
275
-
276
- .flowdrop-notes-node__icon-wrapper :global(.flowdrop-notes-node__icon) {
277
- width: 1.25rem;
278
- height: 1.25rem;
279
- color: var(--fd-node-icon);
280
- }
281
-
282
- .flowdrop-notes-node__type {
283
- font-size: var(--fd-text-sm);
284
- font-weight: 500;
285
- color: var(--fd-foreground);
286
- }
287
-
288
- .flowdrop-notes-node__body {
289
- margin-bottom: var(--fd-space-xs);
290
- flex: 1;
291
- overflow-y: auto;
292
- color: var(--fd-muted-foreground);
293
- }
294
-
295
- /* Markdown content inherits foreground color for better readability */
296
- .flowdrop-notes-node__body :global(.flowdrop-notes-node__markdown) {
297
- color: var(--fd-foreground);
298
- }
299
-
300
- .flowdrop-notes-node__processing {
301
- display: flex;
302
- align-items: center;
303
- gap: var(--fd-space-xs);
304
- font-size: var(--fd-text-xs);
305
- color: var(--fd-muted-foreground);
306
- }
307
-
308
- .flowdrop-notes-node__spinner {
309
- width: 0.75rem;
310
- height: 0.75rem;
311
- border: 1px solid color-mix(in srgb, var(--fd-foreground) 30%, transparent);
312
- border-top-color: var(--fd-foreground);
313
- border-radius: 50%;
314
- animation: spin 1s linear infinite;
315
- }
316
-
317
- .flowdrop-notes-node__error-indicator {
318
- display: flex;
319
- align-items: center;
320
- gap: var(--fd-space-xs);
321
- font-size: var(--fd-text-xs);
322
- color: var(--fd-error);
323
- }
324
-
325
- :global(.flowdrop-notes-node__error-icon) {
326
- width: 0.75rem;
327
- height: 0.75rem;
328
- }
329
-
330
- @keyframes spin {
331
- to {
332
- transform: rotate(360deg);
333
- }
334
- }
335
-
336
- .flowdrop-notes-node__config-btn {
337
- position: absolute;
338
- top: var(--fd-space-xs);
339
- right: var(--fd-space-xs);
340
- width: 1.5rem;
341
- height: 1.5rem;
342
- background-color: var(--fd-backdrop);
343
- border: 1px solid var(--fd-border);
344
- border-radius: var(--fd-radius-sm);
345
- color: var(--fd-muted-foreground);
346
- cursor: pointer;
347
- display: flex;
348
- align-items: center;
349
- justify-content: center;
350
- opacity: 0;
351
- transition: all var(--fd-transition-normal);
352
- backdrop-filter: var(--fd-backdrop-blur);
353
- z-index: 15;
354
- font-size: var(--fd-text-sm);
355
- }
356
-
357
- .flowdrop-notes-node:hover .flowdrop-notes-node__config-btn {
358
- opacity: 1;
359
- }
360
-
361
- .flowdrop-notes-node__config-btn:hover {
362
- background-color: var(--fd-muted);
363
- border-color: var(--fd-border-strong);
364
- color: var(--fd-foreground);
365
- }
366
-
367
- /* Responsive design */
368
- @media (max-width: 640px) {
369
- .flowdrop-notes-node {
370
- min-width: 200px;
371
- max-width: 350px;
372
- }
373
-
374
- .flowdrop-notes-node__content {
375
- padding: var(--fd-space-md);
376
- }
377
- }
160
+ .flowdrop-notes-node {
161
+ min-width: var(--fd-notes-node-min-width);
162
+ max-width: var(--fd-notes-node-max-width);
163
+ width: var(--fd-notes-node-width);
164
+ border-radius: var(--fd-radius-xl);
165
+ border: 1.5px solid var(--fd-node-border);
166
+ background: var(--fd-card);
167
+ backdrop-filter: var(--fd-notes-node-backdrop-filter);
168
+ box-shadow: var(--fd-shadow-md);
169
+ color: var(--fd-foreground);
170
+ transition: all var(--fd-transition-fast);
171
+ overflow: hidden;
172
+ z-index: 5;
173
+ }
174
+
175
+ /* Note type: Info (blue) - subtle background tint, neutral border */
176
+ .flowdrop-notes-node--info {
177
+ background-color: var(--fd-info-muted);
178
+ --_notes-icon: var(--fd-primary);
179
+ }
180
+
181
+ /* Note type: Warning (yellow/amber) - subtle background tint */
182
+ .flowdrop-notes-node--warning {
183
+ background-color: var(--fd-warning-muted);
184
+ --_notes-icon: var(--fd-warning);
185
+ }
186
+
187
+ /* Note type: Success (green) - subtle background tint */
188
+ .flowdrop-notes-node--success {
189
+ background-color: var(--fd-success-muted);
190
+ --_notes-icon: var(--fd-success);
191
+ }
192
+
193
+ /* Note type: Error (red) - subtle background tint */
194
+ .flowdrop-notes-node--error {
195
+ background-color: var(--fd-error-muted);
196
+ --_notes-icon: var(--fd-error);
197
+ }
198
+
199
+ /* Note type: Note (gray/neutral) - subtle background tint */
200
+ .flowdrop-notes-node--note {
201
+ background-color: var(--fd-muted);
202
+ --_notes-icon: var(--fd-muted-foreground);
203
+ }
204
+
205
+ .flowdrop-notes-node:hover {
206
+ box-shadow: var(--fd-shadow-lg);
207
+ border-color: var(--fd-node-border-hover);
208
+ }
209
+
210
+ /* Selected state - matches other node components */
211
+ .flowdrop-notes-node--selected {
212
+ box-shadow:
213
+ 0 0 0 2px var(--fd-primary-muted),
214
+ var(--fd-shadow-lg);
215
+ border-color: var(--fd-primary);
216
+ }
217
+
218
+ .flowdrop-notes-node--selected:hover {
219
+ box-shadow:
220
+ 0 0 0 2px var(--fd-primary-muted),
221
+ var(--fd-shadow-lg);
222
+ border-color: var(--fd-primary);
223
+ }
224
+
225
+ .flowdrop-notes-node:focus-visible {
226
+ outline: 2px solid var(--fd-ring);
227
+ outline-offset: 2px;
228
+ }
229
+
230
+ .flowdrop-notes-node--processing {
231
+ opacity: 0.7;
232
+ }
233
+
234
+ .flowdrop-notes-node--has-error {
235
+ border-color: var(--fd-error) !important;
236
+ background-color: var(--fd-error-muted) !important;
237
+ }
238
+
239
+ /* Display Mode Styles */
240
+ .flowdrop-notes-node__content {
241
+ padding: var(--fd-space-xl);
242
+ height: 100%;
243
+ display: flex;
244
+ flex-direction: column;
245
+ }
246
+
247
+ .flowdrop-notes-node__header {
248
+ display: flex;
249
+ align-items: center;
250
+ justify-content: space-between;
251
+ margin-bottom: 0.75rem;
252
+ flex-shrink: 0;
253
+ }
254
+
255
+ .flowdrop-notes-node__header-left {
256
+ display: flex;
257
+ align-items: center;
258
+ gap: var(--fd-space-md);
259
+ }
260
+
261
+ /* Squircle icon wrapper - Apple-style rounded square background */
262
+ .flowdrop-notes-node__icon-wrapper {
263
+ display: flex;
264
+ align-items: center;
265
+ justify-content: center;
266
+ width: 2.25rem;
267
+ height: 2.25rem;
268
+ border-radius: 0.5rem;
269
+ background: color-mix(
270
+ in srgb,
271
+ var(--_notes-icon) var(--fd-node-icon-bg-opacity),
272
+ transparent
273
+ );
274
+ flex-shrink: 0;
275
+ transition: all var(--fd-transition-normal);
276
+ }
277
+
278
+ .flowdrop-notes-node:hover .flowdrop-notes-node__icon-wrapper {
279
+ background: color-mix(
280
+ in srgb,
281
+ var(--_notes-icon) var(--fd-node-icon-bg-opacity-hover),
282
+ transparent
283
+ );
284
+ transform: scale(1.05);
285
+ }
286
+
287
+ .flowdrop-notes-node__icon-wrapper :global(.flowdrop-notes-node__icon) {
288
+ width: 1.25rem;
289
+ height: 1.25rem;
290
+ color: var(--fd-node-icon);
291
+ }
292
+
293
+ .flowdrop-notes-node__type {
294
+ font-size: var(--fd-text-sm);
295
+ font-weight: 500;
296
+ color: var(--fd-foreground);
297
+ }
298
+
299
+ .flowdrop-notes-node__body {
300
+ margin-bottom: var(--fd-space-xs);
301
+ flex: 1;
302
+ overflow-y: auto;
303
+ color: var(--fd-muted-foreground);
304
+ }
305
+
306
+ /* Markdown content inherits foreground color for better readability */
307
+ .flowdrop-notes-node__body :global(.flowdrop-notes-node__markdown) {
308
+ color: var(--fd-foreground);
309
+ }
310
+
311
+ .flowdrop-notes-node__processing {
312
+ display: flex;
313
+ align-items: center;
314
+ gap: var(--fd-space-xs);
315
+ font-size: var(--fd-text-xs);
316
+ color: var(--fd-muted-foreground);
317
+ }
318
+
319
+ .flowdrop-notes-node__spinner {
320
+ width: 0.75rem;
321
+ height: 0.75rem;
322
+ border: 1px solid color-mix(in srgb, var(--fd-foreground) 30%, transparent);
323
+ border-top-color: var(--fd-foreground);
324
+ border-radius: 50%;
325
+ animation: spin 1s linear infinite;
326
+ }
327
+
328
+ .flowdrop-notes-node__error-indicator {
329
+ display: flex;
330
+ align-items: center;
331
+ gap: var(--fd-space-xs);
332
+ font-size: var(--fd-text-xs);
333
+ color: var(--fd-error);
334
+ }
335
+
336
+ :global(.flowdrop-notes-node__error-icon) {
337
+ width: 0.75rem;
338
+ height: 0.75rem;
339
+ }
340
+
341
+ @keyframes spin {
342
+ to {
343
+ transform: rotate(360deg);
344
+ }
345
+ }
346
+
347
+ .flowdrop-notes-node__config-btn {
348
+ position: absolute;
349
+ top: var(--fd-space-xs);
350
+ right: var(--fd-space-xs);
351
+ width: 1.5rem;
352
+ height: 1.5rem;
353
+ background-color: var(--fd-backdrop);
354
+ border: 1px solid var(--fd-border);
355
+ border-radius: var(--fd-radius-sm);
356
+ color: var(--fd-muted-foreground);
357
+ cursor: pointer;
358
+ display: flex;
359
+ align-items: center;
360
+ justify-content: center;
361
+ opacity: 0;
362
+ transition: all var(--fd-transition-normal);
363
+ backdrop-filter: var(--fd-backdrop-blur);
364
+ z-index: 15;
365
+ font-size: var(--fd-text-sm);
366
+ }
367
+
368
+ .flowdrop-notes-node:hover .flowdrop-notes-node__config-btn {
369
+ opacity: 1;
370
+ }
371
+
372
+ .flowdrop-notes-node__config-btn:hover {
373
+ background-color: var(--fd-muted);
374
+ border-color: var(--fd-border-strong);
375
+ color: var(--fd-foreground);
376
+ }
377
+
378
+ /* Responsive design */
379
+ @media (max-width: 640px) {
380
+ .flowdrop-notes-node {
381
+ min-width: 200px;
382
+ max-width: 350px;
383
+ }
384
+
385
+ .flowdrop-notes-node__content {
386
+ padding: var(--fd-space-md);
387
+ }
388
+ }
378
389
  </style>