@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,645 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, waitFor } from '@pie-lib/test-utils';
3
+ import GridSetup from '../grid-setup';
4
+
5
+ const mockOnChange = jest.fn();
6
+ const mockOnChangeView = jest.fn();
7
+
8
+ const defaultProps = {
9
+ domain: {
10
+ min: -5,
11
+ max: 5,
12
+ step: 1,
13
+ labelStep: 1,
14
+ axisLabel: 'x',
15
+ },
16
+ range: {
17
+ min: -5,
18
+ max: 5,
19
+ step: 1,
20
+ labelStep: 1,
21
+ axisLabel: 'y',
22
+ },
23
+ size: {
24
+ width: 480,
25
+ height: 480,
26
+ },
27
+ sizeConstraints: {
28
+ min: 300,
29
+ max: 900,
30
+ step: 10,
31
+ },
32
+ includeAxes: true,
33
+ standardGrid: false,
34
+ displayedFields: {
35
+ axisLabel: { enabled: true, label: 'Axis Label' },
36
+ min: { enabled: true, label: 'Min' },
37
+ max: { enabled: true, label: 'Max' },
38
+ step: { enabled: true, label: 'Interval' },
39
+ labelStep: { enabled: true, label: 'Label Interval' },
40
+ dimensionsEnabled: true,
41
+ includeAxesEnabled: true,
42
+ standardGridEnabled: true,
43
+ },
44
+ gridValues: {
45
+ domain: [1, 2, 5, 10],
46
+ range: [1, 2, 5, 10],
47
+ },
48
+ labelValues: {
49
+ domain: [0, 1, 2],
50
+ range: [0, 1, 2],
51
+ },
52
+ onChange: mockOnChange,
53
+ onChangeView: mockOnChangeView,
54
+ };
55
+
56
+ describe('GridSetup', () => {
57
+ beforeEach(() => {
58
+ jest.clearAllMocks();
59
+ });
60
+
61
+ describe('rendering', () => {
62
+ it('renders without crashing', () => {
63
+ const { container } = render(<GridSetup {...defaultProps} />);
64
+ expect(container).toBeTruthy();
65
+ });
66
+
67
+ it('renders accordion with title', () => {
68
+ const { getByText } = render(<GridSetup {...defaultProps} />);
69
+ expect(getByText('Customize Grid Setup')).toBeTruthy();
70
+ });
71
+
72
+ it('renders Include axes toggle when enabled', () => {
73
+ const { getByText } = render(<GridSetup {...defaultProps} />);
74
+ expect(getByText('Include axes and labels?')).toBeTruthy();
75
+ });
76
+
77
+ it('does not render Include axes toggle when disabled', () => {
78
+ const props = {
79
+ ...defaultProps,
80
+ displayedFields: {
81
+ ...defaultProps.displayedFields,
82
+ includeAxesEnabled: false,
83
+ },
84
+ };
85
+ const { queryByText } = render(<GridSetup {...props} />);
86
+ expect(queryByText('Include axes and labels?')).toBeFalsy();
87
+ });
88
+
89
+ it('renders standard grid toggle when enabled', () => {
90
+ const { getByText } = render(<GridSetup {...defaultProps} />);
91
+ expect(getByText('Constrain to standard coordinate grid?')).toBeTruthy();
92
+ });
93
+
94
+ it('does not render standard grid toggle when disabled', () => {
95
+ const props = {
96
+ ...defaultProps,
97
+ displayedFields: {
98
+ ...defaultProps.displayedFields,
99
+ standardGridEnabled: false,
100
+ },
101
+ };
102
+ const { queryByText } = render(<GridSetup {...props} />);
103
+ expect(queryByText('Constrain to standard coordinate grid?')).toBeFalsy();
104
+ });
105
+
106
+ it('renders dimensions section when enabled', () => {
107
+ const { getByText } = render(<GridSetup {...defaultProps} />);
108
+ expect(getByText('Dimensions(px)')).toBeTruthy();
109
+ expect(getByText(/Min 300, Max 900/)).toBeTruthy();
110
+ });
111
+
112
+ it('does not render dimensions section when disabled', () => {
113
+ const props = {
114
+ ...defaultProps,
115
+ displayedFields: {
116
+ ...defaultProps.displayedFields,
117
+ dimensionsEnabled: false,
118
+ },
119
+ };
120
+ const { queryByText } = render(<GridSetup {...props} />);
121
+ expect(queryByText('Dimensions(px)')).toBeFalsy();
122
+ });
123
+ });
124
+
125
+ describe('axes configuration', () => {
126
+ it('renders axis headers when includeAxes is true', () => {
127
+ const { container } = render(<GridSetup {...defaultProps} />);
128
+ const xAxisHeader = container.querySelector('i');
129
+ expect(xAxisHeader?.textContent).toBe('x');
130
+ });
131
+
132
+ it('renders min/max fields when enabled', () => {
133
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
134
+ const minFields = getAllByLabelText('Min');
135
+ const maxFields = getAllByLabelText('Max');
136
+ expect(minFields.length).toBe(2); // domain and range
137
+ expect(maxFields.length).toBe(2); // domain and range
138
+ });
139
+
140
+ it('does not render min/max fields when disabled', () => {
141
+ const props = {
142
+ ...defaultProps,
143
+ displayedFields: {
144
+ ...defaultProps.displayedFields,
145
+ min: { enabled: false },
146
+ max: { enabled: false },
147
+ },
148
+ };
149
+ const { queryByLabelText } = render(<GridSetup {...props} />);
150
+ expect(queryByLabelText('Min')).toBeFalsy();
151
+ expect(queryByLabelText('Max')).toBeFalsy();
152
+ });
153
+
154
+ it('renders axis label fields when enabled', () => {
155
+ const { getAllByText } = render(<GridSetup {...defaultProps} />);
156
+ const axisLabelFields = getAllByText('Axis Label');
157
+ expect(axisLabelFields.length).toBe(2); // domain and range
158
+ });
159
+
160
+ it('does not render axis label fields when disabled', () => {
161
+ const props = {
162
+ ...defaultProps,
163
+ displayedFields: {
164
+ ...defaultProps.displayedFields,
165
+ axisLabel: { enabled: false },
166
+ },
167
+ };
168
+ const { queryByText } = render(<GridSetup {...props} />);
169
+ expect(queryByText('Axis Label')).toBeFalsy();
170
+ });
171
+
172
+ it('renders step and labelStep fields when enabled', () => {
173
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
174
+ const intervalFields = getAllByLabelText('Interval');
175
+ const labelIntervalFields = getAllByLabelText('Label Interval');
176
+ expect(intervalFields.length).toBe(2); // domain and range
177
+ expect(labelIntervalFields.length).toBe(2); // domain and range
178
+ });
179
+
180
+ it('does not render step fields when disabled', () => {
181
+ const props = {
182
+ ...defaultProps,
183
+ displayedFields: {
184
+ ...defaultProps.displayedFields,
185
+ step: { enabled: false },
186
+ },
187
+ };
188
+ const { queryByLabelText } = render(<GridSetup {...props} />);
189
+ expect(queryByLabelText('Interval')).toBeFalsy();
190
+ });
191
+
192
+ it('does not render labelStep fields when disabled', () => {
193
+ const props = {
194
+ ...defaultProps,
195
+ displayedFields: {
196
+ ...defaultProps.displayedFields,
197
+ labelStep: { enabled: false },
198
+ },
199
+ };
200
+ const { queryByLabelText } = render(<GridSetup {...props} />);
201
+ expect(queryByLabelText('Label Interval')).toBeFalsy();
202
+ });
203
+
204
+ it('displays axis visibility hint when min/max enabled', () => {
205
+ const { getByText } = render(<GridSetup {...defaultProps} />);
206
+ expect(
207
+ getByText('If you want the axis to be visible, use a zero or negative Min Value, and a positive Max Value'),
208
+ ).toBeTruthy();
209
+ });
210
+
211
+ it('displays unnumbered gridlines hint when labelStep enabled', () => {
212
+ const { getByText } = render(<GridSetup {...defaultProps} />);
213
+ expect(getByText('For unnumbered gridlines, enter a label interval of 0')).toBeTruthy();
214
+ });
215
+ });
216
+
217
+ describe('gridlines configuration', () => {
218
+ it('renders gridlines config when includeAxes is false', () => {
219
+ const props = {
220
+ ...defaultProps,
221
+ includeAxes: false,
222
+ };
223
+ const { getByLabelText } = render(<GridSetup {...props} />);
224
+ expect(getByLabelText('Number of Vertical Gridlines')).toBeTruthy();
225
+ expect(getByLabelText('Number of Horizontal Gridlines')).toBeTruthy();
226
+ });
227
+
228
+ it('does not render axes config when includeAxes is false', () => {
229
+ const props = {
230
+ ...defaultProps,
231
+ includeAxes: false,
232
+ };
233
+ const { queryByText } = render(<GridSetup {...props} />);
234
+ expect(queryByText('Axis Label')).toBeFalsy();
235
+ });
236
+
237
+ it('does not render gridlines config when max is disabled', () => {
238
+ const props = {
239
+ ...defaultProps,
240
+ includeAxes: false,
241
+ displayedFields: {
242
+ ...defaultProps.displayedFields,
243
+ max: { enabled: false },
244
+ },
245
+ };
246
+ const { queryByLabelText } = render(<GridSetup {...props} />);
247
+ expect(queryByLabelText('Number of Vertical Gridlines')).toBeFalsy();
248
+ expect(queryByLabelText('Number of Horizontal Gridlines')).toBeFalsy();
249
+ });
250
+ });
251
+
252
+ describe('user interactions', () => {
253
+ it('calls onChange when includeAxes toggle is clicked', () => {
254
+ const { container } = render(<GridSetup {...defaultProps} />);
255
+ const toggleInput = container.querySelector('input[type="checkbox"]');
256
+
257
+ fireEvent.click(toggleInput);
258
+
259
+ expect(mockOnChange).toHaveBeenCalledWith(
260
+ expect.objectContaining({
261
+ includeAxes: false,
262
+ }),
263
+ );
264
+ });
265
+
266
+ it('calls onChange with proper config when includeAxes is disabled', () => {
267
+ const { container } = render(<GridSetup {...defaultProps} />);
268
+ const toggleInput = container.querySelector('input[type="checkbox"]');
269
+
270
+ fireEvent.click(toggleInput);
271
+
272
+ expect(mockOnChange).toHaveBeenCalledWith(
273
+ expect.objectContaining({
274
+ includeAxes: false,
275
+ domain: expect.objectContaining({
276
+ min: 1,
277
+ max: 5,
278
+ step: 1,
279
+ labelStep: 0,
280
+ }),
281
+ range: expect.objectContaining({
282
+ min: 1,
283
+ max: 5,
284
+ step: 1,
285
+ labelStep: 0,
286
+ }),
287
+ }),
288
+ );
289
+ });
290
+
291
+ it('calls onChange with proper config when includeAxes is enabled', () => {
292
+ const props = {
293
+ ...defaultProps,
294
+ includeAxes: false,
295
+ };
296
+ const { container } = render(<GridSetup {...props} />);
297
+ const toggleInputs = container.querySelectorAll('input[type="checkbox"]');
298
+ const includeAxesToggle = toggleInputs[0]; // First toggle is includeAxes
299
+
300
+ fireEvent.click(includeAxesToggle);
301
+
302
+ expect(mockOnChange).toHaveBeenCalledWith(
303
+ expect.objectContaining({
304
+ includeAxes: true,
305
+ domain: expect.objectContaining({
306
+ labelStep: 1,
307
+ }),
308
+ range: expect.objectContaining({
309
+ labelStep: 1,
310
+ }),
311
+ }),
312
+ );
313
+ });
314
+
315
+ it('calls onChange when standardGrid toggle is clicked', () => {
316
+ const { container } = render(<GridSetup {...defaultProps} />);
317
+ const toggleInputs = container.querySelectorAll('input[type="checkbox"]');
318
+ const standardGridToggle = toggleInputs[1]; // Second toggle is standardGrid
319
+
320
+ fireEvent.click(standardGridToggle);
321
+
322
+ expect(mockOnChange).toHaveBeenCalledWith(
323
+ expect.objectContaining({
324
+ standardGrid: true,
325
+ graph: expect.objectContaining({
326
+ width: 480,
327
+ height: 480,
328
+ }),
329
+ }),
330
+ );
331
+ });
332
+
333
+ it('calls onChange when width is changed', async () => {
334
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
335
+ const widthInput = getAllByLabelText('Width')[0];
336
+
337
+ fireEvent.change(widthInput, { target: { value: '500' } });
338
+ fireEvent.blur(widthInput);
339
+
340
+ await waitFor(() => {
341
+ expect(mockOnChange).toHaveBeenCalledWith(
342
+ expect.objectContaining({
343
+ graph: expect.objectContaining({
344
+ width: 500,
345
+ }),
346
+ }),
347
+ );
348
+ });
349
+ });
350
+
351
+ it('calls onChange when height is changed', async () => {
352
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
353
+ const heightInput = getAllByLabelText('Height')[0];
354
+
355
+ fireEvent.change(heightInput, { target: { value: '520' } });
356
+ fireEvent.blur(heightInput);
357
+
358
+ await waitFor(() => {
359
+ expect(mockOnChange).toHaveBeenCalledWith(
360
+ expect.objectContaining({
361
+ graph: expect.objectContaining({
362
+ height: 520,
363
+ }),
364
+ }),
365
+ );
366
+ });
367
+ });
368
+
369
+ it('updates both width and height when standardGrid is true', async () => {
370
+ const props = {
371
+ ...defaultProps,
372
+ standardGrid: true,
373
+ };
374
+ const { getAllByLabelText } = render(<GridSetup {...props} />);
375
+ const widthInput = getAllByLabelText('Width')[0];
376
+
377
+ fireEvent.change(widthInput, { target: { value: '600' } });
378
+ fireEvent.blur(widthInput);
379
+
380
+ await waitFor(() => {
381
+ expect(mockOnChange).toHaveBeenCalledWith(
382
+ expect.objectContaining({
383
+ graph: expect.objectContaining({
384
+ width: 600,
385
+ height: 600,
386
+ }),
387
+ }),
388
+ );
389
+ });
390
+ });
391
+
392
+ it('calls onChange when domain min is changed', async () => {
393
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
394
+ const minInputs = getAllByLabelText('Min');
395
+ const domainMinInput = minInputs[0];
396
+
397
+ fireEvent.change(domainMinInput, { target: { value: '-10' } });
398
+ fireEvent.blur(domainMinInput);
399
+
400
+ await waitFor(() => {
401
+ expect(mockOnChange).toHaveBeenCalledWith(
402
+ expect.objectContaining({
403
+ domain: expect.objectContaining({
404
+ min: -10,
405
+ }),
406
+ }),
407
+ );
408
+ });
409
+ });
410
+
411
+ it('calls onChange when domain max is changed', async () => {
412
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
413
+ const maxInputs = getAllByLabelText('Max');
414
+ const domainMaxInput = maxInputs[0];
415
+
416
+ fireEvent.change(domainMaxInput, { target: { value: '10' } });
417
+ fireEvent.blur(domainMaxInput);
418
+
419
+ await waitFor(() => {
420
+ expect(mockOnChange).toHaveBeenCalledWith(
421
+ expect.objectContaining({
422
+ domain: expect.objectContaining({
423
+ max: 10,
424
+ }),
425
+ }),
426
+ );
427
+ });
428
+ });
429
+
430
+ it('calls onChange when range min is changed', async () => {
431
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
432
+ const minInputs = getAllByLabelText('Min');
433
+ const rangeMinInput = minInputs[1];
434
+
435
+ fireEvent.change(rangeMinInput, { target: { value: '-8' } });
436
+ fireEvent.blur(rangeMinInput);
437
+
438
+ await waitFor(() => {
439
+ expect(mockOnChange).toHaveBeenCalledWith(
440
+ expect.objectContaining({
441
+ range: expect.objectContaining({
442
+ min: -8,
443
+ }),
444
+ }),
445
+ );
446
+ });
447
+ });
448
+
449
+ it('calls onChange when range max is changed', async () => {
450
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
451
+ const maxInputs = getAllByLabelText('Max');
452
+ const rangeMaxInput = maxInputs[1];
453
+
454
+ fireEvent.change(rangeMaxInput, { target: { value: '12' } });
455
+ fireEvent.blur(rangeMaxInput);
456
+
457
+ await waitFor(() => {
458
+ expect(mockOnChange).toHaveBeenCalledWith(
459
+ expect.objectContaining({
460
+ range: expect.objectContaining({
461
+ max: 12,
462
+ }),
463
+ }),
464
+ );
465
+ });
466
+ });
467
+
468
+ it('updates both domain and range when standardGrid is true and domain changes', async () => {
469
+ const props = {
470
+ ...defaultProps,
471
+ standardGrid: true,
472
+ };
473
+ const { getAllByLabelText } = render(<GridSetup {...props} />);
474
+ const minInputs = getAllByLabelText('Min');
475
+ const domainMinInput = minInputs[0];
476
+
477
+ fireEvent.change(domainMinInput, { target: { value: '-15' } });
478
+ fireEvent.blur(domainMinInput);
479
+
480
+ await waitFor(() => {
481
+ expect(mockOnChange).toHaveBeenCalledWith(
482
+ expect.objectContaining({
483
+ domain: expect.objectContaining({
484
+ min: -15,
485
+ }),
486
+ range: expect.objectContaining({
487
+ min: -15,
488
+ }),
489
+ }),
490
+ );
491
+ });
492
+ });
493
+
494
+ it('does not update range when domain axisLabel changes with standardGrid', async () => {
495
+ const props = {
496
+ ...defaultProps,
497
+ standardGrid: true,
498
+ };
499
+ const { container } = render(<GridSetup {...props} />);
500
+
501
+ // EditableHTML change is harder to trigger, but we can test the handler directly
502
+ // by verifying the range doesn't get the axisLabel value from domain
503
+ const axisLabelInputs = container.querySelectorAll('[contenteditable="true"]');
504
+
505
+ if (axisLabelInputs.length > 0) {
506
+ fireEvent.input(axisLabelInputs[0], { target: { innerHTML: 'X-Axis' } });
507
+
508
+ await waitFor(() => {
509
+ if (mockOnChange.mock.calls.length > 0) {
510
+ const lastCall = mockOnChange.mock.calls[mockOnChange.mock.calls.length - 1][0];
511
+ // range.axisLabel should not be 'X-Axis', it should keep its original value
512
+ expect(lastCall.range?.axisLabel).not.toBe('X-Axis');
513
+ }
514
+ });
515
+ }
516
+ });
517
+
518
+ it('calls onChangeView when accordion is toggled', () => {
519
+ const { container } = render(<GridSetup {...defaultProps} />);
520
+ const accordionSummary = container.querySelector('[aria-expanded]');
521
+
522
+ fireEvent.click(accordionSummary);
523
+
524
+ expect(mockOnChangeView).toHaveBeenCalled();
525
+ });
526
+ });
527
+
528
+ describe('disabled states', () => {
529
+ it('disables range fields when standardGrid is true', () => {
530
+ const props = {
531
+ ...defaultProps,
532
+ standardGrid: true,
533
+ };
534
+ const { getAllByLabelText } = render(<GridSetup {...props} />);
535
+ const minInputs = getAllByLabelText('Min');
536
+ const rangeMinInput = minInputs[1];
537
+
538
+ expect(rangeMinInput).toBeDisabled();
539
+ });
540
+
541
+ it('disables height field when standardGrid is true', () => {
542
+ const props = {
543
+ ...defaultProps,
544
+ standardGrid: true,
545
+ };
546
+ const { getAllByLabelText } = render(<GridSetup {...props} />);
547
+ const heightInput = getAllByLabelText('Height')[0];
548
+
549
+ expect(heightInput).toBeDisabled();
550
+ });
551
+
552
+ it('disables horizontal gridlines field when standardGrid is true and includeAxes is false', () => {
553
+ const props = {
554
+ ...defaultProps,
555
+ includeAxes: false,
556
+ standardGrid: true,
557
+ };
558
+ const { getByLabelText } = render(<GridSetup {...props} />);
559
+ const horizontalGridlinesInput = getByLabelText('Number of Horizontal Gridlines');
560
+
561
+ expect(horizontalGridlinesInput).toBeDisabled();
562
+ });
563
+ });
564
+
565
+ describe('GridConfig component', () => {
566
+ it('renders step field when enabled', () => {
567
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
568
+ const intervalFields = getAllByLabelText('Interval');
569
+ expect(intervalFields.length).toBeGreaterThan(0);
570
+ });
571
+
572
+ it('renders labelStep field when enabled', () => {
573
+ const { getAllByLabelText } = render(<GridSetup {...defaultProps} />);
574
+ const labelIntervalFields = getAllByLabelText('Label Interval');
575
+ expect(labelIntervalFields.length).toBeGreaterThan(0);
576
+ });
577
+
578
+ it('does not render when both step and labelStep are disabled', () => {
579
+ const props = {
580
+ ...defaultProps,
581
+ displayedFields: {
582
+ ...defaultProps.displayedFields,
583
+ step: { enabled: false },
584
+ labelStep: { enabled: false },
585
+ },
586
+ };
587
+ const { queryByLabelText } = render(<GridSetup {...props} />);
588
+ expect(queryByLabelText('Interval')).toBeFalsy();
589
+ expect(queryByLabelText('Label Interval')).toBeFalsy();
590
+ });
591
+ });
592
+
593
+ describe('AxisConfig component', () => {
594
+ it('renders x-axis header', () => {
595
+ const { container } = render(<GridSetup {...defaultProps} />);
596
+ const headers = container.querySelectorAll('i');
597
+ const xAxisHeader = Array.from(headers).find((h) => h.textContent === 'x');
598
+ expect(xAxisHeader).toBeTruthy();
599
+ });
600
+
601
+ it('renders y-axis header', () => {
602
+ const { container } = render(<GridSetup {...defaultProps} />);
603
+ const headers = container.querySelectorAll('i');
604
+ const yAxisHeader = Array.from(headers).find((h) => h.textContent === 'y');
605
+ expect(yAxisHeader).toBeTruthy();
606
+ });
607
+
608
+ it('does not render headers when all fields are disabled', () => {
609
+ const props = {
610
+ ...defaultProps,
611
+ displayedFields: {
612
+ ...defaultProps.displayedFields,
613
+ min: { enabled: false },
614
+ max: { enabled: false },
615
+ axisLabel: { enabled: false },
616
+ step: { enabled: false },
617
+ labelStep: { enabled: false },
618
+ },
619
+ };
620
+ const { container } = render(<GridSetup {...props} />);
621
+ const headers = container.querySelectorAll('i');
622
+ const axisHeaders = Array.from(headers).filter((h) => h.textContent === 'x' || h.textContent === 'y');
623
+ expect(axisHeaders.length).toBe(0);
624
+ });
625
+ });
626
+
627
+ describe('Accordion behavior', () => {
628
+ it('renders with correct transition props', () => {
629
+ const { container } = render(<GridSetup {...defaultProps} />);
630
+ const accordion = container.querySelector('.MuiAccordion-root');
631
+ expect(accordion).toBeTruthy();
632
+ });
633
+
634
+ it('expands and collapses accordion', () => {
635
+ const { container } = render(<GridSetup {...defaultProps} />);
636
+ const accordionSummary = container.querySelector('[aria-expanded]');
637
+
638
+ expect(accordionSummary.getAttribute('aria-expanded')).toBe('false');
639
+
640
+ fireEvent.click(accordionSummary);
641
+
642
+ expect(mockOnChangeView).toHaveBeenCalled();
643
+ });
644
+ });
645
+ });
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { render } from '@pie-lib/test-utils';
3
+ import { Grid } from '../grid';
4
+ import { graphProps } from './utils';
5
+
6
+ describe('Grid', () => {
7
+ const renderComponent = (extras) => {
8
+ const defaults = {
9
+ classes: {},
10
+ className: 'className',
11
+ graphProps: graphProps(),
12
+ };
13
+ const props = { ...defaults, ...extras };
14
+ return render(<Grid {...props} />);
15
+ };
16
+ describe('rendering', () => {
17
+ it('renders without crashing', () => {
18
+ const { container } = renderComponent();
19
+ expect(container.firstChild).toBeInTheDocument();
20
+ });
21
+ });
22
+ });