@logicflow/core 2.0.0-beta.0 → 2.0.0-beta.10

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 (479) hide show
  1. package/.turbo/turbo-build$colon$dev.log +2 -2
  2. package/.turbo/turbo-build.log +16 -22
  3. package/__tests__/bugs/1545-spec.test.ts +19 -15
  4. package/__tests__/util/edge.test.ts +57 -57
  5. package/dist/index.min.js +32 -0
  6. package/dist/index.min.js.map +1 -0
  7. package/es/LogicFlow.d.ts +88 -40
  8. package/es/LogicFlow.js +38 -33
  9. package/es/LogicFlow.js.map +1 -1
  10. package/es/algorithm/edge.js.map +1 -1
  11. package/es/algorithm/index.d.ts +2 -0
  12. package/es/algorithm/index.js +2 -0
  13. package/es/algorithm/index.js.map +1 -1
  14. package/es/algorithm/outline.d.ts +1 -1
  15. package/es/common/drag.d.ts +51 -0
  16. package/es/common/drag.js +145 -0
  17. package/es/common/drag.js.map +1 -0
  18. package/es/common/history.d.ts +28 -0
  19. package/es/common/history.js +92 -0
  20. package/es/common/history.js.map +1 -0
  21. package/es/common/index.d.ts +5 -0
  22. package/es/common/index.js +6 -0
  23. package/es/common/index.js.map +1 -0
  24. package/es/common/keyboard.d.ts +34 -0
  25. package/es/common/keyboard.js +80 -0
  26. package/es/common/keyboard.js.map +1 -0
  27. package/es/common/matrix.d.ts +30 -0
  28. package/es/common/matrix.js +155 -0
  29. package/es/common/matrix.js.map +1 -0
  30. package/es/common/vector.d.ts +23 -0
  31. package/es/common/vector.js +97 -0
  32. package/es/common/vector.js.map +1 -0
  33. package/es/constant/index.d.ts +39 -2
  34. package/es/constant/index.js +41 -1
  35. package/es/constant/index.js.map +1 -1
  36. package/es/event/eventArgs.d.ts +103 -25
  37. package/es/event/eventEmitter.d.ts +2 -2
  38. package/es/event/eventEmitter.js +0 -1
  39. package/es/event/eventEmitter.js.map +1 -1
  40. package/es/index.d.ts +6 -1
  41. package/es/index.js +6 -1
  42. package/es/index.js.map +1 -1
  43. package/es/keyboard/index.d.ts +1 -0
  44. package/es/keyboard/index.js +1 -0
  45. package/es/keyboard/index.js.map +1 -1
  46. package/es/keyboard/shortcut.d.ts +8 -0
  47. package/es/keyboard/shortcut.js +70 -8
  48. package/es/keyboard/shortcut.js.map +1 -1
  49. package/es/model/BaseModel.d.ts +16 -7
  50. package/es/model/EditConfigModel.d.ts +97 -36
  51. package/es/model/EditConfigModel.js +169 -82
  52. package/es/model/EditConfigModel.js.map +1 -1
  53. package/es/model/GraphModel.d.ts +36 -14
  54. package/es/model/GraphModel.js +60 -10
  55. package/es/model/GraphModel.js.map +1 -1
  56. package/es/model/SnaplineModel.d.ts +2 -0
  57. package/es/model/TransformModel.js +1 -1
  58. package/es/model/TransformModel.js.map +1 -1
  59. package/es/model/edge/BaseEdgeModel.d.ts +21 -17
  60. package/es/model/edge/BaseEdgeModel.js +64 -42
  61. package/es/model/edge/BaseEdgeModel.js.map +1 -1
  62. package/es/model/edge/BezierEdgeModel.d.ts +5 -3
  63. package/es/model/edge/BezierEdgeModel.js +7 -3
  64. package/es/model/edge/BezierEdgeModel.js.map +1 -1
  65. package/es/model/edge/LineEdgeModel.d.ts +2 -0
  66. package/es/model/edge/LineEdgeModel.js +2 -1
  67. package/es/model/edge/LineEdgeModel.js.map +1 -1
  68. package/es/model/edge/PolylineEdgeModel.d.ts +5 -3
  69. package/es/model/edge/PolylineEdgeModel.js +22 -15
  70. package/es/model/edge/PolylineEdgeModel.js.map +1 -1
  71. package/es/model/node/BaseNodeModel.d.ts +42 -14
  72. package/es/model/node/BaseNodeModel.js +62 -48
  73. package/es/model/node/BaseNodeModel.js.map +1 -1
  74. package/es/model/node/CircleNodeModel.d.ts +4 -3
  75. package/es/model/node/CircleNodeModel.js +4 -7
  76. package/es/model/node/CircleNodeModel.js.map +1 -1
  77. package/es/model/node/DiamondNodeModel.d.ts +5 -4
  78. package/es/model/node/DiamondNodeModel.js +4 -6
  79. package/es/model/node/DiamondNodeModel.js.map +1 -1
  80. package/es/model/node/EllipseNodeModel.d.ts +5 -4
  81. package/es/model/node/EllipseNodeModel.js +4 -6
  82. package/es/model/node/EllipseNodeModel.js.map +1 -1
  83. package/es/model/node/HtmlNodeModel.d.ts +4 -5
  84. package/es/model/node/HtmlNodeModel.js +2 -12
  85. package/es/model/node/HtmlNodeModel.js.map +1 -1
  86. package/es/model/node/PolygonNodeModel.d.ts +5 -4
  87. package/es/model/node/PolygonNodeModel.js +4 -7
  88. package/es/model/node/PolygonNodeModel.js.map +1 -1
  89. package/es/model/node/RectNodeModel.d.ts +7 -5
  90. package/es/model/node/RectNodeModel.js +10 -7
  91. package/es/model/node/RectNodeModel.js.map +1 -1
  92. package/es/model/node/TextNodeModel.d.ts +17 -9
  93. package/es/model/node/TextNodeModel.js +2 -1
  94. package/es/model/node/TextNodeModel.js.map +1 -1
  95. package/es/options.d.ts +11 -14
  96. package/es/options.js +3 -42
  97. package/es/options.js.map +1 -1
  98. package/es/tool/MultipleSelectTool.d.ts +1 -1
  99. package/es/tool/MultipleSelectTool.js +5 -5
  100. package/es/tool/MultipleSelectTool.js.map +1 -1
  101. package/es/tool/TextEditTool.d.ts +3 -3
  102. package/es/tool/TextEditTool.js +2 -2
  103. package/es/tool/TextEditTool.js.map +1 -1
  104. package/es/tool/index.d.ts +24 -2
  105. package/es/tool/index.js +82 -2
  106. package/es/tool/index.js.map +1 -1
  107. package/es/util/drag.d.ts +5 -5
  108. package/es/util/drag.js +3 -1
  109. package/es/util/drag.js.map +1 -1
  110. package/es/util/edge.d.ts +9 -2
  111. package/es/util/edge.js +23 -12
  112. package/es/util/edge.js.map +1 -1
  113. package/es/util/index.d.ts +1 -0
  114. package/es/util/index.js +1 -0
  115. package/es/util/index.js.map +1 -1
  116. package/es/util/node.d.ts +8 -7
  117. package/es/util/node.js +26 -7
  118. package/es/util/node.js.map +1 -1
  119. package/es/util/resize.d.ts +32 -0
  120. package/es/util/resize.js +197 -0
  121. package/es/util/resize.js.map +1 -0
  122. package/es/view/Anchor.d.ts +6 -7
  123. package/es/view/Anchor.js +6 -3
  124. package/es/view/Anchor.js.map +1 -1
  125. package/es/view/Control.d.ts +1 -1
  126. package/es/view/Control.js +88 -39
  127. package/es/view/Control.js.map +1 -1
  128. package/es/view/Graph.d.ts +5 -1
  129. package/es/view/Graph.js +45 -5
  130. package/es/view/Graph.js.map +1 -1
  131. package/es/view/Rotate.js +2 -1
  132. package/es/view/Rotate.js.map +1 -1
  133. package/es/view/behavior/index.d.ts +2 -0
  134. package/es/view/behavior/index.js +3 -0
  135. package/es/view/behavior/index.js.map +1 -0
  136. package/es/view/behavior/snapline.d.ts +3 -0
  137. package/es/{tool → view/behavior}/snapline.js +0 -1
  138. package/es/view/behavior/snapline.js.map +1 -0
  139. package/es/view/edge/AdjustPoint.js +12 -23
  140. package/es/view/edge/AdjustPoint.js.map +1 -1
  141. package/es/view/edge/BaseEdge.d.ts +2 -2
  142. package/es/view/edge/BaseEdge.js +30 -22
  143. package/es/view/edge/BaseEdge.js.map +1 -1
  144. package/es/view/node/BaseNode.d.ts +4 -4
  145. package/es/view/node/BaseNode.js +33 -24
  146. package/es/view/node/BaseNode.js.map +1 -1
  147. package/es/view/node/CircleNode.d.ts +1 -1
  148. package/es/view/node/CircleNode.js.map +1 -1
  149. package/es/view/node/DiamondNode.d.ts +1 -1
  150. package/es/view/node/DiamondNode.js.map +1 -1
  151. package/es/view/node/EllipseNode.d.ts +1 -1
  152. package/es/view/node/EllipseNode.js.map +1 -1
  153. package/es/view/node/HtmlNode.d.ts +1 -1
  154. package/es/view/node/HtmlNode.js +2 -2
  155. package/es/view/node/HtmlNode.js.map +1 -1
  156. package/es/view/node/PolygonNode.d.ts +1 -1
  157. package/es/view/node/PolygonNode.js.map +1 -1
  158. package/es/view/node/RectNode.d.ts +1 -1
  159. package/es/view/node/RectNode.js.map +1 -1
  160. package/es/view/node/TextNode.d.ts +1 -1
  161. package/es/view/node/TextNode.js +1 -1
  162. package/es/view/node/TextNode.js.map +1 -1
  163. package/es/view/overlay/CanvasOverlay.js +5 -4
  164. package/es/view/overlay/CanvasOverlay.js.map +1 -1
  165. package/es/view/overlay/Grid.d.ts +35 -20
  166. package/es/view/overlay/Grid.js +35 -26
  167. package/es/view/overlay/Grid.js.map +1 -1
  168. package/es/view/overlay/ToolOverlay.d.ts +1 -1
  169. package/es/view/overlay/ToolOverlay.js +1 -1
  170. package/es/view/overlay/ToolOverlay.js.map +1 -1
  171. package/es/view/shape/Circle.d.ts +9 -1
  172. package/es/view/shape/Circle.js +5 -5
  173. package/es/view/shape/Circle.js.map +1 -1
  174. package/es/view/shape/Ellipse.d.ts +10 -1
  175. package/es/view/shape/Ellipse.js +5 -5
  176. package/es/view/shape/Ellipse.js.map +1 -1
  177. package/es/view/shape/Line.d.ts +14 -1
  178. package/es/view/shape/Line.js +5 -7
  179. package/es/view/shape/Line.js.map +1 -1
  180. package/es/view/shape/Path.d.ts +3 -2
  181. package/es/view/shape/Path.js +3 -3
  182. package/es/view/shape/Path.js.map +1 -1
  183. package/es/view/shape/Polygon.d.ts +5 -3
  184. package/es/view/shape/Polygon.js +6 -6
  185. package/es/view/shape/Polygon.js.map +1 -1
  186. package/es/view/shape/Polyline.d.ts +7 -1
  187. package/es/view/shape/Polyline.js +8 -6
  188. package/es/view/shape/Polyline.js.map +1 -1
  189. package/es/view/shape/Rect.d.ts +11 -13
  190. package/es/view/shape/Rect.js +6 -9
  191. package/es/view/shape/Rect.js.map +1 -1
  192. package/es/view/shape/Text.d.ts +19 -1
  193. package/es/view/shape/Text.js +28 -21
  194. package/es/view/shape/Text.js.map +1 -1
  195. package/es/view/text/BaseText.d.ts +12 -15
  196. package/es/view/text/BaseText.js +43 -29
  197. package/es/view/text/BaseText.js.map +1 -1
  198. package/es/view/text/LineText.d.ts +19 -7
  199. package/es/view/text/LineText.js +62 -54
  200. package/es/view/text/LineText.js.map +1 -1
  201. package/lib/LogicFlow.d.ts +88 -40
  202. package/lib/LogicFlow.js +40 -35
  203. package/lib/LogicFlow.js.map +1 -1
  204. package/lib/algorithm/edge.js.map +1 -1
  205. package/lib/algorithm/index.d.ts +2 -0
  206. package/lib/algorithm/index.js +17 -1
  207. package/lib/algorithm/index.js.map +1 -1
  208. package/lib/algorithm/outline.d.ts +1 -1
  209. package/lib/common/drag.d.ts +51 -0
  210. package/lib/common/drag.js +148 -0
  211. package/lib/common/drag.js.map +1 -0
  212. package/lib/common/history.d.ts +28 -0
  213. package/lib/common/history.js +95 -0
  214. package/lib/common/history.js.map +1 -0
  215. package/lib/common/index.d.ts +5 -0
  216. package/lib/common/index.js +22 -0
  217. package/lib/common/index.js.map +1 -0
  218. package/lib/common/keyboard.d.ts +34 -0
  219. package/lib/common/keyboard.js +86 -0
  220. package/lib/common/keyboard.js.map +1 -0
  221. package/lib/common/matrix.d.ts +30 -0
  222. package/lib/common/matrix.js +158 -0
  223. package/lib/common/matrix.js.map +1 -0
  224. package/lib/common/vector.d.ts +23 -0
  225. package/lib/common/vector.js +101 -0
  226. package/lib/common/vector.js.map +1 -0
  227. package/lib/constant/index.d.ts +39 -2
  228. package/lib/constant/index.js +42 -2
  229. package/lib/constant/index.js.map +1 -1
  230. package/lib/event/eventArgs.d.ts +103 -25
  231. package/lib/event/eventEmitter.d.ts +2 -2
  232. package/lib/event/eventEmitter.js +0 -1
  233. package/lib/event/eventEmitter.js.map +1 -1
  234. package/lib/index.d.ts +6 -1
  235. package/lib/index.js +7 -2
  236. package/lib/index.js.map +1 -1
  237. package/lib/keyboard/index.d.ts +1 -0
  238. package/lib/keyboard/index.js +15 -0
  239. package/lib/keyboard/index.js.map +1 -1
  240. package/lib/keyboard/shortcut.d.ts +8 -0
  241. package/lib/keyboard/shortcut.js +75 -9
  242. package/lib/keyboard/shortcut.js.map +1 -1
  243. package/lib/model/BaseModel.d.ts +16 -7
  244. package/lib/model/EditConfigModel.d.ts +97 -36
  245. package/lib/model/EditConfigModel.js +168 -81
  246. package/lib/model/EditConfigModel.js.map +1 -1
  247. package/lib/model/GraphModel.d.ts +36 -14
  248. package/lib/model/GraphModel.js +59 -9
  249. package/lib/model/GraphModel.js.map +1 -1
  250. package/lib/model/SnaplineModel.d.ts +2 -0
  251. package/lib/model/TransformModel.js +1 -1
  252. package/lib/model/TransformModel.js.map +1 -1
  253. package/lib/model/edge/BaseEdgeModel.d.ts +21 -17
  254. package/lib/model/edge/BaseEdgeModel.js +61 -39
  255. package/lib/model/edge/BaseEdgeModel.js.map +1 -1
  256. package/lib/model/edge/BezierEdgeModel.d.ts +5 -3
  257. package/lib/model/edge/BezierEdgeModel.js +6 -2
  258. package/lib/model/edge/BezierEdgeModel.js.map +1 -1
  259. package/lib/model/edge/LineEdgeModel.d.ts +2 -0
  260. package/lib/model/edge/LineEdgeModel.js +2 -1
  261. package/lib/model/edge/LineEdgeModel.js.map +1 -1
  262. package/lib/model/edge/PolylineEdgeModel.d.ts +5 -3
  263. package/lib/model/edge/PolylineEdgeModel.js +21 -14
  264. package/lib/model/edge/PolylineEdgeModel.js.map +1 -1
  265. package/lib/model/node/BaseNodeModel.d.ts +42 -14
  266. package/lib/model/node/BaseNodeModel.js +60 -46
  267. package/lib/model/node/BaseNodeModel.js.map +1 -1
  268. package/lib/model/node/CircleNodeModel.d.ts +4 -3
  269. package/lib/model/node/CircleNodeModel.js +4 -7
  270. package/lib/model/node/CircleNodeModel.js.map +1 -1
  271. package/lib/model/node/DiamondNodeModel.d.ts +5 -4
  272. package/lib/model/node/DiamondNodeModel.js +4 -6
  273. package/lib/model/node/DiamondNodeModel.js.map +1 -1
  274. package/lib/model/node/EllipseNodeModel.d.ts +5 -4
  275. package/lib/model/node/EllipseNodeModel.js +4 -6
  276. package/lib/model/node/EllipseNodeModel.js.map +1 -1
  277. package/lib/model/node/HtmlNodeModel.d.ts +4 -5
  278. package/lib/model/node/HtmlNodeModel.js +2 -12
  279. package/lib/model/node/HtmlNodeModel.js.map +1 -1
  280. package/lib/model/node/PolygonNodeModel.d.ts +5 -4
  281. package/lib/model/node/PolygonNodeModel.js +4 -7
  282. package/lib/model/node/PolygonNodeModel.js.map +1 -1
  283. package/lib/model/node/RectNodeModel.d.ts +7 -5
  284. package/lib/model/node/RectNodeModel.js +10 -7
  285. package/lib/model/node/RectNodeModel.js.map +1 -1
  286. package/lib/model/node/TextNodeModel.d.ts +17 -9
  287. package/lib/model/node/TextNodeModel.js +2 -1
  288. package/lib/model/node/TextNodeModel.js.map +1 -1
  289. package/lib/options.d.ts +11 -14
  290. package/lib/options.js +3 -42
  291. package/lib/options.js.map +1 -1
  292. package/lib/tool/MultipleSelectTool.d.ts +1 -1
  293. package/lib/tool/MultipleSelectTool.js +5 -5
  294. package/lib/tool/MultipleSelectTool.js.map +1 -1
  295. package/lib/tool/TextEditTool.d.ts +3 -3
  296. package/lib/tool/TextEditTool.js +4 -4
  297. package/lib/tool/TextEditTool.js.map +1 -1
  298. package/lib/tool/index.d.ts +24 -2
  299. package/lib/tool/index.js +85 -15
  300. package/lib/tool/index.js.map +1 -1
  301. package/lib/util/drag.d.ts +5 -5
  302. package/lib/util/drag.js +3 -1
  303. package/lib/util/drag.js.map +1 -1
  304. package/lib/util/edge.d.ts +9 -2
  305. package/lib/util/edge.js +27 -15
  306. package/lib/util/edge.js.map +1 -1
  307. package/lib/util/index.d.ts +1 -0
  308. package/lib/util/index.js +1 -0
  309. package/lib/util/index.js.map +1 -1
  310. package/lib/util/node.d.ts +8 -7
  311. package/lib/util/node.js +28 -9
  312. package/lib/util/node.js.map +1 -1
  313. package/lib/util/resize.d.ts +32 -0
  314. package/lib/util/resize.js +204 -0
  315. package/lib/util/resize.js.map +1 -0
  316. package/lib/view/Anchor.d.ts +6 -7
  317. package/lib/view/Anchor.js +5 -2
  318. package/lib/view/Anchor.js.map +1 -1
  319. package/lib/view/Control.d.ts +1 -1
  320. package/lib/view/Control.js +87 -38
  321. package/lib/view/Control.js.map +1 -1
  322. package/lib/view/Graph.d.ts +5 -1
  323. package/lib/view/Graph.js +44 -4
  324. package/lib/view/Graph.js.map +1 -1
  325. package/lib/view/Rotate.js +2 -1
  326. package/lib/view/Rotate.js.map +1 -1
  327. package/lib/view/behavior/index.d.ts +2 -0
  328. package/lib/view/behavior/index.js +19 -0
  329. package/lib/view/behavior/index.js.map +1 -0
  330. package/lib/view/behavior/snapline.d.ts +3 -0
  331. package/lib/{tool → view/behavior}/snapline.js +0 -1
  332. package/lib/view/behavior/snapline.js.map +1 -0
  333. package/lib/view/edge/AdjustPoint.js +11 -22
  334. package/lib/view/edge/AdjustPoint.js.map +1 -1
  335. package/lib/view/edge/BaseEdge.d.ts +2 -2
  336. package/lib/view/edge/BaseEdge.js +29 -21
  337. package/lib/view/edge/BaseEdge.js.map +1 -1
  338. package/lib/view/node/BaseNode.d.ts +4 -4
  339. package/lib/view/node/BaseNode.js +32 -23
  340. package/lib/view/node/BaseNode.js.map +1 -1
  341. package/lib/view/node/CircleNode.d.ts +1 -1
  342. package/lib/view/node/CircleNode.js.map +1 -1
  343. package/lib/view/node/DiamondNode.d.ts +1 -1
  344. package/lib/view/node/DiamondNode.js.map +1 -1
  345. package/lib/view/node/EllipseNode.d.ts +1 -1
  346. package/lib/view/node/EllipseNode.js.map +1 -1
  347. package/lib/view/node/HtmlNode.d.ts +1 -1
  348. package/lib/view/node/HtmlNode.js +2 -2
  349. package/lib/view/node/HtmlNode.js.map +1 -1
  350. package/lib/view/node/PolygonNode.d.ts +1 -1
  351. package/lib/view/node/PolygonNode.js.map +1 -1
  352. package/lib/view/node/RectNode.d.ts +1 -1
  353. package/lib/view/node/RectNode.js.map +1 -1
  354. package/lib/view/node/TextNode.d.ts +1 -1
  355. package/lib/view/node/TextNode.js +1 -1
  356. package/lib/view/node/TextNode.js.map +1 -1
  357. package/lib/view/overlay/CanvasOverlay.js +5 -4
  358. package/lib/view/overlay/CanvasOverlay.js.map +1 -1
  359. package/lib/view/overlay/Grid.d.ts +35 -20
  360. package/lib/view/overlay/Grid.js +35 -26
  361. package/lib/view/overlay/Grid.js.map +1 -1
  362. package/lib/view/overlay/ToolOverlay.d.ts +1 -1
  363. package/lib/view/overlay/ToolOverlay.js +1 -1
  364. package/lib/view/overlay/ToolOverlay.js.map +1 -1
  365. package/lib/view/shape/Circle.d.ts +9 -1
  366. package/lib/view/shape/Circle.js +5 -5
  367. package/lib/view/shape/Circle.js.map +1 -1
  368. package/lib/view/shape/Ellipse.d.ts +10 -1
  369. package/lib/view/shape/Ellipse.js +5 -5
  370. package/lib/view/shape/Ellipse.js.map +1 -1
  371. package/lib/view/shape/Line.d.ts +14 -1
  372. package/lib/view/shape/Line.js +5 -7
  373. package/lib/view/shape/Line.js.map +1 -1
  374. package/lib/view/shape/Path.d.ts +3 -2
  375. package/lib/view/shape/Path.js +3 -3
  376. package/lib/view/shape/Path.js.map +1 -1
  377. package/lib/view/shape/Polygon.d.ts +5 -3
  378. package/lib/view/shape/Polygon.js +6 -6
  379. package/lib/view/shape/Polygon.js.map +1 -1
  380. package/lib/view/shape/Polyline.d.ts +7 -1
  381. package/lib/view/shape/Polyline.js +8 -6
  382. package/lib/view/shape/Polyline.js.map +1 -1
  383. package/lib/view/shape/Rect.d.ts +11 -13
  384. package/lib/view/shape/Rect.js +6 -9
  385. package/lib/view/shape/Rect.js.map +1 -1
  386. package/lib/view/shape/Text.d.ts +19 -1
  387. package/lib/view/shape/Text.js +29 -21
  388. package/lib/view/shape/Text.js.map +1 -1
  389. package/lib/view/text/BaseText.d.ts +12 -15
  390. package/lib/view/text/BaseText.js +46 -29
  391. package/lib/view/text/BaseText.js.map +1 -1
  392. package/lib/view/text/LineText.d.ts +19 -7
  393. package/lib/view/text/LineText.js +62 -57
  394. package/lib/view/text/LineText.js.map +1 -1
  395. package/package.json +5 -4
  396. package/src/LogicFlow.tsx +163 -79
  397. package/src/algorithm/edge.ts +1 -0
  398. package/src/algorithm/index.ts +2 -0
  399. package/src/algorithm/outline.ts +2 -2
  400. package/src/common/drag.ts +219 -0
  401. package/src/common/history.ts +108 -0
  402. package/src/common/index.ts +6 -0
  403. package/src/common/keyboard.ts +108 -0
  404. package/src/common/matrix.ts +122 -0
  405. package/src/common/vector.ts +93 -0
  406. package/src/constant/index.ts +43 -1
  407. package/src/event/eventArgs.ts +173 -34
  408. package/src/event/eventEmitter.ts +2 -3
  409. package/src/index.ts +6 -1
  410. package/src/keyboard/index.ts +2 -0
  411. package/src/keyboard/shortcut.ts +79 -8
  412. package/src/model/BaseModel.ts +18 -7
  413. package/src/model/EditConfigModel.ts +209 -97
  414. package/src/model/GraphModel.ts +64 -9
  415. package/src/model/TransformModel.ts +1 -1
  416. package/src/model/edge/BaseEdgeModel.ts +105 -42
  417. package/src/model/edge/BezierEdgeModel.ts +7 -6
  418. package/src/model/edge/LineEdgeModel.ts +2 -0
  419. package/src/model/edge/PolylineEdgeModel.ts +24 -18
  420. package/src/model/node/BaseNodeModel.ts +72 -47
  421. package/src/model/node/CircleNodeModel.ts +8 -7
  422. package/src/model/node/DiamondNodeModel.ts +9 -6
  423. package/src/model/node/EllipseNodeModel.ts +9 -6
  424. package/src/model/node/HtmlNodeModel.ts +8 -7
  425. package/src/model/node/PolygonNodeModel.ts +9 -7
  426. package/src/model/node/RectNodeModel.ts +16 -8
  427. package/src/model/node/TextNodeModel.ts +14 -1
  428. package/src/options.ts +18 -53
  429. package/src/tool/MultipleSelectTool.tsx +6 -6
  430. package/src/tool/TextEditTool.tsx +3 -3
  431. package/src/tool/index.ts +96 -2
  432. package/src/util/drag.ts +22 -6
  433. package/src/util/edge.ts +39 -13
  434. package/src/util/index.ts +1 -0
  435. package/src/util/node.ts +36 -13
  436. package/src/util/resize.ts +286 -0
  437. package/src/view/Anchor.tsx +7 -5
  438. package/src/view/Control.tsx +93 -62
  439. package/src/view/Graph.tsx +23 -6
  440. package/src/view/Rotate.tsx +2 -1
  441. package/src/view/behavior/index.ts +2 -0
  442. package/src/{tool → view/behavior}/snapline.ts +3 -4
  443. package/src/view/edge/AdjustPoint.tsx +35 -49
  444. package/src/view/edge/BaseEdge.tsx +65 -45
  445. package/src/view/node/BaseNode.tsx +55 -28
  446. package/src/view/node/CircleNode.tsx +3 -1
  447. package/src/view/node/DiamondNode.tsx +3 -1
  448. package/src/view/node/EllipseNode.tsx +3 -1
  449. package/src/view/node/HtmlNode.tsx +5 -3
  450. package/src/view/node/PolygonNode.tsx +3 -1
  451. package/src/view/node/RectNode.tsx +3 -1
  452. package/src/view/node/TextNode.tsx +4 -2
  453. package/src/view/overlay/CanvasOverlay.tsx +5 -4
  454. package/src/view/overlay/Grid.tsx +75 -53
  455. package/src/view/overlay/ToolOverlay.tsx +1 -1
  456. package/src/view/shape/Circle.tsx +21 -7
  457. package/src/view/shape/Ellipse.tsx +20 -6
  458. package/src/view/shape/Line.tsx +24 -9
  459. package/src/view/shape/Path.tsx +9 -6
  460. package/src/view/shape/Polygon.tsx +13 -10
  461. package/src/view/shape/Polyline.tsx +20 -8
  462. package/src/view/shape/Rect.tsx +19 -19
  463. package/src/view/shape/Text.tsx +64 -33
  464. package/src/view/text/BaseText.tsx +76 -42
  465. package/src/view/text/LineText.tsx +94 -80
  466. package/tsconfig.json +1 -1
  467. package/dist/index.js +0 -26
  468. package/dist/index.js.map +0 -1
  469. package/es/tool/snapline.d.ts +0 -3
  470. package/es/tool/snapline.js.map +0 -1
  471. package/es/tool/tool.d.ts +0 -22
  472. package/es/tool/tool.js +0 -43
  473. package/es/tool/tool.js.map +0 -1
  474. package/lib/tool/snapline.d.ts +0 -3
  475. package/lib/tool/snapline.js.map +0 -1
  476. package/lib/tool/tool.d.ts +0 -22
  477. package/lib/tool/tool.js +0 -49
  478. package/lib/tool/tool.js.map +0 -1
  479. package/src/tool/tool.ts +0 -66
@@ -1,91 +1,125 @@
1
- import { Component, createElement as h } from 'preact/compat'
1
+ import classNames from 'classnames'
2
+ import { createElement as h, Component } from 'preact/compat'
3
+ import { ElementState, EventType } from '../../constant'
4
+ import { GraphModel, BaseNodeModel, BaseEdgeModel } from '../../model'
2
5
  import { Text } from '../shape'
3
- import { StepDrag } from '../../util'
4
- import { ElementState } from '../../constant'
5
- import { GraphModel, Model } from '../../model'
6
+ import { IDragParams, StepDrag } from '../../util'
6
7
 
7
- type IProps = {
8
- model: Model.BaseModel
8
+ export type IBaseTextProps = {
9
+ model: BaseNodeModel | BaseEdgeModel
9
10
  graphModel: GraphModel
10
11
  draggable: boolean
11
12
  editable: boolean
12
13
  }
13
- type IState = {
14
+
15
+ export type IBaseTextState = {
14
16
  isHovered: boolean
15
17
  }
16
18
 
17
- export class BaseText extends Component<IProps, IState> {
18
- stepDrag: StepDrag
19
+ export class BaseText<
20
+ P extends IBaseTextProps,
21
+ S extends IBaseTextState,
22
+ > extends Component<P, S> {
23
+ stepperDrag: StepDrag
19
24
 
20
- constructor(config) {
25
+ constructor(props: P) {
21
26
  super()
22
- const { draggable } = config
23
- this.stepDrag = new StepDrag({
27
+ const { draggable } = props
28
+ // TODO: 确认为什么不在 new 的时候传入 model,而在下面使用的时候赋值
29
+ this.stepperDrag = new StepDrag({
24
30
  onDragging: this.onDragging,
25
31
  step: 1,
32
+ // model,
33
+ eventType: 'TEXT',
26
34
  isStopPropagation: draggable,
27
35
  })
28
36
  }
29
37
 
30
38
  getShape(): h.JSX.Element | null {
31
39
  const { model, graphModel } = this.props
32
- const { text } = model
33
40
  const { editConfigModel } = graphModel
34
- const { value, x, y, editable, draggable } = text
41
+ const {
42
+ text: { value, x, y, editable, draggable },
43
+ } = model
35
44
  const attr = {
36
45
  x,
37
46
  y,
38
47
  className: '',
39
48
  value,
40
49
  }
41
- if (editable) {
42
- attr.className = 'lf-element-text'
43
- } else if (draggable || editConfigModel.nodeTextDraggable) {
44
- attr.className = 'lf-text-draggable'
45
- } else {
46
- attr.className = 'lf-text-disabled'
47
- }
50
+ // DONE: 代码优化,看是否可以引入 classnames
51
+ // TODO: 确认下面逻辑是否正确,确认正确后删除下面注释
52
+ // if (editable) {
53
+ // attr.className = 'lf-element-text';
54
+ // } else if (draggable || editConfigModel.nodeTextDraggable) {
55
+ // attr.className = 'lf-text-draggable';
56
+ // } else {
57
+ // attr.className = 'lf-text-disabled';
58
+ // }
48
59
  const style = model.getTextStyle()
49
- return <Text {...attr} {...style} model={model} />
60
+ const isDraggable = editConfigModel.nodeTextDraggable || draggable
61
+
62
+ return (
63
+ <Text
64
+ {...attr}
65
+ {...style}
66
+ className={classNames({
67
+ 'lf-element-text': editable,
68
+ 'lf-text-draggable': !editable && isDraggable,
69
+ 'lf-text-disabled': !editable && !isDraggable,
70
+ })}
71
+ model={model}
72
+ />
73
+ )
50
74
  }
51
75
 
52
- onDragging = ({ deltaX, deltaY }) => {
76
+ mouseDownHandler = (e: MouseEvent) => {
77
+ const { draggable, model, graphModel } = this.props
78
+ const {
79
+ editConfigModel: { nodeTextDraggable },
80
+ } = graphModel
81
+
82
+ if (draggable ?? nodeTextDraggable) {
83
+ this.stepperDrag.model = model
84
+ this.stepperDrag.handleMouseDown(e)
85
+ }
86
+ }
87
+
88
+ onDragging = ({ deltaX, deltaY }: IDragParams) => {
53
89
  const {
54
90
  model,
55
91
  graphModel: { transformModel },
56
92
  } = this.props
57
- const [curDeltaX, curDeltaY] = transformModel.fixDeltaXY(deltaX, deltaY)
58
- model.moveText(curDeltaX, curDeltaY)
59
- }
60
- dblClickHandler = () => {
61
- // 静默模式下,双击不更改状态,不可编辑
62
- const { editable } = this.props
63
- if (editable) {
64
- const { model } = this.props
65
- model.setElementState(ElementState.TEXT_EDIT)
93
+
94
+ if (deltaX && deltaY) {
95
+ const [curDeltaX, curDeltaY] = transformModel.fixDeltaXY(deltaX, deltaY)
96
+ model.moveText(curDeltaX, curDeltaY)
66
97
  }
67
98
  }
68
- mouseDownHandle = (ev: MouseEvent) => {
99
+
100
+ dbClickHandler = () => {
101
+ // 静默模式下,双击不更改状态,不可编辑
69
102
  const {
70
- draggable,
103
+ editable,
104
+ graphModel: { eventCenter },
71
105
  model,
72
- graphModel: {
73
- editConfigModel: { nodeTextDraggable },
74
- },
75
106
  } = this.props
76
- if (draggable || nodeTextDraggable) {
77
- this.stepDrag.model = model
78
- this.stepDrag.handleMouseDown(ev)
107
+ if (editable) {
108
+ model.setElementState(ElementState.TEXT_EDIT)
79
109
  }
110
+ eventCenter.emit(EventType.TEXT_DBCLICK, {
111
+ data: model.text,
112
+ model,
113
+ })
80
114
  }
81
115
 
82
- render() {
116
+ render(): h.JSX.Element | undefined {
83
117
  const {
84
118
  model: { text },
85
119
  } = this.props
86
120
  if (text) {
87
121
  return (
88
- <g onMouseDown={this.mouseDownHandle} onDblClick={this.dblClickHandler}>
122
+ <g onMouseDown={this.mouseDownHandler} onDblClick={this.dbClickHandler}>
89
123
  {this.getShape()}
90
124
  </g>
91
125
  )
@@ -1,40 +1,62 @@
1
- import Text from '../shape/Text'
2
- import Rect from '../shape/Rect'
3
- import BaseText from './BaseText'
4
- import { BaseEdgeModel } from '../../model'
5
- import {
6
- getBytesLength,
7
- getHtmlTextHeight,
8
- getSvgTextWidthHeight,
9
- } from '../../util'
10
-
11
- export class LineText extends BaseText {
12
- constructor(config) {
13
- super(config)
1
+ import { createElement as h } from 'preact/compat'
2
+ import { Text, ITextProps, Rect, IRectProps } from '..'
3
+ import { BaseText } from '.'
4
+ import { BaseEdgeModel, GraphModel } from '../../model'
5
+ import { getHtmlTextHeight, getSvgTextSize } from '../../util'
6
+
7
+ export type ILineTextProps = {
8
+ model: BaseEdgeModel
9
+ graphModel: GraphModel
10
+ draggable: boolean
11
+ editable: boolean
12
+ [key: string]: unknown
13
+ }
14
+
15
+ export type ILineTextState = {
16
+ isHovered: boolean
17
+ }
18
+
19
+ export class LineText extends BaseText<ILineTextProps, ILineTextState> {
20
+ constructor(props: ILineTextProps) {
21
+ super(props)
14
22
  this.state = {
15
23
  isHovered: false,
16
24
  }
17
25
  }
18
26
 
19
- getBackground() {
20
- const model = this.props.model as BaseEdgeModel
27
+ // Hover 状态相关
28
+ setHoverOn = () => {
29
+ this.setState({
30
+ isHovered: true,
31
+ })
32
+ }
33
+ setHoverOff = () => {
34
+ this.setState({
35
+ isHovered: false,
36
+ })
37
+ }
38
+
39
+ getBackground(): h.JSX.Element | null {
40
+ const { isHovered } = this.state
41
+ const { model } = this.props
42
+ const { text } = model
21
43
  const style = model.getTextStyle()
22
- const { text, width: modelWidth } = model
44
+
23
45
  let backgroundStyle = style.background || {}
24
- const { isHovered } = this.state
25
- if (isHovered && style?.hover && style?.hover.background) {
26
- backgroundStyle = { ...backgroundStyle, ...style?.hover.background }
46
+ if (isHovered && style.hover && style.hover.background) {
47
+ backgroundStyle = { ...backgroundStyle, ...style.hover.background }
27
48
  }
28
- // 存在文本并且文本背景不为透明时计算背景框
29
- if (text && text.value && backgroundStyle.fill !== 'transparent') {
30
- const { fontSize, overflowMode, lineHeight, wrapPadding, textWidth } =
31
- style ?? {}
32
- const { value } = text
33
- let { x, y } = text
34
- const rows = String(value).split(/[\r\n]/g)
35
- // 计算行数
49
+
50
+ // 当存在文本并且文本背景不为透明时,计算背景框
51
+ if (text?.value && backgroundStyle?.fill !== 'transparent') {
52
+ const { fontSize, textWidth, lineHeight, overflowMode } = style
53
+ const { wrapPadding } = backgroundStyle
54
+ const rows = text?.value.split(/[\r\n]/g)
36
55
  const rowsLength = rows.length
37
- let rectAttr
56
+
57
+ let { x, y } = text
58
+ let rectAttr: unknown = {}
59
+
38
60
  if (overflowMode === 'autoWrap' && textWidth) {
39
61
  const textHeight = getHtmlTextHeight({
40
62
  rows,
@@ -47,30 +69,18 @@ export class LineText extends BaseText {
47
69
  rowsLength,
48
70
  className: 'lf-get-text-height',
49
71
  })
72
+
50
73
  rectAttr = {
51
74
  ...backgroundStyle,
52
- x: x - 1,
53
- y: y - 1,
75
+ x,
76
+ y,
54
77
  width: textWidth,
55
78
  height: textHeight,
56
79
  }
57
80
  } else {
58
- // 计算文本中最长的一行的字节数
59
- let longestBytes = 0
60
- rows &&
61
- rows.forEach((item) => {
62
- const rowByteLength = getBytesLength(item)
63
- longestBytes =
64
- rowByteLength > longestBytes ? rowByteLength : longestBytes
65
- })
66
- // 背景框宽度,最长一行字节数/2 * fontsize + 2
67
- // 背景框宽度, 行数 * fontsize + 2
68
- let { width, height } = getSvgTextWidthHeight({
69
- rows,
70
- fontSize,
71
- rowsLength,
72
- })
73
-
81
+ // 背景框宽度,最长一行字节数 / 2 * fontSize + 2
82
+ // 背景框宽度,行数 * fontSize + 2
83
+ let { width, height } = getSvgTextSize({ rows, rowsLength, fontSize })
74
84
  if (overflowMode === 'ellipsis') {
75
85
  // https://github.com/didi/LogicFlow/issues/1151
76
86
  // 边上的文字过长(使用"ellipsis"模式)出现省略号,背景也需要进行宽度的重新计算
@@ -78,30 +88,38 @@ export class LineText extends BaseText {
78
88
  // 跟Text.tsx保持同样的计算逻辑(overflowMode === 'ellipsis')
79
89
  // Text.tsx使用textRealWidth=textWidth || width
80
90
  // Text.tsx使用foreignObjectHeight = fontSize + 2;
81
- width = textWidth || (modelWidth as number)
91
+ width = textWidth
82
92
  height = fontSize + 2
83
93
  }
84
94
 
85
- // 根据设置的padding调整width, height, x, y的值
95
+ // 根据设置的 padding 调整 width, height, x, y 的值
96
+ // TODO: 下面方法感觉可以提取成工具方法
86
97
  if (typeof backgroundStyle.wrapPadding === 'string') {
87
- let paddings = backgroundStyle.wrapPadding
98
+ let padding = backgroundStyle.wrapPadding
88
99
  .split(',')
89
100
  .filter((padding) => padding.trim())
90
101
  .map((padding) => parseFloat(padding.trim()))
91
- if (paddings.length > 0 && paddings.length <= 4) {
92
- if (paddings.length === 1) {
93
- paddings = [paddings[0], paddings[0], paddings[0], paddings[0]]
94
- } else if (paddings.length === 2) {
95
- paddings = [paddings[0], paddings[1], paddings[0], paddings[1]]
96
- } else if (paddings.length === 3) {
97
- paddings = [paddings[0], paddings[1], paddings[2], paddings[1]]
102
+
103
+ if (padding.length > 0 && padding.length <= 4) {
104
+ if (padding.length === 1) {
105
+ const [allSides] = padding
106
+ padding = [allSides, allSides, allSides, allSides]
107
+ } else if (padding.length === 2) {
108
+ const [vertical, horizontal] = padding
109
+ padding = [vertical, horizontal, vertical, horizontal]
110
+ } else if (padding.length === 3) {
111
+ const [top, horizontal, bottom] = padding
112
+ padding = [top, horizontal, bottom, horizontal]
98
113
  }
99
- width += paddings[1] + paddings[3]
100
- height += paddings[0] + paddings[2]
101
- x = x + (paddings[1] - paddings[3]) / 2
102
- y = y + (paddings[2] - paddings[0]) / 2
114
+
115
+ const [top, right, bottom, left] = padding
116
+ width += right + left
117
+ height += top + bottom
118
+ x = x + (right - left) / 2
119
+ y = y + (bottom - top) / 2
103
120
  }
104
121
  }
122
+
105
123
  rectAttr = {
106
124
  ...backgroundStyle,
107
125
  x: x - 1,
@@ -110,42 +128,38 @@ export class LineText extends BaseText {
110
128
  height,
111
129
  }
112
130
  }
113
- return <Rect {...rectAttr} />
131
+
132
+ return <Rect {...(rectAttr as IRectProps)} />
114
133
  }
115
- }
116
134
 
117
- setHoverON = () => {
118
- this.setState({
119
- isHovered: true,
120
- })
121
- }
122
- setHoverOFF = () => {
123
- this.setState({
124
- isHovered: false,
125
- })
135
+ return null
126
136
  }
127
137
 
128
- getShape() {
138
+ getShape(): h.JSX.Element | null {
129
139
  const { model } = this.props
130
- const { text } = model
131
- const { value, x, y } = text
140
+ const {
141
+ text: { x, y, value },
142
+ } = model
132
143
  if (!value) return null
144
+
133
145
  const style = model.getTextStyle()
134
- const attr = {
146
+ const attrs: ITextProps = {
135
147
  x,
136
148
  y,
137
- className: 'lf-element-text',
138
149
  value,
139
- ...style, // 透传 edgeText 属性, 如 color fontSize fontWeight fontFamily textAnchor 等
150
+ model,
151
+ className: 'lf-element-text',
152
+ ...style, // 透传 edgeText 属性,如:color, fontSize, fontWeight, fontFamily, textAnchor 等
140
153
  }
154
+
141
155
  return (
142
156
  <g
143
157
  className="lf-line-text"
144
- onMouseEnter={this.setHoverON}
145
- onMouseLeave={this.setHoverOFF}
158
+ onMouseEnter={this.setHoverOn}
159
+ onMouseLeave={this.setHoverOff}
146
160
  >
147
161
  {this.getBackground()}
148
- <Text {...attr} model={model} />
162
+ <Text {...attrs} />
149
163
  </g>
150
164
  )
151
165
  }
package/tsconfig.json CHANGED
@@ -14,5 +14,5 @@
14
14
  }
15
15
  },
16
16
  "include": ["src/**/*", "**/*.d.ts"],
17
- "exclude": ["node_modules", "**/*.spec.ts", "es", "lib"]
17
+ "exclude": ["node_modules", "**/*.spec.ts", "es", "lib", "__tests__"]
18
18
  }