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