@pie-lib/graphing 4.0.5-next.30 → 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.18.1/node_modules/lodash/_Hash.js +0 -21
  315. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_ListCache.js +0 -21
  316. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Map.js +0 -10
  317. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_MapCache.js +0 -21
  318. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Symbol.js +0 -9
  319. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_assocIndexOf.js +0 -14
  320. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseGetTag.js +0 -15
  321. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseIsNative.js +0 -16
  322. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_coreJsData.js +0 -9
  323. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_freeGlobal.js +0 -8
  324. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getMapData.js +0 -14
  325. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getNative.js +0 -15
  326. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getRawTag.js +0 -19
  327. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getValue.js +0 -11
  328. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashClear.js +0 -13
  329. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashDelete.js +0 -12
  330. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashGet.js +0 -18
  331. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashHas.js +0 -14
  332. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashSet.js +0 -14
  333. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isKeyable.js +0 -12
  334. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isMasked.js +0 -16
  335. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheClear.js +0 -11
  336. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheDelete.js +0 -14
  337. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheGet.js +0 -14
  338. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheHas.js +0 -13
  339. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheSet.js +0 -14
  340. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheClear.js +0 -19
  341. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheDelete.js +0 -14
  342. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheGet.js +0 -13
  343. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheHas.js +0 -13
  344. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheSet.js +0 -14
  345. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_nativeCreate.js +0 -9
  346. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_objectToString.js +0 -12
  347. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_root.js +0 -10
  348. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_toSource.js +0 -20
  349. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/eq.js +0 -11
  350. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isFunction.js +0 -16
  351. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isObject.js +0 -12
  352. package/dist/node_modules/.bun/lodash@4.18.1/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,260 @@
1
+ import React from 'react';
2
+ import { render } from '@pie-lib/test-utils';
3
+ import KeyLegend from '../key-legend';
4
+
5
+ describe('KeyLegend', () => {
6
+ describe('rendering', () => {
7
+ it('renders without crashing', () => {
8
+ const { container } = render(<KeyLegend />);
9
+ expect(container).toBeTruthy();
10
+ });
11
+
12
+ it('renders the title "Key"', () => {
13
+ const { getByText } = render(<KeyLegend />);
14
+ expect(getByText('Key')).toBeTruthy();
15
+ });
16
+
17
+ it('applies custom className when provided', () => {
18
+ const { container } = render(<KeyLegend className="custom-class" />);
19
+ const mainContainer = container.firstChild;
20
+ expect(mainContainer).toHaveClass('custom-class');
21
+ });
22
+
23
+ it('renders without className', () => {
24
+ const { container } = render(<KeyLegend />);
25
+ expect(container.firstChild).toBeTruthy();
26
+ });
27
+ });
28
+
29
+ describe('without label support (isLabelAvailable=false)', () => {
30
+ it('renders Answer Key Correct row', () => {
31
+ const { getByText } = render(<KeyLegend isLabelAvailable={false} />);
32
+ expect(getByText('Answer Key Correct')).toBeTruthy();
33
+ });
34
+
35
+ it('renders Student Incorrect row', () => {
36
+ const { getByText } = render(<KeyLegend isLabelAvailable={false} />);
37
+ expect(getByText('Student Incorrect')).toBeTruthy();
38
+ });
39
+
40
+ it('does not render Missing Required Label row', () => {
41
+ const { queryByText } = render(<KeyLegend isLabelAvailable={false} />);
42
+ expect(queryByText('Missing Required Label')).toBeFalsy();
43
+ });
44
+
45
+ it('does not render Answer Key Correct Label row', () => {
46
+ const { queryByText } = render(<KeyLegend isLabelAvailable={false} />);
47
+ expect(queryByText('Answer Key Correct Label')).toBeFalsy();
48
+ });
49
+
50
+ it('does not render Incorrect Student Label row', () => {
51
+ const { queryByText } = render(<KeyLegend isLabelAvailable={false} />);
52
+ expect(queryByText('Incorrect Student Label')).toBeFalsy();
53
+ });
54
+
55
+ it('renders exactly 2 rows (correct + incorrect)', () => {
56
+ const { getByText } = render(<KeyLegend isLabelAvailable={false} />);
57
+ // Verify the 2 text labels are present (one per row)
58
+ expect(getByText('Answer Key Correct')).toBeTruthy();
59
+ expect(getByText('Student Incorrect')).toBeTruthy();
60
+ });
61
+ });
62
+
63
+ describe('with label support (isLabelAvailable=true)', () => {
64
+ it('renders Missing Required Label row', () => {
65
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
66
+ expect(getByText('Missing Required Label')).toBeTruthy();
67
+ });
68
+
69
+ it('renders Answer Key Correct row', () => {
70
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
71
+ expect(getByText('Answer Key Correct')).toBeTruthy();
72
+ });
73
+
74
+ it('renders Answer Key Correct Label row', () => {
75
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
76
+ expect(getByText('Answer Key Correct Label')).toBeTruthy();
77
+ });
78
+
79
+ it('renders Student Incorrect row', () => {
80
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
81
+ expect(getByText('Student Incorrect')).toBeTruthy();
82
+ });
83
+
84
+ it('renders Incorrect Student Label row', () => {
85
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
86
+ expect(getByText('Incorrect Student Label')).toBeTruthy();
87
+ });
88
+
89
+ it('renders exactly 5 rows (all legend items)', () => {
90
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
91
+ // Verify all 5 text labels are present (one per row)
92
+ expect(getByText('Missing Required Label')).toBeTruthy();
93
+ expect(getByText('Answer Key Correct')).toBeTruthy();
94
+ expect(getByText('Answer Key Correct Label')).toBeTruthy();
95
+ expect(getByText('Student Incorrect')).toBeTruthy();
96
+ expect(getByText('Incorrect Student Label')).toBeTruthy();
97
+ });
98
+ });
99
+
100
+ describe('default behavior', () => {
101
+ it('treats undefined isLabelAvailable as false', () => {
102
+ const { queryByText } = render(<KeyLegend />);
103
+ expect(queryByText('Missing Required Label')).toBeFalsy();
104
+ expect(queryByText('Answer Key Correct Label')).toBeFalsy();
105
+ expect(queryByText('Incorrect Student Label')).toBeFalsy();
106
+ });
107
+ });
108
+
109
+ describe('SVG icons', () => {
110
+ it('renders SVG for Missing Required Label', () => {
111
+ const { container } = render(<KeyLegend isLabelAvailable={true} />);
112
+ const svgs = container.querySelectorAll('svg');
113
+ expect(svgs.length).toBeGreaterThan(0);
114
+ });
115
+
116
+ it('renders SVG for Answer Key Correct', () => {
117
+ const { container } = render(<KeyLegend isLabelAvailable={false} />);
118
+ const svgs = container.querySelectorAll('svg');
119
+ expect(svgs.length).toBeGreaterThan(0);
120
+ });
121
+
122
+ it('renders SVG for Student Incorrect', () => {
123
+ const { container } = render(<KeyLegend isLabelAvailable={false} />);
124
+ const svgs = container.querySelectorAll('svg');
125
+ // There are 3 SVGs: 2 for rows + possibly decorative elements
126
+ expect(svgs.length).toBeGreaterThanOrEqual(2);
127
+ });
128
+
129
+ it('renders more SVGs when labels are available', () => {
130
+ const { container: withoutLabels } = render(<KeyLegend isLabelAvailable={false} />);
131
+ const svgsWithoutLabels = withoutLabels.querySelectorAll('svg');
132
+
133
+ const { container: withLabels } = render(<KeyLegend isLabelAvailable={true} />);
134
+ const svgsWithLabels = withLabels.querySelectorAll('svg');
135
+
136
+ expect(svgsWithLabels.length).toBeGreaterThan(svgsWithoutLabels.length);
137
+ });
138
+ });
139
+
140
+ describe('styling', () => {
141
+ it('applies container styles', () => {
142
+ const { container } = render(<KeyLegend />);
143
+ const mainContainer = container.firstChild;
144
+
145
+ expect(mainContainer).toHaveStyle({
146
+ padding: '20px',
147
+ width: '355px',
148
+ });
149
+ });
150
+
151
+ it('renders title with correct styling', () => {
152
+ const { getByText } = render(<KeyLegend />);
153
+ const title = getByText('Key');
154
+
155
+ expect(title).toHaveStyle({
156
+ marginLeft: '30px',
157
+ fontWeight: '700',
158
+ marginBottom: '10px',
159
+ });
160
+ });
161
+ });
162
+
163
+ describe('row structure', () => {
164
+ it('each row contains text and SVG', () => {
165
+ const { getByText, container } = render(<KeyLegend isLabelAvailable={true} />);
166
+
167
+ // Verify that text labels exist
168
+ expect(getByText('Missing Required Label')).toBeTruthy();
169
+ expect(getByText('Answer Key Correct')).toBeTruthy();
170
+ expect(getByText('Answer Key Correct Label')).toBeTruthy();
171
+ expect(getByText('Student Incorrect')).toBeTruthy();
172
+ expect(getByText('Incorrect Student Label')).toBeTruthy();
173
+
174
+ // Verify SVGs exist
175
+ const svgs = container.querySelectorAll('svg');
176
+ expect(svgs.length).toBeGreaterThanOrEqual(5);
177
+ });
178
+
179
+ it('displays correct text alignment', () => {
180
+ const { getByText } = render(<KeyLegend />);
181
+ const text = getByText('Answer Key Correct');
182
+
183
+ expect(text).toHaveStyle({
184
+ textAlign: 'right',
185
+ marginRight: '10px',
186
+ });
187
+ });
188
+ });
189
+
190
+ describe('accessibility', () => {
191
+ it('includes descriptive text for each legend item', () => {
192
+ const { getByText } = render(<KeyLegend isLabelAvailable={true} />);
193
+
194
+ expect(getByText('Missing Required Label')).toBeTruthy();
195
+ expect(getByText('Answer Key Correct')).toBeTruthy();
196
+ expect(getByText('Answer Key Correct Label')).toBeTruthy();
197
+ expect(getByText('Student Incorrect')).toBeTruthy();
198
+ expect(getByText('Incorrect Student Label')).toBeTruthy();
199
+ });
200
+
201
+ it('SVGs are decorative (no role or aria-label needed)', () => {
202
+ const { container } = render(<KeyLegend isLabelAvailable={true} />);
203
+ const svgs = container.querySelectorAll('svg');
204
+
205
+ svgs.forEach((svg) => {
206
+ // SVGs should not have interactive roles
207
+ expect(svg.getAttribute('role')).toBeFalsy();
208
+ });
209
+ });
210
+ });
211
+
212
+ describe('edge cases', () => {
213
+ it('handles isLabelAvailable as boolean true', () => {
214
+ const { queryByText } = render(<KeyLegend isLabelAvailable={true} />);
215
+ expect(queryByText('Missing Required Label')).toBeTruthy();
216
+ });
217
+
218
+ it('handles isLabelAvailable as boolean false', () => {
219
+ const { queryByText } = render(<KeyLegend isLabelAvailable={false} />);
220
+ expect(queryByText('Missing Required Label')).toBeFalsy();
221
+ });
222
+
223
+ it('handles isLabelAvailable as truthy value', () => {
224
+ const { queryByText } = render(<KeyLegend isLabelAvailable={1} />);
225
+ expect(queryByText('Missing Required Label')).toBeTruthy();
226
+ });
227
+
228
+ it('handles isLabelAvailable as falsy value', () => {
229
+ const { queryByText } = render(<KeyLegend isLabelAvailable={0} />);
230
+ expect(queryByText('Missing Required Label')).toBeFalsy();
231
+ });
232
+ });
233
+
234
+ describe('updates', () => {
235
+ it('updates when isLabelAvailable changes from false to true', () => {
236
+ const { queryByText, rerender } = render(<KeyLegend isLabelAvailable={false} />);
237
+ expect(queryByText('Missing Required Label')).toBeFalsy();
238
+
239
+ rerender(<KeyLegend isLabelAvailable={true} />);
240
+ expect(queryByText('Missing Required Label')).toBeTruthy();
241
+ });
242
+
243
+ it('updates when isLabelAvailable changes from true to false', () => {
244
+ const { queryByText, rerender } = render(<KeyLegend isLabelAvailable={true} />);
245
+ expect(queryByText('Missing Required Label')).toBeTruthy();
246
+
247
+ rerender(<KeyLegend isLabelAvailable={false} />);
248
+ expect(queryByText('Missing Required Label')).toBeFalsy();
249
+ });
250
+
251
+ it('updates className on rerender', () => {
252
+ const { container, rerender } = render(<KeyLegend className="class1" />);
253
+ expect(container.firstChild).toHaveClass('class1');
254
+
255
+ rerender(<KeyLegend className="class2" />);
256
+ expect(container.firstChild).toHaveClass('class2');
257
+ expect(container.firstChild).not.toHaveClass('class1');
258
+ });
259
+ });
260
+ });
@@ -0,0 +1,278 @@
1
+ import React from 'react';
2
+ import { render } from '@pie-lib/test-utils';
3
+
4
+ import SvgIcon from '../label-svg-icon';
5
+
6
+ describe('SvgIcon', () => {
7
+ describe('rendering', () => {
8
+ it('renders without crashing with correct type', () => {
9
+ const { container } = render(<SvgIcon type="correct" />);
10
+ expect(container.firstChild).toBeInTheDocument();
11
+ });
12
+
13
+ it('renders correct icon type', () => {
14
+ const { container } = render(<SvgIcon type="correct" />);
15
+ const svg = container.querySelector('svg');
16
+ expect(svg).toBeInTheDocument();
17
+ expect(svg).toHaveAttribute('width', '8');
18
+ expect(svg).toHaveAttribute('height', '6');
19
+ });
20
+
21
+ it('renders incorrect icon type', () => {
22
+ const { container } = render(<SvgIcon type="incorrect" />);
23
+ const svg = container.querySelector('svg');
24
+ expect(svg).toBeInTheDocument();
25
+ expect(svg).toHaveAttribute('width', '7');
26
+ expect(svg).toHaveAttribute('height', '7');
27
+ });
28
+
29
+ it('renders empty icon type', () => {
30
+ const { container } = render(<SvgIcon type="empty" />);
31
+ const svg = container.querySelector('svg');
32
+ expect(svg).toBeInTheDocument();
33
+ expect(svg).toHaveAttribute('width', '11');
34
+ expect(svg).toHaveAttribute('height', '12');
35
+ });
36
+
37
+ it('renders null for unknown icon type', () => {
38
+ const { container } = render(<SvgIcon type="unknown" />);
39
+ expect(container.firstChild).toBeNull();
40
+ });
41
+
42
+ it('renders null for invalid icon type', () => {
43
+ const { container } = render(<SvgIcon type="invalid" />);
44
+ expect(container.firstChild).toBeNull();
45
+ });
46
+ });
47
+
48
+ describe('correct icon', () => {
49
+ it('has correct viewBox attribute', () => {
50
+ const { container } = render(<SvgIcon type="correct" />);
51
+ const svg = container.querySelector('svg');
52
+ expect(svg).toHaveAttribute('viewBox', '0 0 8 6');
53
+ });
54
+
55
+ it('has correct fill color for path', () => {
56
+ const { container } = render(<SvgIcon type="correct" />);
57
+ const path = container.querySelector('path');
58
+ expect(path).toHaveAttribute('fill', '#0B7D38');
59
+ });
60
+
61
+ it('has correct path d attribute for checkmark', () => {
62
+ const { container } = render(<SvgIcon type="correct" />);
63
+ const path = container.querySelector('path');
64
+ expect(path).toHaveAttribute('d');
65
+ const dAttribute = path.getAttribute('d');
66
+ expect(dAttribute).toContain('M6.79688');
67
+ });
68
+
69
+ it('has xmlns attribute', () => {
70
+ const { container } = render(<SvgIcon type="correct" />);
71
+ const svg = container.querySelector('svg');
72
+ expect(svg).toHaveAttribute('xmlns', 'http://www.w3.org/2000/svg');
73
+ });
74
+ });
75
+
76
+ describe('incorrect icon', () => {
77
+ it('has correct viewBox attribute', () => {
78
+ const { container } = render(<SvgIcon type="incorrect" />);
79
+ const svg = container.querySelector('svg');
80
+ expect(svg).toHaveAttribute('viewBox', '0 0 7 7');
81
+ });
82
+
83
+ it('has correct fill color for path', () => {
84
+ const { container } = render(<SvgIcon type="incorrect" />);
85
+ const path = container.querySelector('path');
86
+ expect(path).toHaveAttribute('fill', '#BF0D00');
87
+ });
88
+
89
+ it('has correct path d attribute for X mark', () => {
90
+ const { container } = render(<SvgIcon type="incorrect" />);
91
+ const path = container.querySelector('path');
92
+ expect(path).toHaveAttribute('d');
93
+ const dAttribute = path.getAttribute('d');
94
+ expect(dAttribute).toContain('M4.23438');
95
+ });
96
+
97
+ it('has xmlns attribute', () => {
98
+ const { container } = render(<SvgIcon type="incorrect" />);
99
+ const svg = container.querySelector('svg');
100
+ expect(svg).toHaveAttribute('xmlns', 'http://www.w3.org/2000/svg');
101
+ });
102
+ });
103
+
104
+ describe('empty icon', () => {
105
+ it('has correct viewBox attribute', () => {
106
+ const { container } = render(<SvgIcon type="empty" />);
107
+ const svg = container.querySelector('svg');
108
+ expect(svg).toHaveAttribute('viewBox', '0 0 11 12');
109
+ });
110
+
111
+ it('has correct fill color for path', () => {
112
+ const { container } = render(<SvgIcon type="empty" />);
113
+ const path = container.querySelector('path');
114
+ expect(path).toHaveAttribute('fill', '#BF0D00');
115
+ });
116
+
117
+ it('has correct path d attribute for empty frame', () => {
118
+ const { container } = render(<SvgIcon type="empty" />);
119
+ const path = container.querySelector('path');
120
+ expect(path).toHaveAttribute('d');
121
+ const dAttribute = path.getAttribute('d');
122
+ expect(dAttribute).toContain('M0.25');
123
+ });
124
+
125
+ it('has xmlns attribute', () => {
126
+ const { container } = render(<SvgIcon type="empty" />);
127
+ const svg = container.querySelector('svg');
128
+ expect(svg).toHaveAttribute('xmlns', 'http://www.w3.org/2000/svg');
129
+ });
130
+ });
131
+
132
+ describe('icon structure', () => {
133
+ it('correct icon has one path element', () => {
134
+ const { container } = render(<SvgIcon type="correct" />);
135
+ const paths = container.querySelectorAll('path');
136
+ expect(paths.length).toBe(1);
137
+ });
138
+
139
+ it('incorrect icon has one path element', () => {
140
+ const { container } = render(<SvgIcon type="incorrect" />);
141
+ const paths = container.querySelectorAll('path');
142
+ expect(paths.length).toBe(1);
143
+ });
144
+
145
+ it('empty icon has one path element', () => {
146
+ const { container } = render(<SvgIcon type="empty" />);
147
+ const paths = container.querySelectorAll('path');
148
+ expect(paths.length).toBe(1);
149
+ });
150
+
151
+ it('each icon renders only one svg element', () => {
152
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
153
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
154
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
155
+
156
+ expect(correctContainer.querySelectorAll('svg').length).toBe(1);
157
+ expect(incorrectContainer.querySelectorAll('svg').length).toBe(1);
158
+ expect(emptyContainer.querySelectorAll('svg').length).toBe(1);
159
+ });
160
+ });
161
+
162
+ describe('edge cases', () => {
163
+ it('handles empty string type gracefully', () => {
164
+ const { container } = render(<SvgIcon type="" />);
165
+ expect(container.firstChild).toBeNull();
166
+ });
167
+
168
+ it('handles null type gracefully', () => {
169
+ const { container } = render(<SvgIcon type={null} />);
170
+ expect(container.firstChild).toBeNull();
171
+ });
172
+
173
+ it('handles undefined type gracefully', () => {
174
+ const { container } = render(<SvgIcon type={undefined} />);
175
+ expect(container.firstChild).toBeNull();
176
+ });
177
+
178
+ it('handles numeric type gracefully', () => {
179
+ const { container } = render(<SvgIcon type={123} />);
180
+ expect(container.firstChild).toBeNull();
181
+ });
182
+
183
+ it('handles object type gracefully', () => {
184
+ const { container } = render(<SvgIcon type={{}} />);
185
+ expect(container.firstChild).toBeNull();
186
+ });
187
+ });
188
+
189
+ describe('icon differentiation', () => {
190
+ it('correct and incorrect icons have different dimensions', () => {
191
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
192
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
193
+
194
+ const correctSvg = correctContainer.querySelector('svg');
195
+ const incorrectSvg = incorrectContainer.querySelector('svg');
196
+
197
+ expect(correctSvg.getAttribute('width')).not.toBe(incorrectSvg.getAttribute('width'));
198
+ });
199
+
200
+ it('correct and empty icons have different fill colors', () => {
201
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
202
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
203
+
204
+ const correctPath = correctContainer.querySelector('path');
205
+ const emptyPath = emptyContainer.querySelector('path');
206
+
207
+ expect(correctPath.getAttribute('fill')).not.toBe(emptyPath.getAttribute('fill'));
208
+ });
209
+
210
+ it('incorrect and empty icons have same fill color', () => {
211
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
212
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
213
+
214
+ const incorrectPath = incorrectContainer.querySelector('path');
215
+ const emptyPath = emptyContainer.querySelector('path');
216
+
217
+ expect(incorrectPath.getAttribute('fill')).toBe(emptyPath.getAttribute('fill'));
218
+ });
219
+
220
+ it('each icon type has unique path data', () => {
221
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
222
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
223
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
224
+
225
+ const correctPath = correctContainer.querySelector('path').getAttribute('d');
226
+ const incorrectPath = incorrectContainer.querySelector('path').getAttribute('d');
227
+ const emptyPath = emptyContainer.querySelector('path').getAttribute('d');
228
+
229
+ expect(correctPath).not.toBe(incorrectPath);
230
+ expect(correctPath).not.toBe(emptyPath);
231
+ expect(incorrectPath).not.toBe(emptyPath);
232
+ });
233
+ });
234
+
235
+ describe('SVG attributes', () => {
236
+ it('all icons have fill="none" on svg element', () => {
237
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
238
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
239
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
240
+
241
+ expect(correctContainer.querySelector('svg')).toHaveAttribute('fill', 'none');
242
+ expect(incorrectContainer.querySelector('svg')).toHaveAttribute('fill', 'none');
243
+ expect(emptyContainer.querySelector('svg')).toHaveAttribute('fill', 'none');
244
+ });
245
+
246
+ it('all icons have proper xmlns namespace', () => {
247
+ const { container: correctContainer } = render(<SvgIcon type="correct" />);
248
+ const { container: incorrectContainer } = render(<SvgIcon type="incorrect" />);
249
+ const { container: emptyContainer } = render(<SvgIcon type="empty" />);
250
+
251
+ const xmlns = 'http://www.w3.org/2000/svg';
252
+ expect(correctContainer.querySelector('svg')).toHaveAttribute('xmlns', xmlns);
253
+ expect(incorrectContainer.querySelector('svg')).toHaveAttribute('xmlns', xmlns);
254
+ expect(emptyContainer.querySelector('svg')).toHaveAttribute('xmlns', xmlns);
255
+ });
256
+ });
257
+
258
+ describe('accessibility', () => {
259
+ it('svg elements are properly structured for screen readers', () => {
260
+ const { container } = render(<SvgIcon type="correct" />);
261
+ const svg = container.querySelector('svg');
262
+
263
+ // SVG should be in DOM
264
+ expect(svg).toBeInTheDocument();
265
+
266
+ // Should have valid viewBox for proper scaling
267
+ expect(svg.getAttribute('viewBox')).toBeTruthy();
268
+ });
269
+
270
+ it('icons render as inline elements', () => {
271
+ const { container } = render(<SvgIcon type="correct" />);
272
+ const svg = container.querySelector('svg');
273
+
274
+ // SVG should be direct child (inline)
275
+ expect(container.firstChild).toBe(svg);
276
+ });
277
+ });
278
+ });
@@ -0,0 +1,55 @@
1
+ import { render } from '@pie-lib/test-utils';
2
+ import React from 'react';
3
+
4
+ import Labels, { getTransform } from '../labels';
5
+
6
+ describe('Labels', () => {
7
+ let onChange = jest.fn();
8
+ const renderComponent = (extras) => {
9
+ const defaults = {
10
+ classes: {},
11
+ className: 'className',
12
+ onChange,
13
+ graphProps: {
14
+ size: {
15
+ width: 400,
16
+ height: 400,
17
+ },
18
+ domain: {
19
+ min: 0,
20
+ max: 10,
21
+ step: 1,
22
+ padding: 0,
23
+ },
24
+ range: {
25
+ min: 0,
26
+ max: 10,
27
+ step: 1,
28
+ padding: 0,
29
+ },
30
+ },
31
+ };
32
+ const props = { ...defaults, ...extras };
33
+ return render(<Labels {...props} />);
34
+ };
35
+ describe('rendering', () => {
36
+ it('renders without crashing', () => {
37
+ const { container } = renderComponent();
38
+ expect(container.firstChild).toBeInTheDocument();
39
+ });
40
+ });
41
+ });
42
+
43
+ describe('getTransform', () => {
44
+ const assertTransform = (side, expected) => {
45
+ it(`returns ${expected} for ${side}`, () => {
46
+ const r = getTransform('left', 100, 100);
47
+ expect(r).toEqual('translate(-20, 50), rotate(-90)');
48
+ });
49
+ };
50
+
51
+ assertTransform('left', 'translate(-20, 50), rotate(-90)');
52
+ assertTransform('right', 'translate(130, 50), rotate(90)');
53
+ assertTransform('top', 'translate(50, -20), rotate(0)');
54
+ assertTransform('bottom', 'translate(50, 130), rotate(0)');
55
+ });
@@ -0,0 +1,63 @@
1
+ import { render } from '@pie-lib/test-utils';
2
+ import React from 'react';
3
+ import { coordinates, MarkLabel, position } from '../mark-label';
4
+ import { graphProps as getGraphProps } from './utils';
5
+
6
+ describe('MarkLabel', () => {
7
+ let onChange = jest.fn();
8
+ let inputRef = jest.fn();
9
+ const renderComponent = (extras) => {
10
+ const defaults = {
11
+ classes: {},
12
+ className: 'className',
13
+ onChange,
14
+ inputRef,
15
+ mark: { x: 1, y: 1 },
16
+ graphProps: getGraphProps(0, 10, 0, 10),
17
+ };
18
+ const props = { ...defaults, ...extras };
19
+ return render(<MarkLabel {...props} />);
20
+ };
21
+ describe('rendering', () => {
22
+ it('renders without crashing', () => {
23
+ const { container } = renderComponent();
24
+ expect(container.firstChild).toBeInTheDocument();
25
+ });
26
+ it('renders with different mark position', () => {
27
+ const { container } = renderComponent({ mark: { x: 10, y: 10 } });
28
+ expect(container.firstChild).toBeInTheDocument();
29
+ });
30
+ });
31
+ });
32
+
33
+ describe('position', () => {
34
+ const assertPosition = (mark, rect, expected) => {
35
+ it(`${mark.x},${mark.y} + ${rect.width},${rect.height} => ${expected}`, () => {
36
+ // we set range.min to a value because in pixels - the greater the Y the lower down on the screen.
37
+ const graphProps = getGraphProps(0, 12, 12, 0);
38
+ const result = position(graphProps, mark, rect);
39
+ expect(result).toEqual(expected);
40
+ });
41
+ };
42
+
43
+ assertPosition({ x: 0, y: 0 }, { width: 10, height: 10 }, 'top-left');
44
+ assertPosition({ x: 0, y: 0 }, { width: 1, height: 1 }, 'bottom-right');
45
+ assertPosition({ x: 0, y: 0 }, { width: 10, height: 0 }, 'bottom-left');
46
+ assertPosition({ x: 0, y: 0 }, { width: 0, height: 10 }, 'top-right');
47
+ });
48
+
49
+ describe('coordinates', () => {
50
+ const assertCoordinates = (mark, rect, pos, expected) => {
51
+ it(`${mark.x}, ${mark.y} -> ${pos} = ${expected.left}, ${expected.top}`, () => {
52
+ const result = coordinates(getGraphProps(), mark, rect, pos);
53
+ expect(result).toEqual(expected);
54
+ });
55
+ };
56
+ assertCoordinates({ x: 0, y: 0 }, { width: 0, height: 0 }, 'top-left', { left: -5, top: -5 });
57
+ assertCoordinates({ x: 0, y: 0 }, { width: 0, height: 0 }, 'bottom-left', { left: -5, top: 5 });
58
+ assertCoordinates({ x: 0, y: 0 }, { width: 0, height: 0 }, 'top-right', { left: 5, top: -5 });
59
+ assertCoordinates({ x: 0, y: 0 }, { width: 0, height: 0 }, 'bottom-right', {
60
+ left: 5,
61
+ top: 5,
62
+ });
63
+ });