@pie-lib/graphing 4.0.5-next.31 → 4.0.5-next.34

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 (453) hide show
  1. package/CHANGELOG.json +1 -0
  2. package/CHANGELOG.md +1469 -0
  3. package/LICENSE.md +5 -0
  4. package/lib/axis/arrow.js +79 -0
  5. package/lib/axis/arrow.js.map +1 -0
  6. package/lib/axis/axes.js +329 -0
  7. package/lib/axis/axes.js.map +1 -0
  8. package/lib/axis/index.js +21 -0
  9. package/lib/axis/index.js.map +1 -0
  10. package/lib/bg.js +114 -0
  11. package/lib/bg.js.map +1 -0
  12. package/lib/container/actions.js +18 -0
  13. package/lib/container/actions.js.map +1 -0
  14. package/lib/container/index.js +127 -0
  15. package/lib/container/index.js.map +1 -0
  16. package/lib/container/marks.js +22 -0
  17. package/lib/container/marks.js.map +1 -0
  18. package/lib/container/middleware.js +19 -0
  19. package/lib/container/middleware.js.map +1 -0
  20. package/lib/container/reducer.js +18 -0
  21. package/lib/container/reducer.js.map +1 -0
  22. package/lib/coordinates-label.js +79 -0
  23. package/lib/coordinates-label.js.map +1 -0
  24. package/lib/graph-with-controls.js +294 -0
  25. package/lib/graph-with-controls.js.map +1 -0
  26. package/lib/graph.js +327 -0
  27. package/lib/graph.js.map +1 -0
  28. package/lib/grid-setup.js +414 -0
  29. package/lib/grid-setup.js.map +1 -0
  30. package/lib/grid.js +131 -0
  31. package/lib/grid.js.map +1 -0
  32. package/lib/index.js +47 -0
  33. package/lib/index.js.map +1 -0
  34. package/lib/key-legend.js +201 -0
  35. package/lib/key-legend.js.map +1 -0
  36. package/lib/label-svg-icon.js +50 -0
  37. package/lib/label-svg-icon.js.map +1 -0
  38. package/lib/labels.js +243 -0
  39. package/lib/labels.js.map +1 -0
  40. package/lib/mark-label.js +285 -0
  41. package/lib/mark-label.js.map +1 -0
  42. package/lib/toggle-bar.js +252 -0
  43. package/lib/toggle-bar.js.map +1 -0
  44. package/lib/tool-menu.js +78 -0
  45. package/lib/tool-menu.js.map +1 -0
  46. package/lib/tools/absolute/component.js +29 -0
  47. package/lib/tools/absolute/component.js.map +1 -0
  48. package/lib/tools/absolute/index.js +50 -0
  49. package/lib/tools/absolute/index.js.map +1 -0
  50. package/lib/tools/circle/bg-circle.js +123 -0
  51. package/lib/tools/circle/bg-circle.js.map +1 -0
  52. package/lib/tools/circle/component.js +321 -0
  53. package/lib/tools/circle/component.js.map +1 -0
  54. package/lib/tools/circle/index.js +41 -0
  55. package/lib/tools/circle/index.js.map +1 -0
  56. package/lib/tools/exponential/component.js +28 -0
  57. package/lib/tools/exponential/component.js.map +1 -0
  58. package/lib/tools/exponential/index.js +56 -0
  59. package/lib/tools/exponential/index.js.map +1 -0
  60. package/lib/tools/index.js +86 -0
  61. package/lib/tools/index.js.map +1 -0
  62. package/lib/tools/line/component.js +97 -0
  63. package/lib/tools/line/component.js.map +1 -0
  64. package/lib/tools/line/index.js +11 -0
  65. package/lib/tools/line/index.js.map +1 -0
  66. package/lib/tools/parabola/component.js +28 -0
  67. package/lib/tools/parabola/component.js.map +1 -0
  68. package/lib/tools/parabola/index.js +50 -0
  69. package/lib/tools/parabola/index.js.map +1 -0
  70. package/lib/tools/point/component.js +148 -0
  71. package/lib/tools/point/component.js.map +1 -0
  72. package/lib/tools/point/index.js +24 -0
  73. package/lib/tools/point/index.js.map +1 -0
  74. package/lib/tools/polygon/component.js +437 -0
  75. package/lib/tools/polygon/component.js.map +1 -0
  76. package/lib/tools/polygon/index.js +89 -0
  77. package/lib/tools/polygon/index.js.map +1 -0
  78. package/lib/tools/polygon/line.js +112 -0
  79. package/lib/tools/polygon/line.js.map +1 -0
  80. package/lib/tools/polygon/polygon.js +130 -0
  81. package/lib/tools/polygon/polygon.js.map +1 -0
  82. package/lib/tools/ray/component.js +95 -0
  83. package/lib/tools/ray/component.js.map +1 -0
  84. package/lib/tools/ray/index.js +11 -0
  85. package/lib/tools/ray/index.js.map +1 -0
  86. package/lib/tools/segment/component.js +71 -0
  87. package/lib/tools/segment/component.js.map +1 -0
  88. package/lib/tools/segment/index.js +11 -0
  89. package/lib/tools/segment/index.js.map +1 -0
  90. package/lib/tools/shared/arrow-head.js +111 -0
  91. package/lib/tools/shared/arrow-head.js.map +1 -0
  92. package/lib/tools/shared/icons/CorrectSVG.js +40 -0
  93. package/lib/tools/shared/icons/CorrectSVG.js.map +1 -0
  94. package/lib/tools/shared/icons/IncorrectSVG.js +40 -0
  95. package/lib/tools/shared/icons/IncorrectSVG.js.map +1 -0
  96. package/lib/tools/shared/icons/MissingSVG.js +39 -0
  97. package/lib/tools/shared/icons/MissingSVG.js.map +1 -0
  98. package/lib/tools/shared/line/index.js +550 -0
  99. package/lib/tools/shared/line/index.js.map +1 -0
  100. package/lib/tools/shared/line/line-path.js +118 -0
  101. package/lib/tools/shared/line/line-path.js.map +1 -0
  102. package/lib/tools/shared/line/with-root-edge.js +121 -0
  103. package/lib/tools/shared/line/with-root-edge.js.map +1 -0
  104. package/lib/tools/shared/point/arrow-point.js +72 -0
  105. package/lib/tools/shared/point/arrow-point.js.map +1 -0
  106. package/lib/tools/shared/point/arrow.js +67 -0
  107. package/lib/tools/shared/point/arrow.js.map +1 -0
  108. package/lib/tools/shared/point/base-point.js +157 -0
  109. package/lib/tools/shared/point/base-point.js.map +1 -0
  110. package/lib/tools/shared/point/index.js +68 -0
  111. package/lib/tools/shared/point/index.js.map +1 -0
  112. package/lib/tools/shared/styles.js +33 -0
  113. package/lib/tools/shared/styles.js.map +1 -0
  114. package/lib/tools/shared/types.js +16 -0
  115. package/lib/tools/shared/types.js.map +1 -0
  116. package/lib/tools/sine/component.js +40 -0
  117. package/lib/tools/sine/component.js.map +1 -0
  118. package/lib/tools/sine/index.js +50 -0
  119. package/lib/tools/sine/index.js.map +1 -0
  120. package/lib/tools/vector/component.js +68 -0
  121. package/lib/tools/vector/component.js.map +1 -0
  122. package/lib/tools/vector/index.js +11 -0
  123. package/lib/tools/vector/index.js.map +1 -0
  124. package/lib/undo-redo.js +86 -0
  125. package/lib/undo-redo.js.map +1 -0
  126. package/lib/use-debounce.js +25 -0
  127. package/lib/use-debounce.js.map +1 -0
  128. package/lib/utils.js +229 -0
  129. package/lib/utils.js.map +1 -0
  130. package/package.json +33 -45
  131. package/src/__tests__/bg.test.jsx +250 -0
  132. package/src/__tests__/coordinates-label.test.jsx +243 -0
  133. package/src/__tests__/graph-with-controls.test.jsx +198 -0
  134. package/src/__tests__/graph.test.jsx +721 -0
  135. package/src/__tests__/grid-setup.test.jsx +645 -0
  136. package/src/__tests__/grid.test.jsx +22 -0
  137. package/src/__tests__/key-legend.test.jsx +260 -0
  138. package/src/__tests__/label-svg-icon.test.jsx +278 -0
  139. package/src/__tests__/labels.test.jsx +55 -0
  140. package/src/__tests__/mark-label.test.jsx +63 -0
  141. package/src/__tests__/toggle-bar.test.jsx +146 -0
  142. package/src/__tests__/tool-menu.test.jsx +115 -0
  143. package/src/__tests__/undo-redo.test.jsx +24 -0
  144. package/src/__tests__/use-debounce.test.js +21 -0
  145. package/src/__tests__/utils.js +41 -0
  146. package/src/__tests__/utils.test.js +105 -0
  147. package/src/axis/__tests__/arrow.test.jsx +38 -0
  148. package/src/axis/__tests__/axes.test.jsx +216 -0
  149. package/src/axis/arrow.jsx +57 -0
  150. package/src/axis/axes.jsx +285 -0
  151. package/src/axis/index.js +3 -0
  152. package/src/bg.jsx +96 -0
  153. package/src/container/__tests__/actions.test.js +105 -0
  154. package/src/container/__tests__/index.test.jsx +319 -0
  155. package/src/container/__tests__/marks.test.js +172 -0
  156. package/src/container/__tests__/middleware.test.js +235 -0
  157. package/src/container/__tests__/reducer.test.js +324 -0
  158. package/src/container/actions.js +8 -0
  159. package/src/container/index.jsx +91 -0
  160. package/src/container/marks.js +14 -0
  161. package/src/container/middleware.js +7 -0
  162. package/src/container/reducer.js +5 -0
  163. package/src/coordinates-label.jsx +63 -0
  164. package/src/graph-with-controls.jsx +239 -0
  165. package/src/graph.jsx +303 -0
  166. package/src/grid-setup.jsx +432 -0
  167. package/src/grid.jsx +133 -0
  168. package/src/index.js +7 -0
  169. package/src/key-legend.jsx +142 -0
  170. package/src/label-svg-icon.jsx +39 -0
  171. package/src/labels.jsx +207 -0
  172. package/src/mark-label.jsx +244 -0
  173. package/src/toggle-bar.jsx +224 -0
  174. package/src/tool-menu.jsx +49 -0
  175. package/src/tools/absolute/__tests__/component.test.jsx +53 -0
  176. package/src/tools/absolute/component.jsx +23 -0
  177. package/src/tools/absolute/index.js +31 -0
  178. package/src/tools/circle/__tests__/bg-circle.test.jsx +26 -0
  179. package/src/tools/circle/__tests__/component.test.jsx +494 -0
  180. package/src/tools/circle/__tests__/index.test.js +480 -0
  181. package/src/tools/circle/bg-circle.jsx +81 -0
  182. package/src/tools/circle/component.jsx +264 -0
  183. package/src/tools/circle/index.js +25 -0
  184. package/src/tools/exponential/__tests__/component.test.jsx +53 -0
  185. package/src/tools/exponential/__tests__/index.test.js +729 -0
  186. package/src/tools/exponential/component.jsx +23 -0
  187. package/src/tools/exponential/index.js +39 -0
  188. package/src/tools/index.js +48 -0
  189. package/src/tools/line/__tests__/component.test.jsx +37 -0
  190. package/src/tools/line/component.jsx +93 -0
  191. package/src/tools/line/index.js +4 -0
  192. package/src/tools/parabola/__tests__/component.test.jsx +48 -0
  193. package/src/tools/parabola/__tests__/index.test.js +470 -0
  194. package/src/tools/parabola/component.jsx +23 -0
  195. package/src/tools/parabola/index.js +31 -0
  196. package/src/tools/point/__tests__/component.test.jsx +349 -0
  197. package/src/tools/point/__tests__/index.test.js +241 -0
  198. package/src/tools/point/component.jsx +126 -0
  199. package/src/tools/point/index.js +11 -0
  200. package/src/tools/polygon/__tests__/component.test.jsx +471 -0
  201. package/src/tools/polygon/__tests__/index.test.js +294 -0
  202. package/src/tools/polygon/__tests__/line.test.jsx +35 -0
  203. package/src/tools/polygon/__tests__/polygon.test.jsx +61 -0
  204. package/src/tools/polygon/component.jsx +409 -0
  205. package/src/tools/polygon/index.js +52 -0
  206. package/src/tools/polygon/line.jsx +74 -0
  207. package/src/tools/polygon/polygon.jsx +110 -0
  208. package/src/tools/ray/__tests__/component.test.jsx +29 -0
  209. package/src/tools/ray/component.jsx +92 -0
  210. package/src/tools/ray/index.js +4 -0
  211. package/src/tools/segment/__tests__/component.test.jsx +28 -0
  212. package/src/tools/segment/component.jsx +65 -0
  213. package/src/tools/segment/index.js +4 -0
  214. package/src/tools/shared/__tests__/arrow-head.test.jsx +31 -0
  215. package/src/tools/shared/arrow-head.jsx +102 -0
  216. package/src/tools/shared/icons/CorrectSVG.jsx +32 -0
  217. package/src/tools/shared/icons/IncorrectSVG.jsx +30 -0
  218. package/src/tools/shared/icons/MissingSVG.jsx +31 -0
  219. package/src/tools/shared/line/__tests__/index.test.jsx +109 -0
  220. package/src/tools/shared/line/__tests__/line-path.test.jsx +53 -0
  221. package/src/tools/shared/line/__tests__/with-root-edge.test.jsx +73 -0
  222. package/src/tools/shared/line/index.jsx +487 -0
  223. package/src/tools/shared/line/line-path.jsx +80 -0
  224. package/src/tools/shared/line/with-root-edge.jsx +97 -0
  225. package/src/tools/shared/point/__tests__/arrow-point.test.jsx +91 -0
  226. package/src/tools/shared/point/__tests__/base-point.test.jsx +87 -0
  227. package/src/tools/shared/point/arrow-point.jsx +46 -0
  228. package/src/tools/shared/point/arrow.jsx +37 -0
  229. package/src/tools/shared/point/base-point.jsx +121 -0
  230. package/src/tools/shared/point/index.jsx +54 -0
  231. package/src/tools/shared/styles.js +27 -0
  232. package/src/tools/shared/types.js +10 -0
  233. package/src/tools/sine/__tests__/component.test.jsx +51 -0
  234. package/src/tools/sine/component.jsx +32 -0
  235. package/src/tools/sine/index.js +33 -0
  236. package/src/tools/vector/__tests__/component.test.jsx +25 -0
  237. package/src/tools/vector/component.jsx +56 -0
  238. package/src/tools/vector/index.js +4 -0
  239. package/src/undo-redo.jsx +45 -0
  240. package/src/use-debounce.js +13 -0
  241. package/src/utils.js +224 -0
  242. package/dist/_virtual/_rolldown/runtime.js +0 -23
  243. package/dist/autosize-input.d.ts +0 -10
  244. package/dist/autosize-input.js +0 -66
  245. package/dist/axis/arrow.d.ts +0 -13
  246. package/dist/axis/arrow.js +0 -34
  247. package/dist/axis/axes.d.ts +0 -132
  248. package/dist/axis/axes.js +0 -214
  249. package/dist/axis/index.d.ts +0 -10
  250. package/dist/bg.d.ts +0 -51
  251. package/dist/bg.js +0 -44
  252. package/dist/container/actions.d.ts +0 -15
  253. package/dist/container/actions.js +0 -7
  254. package/dist/container/index.d.ts +0 -58
  255. package/dist/container/index.js +0 -48
  256. package/dist/container/marks.d.ts +0 -10
  257. package/dist/container/marks.js +0 -11
  258. package/dist/container/middleware.d.ts +0 -10
  259. package/dist/container/middleware.js +0 -4
  260. package/dist/container/reducer.d.ts +0 -14
  261. package/dist/container/reducer.js +0 -7
  262. package/dist/coordinates-label.d.ts +0 -50
  263. package/dist/coordinates-label.js +0 -46
  264. package/dist/graph-with-controls.d.ts +0 -88
  265. package/dist/graph-with-controls.js +0 -154
  266. package/dist/graph.d.ts +0 -126
  267. package/dist/graph.js +0 -209
  268. package/dist/grid-setup.d.ts +0 -27
  269. package/dist/grid-setup.js +0 -307
  270. package/dist/grid.d.ts +0 -43
  271. package/dist/grid.js +0 -59
  272. package/dist/index.d.ts +0 -15
  273. package/dist/index.js +0 -7
  274. package/dist/key-legend.d.ts +0 -21
  275. package/dist/key-legend.js +0 -231
  276. package/dist/label-svg-icon.d.ts +0 -18
  277. package/dist/label-svg-icon.js +0 -42
  278. package/dist/labels.d.ts +0 -37
  279. package/dist/labels.js +0 -152
  280. package/dist/mark-label.d.ts +0 -58
  281. package/dist/mark-label.js +0 -171
  282. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Axis.js +0 -101
  283. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisRenderer.js +0 -63
  284. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Ticks.js +0 -44
  285. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/constants/orientation.js +0 -9
  286. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/createPoint.js +0 -14
  287. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getAxisRangePaddingConfig.js +0 -21
  288. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getLabelTransform.js +0 -16
  289. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickFormatter.js +0 -8
  290. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickPosition.js +0 -15
  291. package/dist/node_modules/.bun/@visx_curve@3.12.0/node_modules/@visx/curve/esm/index.js +0 -2
  292. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/Grid.js +0 -79
  293. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridColumns.js +0 -79
  294. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridRows.js +0 -79
  295. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/utils/getScaleBandwidth.js +0 -6
  296. package/dist/node_modules/.bun/@visx_group@3.12.0_f4eacebf2041cd4f/node_modules/@visx/group/esm/Group.js +0 -50
  297. package/dist/node_modules/.bun/@visx_point@3.12.0/node_modules/@visx/point/esm/Point.js +0 -18
  298. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/coerceNumber.js +0 -10
  299. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/getTicks.js +0 -9
  300. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/toString.js +0 -6
  301. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Line.js +0 -47
  302. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/LinePath.js +0 -50
  303. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/D3ShapeFactories.js +0 -9
  304. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/setNumberOrNumberAccessor.js +0 -6
  305. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/lib/shapes/Line.js +0 -53
  306. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/Text.js +0 -57
  307. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/hooks/useText.js +0 -91
  308. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/util/getStringWidth.js +0 -21
  309. package/dist/node_modules/.bun/balanced-match@0.4.2/node_modules/balanced-match/index.js +0 -32
  310. package/dist/node_modules/.bun/balanced-match@1.0.2/node_modules/balanced-match/index.js +0 -33
  311. package/dist/node_modules/.bun/classnames@2.5.1/node_modules/classnames/index.js +0 -32
  312. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +0 -16
  313. package/dist/node_modules/.bun/invariant@2.2.4/node_modules/invariant/browser.js +0 -28
  314. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_Hash.js +0 -21
  315. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_ListCache.js +0 -21
  316. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_Map.js +0 -10
  317. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_MapCache.js +0 -21
  318. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_Symbol.js +0 -9
  319. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_assocIndexOf.js +0 -14
  320. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_baseGetTag.js +0 -15
  321. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_baseIsNative.js +0 -16
  322. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_coreJsData.js +0 -9
  323. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_freeGlobal.js +0 -8
  324. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_getMapData.js +0 -14
  325. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_getNative.js +0 -15
  326. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_getRawTag.js +0 -19
  327. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_getValue.js +0 -11
  328. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_hashClear.js +0 -13
  329. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_hashDelete.js +0 -12
  330. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_hashGet.js +0 -18
  331. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_hashHas.js +0 -14
  332. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_hashSet.js +0 -14
  333. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_isKeyable.js +0 -12
  334. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_isMasked.js +0 -16
  335. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_listCacheClear.js +0 -11
  336. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_listCacheDelete.js +0 -14
  337. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_listCacheGet.js +0 -14
  338. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_listCacheHas.js +0 -13
  339. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_listCacheSet.js +0 -14
  340. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_mapCacheClear.js +0 -19
  341. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_mapCacheDelete.js +0 -14
  342. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_mapCacheGet.js +0 -13
  343. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_mapCacheHas.js +0 -13
  344. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_mapCacheSet.js +0 -14
  345. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_nativeCreate.js +0 -9
  346. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_objectToString.js +0 -12
  347. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_root.js +0 -10
  348. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/_toSource.js +0 -20
  349. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/eq.js +0 -11
  350. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/isFunction.js +0 -16
  351. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/isObject.js +0 -12
  352. package/dist/node_modules/.bun/lodash@4.17.21/node_modules/lodash/memoize.js +0 -20
  353. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/formula_evaluator.js +0 -37
  354. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/lexer.js +0 -509
  355. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/math_function.js +0 -108
  356. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix.js +0 -31
  357. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix_evaluator.js +0 -45
  358. package/dist/node_modules/.bun/react-redux@9.3.0_9e2203c65d1d5fa1/node_modules/react-redux/dist/react-redux.js +0 -471
  359. package/dist/node_modules/.bun/reduce-css-calc@1.3.0/node_modules/reduce-css-calc/index.js +0 -49
  360. package/dist/node_modules/.bun/reduce-function-call@1.0.3/node_modules/reduce-function-call/index.js +0 -34
  361. package/dist/node_modules/.bun/redux-undo@1.1.0/node_modules/redux-undo/dist/redux-undo.js +0 -185
  362. package/dist/node_modules/.bun/redux@5.0.1/node_modules/redux/dist/redux.js +0 -198
  363. package/dist/node_modules/.bun/use-sync-external-store@1.6.0_f4eacebf2041cd4f/node_modules/use-sync-external-store/cjs/use-sync-external-store-with-selector.development.js +0 -53
  364. package/dist/node_modules/.bun/use-sync-external-store@1.6.0_f4eacebf2041cd4f/node_modules/use-sync-external-store/cjs/use-sync-external-store-with-selector.production.js +0 -51
  365. package/dist/node_modules/.bun/use-sync-external-store@1.6.0_f4eacebf2041cd4f/node_modules/use-sync-external-store/with-selector.js +0 -10
  366. package/dist/toggle-bar.d.ts +0 -40
  367. package/dist/toggle-bar.js +0 -155
  368. package/dist/tool-menu.d.ts +0 -29
  369. package/dist/tool-menu.js +0 -41
  370. package/dist/tools/absolute/component.d.ts +0 -16
  371. package/dist/tools/absolute/component.js +0 -15
  372. package/dist/tools/absolute/index.d.ts +0 -20
  373. package/dist/tools/absolute/index.js +0 -32
  374. package/dist/tools/circle/bg-circle.d.ts +0 -116
  375. package/dist/tools/circle/bg-circle.js +0 -72
  376. package/dist/tools/circle/component.d.ts +0 -83
  377. package/dist/tools/circle/component.js +0 -195
  378. package/dist/tools/circle/index.d.ts +0 -20
  379. package/dist/tools/circle/index.js +0 -22
  380. package/dist/tools/exponential/component.d.ts +0 -16
  381. package/dist/tools/exponential/component.js +0 -14
  382. package/dist/tools/exponential/index.d.ts +0 -20
  383. package/dist/tools/exponential/index.js +0 -32
  384. package/dist/tools/index.d.ts +0 -27
  385. package/dist/tools/index.js +0 -55
  386. package/dist/tools/line/component.d.ts +0 -124
  387. package/dist/tools/line/component.js +0 -72
  388. package/dist/tools/line/index.d.ts +0 -13
  389. package/dist/tools/line/index.js +0 -6
  390. package/dist/tools/parabola/component.d.ts +0 -16
  391. package/dist/tools/parabola/component.js +0 -14
  392. package/dist/tools/parabola/index.d.ts +0 -20
  393. package/dist/tools/parabola/index.js +0 -32
  394. package/dist/tools/point/component.d.ts +0 -50
  395. package/dist/tools/point/component.js +0 -85
  396. package/dist/tools/point/index.d.ts +0 -15
  397. package/dist/tools/point/index.js +0 -13
  398. package/dist/tools/polygon/component.d.ts +0 -120
  399. package/dist/tools/polygon/component.js +0 -262
  400. package/dist/tools/polygon/index.d.ts +0 -19
  401. package/dist/tools/polygon/index.js +0 -55
  402. package/dist/tools/polygon/line.d.ts +0 -125
  403. package/dist/tools/polygon/line.js +0 -63
  404. package/dist/tools/polygon/polygon.d.ts +0 -122
  405. package/dist/tools/polygon/polygon.js +0 -74
  406. package/dist/tools/ray/component.d.ts +0 -101
  407. package/dist/tools/ray/component.js +0 -71
  408. package/dist/tools/ray/index.d.ts +0 -13
  409. package/dist/tools/ray/index.js +0 -6
  410. package/dist/tools/segment/component.d.ts +0 -100
  411. package/dist/tools/segment/component.js +0 -52
  412. package/dist/tools/segment/index.d.ts +0 -13
  413. package/dist/tools/segment/index.js +0 -6
  414. package/dist/tools/shared/arrow-head.d.ts +0 -51
  415. package/dist/tools/shared/arrow-head.js +0 -63
  416. package/dist/tools/shared/icons/CorrectSVG.d.ts +0 -26
  417. package/dist/tools/shared/icons/CorrectSVG.js +0 -29
  418. package/dist/tools/shared/icons/IncorrectSVG.d.ts +0 -26
  419. package/dist/tools/shared/icons/IncorrectSVG.js +0 -27
  420. package/dist/tools/shared/icons/MissingSVG.d.ts +0 -26
  421. package/dist/tools/shared/icons/MissingSVG.js +0 -28
  422. package/dist/tools/shared/line/index.d.ts +0 -245
  423. package/dist/tools/shared/line/index.js +0 -319
  424. package/dist/tools/shared/line/line-path.d.ts +0 -57
  425. package/dist/tools/shared/line/line-path.js +0 -71
  426. package/dist/tools/shared/line/with-root-edge.d.ts +0 -142
  427. package/dist/tools/shared/line/with-root-edge.js +0 -73
  428. package/dist/tools/shared/point/arrow-point.d.ts +0 -56
  429. package/dist/tools/shared/point/arrow-point.js +0 -41
  430. package/dist/tools/shared/point/arrow.d.ts +0 -45
  431. package/dist/tools/shared/point/arrow.js +0 -35
  432. package/dist/tools/shared/point/base-point.d.ts +0 -52
  433. package/dist/tools/shared/point/base-point.js +0 -103
  434. package/dist/tools/shared/point/index.d.ts +0 -216
  435. package/dist/tools/shared/point/index.js +0 -45
  436. package/dist/tools/shared/styles.d.ts +0 -29
  437. package/dist/tools/shared/styles.js +0 -20
  438. package/dist/tools/shared/types.d.ts +0 -21
  439. package/dist/tools/shared/types.js +0 -11
  440. package/dist/tools/sine/component.d.ts +0 -16
  441. package/dist/tools/sine/component.js +0 -22
  442. package/dist/tools/sine/index.d.ts +0 -20
  443. package/dist/tools/sine/index.js +0 -32
  444. package/dist/tools/vector/component.d.ts +0 -100
  445. package/dist/tools/vector/component.js +0 -44
  446. package/dist/tools/vector/index.d.ts +0 -13
  447. package/dist/tools/vector/index.js +0 -6
  448. package/dist/undo-redo.d.ts +0 -22
  449. package/dist/undo-redo.js +0 -47
  450. package/dist/use-debounce.d.ts +0 -9
  451. package/dist/use-debounce.js +0 -13
  452. package/dist/utils.d.ts +0 -61
  453. package/dist/utils.js +0 -75
@@ -0,0 +1,721 @@
1
+ import React from 'react';
2
+ import { render } from '@pie-lib/test-utils';
3
+ import { graphProps } from './utils';
4
+ import Graph, { removeBuildingToolIfCurrentToolDiffers } from '../graph';
5
+ import { toolsArr } from '../tools';
6
+
7
+ describe('removeBuildingToolIfCurrentToolDiffers', () => {
8
+ let marks = [
9
+ {
10
+ type: 'point',
11
+ x: 2,
12
+ y: 2,
13
+ label: 'Point',
14
+ showLabel: true,
15
+ },
16
+ {
17
+ type: 'line',
18
+ from: { x: 0, y: 0 },
19
+ to: { x: 1, y: 1 },
20
+ label: 'Line',
21
+ building: true,
22
+ },
23
+ ];
24
+
25
+ it('keeps all marks if currentTool is the same', () => {
26
+ expect(removeBuildingToolIfCurrentToolDiffers({ marks, currentTool: { type: 'line' } })).toEqual(marks);
27
+ });
28
+
29
+ it('removes building marks if currentTool is different', () => {
30
+ expect(removeBuildingToolIfCurrentToolDiffers({ marks, currentTool: { type: 'different' } })).toEqual([marks[0]]);
31
+ });
32
+ });
33
+
34
+ describe('Graph', () => {
35
+ let onChangeMarks = jest.fn();
36
+
37
+ const defaultProps = {
38
+ className: 'className',
39
+ onChangeMarks,
40
+ tools: toolsArr,
41
+ domain: { min: 0, max: 1, step: 1 },
42
+ range: { min: 0, max: 1, step: 1 },
43
+ size: { width: 400, height: 400 },
44
+ marks: [
45
+ {
46
+ type: 'point',
47
+ x: 2,
48
+ y: 2,
49
+ label: 'Point',
50
+ showLabel: true,
51
+ },
52
+ {
53
+ type: 'line',
54
+ from: { x: 0, y: 0 },
55
+ to: { x: 1, y: 1 },
56
+ label: 'Line',
57
+ },
58
+ ],
59
+ ...graphProps(),
60
+ };
61
+
62
+ beforeEach(() => {
63
+ onChangeMarks.mockClear();
64
+ });
65
+
66
+ describe('rendering', () => {
67
+ it('renders without crashing', () => {
68
+ const { container } = render(<Graph {...defaultProps} />);
69
+ expect(container.firstChild).toBeInTheDocument();
70
+ });
71
+
72
+ it('renders with currentTool', () => {
73
+ const props = {
74
+ ...defaultProps,
75
+ currentTool: toolsArr[0],
76
+ };
77
+ const { container } = render(<Graph {...props} />);
78
+ expect(container.firstChild).toBeInTheDocument();
79
+ });
80
+
81
+ it('renders with marks', () => {
82
+ const { container } = render(<Graph {...defaultProps} />);
83
+ expect(container.firstChild).toBeInTheDocument();
84
+ });
85
+
86
+ it('renders with empty marks array', () => {
87
+ const props = {
88
+ ...defaultProps,
89
+ marks: [],
90
+ };
91
+ const { container } = render(<Graph {...props} />);
92
+ expect(container.firstChild).toBeInTheDocument();
93
+ });
94
+
95
+ it('renders with labelModeEnabled', () => {
96
+ const props = {
97
+ ...defaultProps,
98
+ labelModeEnabled: true,
99
+ };
100
+ const { container } = render(<Graph {...props} />);
101
+ expect(container.firstChild).toBeInTheDocument();
102
+ });
103
+ });
104
+
105
+ describe('props handling', () => {
106
+ it('calls onChangeMarks when marks prop changes', () => {
107
+ const { rerender } = render(<Graph {...defaultProps} />);
108
+
109
+ const newMarks = [
110
+ {
111
+ type: 'point',
112
+ x: 3,
113
+ y: 3,
114
+ label: 'New Point',
115
+ showLabel: true,
116
+ },
117
+ ];
118
+
119
+ rerender(<Graph {...defaultProps} marks={newMarks} />);
120
+
121
+ // Component should render with new marks
122
+ // Note: onChangeMarks is called internally when marks are changed through user interaction,
123
+ // not when props change, so we just verify the component renders correctly
124
+ expect(onChangeMarks).not.toHaveBeenCalled();
125
+ });
126
+
127
+ it('handles undefined onChangeMarks gracefully', () => {
128
+ const props = {
129
+ ...defaultProps,
130
+ onChangeMarks: undefined,
131
+ };
132
+ const { container } = render(<Graph {...props} />);
133
+ expect(container.firstChild).toBeInTheDocument();
134
+ });
135
+ });
136
+
137
+ describe('removeBuildingToolIfCurrentToolDiffers integration', () => {
138
+ it('removes building marks when currentTool changes', () => {
139
+ const marksWithBuilding = [
140
+ {
141
+ type: 'point',
142
+ x: 2,
143
+ y: 2,
144
+ label: 'Point',
145
+ showLabel: true,
146
+ },
147
+ {
148
+ type: 'line',
149
+ from: { x: 0, y: 0 },
150
+ to: { x: 1, y: 1 },
151
+ building: true,
152
+ },
153
+ ];
154
+
155
+ const props = {
156
+ ...defaultProps,
157
+ marks: marksWithBuilding,
158
+ currentTool: { type: 'point' }, // Different from building mark type
159
+ };
160
+
161
+ const { container } = render(<Graph {...props} />);
162
+ expect(container.firstChild).toBeInTheDocument();
163
+ });
164
+ });
165
+
166
+ describe('updateMarks method', () => {
167
+ it('updates an existing mark', () => {
168
+ const wrapper = render(<Graph {...defaultProps} />);
169
+
170
+ const { rerender } = wrapper;
171
+
172
+ const updatedMarks = [
173
+ {
174
+ type: 'point',
175
+ x: 3,
176
+ y: 3,
177
+ label: 'Updated Point',
178
+ showLabel: true,
179
+ },
180
+ {
181
+ type: 'line',
182
+ from: { x: 0, y: 0 },
183
+ to: { x: 1, y: 1 },
184
+ label: 'Line',
185
+ },
186
+ ];
187
+
188
+ rerender(<Graph {...defaultProps} marks={updatedMarks} />);
189
+
190
+ // Component should render with updated marks
191
+ expect(wrapper.container.firstChild).toBeInTheDocument();
192
+ });
193
+
194
+ it('does not update if mark is duplicated', () => {
195
+ const duplicatedMarks = [
196
+ {
197
+ type: 'point',
198
+ x: 2,
199
+ y: 2,
200
+ label: 'Point',
201
+ showLabel: true,
202
+ },
203
+ {
204
+ type: 'point',
205
+ x: 2,
206
+ y: 2,
207
+ label: 'Point',
208
+ showLabel: true,
209
+ },
210
+ ];
211
+
212
+ const { container } = render(<Graph {...defaultProps} marks={duplicatedMarks} />);
213
+ expect(container.firstChild).toBeInTheDocument();
214
+ });
215
+
216
+ it('adds mark if addIfMissing is true and mark does not exist', () => {
217
+ const { container } = render(<Graph {...defaultProps} />);
218
+
219
+ // The component should handle adding new marks through user interaction
220
+ expect(container.firstChild).toBeInTheDocument();
221
+ });
222
+
223
+ it('does not update if mark has no building flag and is duplicated', () => {
224
+ const marks = [
225
+ {
226
+ type: 'point',
227
+ x: 2,
228
+ y: 2,
229
+ label: 'Point',
230
+ showLabel: true,
231
+ },
232
+ ];
233
+
234
+ const { container } = render(<Graph {...defaultProps} marks={marks} />);
235
+ expect(container.firstChild).toBeInTheDocument();
236
+ });
237
+
238
+ it('handles building marks correctly', () => {
239
+ const marksWithBuilding = [
240
+ {
241
+ type: 'line',
242
+ from: { x: 0, y: 0 },
243
+ building: true,
244
+ },
245
+ ];
246
+
247
+ const { container } = render(<Graph {...defaultProps} marks={marksWithBuilding} />);
248
+ expect(container.firstChild).toBeInTheDocument();
249
+ });
250
+
251
+ it('updates building mark to completed mark', () => {
252
+ const marksWithBuilding = [
253
+ {
254
+ type: 'line',
255
+ from: { x: 0, y: 0 },
256
+ building: true,
257
+ },
258
+ ];
259
+
260
+ const { rerender, container } = render(<Graph {...defaultProps} marks={marksWithBuilding} />);
261
+
262
+ const completedMarks = [
263
+ {
264
+ type: 'line',
265
+ from: { x: 0, y: 0 },
266
+ to: { x: 1, y: 1 },
267
+ building: false,
268
+ },
269
+ ];
270
+
271
+ rerender(<Graph {...defaultProps} marks={completedMarks} />);
272
+ expect(container.firstChild).toBeInTheDocument();
273
+ });
274
+
275
+ it('does not call onChangeMarks if update is undefined', () => {
276
+ const { container } = render(<Graph {...defaultProps} />);
277
+
278
+ // If update is undefined, onChangeMarks should not be called
279
+ // This is handled internally by the component
280
+ expect(container.firstChild).toBeInTheDocument();
281
+ });
282
+
283
+ it('does not add mark if existing is not found and addIfMissing is false', () => {
284
+ const { container } = render(<Graph {...defaultProps} />);
285
+
286
+ // By default, marks are not added if they don't exist and addIfMissing is false
287
+ expect(container.firstChild).toBeInTheDocument();
288
+ });
289
+
290
+ it('calls onChangeMarks with correct marks when updating', () => {
291
+ const marks = [
292
+ {
293
+ type: 'point',
294
+ x: 2,
295
+ y: 2,
296
+ label: 'Point',
297
+ showLabel: true,
298
+ },
299
+ ];
300
+
301
+ const { rerender } = render(<Graph {...defaultProps} marks={marks} />);
302
+
303
+ const updatedMarks = [
304
+ {
305
+ type: 'point',
306
+ x: 3,
307
+ y: 3,
308
+ label: 'Updated Point',
309
+ showLabel: true,
310
+ },
311
+ ];
312
+
313
+ rerender(<Graph {...defaultProps} marks={updatedMarks} />);
314
+
315
+ // The component handles mark updates internally
316
+ // onChangeMarks is called through user interactions
317
+ });
318
+
319
+ it('preserves other marks when updating a specific mark', () => {
320
+ const marks = [
321
+ {
322
+ type: 'point',
323
+ x: 2,
324
+ y: 2,
325
+ label: 'Point 1',
326
+ showLabel: true,
327
+ },
328
+ {
329
+ type: 'point',
330
+ x: 3,
331
+ y: 3,
332
+ label: 'Point 2',
333
+ showLabel: true,
334
+ },
335
+ ];
336
+
337
+ const { container } = render(<Graph {...defaultProps} marks={marks} />);
338
+ expect(container.firstChild).toBeInTheDocument();
339
+ });
340
+ });
341
+
342
+ describe('getComponent method', () => {
343
+ it('returns null if mark is null', () => {
344
+ const { container } = render(<Graph {...defaultProps} />);
345
+
346
+ // getComponent returns null for null marks
347
+ // This is tested by rendering with undefined marks
348
+ const propsWithoutMarks = { ...defaultProps, marks: [] };
349
+ const { container: emptyContainer } = render(<Graph {...propsWithoutMarks} />);
350
+ expect(emptyContainer.firstChild).toBeInTheDocument();
351
+ });
352
+
353
+ it('returns null if mark is undefined', () => {
354
+ const { container } = render(<Graph {...defaultProps} />);
355
+ expect(container.firstChild).toBeInTheDocument();
356
+ });
357
+
358
+ it('returns null if tools is undefined', () => {
359
+ const propsWithUndefinedTools = { ...defaultProps, tools: undefined };
360
+ const graphInstance = new Graph(propsWithUndefinedTools);
361
+ const mark = { type: 'point', x: 1, y: 1 };
362
+ const component = graphInstance.getComponent(mark);
363
+ expect(component).toBeNull();
364
+ });
365
+
366
+ it('returns null if tools is empty array', () => {
367
+ const propsWithEmptyTools = { ...defaultProps, tools: [] };
368
+ const graphInstance = new Graph(propsWithEmptyTools);
369
+ const mark = { type: 'point', x: 1, y: 1 };
370
+ const component = graphInstance.getComponent(mark);
371
+ expect(component).toBeNull();
372
+ });
373
+
374
+ it('returns null if mark type is not found in tools', () => {
375
+ const graphInstance = new Graph(defaultProps);
376
+ const mark = { type: 'nonexistent-type', x: 1, y: 1 };
377
+ const component = graphInstance.getComponent(mark);
378
+ expect(component).toBeNull();
379
+ });
380
+
381
+ it('returns component if tool has no Component property', () => {
382
+ const toolWithoutComponent = [{ type: 'custom', label: 'Custom' }];
383
+ const propsWithCustomTool = { ...defaultProps, tools: toolWithoutComponent };
384
+ const graphInstance = new Graph(propsWithCustomTool);
385
+ const mark = { type: 'custom', x: 1, y: 1 };
386
+ const component = graphInstance.getComponent(mark);
387
+ expect(component).toBeNull();
388
+ });
389
+
390
+ it('returns correct component for point mark', () => {
391
+ const graphInstance = new Graph(defaultProps);
392
+ const mark = { type: 'point', x: 1, y: 1 };
393
+ const component = graphInstance.getComponent(mark);
394
+ expect(component).toBeTruthy();
395
+ });
396
+
397
+ it('returns correct component for line mark', () => {
398
+ const graphInstance = new Graph(defaultProps);
399
+ const mark = { type: 'line', from: { x: 0, y: 0 }, to: { x: 1, y: 1 } };
400
+ const component = graphInstance.getComponent(mark);
401
+ expect(component).toBeTruthy();
402
+ });
403
+
404
+ it('returns correct component for different mark types', () => {
405
+ const graphInstance = new Graph(defaultProps);
406
+
407
+ const pointMark = { type: 'point', x: 1, y: 1 };
408
+ const lineMark = { type: 'line', from: { x: 0, y: 0 }, to: { x: 1, y: 1 } };
409
+ const circleMark = { type: 'circle', center: { x: 0, y: 0 }, edge: { x: 1, y: 1 } };
410
+
411
+ const pointComponent = graphInstance.getComponent(pointMark);
412
+ const lineComponent = graphInstance.getComponent(lineMark);
413
+ const circleComponent = graphInstance.getComponent(circleMark);
414
+
415
+ expect(pointComponent).toBeTruthy();
416
+ expect(lineComponent).toBeTruthy();
417
+ expect(circleComponent).toBeTruthy();
418
+ });
419
+ });
420
+
421
+ describe('getComponent method - unit tests', () => {
422
+ it('returns null if mark is null', () => {
423
+ const graphInstance = new Graph(defaultProps);
424
+ const component = graphInstance.getComponent(null);
425
+ expect(component).toBeNull();
426
+ });
427
+
428
+ it('returns null if mark is undefined', () => {
429
+ const graphInstance = new Graph(defaultProps);
430
+ const component = graphInstance.getComponent(undefined);
431
+ expect(component).toBeNull();
432
+ });
433
+
434
+ it('returns null if tools is undefined', () => {
435
+ const propsWithUndefinedTools = { ...defaultProps, tools: undefined };
436
+ const graphInstance = new Graph(propsWithUndefinedTools);
437
+ const mark = { type: 'point', x: 1, y: 1 };
438
+ const component = graphInstance.getComponent(mark);
439
+ expect(component).toBeNull();
440
+ });
441
+
442
+ it('returns null if tools is empty array', () => {
443
+ const propsWithEmptyTools = { ...defaultProps, tools: [] };
444
+ const graphInstance = new Graph(propsWithEmptyTools);
445
+ const mark = { type: 'point', x: 1, y: 1 };
446
+ const component = graphInstance.getComponent(mark);
447
+ expect(component).toBeNull();
448
+ });
449
+
450
+ it('returns null if mark type is not found in tools', () => {
451
+ const graphInstance = new Graph(defaultProps);
452
+ const mark = { type: 'nonexistent-type', x: 1, y: 1 };
453
+ const component = graphInstance.getComponent(mark);
454
+ expect(component).toBeNull();
455
+ });
456
+
457
+ it('returns component if tool has no Component property', () => {
458
+ const toolWithoutComponent = [{ type: 'custom', label: 'Custom' }];
459
+ const propsWithCustomTool = { ...defaultProps, tools: toolWithoutComponent };
460
+ const graphInstance = new Graph(propsWithCustomTool);
461
+ const mark = { type: 'custom', x: 1, y: 1 };
462
+ const component = graphInstance.getComponent(mark);
463
+ expect(component).toBeNull();
464
+ });
465
+
466
+ it('returns correct component for point mark', () => {
467
+ const graphInstance = new Graph(defaultProps);
468
+ const mark = { type: 'point', x: 1, y: 1 };
469
+ const component = graphInstance.getComponent(mark);
470
+ expect(component).toBeTruthy();
471
+ });
472
+
473
+ it('returns correct component for line mark', () => {
474
+ const graphInstance = new Graph(defaultProps);
475
+ const mark = { type: 'line', from: { x: 0, y: 0 }, to: { x: 1, y: 1 } };
476
+ const component = graphInstance.getComponent(mark);
477
+ expect(component).toBeTruthy();
478
+ });
479
+
480
+ it('returns correct component for different mark types', () => {
481
+ const graphInstance = new Graph(defaultProps);
482
+
483
+ const pointMark = { type: 'point', x: 1, y: 1 };
484
+ const lineMark = { type: 'line', from: { x: 0, y: 0 }, to: { x: 1, y: 1 } };
485
+ const circleMark = { type: 'circle', center: { x: 0, y: 0 }, edge: { x: 1, y: 1 } };
486
+
487
+ const pointComponent = graphInstance.getComponent(pointMark);
488
+ const lineComponent = graphInstance.getComponent(lineMark);
489
+ const circleComponent = graphInstance.getComponent(circleMark);
490
+
491
+ expect(pointComponent).toBeTruthy();
492
+ expect(lineComponent).toBeTruthy();
493
+ expect(circleComponent).toBeTruthy();
494
+ });
495
+ });
496
+
497
+ describe('updateMarks method - unit tests', () => {
498
+ it('does not update if update parameter is null', () => {
499
+ const onChangeMarks = jest.fn();
500
+ const marks = [{ type: 'point', x: 1, y: 1 }];
501
+ const props = { ...defaultProps, onChangeMarks, marks };
502
+ const graphInstance = new Graph(props);
503
+
504
+ const existing = marks[0];
505
+ graphInstance.updateMarks(existing, null);
506
+
507
+ expect(onChangeMarks).not.toHaveBeenCalled();
508
+ });
509
+
510
+ it('does not update if update parameter is undefined', () => {
511
+ const onChangeMarks = jest.fn();
512
+ const marks = [{ type: 'point', x: 1, y: 1 }];
513
+ const props = { ...defaultProps, onChangeMarks, marks };
514
+ const graphInstance = new Graph(props);
515
+
516
+ const existing = marks[0];
517
+ graphInstance.updateMarks(existing, undefined);
518
+
519
+ expect(onChangeMarks).not.toHaveBeenCalled();
520
+ });
521
+
522
+ it('updates existing mark when found', () => {
523
+ const onChangeMarks = jest.fn();
524
+ const marks = [
525
+ { type: 'point', x: 1, y: 1 },
526
+ { type: 'point', x: 2, y: 2 },
527
+ ];
528
+ const props = { ...defaultProps, onChangeMarks, marks };
529
+ const graphInstance = new Graph(props);
530
+
531
+ const existing = marks[0];
532
+ const updated = { type: 'point', x: 1, y: 3 };
533
+
534
+ graphInstance.updateMarks(existing, updated);
535
+
536
+ expect(onChangeMarks).toHaveBeenCalledTimes(1);
537
+ const updatedMarks = onChangeMarks.mock.calls[0][0];
538
+ expect(updatedMarks[0]).toEqual(updated);
539
+ expect(updatedMarks[1]).toEqual(marks[1]);
540
+ });
541
+
542
+ it('adds mark if addIfMissing is true and mark not found', () => {
543
+ const onChangeMarks = jest.fn();
544
+ const marks = [{ type: 'point', x: 1, y: 1 }];
545
+ const props = { ...defaultProps, onChangeMarks, marks };
546
+ const graphInstance = new Graph(props);
547
+
548
+ const existing = { type: 'point', x: 5, y: 5 };
549
+ const updated = { type: 'point', x: 2, y: 2 };
550
+
551
+ graphInstance.updateMarks(existing, updated, true);
552
+
553
+ expect(onChangeMarks).toHaveBeenCalledTimes(1);
554
+ const updatedMarks = onChangeMarks.mock.calls[0][0];
555
+ expect(updatedMarks.length).toBe(2);
556
+ expect(updatedMarks[1]).toEqual(updated);
557
+ });
558
+
559
+ it('does not add mark if addIfMissing is false and mark not found', () => {
560
+ const onChangeMarks = jest.fn();
561
+ const marks = [{ type: 'point', x: 1, y: 1 }];
562
+ const props = { ...defaultProps, onChangeMarks, marks };
563
+ const graphInstance = new Graph(props);
564
+
565
+ const existing = { type: 'point', x: 5, y: 5 };
566
+ const updated = { type: 'point', x: 2, y: 2 };
567
+
568
+ graphInstance.updateMarks(existing, updated, false);
569
+
570
+ expect(onChangeMarks).not.toHaveBeenCalled();
571
+ });
572
+
573
+ it('does not update if mark is still building', () => {
574
+ const onChangeMarks = jest.fn();
575
+ const marks = [{ type: 'point', x: 1, y: 1, building: true }];
576
+ const props = { ...defaultProps, onChangeMarks, marks };
577
+ const graphInstance = new Graph(props);
578
+
579
+ const existing = marks[0];
580
+ const updated = { type: 'point', x: 2, y: 2 };
581
+
582
+ graphInstance.updateMarks(existing, updated);
583
+
584
+ expect(onChangeMarks).toHaveBeenCalled();
585
+ });
586
+
587
+ it('preserves mark order when updating', () => {
588
+ const onChangeMarks = jest.fn();
589
+ const marks = [
590
+ { type: 'point', x: 1, y: 1 },
591
+ { type: 'point', x: 2, y: 2 },
592
+ { type: 'point', x: 3, y: 3 },
593
+ ];
594
+ const props = { ...defaultProps, onChangeMarks, marks };
595
+ const graphInstance = new Graph(props);
596
+
597
+ const existing = marks[1];
598
+ const updated = { type: 'point', x: 2, y: 5 };
599
+
600
+ graphInstance.updateMarks(existing, updated);
601
+
602
+ const updatedMarks = onChangeMarks.mock.calls[0][0];
603
+ expect(updatedMarks[0]).toEqual(marks[0]);
604
+ expect(updatedMarks[1]).toEqual(updated);
605
+ expect(updatedMarks[2]).toEqual(marks[2]);
606
+ });
607
+
608
+ it('handles empty marks array', () => {
609
+ const onChangeMarks = jest.fn();
610
+ const props = { ...defaultProps, onChangeMarks, marks: [] };
611
+ const graphInstance = new Graph(props);
612
+
613
+ const existing = { type: 'point', x: 1, y: 1 };
614
+ const updated = { type: 'point', x: 2, y: 2 };
615
+
616
+ graphInstance.updateMarks(existing, updated, true);
617
+
618
+ expect(onChangeMarks).toHaveBeenCalledTimes(1);
619
+ const updatedMarks = onChangeMarks.mock.calls[0][0];
620
+ expect(updatedMarks.length).toBe(1);
621
+ expect(updatedMarks[0]).toEqual(updated);
622
+ });
623
+ });
624
+
625
+ describe('updateMarks and getComponent integration', () => {
626
+ it('updates marks and renders with correct components', () => {
627
+ const initialMarks = [
628
+ {
629
+ type: 'point',
630
+ x: 2,
631
+ y: 2,
632
+ label: 'Point',
633
+ showLabel: true,
634
+ },
635
+ ];
636
+
637
+ const { rerender, container } = render(<Graph {...defaultProps} marks={initialMarks} />);
638
+
639
+ const updatedMarks = [
640
+ {
641
+ type: 'line',
642
+ from: { x: 0, y: 0 },
643
+ to: { x: 1, y: 1 },
644
+ label: 'Line',
645
+ },
646
+ ];
647
+
648
+ rerender(<Graph {...defaultProps} marks={updatedMarks} />);
649
+
650
+ expect(container.querySelector('#marks')).toBeInTheDocument();
651
+ });
652
+
653
+ it('handles adding new marks with different types', () => {
654
+ const initialMarks = [
655
+ {
656
+ type: 'point',
657
+ x: 2,
658
+ y: 2,
659
+ label: 'Point',
660
+ showLabel: true,
661
+ },
662
+ ];
663
+
664
+ const { rerender, container } = render(<Graph {...defaultProps} marks={initialMarks} />);
665
+
666
+ const updatedMarks = [
667
+ {
668
+ type: 'point',
669
+ x: 2,
670
+ y: 2,
671
+ label: 'Point',
672
+ showLabel: true,
673
+ },
674
+ {
675
+ type: 'line',
676
+ from: { x: 0, y: 0 },
677
+ to: { x: 1, y: 1 },
678
+ label: 'Line',
679
+ },
680
+ ];
681
+
682
+ rerender(<Graph {...defaultProps} marks={updatedMarks} />);
683
+
684
+ expect(container.querySelector('#marks')).toBeInTheDocument();
685
+ });
686
+
687
+ it('handles removing marks', () => {
688
+ const initialMarks = [
689
+ {
690
+ type: 'point',
691
+ x: 2,
692
+ y: 2,
693
+ label: 'Point',
694
+ showLabel: true,
695
+ },
696
+ {
697
+ type: 'line',
698
+ from: { x: 0, y: 0 },
699
+ to: { x: 1, y: 1 },
700
+ label: 'Line',
701
+ },
702
+ ];
703
+
704
+ const { rerender, container } = render(<Graph {...defaultProps} marks={initialMarks} />);
705
+
706
+ const updatedMarks = [
707
+ {
708
+ type: 'point',
709
+ x: 2,
710
+ y: 2,
711
+ label: 'Point',
712
+ showLabel: true,
713
+ },
714
+ ];
715
+
716
+ rerender(<Graph {...defaultProps} marks={updatedMarks} />);
717
+
718
+ expect(container.querySelector('#marks')).toBeInTheDocument();
719
+ });
720
+ });
721
+ });