@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,112 @@
1
+ import { debounce, isEqual, last, cloneDeep } from 'lodash-es'
2
+ import { deepObserve, IDisposer } from 'mobx-utils'
3
+ import LogicFlow from '..'
4
+ import { GraphModel } from '../model'
5
+ import { EventType } from '../constant'
6
+ import EventEmitter from '../event/eventEmitter'
7
+
8
+ import GraphData = LogicFlow.GraphData
9
+
10
+ export class History {
11
+ undos: GraphData[] = []
12
+ redos: GraphData[] = []
13
+ callbacks = []
14
+ stopWatch: IDisposer | null = null
15
+ curData: GraphData | null = null
16
+ maxSize = 50
17
+ // 发生数据变化后,最多再等500ms,把距离上次的数据变更存储起来。
18
+ // 所以waitTime值越小,History对数据变化越敏感,存的undos就越细。
19
+ waitTime = 100
20
+ eventCenter: EventEmitter
21
+
22
+ constructor(eventCenter: EventEmitter) {
23
+ this.eventCenter = eventCenter
24
+ }
25
+
26
+ add(data: GraphData) {
27
+ if (isEqual(last(this.undos), data)) return
28
+ this.undos.push(data)
29
+ // 因为undo的时候,会触发add.
30
+ // 所以需要区分这个add是undo触发的,还是用户正常操作触发的。
31
+ // 如果是用户正常操作触发的,需要清空redos
32
+ if (!isEqual(this.curData, data)) {
33
+ this.redos = []
34
+ }
35
+ this.eventCenter.emit(EventType.HISTORY_CHANGE, {
36
+ data: {
37
+ undos: this.undos,
38
+ redos: this.redos,
39
+ undoAble: this.undoAble(),
40
+ redoAble: this.redoAble(),
41
+ },
42
+ })
43
+ if (this.undos.length > this.maxSize) {
44
+ this.undos.shift()
45
+ }
46
+ }
47
+
48
+ undoAble() {
49
+ // undos栈顶就是当前图渲染出来的数据。
50
+ return this.undos.length > 1
51
+ }
52
+
53
+ // 1) undo方法触发
54
+ // 2) graphModel重新渲染nodes和edges
55
+ // 3) graphModel发生变化,触发watch
56
+ // 4) watch触发add
57
+ undo() {
58
+ if (!this.undoAble()) return
59
+ const preData = this.undos.pop()!
60
+ this.redos.push(preData)
61
+ const curData = this.undos.pop()!
62
+ this.curData = cloneDeep(curData)
63
+ return curData
64
+ }
65
+
66
+ redoAble() {
67
+ return this.redos.length > 0
68
+ }
69
+
70
+ redo() {
71
+ if (!this.redoAble()) return
72
+ const curData = this.redos.pop()!
73
+ this.curData = cloneDeep(curData)
74
+ return curData
75
+ }
76
+
77
+ watch(model: GraphModel) {
78
+ this.stopWatch && this.stopWatch()
79
+
80
+ // 把当前watch的model转换一下数据存起来,无需清空redos。
81
+ this.undos.push(model.modelToGraphData())
82
+
83
+ this.stopWatch = deepObserve(
84
+ // TODO:避免用户触发「The same observable object cannot appear twice in the same tree」 错误
85
+ // 例如:在自定义节点的 setAttributes 方法中,将 nodeModel 属性赋值给另一个 observable 属性
86
+ // eg:
87
+ // setAttributes() {
88
+ // this.width = 120
89
+ // this.height = 50
90
+ //
91
+ // if (this.text) {
92
+ // this.properties.text = this.text;
93
+ // this.text.value = '';
94
+ // }
95
+ // }
96
+ // 解决方案:使用 cloneDeep 方法,将 observable 对象克隆一份。需要测试下面操作是否会造成其它问题
97
+ // https://stackoverflow.com/questions/55328504/a-node-cannot-exists-twice-in-the-state-tree-mobx-state-tree
98
+ // cloneDeep(model),
99
+ model,
100
+ debounce(() => {
101
+ // 数据变更后,把最新的当前model数据存起来,并清空 redos。
102
+ // 因为这个回调函数的触发,一般是用户交互而引起的,所以按正常逻辑需要清空 redos。
103
+ const data = model.modelToHistoryData()
104
+ if (data) {
105
+ this.add({ ...data })
106
+ }
107
+ }, this.waitTime),
108
+ )
109
+ }
110
+ }
111
+
112
+ export default History
package/src/index.less ADDED
@@ -0,0 +1 @@
1
+ @import url('./style/index');
package/src/index.ts ADDED
@@ -0,0 +1,21 @@
1
+ import { observer as mobxObserver } from 'mobx-preact'
2
+ import { createElement as h, createRef, Component } from 'preact/compat'
3
+ import LogicFlow from './LogicFlow'
4
+
5
+ import * as LogicFlowUtil from './util'
6
+
7
+ export function observer<P>(props: P) {
8
+ return mobxObserver(props as any)
9
+ }
10
+
11
+ export { LogicFlow, h, createRef, Component, LogicFlowUtil }
12
+
13
+ export * from './view'
14
+ export * from './model'
15
+ export * from './options'
16
+ export * from './keyboard'
17
+ export { ElementState, ModelType, ElementType, EventType } from './constant'
18
+
19
+ export { formateAnchorConnectValidateData } from './util/node'
20
+
21
+ export default LogicFlow
@@ -0,0 +1,106 @@
1
+ import { isArray } from 'lodash-es'
2
+ import Mousetrap, { MousetrapInstance } from 'mousetrap'
3
+ import LogicFlow from '../LogicFlow'
4
+
5
+ export type Action = 'keypress' | 'keydown' | 'keyup'
6
+ export type Handler = (e: KeyboardEvent) => void
7
+
8
+ export interface KeyboardDef {
9
+ enabled: boolean
10
+ shortcuts?: Array<{
11
+ keys: string | string[]
12
+ callback: Handler
13
+ action?: Action
14
+ }>
15
+ }
16
+
17
+ export interface KeyboardOptions {
18
+ lf: LogicFlow
19
+ keyboard?: KeyboardDef
20
+ }
21
+
22
+ export class Keyboard {
23
+ public readonly mousetrap: MousetrapInstance
24
+ public options: KeyboardOptions
25
+ private readonly target: HTMLElement
26
+
27
+ constructor(options: KeyboardOptions) {
28
+ if (!options.keyboard) {
29
+ options.keyboard = { enabled: false }
30
+ }
31
+ this.options = options
32
+ const { lf } = options
33
+ this.target = lf.container
34
+ this.mousetrap = new Mousetrap(this.target)
35
+ // 默认开启快捷键,且不是静默模式时enable
36
+ if (options.keyboard.enabled && !lf.options.isSilentMode) {
37
+ this.enable(true)
38
+ }
39
+ }
40
+
41
+ initShortcuts() {
42
+ const { shortcuts } = this.options.keyboard ?? {}
43
+ if (shortcuts) {
44
+ if (isArray(shortcuts)) {
45
+ shortcuts.forEach(({ keys, callback, action }) =>
46
+ this.on(keys, callback, action),
47
+ )
48
+ } else {
49
+ const { keys, callback, action } = shortcuts
50
+ this.on(keys, callback, action)
51
+ }
52
+ }
53
+ }
54
+
55
+ on(keys: string | string[], callback: Handler, action?: Action) {
56
+ this.mousetrap.bind(this.getKeys(keys), callback, action)
57
+ }
58
+
59
+ get disabled() {
60
+ return this.options?.keyboard?.enabled !== true
61
+ }
62
+
63
+ off(keys: string | string[], action?: Action) {
64
+ this.mousetrap.unbind(this.getKeys(keys), action)
65
+ }
66
+
67
+ enable(force: boolean) {
68
+ if (this.disabled || force) {
69
+ if (this.options.keyboard) {
70
+ this.options.keyboard.enabled = true
71
+ }
72
+ if (this.target instanceof HTMLElement) {
73
+ this.target.setAttribute('tabindex', '-1')
74
+ // 去掉节点被选中时container出现的边框
75
+ this.target.style.outline = 'none'
76
+ }
77
+ }
78
+ }
79
+
80
+ disable() {
81
+ if (!this.disabled) {
82
+ if (this.options.keyboard) {
83
+ this.options.keyboard.enabled = false
84
+ }
85
+ if (this.target instanceof HTMLElement) {
86
+ this.target.removeAttribute('tabindex')
87
+ }
88
+ }
89
+ }
90
+
91
+ private getKeys(keys: string | string[]) {
92
+ return (Array.isArray(keys) ? keys : [keys]).map((key) =>
93
+ this.formatKey(key),
94
+ )
95
+ }
96
+
97
+ protected formatKey(key: string) {
98
+ return key
99
+ .toLowerCase()
100
+ .replace(/\s/g, '')
101
+ .replace('delete', 'del')
102
+ .replace('cmd', 'command')
103
+ }
104
+ }
105
+
106
+ export default Keyboard
@@ -0,0 +1,123 @@
1
+ import LogicFlow from '../LogicFlow'
2
+ import GraphModel from '../model/GraphModel'
3
+
4
+ import NodeData = LogicFlow.NodeData
5
+ import EdgeData = LogicFlow.EdgeData
6
+
7
+ let selected: LogicFlow.GraphData | null = null
8
+
9
+ function translationNodeData(nodeData: NodeData, distance: number) {
10
+ nodeData.x += distance
11
+ nodeData.y += distance
12
+ if (nodeData.text) {
13
+ nodeData.text.x += distance
14
+ nodeData.text.y += distance
15
+ }
16
+ return nodeData
17
+ }
18
+
19
+ function translationEdgeData(edgeData: EdgeData, distance: number) {
20
+ if (edgeData.startPoint) {
21
+ edgeData.startPoint.x += distance
22
+ edgeData.startPoint.y += distance
23
+ }
24
+ if (edgeData.endPoint) {
25
+ edgeData.endPoint.x += distance
26
+ edgeData.endPoint.y += distance
27
+ }
28
+ if (edgeData.pointsList && edgeData.pointsList.length > 0) {
29
+ edgeData.pointsList.forEach((point) => {
30
+ point.x += distance
31
+ point.y += distance
32
+ })
33
+ }
34
+ if (edgeData.text) {
35
+ edgeData.text.x += distance
36
+ edgeData.text.y += distance
37
+ }
38
+ return edgeData
39
+ }
40
+
41
+ const TRANSLATION_DISTANCE = 40
42
+ let CHILDREN_TRANSLATION_DISTANCE = 40
43
+
44
+ export function initDefaultShortcut(lf: LogicFlow, graph: GraphModel) {
45
+ const { keyboard } = lf
46
+ const {
47
+ options: { keyboard: keyboardOptions },
48
+ } = keyboard
49
+
50
+ // 复制
51
+ keyboard.on(['cmd + c', 'ctrl + c'], () => {
52
+ CHILDREN_TRANSLATION_DISTANCE = TRANSLATION_DISTANCE
53
+ if (!keyboardOptions?.enabled) return true
54
+ if (graph.textEditElement) return true
55
+ const { guards } = lf.options
56
+ const elements = graph.getSelectElements(false)
57
+ const enabledClone =
58
+ guards && guards.beforeClone ? guards.beforeClone(elements) : true
59
+ if (
60
+ !enabledClone ||
61
+ (elements.nodes.length === 0 && elements.edges.length === 0)
62
+ ) {
63
+ selected = null
64
+ return true
65
+ }
66
+ selected = elements
67
+ selected.nodes.forEach((node) =>
68
+ translationNodeData(node, TRANSLATION_DISTANCE),
69
+ )
70
+ selected.edges.forEach((edge) =>
71
+ translationEdgeData(edge, TRANSLATION_DISTANCE),
72
+ )
73
+ return false
74
+ })
75
+ // 粘贴
76
+ keyboard.on(['cmd + v', 'ctrl + v'], () => {
77
+ if (!keyboardOptions?.enabled) return true
78
+ if (graph.textEditElement) return true
79
+ if (selected && (selected.nodes || selected.edges)) {
80
+ lf.clearSelectElements()
81
+ const addElements = lf.addElements(
82
+ selected,
83
+ CHILDREN_TRANSLATION_DISTANCE,
84
+ )
85
+ if (!addElements) return true
86
+ addElements.nodes.forEach((node) => lf.selectElementById(node.id, true))
87
+ addElements.edges.forEach((edge) => lf.selectElementById(edge.id, true))
88
+ selected.nodes.forEach((node) =>
89
+ translationNodeData(node, TRANSLATION_DISTANCE),
90
+ )
91
+ selected.edges.forEach((edge) =>
92
+ translationEdgeData(edge, TRANSLATION_DISTANCE),
93
+ )
94
+ CHILDREN_TRANSLATION_DISTANCE =
95
+ CHILDREN_TRANSLATION_DISTANCE + TRANSLATION_DISTANCE
96
+ }
97
+ return false
98
+ })
99
+ // undo
100
+ keyboard.on(['cmd + z', 'ctrl + z'], () => {
101
+ if (!keyboardOptions?.enabled) return true
102
+ if (graph.textEditElement) return true
103
+ lf.undo()
104
+ return false
105
+ })
106
+ // redo
107
+ keyboard.on(['cmd + y', 'ctrl + y'], () => {
108
+ if (!keyboardOptions?.enabled) return true
109
+ if (graph.textEditElement) return true
110
+ lf.redo()
111
+ return false
112
+ })
113
+ // delete
114
+ keyboard.on(['backspace'], () => {
115
+ if (!keyboardOptions?.enabled) return true
116
+ if (graph.textEditElement) return true
117
+ const elements = graph.getSelectElements(true)
118
+ lf.clearSelectElements()
119
+ elements.edges.forEach((edge) => edge.id && lf.deleteEdge(edge.id))
120
+ elements.nodes.forEach((node) => node.id && lf.deleteNode(node.id))
121
+ return false
122
+ })
123
+ }
@@ -0,0 +1,223 @@
1
+ import GraphModel from './GraphModel'
2
+ import { BaseNodeModel } from './node'
3
+ import LogicFlow from '../LogicFlow'
4
+ import { ElementState } from '../constant'
5
+
6
+ export namespace Model {
7
+ export type AdditionStateDataType = Record<string, unknown>
8
+ export type PropertyType = Record<string, unknown>
9
+ export type VectorType = [number, number]
10
+ export type IsAllowMove = {
11
+ x: boolean
12
+ y: boolean
13
+ }
14
+
15
+ export type AnchorConfig = {
16
+ id?: string
17
+ x: number
18
+ y: number
19
+ [key: string]: unknown
20
+ }
21
+ export type AnchorInfo = {
22
+ index: number
23
+ anchor: AnchorConfig
24
+ }
25
+
26
+ export type ConnectRule = {
27
+ message: string
28
+ validate: (
29
+ source?: BaseNodeModel,
30
+ target?: BaseNodeModel,
31
+ sourceAnchor?: AnchorConfig,
32
+ targetAnchor?: AnchorConfig,
33
+ /**
34
+ * REMIND: 调整的边的 id
35
+ * 在开启 adjustEdgeStartAndEnd 后调整边连接的节点时会传入
36
+ * 详见:https://github.com/didi/LogicFlow/issues/926#issuecomment-1371823306
37
+ */
38
+ edgeID?: string,
39
+ ) => boolean | undefined
40
+ }
41
+ export type ConnectRuleResult = {
42
+ isAllPass: boolean
43
+ msg?: string
44
+ }
45
+
46
+ /**
47
+ * 限制节点移动规则
48
+ * model: 移动节点的 model
49
+ * deltaX: 移动的 X 轴距离
50
+ * deltaY: 移动的 Y 轴距离
51
+ */
52
+ export type NodeMoveRule = (
53
+ model: BaseNodeModel,
54
+ deltaX: number,
55
+ deltaY: number,
56
+ ) => boolean | IsAllowMove
57
+
58
+ export type AdjustEdgeStartAndEndParams = {
59
+ startPoint: LogicFlow.Point
60
+ endPoint: LogicFlow.Point
61
+ sourceNode?: BaseNodeModel
62
+ targetNode?: BaseNodeModel
63
+ }
64
+
65
+ // 定义边界数据结构,左上坐标 + 右下坐标定位一个矩形
66
+ export type BoxBoundsPoint = {
67
+ x1: number // Left Top X
68
+ y1: number // Left Top Y
69
+ x2: number // Right Bottom X
70
+ y2: number // Right Bottom Y
71
+ }
72
+
73
+ export type OutlineInfo = {
74
+ x: number
75
+ y: number
76
+ x1: number
77
+ y1: number
78
+ }
79
+
80
+ export interface BoxBounds {
81
+ x: number
82
+ y: number
83
+ width: number
84
+ height: number
85
+ minX: number
86
+ minY: number
87
+ maxX: number
88
+ maxY: number
89
+ centerX: number
90
+ centerY: number
91
+ }
92
+
93
+ export interface BaseModel {
94
+ /**
95
+ * 节点或边对应的 ID.
96
+ *
97
+ * 默认情况下,使用 uuidV4 生成。如需自定义,可通过传入 createId 方法覆盖。
98
+ */
99
+ id: string
100
+
101
+ /**
102
+ * model 对应的图形外观类型 (eg: 圆形、矩形、多边形等)
103
+ *
104
+ * 不可自定义,用于 LogicFlow 内部计算使用
105
+ */
106
+ readonly modelType: string
107
+
108
+ /**
109
+ * 请勿直接修改属性,如果想要将一个节点类型修改为另一个类型。(直接禁止修改不就可以了 public readonly)
110
+ * `lf.graphModel.changeEdgeType` or `lf.graphModel.changeNodeType`
111
+ *
112
+ * 流程图元素类型,自定义元素时对应的标识
113
+ * 在 logicflow/core 中对应着 rect/circle/polyline 这种
114
+ * 在实际项目中,我们会基于业务类型进行自定义 type.
115
+ * 例如 BPMN 场景中,我们会定义开始节点的类型为 bpmn:start-event
116
+ *
117
+ * 与 modelType 的区别是,type 更多的是业务上的类型,而 modelType 则是外观上的类型。
118
+ * 例如 bpmn.js 的开始节点和结束节点 type 分别为 'bpmn:start-event' 和 'bpmn:end-event'。
119
+ * 但是他们的 modelType 都是 circle-node,因为他们的外观都是基于圆形自定义而来。
120
+ */
121
+ readonly type: string
122
+ graphModel: GraphModel
123
+
124
+ /**
125
+ * 状态附加数据,例如显示菜单,菜单的位置信息
126
+ * @deprecated: 请勿使用,即将废弃
127
+ */
128
+ additionStateData?: AdditionStateDataType
129
+
130
+ /**
131
+ * Rule 相关配置,包括连入、连出、移动等
132
+ */
133
+ targetRules?: ConnectRule[]
134
+ sourceRules?: ConnectRule[]
135
+ moveRules?: NodeMoveRule[]
136
+ hasSetTargetRules?: boolean
137
+ hasSetSourceRules?: boolean
138
+
139
+ /**
140
+ * 元素上的文本
141
+ *
142
+ * LogicFlow 中存在梁总文本:1. 脱离边和节点单独存在的问题;2. 必须和边、节点关联的文本
143
+ * 此属性控制的是第二种。节点和边在删除、调整的同时,其关联的文本也会对应删除、调整。
144
+ */
145
+ text: LogicFlow.TextConfig
146
+ properties: Record<string, unknown>
147
+
148
+ isSelected: boolean // 元素是否被选中
149
+ isHovered: boolean // 鼠标是否悬停在元素上
150
+ // TODO: 确认拼写 fix typo(兼容拼写错误的情况)
151
+ isHitable: boolean // TODO: 错误拼写,兼容拼写错误的情况 REMIND TO REMOVE
152
+ isHittable: boolean // 细粒度控制节点是否对用户操作进行反应
153
+ draggable: boolean // 是否可拖拽
154
+ visible: boolean // 元素是否显示
155
+ virtual: boolean // 元素是否可以通过 getGraphData 获取到
156
+
157
+ /**
158
+ * 元素堆叠的层级,默认情况下节点 zIndex 值为 1,边 zIndex 为 0
159
+ */
160
+ zIndex: number
161
+
162
+ /**
163
+ * 元素状态: 不同状态不应不同元素的显示效果(无法直接修改)
164
+ */
165
+ readonly state: ElementState
166
+
167
+ /**
168
+ * 创建节点 ID
169
+ *
170
+ * 默认情况下,LogicFlow 内部使用 uuidV4 生成 id。在自定义节点的时候,可以重写此方法,
171
+ * 基于自己的规则生成 id。
172
+ * 注意 📢:此方法必须是同步方法,如果想要异步修改 ID,建议删除此节点后在同一位置创建一个新的节点
173
+ * @overridable 可被重写
174
+ * @returns string
175
+ */
176
+ createId: () => string | null
177
+
178
+ // Actions
179
+ isAllowMoveNode?: (deltaX: number, deltaY: number) => boolean | IsAllowMove
180
+ moveText: (deltaX: number, deltaY: number) => void
181
+ moveTo?: (x: number, y: number, isIgnoreRule: boolean) => boolean
182
+ getMoveDistance?: (
183
+ deltaX: number,
184
+ deltaY: number,
185
+ isIgnoreRule: boolean,
186
+ ) => VectorType
187
+ move?: (x: number, y: number, isIgnoreRule: boolean) => boolean
188
+ updateText: (text: string) => void
189
+
190
+ setSelected: (isSelected: boolean) => void
191
+ setHovered: (isHovered: boolean) => void
192
+ setHitable: (isHittable: boolean) => void // TODO: 拼写错误 fix typo(兼容拼写错误的情况)
193
+ setHittable: (isHittable: boolean) => void
194
+
195
+ setZIndex: (zIndex?: number) => void
196
+ updateAttributes: (attributes: LogicFlow.AttributesType) => void
197
+ /**
198
+ * 设置 Node | Edge 等 model 的状态
199
+ * @param state 状态
200
+ * @param additionStateData 额外的参数
201
+ */
202
+ setElementState: (
203
+ state: ElementState,
204
+ additionStateData?: AdditionStateDataType,
205
+ ) => void
206
+
207
+ getData: () => Record<string, unknown>
208
+ getProperties: () => PropertyType
209
+ setProperty: (key: string, val: unknown) => void
210
+ setProperties: (properties: PropertyType) => void
211
+ deleteProperty: (key: string) => void
212
+
213
+ getNodeStyle?: () => LogicFlow.CommonTheme
214
+ getEdgeStyle?: () => LogicFlow.EdgeTheme
215
+ getTextStyle: () => LogicFlow.TextNodeTheme
216
+ getAnchorStyle?: () => LogicFlow.AnchorTheme
217
+ getAnchorLineStyle?: () => LogicFlow.AnchorLineTheme
218
+ getOutlineStyle: () => LogicFlow.OutlineTheme
219
+ setStyle: (key: string, val: LogicFlow.CommonThemePropTypes) => void
220
+ setStyles: (styles: LogicFlow.CommonTheme) => void
221
+ updateStyles: (styles: LogicFlow.CommonTheme) => void
222
+ }
223
+ }