@logicflow/core 1.2.27 → 2.0.0-beta.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 (804) hide show
  1. package/.turbo/turbo-build$colon$dev.log +10 -0
  2. package/.turbo/turbo-build.log +42 -0
  3. package/CHANGELOG.md +2114 -0
  4. package/LICENSE +206 -0
  5. package/__tests__/algorithm/egde.test.ts +118 -0
  6. package/__tests__/algorithm/index.test.ts +69 -0
  7. package/__tests__/algorithm/outline.test.ts +43 -0
  8. package/__tests__/bugs/1545-spec.test.ts +38 -0
  9. package/__tests__/event/event.test.ts +22 -0
  10. package/__tests__/history/history.test.ts +28 -0
  11. package/__tests__/logicflow.test.ts +567 -0
  12. package/__tests__/model/graphmodel.test.ts +67 -0
  13. package/__tests__/util/compatible.test.ts +48 -0
  14. package/__tests__/util/edge.test.ts +224 -0
  15. package/__tests__/util/geometry.test.ts +14 -0
  16. package/__tests__/util/graph.test.ts +16 -0
  17. package/__tests__/util/matrix.test.ts +41 -0
  18. package/__tests__/util/node.test.ts +68 -0
  19. package/__tests__/util/sampling.test.ts +16 -0
  20. package/__tests__/util/vector.test.ts +50 -0
  21. package/__tests__/util/zIndex.test.ts +10 -0
  22. package/dist/{style/index.css → index.css} +64 -52
  23. package/dist/index.js +26 -0
  24. package/dist/index.js.map +1 -0
  25. package/es/LogicFlow.d.ts +966 -0
  26. package/es/LogicFlow.js +1174 -0
  27. package/es/LogicFlow.js.map +1 -0
  28. package/es/algorithm/edge.d.ts +15 -0
  29. package/es/algorithm/edge.js +57 -0
  30. package/es/algorithm/edge.js.map +1 -0
  31. package/es/algorithm/index.js +71 -0
  32. package/es/algorithm/index.js.map +1 -0
  33. package/es/algorithm/outline.d.ts +7 -0
  34. package/es/algorithm/outline.js +61 -0
  35. package/es/algorithm/outline.js.map +1 -0
  36. package/{types/constant/constant.d.ts → es/constant/index.d.ts} +23 -22
  37. package/es/constant/index.js +117 -0
  38. package/es/constant/index.js.map +1 -0
  39. package/es/event/eventArgs.d.ts +428 -0
  40. package/es/event/eventArgs.js +2 -0
  41. package/es/event/eventArgs.js.map +1 -0
  42. package/es/event/eventEmitter.d.ts +48 -0
  43. package/es/event/eventEmitter.js +92 -0
  44. package/es/event/eventEmitter.js.map +1 -0
  45. package/es/history/index.d.ts +23 -0
  46. package/es/history/index.js +111 -0
  47. package/es/history/index.js.map +1 -0
  48. package/es/index.css +210 -0
  49. package/{types → es}/index.d.ts +4 -6
  50. package/es/index.js +16 -0
  51. package/es/index.js.map +1 -0
  52. package/es/index.less +1 -0
  53. package/{types → es}/keyboard/index.d.ts +7 -8
  54. package/es/keyboard/index.js +87 -0
  55. package/es/keyboard/index.js.map +1 -0
  56. package/es/keyboard/shortcut.js +116 -0
  57. package/es/keyboard/shortcut.js.map +1 -0
  58. package/es/model/BaseModel.d.ts +181 -0
  59. package/es/model/BaseModel.js +2 -0
  60. package/es/model/BaseModel.js.map +1 -0
  61. package/{types → es}/model/EditConfigModel.d.ts +13 -8
  62. package/es/model/EditConfigModel.js +192 -0
  63. package/es/model/EditConfigModel.js.map +1 -0
  64. package/{types → es}/model/GraphModel.d.ts +118 -178
  65. package/es/model/GraphModel.js +1473 -0
  66. package/es/model/GraphModel.js.map +1 -0
  67. package/es/model/SnaplineModel.d.ts +34 -0
  68. package/es/model/SnaplineModel.js +217 -0
  69. package/es/model/SnaplineModel.js.map +1 -0
  70. package/{types → es}/model/TransformModel.d.ts +21 -11
  71. package/es/model/TransformModel.js +240 -0
  72. package/es/model/TransformModel.js.map +1 -0
  73. package/{types → es}/model/edge/BaseEdgeModel.d.ts +82 -63
  74. package/es/model/edge/BaseEdgeModel.js +739 -0
  75. package/es/model/edge/BaseEdgeModel.js.map +1 -0
  76. package/es/model/edge/BezierEdgeModel.d.ts +63 -0
  77. package/es/model/edge/BezierEdgeModel.js +244 -0
  78. package/es/model/edge/BezierEdgeModel.js.map +1 -0
  79. package/es/model/edge/LineEdgeModel.d.ts +19 -0
  80. package/es/model/edge/LineEdgeModel.js +77 -0
  81. package/es/model/edge/LineEdgeModel.js.map +1 -0
  82. package/es/model/edge/PolylineEdgeModel.d.ts +85 -0
  83. package/es/model/edge/PolylineEdgeModel.js +593 -0
  84. package/es/model/edge/PolylineEdgeModel.js.map +1 -0
  85. package/es/model/edge/index.js +5 -0
  86. package/es/model/edge/index.js.map +1 -0
  87. package/es/model/index.js +8 -0
  88. package/es/model/index.js.map +1 -0
  89. package/es/model/node/BaseNodeModel.d.ts +260 -0
  90. package/es/model/node/BaseNodeModel.js +883 -0
  91. package/es/model/node/BaseNodeModel.js.map +1 -0
  92. package/es/model/node/CircleNodeModel.d.ts +40 -0
  93. package/es/model/node/CircleNodeModel.js +110 -0
  94. package/es/model/node/CircleNodeModel.js.map +1 -0
  95. package/es/model/node/DiamondNodeModel.d.ts +46 -0
  96. package/es/model/node/DiamondNodeModel.js +187 -0
  97. package/es/model/node/DiamondNodeModel.js.map +1 -0
  98. package/es/model/node/EllipseNodeModel.d.ts +42 -0
  99. package/es/model/node/EllipseNodeModel.js +118 -0
  100. package/es/model/node/EllipseNodeModel.js.map +1 -0
  101. package/es/model/node/HtmlNodeModel.d.ts +21 -0
  102. package/es/model/node/HtmlNodeModel.js +59 -0
  103. package/es/model/node/HtmlNodeModel.js.map +1 -0
  104. package/es/model/node/PolygonNodeModel.d.ts +50 -0
  105. package/es/model/node/PolygonNodeModel.js +196 -0
  106. package/es/model/node/PolygonNodeModel.js.map +1 -0
  107. package/es/model/node/RectNodeModel.d.ts +34 -0
  108. package/es/model/node/RectNodeModel.js +80 -0
  109. package/es/model/node/RectNodeModel.js.map +1 -0
  110. package/es/model/node/TextNodeModel.d.ts +27 -0
  111. package/es/model/node/TextNodeModel.js +113 -0
  112. package/es/model/node/TextNodeModel.js.map +1 -0
  113. package/es/model/node/index.js +9 -0
  114. package/es/model/node/index.js.map +1 -0
  115. package/es/options.d.ts +86 -0
  116. package/es/options.js +74 -0
  117. package/es/options.js.map +1 -0
  118. package/es/style/index.css +210 -0
  119. package/es/style/index.less +256 -0
  120. package/es/style/raw.d.ts +4 -0
  121. package/es/style/raw.js +6 -0
  122. package/es/style/raw.js.map +1 -0
  123. package/es/tool/MultipleSelectTool.d.ts +13 -0
  124. package/es/tool/MultipleSelectTool.js +159 -0
  125. package/es/tool/MultipleSelectTool.js.map +1 -0
  126. package/es/tool/TextEditTool.d.ts +26 -0
  127. package/es/tool/TextEditTool.js +187 -0
  128. package/es/tool/TextEditTool.js.map +1 -0
  129. package/es/tool/index.d.ts +2 -0
  130. package/es/tool/index.js +3 -0
  131. package/es/tool/index.js.map +1 -0
  132. package/{types/tool/SnaplineTool.d.ts → es/tool/snapline.d.ts} +1 -1
  133. package/es/tool/snapline.js +13 -0
  134. package/es/tool/snapline.js.map +1 -0
  135. package/es/tool/tool.d.ts +22 -0
  136. package/es/tool/tool.js +43 -0
  137. package/es/tool/tool.js.map +1 -0
  138. package/es/util/animation.d.ts +12 -0
  139. package/es/util/animation.js +20 -0
  140. package/es/util/animation.js.map +1 -0
  141. package/es/util/browser.js +3 -0
  142. package/es/util/browser.js.map +1 -0
  143. package/es/util/compatible.d.ts +6 -0
  144. package/es/util/compatible.js +17 -0
  145. package/es/util/compatible.js.map +1 -0
  146. package/es/util/drag.d.ts +47 -0
  147. package/es/util/drag.js +139 -0
  148. package/es/util/drag.js.map +1 -0
  149. package/es/util/edge.d.ts +94 -0
  150. package/es/util/edge.js +833 -0
  151. package/es/util/edge.js.map +1 -0
  152. package/es/util/geometry.d.ts +11 -0
  153. package/es/util/geometry.js +72 -0
  154. package/es/util/geometry.js.map +1 -0
  155. package/{types → es}/util/graph.d.ts +4 -3
  156. package/es/util/graph.js +54 -0
  157. package/es/util/graph.js.map +1 -0
  158. package/es/util/index.d.ts +16 -0
  159. package/es/util/index.js +17 -0
  160. package/es/util/index.js.map +1 -0
  161. package/{types → es}/util/matrix.d.ts +1 -1
  162. package/es/util/matrix.js +161 -0
  163. package/es/util/matrix.js.map +1 -0
  164. package/es/util/mobx.js +4 -0
  165. package/es/util/mobx.js.map +1 -0
  166. package/es/util/node.d.ts +69 -0
  167. package/es/util/node.js +402 -0
  168. package/es/util/node.js.map +1 -0
  169. package/es/util/raf.d.ts +2 -0
  170. package/es/util/raf.js +24 -0
  171. package/es/util/raf.js.map +1 -0
  172. package/{types → es}/util/sampling.d.ts +4 -2
  173. package/es/util/sampling.js +66 -0
  174. package/es/util/sampling.js.map +1 -0
  175. package/es/util/theme.d.ts +4 -0
  176. package/es/util/theme.js +156 -0
  177. package/es/util/theme.js.map +1 -0
  178. package/es/util/uuid.d.ts +7 -0
  179. package/es/util/uuid.js +20 -0
  180. package/es/util/uuid.js.map +1 -0
  181. package/{types → es}/util/vector.d.ts +2 -2
  182. package/es/util/vector.js +97 -0
  183. package/es/util/vector.js.map +1 -0
  184. package/es/util/zIndex.js +5 -0
  185. package/es/util/zIndex.js.map +1 -0
  186. package/es/view/Anchor.d.ts +47 -0
  187. package/es/view/Anchor.js +315 -0
  188. package/es/view/Anchor.js.map +1 -0
  189. package/es/view/Control.d.ts +100 -0
  190. package/es/view/Control.js +324 -0
  191. package/es/view/Control.js.map +1 -0
  192. package/es/view/Graph.d.ts +18 -0
  193. package/es/view/Graph.js +77 -0
  194. package/es/view/Graph.js.map +1 -0
  195. package/{types → es}/view/Rotate.d.ts +9 -9
  196. package/es/view/Rotate.js +108 -0
  197. package/es/view/Rotate.js.map +1 -0
  198. package/es/view/behavior/dnd.d.ts +27 -0
  199. package/es/view/behavior/dnd.js +110 -0
  200. package/es/view/behavior/dnd.js.map +1 -0
  201. package/es/view/edge/AdjustPoint.d.ts +50 -0
  202. package/es/view/edge/AdjustPoint.js +368 -0
  203. package/es/view/edge/AdjustPoint.js.map +1 -0
  204. package/es/view/edge/Arrow.d.ts +25 -0
  205. package/es/view/edge/Arrow.js +60 -0
  206. package/es/view/edge/Arrow.js.map +1 -0
  207. package/{types → es}/view/edge/BaseEdge.d.ts +25 -17
  208. package/es/view/edge/BaseEdge.js +381 -0
  209. package/es/view/edge/BaseEdge.js.map +1 -0
  210. package/es/view/edge/BezierEdge.d.ts +26 -0
  211. package/es/view/edge/BezierEdge.js +118 -0
  212. package/es/view/edge/BezierEdge.js.map +1 -0
  213. package/{types → es}/view/edge/LineEdge.d.ts +9 -4
  214. package/es/view/edge/LineEdge.js +78 -0
  215. package/es/view/edge/LineEdge.js.map +1 -0
  216. package/{types → es}/view/edge/PolylineEdge.d.ts +18 -8
  217. package/es/view/edge/PolylineEdge.js +274 -0
  218. package/es/view/edge/PolylineEdge.js.map +1 -0
  219. package/es/view/edge/index.d.ts +6 -0
  220. package/es/view/edge/index.js +7 -0
  221. package/es/view/edge/index.js.map +1 -0
  222. package/es/view/index.d.ts +7 -0
  223. package/es/view/index.js +8 -0
  224. package/es/view/index.js.map +1 -0
  225. package/es/view/node/BaseNode.d.ts +49 -0
  226. package/es/view/node/BaseNode.js +420 -0
  227. package/es/view/node/BaseNode.js.map +1 -0
  228. package/es/view/node/CircleNode.d.ts +10 -0
  229. package/es/view/node/CircleNode.js +45 -0
  230. package/es/view/node/CircleNode.js.map +1 -0
  231. package/es/view/node/DiamondNode.d.ts +10 -0
  232. package/es/view/node/DiamondNode.js +44 -0
  233. package/es/view/node/DiamondNode.js.map +1 -0
  234. package/es/view/node/EllipseNode.d.ts +10 -0
  235. package/es/view/node/EllipseNode.js +44 -0
  236. package/es/view/node/EllipseNode.js.map +1 -0
  237. package/{types → es}/view/node/HtmlNode.d.ts +15 -9
  238. package/es/view/node/HtmlNode.js +129 -0
  239. package/es/view/node/HtmlNode.js.map +1 -0
  240. package/es/view/node/PolygonNode.d.ts +10 -0
  241. package/es/view/node/PolygonNode.js +48 -0
  242. package/es/view/node/PolygonNode.js.map +1 -0
  243. package/es/view/node/RectNode.d.ts +11 -0
  244. package/es/view/node/RectNode.js +44 -0
  245. package/es/view/node/RectNode.js.map +1 -0
  246. package/es/view/node/TextNode.d.ts +12 -0
  247. package/es/view/node/TextNode.js +55 -0
  248. package/es/view/node/TextNode.js.map +1 -0
  249. package/es/view/node/index.d.ts +8 -0
  250. package/es/view/node/index.js +9 -0
  251. package/es/view/node/index.js.map +1 -0
  252. package/{types → es}/view/overlay/BackgroundOverlay.d.ts +7 -7
  253. package/es/view/overlay/BackgroundOverlay.js +31 -0
  254. package/es/view/overlay/BackgroundOverlay.js.map +1 -0
  255. package/es/view/overlay/BezierAdjustOverlay.d.ts +31 -0
  256. package/es/view/overlay/BezierAdjustOverlay.js +142 -0
  257. package/es/view/overlay/BezierAdjustOverlay.js.map +1 -0
  258. package/{types → es}/view/overlay/CanvasOverlay.d.ts +8 -11
  259. package/es/view/overlay/CanvasOverlay.js +172 -0
  260. package/es/view/overlay/CanvasOverlay.js.map +1 -0
  261. package/es/view/overlay/Grid.d.ts +30 -0
  262. package/es/view/overlay/Grid.js +118 -0
  263. package/es/view/overlay/Grid.js.map +1 -0
  264. package/es/view/overlay/ModificationOverlay.d.ts +9 -0
  265. package/es/view/overlay/ModificationOverlay.js +43 -0
  266. package/es/view/overlay/ModificationOverlay.js.map +1 -0
  267. package/es/view/overlay/OutlineOverlay.d.ts +14 -0
  268. package/es/view/overlay/OutlineOverlay.js +134 -0
  269. package/es/view/overlay/OutlineOverlay.js.map +1 -0
  270. package/es/view/overlay/SnaplineOverlay.d.ts +10 -0
  271. package/es/view/overlay/SnaplineOverlay.js +60 -0
  272. package/es/view/overlay/SnaplineOverlay.js.map +1 -0
  273. package/es/view/overlay/ToolOverlay.d.ts +19 -0
  274. package/es/view/overlay/ToolOverlay.js +76 -0
  275. package/es/view/overlay/ToolOverlay.js.map +1 -0
  276. package/{types → es}/view/overlay/getTransformHoc.d.ts +17 -14
  277. package/es/view/overlay/getTransformHoc.js +57 -0
  278. package/es/view/overlay/getTransformHoc.js.map +1 -0
  279. package/es/view/overlay/index.d.ts +8 -0
  280. package/es/view/overlay/index.js +9 -0
  281. package/es/view/overlay/index.js.map +1 -0
  282. package/es/view/shape/Circle.d.ts +2 -0
  283. package/es/view/shape/Circle.js +57 -0
  284. package/es/view/shape/Circle.js.map +1 -0
  285. package/es/view/shape/Ellipse.d.ts +2 -0
  286. package/es/view/shape/Ellipse.js +58 -0
  287. package/es/view/shape/Ellipse.js.map +1 -0
  288. package/es/view/shape/Line.d.ts +2 -0
  289. package/es/view/shape/Line.js +54 -0
  290. package/es/view/shape/Line.js.map +1 -0
  291. package/es/view/shape/Path.d.ts +6 -0
  292. package/es/view/shape/Path.js +43 -0
  293. package/es/view/shape/Path.js.map +1 -0
  294. package/es/view/shape/Polygon.d.ts +8 -0
  295. package/es/view/shape/Polygon.js +56 -0
  296. package/es/view/shape/Polygon.js.map +1 -0
  297. package/es/view/shape/Polyline.d.ts +2 -0
  298. package/es/view/shape/Polyline.js +49 -0
  299. package/es/view/shape/Polyline.js.map +1 -0
  300. package/es/view/shape/Rect.d.ts +15 -0
  301. package/es/view/shape/Rect.js +60 -0
  302. package/es/view/shape/Rect.js.map +1 -0
  303. package/es/view/shape/Text.d.ts +2 -0
  304. package/es/view/shape/Text.js +110 -0
  305. package/es/view/shape/Text.js.map +1 -0
  306. package/es/view/shape/index.d.ts +8 -0
  307. package/es/view/shape/index.js +9 -0
  308. package/es/view/shape/index.js.map +1 -0
  309. package/es/view/text/BaseText.d.ts +25 -0
  310. package/es/view/text/BaseText.js +114 -0
  311. package/es/view/text/BaseText.js.map +1 -0
  312. package/es/view/text/LineText.d.ts +9 -0
  313. package/es/view/text/LineText.js +149 -0
  314. package/es/view/text/LineText.js.map +1 -0
  315. package/es/view/text/index.d.ts +2 -0
  316. package/es/view/text/index.js +3 -0
  317. package/es/view/text/index.js.map +1 -0
  318. package/lib/LogicFlow.d.ts +966 -0
  319. package/lib/LogicFlow.js +1203 -0
  320. package/lib/LogicFlow.js.map +1 -0
  321. package/lib/algorithm/edge.d.ts +15 -0
  322. package/lib/algorithm/edge.js +62 -0
  323. package/lib/algorithm/edge.js.map +1 -0
  324. package/lib/algorithm/index.d.ts +6 -0
  325. package/lib/algorithm/index.js +75 -0
  326. package/lib/algorithm/index.js.map +1 -0
  327. package/lib/algorithm/outline.d.ts +7 -0
  328. package/lib/algorithm/outline.js +69 -0
  329. package/lib/algorithm/outline.js.map +1 -0
  330. package/lib/constant/index.d.ts +102 -0
  331. package/lib/constant/index.js +120 -0
  332. package/lib/constant/index.js.map +1 -0
  333. package/lib/event/eventArgs.d.ts +428 -0
  334. package/lib/event/eventArgs.js +3 -0
  335. package/lib/event/eventArgs.js.map +1 -0
  336. package/lib/event/eventEmitter.d.ts +48 -0
  337. package/lib/event/eventEmitter.js +95 -0
  338. package/lib/event/eventEmitter.js.map +1 -0
  339. package/lib/history/index.d.ts +23 -0
  340. package/lib/history/index.js +114 -0
  341. package/lib/history/index.js.map +1 -0
  342. package/lib/index.css +210 -0
  343. package/lib/index.d.ts +12 -0
  344. package/lib/index.js +58 -0
  345. package/lib/index.js.map +1 -0
  346. package/lib/index.less +1 -0
  347. package/lib/keyboard/index.d.ts +31 -0
  348. package/lib/keyboard/index.js +93 -0
  349. package/lib/keyboard/index.js.map +1 -0
  350. package/lib/keyboard/shortcut.d.ts +3 -0
  351. package/lib/keyboard/shortcut.js +120 -0
  352. package/lib/keyboard/shortcut.js.map +1 -0
  353. package/lib/model/BaseModel.d.ts +181 -0
  354. package/lib/model/BaseModel.js +3 -0
  355. package/lib/model/BaseModel.js.map +1 -0
  356. package/lib/model/EditConfigModel.d.ts +114 -0
  357. package/lib/model/EditConfigModel.js +195 -0
  358. package/lib/model/EditConfigModel.js.map +1 -0
  359. package/lib/model/GraphModel.d.ts +426 -0
  360. package/lib/model/GraphModel.js +1479 -0
  361. package/lib/model/GraphModel.js.map +1 -0
  362. package/lib/model/SnaplineModel.d.ts +34 -0
  363. package/lib/model/SnaplineModel.js +220 -0
  364. package/lib/model/SnaplineModel.js.map +1 -0
  365. package/lib/model/TransformModel.d.ts +101 -0
  366. package/lib/model/TransformModel.js +243 -0
  367. package/lib/model/TransformModel.js.map +1 -0
  368. package/lib/model/edge/BaseEdgeModel.d.ts +270 -0
  369. package/lib/model/edge/BaseEdgeModel.js +742 -0
  370. package/lib/model/edge/BaseEdgeModel.js.map +1 -0
  371. package/lib/model/edge/BezierEdgeModel.d.ts +63 -0
  372. package/lib/model/edge/BezierEdgeModel.js +250 -0
  373. package/lib/model/edge/BezierEdgeModel.js.map +1 -0
  374. package/lib/model/edge/LineEdgeModel.d.ts +19 -0
  375. package/lib/model/edge/LineEdgeModel.js +83 -0
  376. package/lib/model/edge/LineEdgeModel.js.map +1 -0
  377. package/lib/model/edge/PolylineEdgeModel.d.ts +85 -0
  378. package/lib/model/edge/PolylineEdgeModel.js +596 -0
  379. package/lib/model/edge/PolylineEdgeModel.js.map +1 -0
  380. package/lib/model/edge/index.d.ts +4 -0
  381. package/lib/model/edge/index.js +21 -0
  382. package/lib/model/edge/index.js.map +1 -0
  383. package/lib/model/index.d.ts +7 -0
  384. package/lib/model/index.js +24 -0
  385. package/lib/model/index.js.map +1 -0
  386. package/lib/model/node/BaseNodeModel.d.ts +260 -0
  387. package/lib/model/node/BaseNodeModel.js +886 -0
  388. package/lib/model/node/BaseNodeModel.js.map +1 -0
  389. package/lib/model/node/CircleNodeModel.d.ts +40 -0
  390. package/lib/model/node/CircleNodeModel.js +116 -0
  391. package/lib/model/node/CircleNodeModel.js.map +1 -0
  392. package/lib/model/node/DiamondNodeModel.d.ts +46 -0
  393. package/lib/model/node/DiamondNodeModel.js +193 -0
  394. package/lib/model/node/DiamondNodeModel.js.map +1 -0
  395. package/lib/model/node/EllipseNodeModel.d.ts +42 -0
  396. package/lib/model/node/EllipseNodeModel.js +124 -0
  397. package/lib/model/node/EllipseNodeModel.js.map +1 -0
  398. package/lib/model/node/HtmlNodeModel.d.ts +21 -0
  399. package/lib/model/node/HtmlNodeModel.js +65 -0
  400. package/lib/model/node/HtmlNodeModel.js.map +1 -0
  401. package/lib/model/node/PolygonNodeModel.d.ts +50 -0
  402. package/lib/model/node/PolygonNodeModel.js +202 -0
  403. package/lib/model/node/PolygonNodeModel.js.map +1 -0
  404. package/lib/model/node/RectNodeModel.d.ts +34 -0
  405. package/lib/model/node/RectNodeModel.js +86 -0
  406. package/lib/model/node/RectNodeModel.js.map +1 -0
  407. package/lib/model/node/TextNodeModel.d.ts +27 -0
  408. package/lib/model/node/TextNodeModel.js +119 -0
  409. package/lib/model/node/TextNodeModel.js.map +1 -0
  410. package/lib/model/node/index.d.ts +8 -0
  411. package/lib/model/node/index.js +25 -0
  412. package/lib/model/node/index.js.map +1 -0
  413. package/lib/options.d.ts +86 -0
  414. package/lib/options.js +77 -0
  415. package/lib/options.js.map +1 -0
  416. package/lib/style/index.css +210 -0
  417. package/lib/style/index.less +256 -0
  418. package/lib/style/raw.d.ts +4 -0
  419. package/lib/style/raw.js +9 -0
  420. package/lib/style/raw.js.map +1 -0
  421. package/lib/tool/MultipleSelectTool.d.ts +13 -0
  422. package/lib/tool/MultipleSelectTool.js +161 -0
  423. package/lib/tool/MultipleSelectTool.js.map +1 -0
  424. package/lib/tool/TextEditTool.d.ts +26 -0
  425. package/lib/tool/TextEditTool.js +190 -0
  426. package/lib/tool/TextEditTool.js.map +1 -0
  427. package/lib/tool/index.d.ts +2 -0
  428. package/lib/tool/index.js +19 -0
  429. package/lib/tool/index.js.map +1 -0
  430. package/lib/tool/snapline.d.ts +3 -0
  431. package/lib/tool/snapline.js +17 -0
  432. package/lib/tool/snapline.js.map +1 -0
  433. package/lib/tool/tool.d.ts +22 -0
  434. package/lib/tool/tool.js +49 -0
  435. package/lib/tool/tool.js.map +1 -0
  436. package/lib/util/animation.d.ts +12 -0
  437. package/lib/util/animation.js +24 -0
  438. package/lib/util/animation.js.map +1 -0
  439. package/lib/util/browser.d.ts +1 -0
  440. package/lib/util/browser.js +6 -0
  441. package/lib/util/browser.js.map +1 -0
  442. package/lib/util/compatible.d.ts +6 -0
  443. package/lib/util/compatible.js +21 -0
  444. package/lib/util/compatible.js.map +1 -0
  445. package/lib/util/drag.d.ts +47 -0
  446. package/lib/util/drag.js +142 -0
  447. package/lib/util/drag.js.map +1 -0
  448. package/lib/util/edge.d.ts +94 -0
  449. package/lib/util/edge.js +879 -0
  450. package/lib/util/edge.js.map +1 -0
  451. package/lib/util/geometry.d.ts +11 -0
  452. package/lib/util/geometry.js +78 -0
  453. package/lib/util/geometry.js.map +1 -0
  454. package/lib/util/graph.d.ts +13 -0
  455. package/lib/util/graph.js +59 -0
  456. package/lib/util/graph.js.map +1 -0
  457. package/lib/util/index.d.ts +16 -0
  458. package/lib/util/index.js +33 -0
  459. package/lib/util/index.js.map +1 -0
  460. package/lib/util/matrix.d.ts +32 -0
  461. package/lib/util/matrix.js +164 -0
  462. package/lib/util/matrix.js.map +1 -0
  463. package/lib/util/mobx.d.ts +2 -0
  464. package/lib/util/mobx.js +13 -0
  465. package/lib/util/mobx.js.map +1 -0
  466. package/lib/util/node.d.ts +69 -0
  467. package/lib/util/node.js +424 -0
  468. package/lib/util/node.js.map +1 -0
  469. package/lib/util/raf.d.ts +2 -0
  470. package/lib/util/raf.js +29 -0
  471. package/lib/util/raf.js.map +1 -0
  472. package/lib/util/sampling.d.ts +6 -0
  473. package/lib/util/sampling.js +72 -0
  474. package/lib/util/sampling.js.map +1 -0
  475. package/lib/util/theme.d.ts +4 -0
  476. package/lib/util/theme.js +160 -0
  477. package/lib/util/theme.js.map +1 -0
  478. package/lib/util/uuid.d.ts +7 -0
  479. package/lib/util/uuid.js +25 -0
  480. package/lib/util/uuid.js.map +1 -0
  481. package/lib/util/vector.d.ts +23 -0
  482. package/lib/util/vector.js +101 -0
  483. package/lib/util/vector.js.map +1 -0
  484. package/lib/util/zIndex.d.ts +2 -0
  485. package/lib/util/zIndex.js +10 -0
  486. package/lib/util/zIndex.js.map +1 -0
  487. package/lib/view/Anchor.d.ts +47 -0
  488. package/lib/view/Anchor.js +317 -0
  489. package/lib/view/Anchor.js.map +1 -0
  490. package/lib/view/Control.d.ts +100 -0
  491. package/lib/view/Control.js +327 -0
  492. package/lib/view/Control.js.map +1 -0
  493. package/lib/view/Graph.d.ts +18 -0
  494. package/lib/view/Graph.js +79 -0
  495. package/lib/view/Graph.js.map +1 -0
  496. package/lib/view/Rotate.d.ts +21 -0
  497. package/lib/view/Rotate.js +113 -0
  498. package/lib/view/Rotate.js.map +1 -0
  499. package/lib/view/behavior/dnd.d.ts +27 -0
  500. package/lib/view/behavior/dnd.js +113 -0
  501. package/lib/view/behavior/dnd.js.map +1 -0
  502. package/lib/view/edge/AdjustPoint.d.ts +50 -0
  503. package/lib/view/edge/AdjustPoint.js +371 -0
  504. package/lib/view/edge/AdjustPoint.js.map +1 -0
  505. package/lib/view/edge/Arrow.d.ts +25 -0
  506. package/lib/view/edge/Arrow.js +63 -0
  507. package/lib/view/edge/Arrow.js.map +1 -0
  508. package/lib/view/edge/BaseEdge.d.ts +148 -0
  509. package/lib/view/edge/BaseEdge.js +407 -0
  510. package/lib/view/edge/BaseEdge.js.map +1 -0
  511. package/lib/view/edge/BezierEdge.d.ts +26 -0
  512. package/lib/view/edge/BezierEdge.js +124 -0
  513. package/lib/view/edge/BezierEdge.js.map +1 -0
  514. package/{types/view/edge/BezierEdge.d.ts → lib/view/edge/LineEdge.d.ts} +9 -10
  515. package/lib/view/edge/LineEdge.js +84 -0
  516. package/lib/view/edge/LineEdge.js.map +1 -0
  517. package/lib/view/edge/PolylineEdge.d.ts +55 -0
  518. package/lib/view/edge/PolylineEdge.js +280 -0
  519. package/lib/view/edge/PolylineEdge.js.map +1 -0
  520. package/lib/view/edge/index.d.ts +6 -0
  521. package/lib/view/edge/index.js +23 -0
  522. package/lib/view/edge/index.js.map +1 -0
  523. package/lib/view/index.d.ts +7 -0
  524. package/lib/view/index.js +24 -0
  525. package/lib/view/index.js.map +1 -0
  526. package/lib/view/node/BaseNode.d.ts +49 -0
  527. package/lib/view/node/BaseNode.js +424 -0
  528. package/lib/view/node/BaseNode.js.map +1 -0
  529. package/lib/view/node/CircleNode.d.ts +10 -0
  530. package/lib/view/node/CircleNode.js +51 -0
  531. package/lib/view/node/CircleNode.js.map +1 -0
  532. package/lib/view/node/DiamondNode.d.ts +10 -0
  533. package/lib/view/node/DiamondNode.js +50 -0
  534. package/lib/view/node/DiamondNode.js.map +1 -0
  535. package/lib/view/node/EllipseNode.d.ts +10 -0
  536. package/lib/view/node/EllipseNode.js +50 -0
  537. package/lib/view/node/EllipseNode.js.map +1 -0
  538. package/lib/view/node/HtmlNode.d.ts +38 -0
  539. package/lib/view/node/HtmlNode.js +135 -0
  540. package/lib/view/node/HtmlNode.js.map +1 -0
  541. package/lib/view/node/PolygonNode.d.ts +10 -0
  542. package/lib/view/node/PolygonNode.js +54 -0
  543. package/lib/view/node/PolygonNode.js.map +1 -0
  544. package/lib/view/node/RectNode.d.ts +11 -0
  545. package/lib/view/node/RectNode.js +50 -0
  546. package/lib/view/node/RectNode.js.map +1 -0
  547. package/lib/view/node/TextNode.d.ts +12 -0
  548. package/lib/view/node/TextNode.js +61 -0
  549. package/lib/view/node/TextNode.js.map +1 -0
  550. package/lib/view/node/index.d.ts +8 -0
  551. package/lib/view/node/index.js +25 -0
  552. package/lib/view/node/index.js.map +1 -0
  553. package/lib/view/overlay/BackgroundOverlay.d.ts +28 -0
  554. package/lib/view/overlay/BackgroundOverlay.js +34 -0
  555. package/lib/view/overlay/BackgroundOverlay.js.map +1 -0
  556. package/lib/view/overlay/BezierAdjustOverlay.d.ts +31 -0
  557. package/lib/view/overlay/BezierAdjustOverlay.js +145 -0
  558. package/lib/view/overlay/BezierAdjustOverlay.js.map +1 -0
  559. package/lib/view/overlay/CanvasOverlay.d.ts +25 -0
  560. package/lib/view/overlay/CanvasOverlay.js +175 -0
  561. package/lib/view/overlay/CanvasOverlay.js.map +1 -0
  562. package/lib/view/overlay/Grid.d.ts +30 -0
  563. package/lib/view/overlay/Grid.js +121 -0
  564. package/lib/view/overlay/Grid.js.map +1 -0
  565. package/lib/view/overlay/ModificationOverlay.d.ts +9 -0
  566. package/lib/view/overlay/ModificationOverlay.js +46 -0
  567. package/lib/view/overlay/ModificationOverlay.js.map +1 -0
  568. package/lib/view/overlay/OutlineOverlay.d.ts +14 -0
  569. package/lib/view/overlay/OutlineOverlay.js +137 -0
  570. package/lib/view/overlay/OutlineOverlay.js.map +1 -0
  571. package/lib/view/overlay/SnaplineOverlay.d.ts +10 -0
  572. package/lib/view/overlay/SnaplineOverlay.js +66 -0
  573. package/lib/view/overlay/SnaplineOverlay.js.map +1 -0
  574. package/lib/view/overlay/ToolOverlay.d.ts +19 -0
  575. package/lib/view/overlay/ToolOverlay.js +79 -0
  576. package/lib/view/overlay/ToolOverlay.js.map +1 -0
  577. package/lib/view/overlay/getTransformHoc.d.ts +37 -0
  578. package/lib/view/overlay/getTransformHoc.js +61 -0
  579. package/lib/view/overlay/getTransformHoc.js.map +1 -0
  580. package/lib/view/overlay/index.d.ts +8 -0
  581. package/lib/view/overlay/index.js +25 -0
  582. package/lib/view/overlay/index.js.map +1 -0
  583. package/lib/view/shape/Circle.d.ts +2 -0
  584. package/lib/view/shape/Circle.js +61 -0
  585. package/lib/view/shape/Circle.js.map +1 -0
  586. package/lib/view/shape/Ellipse.d.ts +2 -0
  587. package/lib/view/shape/Ellipse.js +62 -0
  588. package/lib/view/shape/Ellipse.js.map +1 -0
  589. package/lib/view/shape/Line.d.ts +2 -0
  590. package/lib/view/shape/Line.js +58 -0
  591. package/lib/view/shape/Line.js.map +1 -0
  592. package/lib/view/shape/Path.d.ts +6 -0
  593. package/lib/view/shape/Path.js +47 -0
  594. package/lib/view/shape/Path.js.map +1 -0
  595. package/lib/view/shape/Polygon.d.ts +8 -0
  596. package/lib/view/shape/Polygon.js +60 -0
  597. package/lib/view/shape/Polygon.js.map +1 -0
  598. package/lib/view/shape/Polyline.d.ts +2 -0
  599. package/lib/view/shape/Polyline.js +53 -0
  600. package/lib/view/shape/Polyline.js.map +1 -0
  601. package/lib/view/shape/Rect.d.ts +15 -0
  602. package/lib/view/shape/Rect.js +64 -0
  603. package/lib/view/shape/Rect.js.map +1 -0
  604. package/lib/view/shape/Text.d.ts +2 -0
  605. package/lib/view/shape/Text.js +114 -0
  606. package/lib/view/shape/Text.js.map +1 -0
  607. package/lib/view/shape/index.d.ts +8 -0
  608. package/lib/view/shape/index.js +25 -0
  609. package/lib/view/shape/index.js.map +1 -0
  610. package/lib/view/text/BaseText.d.ts +25 -0
  611. package/lib/view/text/BaseText.js +117 -0
  612. package/lib/view/text/BaseText.js.map +1 -0
  613. package/lib/view/text/LineText.d.ts +9 -0
  614. package/lib/view/text/LineText.js +155 -0
  615. package/lib/view/text/LineText.js.map +1 -0
  616. package/lib/view/text/index.d.ts +2 -0
  617. package/lib/view/text/index.js +19 -0
  618. package/lib/view/text/index.js.map +1 -0
  619. package/package.json +41 -88
  620. package/rollup.config.js +15 -0
  621. package/src/LogicFlow.tsx +1831 -0
  622. package/src/algorithm/edge.ts +68 -0
  623. package/src/algorithm/index.ts +68 -0
  624. package/src/algorithm/outline.ts +77 -0
  625. package/src/constant/index.ts +127 -0
  626. package/src/event/event.md +66 -0
  627. package/src/event/eventArgs.ts +476 -0
  628. package/src/event/eventEmitter.ts +153 -0
  629. package/src/history/index.ts +112 -0
  630. package/src/index.less +1 -0
  631. package/src/index.ts +21 -0
  632. package/src/keyboard/index.ts +106 -0
  633. package/src/keyboard/shortcut.ts +123 -0
  634. package/src/model/BaseModel.ts +223 -0
  635. package/src/model/EditConfigModel.ts +215 -0
  636. package/src/model/GraphModel.ts +1516 -0
  637. package/src/model/SnaplineModel.ts +238 -0
  638. package/src/model/TransformModel.ts +258 -0
  639. package/src/model/edge/BaseEdgeModel.ts +688 -0
  640. package/src/model/edge/BezierEdgeModel.ts +196 -0
  641. package/src/model/edge/LineEdgeModel.ts +26 -0
  642. package/src/model/edge/PolylineEdgeModel.ts +656 -0
  643. package/src/model/edge/index.ts +4 -0
  644. package/src/model/index.ts +8 -0
  645. package/src/model/node/BaseNodeModel.ts +839 -0
  646. package/src/model/node/CircleNodeModel.ts +89 -0
  647. package/src/model/node/DiamondNodeModel.ts +128 -0
  648. package/src/model/node/EllipseNodeModel.ts +94 -0
  649. package/src/model/node/HtmlNodeModel.ts +49 -0
  650. package/src/model/node/PolygonNodeModel.ts +147 -0
  651. package/src/model/node/RectNodeModel.ts +57 -0
  652. package/src/model/node/TextNodeModel.ts +41 -0
  653. package/src/model/node/index.ts +8 -0
  654. package/src/options.ts +173 -0
  655. package/src/style/index.less +256 -0
  656. package/src/style/raw.ts +217 -0
  657. package/src/tool/MultipleSelectTool.tsx +132 -0
  658. package/src/tool/TextEditTool.tsx +193 -0
  659. package/src/tool/index.ts +2 -0
  660. package/src/tool/snapline.ts +17 -0
  661. package/src/tool/tool.ts +66 -0
  662. package/src/typings.d.ts +5 -0
  663. package/src/util/animation.ts +29 -0
  664. package/src/util/browser.ts +4 -0
  665. package/src/util/compatible.ts +15 -0
  666. package/src/util/drag.ts +186 -0
  667. package/src/util/edge.ts +1034 -0
  668. package/src/util/geometry.ts +53 -0
  669. package/src/util/graph.ts +46 -0
  670. package/src/util/index.ts +16 -0
  671. package/src/util/matrix.ts +129 -0
  672. package/src/util/mobx.ts +23 -0
  673. package/src/util/node.ts +519 -0
  674. package/src/util/raf.ts +28 -0
  675. package/src/util/sampling.ts +85 -0
  676. package/src/util/theme.ts +180 -0
  677. package/src/util/uuid.ts +26 -0
  678. package/src/util/vector.ts +93 -0
  679. package/src/util/zIndex.ts +6 -0
  680. package/src/view/Anchor.tsx +407 -0
  681. package/src/view/Control.tsx +446 -0
  682. package/src/view/Graph.tsx +104 -0
  683. package/src/view/Rotate.tsx +112 -0
  684. package/src/view/behavior/dnd.ts +116 -0
  685. package/src/view/edge/AdjustPoint.tsx +439 -0
  686. package/src/view/edge/Arrow.tsx +54 -0
  687. package/src/view/edge/BaseEdge.tsx +489 -0
  688. package/src/view/edge/BezierEdge.tsx +101 -0
  689. package/src/view/edge/LineEdge.tsx +81 -0
  690. package/src/view/edge/PolylineEdge.tsx +299 -0
  691. package/src/view/edge/index.ts +6 -0
  692. package/src/view/index.ts +8 -0
  693. package/src/view/node/BaseNode.tsx +494 -0
  694. package/src/view/node/CircleNode.tsx +19 -0
  695. package/src/view/node/DiamondNode.tsx +22 -0
  696. package/src/view/node/EllipseNode.tsx +20 -0
  697. package/src/view/node/HtmlNode.tsx +92 -0
  698. package/src/view/node/PolygonNode.tsx +26 -0
  699. package/src/view/node/RectNode.tsx +28 -0
  700. package/src/view/node/TextNode.tsx +37 -0
  701. package/src/view/node/index.ts +8 -0
  702. package/src/view/overlay/BackgroundOverlay.tsx +39 -0
  703. package/src/view/overlay/BezierAdjustOverlay.tsx +150 -0
  704. package/src/view/overlay/CanvasOverlay.tsx +180 -0
  705. package/src/view/overlay/Grid.tsx +135 -0
  706. package/src/view/overlay/ModificationOverlay.tsx +31 -0
  707. package/src/view/overlay/OutlineOverlay.tsx +170 -0
  708. package/src/view/overlay/SnaplineOverlay.tsx +44 -0
  709. package/src/view/overlay/ToolOverlay.tsx +65 -0
  710. package/src/view/overlay/getTransformHoc.tsx +50 -0
  711. package/src/view/overlay/index.ts +8 -0
  712. package/src/view/shape/Circle.tsx +27 -0
  713. package/src/view/shape/Ellipse.tsx +28 -0
  714. package/src/view/shape/Line.tsx +24 -0
  715. package/src/view/shape/Path.tsx +19 -0
  716. package/src/view/shape/Polygon.tsx +36 -0
  717. package/src/view/shape/Polyline.tsx +19 -0
  718. package/src/view/shape/Rect.tsx +44 -0
  719. package/src/view/shape/Text.tsx +138 -0
  720. package/src/view/shape/index.ts +8 -0
  721. package/src/view/text/BaseText.tsx +96 -0
  722. package/src/view/text/LineText.tsx +154 -0
  723. package/src/view/text/index.ts +2 -0
  724. package/tsconfig.json +18 -0
  725. package/dist/entry.js +0 -7
  726. package/dist/logic-flow.js +0 -23
  727. package/dist/logic-flow.min.js +0 -23
  728. package/types/LogicFlow.d.ts +0 -581
  729. package/types/algorithm/edge.d.ts +0 -6
  730. package/types/algorithm/outline.d.ts +0 -35
  731. package/types/constant/DefaultAnimation.d.ts +0 -12
  732. package/types/constant/DefaultTheme.d.ts +0 -270
  733. package/types/event/eventEmitter.d.ts +0 -36
  734. package/types/history/History.d.ts +0 -20
  735. package/types/model/BaseModel.d.ts +0 -99
  736. package/types/model/SnaplineModel.d.ts +0 -33
  737. package/types/model/edge/BezierEdgeModel.d.ts +0 -51
  738. package/types/model/edge/LineEdgeModel.d.ts +0 -14
  739. package/types/model/edge/PolylineEdgeModel.d.ts +0 -63
  740. package/types/model/node/BaseNodeModel.d.ts +0 -232
  741. package/types/model/node/CircleNodeModel.d.ts +0 -21
  742. package/types/model/node/DiamondNodeModel.d.ts +0 -25
  743. package/types/model/node/EllipseNodeModel.d.ts +0 -22
  744. package/types/model/node/HtmlNodeModel.d.ts +0 -12
  745. package/types/model/node/PolygonNodeModel.d.ts +0 -28
  746. package/types/model/node/RectNodeModel.d.ts +0 -19
  747. package/types/model/node/TextNodeModel.d.ts +0 -19
  748. package/types/options.d.ts +0 -240
  749. package/types/tool/MultipleSelectTool.d.ts +0 -20
  750. package/types/tool/TextEditTool.d.ts +0 -34
  751. package/types/tool/index.d.ts +0 -13
  752. package/types/type/index.d.ts +0 -429
  753. package/types/util/animation.d.ts +0 -2
  754. package/types/util/compatible.d.ts +0 -1
  755. package/types/util/drag.d.ts +0 -38
  756. package/types/util/edge.d.ts +0 -108
  757. package/types/util/geometry.d.ts +0 -2
  758. package/types/util/index.d.ts +0 -7
  759. package/types/util/node.d.ts +0 -66
  760. package/types/util/raf.d.ts +0 -2
  761. package/types/util/theme.d.ts +0 -2
  762. package/types/util/uuid.d.ts +0 -6
  763. package/types/view/Anchor.d.ts +0 -54
  764. package/types/view/Graph.d.ts +0 -21
  765. package/types/view/basic-shape/Circle.d.ts +0 -2
  766. package/types/view/basic-shape/Ellipse.d.ts +0 -2
  767. package/types/view/basic-shape/Line.d.ts +0 -3
  768. package/types/view/basic-shape/LinearGradient.d.ts +0 -1
  769. package/types/view/basic-shape/Path.d.ts +0 -7
  770. package/types/view/basic-shape/Polygon.d.ts +0 -2
  771. package/types/view/basic-shape/Polyline.d.ts +0 -3
  772. package/types/view/basic-shape/Rect.d.ts +0 -14
  773. package/types/view/basic-shape/Text.d.ts +0 -2
  774. package/types/view/behavior/DnD.d.ts +0 -35
  775. package/types/view/behavior/Transform.d.ts +0 -4
  776. package/types/view/edge/AdjustPoint.d.ts +0 -56
  777. package/types/view/edge/Arrow.d.ts +0 -24
  778. package/types/view/edge/index.d.ts +0 -6
  779. package/types/view/index.d.ts +0 -2
  780. package/types/view/node/BaseNode.d.ts +0 -57
  781. package/types/view/node/CircleNode.d.ts +0 -5
  782. package/types/view/node/DiamondNode.d.ts +0 -5
  783. package/types/view/node/EllipseNode.d.ts +0 -5
  784. package/types/view/node/PolygonNode.d.ts +0 -5
  785. package/types/view/node/RectNode.d.ts +0 -5
  786. package/types/view/node/TextNode.d.ts +0 -6
  787. package/types/view/node/index.d.ts +0 -9
  788. package/types/view/overlay/BezierAdjustOverlay.d.ts +0 -12
  789. package/types/view/overlay/Grid.d.ts +0 -30
  790. package/types/view/overlay/HtmlOverlay.d.ts +0 -15
  791. package/types/view/overlay/ModificationOverlay.d.ts +0 -9
  792. package/types/view/overlay/OutlineOverlay.d.ts +0 -17
  793. package/types/view/overlay/SnaplineOverlay.d.ts +0 -9
  794. package/types/view/overlay/ToolOverlay.d.ts +0 -17
  795. package/types/view/text/BaseText.d.ts +0 -29
  796. package/types/view/text/LineText.d.ts +0 -9
  797. /package/{types → es}/algorithm/index.d.ts +0 -0
  798. /package/{types → es}/keyboard/shortcut.d.ts +0 -0
  799. /package/{types → es}/model/edge/index.d.ts +0 -0
  800. /package/{types → es}/model/index.d.ts +0 -0
  801. /package/{types → es}/model/node/index.d.ts +0 -0
  802. /package/{types → es}/util/browser.d.ts +0 -0
  803. /package/{types → es}/util/mobx.d.ts +0 -0
  804. /package/{types → es}/util/zIndex.d.ts +0 -0
@@ -0,0 +1,1174 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __read = (this && this.__read) || function (o, n) {
13
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
14
+ if (!m) return o;
15
+ var i = m.call(o), r, ar = [], e;
16
+ try {
17
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
18
+ }
19
+ catch (error) { e = { error: error }; }
20
+ finally {
21
+ try {
22
+ if (r && !r.done && (m = i["return"])) m.call(i);
23
+ }
24
+ finally { if (e) throw e.error; }
25
+ }
26
+ return ar;
27
+ };
28
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
29
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
30
+ if (ar || !(i in from)) {
31
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
32
+ ar[i] = from[i];
33
+ }
34
+ }
35
+ return to.concat(ar || Array.prototype.slice.call(from));
36
+ };
37
+ import { jsx as _jsx } from "preact/jsx-runtime";
38
+ import { createElement as h, render } from 'preact/compat';
39
+ import { cloneDeep, forEach } from 'lodash-es';
40
+ import { observer } from '.';
41
+ import { Options as LFOptions } from './options';
42
+ import * as _Model from './model';
43
+ import { GraphModel, SnaplineModel, } from './model';
44
+ import Graph from './view/Graph';
45
+ import * as _View from './view';
46
+ import { formatData } from './util';
47
+ import Dnd from './view/behavior/dnd';
48
+ import Tool from './tool/tool';
49
+ import { snapline } from './tool';
50
+ import Keyboard from './keyboard';
51
+ import History from './history';
52
+ import { ElementType, EventType } from './constant';
53
+ import { initDefaultShortcut } from './keyboard/shortcut';
54
+ var pluginFlag = Symbol('plugin registered by Logicflow.use');
55
+ var LogicFlow = /** @class */ (function () {
56
+ function LogicFlow(options) {
57
+ var _this = this;
58
+ var _a;
59
+ this.viewMap = new Map();
60
+ this.components = [];
61
+ // 插件扩展方法
62
+ this.extension = {};
63
+ /*********************************************************
64
+ * Register 相关
65
+ ********************************************************/
66
+ this.setView = function (type, component) {
67
+ return _this.viewMap.set(type, component);
68
+ };
69
+ // 根据 type 获取对应的 view
70
+ this.getView = function (type) {
71
+ return _this.viewMap.get(type);
72
+ };
73
+ var initOptions = LFOptions.get(options);
74
+ this.options = initOptions;
75
+ this.container = this.initContainer(initOptions.container);
76
+ this.graphModel = new GraphModel(__assign(__assign({}, initOptions), { container: this.container }));
77
+ this.plugins = (_a = initOptions.plugins) !== null && _a !== void 0 ? _a : [];
78
+ var eventCenter = this.graphModel.eventCenter;
79
+ this.tool = new Tool(this);
80
+ this.dnd = new Dnd({ lf: this });
81
+ this.history = new History(eventCenter);
82
+ this.keyboard = new Keyboard({
83
+ lf: this,
84
+ keyboard: initOptions.keyboard,
85
+ });
86
+ if (initOptions.snapline !== false) {
87
+ this.snaplineModel = new SnaplineModel(this.graphModel);
88
+ snapline(eventCenter, this.snaplineModel);
89
+ }
90
+ if (!initOptions.isSilentMode) {
91
+ // 先初始化默认内置快捷键,自定义快捷键可以覆盖默认快捷键
92
+ initDefaultShortcut(this, this.graphModel);
93
+ // 然后再初始化自定义快捷键,自定义快捷键可以覆盖默认快捷键.
94
+ // 插件最后初始化。方便插件强制覆盖内置快捷键
95
+ this.keyboard.initShortcuts();
96
+ }
97
+ this.defaultRegister();
98
+ this.installPlugins(initOptions.disabledPlugins);
99
+ }
100
+ LogicFlow.prototype.initContainer = function (container) {
101
+ // TODO: 确认是否需要,后续是否只要返回 container 即可(下面方法是为了解决事件绑定问题的)
102
+ // fix: destroy keyboard events while destroy LogicFlow.(#1110)
103
+ var lfContainer = document.createElement('div');
104
+ lfContainer.style.position = 'relative';
105
+ lfContainer.style.width = '100%';
106
+ lfContainer.style.height = '100%';
107
+ container.innerHTML = '';
108
+ container.appendChild(lfContainer);
109
+ return lfContainer;
110
+ };
111
+ Object.defineProperty(LogicFlow.prototype, Symbol.toStringTag, {
112
+ get: function () {
113
+ return LogicFlow.toStringTag;
114
+ },
115
+ enumerable: false,
116
+ configurable: true
117
+ });
118
+ /**
119
+ * 注册自定义节点和边
120
+ * 支持两种方式
121
+ * 方式一(推荐)
122
+ * 详情见 todo: docs link
123
+ * @example
124
+ * import { RectNode, RectModel } from '@logicflow/core'
125
+ * class CustomView extends RectNode {
126
+ * }
127
+ * class CustomModel extends RectModel {
128
+ * }
129
+ * lf.register({
130
+ * type: 'custom',
131
+ * view: CustomView,
132
+ * model: CustomModel
133
+ * })
134
+ * 方式二
135
+ * 不推荐,极个别在自定义的时候需要用到lf的情况下可以用这种方式。
136
+ * 大多数情况下,我们可以直接在view中从this.props中获取graphModel
137
+ * 或者model中直接this.graphModel获取model的方法。
138
+ * @example
139
+ * lf.register('custom', ({ RectNode, RectModel }) => {
140
+ * class CustomView extends RectNode {}
141
+ * class CustomModel extends RectModel {}
142
+ * return {
143
+ * view: CustomView,
144
+ * model: CustomModel
145
+ * }
146
+ * })
147
+ */
148
+ LogicFlow.prototype.register = function (element, fn, isObserverView) {
149
+ if (isObserverView === void 0) { isObserverView = true; }
150
+ // 方式1
151
+ if (typeof element !== 'string') {
152
+ this.registerElement(element);
153
+ return;
154
+ }
155
+ // 方式2 TODO: 优化下面这段代码,没太看懂这一块的背景
156
+ var registerParam = {
157
+ BaseEdge: _View.BaseEdge,
158
+ BaseEdgeModel: _Model.BaseEdgeModel,
159
+ BaseNode: _View.BaseNode,
160
+ BaseNodeModel: _Model.BaseNodeModel,
161
+ RectNode: _View.RectNode,
162
+ RectNodeModel: _Model.RectNodeModel,
163
+ CircleNode: _View.CircleNode,
164
+ CircleNodeModel: _Model.CircleNodeModel,
165
+ PolygonNode: _View.PolygonNode,
166
+ PolygonNodeModel: _Model.PolygonNodeModel,
167
+ TextNode: _View.TextNode,
168
+ TextNodeModel: _Model.TextNodeModel,
169
+ LineEdge: _View.LineEdge,
170
+ LineEdgeModel: _Model.LineEdgeModel,
171
+ DiamondNode: _View.DiamondNode,
172
+ DiamondNodeModel: _Model.DiamondNodeModel,
173
+ PolylineEdge: _View.PolylineEdge,
174
+ PolylineEdgeModel: _Model.PolylineEdgeModel,
175
+ BezierEdge: _View.BezierEdge,
176
+ BezierEdgeModel: _Model.BezierEdgeModel,
177
+ EllipseNode: _View.EllipseNode,
178
+ EllipseNodeModel: _Model.EllipseNodeModel,
179
+ HtmlNode: _View.HtmlNode,
180
+ HtmlNodeModel: _Model.HtmlNodeModel,
181
+ // mobx,
182
+ h: h,
183
+ type: element,
184
+ };
185
+ // 为了能让后来注册的可以继承前面注册的
186
+ // 例如我注册一个“开始节点”
187
+ // 然后我再想注册一个“立即开始节点”
188
+ // 注册传递参数改为动态。
189
+ // TODO: 确定 extendKey 的作用
190
+ this.viewMap.forEach(function (component) {
191
+ var key = component.extendKey;
192
+ if (key) {
193
+ registerParam[key] = component;
194
+ }
195
+ });
196
+ this.graphModel.modelMap.forEach(function (component) {
197
+ var key = component.extendKey;
198
+ if (key) {
199
+ registerParam[key] = component;
200
+ }
201
+ });
202
+ if (fn) {
203
+ var _a = fn(registerParam), ViewClass = _a.view, ModelClass = _a.model;
204
+ var vClass = ViewClass; // TODO: 确认 ViewClass 类型
205
+ if (isObserverView && !vClass.isObserved) {
206
+ vClass.isObserved = true;
207
+ vClass = observer(vClass);
208
+ }
209
+ this.setView(element, vClass);
210
+ this.graphModel.setModel(element, ModelClass);
211
+ }
212
+ };
213
+ /**
214
+ * 注册元素(节点 or 边)
215
+ * @param config 注册元素的配置项
216
+ * @private
217
+ */
218
+ LogicFlow.prototype.registerElement = function (config) {
219
+ var ViewComp = config.view;
220
+ if (config.isObserverView !== false && !ViewComp.isObserved) {
221
+ ViewComp.isObserved = true;
222
+ ViewComp = observer(ViewComp);
223
+ }
224
+ this.setView(config.type, ViewComp);
225
+ this.graphModel.setModel(config.type, config.model);
226
+ };
227
+ /**
228
+ * 批量注册元素
229
+ * @param elements 注册的元素
230
+ */
231
+ LogicFlow.prototype.batchRegister = function (elements) {
232
+ var _this = this;
233
+ if (elements === void 0) { elements = []; }
234
+ forEach(elements, function (element) {
235
+ _this.registerElement(element);
236
+ });
237
+ };
238
+ LogicFlow.prototype.defaultRegister = function () {
239
+ // LogicFlow default Nodes and Edges
240
+ var defaultElements = [
241
+ // Node
242
+ {
243
+ type: 'rect',
244
+ view: _View.RectNode,
245
+ model: _Model.RectNodeModel,
246
+ },
247
+ {
248
+ type: 'circle',
249
+ view: _View.CircleNode,
250
+ model: _Model.CircleNodeModel,
251
+ },
252
+ {
253
+ type: 'polygon',
254
+ view: _View.PolygonNode,
255
+ model: _Model.PolygonNodeModel,
256
+ },
257
+ {
258
+ type: 'text',
259
+ view: _View.TextNode,
260
+ model: _Model.TextNodeModel,
261
+ },
262
+ {
263
+ type: 'ellipse',
264
+ view: _View.EllipseNode,
265
+ model: _Model.EllipseNodeModel,
266
+ },
267
+ {
268
+ type: 'diamond',
269
+ view: _View.DiamondNode,
270
+ model: _Model.DiamondNodeModel,
271
+ },
272
+ {
273
+ type: 'html',
274
+ view: _View.HtmlNode,
275
+ model: _Model.HtmlNodeModel,
276
+ },
277
+ // Edge
278
+ {
279
+ type: 'line',
280
+ view: _View.LineEdge,
281
+ model: _Model.LineEdgeModel,
282
+ },
283
+ {
284
+ type: 'polyline',
285
+ view: _View.PolylineEdge,
286
+ model: _Model.PolylineEdgeModel,
287
+ },
288
+ {
289
+ type: 'bezier',
290
+ view: _View.BezierEdge,
291
+ model: _Model.BezierEdgeModel,
292
+ },
293
+ ];
294
+ this.batchRegister(defaultElements);
295
+ };
296
+ /*********************************************************
297
+ * Node 相关方法
298
+ ********************************************************/
299
+ /**
300
+ * 添加节点
301
+ * @param nodeConfig 节点配置
302
+ * @param eventType 新增节点事件类型,默认EventType.NODE_ADD
303
+ * @param e MouseEvent 事件
304
+ */
305
+ LogicFlow.prototype.addNode = function (nodeConfig, eventType, e) {
306
+ if (eventType === void 0) { eventType = EventType.NODE_ADD; }
307
+ return this.graphModel.addNode(nodeConfig, eventType, e);
308
+ };
309
+ /**
310
+ * 删除节点
311
+ * @param {string} nodeId 节点Id
312
+ */
313
+ LogicFlow.prototype.deleteNode = function (nodeId) {
314
+ var nodeModel = this.graphModel.getNodeModelById(nodeId);
315
+ if (!nodeModel)
316
+ return false;
317
+ var nodeData = nodeModel.getData();
318
+ var guards = this.options.guards;
319
+ var isEnableDelete = (guards === null || guards === void 0 ? void 0 : guards.beforeDelete)
320
+ ? guards.beforeDelete(nodeData)
321
+ : true;
322
+ if (isEnableDelete) {
323
+ this.graphModel.deleteNode(nodeId);
324
+ }
325
+ return isEnableDelete;
326
+ };
327
+ /**
328
+ * 克隆节点
329
+ * @param nodeId 节点Id
330
+ */
331
+ LogicFlow.prototype.cloneNode = function (nodeId) {
332
+ var nodeModel = this.graphModel.getNodeModelById(nodeId);
333
+ var nodeData = nodeModel === null || nodeModel === void 0 ? void 0 : nodeModel.getData();
334
+ if (nodeData) {
335
+ var guards = this.options.guards;
336
+ var isEnableClone = (guards === null || guards === void 0 ? void 0 : guards.beforeClone)
337
+ ? guards.beforeClone(nodeData)
338
+ : true;
339
+ if (isEnableClone) {
340
+ return this.graphModel.cloneNode(nodeId);
341
+ }
342
+ }
343
+ };
344
+ /**
345
+ * 修改节点的id,如果不传新的id,会内部自动创建一个。
346
+ * @param { string } nodeId 将要被修改的id
347
+ * @param { string } newId 可选,修改后的id
348
+ * @returns 修改后的节点id, 如果传入的oldId不存在,返回空字符串
349
+ */
350
+ LogicFlow.prototype.changeNodeId = function (nodeId, newId) {
351
+ return this.graphModel.changeNodeId(nodeId, newId);
352
+ };
353
+ /**
354
+ * 修改指定节点类型
355
+ * @param nodeId 节点id
356
+ * @param type 节点类型
357
+ */
358
+ LogicFlow.prototype.changeNodeType = function (nodeId, type) {
359
+ this.graphModel.changeNodeType(nodeId, type);
360
+ };
361
+ /**
362
+ * 获取节点对象
363
+ * @param nodeId 节点Id
364
+ */
365
+ LogicFlow.prototype.getNodeModelById = function (nodeId) {
366
+ return this.graphModel.getNodeModelById(nodeId);
367
+ };
368
+ /**
369
+ * 获取节点数据
370
+ * @param nodeId 节点
371
+ */
372
+ LogicFlow.prototype.getNodeDataById = function (nodeId) {
373
+ var nodeModel = this.getNodeModelById(nodeId);
374
+ return nodeModel === null || nodeModel === void 0 ? void 0 : nodeModel.getData();
375
+ };
376
+ /**
377
+ * 获取所有以此节点为终点的边
378
+ * @param { string } nodeId
379
+ */
380
+ LogicFlow.prototype.getNodeIncomingEdge = function (nodeId) {
381
+ return this.graphModel.getNodeIncomingEdge(nodeId);
382
+ };
383
+ /**
384
+ * 获取所有以此节点为起点的边
385
+ * @param {string} nodeId
386
+ */
387
+ LogicFlow.prototype.getNodeOutgoingEdge = function (nodeId) {
388
+ return this.graphModel.getNodeOutgoingEdge(nodeId);
389
+ };
390
+ /**
391
+ * 获取节点连接到的所有起始节点
392
+ * @param {string} nodeId
393
+ */
394
+ LogicFlow.prototype.getNodeIncomingNode = function (nodeId) {
395
+ return this.graphModel.getNodeIncomingNode(nodeId);
396
+ };
397
+ /**
398
+ * 获取节点连接到的所有目标节点
399
+ * @param {string} nodeId
400
+ */
401
+ LogicFlow.prototype.getNodeOutgoingNode = function (nodeId) {
402
+ return this.graphModel.getNodeOutgoingNode(nodeId);
403
+ };
404
+ /**
405
+ * 内部保留方法
406
+ * 创建一个fakeNode,用于dnd插件拖动节点进画布的时候使用。
407
+ */
408
+ LogicFlow.prototype.createFakeNode = function (nodeConfig) {
409
+ var Model = this.graphModel.modelMap.get(nodeConfig.type);
410
+ if (!Model) {
411
+ console.warn("\u4E0D\u5B58\u5728\u4E3A".concat(nodeConfig.type, "\u7C7B\u578B\u7684\u8282\u70B9"));
412
+ return null;
413
+ }
414
+ // * initNodeData区分是否为虚拟节点
415
+ var fakeNodeModel = new Model(__assign(__assign({}, nodeConfig), { virtual: true }), this.graphModel);
416
+ this.graphModel.setFakeNode(fakeNodeModel);
417
+ return fakeNodeModel;
418
+ };
419
+ /**
420
+ * 内部保留方法
421
+ * 移除fakeNode
422
+ */
423
+ LogicFlow.prototype.removeFakeNode = function () {
424
+ this.graphModel.removeFakeNode();
425
+ };
426
+ /**
427
+ * 内部保留方法
428
+ * 用于fakeNode显示对齐线
429
+ */
430
+ LogicFlow.prototype.setNodeSnapLine = function (data) {
431
+ var _a;
432
+ (_a = this.snaplineModel) === null || _a === void 0 ? void 0 : _a.setNodeSnapLine(data);
433
+ };
434
+ /**
435
+ * 内部保留方法
436
+ * 用于fakeNode移除对齐线
437
+ */
438
+ LogicFlow.prototype.removeNodeSnapLine = function () {
439
+ var _a;
440
+ (_a = this.snaplineModel) === null || _a === void 0 ? void 0 : _a.clearSnapline();
441
+ };
442
+ /*********************************************************
443
+ * Edge 相关方法
444
+ ********************************************************/
445
+ /**
446
+ * 设置默认的边类型。
447
+ * 也就是设置在节点直接由用户手动绘制的连线类型。
448
+ * @param type LFOptions.EdgeType
449
+ */
450
+ LogicFlow.prototype.setDefaultEdgeType = function (type) {
451
+ this.graphModel.setDefaultEdgeType(type);
452
+ };
453
+ /**
454
+ * 给两个节点之间添加一条边
455
+ * @example
456
+ * lf.addEdge({
457
+ * type: 'polygon'
458
+ * sourceNodeId: 'node_id_1',
459
+ * targetNodeId: 'node_id_2',
460
+ * })
461
+ * @param {EdgeConfig} edgeConfig
462
+ */
463
+ LogicFlow.prototype.addEdge = function (edgeConfig) {
464
+ return this.graphModel.addEdge(edgeConfig);
465
+ };
466
+ /**
467
+ * 基于id获取边数据
468
+ * @param edgeId 边Id
469
+ * @returns EdgeData
470
+ */
471
+ LogicFlow.prototype.getEdgeDataById = function (edgeId) {
472
+ var edgeModel = this.getEdgeModelById(edgeId);
473
+ return edgeModel === null || edgeModel === void 0 ? void 0 : edgeModel.getData();
474
+ };
475
+ /**
476
+ * 基于边Id获取边的model
477
+ * @param edgeId 边的Id
478
+ * @return model
479
+ */
480
+ LogicFlow.prototype.getEdgeModelById = function (edgeId) {
481
+ return this.graphModel.getEdgeModelById(edgeId);
482
+ };
483
+ /**
484
+ * 获取满足条件边的model
485
+ * @param edgeFilter 过滤条件
486
+ * @example
487
+ * 获取所有起点为节点 A 的边的 model
488
+ * lf.getEdgeModels({
489
+ * sourceNodeId: 'nodeA_id'
490
+ * })
491
+ * 获取所有终点为节点 B 的边的 model
492
+ * lf.getEdgeModels({
493
+ * targetNodeId: 'nodeB_id'
494
+ * })
495
+ * 获取起点为节点 A,终点为节点 B 的边
496
+ * lf.getEdgeModels({
497
+ * sourceNodeId: 'nodeA_id',
498
+ * targetNodeId: 'nodeB_id'
499
+ * })
500
+ * @return model数组
501
+ */
502
+ LogicFlow.prototype.getEdgeModels = function (_a) {
503
+ var sourceNodeId = _a.sourceNodeId, targetNodeId = _a.targetNodeId;
504
+ var results = [];
505
+ var edges = this.graphModel.edges;
506
+ if (sourceNodeId && targetNodeId) {
507
+ forEach(edges, function (edge) {
508
+ if (edge.sourceNodeId === sourceNodeId &&
509
+ edge.targetNodeId === targetNodeId) {
510
+ results.push(edge);
511
+ }
512
+ });
513
+ }
514
+ else if (sourceNodeId) {
515
+ forEach(edges, function (edge) {
516
+ if (edge.sourceNodeId === sourceNodeId) {
517
+ results.push(edge);
518
+ }
519
+ });
520
+ }
521
+ else if (targetNodeId) {
522
+ forEach(edges, function (edge) {
523
+ if (edge.targetNodeId === targetNodeId) {
524
+ results.push(edge);
525
+ }
526
+ });
527
+ }
528
+ return results;
529
+ };
530
+ /**
531
+ * 修改边的id, 如果不传新的id,会内部自动创建一个。
532
+ * @param { string } edgeId 将要被修改的id
533
+ * @param { string } newId 可选,修改后的id
534
+ * @returns 修改后的节点id, 如果传入的oldId不存在,返回空字符串
535
+ */
536
+ LogicFlow.prototype.changeEdgeId = function (edgeId, newId) {
537
+ return this.graphModel.changeEdgeId(edgeId, newId);
538
+ };
539
+ /**
540
+ * 切换边的类型
541
+ * @param edgeId 边Id
542
+ * @param type 边类型
543
+ */
544
+ LogicFlow.prototype.changeEdgeType = function (edgeId, type) {
545
+ this.graphModel.changeEdgeType(edgeId, type);
546
+ };
547
+ /**
548
+ * 删除边
549
+ * @param {string} edgeId 边Id
550
+ */
551
+ LogicFlow.prototype.deleteEdge = function (edgeId) {
552
+ var edgeModel = this.graphModel.getEdgeModelById(edgeId);
553
+ if (!edgeModel)
554
+ return false;
555
+ var edgeData = edgeModel.getData();
556
+ var guards = this.options.guards;
557
+ var isEnableDelete = (guards === null || guards === void 0 ? void 0 : guards.beforeDelete)
558
+ ? guards.beforeDelete(edgeData)
559
+ : true;
560
+ if (isEnableDelete) {
561
+ this.graphModel.deleteEdgeById(edgeId);
562
+ }
563
+ return isEnableDelete;
564
+ };
565
+ /**
566
+ * 基于给定节点(作为边起点或终点,可以只传其一),删除对应的边
567
+ * @param sourceNodeId 边的起点节点ID
568
+ * @param targetNodeId 边的终点节点ID
569
+ */
570
+ LogicFlow.prototype.deleteEdgeByNodeId = function (_a) {
571
+ var sourceNodeId = _a.sourceNodeId, targetNodeId = _a.targetNodeId;
572
+ // TODO: 将下面方法从 this.graphModel 解构,并测试代码功能是否正常(需要确认 this 指向是否有异常)
573
+ if (sourceNodeId && targetNodeId) {
574
+ this.graphModel.deleteEdgeBySourceAndTarget(sourceNodeId, targetNodeId);
575
+ }
576
+ else if (sourceNodeId) {
577
+ this.graphModel.deleteEdgeBySource(sourceNodeId);
578
+ }
579
+ else if (targetNodeId) {
580
+ this.graphModel.deleteEdgeByTarget(targetNodeId);
581
+ }
582
+ };
583
+ /**
584
+ * 获取节点连接的所有边的model
585
+ * @param nodeId 节点ID
586
+ * @returns model数组
587
+ */
588
+ LogicFlow.prototype.getNodeEdges = function (nodeId) {
589
+ return this.graphModel.getNodeEdges(nodeId);
590
+ };
591
+ /*********************************************************
592
+ * Element 相关方法
593
+ ********************************************************/
594
+ /**
595
+ * 添加多个元素, 包括边和节点。
596
+ * @param nodes
597
+ * @param edges
598
+ * @param distance
599
+ */
600
+ LogicFlow.prototype.addElements = function (_a, distance) {
601
+ var _this = this;
602
+ var nodes = _a.nodes, edges = _a.edges;
603
+ if (distance === void 0) { distance = 40; }
604
+ // TODO: 1. 解决下面方法中 distance 传参缺未使用的问题;该方法在快捷键中有调用
605
+ console.log('addElements', nodes, edges, distance);
606
+ // TODO: 2. review 一下本函数代码逻辑,确认 nodeIdMap 的作用,看是否有优化的空间
607
+ var nodeIdMap = {};
608
+ var elements = {
609
+ nodes: [],
610
+ edges: [],
611
+ };
612
+ forEach(nodes, function (node) {
613
+ var nodeId = node.id;
614
+ var nodeModel = _this.addNode(node);
615
+ if (nodeId)
616
+ nodeIdMap[nodeId] = nodeModel.id;
617
+ elements.nodes.push(nodeModel);
618
+ });
619
+ forEach(edges, function (edge) {
620
+ var sourceNodeId = edge.sourceNodeId, targetNodeId = edge.targetNodeId;
621
+ if (nodeIdMap[sourceNodeId])
622
+ sourceNodeId = nodeIdMap[sourceNodeId];
623
+ if (nodeIdMap[targetNodeId])
624
+ targetNodeId = nodeIdMap[targetNodeId];
625
+ var edgeModel = _this.graphModel.addEdge(__assign(__assign({}, edge), { sourceNodeId: sourceNodeId, targetNodeId: targetNodeId }));
626
+ elements.edges.push(edgeModel);
627
+ });
628
+ return elements;
629
+ };
630
+ /**
631
+ * 将图形选中
632
+ * @param id 选择元素ID
633
+ * @param multiple 是否允许多选,如果为true,不会将上一个选中的元素重置
634
+ * @param toFront 是否将选中的元素置顶,默认为true
635
+ */
636
+ LogicFlow.prototype.selectElementById = function (id, multiple, toFront) {
637
+ if (multiple === void 0) { multiple = false; }
638
+ if (toFront === void 0) { toFront = true; }
639
+ this.graphModel.selectElementById(id, multiple);
640
+ if (!multiple && toFront) {
641
+ this.graphModel.toFront(id);
642
+ }
643
+ };
644
+ /**
645
+ * 获取选中的元素数据
646
+ * @param isIgnoreCheck 是否包括sourceNode和targetNode没有被选中的边,默认包括。
647
+ * 注意:复制的时候不能包括此类边, 因为复制的时候不允许悬空的边。
648
+ */
649
+ LogicFlow.prototype.getSelectElements = function (isIgnoreCheck) {
650
+ if (isIgnoreCheck === void 0) { isIgnoreCheck = true; }
651
+ return this.graphModel.getSelectElements(isIgnoreCheck);
652
+ };
653
+ /**
654
+ * 将所有选中的元素设置为非选中
655
+ */
656
+ LogicFlow.prototype.clearSelectElements = function () {
657
+ this.graphModel.clearSelectElements();
658
+ };
659
+ /**
660
+ * 获取节点或边对象
661
+ * @param id id
662
+ */
663
+ LogicFlow.prototype.getModelById = function (id) {
664
+ return this.graphModel.getElement(id);
665
+ };
666
+ /**
667
+ * 获取节点或边的数据
668
+ * @param id id
669
+ */
670
+ LogicFlow.prototype.getDataById = function (id) {
671
+ var _a;
672
+ return (_a = this.graphModel.getElement(id)) === null || _a === void 0 ? void 0 : _a.getData();
673
+ };
674
+ /**
675
+ * 删除元素,在不确定当前id是节点还是边时使用
676
+ * @param id 元素id
677
+ */
678
+ LogicFlow.prototype.deleteElement = function (id) {
679
+ var _a;
680
+ var _b, _c;
681
+ var model = this.getModelById(id);
682
+ if (!model)
683
+ return false;
684
+ var callback = (_a = {},
685
+ _a[ElementType.NODE] = this.deleteNode,
686
+ _a[ElementType.EDGE] = this.deleteEdge,
687
+ _a);
688
+ return (_c = (_b = callback[model.BaseType]) === null || _b === void 0 ? void 0 : _b.call(this, id)) !== null && _c !== void 0 ? _c : false;
689
+ };
690
+ /**
691
+ * 设置元素的zIndex.
692
+ * 注意:默认堆叠模式下,不建议使用此方法。
693
+ * @see todo link 堆叠模式
694
+ * @param id 元素id
695
+ * @param zIndex zIndex的值,可以传数字,也支持传入 'top' 和 'bottom'
696
+ */
697
+ LogicFlow.prototype.setElementZIndex = function (id, zIndex) {
698
+ return this.graphModel.setElementZIndex(id, zIndex);
699
+ };
700
+ /**
701
+ * 获取指定区域内的所有元素,此区域必须是DOM层。
702
+ * 例如鼠标绘制选区后,获取选区内的所有元素。
703
+ * @see todo 分层
704
+ * @param leftTopPoint 区域左上角坐标, dom层坐标
705
+ * @param rightBottomPoint 区域右下角坐标,dom层坐标
706
+ * @param wholeEdge
707
+ * @param wholeNode
708
+ * @param ignoreHideElement
709
+ */
710
+ LogicFlow.prototype.getAreaElement = function (leftTopPoint, rightBottomPoint, wholeEdge, wholeNode, ignoreHideElement) {
711
+ if (wholeEdge === void 0) { wholeEdge = true; }
712
+ if (wholeNode === void 0) { wholeNode = true; }
713
+ if (ignoreHideElement === void 0) { ignoreHideElement = false; }
714
+ return this.graphModel
715
+ .getAreaElement(leftTopPoint, rightBottomPoint, wholeEdge, wholeNode, ignoreHideElement)
716
+ .map(function (element) { return element.getData(); });
717
+ };
718
+ /**
719
+ * 设置元素的自定义属性
720
+ * @see todo docs link
721
+ * @param id 元素的id
722
+ * @param properties 自定义属性
723
+ */
724
+ LogicFlow.prototype.setProperties = function (id, properties) {
725
+ var _a;
726
+ (_a = this.graphModel.getElement(id)) === null || _a === void 0 ? void 0 : _a.setProperties(formatData(properties));
727
+ };
728
+ /**
729
+ * 获取元素的自定义属性
730
+ * @param id 元素的id
731
+ * @returns 自定义属性
732
+ */
733
+ LogicFlow.prototype.getProperties = function (id) {
734
+ var _a;
735
+ return (_a = this.graphModel.getElement(id)) === null || _a === void 0 ? void 0 : _a.getProperties();
736
+ };
737
+ LogicFlow.prototype.deleteProperty = function (id, key) {
738
+ var _a;
739
+ (_a = this.graphModel.getElement(id)) === null || _a === void 0 ? void 0 : _a.deleteProperty(key);
740
+ };
741
+ /**
742
+ * FBI WARNING !!! 慎用 === 不要用
743
+ * 修改对应元素 model 中的属性
744
+ * 注意:此方法慎用,除非您对logicflow内部有足够的了解。
745
+ * 大多数情况下,请使用setProperties、updateText、changeNodeId等方法。
746
+ * 例如直接使用此方法修改节点的id,那么就是会导致连接到此节点的边的sourceNodeId出现找不到的情况。
747
+ * @param {string} id 元素id
748
+ * @param {object} attributes 需要更新的属性
749
+ */
750
+ LogicFlow.prototype.updateAttributes = function (id, attributes) {
751
+ this.graphModel.updateAttributes(id, attributes);
752
+ };
753
+ /*********************************************************
754
+ * Text 相关方法
755
+ ********************************************************/
756
+ /**
757
+ * 显示节点、连线文本编辑框
758
+ * @param id 元素id
759
+ */
760
+ LogicFlow.prototype.editText = function (id) {
761
+ this.graphModel.editText(id);
762
+ };
763
+ /**
764
+ * 更新节点或边的文案
765
+ * @param id 节点或者边id
766
+ * @param value 文案内容
767
+ */
768
+ LogicFlow.prototype.updateText = function (id, value) {
769
+ this.graphModel.updateText(id, value);
770
+ };
771
+ /*********************************************************
772
+ * EditConfig 相关方法
773
+ ********************************************************/
774
+ /**
775
+ * 更新流程图编辑相关设置
776
+ * @param {object} config 编辑配置
777
+ * @see todo docs link
778
+ */
779
+ LogicFlow.prototype.updateEditConfig = function (config) {
780
+ var _a = this.graphModel, editConfigModel = _a.editConfigModel, transformModel = _a.transformModel;
781
+ editConfigModel.updateEditConfig(config);
782
+ if ((config === null || config === void 0 ? void 0 : config.stopMoveGraph) !== undefined) {
783
+ transformModel.updateTranslateLimits(config.stopMoveGraph);
784
+ }
785
+ // 静默模式切换时,修改快捷键的启用状态
786
+ (config === null || config === void 0 ? void 0 : config.isSilentMode) ? this.keyboard.disable() : this.keyboard.enable(true);
787
+ };
788
+ /**
789
+ * 获取流程图当前编辑相关设置
790
+ * @see todo docs link
791
+ */
792
+ LogicFlow.prototype.getEditConfig = function () {
793
+ return this.graphModel.editConfigModel.getConfig();
794
+ };
795
+ /*********************************************************
796
+ * Graph 相关方法
797
+ ********************************************************/
798
+ /**
799
+ * 设置主题样式
800
+ * @param { object } style 自定义主题样式
801
+ * todo docs link
802
+ */
803
+ LogicFlow.prototype.setTheme = function (style) {
804
+ this.graphModel.setTheme(style);
805
+ };
806
+ LogicFlow.prototype.focusByElement = function (id) {
807
+ var coordinate = undefined;
808
+ var nodeModel = this.getNodeModelById(id);
809
+ if (nodeModel) {
810
+ var _a = nodeModel.getData(), x = _a.x, y = _a.y;
811
+ coordinate = {
812
+ x: x,
813
+ y: y,
814
+ };
815
+ }
816
+ var edgeModel = this.getEdgeModelById(id);
817
+ if (edgeModel) {
818
+ var _b = edgeModel.textPosition, x = _b.x, y = _b.y;
819
+ coordinate = {
820
+ x: x,
821
+ y: y,
822
+ };
823
+ }
824
+ if (coordinate) {
825
+ this.focusByCoordinate(coordinate);
826
+ }
827
+ };
828
+ LogicFlow.prototype.focusByCoordinate = function (coordinate) {
829
+ var _a = this.graphModel, transformModel = _a.transformModel, width = _a.width, height = _a.height;
830
+ var x = coordinate.x, y = coordinate.y;
831
+ transformModel.focusOn(x, y, width, height);
832
+ };
833
+ LogicFlow.prototype.focusOn = function (focusOnArgs) {
834
+ if (typeof focusOnArgs === 'string') {
835
+ // string focusOnArgs -> id
836
+ this.focusByElement(focusOnArgs);
837
+ }
838
+ else if ('x' in focusOnArgs && 'y' in focusOnArgs) {
839
+ // Position focusOnArgs -> coordinate
840
+ this.focusByCoordinate(focusOnArgs);
841
+ }
842
+ else {
843
+ // FocusOnArgsType
844
+ var id = focusOnArgs.id, coordinate = focusOnArgs.coordinate;
845
+ if (id) {
846
+ this.focusByElement(id);
847
+ }
848
+ if (coordinate) {
849
+ this.focusByCoordinate(coordinate);
850
+ }
851
+ }
852
+ };
853
+ /**
854
+ * 重新设置画布的宽高
855
+ * 不传会自动计算画布宽高
856
+ */
857
+ LogicFlow.prototype.resize = function (width, height) {
858
+ this.graphModel.resize(width, height);
859
+ this.options.width = this.graphModel.width;
860
+ this.options.height = this.graphModel.height;
861
+ };
862
+ /**
863
+ * 将某个元素放置到顶部。
864
+ * 如果堆叠模式为默认模式,则将原置顶元素重新恢复原有层级。
865
+ * 如果堆叠模式为递增模式,则将需指定元素zIndex设置为当前最大zIndex + 1。
866
+ * @see todo link 堆叠模式
867
+ * @param id 元素Id
868
+ */
869
+ LogicFlow.prototype.toFront = function (id) {
870
+ this.graphModel.toFront(id);
871
+ };
872
+ LogicFlow.prototype.getPointByClient = function (x, y) {
873
+ if (typeof x === 'object') {
874
+ return this.graphModel.getPointByClient(x);
875
+ }
876
+ else if (typeof y === 'number') {
877
+ return this.graphModel.getPointByClient({
878
+ x: x,
879
+ y: y,
880
+ });
881
+ }
882
+ };
883
+ /**
884
+ * 获取流程绘图数据
885
+ * 注意: getGraphData返回的数据受到adapter影响,所以其数据格式不一定是logicflow内部图数据格式。
886
+ * 如果实现通用插件,请使用getGraphRawData
887
+ */
888
+ LogicFlow.prototype.getGraphData = function () {
889
+ var params = [];
890
+ for (var _i = 0; _i < arguments.length; _i++) {
891
+ params[_i] = arguments[_i];
892
+ }
893
+ var data = this.getGraphRawData();
894
+ if (this.adapterOut) {
895
+ return this.adapterOut.apply(this, __spreadArray([data], __read(params), false));
896
+ }
897
+ return data;
898
+ };
899
+ /**
900
+ * 获取流程绘图原始数据
901
+ * 在存在adapter时,可以使用getGraphRawData获取图原始数据
902
+ */
903
+ LogicFlow.prototype.getGraphRawData = function () {
904
+ return this.graphModel.modelToGraphData();
905
+ };
906
+ /**
907
+ * 清空画布
908
+ */
909
+ LogicFlow.prototype.clearData = function () {
910
+ this.graphModel.clearData();
911
+ };
912
+ /*********************************************************
913
+ * LogicFlow Render方法
914
+ ********************************************************/
915
+ LogicFlow.prototype.renderRawData = function (graphRawData) {
916
+ this.graphModel.graphDataToModel(formatData(graphRawData));
917
+ if (this.options.history !== false) {
918
+ this.history.watch(this.graphModel);
919
+ }
920
+ render(_jsx(Graph, { getView: this.getView, tool: this.tool, options: this.options, dnd: this.dnd, snaplineModel: this.snaplineModel, graphModel: this.graphModel }), this.container);
921
+ this.emit(EventType.GRAPH_RENDERED, {
922
+ data: this.graphModel.modelToGraphData(),
923
+ });
924
+ };
925
+ /**
926
+ * 渲染图
927
+ * @example
928
+ * lf.render({
929
+ * nodes: [
930
+ * {
931
+ * id: 'node_1',
932
+ * type: 'rect',
933
+ * x: 100,
934
+ * y: 100
935
+ * },
936
+ * {
937
+ * id: 'node_2',
938
+ * type: 'circle',
939
+ * x: 300,
940
+ * y: 200
941
+ * }
942
+ * ],
943
+ * edges: [
944
+ * {
945
+ * sourceNodeId: 'node_1',
946
+ * targetNodeId: 'node_2',
947
+ * type: 'polyline'
948
+ * }
949
+ * ]
950
+ * })
951
+ * @param graphData 图数据
952
+ */
953
+ LogicFlow.prototype.render = function (graphData) {
954
+ var graphRawData = cloneDeep(graphData);
955
+ if (this.adapterIn) {
956
+ graphRawData = this.adapterIn(graphRawData);
957
+ }
958
+ this.renderRawData(graphRawData);
959
+ };
960
+ /*********************************************************
961
+ * History/Resize 相关方法
962
+ ********************************************************/
963
+ /**
964
+ * 历史记录操作
965
+ * 返回上一步
966
+ */
967
+ LogicFlow.prototype.undo = function () {
968
+ if (!this.history.undoAble())
969
+ return;
970
+ // formatData兼容vue数据
971
+ var graphData = formatData(this.history.undo());
972
+ this.clearSelectElements();
973
+ this.graphModel.graphDataToModel(graphData);
974
+ };
975
+ /**
976
+ * 历史记录操作
977
+ * 恢复下一步
978
+ */
979
+ LogicFlow.prototype.redo = function () {
980
+ if (!this.history.redoAble())
981
+ return;
982
+ // formatData兼容vue数据
983
+ var graphData = formatData(this.history.redo());
984
+ this.clearSelectElements();
985
+ this.graphModel.graphDataToModel(graphData);
986
+ };
987
+ /**
988
+ * 放大缩小图形
989
+ * @param zoomSize 放大缩小的值,支持传入0-n之间的数字。小于1表示缩小,大于1表示放大。也支持传入true和false按照内置的刻度放大缩小
990
+ * @param point 缩放的原点
991
+ * @returns {string} -放大缩小的比例
992
+ */
993
+ LogicFlow.prototype.zoom = function (zoomSize, point) {
994
+ var transformModel = this.graphModel.transformModel;
995
+ return transformModel.zoom(zoomSize, point);
996
+ };
997
+ /**
998
+ * 重置图形的放大缩写比例为默认
999
+ */
1000
+ LogicFlow.prototype.resetZoom = function () {
1001
+ var transformModel = this.graphModel.transformModel;
1002
+ transformModel.resetZoom();
1003
+ };
1004
+ /**
1005
+ * 设置图形缩小时,能缩放到的最小倍数。参数为0-1自己。默认0.2
1006
+ * @param size 图形缩小的最小值
1007
+ */
1008
+ LogicFlow.prototype.setZoomMiniSize = function (size) {
1009
+ var transformModel = this.graphModel.transformModel;
1010
+ transformModel.setZoomMiniSize(size);
1011
+ };
1012
+ /**
1013
+ * 设置图形放大时,能放大到的最大倍数,默认16
1014
+ * @param size 图形放大的最大值
1015
+ */
1016
+ LogicFlow.prototype.setZoomMaxSize = function (size) {
1017
+ var transformModel = this.graphModel.transformModel;
1018
+ transformModel.setZoomMaxSize(size);
1019
+ };
1020
+ /**
1021
+ * 获取缩放的值和平移的值。
1022
+ */
1023
+ LogicFlow.prototype.getTransform = function () {
1024
+ var _a = this.graphModel.transformModel, SCALE_X = _a.SCALE_X, SCALE_Y = _a.SCALE_Y, TRANSLATE_X = _a.TRANSLATE_X, TRANSLATE_Y = _a.TRANSLATE_Y;
1025
+ return {
1026
+ SCALE_X: SCALE_X,
1027
+ SCALE_Y: SCALE_Y,
1028
+ TRANSLATE_X: TRANSLATE_X,
1029
+ TRANSLATE_Y: TRANSLATE_Y,
1030
+ };
1031
+ };
1032
+ /**
1033
+ * 平移图
1034
+ * @param x 向x轴移动距离
1035
+ * @param y 向y轴移动距离
1036
+ */
1037
+ LogicFlow.prototype.translate = function (x, y) {
1038
+ var transformModel = this.graphModel.transformModel;
1039
+ transformModel.translate(x, y);
1040
+ };
1041
+ /**
1042
+ * 还原图形为初始位置
1043
+ */
1044
+ LogicFlow.prototype.resetTranslate = function () {
1045
+ var transformModel = this.graphModel.transformModel;
1046
+ var TRANSLATE_X = transformModel.TRANSLATE_X, TRANSLATE_Y = transformModel.TRANSLATE_Y;
1047
+ this.translate(-TRANSLATE_X, -TRANSLATE_Y);
1048
+ };
1049
+ /**
1050
+ * 图形画布居中显示
1051
+ */
1052
+ LogicFlow.prototype.translateCenter = function () {
1053
+ this.graphModel.translateCenter();
1054
+ };
1055
+ /**
1056
+ * 图形适应屏幕大小
1057
+ * @param verticalOffset number 距离盒子上下的距离, 默认为20
1058
+ * @param horizontalOffset number 距离盒子左右的距离, 默认为20
1059
+ */
1060
+ LogicFlow.prototype.fitView = function (verticalOffset, horizontalOffset) {
1061
+ if (horizontalOffset === undefined) {
1062
+ horizontalOffset = verticalOffset; // 兼容以前的只传一个参数的情况
1063
+ }
1064
+ this.graphModel.fitView(verticalOffset, horizontalOffset);
1065
+ };
1066
+ /**
1067
+ * 开启边的动画
1068
+ * @param edgeId string
1069
+ */
1070
+ LogicFlow.prototype.openEdgeAnimation = function (edgeId) {
1071
+ this.graphModel.openEdgeAnimation(edgeId);
1072
+ };
1073
+ /**
1074
+ * 关闭边的动画
1075
+ * @param edgeId string
1076
+ */
1077
+ LogicFlow.prototype.closeEdgeAnimation = function (edgeId) {
1078
+ this.graphModel.closeEdgeAnimation(edgeId);
1079
+ };
1080
+ LogicFlow.prototype.on = function (evt, callback) {
1081
+ this.graphModel.eventCenter.on(evt, callback);
1082
+ };
1083
+ LogicFlow.prototype.off = function (evt, callback) {
1084
+ this.graphModel.eventCenter.off(evt, callback);
1085
+ };
1086
+ LogicFlow.prototype.once = function (evt, callback) {
1087
+ this.graphModel.eventCenter.once(evt, callback);
1088
+ };
1089
+ LogicFlow.prototype.emit = function (evt, arg) {
1090
+ this.graphModel.eventCenter.emit(evt, arg);
1091
+ };
1092
+ /*********************************************************
1093
+ * 插件系统方法
1094
+ ********************************************************/
1095
+ /**
1096
+ * 添加扩展, 待讨论,这里是不是静态方法好一些?
1097
+ * 重复添加插件的时候,把上一次添加的插件的销毁。
1098
+ * @param extension
1099
+ * @param props
1100
+ */
1101
+ LogicFlow.use = function (extension, props) {
1102
+ var _a;
1103
+ var pluginName = extension.pluginName;
1104
+ if (!pluginName) {
1105
+ console.warn("\u8BF7\u7ED9\u63D2\u4EF6".concat(extension.name || extension.constructor.name, "\u6307\u5B9ApluginName!"));
1106
+ pluginName = extension.name; // 兼容以前name的情况,1.0版本去掉。
1107
+ }
1108
+ // TODO: 应该在何时进行插件的销毁
1109
+ // const preExtension = this.extensions.get(pluginName)?.extension
1110
+ // preExtension?.destroy?.() // 该代码应该有问题,因为 preExtension 直接用的是 Constructor,没有实例化。无法访问实例方法 destroy
1111
+ this.extensions.set(pluginName, (_a = {},
1112
+ _a[pluginFlag] = pluginFlag,
1113
+ _a.extension = extension,
1114
+ _a.props = props,
1115
+ _a));
1116
+ };
1117
+ LogicFlow.prototype.installPlugins = function (disabledPlugins) {
1118
+ var _this = this;
1119
+ var _a;
1120
+ if (disabledPlugins === void 0) { disabledPlugins = []; }
1121
+ // 安装插件,优先使用个性插件
1122
+ var extensions = (_a = this.plugins) !== null && _a !== void 0 ? _a : LogicFlow.extensions;
1123
+ extensions.forEach(function (ext) {
1124
+ var extension;
1125
+ var props = null;
1126
+ if (ext[pluginFlag]) {
1127
+ extension = ext.extension;
1128
+ props = ext.props;
1129
+ }
1130
+ else {
1131
+ extension = ext;
1132
+ }
1133
+ var pluginName = (extension === null || extension === void 0 ? void 0 : extension.pluginName) || (extension === null || extension === void 0 ? void 0 : extension.name);
1134
+ if (disabledPlugins.indexOf(pluginName) === -1) {
1135
+ _this.installPlugin(extension, props);
1136
+ }
1137
+ });
1138
+ };
1139
+ /**
1140
+ * 加载插件-内部方法
1141
+ */
1142
+ LogicFlow.prototype.installPlugin = function (extension, props) {
1143
+ var _a;
1144
+ if (typeof extension === 'object') {
1145
+ var pluginName = extension.pluginName, install = extension.install, renderComponent = extension.render;
1146
+ if (pluginName) {
1147
+ install && install.call(extension, this, LogicFlow);
1148
+ renderComponent && this.components.push(renderComponent.bind(extension));
1149
+ this.extension[pluginName] = extension;
1150
+ }
1151
+ return;
1152
+ }
1153
+ var ExtensionCls = extension;
1154
+ var extensionInstance = new ExtensionCls({
1155
+ lf: this,
1156
+ LogicFlow: LogicFlow,
1157
+ options: (_a = this.options.pluginsOptions) !== null && _a !== void 0 ? _a : {},
1158
+ props: props,
1159
+ });
1160
+ extensionInstance.render &&
1161
+ this.components.push(extensionInstance.render.bind(extensionInstance));
1162
+ this.extension[ExtensionCls.pluginName] = extensionInstance;
1163
+ };
1164
+ // 全局配置的插件,所有的LogicFlow示例都会使用
1165
+ LogicFlow.extensions = new Map();
1166
+ return LogicFlow;
1167
+ }());
1168
+ export { LogicFlow };
1169
+ // toStringTag
1170
+ (function (LogicFlow) {
1171
+ LogicFlow.toStringTag = "LF.".concat(LogicFlow.name);
1172
+ })(LogicFlow || (LogicFlow = {}));
1173
+ export default LogicFlow;
1174
+ //# sourceMappingURL=LogicFlow.js.map