@rxflow/workflow 0.0.1-alpha.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 (446) hide show
  1. package/README.md +43 -0
  2. package/cjs/components/CanvasLoading/index.d.ts +14 -0
  3. package/cjs/components/CanvasLoading/index.d.ts.map +1 -0
  4. package/cjs/components/CanvasLoading/index.js +51 -0
  5. package/cjs/components/CanvasLoading/index.less +69 -0
  6. package/cjs/components/CodeEditor/DebugPanel/index.d.ts +16 -0
  7. package/cjs/components/CodeEditor/DebugPanel/index.d.ts.map +1 -0
  8. package/cjs/components/CodeEditor/DebugPanel/index.js +156 -0
  9. package/cjs/components/CodeEditor/DebugPanel/index.less +56 -0
  10. package/cjs/components/CodeEditor/FileTree/LibraryIcon.d.ts +11 -0
  11. package/cjs/components/CodeEditor/FileTree/LibraryIcon.d.ts.map +1 -0
  12. package/cjs/components/CodeEditor/FileTree/LibraryIcon.js +33 -0
  13. package/cjs/components/CodeEditor/FileTree/icons/Javascript.d.ts +11 -0
  14. package/cjs/components/CodeEditor/FileTree/icons/Javascript.d.ts.map +1 -0
  15. package/cjs/components/CodeEditor/FileTree/icons/Javascript.js +37 -0
  16. package/cjs/components/CodeEditor/FileTree/icons/Python.d.ts +11 -0
  17. package/cjs/components/CodeEditor/FileTree/icons/Python.d.ts.map +1 -0
  18. package/cjs/components/CodeEditor/FileTree/icons/Python.js +37 -0
  19. package/cjs/components/CodeEditor/FileTree/index.d.ts +9 -0
  20. package/cjs/components/CodeEditor/FileTree/index.d.ts.map +1 -0
  21. package/cjs/components/CodeEditor/FileTree/index.js +73 -0
  22. package/cjs/components/CodeEditor/FileTree/index.less +83 -0
  23. package/cjs/components/CodeEditor/FileTree/useFileIcon.d.ts +11 -0
  24. package/cjs/components/CodeEditor/FileTree/useFileIcon.d.ts.map +1 -0
  25. package/cjs/components/CodeEditor/FileTree/useFileIcon.js +44 -0
  26. package/cjs/components/CodeEditor/Header/index.d.ts +15 -0
  27. package/cjs/components/CodeEditor/Header/index.d.ts.map +1 -0
  28. package/cjs/components/CodeEditor/Header/index.js +51 -0
  29. package/cjs/components/CodeEditor/Header/style.less +23 -0
  30. package/cjs/components/CodeEditor/Terminal/XTerm.d.ts +5 -0
  31. package/cjs/components/CodeEditor/Terminal/XTerm.d.ts.map +1 -0
  32. package/cjs/components/CodeEditor/Terminal/XTerm.js +54 -0
  33. package/cjs/components/CodeEditor/Terminal/index.d.ts +15 -0
  34. package/cjs/components/CodeEditor/Terminal/index.d.ts.map +1 -0
  35. package/cjs/components/CodeEditor/Terminal/index.js +30 -0
  36. package/cjs/components/CodeEditor/Terminal/index.less +28 -0
  37. package/cjs/components/CodeEditor/Terminal/types.d.ts +13 -0
  38. package/cjs/components/CodeEditor/editors/JSON.d.ts +12 -0
  39. package/cjs/components/CodeEditor/editors/JSON.d.ts.map +1 -0
  40. package/cjs/components/CodeEditor/editors/JSON.js +43 -0
  41. package/cjs/components/CodeEditor/editors/Python.d.ts +4 -0
  42. package/cjs/components/CodeEditor/editors/Python.d.ts.map +1 -0
  43. package/cjs/components/CodeEditor/editors/Python.js +43 -0
  44. package/cjs/components/CodeEditor/editors/index.less +11 -0
  45. package/cjs/components/CodeEditor/editors/types.d.ts +24 -0
  46. package/cjs/components/CodeEditor/index.d.ts +7 -0
  47. package/cjs/components/CodeEditor/index.d.ts.map +1 -0
  48. package/cjs/components/CodeEditor/index.js +230 -0
  49. package/cjs/components/CodeEditor/style.less +49 -0
  50. package/cjs/components/CodeEditor/types.d.ts +46 -0
  51. package/cjs/components/Handle/NodePopover.d.ts +15 -0
  52. package/cjs/components/Handle/NodePopover.d.ts.map +1 -0
  53. package/cjs/components/Handle/NodePopover.js +169 -0
  54. package/cjs/components/Handle/index.d.ts +24 -0
  55. package/cjs/components/Handle/index.d.ts.map +1 -0
  56. package/cjs/components/Handle/index.js +165 -0
  57. package/cjs/components/Handle/index.less +111 -0
  58. package/cjs/components/InlineCodeEditor/index.d.ts +11 -0
  59. package/cjs/components/InlineCodeEditor/index.d.ts.map +1 -0
  60. package/cjs/components/InlineCodeEditor/index.js +31 -0
  61. package/cjs/components/InlineCodeEditor/index.module.less +0 -0
  62. package/cjs/components/InlineCodeEditor/types.d.ts +22 -0
  63. package/cjs/components/Layout/index.d.ts +14 -0
  64. package/cjs/components/Layout/index.d.ts.map +1 -0
  65. package/cjs/components/Layout/index.js +49 -0
  66. package/cjs/components/Layout/index.less +14 -0
  67. package/cjs/components/LoadingButton.d.ts +16 -0
  68. package/cjs/components/LoadingButton.d.ts.map +1 -0
  69. package/cjs/components/LoadingButton.js +86 -0
  70. package/cjs/components/Sider/index.d.ts +15 -0
  71. package/cjs/components/Sider/index.d.ts.map +1 -0
  72. package/cjs/components/Sider/index.js +142 -0
  73. package/cjs/components/Sider/index.less +68 -0
  74. package/cjs/constants/RunningStatus.d.ts +14 -0
  75. package/cjs/constants/RunningStatus.d.ts.map +1 -0
  76. package/cjs/constants/RunningStatus.js +20 -0
  77. package/cjs/hooks/run/useActiveEdge.d.ts +15 -0
  78. package/cjs/hooks/run/useActiveEdge.d.ts.map +1 -0
  79. package/cjs/hooks/run/useActiveEdge.js +36 -0
  80. package/cjs/hooks/run/useCleanRunState.d.ts +9 -0
  81. package/cjs/hooks/run/useCleanRunState.d.ts.map +1 -0
  82. package/cjs/hooks/run/useCleanRunState.js +33 -0
  83. package/cjs/hooks/run/useNodeRunningState.d.ts +8 -0
  84. package/cjs/hooks/run/useNodeRunningState.d.ts.map +1 -0
  85. package/cjs/hooks/run/useNodeRunningState.js +30 -0
  86. package/cjs/hooks/run/useRunState.d.ts +21 -0
  87. package/cjs/hooks/run/useRunState.d.ts.map +1 -0
  88. package/cjs/hooks/run/useRunState.js +39 -0
  89. package/cjs/hooks/run/useSetRunState.d.ts +18 -0
  90. package/cjs/hooks/run/useSetRunState.d.ts.map +1 -0
  91. package/cjs/hooks/run/useSetRunState.js +39 -0
  92. package/cjs/hooks/state.d.ts +7 -0
  93. package/cjs/hooks/state.d.ts.map +1 -0
  94. package/cjs/hooks/state.js +13 -0
  95. package/cjs/hooks/useDeleteNode.d.ts +2 -0
  96. package/cjs/hooks/useDeleteNode.d.ts.map +1 -0
  97. package/cjs/hooks/useDeleteNode.js +32 -0
  98. package/cjs/hooks/useEdgeIsHover.d.ts +2 -0
  99. package/cjs/hooks/useEdgeIsHover.d.ts.map +1 -0
  100. package/cjs/hooks/useEdgeIsHover.js +20 -0
  101. package/cjs/hooks/useGetSelection.d.ts +13 -0
  102. package/cjs/hooks/useGetSelection.d.ts.map +1 -0
  103. package/cjs/hooks/useGetSelection.js +28 -0
  104. package/cjs/hooks/useGetUpstreamNodes.d.ts +14 -0
  105. package/cjs/hooks/useGetUpstreamNodes.d.ts.map +1 -0
  106. package/cjs/hooks/useGetUpstreamNodes.js +81 -0
  107. package/cjs/hooks/useGetWillDropTarget.d.ts +5 -0
  108. package/cjs/hooks/useGetWillDropTarget.d.ts.map +1 -0
  109. package/cjs/hooks/useGetWillDropTarget.js +27 -0
  110. package/cjs/hooks/useGroupIsWillDrop.d.ts +2 -0
  111. package/cjs/hooks/useGroupIsWillDrop.d.ts.map +1 -0
  112. package/cjs/hooks/useGroupIsWillDrop.js +20 -0
  113. package/cjs/hooks/useIsValidConnection.d.ts +12 -0
  114. package/cjs/hooks/useIsValidConnection.d.ts.map +1 -0
  115. package/cjs/hooks/useIsValidConnection.js +83 -0
  116. package/cjs/hooks/useMouseEvents.d.ts +19 -0
  117. package/cjs/hooks/useMouseEvents.d.ts.map +1 -0
  118. package/cjs/hooks/useMouseEvents.js +49 -0
  119. package/cjs/hooks/useNodeDragHandles.d.ts +10 -0
  120. package/cjs/hooks/useNodeDragHandles.d.ts.map +1 -0
  121. package/cjs/hooks/useNodeDragHandles.js +273 -0
  122. package/cjs/hooks/useNodes.d.ts +9 -0
  123. package/cjs/hooks/useNodes.d.ts.map +1 -0
  124. package/cjs/hooks/useNodes.js +19 -0
  125. package/cjs/hooks/useOnBeforeDelete.d.ts +19 -0
  126. package/cjs/hooks/useOnBeforeDelete.d.ts.map +1 -0
  127. package/cjs/hooks/useOnBeforeDelete.js +104 -0
  128. package/cjs/hooks/useOnConnect.d.ts +12 -0
  129. package/cjs/hooks/useOnConnect.d.ts.map +1 -0
  130. package/cjs/hooks/useOnConnect.js +36 -0
  131. package/cjs/hooks/useOnEdgeMouseEnter.d.ts +13 -0
  132. package/cjs/hooks/useOnEdgeMouseEnter.d.ts.map +1 -0
  133. package/cjs/hooks/useOnEdgeMouseEnter.js +27 -0
  134. package/cjs/hooks/useOnEdgeMouseLeave.d.ts +13 -0
  135. package/cjs/hooks/useOnEdgeMouseLeave.d.ts.map +1 -0
  136. package/cjs/hooks/useOnEdgeMouseLeave.js +27 -0
  137. package/cjs/hooks/useOnNodesChange.d.ts +4 -0
  138. package/cjs/hooks/useOnNodesChange.d.ts.map +1 -0
  139. package/cjs/hooks/useOnNodesChange.js +102 -0
  140. package/cjs/hooks/useOnSelectionChange.d.ts +13 -0
  141. package/cjs/hooks/useOnSelectionChange.d.ts.map +1 -0
  142. package/cjs/hooks/useOnSelectionChange.js +130 -0
  143. package/cjs/hooks/useSetEdges.d.ts +12 -0
  144. package/cjs/hooks/useSetEdges.d.ts.map +1 -0
  145. package/cjs/hooks/useSetEdges.js +29 -0
  146. package/cjs/hooks/useSetSelection.d.ts +3 -0
  147. package/cjs/hooks/useSetSelection.d.ts.map +1 -0
  148. package/cjs/hooks/useSetSelection.js +40 -0
  149. package/cjs/hooks/useSetWillDropTargets.d.ts +2 -0
  150. package/cjs/hooks/useSetWillDropTargets.d.ts.map +1 -0
  151. package/cjs/hooks/useSetWillDropTargets.js +26 -0
  152. package/cjs/hooks/useUpstream.d.ts +3 -0
  153. package/cjs/hooks/useUpstream.d.ts.map +1 -0
  154. package/cjs/hooks/useUpstream.js +105 -0
  155. package/cjs/hooks/useWatchSelectionNodes.d.ts +2 -0
  156. package/cjs/hooks/useWatchSelectionNodes.d.ts.map +1 -0
  157. package/cjs/hooks/useWatchSelectionNodes.js +22 -0
  158. package/cjs/hooks/useWorkFlow.d.ts +12 -0
  159. package/cjs/hooks/useWorkFlow.d.ts.map +1 -0
  160. package/cjs/hooks/useWorkFlow.js +93 -0
  161. package/cjs/hooks/useWorkFlowProps.d.ts +485 -0
  162. package/cjs/hooks/useWorkFlowProps.d.ts.map +1 -0
  163. package/cjs/hooks/useWorkFlowProps.js +98 -0
  164. package/cjs/index.d.ts +23 -0
  165. package/cjs/index.d.ts.map +1 -0
  166. package/cjs/index.js +77 -0
  167. package/cjs/types.d.ts +103 -0
  168. package/cjs/types.d.ts.map +1 -0
  169. package/cjs/types.js +8 -0
  170. package/cjs/utils/arrayUtils.d.ts +2 -0
  171. package/cjs/utils/arrayUtils.d.ts.map +1 -0
  172. package/cjs/utils/arrayUtils.js +23 -0
  173. package/cjs/utils/checkChildren.d.ts +11 -0
  174. package/cjs/utils/checkChildren.d.ts.map +1 -0
  175. package/cjs/utils/checkChildren.js +27 -0
  176. package/cjs/utils/dimensions.d.ts +12 -0
  177. package/cjs/utils/dimensions.d.ts.map +1 -0
  178. package/cjs/utils/dimensions.js +23 -0
  179. package/cjs/utils/dragDataTransfer.d.ts +19 -0
  180. package/cjs/utils/dragDataTransfer.d.ts.map +1 -0
  181. package/cjs/utils/dragDataTransfer.js +29 -0
  182. package/cjs/utils/dropTargetsCheck.d.ts +20 -0
  183. package/cjs/utils/dropTargetsCheck.d.ts.map +1 -0
  184. package/cjs/utils/dropTargetsCheck.js +105 -0
  185. package/cjs/utils/edgeEqualConnect.d.ts +11 -0
  186. package/cjs/utils/edgeEqualConnect.d.ts.map +1 -0
  187. package/cjs/utils/edgeEqualConnect.js +19 -0
  188. package/cjs/utils/events.d.ts +11 -0
  189. package/cjs/utils/events.d.ts.map +1 -0
  190. package/cjs/utils/events.js +19 -0
  191. package/cjs/utils/getEdgeId.d.ts +12 -0
  192. package/cjs/utils/getEdgeId.d.ts.map +1 -0
  193. package/cjs/utils/getEdgeId.js +22 -0
  194. package/cjs/utils/getParentFlow.d.ts +5 -0
  195. package/cjs/utils/getParentFlow.d.ts.map +1 -0
  196. package/cjs/utils/getParentFlow.js +36 -0
  197. package/cjs/utils/graph.d.ts +12 -0
  198. package/cjs/utils/graph.d.ts.map +1 -0
  199. package/cjs/utils/graph.js +55 -0
  200. package/cjs/utils/index.d.ts +18 -0
  201. package/cjs/utils/index.d.ts.map +1 -0
  202. package/cjs/utils/index.js +104 -0
  203. package/cjs/utils/isInSameParent.d.ts +11 -0
  204. package/cjs/utils/isInSameParent.d.ts.map +1 -0
  205. package/cjs/utils/isInSameParent.js +19 -0
  206. package/cjs/utils/parent.d.ts +23 -0
  207. package/cjs/utils/parent.d.ts.map +1 -0
  208. package/cjs/utils/parent.js +166 -0
  209. package/cjs/utils/position.d.ts +29 -0
  210. package/cjs/utils/position.d.ts.map +1 -0
  211. package/cjs/utils/position.js +67 -0
  212. package/cjs/utils/prepareInnerLookup.d.ts +16 -0
  213. package/cjs/utils/prepareInnerLookup.d.ts.map +1 -0
  214. package/cjs/utils/prepareInnerLookup.js +93 -0
  215. package/cjs/utils/scheduleCallback.d.ts +2 -0
  216. package/cjs/utils/scheduleCallback.d.ts.map +1 -0
  217. package/cjs/utils/scheduleCallback.js +38 -0
  218. package/cjs/utils/serialize.d.ts +31 -0
  219. package/cjs/utils/serialize.d.ts.map +1 -0
  220. package/cjs/utils/serialize.js +60 -0
  221. package/cjs/utils/triggerConnect.d.ts +12 -0
  222. package/cjs/utils/triggerConnect.d.ts.map +1 -0
  223. package/cjs/utils/triggerConnect.js +50 -0
  224. package/esm/components/CanvasLoading/index.d.ts +14 -0
  225. package/esm/components/CanvasLoading/index.d.ts.map +1 -0
  226. package/esm/components/CanvasLoading/index.js +45 -0
  227. package/esm/components/CanvasLoading/index.less +69 -0
  228. package/esm/components/CodeEditor/DebugPanel/index.d.ts +16 -0
  229. package/esm/components/CodeEditor/DebugPanel/index.d.ts.map +1 -0
  230. package/esm/components/CodeEditor/DebugPanel/index.js +199 -0
  231. package/esm/components/CodeEditor/DebugPanel/index.less +56 -0
  232. package/esm/components/CodeEditor/FileTree/LibraryIcon.d.ts +11 -0
  233. package/esm/components/CodeEditor/FileTree/LibraryIcon.d.ts.map +1 -0
  234. package/esm/components/CodeEditor/FileTree/LibraryIcon.js +27 -0
  235. package/esm/components/CodeEditor/FileTree/icons/Javascript.d.ts +11 -0
  236. package/esm/components/CodeEditor/FileTree/icons/Javascript.d.ts.map +1 -0
  237. package/esm/components/CodeEditor/FileTree/icons/Javascript.js +32 -0
  238. package/esm/components/CodeEditor/FileTree/icons/Python.d.ts +11 -0
  239. package/esm/components/CodeEditor/FileTree/icons/Python.d.ts.map +1 -0
  240. package/esm/components/CodeEditor/FileTree/icons/Python.js +32 -0
  241. package/esm/components/CodeEditor/FileTree/index.d.ts +9 -0
  242. package/esm/components/CodeEditor/FileTree/index.d.ts.map +1 -0
  243. package/esm/components/CodeEditor/FileTree/index.js +62 -0
  244. package/esm/components/CodeEditor/FileTree/index.less +83 -0
  245. package/esm/components/CodeEditor/FileTree/useFileIcon.d.ts +11 -0
  246. package/esm/components/CodeEditor/FileTree/useFileIcon.d.ts.map +1 -0
  247. package/esm/components/CodeEditor/FileTree/useFileIcon.js +39 -0
  248. package/esm/components/CodeEditor/Header/index.d.ts +15 -0
  249. package/esm/components/CodeEditor/Header/index.d.ts.map +1 -0
  250. package/esm/components/CodeEditor/Header/index.js +43 -0
  251. package/esm/components/CodeEditor/Header/style.less +23 -0
  252. package/esm/components/CodeEditor/Terminal/XTerm.d.ts +5 -0
  253. package/esm/components/CodeEditor/Terminal/XTerm.d.ts.map +1 -0
  254. package/esm/components/CodeEditor/Terminal/XTerm.js +59 -0
  255. package/esm/components/CodeEditor/Terminal/index.d.ts +15 -0
  256. package/esm/components/CodeEditor/Terminal/index.d.ts.map +1 -0
  257. package/esm/components/CodeEditor/Terminal/index.js +23 -0
  258. package/esm/components/CodeEditor/Terminal/index.less +28 -0
  259. package/esm/components/CodeEditor/Terminal/types.d.ts +13 -0
  260. package/esm/components/CodeEditor/editors/JSON.d.ts +12 -0
  261. package/esm/components/CodeEditor/editors/JSON.d.ts.map +1 -0
  262. package/esm/components/CodeEditor/editors/JSON.js +35 -0
  263. package/esm/components/CodeEditor/editors/Python.d.ts +4 -0
  264. package/esm/components/CodeEditor/editors/Python.d.ts.map +1 -0
  265. package/esm/components/CodeEditor/editors/Python.js +34 -0
  266. package/esm/components/CodeEditor/editors/index.less +11 -0
  267. package/esm/components/CodeEditor/editors/types.d.ts +24 -0
  268. package/esm/components/CodeEditor/index.d.ts +7 -0
  269. package/esm/components/CodeEditor/index.d.ts.map +1 -0
  270. package/esm/components/CodeEditor/index.js +233 -0
  271. package/esm/components/CodeEditor/style.less +49 -0
  272. package/esm/components/CodeEditor/types.d.ts +46 -0
  273. package/esm/components/Handle/NodePopover.d.ts +15 -0
  274. package/esm/components/Handle/NodePopover.d.ts.map +1 -0
  275. package/esm/components/Handle/NodePopover.js +165 -0
  276. package/esm/components/Handle/index.d.ts +24 -0
  277. package/esm/components/Handle/index.d.ts.map +1 -0
  278. package/esm/components/Handle/index.js +190 -0
  279. package/esm/components/Handle/index.less +111 -0
  280. package/esm/components/InlineCodeEditor/index.d.ts +11 -0
  281. package/esm/components/InlineCodeEditor/index.d.ts.map +1 -0
  282. package/esm/components/InlineCodeEditor/index.js +24 -0
  283. package/esm/components/InlineCodeEditor/index.module.less +0 -0
  284. package/esm/components/InlineCodeEditor/types.d.ts +22 -0
  285. package/esm/components/Layout/index.d.ts +14 -0
  286. package/esm/components/Layout/index.d.ts.map +1 -0
  287. package/esm/components/Layout/index.js +43 -0
  288. package/esm/components/Layout/index.less +14 -0
  289. package/esm/components/LoadingButton.d.ts +16 -0
  290. package/esm/components/LoadingButton.d.ts.map +1 -0
  291. package/esm/components/LoadingButton.js +112 -0
  292. package/esm/components/Sider/index.d.ts +15 -0
  293. package/esm/components/Sider/index.d.ts.map +1 -0
  294. package/esm/components/Sider/index.js +142 -0
  295. package/esm/components/Sider/index.less +68 -0
  296. package/esm/constants/RunningStatus.d.ts +14 -0
  297. package/esm/constants/RunningStatus.d.ts.map +1 -0
  298. package/esm/constants/RunningStatus.js +15 -0
  299. package/esm/hooks/run/useActiveEdge.d.ts +15 -0
  300. package/esm/hooks/run/useActiveEdge.d.ts.map +1 -0
  301. package/esm/hooks/run/useActiveEdge.js +30 -0
  302. package/esm/hooks/run/useCleanRunState.d.ts +9 -0
  303. package/esm/hooks/run/useCleanRunState.d.ts.map +1 -0
  304. package/esm/hooks/run/useCleanRunState.js +26 -0
  305. package/esm/hooks/run/useNodeRunningState.d.ts +8 -0
  306. package/esm/hooks/run/useNodeRunningState.d.ts.map +1 -0
  307. package/esm/hooks/run/useNodeRunningState.js +26 -0
  308. package/esm/hooks/run/useRunState.d.ts +21 -0
  309. package/esm/hooks/run/useRunState.d.ts.map +1 -0
  310. package/esm/hooks/run/useRunState.js +35 -0
  311. package/esm/hooks/run/useSetRunState.d.ts +18 -0
  312. package/esm/hooks/run/useSetRunState.d.ts.map +1 -0
  313. package/esm/hooks/run/useSetRunState.js +35 -0
  314. package/esm/hooks/state.d.ts +7 -0
  315. package/esm/hooks/state.d.ts.map +1 -0
  316. package/esm/hooks/state.js +6 -0
  317. package/esm/hooks/useDeleteNode.d.ts +2 -0
  318. package/esm/hooks/useDeleteNode.d.ts.map +1 -0
  319. package/esm/hooks/useDeleteNode.js +44 -0
  320. package/esm/hooks/useEdgeIsHover.d.ts +2 -0
  321. package/esm/hooks/useEdgeIsHover.d.ts.map +1 -0
  322. package/esm/hooks/useEdgeIsHover.js +14 -0
  323. package/esm/hooks/useGetSelection.d.ts +13 -0
  324. package/esm/hooks/useGetSelection.d.ts.map +1 -0
  325. package/esm/hooks/useGetSelection.js +21 -0
  326. package/esm/hooks/useGetUpstreamNodes.d.ts +14 -0
  327. package/esm/hooks/useGetUpstreamNodes.d.ts.map +1 -0
  328. package/esm/hooks/useGetUpstreamNodes.js +71 -0
  329. package/esm/hooks/useGetWillDropTarget.d.ts +5 -0
  330. package/esm/hooks/useGetWillDropTarget.d.ts.map +1 -0
  331. package/esm/hooks/useGetWillDropTarget.js +21 -0
  332. package/esm/hooks/useGroupIsWillDrop.d.ts +2 -0
  333. package/esm/hooks/useGroupIsWillDrop.d.ts.map +1 -0
  334. package/esm/hooks/useGroupIsWillDrop.js +14 -0
  335. package/esm/hooks/useIsValidConnection.d.ts +12 -0
  336. package/esm/hooks/useIsValidConnection.d.ts.map +1 -0
  337. package/esm/hooks/useIsValidConnection.js +82 -0
  338. package/esm/hooks/useMouseEvents.d.ts +19 -0
  339. package/esm/hooks/useMouseEvents.d.ts.map +1 -0
  340. package/esm/hooks/useMouseEvents.js +40 -0
  341. package/esm/hooks/useNodeDragHandles.d.ts +10 -0
  342. package/esm/hooks/useNodeDragHandles.d.ts.map +1 -0
  343. package/esm/hooks/useNodeDragHandles.js +311 -0
  344. package/esm/hooks/useNodes.d.ts +9 -0
  345. package/esm/hooks/useNodes.d.ts.map +1 -0
  346. package/esm/hooks/useNodes.js +14 -0
  347. package/esm/hooks/useOnBeforeDelete.d.ts +19 -0
  348. package/esm/hooks/useOnBeforeDelete.d.ts.map +1 -0
  349. package/esm/hooks/useOnBeforeDelete.js +138 -0
  350. package/esm/hooks/useOnConnect.d.ts +12 -0
  351. package/esm/hooks/useOnConnect.d.ts.map +1 -0
  352. package/esm/hooks/useOnConnect.js +26 -0
  353. package/esm/hooks/useOnEdgeMouseEnter.d.ts +13 -0
  354. package/esm/hooks/useOnEdgeMouseEnter.d.ts.map +1 -0
  355. package/esm/hooks/useOnEdgeMouseEnter.js +20 -0
  356. package/esm/hooks/useOnEdgeMouseLeave.d.ts +13 -0
  357. package/esm/hooks/useOnEdgeMouseLeave.d.ts.map +1 -0
  358. package/esm/hooks/useOnEdgeMouseLeave.js +20 -0
  359. package/esm/hooks/useOnNodesChange.d.ts +4 -0
  360. package/esm/hooks/useOnNodesChange.d.ts.map +1 -0
  361. package/esm/hooks/useOnNodesChange.js +107 -0
  362. package/esm/hooks/useOnSelectionChange.d.ts +13 -0
  363. package/esm/hooks/useOnSelectionChange.d.ts.map +1 -0
  364. package/esm/hooks/useOnSelectionChange.js +171 -0
  365. package/esm/hooks/useSetEdges.d.ts +12 -0
  366. package/esm/hooks/useSetEdges.d.ts.map +1 -0
  367. package/esm/hooks/useSetEdges.js +22 -0
  368. package/esm/hooks/useSetSelection.d.ts +3 -0
  369. package/esm/hooks/useSetSelection.d.ts.map +1 -0
  370. package/esm/hooks/useSetSelection.js +33 -0
  371. package/esm/hooks/useSetWillDropTargets.d.ts +2 -0
  372. package/esm/hooks/useSetWillDropTargets.d.ts.map +1 -0
  373. package/esm/hooks/useSetWillDropTargets.js +18 -0
  374. package/esm/hooks/useUpstream.d.ts +3 -0
  375. package/esm/hooks/useUpstream.d.ts.map +1 -0
  376. package/esm/hooks/useUpstream.js +101 -0
  377. package/esm/hooks/useWatchSelectionNodes.d.ts +2 -0
  378. package/esm/hooks/useWatchSelectionNodes.d.ts.map +1 -0
  379. package/esm/hooks/useWatchSelectionNodes.js +14 -0
  380. package/esm/hooks/useWorkFlow.d.ts +12 -0
  381. package/esm/hooks/useWorkFlow.d.ts.map +1 -0
  382. package/esm/hooks/useWorkFlow.js +92 -0
  383. package/esm/hooks/useWorkFlowProps.d.ts +485 -0
  384. package/esm/hooks/useWorkFlowProps.d.ts.map +1 -0
  385. package/esm/hooks/useWorkFlowProps.js +102 -0
  386. package/esm/index.d.ts +23 -0
  387. package/esm/index.d.ts.map +1 -0
  388. package/esm/index.js +28 -0
  389. package/esm/types.d.ts +103 -0
  390. package/esm/types.d.ts.map +1 -0
  391. package/esm/types.js +4 -0
  392. package/esm/utils/arrayUtils.d.ts +2 -0
  393. package/esm/utils/arrayUtils.d.ts.map +1 -0
  394. package/esm/utils/arrayUtils.js +16 -0
  395. package/esm/utils/checkChildren.d.ts +11 -0
  396. package/esm/utils/checkChildren.d.ts.map +1 -0
  397. package/esm/utils/checkChildren.js +16 -0
  398. package/esm/utils/dimensions.d.ts +12 -0
  399. package/esm/utils/dimensions.d.ts.map +1 -0
  400. package/esm/utils/dimensions.js +17 -0
  401. package/esm/utils/dragDataTransfer.d.ts +19 -0
  402. package/esm/utils/dragDataTransfer.d.ts.map +1 -0
  403. package/esm/utils/dragDataTransfer.js +21 -0
  404. package/esm/utils/dropTargetsCheck.d.ts +20 -0
  405. package/esm/utils/dropTargetsCheck.d.ts.map +1 -0
  406. package/esm/utils/dropTargetsCheck.js +116 -0
  407. package/esm/utils/edgeEqualConnect.d.ts +11 -0
  408. package/esm/utils/edgeEqualConnect.d.ts.map +1 -0
  409. package/esm/utils/edgeEqualConnect.js +12 -0
  410. package/esm/utils/events.d.ts +11 -0
  411. package/esm/utils/events.d.ts.map +1 -0
  412. package/esm/utils/events.js +12 -0
  413. package/esm/utils/getEdgeId.d.ts +12 -0
  414. package/esm/utils/getEdgeId.d.ts.map +1 -0
  415. package/esm/utils/getEdgeId.js +16 -0
  416. package/esm/utils/getParentFlow.d.ts +5 -0
  417. package/esm/utils/getParentFlow.d.ts.map +1 -0
  418. package/esm/utils/getParentFlow.js +28 -0
  419. package/esm/utils/graph.d.ts +12 -0
  420. package/esm/utils/graph.d.ts.map +1 -0
  421. package/esm/utils/graph.js +51 -0
  422. package/esm/utils/index.d.ts +18 -0
  423. package/esm/utils/index.d.ts.map +1 -0
  424. package/esm/utils/index.js +18 -0
  425. package/esm/utils/isInSameParent.d.ts +11 -0
  426. package/esm/utils/isInSameParent.d.ts.map +1 -0
  427. package/esm/utils/isInSameParent.js +12 -0
  428. package/esm/utils/parent.d.ts +23 -0
  429. package/esm/utils/parent.d.ts.map +1 -0
  430. package/esm/utils/parent.js +186 -0
  431. package/esm/utils/position.d.ts +29 -0
  432. package/esm/utils/position.d.ts.map +1 -0
  433. package/esm/utils/position.js +61 -0
  434. package/esm/utils/prepareInnerLookup.d.ts +16 -0
  435. package/esm/utils/prepareInnerLookup.d.ts.map +1 -0
  436. package/esm/utils/prepareInnerLookup.js +79 -0
  437. package/esm/utils/scheduleCallback.d.ts +2 -0
  438. package/esm/utils/scheduleCallback.d.ts.map +1 -0
  439. package/esm/utils/scheduleCallback.js +36 -0
  440. package/esm/utils/serialize.d.ts +31 -0
  441. package/esm/utils/serialize.d.ts.map +1 -0
  442. package/esm/utils/serialize.js +64 -0
  443. package/esm/utils/triggerConnect.d.ts +12 -0
  444. package/esm/utils/triggerConnect.d.ts.map +1 -0
  445. package/esm/utils/triggerConnect.js +59 -0
  446. package/package.json +70 -0
@@ -0,0 +1,165 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Handle = void 0;
7
+ var _PlusOutlined = _interopRequireDefault(require("@ant-design/icons/PlusOutlined"));
8
+ var _ = require("../..");
9
+ var _react = require("@xyflow/react");
10
+ var _ahooks = require("ahooks");
11
+ var _base = require("@rxflow/base");
12
+ var _classcat = _interopRequireDefault(require("classcat"));
13
+ var _react2 = require("react");
14
+ require("./index.less");
15
+ var _useWorkFlow = require("../../hooks/useWorkFlow");
16
+ var _events = require("../../utils/events");
17
+ var _NodePopover = require("./NodePopover");
18
+ var _ExclamationOutlined = _interopRequireDefault(require("@ant-design/icons/lib/icons/ExclamationOutlined"));
19
+ var _jsxRuntime = require("react/jsx-runtime");
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+ /**
22
+ * @author: yanxianliang
23
+ * @date: 2025-09-06 09:52
24
+ * @modified:2025/9/6 09:52 by yanxianliang
25
+ * @desc: Handle 自定义
26
+ *
27
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
28
+ */
29
+
30
+ /**
31
+ * 链接桩组件
32
+ * @param props
33
+ * @constructor
34
+ */
35
+ const Handle = props => {
36
+ const nodeId = (0, _react.useNodeId)();
37
+ const {
38
+ quickAdd,
39
+ onNodeTypeDrop
40
+ } = (0, _base.usePropsSelector)(props => ({
41
+ quickAdd: !!props.quickAdd,
42
+ onNodeTypeDrop: props.onNodeTypeDrop
43
+ }));
44
+ const {
45
+ position,
46
+ style,
47
+ id,
48
+ type,
49
+ readOnly: isReadonly = !onNodeTypeDrop,
50
+ required = true,
51
+ errorMessage = '端口未连接'
52
+ } = props;
53
+ const connections = (0, _react.useNodeConnections)({
54
+ handleType: type,
55
+ id: nodeId || undefined,
56
+ handleId: id || undefined
57
+ });
58
+ const {
59
+ getNode,
60
+ connect
61
+ } = (0, _useWorkFlow.useWorkFlow)();
62
+ const {
63
+ getState
64
+ } = (0, _react.useStoreApi)();
65
+ const [open, setOpen] = (0, _react2.useState)(false);
66
+ const nodeTypeMap = (0, _base.useNodeTypeMap)();
67
+ /**
68
+ * 创建节点实例
69
+ */
70
+ const onNodeCreate = (0, _ahooks.useMemoizedFn)(async type => {
71
+ setOpen(false);
72
+ if (!onNodeTypeDrop) {
73
+ return;
74
+ }
75
+ const {
76
+ nodeLookup
77
+ } = getState();
78
+ const node = getNode(nodeId);
79
+ const parentFlow = (0, _.getParentFlow)(nodeLookup, nodeTypeMap, node?.parentId);
80
+ const positionInFlow = {
81
+ x: position === _react.Position.Left ? (node?.position?.x || 0) - ((0, _base.getNodeWidth)(node) + 50) : (node?.position?.x || 0) + ((0, _base.getNodeWidth)(node) + 50),
82
+ y: node?.position?.y || 0
83
+ };
84
+ try {
85
+ const node = await onNodeTypeDrop(parentFlow, positionInFlow, type);
86
+ if (node) {
87
+ const {
88
+ id: copyNodeId,
89
+ connectSourceHandle: sourceHandle,
90
+ connectTargetHandle: targetHandle
91
+ } = node;
92
+ const autoLinkEdge = position === _react.Position.Left ? {
93
+ source: copyNodeId,
94
+ target: nodeId,
95
+ sourceHandle: sourceHandle,
96
+ targetHandle: targetHandle // inputHandle 通过 create 返回,默认输出 sourceHandle 通过接口返回
97
+ } : {
98
+ source: nodeId,
99
+ target: copyNodeId,
100
+ sourceHandle: id,
101
+ targetHandle: targetHandle
102
+ };
103
+ connect(autoLinkEdge); // 自动连接
104
+ }
105
+ } catch (e) {
106
+ // reject 忽略
107
+ }
108
+ });
109
+ const connected = connections.length > 0;
110
+ const isError = !isReadonly && required && !connected; // 只读模式下不执行端口检测
111
+
112
+ const handle = /*#__PURE__*/(0, _jsxRuntime.jsxs)(_react.Handle, {
113
+ ...props,
114
+ className: (0, _classcat.default)(['rxflow-handle', props.className, {
115
+ 'rxflow-handle-error': isError,
116
+ 'rxflow-handle-linked': connected
117
+ }]),
118
+ style: {
119
+ [position === _react.Position.Left ? 'left' : 'right']: 0,
120
+ ...style
121
+ },
122
+ onClick: _events.stopPropagation,
123
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
124
+ className: 'rxflow-handle-circle'
125
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
126
+ className: 'rxflow-handle-bg',
127
+ children: isError ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_ExclamationOutlined.default, {
128
+ className: 'rxflow-handle-icon'
129
+ }) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_PlusOutlined.default, {
130
+ className: 'rxflow-handle-icon'
131
+ })
132
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_base.Tooltip, {
133
+ color: 'red',
134
+ title: isError ? errorMessage : null,
135
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
136
+ className: 'rxflow-handle-anchor'
137
+ })
138
+ })]
139
+ });
140
+ if (!quickAdd || isReadonly) {
141
+ return handle;
142
+ }
143
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_base.Popover, {
144
+ arrow: false,
145
+ destroyOnHidden: true,
146
+ placement: position === _react.Position.Left ? 'leftTop' : 'rightTop',
147
+ content: /*#__PURE__*/(0, _jsxRuntime.jsx)(_NodePopover.NodePopover, {
148
+ nodeId: nodeId,
149
+ onNodeCreate: onNodeCreate
150
+ }),
151
+ trigger: 'click',
152
+ open: open,
153
+ onOpenChange: setOpen,
154
+ styles: {
155
+ root: {
156
+ paddingLeft: 0
157
+ }
158
+ },
159
+ classNames: {
160
+ root: 'rxflow-handle-dropdown'
161
+ },
162
+ children: handle
163
+ });
164
+ };
165
+ exports.Handle = Handle;
@@ -0,0 +1,111 @@
1
+ .rxflow-handle {
2
+ &.react-flow__handle {
3
+ z-index: 1;
4
+ display: inline-flex;
5
+ align-items: center;
6
+ justify-content: center;
7
+ width: 18px;
8
+ height: 18px;
9
+ border-radius: 50%;
10
+ border: none;
11
+ background-color: transparent;
12
+ }
13
+
14
+ &-circle {
15
+ background-color: #fff;
16
+ position: absolute;
17
+ transform: scale(.5);
18
+ width: 18px;
19
+ height: 18px;
20
+ align-items: center;
21
+ border-radius: 50%;
22
+ display: flex;
23
+ justify-content: center;
24
+ transition: all .2s linear 0s;
25
+ }
26
+
27
+ &-bg{
28
+ align-items: center;
29
+ border-radius: 50%;
30
+ display: flex;
31
+ justify-content: center;
32
+ transition: all .2s linear 0s;
33
+ background: #9197f1;
34
+ height: 100%;
35
+ position: relative;
36
+ transform: scale(.4);
37
+ width: 100%;
38
+ }
39
+
40
+ &-linked &-bg {
41
+ background: #4d53e8;
42
+ }
43
+
44
+ &-anchor {
45
+ position: absolute;
46
+ width: 100%;
47
+ height: 100%;
48
+ left: 0;
49
+ top: 0;
50
+ }
51
+
52
+ &-dropdown {
53
+ .rxflow-popover-inner-content {
54
+ padding: 0;
55
+ }
56
+
57
+ &-content {
58
+ width: 360px;
59
+ padding: 12px 16px;
60
+ }
61
+ }
62
+
63
+
64
+ &.react-flow__handle {
65
+ background-color: transparent;
66
+ border: none;
67
+ }
68
+
69
+ .rxflow-handle-icon {
70
+ z-index: 2;
71
+ color: #fff;
72
+ font-size: 6px;
73
+ transition: all .2s linear 0s;
74
+ pointer-events: none;
75
+ opacity: 0;
76
+ }
77
+
78
+
79
+ &.rxflow-handle-error > &-bg {
80
+ background: red!important;
81
+ }
82
+
83
+ .react-flow__node:hover &-circle {
84
+ transform: scale(1);
85
+ }
86
+
87
+ .react-flow__node:hover &-bg {
88
+ background: #4d53e8;
89
+ transform: scale(.7);
90
+ }
91
+
92
+ .react-flow__node:hover &:hover > &-circle {
93
+ transform: scale(0.5); // 还原
94
+ }
95
+
96
+ .react-flow__node:hover &:hover > &-bg {
97
+ background: #4d53e8;
98
+ border: none;
99
+ cursor: crosshair;
100
+ transform: scale(1);
101
+
102
+ .rxflow-handle-icon {
103
+ opacity: 1;
104
+ font-size: 12px;
105
+ }
106
+ }
107
+
108
+ &-dropdown {
109
+ width: 360px;
110
+ }
111
+ }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * @author: yanxianliang
3
+ * @date: 2025-07-21 10:10
4
+ * @modified:2025/7/21 10:10 by yanxianliang
5
+ * @desc: 代码编辑器(行内模式)
6
+ *
7
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
8
+ */
9
+ import { InlineCodeEditorProps } from "./types";
10
+ export declare const InlineCodeEditor: ({ height, value, onChange, readOnly }: InlineCodeEditorProps) => import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,OAAO,EAAC,qBAAqB,EAAC,MAAM,SAAS,CAAC;AAG9C,eAAO,MAAM,gBAAgB,0CAMxB,qBAAqB,4CAIzB,CAAA"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.InlineCodeEditor = void 0;
7
+ var _Python = require("../CodeEditor/editors/Python");
8
+ var _jsxRuntime = require("react/jsx-runtime");
9
+ /**
10
+ * @author: yanxianliang
11
+ * @date: 2025-07-21 10:10
12
+ * @modified:2025/7/21 10:10 by yanxianliang
13
+ * @desc: 代码编辑器(行内模式)
14
+ *
15
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
16
+ */
17
+
18
+ const InlineCodeEditor = ({
19
+ height = 400,
20
+ value,
21
+ onChange,
22
+ readOnly
23
+ }) => {
24
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_Python.PythonEditor, {
25
+ value: value,
26
+ height: height,
27
+ readOnly: readOnly,
28
+ onChange: onChange
29
+ });
30
+ };
31
+ exports.InlineCodeEditor = InlineCodeEditor;
@@ -0,0 +1,22 @@
1
+ /**
2
+ * @author: yanxianliang
3
+ * @date: 2025-07-21 10:26
4
+ * @modified:2025/7/21 10:26 by yanxianliang
5
+ * @desc: 类型定义
6
+ *
7
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
8
+ */
9
+
10
+ export type InlineCodeEditorProps = {
11
+ /**
12
+ * @description: 编辑区域高度
13
+ * @default: 400
14
+ */
15
+ height?: number;
16
+
17
+ value?: string;
18
+
19
+ readOnly?: boolean;
20
+
21
+ onChange?: (code?: string) => void;
22
+ }
@@ -0,0 +1,14 @@
1
+ /**
2
+ * @author: yanxianliang
3
+ * @date: 2025-07-27 12:11
4
+ * @modified:2025/7/27 12:11 by yanxianliang
5
+ * @desc: 布局组件
6
+ *
7
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
8
+ */
9
+ import { type IBaseFlowProps } from "@rxflow/base";
10
+ import { WorkflowExtendProps, WorkflowNode } from "../..";
11
+ import './index.less';
12
+ import { Edge } from "@xyflow/react";
13
+ export declare const WorkFlowLayout: <NodeType extends WorkflowNode = WorkflowNode, EdgeType extends Edge = Edge>(props: IBaseFlowProps<NodeType, EdgeType> & WorkflowExtendProps<NodeType>) => import("react/jsx-runtime").JSX.Element;
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,OAAO,EAAO,KAAK,cAAc,EAAC,MAAM,cAAc,CAAC;AACvD,OAAO,EAAC,mBAAmB,EAAE,YAAY,EAAC,cAAyB;AACnE,OAAO,cAAc,CAAC;AACtB,OAAO,EAAC,IAAI,EAAC,MAAM,eAAe,CAAC;AAInC,eAAO,MAAM,cAAc,sFAGlB,eAAe,QAAQ,EAAE,QAAQ,CAAC,GAAG,oBAAoB,QAAQ,CAAC,4CAkB1E,CAAA"}
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WorkFlowLayout = void 0;
7
+ var _base = require("@rxflow/base");
8
+ require("./index.less");
9
+ var _CanvasLoading = _interopRequireDefault(require("../CanvasLoading"));
10
+ var _Sider = require("../Sider");
11
+ var _jsxRuntime = require("react/jsx-runtime");
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+ /**
14
+ * @author: yanxianliang
15
+ * @date: 2025-07-27 12:11
16
+ * @modified:2025/7/27 12:11 by yanxianliang
17
+ * @desc: 布局组件
18
+ *
19
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
20
+ */
21
+
22
+ const WorkFlowLayout = props => {
23
+ const {
24
+ readOnly,
25
+ sider,
26
+ loading,
27
+ children
28
+ } = props;
29
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
30
+ className: 'rxflow-workflow',
31
+ style: {
32
+ height: props.height
33
+ },
34
+ children: [readOnly ? null : /*#__PURE__*/(0, _jsxRuntime.jsx)(_Sider.Sider, {
35
+ ...sider,
36
+ nodeTypes: props.nodeTypes
37
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
38
+ className: 'rxflow-graph',
39
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_CanvasLoading.default, {
40
+ loading: loading,
41
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_base.Flow, {
42
+ ...props,
43
+ children: children
44
+ })
45
+ })
46
+ })]
47
+ });
48
+ };
49
+ exports.WorkFlowLayout = WorkFlowLayout;
@@ -0,0 +1,14 @@
1
+ .rxflow {
2
+ &-workflow{
3
+ display: flex;
4
+ flex: 1;
5
+ flex-direction: row;
6
+ height: 100%;
7
+ }
8
+
9
+ &-graph {
10
+ flex: 1;
11
+ width: 0;
12
+ position: relative;
13
+ }
14
+ }
@@ -0,0 +1,16 @@
1
+ import { ButtonProps } from 'antd';
2
+ /**
3
+ * LoadingButton 组件
4
+ * - 支持 loading 状态受控/非受控
5
+ * - 支持点击防抖(防止重复点击)
6
+ * - 支持异步 onClick
7
+ *
8
+ * @param props
9
+ * onClick: 点击事件,支持返回 Promise
10
+ * throttle: 防抖间隔,默认 300ms
11
+ */
12
+ export declare const LoadingButton: (props: Omit<ButtonProps, "onClick"> & {
13
+ onClick?: ((e: React.MouseEvent<HTMLButtonElement>) => Promise<void> | void) | undefined;
14
+ throttle?: number | undefined;
15
+ }) => import("react/jsx-runtime").JSX.Element;
16
+ //# sourceMappingURL=LoadingButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LoadingButton.d.ts","sourceRoot":"","sources":["LoadingButton.tsx"],"names":[],"mappings":"AAWA,OAAO,EAAU,WAAW,EAAE,MAAM,MAAM,CAAC;AAG3C;;;;;;;;;GASG;AACH,eAAO,MAAM,aAAa;mBAER,gBAAgB,CAAC,iBAAiB,CAAC,KAAK,QAAQ,IAAI,CAAC,GAAG,IAAI;;6CAuD7E,CAAC"}
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.LoadingButton = void 0;
7
+ var _ahooks = require("ahooks");
8
+ var _antd = require("antd");
9
+ var _react = require("react");
10
+ var _jsxRuntime = require("react/jsx-runtime");
11
+ /*
12
+ * @author: yanxianliang
13
+ * @date: 2025-05-23 15:19
14
+ * @desc: Loading Button
15
+ *
16
+ * 支持业务防抖
17
+ *
18
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
19
+ */
20
+
21
+ /**
22
+ * LoadingButton 组件
23
+ * - 支持 loading 状态受控/非受控
24
+ * - 支持点击防抖(防止重复点击)
25
+ * - 支持异步 onClick
26
+ *
27
+ * @param props
28
+ * onClick: 点击事件,支持返回 Promise
29
+ * throttle: 防抖间隔,默认 300ms
30
+ */
31
+ const LoadingButton = props => {
32
+ const lockRef = (0, _react.useRef)(false); // 点击锁,loading 无法解决鼠标连击问题
33
+ const throttle = props.throttle ?? 300;
34
+
35
+ /**
36
+ * loading 状态受控/非受控
37
+ */
38
+ const [loading, setLoading] = (0, _ahooks.useControllableValue)(props, {
39
+ valuePropName: 'loading',
40
+ trigger: 'onLoadingChange'
41
+ });
42
+
43
+ /**
44
+ * 包装点击事件,支持防抖和 loading
45
+ */
46
+ const onButtonClick = (0, _ahooks.useMemoizedFn)(e => {
47
+ if (lockRef.current) {
48
+ return; // 防抖拦截
49
+ }
50
+ lockRef.current = true;
51
+ const result = props.onClick?.(e);
52
+ if (result && result instanceof Promise) {
53
+ (async () => {
54
+ setLoading(true);
55
+ try {
56
+ await result;
57
+ // eslint-disable-next-line @typescript-eslint/no-shadow
58
+ } catch (e) {
59
+ /* empty */
60
+ } finally {
61
+ setLoading(false);
62
+ setTimeout(() => {
63
+ lockRef.current = false;
64
+ }, throttle);
65
+ }
66
+ })();
67
+ } else {
68
+ setTimeout(() => {
69
+ /**
70
+ * 纯前端交互的,进行前端防抖
71
+ */
72
+ lockRef.current = false;
73
+ }, throttle);
74
+ }
75
+ });
76
+
77
+ /**
78
+ * 渲染按钮
79
+ */
80
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_antd.Button, {
81
+ ...props,
82
+ loading: loading,
83
+ onClick: onButtonClick
84
+ });
85
+ };
86
+ exports.LoadingButton = LoadingButton;
@@ -0,0 +1,15 @@
1
+ /**
2
+ * @author: yanxianliang
3
+ * @date: 2025-07-27 11:34
4
+ * @modified:2025/7/27 11:34 by yanxianliang
5
+ * @desc: 节点列表
6
+ *
7
+ * Copyright (c) 2025 by yanxianliang, All Rights Reserved.
8
+ */
9
+ import './index.less';
10
+ import { WorkflowNode, WorkFlowNodeDefinition } from "../..";
11
+ export declare const Sider: <NodeType extends WorkflowNode = WorkflowNode>({ loading, nodeTypes, }: {
12
+ loading?: boolean | undefined;
13
+ nodeTypes?: WorkFlowNodeDefinition<NodeType["data"]>[] | undefined;
14
+ }) => import("react/jsx-runtime").JSX.Element;
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,OAAO,cAAc,CAAC;AAGtB,OAAO,EAAC,YAAY,EAAE,sBAAsB,EAAC,cAAyB;AAQtE,eAAO,MAAM,KAAK;;;6CAqGjB,CAAA"}