@logicflow/core 2.0.0-beta.1 → 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 (469) hide show
  1. package/.turbo/turbo-build$colon$dev.log +2 -2
  2. package/.turbo/turbo-build.log +9 -9
  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 +9 -3
  6. package/es/LogicFlow.d.ts +88 -40
  7. package/es/LogicFlow.js +38 -33
  8. package/es/LogicFlow.js.map +1 -1
  9. package/es/algorithm/edge.js.map +1 -1
  10. package/es/algorithm/index.d.ts +2 -0
  11. package/es/algorithm/index.js +2 -0
  12. package/es/algorithm/index.js.map +1 -1
  13. package/es/algorithm/outline.d.ts +1 -1
  14. package/es/common/drag.d.ts +51 -0
  15. package/es/common/drag.js +145 -0
  16. package/es/common/drag.js.map +1 -0
  17. package/es/common/history.d.ts +28 -0
  18. package/es/common/history.js +92 -0
  19. package/es/common/history.js.map +1 -0
  20. package/es/common/index.d.ts +5 -0
  21. package/es/common/index.js +6 -0
  22. package/es/common/index.js.map +1 -0
  23. package/es/common/keyboard.d.ts +34 -0
  24. package/es/common/keyboard.js +80 -0
  25. package/es/common/keyboard.js.map +1 -0
  26. package/es/common/matrix.d.ts +30 -0
  27. package/es/common/matrix.js +155 -0
  28. package/es/common/matrix.js.map +1 -0
  29. package/es/common/vector.d.ts +23 -0
  30. package/es/common/vector.js +97 -0
  31. package/es/common/vector.js.map +1 -0
  32. package/es/constant/index.d.ts +39 -2
  33. package/es/constant/index.js +41 -1
  34. package/es/constant/index.js.map +1 -1
  35. package/es/event/eventArgs.d.ts +103 -25
  36. package/es/event/eventEmitter.d.ts +2 -2
  37. package/es/event/eventEmitter.js +0 -1
  38. package/es/event/eventEmitter.js.map +1 -1
  39. package/es/index.d.ts +6 -1
  40. package/es/index.js +6 -1
  41. package/es/index.js.map +1 -1
  42. package/es/keyboard/index.d.ts +1 -0
  43. package/es/keyboard/index.js +1 -0
  44. package/es/keyboard/index.js.map +1 -1
  45. package/es/keyboard/shortcut.d.ts +8 -0
  46. package/es/keyboard/shortcut.js +70 -8
  47. package/es/keyboard/shortcut.js.map +1 -1
  48. package/es/model/BaseModel.d.ts +16 -7
  49. package/es/model/EditConfigModel.d.ts +97 -36
  50. package/es/model/EditConfigModel.js +169 -82
  51. package/es/model/EditConfigModel.js.map +1 -1
  52. package/es/model/GraphModel.d.ts +36 -14
  53. package/es/model/GraphModel.js +60 -10
  54. package/es/model/GraphModel.js.map +1 -1
  55. package/es/model/SnaplineModel.d.ts +2 -0
  56. package/es/model/TransformModel.js +1 -1
  57. package/es/model/TransformModel.js.map +1 -1
  58. package/es/model/edge/BaseEdgeModel.d.ts +21 -17
  59. package/es/model/edge/BaseEdgeModel.js +64 -42
  60. package/es/model/edge/BaseEdgeModel.js.map +1 -1
  61. package/es/model/edge/BezierEdgeModel.d.ts +5 -3
  62. package/es/model/edge/BezierEdgeModel.js +7 -3
  63. package/es/model/edge/BezierEdgeModel.js.map +1 -1
  64. package/es/model/edge/LineEdgeModel.d.ts +2 -0
  65. package/es/model/edge/LineEdgeModel.js +2 -1
  66. package/es/model/edge/LineEdgeModel.js.map +1 -1
  67. package/es/model/edge/PolylineEdgeModel.d.ts +5 -3
  68. package/es/model/edge/PolylineEdgeModel.js +22 -15
  69. package/es/model/edge/PolylineEdgeModel.js.map +1 -1
  70. package/es/model/node/BaseNodeModel.d.ts +42 -14
  71. package/es/model/node/BaseNodeModel.js +62 -48
  72. package/es/model/node/BaseNodeModel.js.map +1 -1
  73. package/es/model/node/CircleNodeModel.d.ts +4 -3
  74. package/es/model/node/CircleNodeModel.js +4 -7
  75. package/es/model/node/CircleNodeModel.js.map +1 -1
  76. package/es/model/node/DiamondNodeModel.d.ts +5 -4
  77. package/es/model/node/DiamondNodeModel.js +4 -6
  78. package/es/model/node/DiamondNodeModel.js.map +1 -1
  79. package/es/model/node/EllipseNodeModel.d.ts +5 -4
  80. package/es/model/node/EllipseNodeModel.js +4 -6
  81. package/es/model/node/EllipseNodeModel.js.map +1 -1
  82. package/es/model/node/HtmlNodeModel.d.ts +4 -5
  83. package/es/model/node/HtmlNodeModel.js +2 -12
  84. package/es/model/node/HtmlNodeModel.js.map +1 -1
  85. package/es/model/node/PolygonNodeModel.d.ts +5 -4
  86. package/es/model/node/PolygonNodeModel.js +4 -7
  87. package/es/model/node/PolygonNodeModel.js.map +1 -1
  88. package/es/model/node/RectNodeModel.d.ts +7 -5
  89. package/es/model/node/RectNodeModel.js +10 -7
  90. package/es/model/node/RectNodeModel.js.map +1 -1
  91. package/es/model/node/TextNodeModel.d.ts +17 -9
  92. package/es/model/node/TextNodeModel.js +2 -1
  93. package/es/model/node/TextNodeModel.js.map +1 -1
  94. package/es/options.d.ts +6 -3
  95. package/es/options.js +2 -11
  96. package/es/options.js.map +1 -1
  97. package/es/tool/MultipleSelectTool.d.ts +1 -1
  98. package/es/tool/MultipleSelectTool.js +5 -5
  99. package/es/tool/MultipleSelectTool.js.map +1 -1
  100. package/es/tool/TextEditTool.d.ts +3 -3
  101. package/es/tool/TextEditTool.js +2 -2
  102. package/es/tool/TextEditTool.js.map +1 -1
  103. package/es/tool/index.d.ts +24 -2
  104. package/es/tool/index.js +82 -2
  105. package/es/tool/index.js.map +1 -1
  106. package/es/util/drag.d.ts +5 -5
  107. package/es/util/drag.js +3 -1
  108. package/es/util/drag.js.map +1 -1
  109. package/es/util/edge.d.ts +9 -2
  110. package/es/util/edge.js +23 -12
  111. package/es/util/edge.js.map +1 -1
  112. package/es/util/index.d.ts +1 -0
  113. package/es/util/index.js +1 -0
  114. package/es/util/index.js.map +1 -1
  115. package/es/util/node.d.ts +8 -7
  116. package/es/util/node.js +26 -7
  117. package/es/util/node.js.map +1 -1
  118. package/es/util/resize.d.ts +32 -0
  119. package/es/util/resize.js +197 -0
  120. package/es/util/resize.js.map +1 -0
  121. package/es/view/Anchor.d.ts +6 -7
  122. package/es/view/Anchor.js +6 -3
  123. package/es/view/Anchor.js.map +1 -1
  124. package/es/view/Control.d.ts +1 -1
  125. package/es/view/Control.js +88 -39
  126. package/es/view/Control.js.map +1 -1
  127. package/es/view/Graph.d.ts +5 -1
  128. package/es/view/Graph.js +43 -3
  129. package/es/view/Graph.js.map +1 -1
  130. package/es/view/Rotate.js +2 -1
  131. package/es/view/Rotate.js.map +1 -1
  132. package/es/view/behavior/index.d.ts +2 -0
  133. package/es/view/behavior/index.js +3 -0
  134. package/es/view/behavior/index.js.map +1 -0
  135. package/es/view/behavior/snapline.d.ts +3 -0
  136. package/es/{tool → view/behavior}/snapline.js +0 -1
  137. package/es/view/behavior/snapline.js.map +1 -0
  138. package/es/view/edge/AdjustPoint.js +12 -23
  139. package/es/view/edge/AdjustPoint.js.map +1 -1
  140. package/es/view/edge/BaseEdge.d.ts +2 -2
  141. package/es/view/edge/BaseEdge.js +30 -22
  142. package/es/view/edge/BaseEdge.js.map +1 -1
  143. package/es/view/node/BaseNode.d.ts +4 -4
  144. package/es/view/node/BaseNode.js +33 -24
  145. package/es/view/node/BaseNode.js.map +1 -1
  146. package/es/view/node/CircleNode.d.ts +1 -1
  147. package/es/view/node/CircleNode.js.map +1 -1
  148. package/es/view/node/DiamondNode.d.ts +1 -1
  149. package/es/view/node/DiamondNode.js.map +1 -1
  150. package/es/view/node/EllipseNode.d.ts +1 -1
  151. package/es/view/node/EllipseNode.js.map +1 -1
  152. package/es/view/node/HtmlNode.d.ts +1 -1
  153. package/es/view/node/HtmlNode.js +2 -2
  154. package/es/view/node/HtmlNode.js.map +1 -1
  155. package/es/view/node/PolygonNode.d.ts +1 -1
  156. package/es/view/node/PolygonNode.js.map +1 -1
  157. package/es/view/node/RectNode.d.ts +1 -1
  158. package/es/view/node/RectNode.js.map +1 -1
  159. package/es/view/node/TextNode.d.ts +1 -1
  160. package/es/view/node/TextNode.js +1 -1
  161. package/es/view/node/TextNode.js.map +1 -1
  162. package/es/view/overlay/CanvasOverlay.js +5 -4
  163. package/es/view/overlay/CanvasOverlay.js.map +1 -1
  164. package/es/view/overlay/ToolOverlay.d.ts +1 -1
  165. package/es/view/overlay/ToolOverlay.js +1 -1
  166. package/es/view/overlay/ToolOverlay.js.map +1 -1
  167. package/es/view/shape/Circle.d.ts +9 -1
  168. package/es/view/shape/Circle.js +5 -5
  169. package/es/view/shape/Circle.js.map +1 -1
  170. package/es/view/shape/Ellipse.d.ts +10 -1
  171. package/es/view/shape/Ellipse.js +5 -5
  172. package/es/view/shape/Ellipse.js.map +1 -1
  173. package/es/view/shape/Line.d.ts +14 -1
  174. package/es/view/shape/Line.js +5 -7
  175. package/es/view/shape/Line.js.map +1 -1
  176. package/es/view/shape/Path.d.ts +3 -2
  177. package/es/view/shape/Path.js +3 -3
  178. package/es/view/shape/Path.js.map +1 -1
  179. package/es/view/shape/Polygon.d.ts +5 -3
  180. package/es/view/shape/Polygon.js +6 -6
  181. package/es/view/shape/Polygon.js.map +1 -1
  182. package/es/view/shape/Polyline.d.ts +7 -1
  183. package/es/view/shape/Polyline.js +8 -6
  184. package/es/view/shape/Polyline.js.map +1 -1
  185. package/es/view/shape/Rect.d.ts +11 -13
  186. package/es/view/shape/Rect.js +6 -9
  187. package/es/view/shape/Rect.js.map +1 -1
  188. package/es/view/shape/Text.d.ts +19 -1
  189. package/es/view/shape/Text.js +28 -21
  190. package/es/view/shape/Text.js.map +1 -1
  191. package/es/view/text/BaseText.d.ts +12 -15
  192. package/es/view/text/BaseText.js +43 -29
  193. package/es/view/text/BaseText.js.map +1 -1
  194. package/es/view/text/LineText.d.ts +19 -7
  195. package/es/view/text/LineText.js +62 -54
  196. package/es/view/text/LineText.js.map +1 -1
  197. package/lib/LogicFlow.d.ts +88 -40
  198. package/lib/LogicFlow.js +40 -35
  199. package/lib/LogicFlow.js.map +1 -1
  200. package/lib/algorithm/edge.js.map +1 -1
  201. package/lib/algorithm/index.d.ts +2 -0
  202. package/lib/algorithm/index.js +17 -1
  203. package/lib/algorithm/index.js.map +1 -1
  204. package/lib/algorithm/outline.d.ts +1 -1
  205. package/lib/common/drag.d.ts +51 -0
  206. package/lib/common/drag.js +148 -0
  207. package/lib/common/drag.js.map +1 -0
  208. package/lib/common/history.d.ts +28 -0
  209. package/lib/common/history.js +95 -0
  210. package/lib/common/history.js.map +1 -0
  211. package/lib/common/index.d.ts +5 -0
  212. package/lib/common/index.js +22 -0
  213. package/lib/common/index.js.map +1 -0
  214. package/lib/common/keyboard.d.ts +34 -0
  215. package/lib/common/keyboard.js +86 -0
  216. package/lib/common/keyboard.js.map +1 -0
  217. package/lib/common/matrix.d.ts +30 -0
  218. package/lib/common/matrix.js +158 -0
  219. package/lib/common/matrix.js.map +1 -0
  220. package/lib/common/vector.d.ts +23 -0
  221. package/lib/common/vector.js +101 -0
  222. package/lib/common/vector.js.map +1 -0
  223. package/lib/constant/index.d.ts +39 -2
  224. package/lib/constant/index.js +42 -2
  225. package/lib/constant/index.js.map +1 -1
  226. package/lib/event/eventArgs.d.ts +103 -25
  227. package/lib/event/eventEmitter.d.ts +2 -2
  228. package/lib/event/eventEmitter.js +0 -1
  229. package/lib/event/eventEmitter.js.map +1 -1
  230. package/lib/index.d.ts +6 -1
  231. package/lib/index.js +7 -2
  232. package/lib/index.js.map +1 -1
  233. package/lib/keyboard/index.d.ts +1 -0
  234. package/lib/keyboard/index.js +15 -0
  235. package/lib/keyboard/index.js.map +1 -1
  236. package/lib/keyboard/shortcut.d.ts +8 -0
  237. package/lib/keyboard/shortcut.js +75 -9
  238. package/lib/keyboard/shortcut.js.map +1 -1
  239. package/lib/model/BaseModel.d.ts +16 -7
  240. package/lib/model/EditConfigModel.d.ts +97 -36
  241. package/lib/model/EditConfigModel.js +168 -81
  242. package/lib/model/EditConfigModel.js.map +1 -1
  243. package/lib/model/GraphModel.d.ts +36 -14
  244. package/lib/model/GraphModel.js +59 -9
  245. package/lib/model/GraphModel.js.map +1 -1
  246. package/lib/model/SnaplineModel.d.ts +2 -0
  247. package/lib/model/TransformModel.js +1 -1
  248. package/lib/model/TransformModel.js.map +1 -1
  249. package/lib/model/edge/BaseEdgeModel.d.ts +21 -17
  250. package/lib/model/edge/BaseEdgeModel.js +61 -39
  251. package/lib/model/edge/BaseEdgeModel.js.map +1 -1
  252. package/lib/model/edge/BezierEdgeModel.d.ts +5 -3
  253. package/lib/model/edge/BezierEdgeModel.js +6 -2
  254. package/lib/model/edge/BezierEdgeModel.js.map +1 -1
  255. package/lib/model/edge/LineEdgeModel.d.ts +2 -0
  256. package/lib/model/edge/LineEdgeModel.js +2 -1
  257. package/lib/model/edge/LineEdgeModel.js.map +1 -1
  258. package/lib/model/edge/PolylineEdgeModel.d.ts +5 -3
  259. package/lib/model/edge/PolylineEdgeModel.js +21 -14
  260. package/lib/model/edge/PolylineEdgeModel.js.map +1 -1
  261. package/lib/model/node/BaseNodeModel.d.ts +42 -14
  262. package/lib/model/node/BaseNodeModel.js +60 -46
  263. package/lib/model/node/BaseNodeModel.js.map +1 -1
  264. package/lib/model/node/CircleNodeModel.d.ts +4 -3
  265. package/lib/model/node/CircleNodeModel.js +4 -7
  266. package/lib/model/node/CircleNodeModel.js.map +1 -1
  267. package/lib/model/node/DiamondNodeModel.d.ts +5 -4
  268. package/lib/model/node/DiamondNodeModel.js +4 -6
  269. package/lib/model/node/DiamondNodeModel.js.map +1 -1
  270. package/lib/model/node/EllipseNodeModel.d.ts +5 -4
  271. package/lib/model/node/EllipseNodeModel.js +4 -6
  272. package/lib/model/node/EllipseNodeModel.js.map +1 -1
  273. package/lib/model/node/HtmlNodeModel.d.ts +4 -5
  274. package/lib/model/node/HtmlNodeModel.js +2 -12
  275. package/lib/model/node/HtmlNodeModel.js.map +1 -1
  276. package/lib/model/node/PolygonNodeModel.d.ts +5 -4
  277. package/lib/model/node/PolygonNodeModel.js +4 -7
  278. package/lib/model/node/PolygonNodeModel.js.map +1 -1
  279. package/lib/model/node/RectNodeModel.d.ts +7 -5
  280. package/lib/model/node/RectNodeModel.js +10 -7
  281. package/lib/model/node/RectNodeModel.js.map +1 -1
  282. package/lib/model/node/TextNodeModel.d.ts +17 -9
  283. package/lib/model/node/TextNodeModel.js +2 -1
  284. package/lib/model/node/TextNodeModel.js.map +1 -1
  285. package/lib/options.d.ts +6 -3
  286. package/lib/options.js +2 -11
  287. package/lib/options.js.map +1 -1
  288. package/lib/tool/MultipleSelectTool.d.ts +1 -1
  289. package/lib/tool/MultipleSelectTool.js +5 -5
  290. package/lib/tool/MultipleSelectTool.js.map +1 -1
  291. package/lib/tool/TextEditTool.d.ts +3 -3
  292. package/lib/tool/TextEditTool.js +4 -4
  293. package/lib/tool/TextEditTool.js.map +1 -1
  294. package/lib/tool/index.d.ts +24 -2
  295. package/lib/tool/index.js +85 -15
  296. package/lib/tool/index.js.map +1 -1
  297. package/lib/util/drag.d.ts +5 -5
  298. package/lib/util/drag.js +3 -1
  299. package/lib/util/drag.js.map +1 -1
  300. package/lib/util/edge.d.ts +9 -2
  301. package/lib/util/edge.js +27 -15
  302. package/lib/util/edge.js.map +1 -1
  303. package/lib/util/index.d.ts +1 -0
  304. package/lib/util/index.js +1 -0
  305. package/lib/util/index.js.map +1 -1
  306. package/lib/util/node.d.ts +8 -7
  307. package/lib/util/node.js +28 -9
  308. package/lib/util/node.js.map +1 -1
  309. package/lib/util/resize.d.ts +32 -0
  310. package/lib/util/resize.js +204 -0
  311. package/lib/util/resize.js.map +1 -0
  312. package/lib/view/Anchor.d.ts +6 -7
  313. package/lib/view/Anchor.js +5 -2
  314. package/lib/view/Anchor.js.map +1 -1
  315. package/lib/view/Control.d.ts +1 -1
  316. package/lib/view/Control.js +87 -38
  317. package/lib/view/Control.js.map +1 -1
  318. package/lib/view/Graph.d.ts +5 -1
  319. package/lib/view/Graph.js +42 -2
  320. package/lib/view/Graph.js.map +1 -1
  321. package/lib/view/Rotate.js +2 -1
  322. package/lib/view/Rotate.js.map +1 -1
  323. package/lib/view/behavior/index.d.ts +2 -0
  324. package/lib/view/behavior/index.js +19 -0
  325. package/lib/view/behavior/index.js.map +1 -0
  326. package/lib/view/behavior/snapline.d.ts +3 -0
  327. package/lib/{tool → view/behavior}/snapline.js +0 -1
  328. package/lib/view/behavior/snapline.js.map +1 -0
  329. package/lib/view/edge/AdjustPoint.js +11 -22
  330. package/lib/view/edge/AdjustPoint.js.map +1 -1
  331. package/lib/view/edge/BaseEdge.d.ts +2 -2
  332. package/lib/view/edge/BaseEdge.js +29 -21
  333. package/lib/view/edge/BaseEdge.js.map +1 -1
  334. package/lib/view/node/BaseNode.d.ts +4 -4
  335. package/lib/view/node/BaseNode.js +32 -23
  336. package/lib/view/node/BaseNode.js.map +1 -1
  337. package/lib/view/node/CircleNode.d.ts +1 -1
  338. package/lib/view/node/CircleNode.js.map +1 -1
  339. package/lib/view/node/DiamondNode.d.ts +1 -1
  340. package/lib/view/node/DiamondNode.js.map +1 -1
  341. package/lib/view/node/EllipseNode.d.ts +1 -1
  342. package/lib/view/node/EllipseNode.js.map +1 -1
  343. package/lib/view/node/HtmlNode.d.ts +1 -1
  344. package/lib/view/node/HtmlNode.js +2 -2
  345. package/lib/view/node/HtmlNode.js.map +1 -1
  346. package/lib/view/node/PolygonNode.d.ts +1 -1
  347. package/lib/view/node/PolygonNode.js.map +1 -1
  348. package/lib/view/node/RectNode.d.ts +1 -1
  349. package/lib/view/node/RectNode.js.map +1 -1
  350. package/lib/view/node/TextNode.d.ts +1 -1
  351. package/lib/view/node/TextNode.js +1 -1
  352. package/lib/view/node/TextNode.js.map +1 -1
  353. package/lib/view/overlay/CanvasOverlay.js +5 -4
  354. package/lib/view/overlay/CanvasOverlay.js.map +1 -1
  355. package/lib/view/overlay/ToolOverlay.d.ts +1 -1
  356. package/lib/view/overlay/ToolOverlay.js +1 -1
  357. package/lib/view/overlay/ToolOverlay.js.map +1 -1
  358. package/lib/view/shape/Circle.d.ts +9 -1
  359. package/lib/view/shape/Circle.js +5 -5
  360. package/lib/view/shape/Circle.js.map +1 -1
  361. package/lib/view/shape/Ellipse.d.ts +10 -1
  362. package/lib/view/shape/Ellipse.js +5 -5
  363. package/lib/view/shape/Ellipse.js.map +1 -1
  364. package/lib/view/shape/Line.d.ts +14 -1
  365. package/lib/view/shape/Line.js +5 -7
  366. package/lib/view/shape/Line.js.map +1 -1
  367. package/lib/view/shape/Path.d.ts +3 -2
  368. package/lib/view/shape/Path.js +3 -3
  369. package/lib/view/shape/Path.js.map +1 -1
  370. package/lib/view/shape/Polygon.d.ts +5 -3
  371. package/lib/view/shape/Polygon.js +6 -6
  372. package/lib/view/shape/Polygon.js.map +1 -1
  373. package/lib/view/shape/Polyline.d.ts +7 -1
  374. package/lib/view/shape/Polyline.js +8 -6
  375. package/lib/view/shape/Polyline.js.map +1 -1
  376. package/lib/view/shape/Rect.d.ts +11 -13
  377. package/lib/view/shape/Rect.js +6 -9
  378. package/lib/view/shape/Rect.js.map +1 -1
  379. package/lib/view/shape/Text.d.ts +19 -1
  380. package/lib/view/shape/Text.js +29 -21
  381. package/lib/view/shape/Text.js.map +1 -1
  382. package/lib/view/text/BaseText.d.ts +12 -15
  383. package/lib/view/text/BaseText.js +46 -29
  384. package/lib/view/text/BaseText.js.map +1 -1
  385. package/lib/view/text/LineText.d.ts +19 -7
  386. package/lib/view/text/LineText.js +62 -57
  387. package/lib/view/text/LineText.js.map +1 -1
  388. package/package.json +2 -1
  389. package/src/LogicFlow.tsx +163 -79
  390. package/src/algorithm/edge.ts +1 -0
  391. package/src/algorithm/index.ts +2 -0
  392. package/src/algorithm/outline.ts +2 -2
  393. package/src/common/drag.ts +219 -0
  394. package/src/common/history.ts +108 -0
  395. package/src/common/index.ts +6 -0
  396. package/src/common/keyboard.ts +108 -0
  397. package/src/common/matrix.ts +122 -0
  398. package/src/common/vector.ts +93 -0
  399. package/src/constant/index.ts +43 -1
  400. package/src/event/eventArgs.ts +173 -34
  401. package/src/event/eventEmitter.ts +2 -3
  402. package/src/index.ts +6 -1
  403. package/src/keyboard/index.ts +2 -0
  404. package/src/keyboard/shortcut.ts +79 -8
  405. package/src/model/BaseModel.ts +18 -7
  406. package/src/model/EditConfigModel.ts +209 -97
  407. package/src/model/GraphModel.ts +64 -9
  408. package/src/model/TransformModel.ts +1 -1
  409. package/src/model/edge/BaseEdgeModel.ts +75 -44
  410. package/src/model/edge/BezierEdgeModel.ts +7 -6
  411. package/src/model/edge/LineEdgeModel.ts +2 -0
  412. package/src/model/edge/PolylineEdgeModel.ts +24 -18
  413. package/src/model/node/BaseNodeModel.ts +72 -47
  414. package/src/model/node/CircleNodeModel.ts +8 -7
  415. package/src/model/node/DiamondNodeModel.ts +9 -6
  416. package/src/model/node/EllipseNodeModel.ts +9 -6
  417. package/src/model/node/HtmlNodeModel.ts +8 -7
  418. package/src/model/node/PolygonNodeModel.ts +9 -7
  419. package/src/model/node/RectNodeModel.ts +16 -8
  420. package/src/model/node/TextNodeModel.ts +14 -1
  421. package/src/options.ts +11 -15
  422. package/src/tool/MultipleSelectTool.tsx +6 -6
  423. package/src/tool/TextEditTool.tsx +3 -3
  424. package/src/tool/index.ts +96 -2
  425. package/src/util/drag.ts +22 -6
  426. package/src/util/edge.ts +39 -13
  427. package/src/util/index.ts +1 -0
  428. package/src/util/node.ts +36 -13
  429. package/src/util/resize.ts +286 -0
  430. package/src/view/Anchor.tsx +7 -5
  431. package/src/view/Control.tsx +93 -62
  432. package/src/view/Graph.tsx +21 -4
  433. package/src/view/Rotate.tsx +2 -1
  434. package/src/view/behavior/index.ts +2 -0
  435. package/src/{tool → view/behavior}/snapline.ts +3 -4
  436. package/src/view/edge/AdjustPoint.tsx +35 -49
  437. package/src/view/edge/BaseEdge.tsx +65 -45
  438. package/src/view/node/BaseNode.tsx +55 -28
  439. package/src/view/node/CircleNode.tsx +3 -1
  440. package/src/view/node/DiamondNode.tsx +3 -1
  441. package/src/view/node/EllipseNode.tsx +3 -1
  442. package/src/view/node/HtmlNode.tsx +5 -3
  443. package/src/view/node/PolygonNode.tsx +3 -1
  444. package/src/view/node/RectNode.tsx +3 -1
  445. package/src/view/node/TextNode.tsx +4 -2
  446. package/src/view/overlay/CanvasOverlay.tsx +5 -4
  447. package/src/view/overlay/ToolOverlay.tsx +1 -1
  448. package/src/view/shape/Circle.tsx +21 -7
  449. package/src/view/shape/Ellipse.tsx +20 -6
  450. package/src/view/shape/Line.tsx +24 -9
  451. package/src/view/shape/Path.tsx +9 -6
  452. package/src/view/shape/Polygon.tsx +13 -10
  453. package/src/view/shape/Polyline.tsx +20 -8
  454. package/src/view/shape/Rect.tsx +19 -19
  455. package/src/view/shape/Text.tsx +64 -33
  456. package/src/view/text/BaseText.tsx +76 -42
  457. package/src/view/text/LineText.tsx +94 -80
  458. package/tsconfig.json +1 -1
  459. package/es/tool/snapline.d.ts +0 -3
  460. package/es/tool/snapline.js.map +0 -1
  461. package/es/tool/tool.d.ts +0 -22
  462. package/es/tool/tool.js +0 -43
  463. package/es/tool/tool.js.map +0 -1
  464. package/lib/tool/snapline.d.ts +0 -3
  465. package/lib/tool/snapline.js.map +0 -1
  466. package/lib/tool/tool.d.ts +0 -22
  467. package/lib/tool/tool.js +0 -49
  468. package/lib/tool/tool.js.map +0 -1
  469. package/src/tool/tool.ts +0 -66
@@ -0,0 +1,51 @@
1
+ import { Model } from '../model';
2
+ import EventEmitter from '../event/eventEmitter';
3
+ export type IDragParams = {
4
+ deltaX: number;
5
+ deltaY: number;
6
+ event: MouseEvent | null;
7
+ [key: string]: unknown;
8
+ };
9
+ export type ICreateDragParams = {
10
+ onDragStart?: (params: Partial<IDragParams>) => void;
11
+ onDragging?: (param: IDragParams) => void;
12
+ onDragEnd?: (param: Partial<IDragParams>) => void;
13
+ step?: number;
14
+ isStopPropagation?: boolean;
15
+ };
16
+ export type IStepperDragProps = {
17
+ eventType?: 'NODE' | 'BLANK' | 'SELECTION' | 'ADJUST_POINT' | 'TEXT' | 'LABEL' | '';
18
+ eventCenter?: EventEmitter;
19
+ model?: Model.BaseModel;
20
+ data?: Record<string, unknown>;
21
+ [key: string]: unknown;
22
+ } & Partial<ICreateDragParams>;
23
+ /**
24
+ * 支持拖拽时按步长进行移动
25
+ * REMIND:在绘制的过程中因为放大缩小,移动的真实 step 是变化的
26
+ */
27
+ export declare class StepperDrag {
28
+ onDragStart: (params: Partial<IDragParams>) => void;
29
+ onDragging: (params: IDragParams) => void;
30
+ onDragEnd: (params: Partial<IDragParams>) => void;
31
+ step: number;
32
+ isStopPropagation: boolean;
33
+ eventType: 'NODE' | 'BLANK' | 'SELECTION' | 'ADJUST_POINT' | 'TEXT' | 'LABEL' | '';
34
+ eventCenter?: EventEmitter;
35
+ model?: Model.BaseModel;
36
+ data?: Record<string, unknown>;
37
+ isDragging: boolean;
38
+ isStartDrag: boolean;
39
+ startX: number;
40
+ startY: number;
41
+ totalDeltaX: number;
42
+ totalDeltaY: number;
43
+ startTime?: number;
44
+ constructor({ onDragStart, onDragging, onDragEnd, step, eventType, isStopPropagation, eventCenter, model, data, }: IStepperDragProps);
45
+ setStep(step: number): void;
46
+ handleMouseMove: (e: MouseEvent) => void;
47
+ handleMouseUp: (e: MouseEvent) => void;
48
+ handleMouseDown: (e: MouseEvent) => void;
49
+ cancelDrag: () => void;
50
+ }
51
+ export default StepperDrag;
@@ -0,0 +1,145 @@
1
+ import { noop } from 'lodash-es';
2
+ import { EventType } from '../constant';
3
+ // TODO:这种方式在同构项目中,会报错,该如何解决(是否要求用户控制在浏览器环境时才初始化)
4
+ // const DOC: any = window?.document
5
+ var LEFT_MOUSE_BUTTON_CODE = 0;
6
+ /**
7
+ * 支持拖拽时按步长进行移动
8
+ * REMIND:在绘制的过程中因为放大缩小,移动的真实 step 是变化的
9
+ */
10
+ var StepperDrag = /** @class */ (function () {
11
+ function StepperDrag(_a) {
12
+ var _b = _a.onDragStart, onDragStart = _b === void 0 ? noop : _b, _c = _a.onDragging, onDragging = _c === void 0 ? noop : _c, _d = _a.onDragEnd, onDragEnd = _d === void 0 ? noop : _d, _e = _a.step, step = _e === void 0 ? 1 : _e, _f = _a.eventType, eventType = _f === void 0 ? '' : _f, _g = _a.isStopPropagation, isStopPropagation = _g === void 0 ? true : _g, eventCenter = _a.eventCenter, model = _a.model, data = _a.data;
13
+ var _this = this;
14
+ // 运行时
15
+ this.isDragging = false;
16
+ this.isStartDrag = false;
17
+ this.startX = 0;
18
+ this.startY = 0;
19
+ this.totalDeltaX = 0;
20
+ this.totalDeltaY = 0;
21
+ this.handleMouseMove = function (e) {
22
+ var _a, _b;
23
+ if (_this.isStopPropagation)
24
+ e.stopPropagation();
25
+ if (!_this.isStartDrag)
26
+ return;
27
+ _this.totalDeltaX += e.clientX - _this.startX;
28
+ _this.totalDeltaY += e.clientY - _this.startY;
29
+ _this.startX = e.clientX;
30
+ _this.startY = e.clientY;
31
+ if (_this.step <= 1 ||
32
+ Math.abs(_this.totalDeltaX) > _this.step ||
33
+ Math.abs(_this.totalDeltaY) > _this.step) {
34
+ var remainderX = _this.totalDeltaX % _this.step;
35
+ var remainderY = _this.totalDeltaY % _this.step;
36
+ var deltaX_1 = _this.totalDeltaX - remainderX;
37
+ var deltaY_1 = _this.totalDeltaY - remainderY;
38
+ _this.totalDeltaX = remainderX;
39
+ _this.totalDeltaY = remainderY;
40
+ var elementData_1 = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
41
+ // REMIND: 为了区分点击和拖动,在鼠标没有拖动时,不触发 dragstart。
42
+ if (!_this.isDragging) {
43
+ if (_this.eventType) {
44
+ (_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_DRAGSTART")], {
45
+ e: e,
46
+ data: _this.data || elementData_1,
47
+ });
48
+ }
49
+ _this.onDragStart({ event: e });
50
+ }
51
+ _this.isDragging = true;
52
+ // REMIND: 为了让 dragstart 和 drag 不在同一个事件循环中,将 drag 事件放在下一个任务队列中。
53
+ // TODO: 测试用例是否可覆盖???
54
+ Promise.resolve().then(function () {
55
+ var _a, _b;
56
+ _this.onDragging({ deltaX: deltaX_1, deltaY: deltaY_1, event: e });
57
+ if (_this.eventType) {
58
+ (_a = _this.eventCenter) === null || _a === void 0 ? void 0 : _a.emit(EventType["".concat(_this.eventType, "_MOUSEMOVE")], {
59
+ e: e,
60
+ data: _this.data || elementData_1,
61
+ });
62
+ (_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_DRAG")], {
63
+ e: e,
64
+ data: _this.data || elementData_1,
65
+ });
66
+ }
67
+ });
68
+ }
69
+ };
70
+ this.handleMouseUp = function (e) {
71
+ var DOC = window === null || window === void 0 ? void 0 : window.document;
72
+ _this.isStartDrag = false;
73
+ if (_this.isStopPropagation)
74
+ e.stopPropagation();
75
+ // fix: issue#568, 如果 onDragging 在下一个时间循环中触发,而 drop 在当前事件循环,会出现问题
76
+ Promise.resolve().then(function () {
77
+ var _a, _b, _c;
78
+ DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
79
+ DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
80
+ var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
81
+ if (_this.eventType) {
82
+ (_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_MOUSEUP")], {
83
+ e: e,
84
+ data: _this.data || elementData,
85
+ });
86
+ }
87
+ if (!_this.isDragging)
88
+ return;
89
+ _this.isDragging = false;
90
+ _this.onDragEnd({ event: e });
91
+ if (_this.eventType) {
92
+ (_c = _this.eventCenter) === null || _c === void 0 ? void 0 : _c.emit(EventType["".concat(_this.eventType, "_DROP")], {
93
+ e: e,
94
+ data: _this.data || elementData,
95
+ });
96
+ }
97
+ });
98
+ };
99
+ this.handleMouseDown = function (e) {
100
+ var _a, _b;
101
+ var DOC = window === null || window === void 0 ? void 0 : window.document;
102
+ // issue: LogicFlow交流群-3群 8.10 号抛出的事件相关的问题,是否是这引起的???
103
+ if (e.button !== LEFT_MOUSE_BUTTON_CODE)
104
+ return;
105
+ if (_this.isStopPropagation)
106
+ e.stopPropagation();
107
+ _this.isStartDrag = true;
108
+ _this.startX = e.clientX;
109
+ _this.startY = e.clientY;
110
+ DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mousemove', _this.handleMouseMove, true);
111
+ DOC === null || DOC === void 0 ? void 0 : DOC.addEventListener('mouseup', _this.handleMouseUp, true);
112
+ var elementData = (_a = _this.model) === null || _a === void 0 ? void 0 : _a.getData();
113
+ if (_this.eventType) {
114
+ (_b = _this.eventCenter) === null || _b === void 0 ? void 0 : _b.emit(EventType["".concat(_this.eventType, "_MOUSEDOWN")], {
115
+ e: e,
116
+ data: _this.data || elementData,
117
+ });
118
+ }
119
+ _this.startTime = new Date().getTime();
120
+ };
121
+ this.cancelDrag = function () {
122
+ var DOC = window === null || window === void 0 ? void 0 : window.document;
123
+ DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mousemove', _this.handleMouseMove, true);
124
+ DOC === null || DOC === void 0 ? void 0 : DOC.removeEventListener('mouseup', _this.handleMouseUp, true);
125
+ _this.onDragEnd({ event: null });
126
+ _this.isDragging = false;
127
+ };
128
+ this.onDragStart = onDragStart;
129
+ this.onDragging = onDragging;
130
+ this.onDragEnd = onDragEnd;
131
+ this.step = step;
132
+ this.eventType = eventType;
133
+ this.isStopPropagation = isStopPropagation;
134
+ this.eventCenter = eventCenter;
135
+ this.model = model;
136
+ this.data = data;
137
+ }
138
+ StepperDrag.prototype.setStep = function (step) {
139
+ this.step = step;
140
+ };
141
+ return StepperDrag;
142
+ }());
143
+ export { StepperDrag };
144
+ export default StepperDrag;
145
+ //# sourceMappingURL=drag.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drag.js","sourceRoot":"","sources":["../../src/common/drag.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import { IDisposer } from 'mobx-utils';
2
+ import { LogicFlow } from '../LogicFlow';
3
+ import { GraphModel } from '../model';
4
+ import EventEmitter from '../event/eventEmitter';
5
+ export type HistoryData = LogicFlow.GraphConfigData;
6
+ export declare class History {
7
+ undos: HistoryData[];
8
+ redos: HistoryData[];
9
+ stopWatch: IDisposer | null;
10
+ curData: HistoryData | null;
11
+ maxSize: number;
12
+ waitTime: number;
13
+ eventCenter: EventEmitter;
14
+ constructor(eventCenter: EventEmitter);
15
+ add(data: HistoryData): void;
16
+ undoAble(): boolean;
17
+ /**
18
+ * undo 方法触发:
19
+ * graphModel 重新渲染 nodes 和 edges
20
+ * graphModel 发生变化,触发 watch
21
+ * watch 触发 add
22
+ */
23
+ undo(): LogicFlow.GraphConfigData | undefined;
24
+ redoAble(): boolean;
25
+ redo(): LogicFlow.GraphConfigData | undefined;
26
+ watch(model: GraphModel): void;
27
+ }
28
+ export default History;
@@ -0,0 +1,92 @@
1
+ import { cloneDeep, debounce, isEqual, last } from 'lodash-es';
2
+ import { deepObserve } from 'mobx-utils';
3
+ var History = /** @class */ (function () {
4
+ function History(eventCenter) {
5
+ this.undos = [];
6
+ this.redos = [];
7
+ this.stopWatch = null;
8
+ this.curData = null;
9
+ this.maxSize = 50;
10
+ // 发生数据变化后,最多再等 500ms,把距离上次的数据变更存储起来。
11
+ // 所以 waitTime 值越小,History 对数据变化越敏感,存的 undos 数据就越细
12
+ this.waitTime = 100;
13
+ this.eventCenter = eventCenter;
14
+ }
15
+ History.prototype.add = function (data) {
16
+ if (isEqual(last(this.undos), data))
17
+ return;
18
+ this.undos.push(data);
19
+ // 因为 undo 的时候会触发 add.
20
+ // 所以需要区分这个 add 是 undo 触发的还是用户正常操作触发的
21
+ // 如果是用户正常操作触发的,需要清空 redos
22
+ if (!isEqual(this.curData, data)) {
23
+ this.redos = [];
24
+ }
25
+ // this.eventCenter.emit(EventType.HISTORY_CHANGE, {
26
+ // data: {
27
+ // undos: this.undos,
28
+ // redos: this.redos,
29
+ // undoAble: this.undos.length > 1,
30
+ // redoAble: this.redos.length > 0,
31
+ // },
32
+ // })
33
+ if (this.undos.length > this.maxSize) {
34
+ this.undos.shift();
35
+ }
36
+ };
37
+ History.prototype.undoAble = function () {
38
+ return this.undos.length > 1;
39
+ };
40
+ /**
41
+ * undo 方法触发:
42
+ * graphModel 重新渲染 nodes 和 edges
43
+ * graphModel 发生变化,触发 watch
44
+ * watch 触发 add
45
+ */
46
+ History.prototype.undo = function () {
47
+ if (!this.undoAble())
48
+ return;
49
+ var preData = this.undos.pop();
50
+ if (preData) {
51
+ this.redos.push(preData);
52
+ }
53
+ var curData = this.undos.pop();
54
+ if (curData) {
55
+ this.curData = cloneDeep(curData);
56
+ }
57
+ return curData;
58
+ };
59
+ History.prototype.redoAble = function () {
60
+ return this.redos.length > 0;
61
+ };
62
+ History.prototype.redo = function () {
63
+ if (!this.redoAble())
64
+ return;
65
+ var curData = this.redos.pop();
66
+ if (curData) {
67
+ this.curData = cloneDeep(curData);
68
+ }
69
+ return curData;
70
+ };
71
+ History.prototype.watch = function (model) {
72
+ var _this = this;
73
+ this.stopWatch && this.stopWatch();
74
+ // 把当前 watch 的 model 转换一下数据存起来,无需清空 redos
75
+ var historyData = model.modelToHistoryData();
76
+ if (historyData) {
77
+ this.undos.push(historyData);
78
+ }
79
+ this.stopWatch = deepObserve(model, debounce(function () {
80
+ // 数据变更后,把最新的当前 model 数据存起来,并清空 redos
81
+ // 因为这个回调函数的触发,一般是用户交互而引起的,所以按照正常逻辑需要清空 redos
82
+ var data = model.modelToHistoryData();
83
+ if (data) {
84
+ _this.add(data);
85
+ }
86
+ }, this.waitTime));
87
+ };
88
+ return History;
89
+ }());
90
+ export { History };
91
+ export default History;
92
+ //# sourceMappingURL=history.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"history.js","sourceRoot":"","sources":["../../src/common/history.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export * from './drag';
2
+ export * from './history';
3
+ export * from './keyboard';
4
+ export * from './matrix';
5
+ export * from './vector';
@@ -0,0 +1,6 @@
1
+ export * from './drag';
2
+ export * from './history';
3
+ export * from './keyboard';
4
+ export * from './matrix';
5
+ export * from './vector';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAE1B,cAAc,UAAU,CAAA;AACxB,cAAc,UAAU,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { MousetrapInstance } from 'mousetrap';
2
+ import LogicFlow from '..';
3
+ export declare class Keyboard {
4
+ private target;
5
+ readonly mousetrap: MousetrapInstance;
6
+ options: Required<Keyboard.Options>;
7
+ constructor(options: Keyboard.Options);
8
+ protected formatKey(key: string): string;
9
+ private getKeys;
10
+ get disabled(): boolean;
11
+ on(keys: string | string[], callback: Keyboard.HandlerFunc, action?: Keyboard.ActionType): void;
12
+ off(keys: string | string[], action?: Keyboard.ActionType): void;
13
+ enable(force: boolean): void;
14
+ disable(): void;
15
+ initShortcuts(): void;
16
+ }
17
+ export declare namespace Keyboard {
18
+ type ActionType = 'keypress' | 'keydown' | 'keyup';
19
+ type HandlerFunc = (e: KeyboardEvent) => void;
20
+ interface Shortcut {
21
+ keys: string | string[];
22
+ callback: HandlerFunc;
23
+ action?: ActionType;
24
+ }
25
+ interface KeyboardDef {
26
+ enabled: boolean;
27
+ shortcuts?: Shortcut | Shortcut[];
28
+ }
29
+ interface Options {
30
+ lf: LogicFlow;
31
+ keyboard?: KeyboardDef;
32
+ }
33
+ }
34
+ export default Keyboard;
@@ -0,0 +1,80 @@
1
+ import Mousetrap from 'mousetrap';
2
+ import { forEach, isArray } from 'lodash-es';
3
+ var Keyboard = /** @class */ (function () {
4
+ function Keyboard(options) {
5
+ var _a;
6
+ var lf = options.lf;
7
+ if (!options.keyboard) {
8
+ options.keyboard = { enabled: false };
9
+ }
10
+ this.options = options;
11
+ this.target = lf.container;
12
+ this.mousetrap = new Mousetrap(this.target);
13
+ if ((_a = options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) {
14
+ this.enable(true);
15
+ }
16
+ }
17
+ Keyboard.prototype.formatKey = function (key) {
18
+ return key
19
+ .toLowerCase()
20
+ .replace(/\s/g, '')
21
+ .replace('delete', 'del')
22
+ .replace('cmd', 'command');
23
+ };
24
+ Keyboard.prototype.getKeys = function (keys) {
25
+ var _this = this;
26
+ return (isArray(keys) ? keys : [keys]).map(function (key) { return _this.formatKey(key); });
27
+ };
28
+ Object.defineProperty(Keyboard.prototype, "disabled", {
29
+ get: function () {
30
+ var _a;
31
+ return ((_a = this.options.keyboard) === null || _a === void 0 ? void 0 : _a.enabled) !== true;
32
+ },
33
+ enumerable: false,
34
+ configurable: true
35
+ });
36
+ Keyboard.prototype.on = function (keys, callback, action) {
37
+ this.mousetrap.bind(this.getKeys(keys), callback, action);
38
+ };
39
+ Keyboard.prototype.off = function (keys, action) {
40
+ this.mousetrap.unbind(this.getKeys(keys), action);
41
+ };
42
+ Keyboard.prototype.enable = function (force) {
43
+ if (this.disabled || force) {
44
+ this.options.keyboard.enabled = true;
45
+ if (this.target instanceof HTMLElement) {
46
+ this.target.setAttribute('tabindex', '-1');
47
+ // 去掉节点被选中时 container 出现的边框
48
+ this.target.style.outline = 'none';
49
+ }
50
+ }
51
+ };
52
+ Keyboard.prototype.disable = function () {
53
+ if (!this.disabled) {
54
+ this.options.keyboard.enabled = false;
55
+ if (this.target instanceof HTMLElement) {
56
+ this.target.removeAttribute('tabindex');
57
+ }
58
+ }
59
+ };
60
+ Keyboard.prototype.initShortcuts = function () {
61
+ var _this = this;
62
+ var shortcuts = this.options.keyboard.shortcuts;
63
+ if (shortcuts) {
64
+ if (isArray(shortcuts)) {
65
+ forEach(shortcuts, function (_a) {
66
+ var keys = _a.keys, callback = _a.callback, action = _a.action;
67
+ _this.on(keys, callback, action);
68
+ });
69
+ }
70
+ else {
71
+ var keys = shortcuts.keys, callback = shortcuts.callback, action = shortcuts.action;
72
+ this.on(keys, callback, action);
73
+ }
74
+ }
75
+ };
76
+ return Keyboard;
77
+ }());
78
+ export { Keyboard };
79
+ export default Keyboard;
80
+ //# sourceMappingURL=keyboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keyboard.js","sourceRoot":"","sources":["../../src/common/keyboard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ export declare class Matrix extends Array {
2
+ rows: number;
3
+ columns: number;
4
+ constructor(...vectors: any[]);
5
+ getRow(index: number): any;
6
+ getColumn(index: number): number[];
7
+ transpose(): Matrix;
8
+ cross(m1: Matrix): Matrix;
9
+ to2D(): any[][];
10
+ toString(): string;
11
+ translate(tx: number, ty: number): Matrix;
12
+ rotate(angle: number): Matrix;
13
+ scale(sx: number, sy: number): Matrix;
14
+ }
15
+ export declare class RotateMatrix extends Matrix {
16
+ constructor(theta: number);
17
+ inverse(): Matrix;
18
+ }
19
+ export declare class ScaleMatrix extends Matrix {
20
+ private readonly sx;
21
+ private readonly sy;
22
+ constructor(sx: number, sy: number);
23
+ inverse(): ScaleMatrix;
24
+ }
25
+ export declare class TranslateMatrix extends Matrix {
26
+ private readonly tx;
27
+ private readonly ty;
28
+ constructor(tx: number, ty: number);
29
+ inverse(): TranslateMatrix;
30
+ }
@@ -0,0 +1,155 @@
1
+ var __extends = (this && this.__extends) || (function () {
2
+ var extendStatics = function (d, b) {
3
+ extendStatics = Object.setPrototypeOf ||
4
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
6
+ return extendStatics(d, b);
7
+ };
8
+ return function (d, b) {
9
+ if (typeof b !== "function" && b !== null)
10
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
11
+ extendStatics(d, b);
12
+ function __() { this.constructor = d; }
13
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
14
+ };
15
+ })();
16
+ var __read = (this && this.__read) || function (o, n) {
17
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
18
+ if (!m) return o;
19
+ var i = m.call(o), r, ar = [], e;
20
+ try {
21
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
22
+ }
23
+ catch (error) { e = { error: error }; }
24
+ finally {
25
+ try {
26
+ if (r && !r.done && (m = i["return"])) m.call(i);
27
+ }
28
+ finally { if (e) throw e.error; }
29
+ }
30
+ return ar;
31
+ };
32
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
33
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
34
+ if (ar || !(i in from)) {
35
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
36
+ ar[i] = from[i];
37
+ }
38
+ }
39
+ return to.concat(ar || Array.prototype.slice.call(from));
40
+ };
41
+ import { Vector } from './vector';
42
+ var Matrix = /** @class */ (function (_super) {
43
+ __extends(Matrix, _super);
44
+ function Matrix() {
45
+ var vectors = [];
46
+ for (var _i = 0; _i < arguments.length; _i++) {
47
+ vectors[_i] = arguments[_i];
48
+ }
49
+ var _this = _super.call(this, vectors.length) || this;
50
+ _this.fill(new Array(3));
51
+ vectors.forEach(function (v, index) {
52
+ _this[index] = v;
53
+ });
54
+ _this.columns = vectors[0].length;
55
+ _this.rows = vectors.length;
56
+ Object.setPrototypeOf(_this, Matrix.prototype);
57
+ return _this;
58
+ }
59
+ Matrix.prototype.getRow = function (index) {
60
+ return this[index];
61
+ };
62
+ Matrix.prototype.getColumn = function (index) {
63
+ return __spreadArray([], __read(this.map(function (row) { return row[index]; })), false);
64
+ };
65
+ // 转置
66
+ Matrix.prototype.transpose = function () {
67
+ var rows = [];
68
+ for (var i = 0; i < this.columns; i++) {
69
+ rows.push(this.getColumn(i));
70
+ }
71
+ return new (Matrix.bind.apply(Matrix, __spreadArray([void 0], __read(rows), false)))();
72
+ };
73
+ // 叉乘
74
+ Matrix.prototype.cross = function (m1) {
75
+ var arr = new Array(this.rows).fill('').map(function () { return []; });
76
+ if (this.columns === m1.rows) {
77
+ for (var i = 0; i < this.rows; i++) {
78
+ var row = this.getRow(i);
79
+ var _loop_1 = function (j) {
80
+ var column = m1.getColumn(j);
81
+ arr[i][j] = row.reduce(function (prev, r, index) {
82
+ return prev + r * column[index];
83
+ }, 0);
84
+ };
85
+ for (var j = 0; j < m1.columns; j++) {
86
+ _loop_1(j);
87
+ }
88
+ }
89
+ }
90
+ return new (Matrix.bind.apply(Matrix, __spreadArray([void 0], __read(arr), false)))();
91
+ };
92
+ // 返回二维坐标(降维)
93
+ Matrix.prototype.to2D = function () {
94
+ return this.map(function (item) { return [item[0], item[1]]; });
95
+ };
96
+ Matrix.prototype.toString = function () {
97
+ var _a = __read(this, 3), _b = __read(_a[0], 2), a = _b[0], b = _b[1], _c = __read(_a[1], 2), c = _c[0], d = _c[1], _d = __read(_a[2], 2), e = _d[0], f = _d[1];
98
+ return "matrix(".concat(a, " ").concat(b, " ").concat(c, " ").concat(d, " ").concat(e, " ").concat(f, ")");
99
+ };
100
+ Matrix.prototype.translate = function (tx, ty) {
101
+ return this.cross(new TranslateMatrix(tx, ty));
102
+ };
103
+ Matrix.prototype.rotate = function (angle) {
104
+ return this.cross(new RotateMatrix(angle));
105
+ };
106
+ Matrix.prototype.scale = function (sx, sy) {
107
+ return this.cross(new ScaleMatrix(sx, sy));
108
+ };
109
+ return Matrix;
110
+ }(Array));
111
+ export { Matrix };
112
+ var RotateMatrix = /** @class */ (function (_super) {
113
+ __extends(RotateMatrix, _super);
114
+ function RotateMatrix(theta) {
115
+ var _this = _super.call(this, new Vector(+Math.cos(theta).toFixed(2), +Math.sin(theta).toFixed(2), 0), new Vector(-Math.sin(theta).toFixed(2), +Math.cos(theta).toFixed(2), 0), new Vector(0, 0, 1)) || this;
116
+ Object.setPrototypeOf(_this, RotateMatrix.prototype);
117
+ return _this;
118
+ }
119
+ RotateMatrix.prototype.inverse = function () {
120
+ return this.transpose();
121
+ };
122
+ return RotateMatrix;
123
+ }(Matrix));
124
+ export { RotateMatrix };
125
+ var ScaleMatrix = /** @class */ (function (_super) {
126
+ __extends(ScaleMatrix, _super);
127
+ function ScaleMatrix(sx, sy) {
128
+ var _this = _super.call(this, new Vector(sx, 0, 0), new Vector(0, sy, 0), new Vector(0, 0, 1)) || this;
129
+ _this.sx = sx;
130
+ _this.sy = sy;
131
+ Object.setPrototypeOf(_this, ScaleMatrix.prototype);
132
+ return _this;
133
+ }
134
+ ScaleMatrix.prototype.inverse = function () {
135
+ return new ScaleMatrix(1 / this.sx, 1 / this.sy);
136
+ };
137
+ return ScaleMatrix;
138
+ }(Matrix));
139
+ export { ScaleMatrix };
140
+ var TranslateMatrix = /** @class */ (function (_super) {
141
+ __extends(TranslateMatrix, _super);
142
+ function TranslateMatrix(tx, ty) {
143
+ var _this = _super.call(this, new Vector(1, 0, 0), new Vector(0, 1, 0), new Vector(tx, ty, 1)) || this;
144
+ _this.tx = tx;
145
+ _this.ty = ty;
146
+ Object.setPrototypeOf(_this, TranslateMatrix.prototype);
147
+ return _this;
148
+ }
149
+ TranslateMatrix.prototype.inverse = function () {
150
+ return new TranslateMatrix(-this.tx, -this.ty);
151
+ };
152
+ return TranslateMatrix;
153
+ }(Matrix));
154
+ export { TranslateMatrix };
155
+ //# sourceMappingURL=matrix.js.map