@pie-lib/graphing 4.0.5-next.3 → 4.0.5-next.30

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/dist/_virtual/_rolldown/runtime.js +23 -0
  2. package/dist/autosize-input.d.ts +10 -0
  3. package/dist/autosize-input.js +66 -0
  4. package/dist/axis/arrow.d.ts +13 -0
  5. package/dist/axis/arrow.js +34 -0
  6. package/dist/axis/axes.d.ts +132 -0
  7. package/dist/axis/axes.js +214 -0
  8. package/dist/axis/index.d.ts +10 -0
  9. package/dist/bg.d.ts +51 -0
  10. package/dist/bg.js +44 -0
  11. package/dist/container/actions.d.ts +15 -0
  12. package/dist/container/actions.js +7 -0
  13. package/dist/container/index.d.ts +58 -0
  14. package/dist/container/index.js +48 -0
  15. package/dist/container/marks.d.ts +10 -0
  16. package/dist/container/marks.js +11 -0
  17. package/dist/container/middleware.d.ts +10 -0
  18. package/dist/container/middleware.js +4 -0
  19. package/dist/container/reducer.d.ts +14 -0
  20. package/dist/container/reducer.js +7 -0
  21. package/dist/coordinates-label.d.ts +50 -0
  22. package/dist/coordinates-label.js +46 -0
  23. package/dist/graph-with-controls.d.ts +88 -0
  24. package/dist/graph-with-controls.js +154 -0
  25. package/dist/graph.d.ts +126 -0
  26. package/dist/graph.js +209 -0
  27. package/dist/grid-setup.d.ts +27 -0
  28. package/dist/grid-setup.js +307 -0
  29. package/dist/grid.d.ts +43 -0
  30. package/dist/grid.js +59 -0
  31. package/dist/index.d.ts +15 -0
  32. package/dist/index.js +7 -0
  33. package/dist/key-legend.d.ts +21 -0
  34. package/dist/key-legend.js +231 -0
  35. package/dist/label-svg-icon.d.ts +18 -0
  36. package/dist/label-svg-icon.js +42 -0
  37. package/dist/labels.d.ts +37 -0
  38. package/dist/labels.js +152 -0
  39. package/dist/mark-label.d.ts +58 -0
  40. package/dist/mark-label.js +171 -0
  41. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Axis.js +101 -0
  42. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisRenderer.js +63 -0
  43. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Ticks.js +44 -0
  44. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/constants/orientation.js +9 -0
  45. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/createPoint.js +14 -0
  46. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getAxisRangePaddingConfig.js +21 -0
  47. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getLabelTransform.js +16 -0
  48. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickFormatter.js +8 -0
  49. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickPosition.js +15 -0
  50. package/dist/node_modules/.bun/@visx_curve@3.12.0/node_modules/@visx/curve/esm/index.js +2 -0
  51. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/Grid.js +79 -0
  52. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridColumns.js +79 -0
  53. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridRows.js +79 -0
  54. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/utils/getScaleBandwidth.js +6 -0
  55. package/dist/node_modules/.bun/@visx_group@3.12.0_f4eacebf2041cd4f/node_modules/@visx/group/esm/Group.js +50 -0
  56. package/dist/node_modules/.bun/@visx_point@3.12.0/node_modules/@visx/point/esm/Point.js +18 -0
  57. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/coerceNumber.js +10 -0
  58. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/getTicks.js +9 -0
  59. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/toString.js +6 -0
  60. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Line.js +47 -0
  61. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/LinePath.js +50 -0
  62. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/D3ShapeFactories.js +9 -0
  63. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/setNumberOrNumberAccessor.js +6 -0
  64. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/lib/shapes/Line.js +53 -0
  65. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/Text.js +57 -0
  66. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/hooks/useText.js +91 -0
  67. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/util/getStringWidth.js +21 -0
  68. package/dist/node_modules/.bun/balanced-match@0.4.2/node_modules/balanced-match/index.js +32 -0
  69. package/dist/node_modules/.bun/balanced-match@1.0.2/node_modules/balanced-match/index.js +33 -0
  70. package/dist/node_modules/.bun/classnames@2.5.1/node_modules/classnames/index.js +32 -0
  71. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +16 -0
  72. package/dist/node_modules/.bun/invariant@2.2.4/node_modules/invariant/browser.js +28 -0
  73. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Hash.js +21 -0
  74. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_ListCache.js +21 -0
  75. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Map.js +10 -0
  76. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_MapCache.js +21 -0
  77. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Symbol.js +9 -0
  78. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_assocIndexOf.js +14 -0
  79. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseGetTag.js +15 -0
  80. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseIsNative.js +16 -0
  81. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_coreJsData.js +9 -0
  82. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_freeGlobal.js +8 -0
  83. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getMapData.js +14 -0
  84. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getNative.js +15 -0
  85. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getRawTag.js +19 -0
  86. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getValue.js +11 -0
  87. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashClear.js +13 -0
  88. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashDelete.js +12 -0
  89. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashGet.js +18 -0
  90. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashHas.js +14 -0
  91. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashSet.js +14 -0
  92. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isKeyable.js +12 -0
  93. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isMasked.js +16 -0
  94. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheClear.js +11 -0
  95. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheDelete.js +14 -0
  96. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheGet.js +14 -0
  97. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheHas.js +13 -0
  98. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheSet.js +14 -0
  99. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheClear.js +19 -0
  100. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheDelete.js +14 -0
  101. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheGet.js +13 -0
  102. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheHas.js +13 -0
  103. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheSet.js +14 -0
  104. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_nativeCreate.js +9 -0
  105. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_objectToString.js +12 -0
  106. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_root.js +10 -0
  107. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_toSource.js +20 -0
  108. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/eq.js +11 -0
  109. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isFunction.js +16 -0
  110. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isObject.js +12 -0
  111. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/memoize.js +20 -0
  112. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/formula_evaluator.js +37 -0
  113. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/lexer.js +509 -0
  114. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/math_function.js +108 -0
  115. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix.js +31 -0
  116. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix_evaluator.js +45 -0
  117. package/dist/node_modules/.bun/react-redux@9.3.0_9e2203c65d1d5fa1/node_modules/react-redux/dist/react-redux.js +471 -0
  118. package/dist/node_modules/.bun/reduce-css-calc@1.3.0/node_modules/reduce-css-calc/index.js +49 -0
  119. package/dist/node_modules/.bun/reduce-function-call@1.0.3/node_modules/reduce-function-call/index.js +34 -0
  120. package/dist/node_modules/.bun/redux-undo@1.1.0/node_modules/redux-undo/dist/redux-undo.js +185 -0
  121. package/dist/node_modules/.bun/redux@5.0.1/node_modules/redux/dist/redux.js +198 -0
  122. 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 +53 -0
  123. 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 +51 -0
  124. package/dist/node_modules/.bun/use-sync-external-store@1.6.0_f4eacebf2041cd4f/node_modules/use-sync-external-store/with-selector.js +10 -0
  125. package/dist/toggle-bar.d.ts +40 -0
  126. package/dist/toggle-bar.js +155 -0
  127. package/dist/tool-menu.d.ts +29 -0
  128. package/dist/tool-menu.js +41 -0
  129. package/dist/tools/absolute/component.d.ts +16 -0
  130. package/dist/tools/absolute/component.js +15 -0
  131. package/dist/tools/absolute/index.d.ts +20 -0
  132. package/dist/tools/absolute/index.js +32 -0
  133. package/dist/tools/circle/bg-circle.d.ts +116 -0
  134. package/dist/tools/circle/bg-circle.js +72 -0
  135. package/dist/tools/circle/component.d.ts +83 -0
  136. package/dist/tools/circle/component.js +195 -0
  137. package/dist/tools/circle/index.d.ts +20 -0
  138. package/dist/tools/circle/index.js +22 -0
  139. package/dist/tools/exponential/component.d.ts +16 -0
  140. package/dist/tools/exponential/component.js +14 -0
  141. package/dist/tools/exponential/index.d.ts +20 -0
  142. package/dist/tools/exponential/index.js +32 -0
  143. package/dist/tools/index.d.ts +27 -0
  144. package/dist/tools/index.js +55 -0
  145. package/dist/tools/line/component.d.ts +124 -0
  146. package/dist/tools/line/component.js +72 -0
  147. package/dist/tools/line/index.d.ts +13 -0
  148. package/dist/tools/line/index.js +6 -0
  149. package/dist/tools/parabola/component.d.ts +16 -0
  150. package/dist/tools/parabola/component.js +14 -0
  151. package/dist/tools/parabola/index.d.ts +20 -0
  152. package/dist/tools/parabola/index.js +32 -0
  153. package/dist/tools/point/component.d.ts +50 -0
  154. package/dist/tools/point/component.js +85 -0
  155. package/dist/tools/point/index.d.ts +15 -0
  156. package/dist/tools/point/index.js +13 -0
  157. package/dist/tools/polygon/component.d.ts +120 -0
  158. package/dist/tools/polygon/component.js +262 -0
  159. package/dist/tools/polygon/index.d.ts +19 -0
  160. package/dist/tools/polygon/index.js +55 -0
  161. package/dist/tools/polygon/line.d.ts +125 -0
  162. package/dist/tools/polygon/line.js +63 -0
  163. package/dist/tools/polygon/polygon.d.ts +122 -0
  164. package/dist/tools/polygon/polygon.js +74 -0
  165. package/dist/tools/ray/component.d.ts +101 -0
  166. package/dist/tools/ray/component.js +71 -0
  167. package/dist/tools/ray/index.d.ts +13 -0
  168. package/dist/tools/ray/index.js +6 -0
  169. package/dist/tools/segment/component.d.ts +100 -0
  170. package/dist/tools/segment/component.js +52 -0
  171. package/dist/tools/segment/index.d.ts +13 -0
  172. package/dist/tools/segment/index.js +6 -0
  173. package/dist/tools/shared/arrow-head.d.ts +51 -0
  174. package/dist/tools/shared/arrow-head.js +63 -0
  175. package/dist/tools/shared/icons/CorrectSVG.d.ts +26 -0
  176. package/dist/tools/shared/icons/CorrectSVG.js +29 -0
  177. package/dist/tools/shared/icons/IncorrectSVG.d.ts +26 -0
  178. package/dist/tools/shared/icons/IncorrectSVG.js +27 -0
  179. package/dist/tools/shared/icons/MissingSVG.d.ts +26 -0
  180. package/dist/tools/shared/icons/MissingSVG.js +28 -0
  181. package/dist/tools/shared/line/index.d.ts +245 -0
  182. package/dist/tools/shared/line/index.js +319 -0
  183. package/dist/tools/shared/line/line-path.d.ts +57 -0
  184. package/dist/tools/shared/line/line-path.js +71 -0
  185. package/dist/tools/shared/line/with-root-edge.d.ts +142 -0
  186. package/dist/tools/shared/line/with-root-edge.js +73 -0
  187. package/dist/tools/shared/point/arrow-point.d.ts +56 -0
  188. package/dist/tools/shared/point/arrow-point.js +41 -0
  189. package/dist/tools/shared/point/arrow.d.ts +45 -0
  190. package/dist/tools/shared/point/arrow.js +35 -0
  191. package/dist/tools/shared/point/base-point.d.ts +52 -0
  192. package/dist/tools/shared/point/base-point.js +103 -0
  193. package/dist/tools/shared/point/index.d.ts +216 -0
  194. package/dist/tools/shared/point/index.js +45 -0
  195. package/dist/tools/shared/styles.d.ts +29 -0
  196. package/dist/tools/shared/styles.js +20 -0
  197. package/dist/tools/shared/types.d.ts +21 -0
  198. package/dist/tools/shared/types.js +11 -0
  199. package/dist/tools/sine/component.d.ts +16 -0
  200. package/dist/tools/sine/component.js +22 -0
  201. package/dist/tools/sine/index.d.ts +20 -0
  202. package/dist/tools/sine/index.js +32 -0
  203. package/dist/tools/vector/component.d.ts +100 -0
  204. package/dist/tools/vector/component.js +44 -0
  205. package/dist/tools/vector/index.d.ts +13 -0
  206. package/dist/tools/vector/index.js +6 -0
  207. package/dist/undo-redo.d.ts +22 -0
  208. package/dist/undo-redo.js +47 -0
  209. package/dist/use-debounce.d.ts +9 -0
  210. package/dist/use-debounce.js +13 -0
  211. package/dist/utils.d.ts +61 -0
  212. package/dist/utils.js +75 -0
  213. package/package.json +45 -33
  214. package/CHANGELOG.json +0 -1
  215. package/CHANGELOG.md +0 -1469
  216. package/LICENSE.md +0 -5
  217. package/lib/axis/arrow.js +0 -79
  218. package/lib/axis/arrow.js.map +0 -1
  219. package/lib/axis/axes.js +0 -329
  220. package/lib/axis/axes.js.map +0 -1
  221. package/lib/axis/index.js +0 -21
  222. package/lib/axis/index.js.map +0 -1
  223. package/lib/bg.js +0 -114
  224. package/lib/bg.js.map +0 -1
  225. package/lib/container/actions.js +0 -18
  226. package/lib/container/actions.js.map +0 -1
  227. package/lib/container/index.js +0 -118
  228. package/lib/container/index.js.map +0 -1
  229. package/lib/container/marks.js +0 -22
  230. package/lib/container/marks.js.map +0 -1
  231. package/lib/container/middleware.js +0 -19
  232. package/lib/container/middleware.js.map +0 -1
  233. package/lib/container/reducer.js +0 -18
  234. package/lib/container/reducer.js.map +0 -1
  235. package/lib/coordinates-label.js +0 -79
  236. package/lib/coordinates-label.js.map +0 -1
  237. package/lib/graph-with-controls.js +0 -294
  238. package/lib/graph-with-controls.js.map +0 -1
  239. package/lib/graph.js +0 -327
  240. package/lib/graph.js.map +0 -1
  241. package/lib/grid-setup.js +0 -414
  242. package/lib/grid-setup.js.map +0 -1
  243. package/lib/grid.js +0 -131
  244. package/lib/grid.js.map +0 -1
  245. package/lib/index.js +0 -47
  246. package/lib/index.js.map +0 -1
  247. package/lib/key-legend.js +0 -201
  248. package/lib/key-legend.js.map +0 -1
  249. package/lib/label-svg-icon.js +0 -50
  250. package/lib/label-svg-icon.js.map +0 -1
  251. package/lib/labels.js +0 -243
  252. package/lib/labels.js.map +0 -1
  253. package/lib/mark-label.js +0 -285
  254. package/lib/mark-label.js.map +0 -1
  255. package/lib/toggle-bar.js +0 -252
  256. package/lib/toggle-bar.js.map +0 -1
  257. package/lib/tool-menu.js +0 -78
  258. package/lib/tool-menu.js.map +0 -1
  259. package/lib/tools/absolute/component.js +0 -29
  260. package/lib/tools/absolute/component.js.map +0 -1
  261. package/lib/tools/absolute/index.js +0 -50
  262. package/lib/tools/absolute/index.js.map +0 -1
  263. package/lib/tools/circle/bg-circle.js +0 -123
  264. package/lib/tools/circle/bg-circle.js.map +0 -1
  265. package/lib/tools/circle/component.js +0 -321
  266. package/lib/tools/circle/component.js.map +0 -1
  267. package/lib/tools/circle/index.js +0 -41
  268. package/lib/tools/circle/index.js.map +0 -1
  269. package/lib/tools/exponential/component.js +0 -28
  270. package/lib/tools/exponential/component.js.map +0 -1
  271. package/lib/tools/exponential/index.js +0 -56
  272. package/lib/tools/exponential/index.js.map +0 -1
  273. package/lib/tools/index.js +0 -86
  274. package/lib/tools/index.js.map +0 -1
  275. package/lib/tools/line/component.js +0 -97
  276. package/lib/tools/line/component.js.map +0 -1
  277. package/lib/tools/line/index.js +0 -11
  278. package/lib/tools/line/index.js.map +0 -1
  279. package/lib/tools/parabola/component.js +0 -28
  280. package/lib/tools/parabola/component.js.map +0 -1
  281. package/lib/tools/parabola/index.js +0 -50
  282. package/lib/tools/parabola/index.js.map +0 -1
  283. package/lib/tools/point/component.js +0 -148
  284. package/lib/tools/point/component.js.map +0 -1
  285. package/lib/tools/point/index.js +0 -24
  286. package/lib/tools/point/index.js.map +0 -1
  287. package/lib/tools/polygon/component.js +0 -437
  288. package/lib/tools/polygon/component.js.map +0 -1
  289. package/lib/tools/polygon/index.js +0 -89
  290. package/lib/tools/polygon/index.js.map +0 -1
  291. package/lib/tools/polygon/line.js +0 -112
  292. package/lib/tools/polygon/line.js.map +0 -1
  293. package/lib/tools/polygon/polygon.js +0 -130
  294. package/lib/tools/polygon/polygon.js.map +0 -1
  295. package/lib/tools/ray/component.js +0 -95
  296. package/lib/tools/ray/component.js.map +0 -1
  297. package/lib/tools/ray/index.js +0 -11
  298. package/lib/tools/ray/index.js.map +0 -1
  299. package/lib/tools/segment/component.js +0 -71
  300. package/lib/tools/segment/component.js.map +0 -1
  301. package/lib/tools/segment/index.js +0 -11
  302. package/lib/tools/segment/index.js.map +0 -1
  303. package/lib/tools/shared/arrow-head.js +0 -111
  304. package/lib/tools/shared/arrow-head.js.map +0 -1
  305. package/lib/tools/shared/icons/CorrectSVG.js +0 -40
  306. package/lib/tools/shared/icons/CorrectSVG.js.map +0 -1
  307. package/lib/tools/shared/icons/IncorrectSVG.js +0 -40
  308. package/lib/tools/shared/icons/IncorrectSVG.js.map +0 -1
  309. package/lib/tools/shared/icons/MissingSVG.js +0 -39
  310. package/lib/tools/shared/icons/MissingSVG.js.map +0 -1
  311. package/lib/tools/shared/line/index.js +0 -550
  312. package/lib/tools/shared/line/index.js.map +0 -1
  313. package/lib/tools/shared/line/line-path.js +0 -118
  314. package/lib/tools/shared/line/line-path.js.map +0 -1
  315. package/lib/tools/shared/line/with-root-edge.js +0 -121
  316. package/lib/tools/shared/line/with-root-edge.js.map +0 -1
  317. package/lib/tools/shared/point/arrow-point.js +0 -72
  318. package/lib/tools/shared/point/arrow-point.js.map +0 -1
  319. package/lib/tools/shared/point/arrow.js +0 -67
  320. package/lib/tools/shared/point/arrow.js.map +0 -1
  321. package/lib/tools/shared/point/base-point.js +0 -157
  322. package/lib/tools/shared/point/base-point.js.map +0 -1
  323. package/lib/tools/shared/point/index.js +0 -68
  324. package/lib/tools/shared/point/index.js.map +0 -1
  325. package/lib/tools/shared/styles.js +0 -33
  326. package/lib/tools/shared/styles.js.map +0 -1
  327. package/lib/tools/shared/types.js +0 -16
  328. package/lib/tools/shared/types.js.map +0 -1
  329. package/lib/tools/sine/component.js +0 -40
  330. package/lib/tools/sine/component.js.map +0 -1
  331. package/lib/tools/sine/index.js +0 -50
  332. package/lib/tools/sine/index.js.map +0 -1
  333. package/lib/tools/vector/component.js +0 -68
  334. package/lib/tools/vector/component.js.map +0 -1
  335. package/lib/tools/vector/index.js +0 -11
  336. package/lib/tools/vector/index.js.map +0 -1
  337. package/lib/undo-redo.js +0 -86
  338. package/lib/undo-redo.js.map +0 -1
  339. package/lib/use-debounce.js +0 -25
  340. package/lib/use-debounce.js.map +0 -1
  341. package/lib/utils.js +0 -229
  342. package/lib/utils.js.map +0 -1
  343. package/src/__tests__/bg.test.jsx +0 -250
  344. package/src/__tests__/coordinates-label.test.jsx +0 -243
  345. package/src/__tests__/graph-with-controls.test.jsx +0 -198
  346. package/src/__tests__/graph.test.jsx +0 -721
  347. package/src/__tests__/grid-setup.test.jsx +0 -645
  348. package/src/__tests__/grid.test.jsx +0 -22
  349. package/src/__tests__/key-legend.test.jsx +0 -260
  350. package/src/__tests__/label-svg-icon.test.jsx +0 -278
  351. package/src/__tests__/labels.test.jsx +0 -55
  352. package/src/__tests__/mark-label.test.jsx +0 -63
  353. package/src/__tests__/toggle-bar.test.jsx +0 -146
  354. package/src/__tests__/tool-menu.test.jsx +0 -115
  355. package/src/__tests__/undo-redo.test.jsx +0 -24
  356. package/src/__tests__/use-debounce.test.js +0 -21
  357. package/src/__tests__/utils.js +0 -41
  358. package/src/__tests__/utils.test.js +0 -105
  359. package/src/axis/__tests__/arrow.test.jsx +0 -38
  360. package/src/axis/__tests__/axes.test.jsx +0 -216
  361. package/src/axis/arrow.jsx +0 -57
  362. package/src/axis/axes.jsx +0 -285
  363. package/src/axis/index.js +0 -3
  364. package/src/bg.jsx +0 -96
  365. package/src/container/__tests__/actions.test.js +0 -105
  366. package/src/container/__tests__/index.test.jsx +0 -319
  367. package/src/container/__tests__/marks.test.js +0 -172
  368. package/src/container/__tests__/middleware.test.js +0 -235
  369. package/src/container/__tests__/reducer.test.js +0 -324
  370. package/src/container/actions.js +0 -8
  371. package/src/container/index.jsx +0 -83
  372. package/src/container/marks.js +0 -14
  373. package/src/container/middleware.js +0 -7
  374. package/src/container/reducer.js +0 -5
  375. package/src/coordinates-label.jsx +0 -63
  376. package/src/graph-with-controls.jsx +0 -239
  377. package/src/graph.jsx +0 -303
  378. package/src/grid-setup.jsx +0 -432
  379. package/src/grid.jsx +0 -133
  380. package/src/index.js +0 -7
  381. package/src/key-legend.jsx +0 -142
  382. package/src/label-svg-icon.jsx +0 -39
  383. package/src/labels.jsx +0 -207
  384. package/src/mark-label.jsx +0 -244
  385. package/src/toggle-bar.jsx +0 -224
  386. package/src/tool-menu.jsx +0 -49
  387. package/src/tools/absolute/__tests__/component.test.jsx +0 -53
  388. package/src/tools/absolute/component.jsx +0 -23
  389. package/src/tools/absolute/index.js +0 -31
  390. package/src/tools/circle/__tests__/bg-circle.test.jsx +0 -26
  391. package/src/tools/circle/__tests__/component.test.jsx +0 -494
  392. package/src/tools/circle/__tests__/index.test.js +0 -480
  393. package/src/tools/circle/bg-circle.jsx +0 -81
  394. package/src/tools/circle/component.jsx +0 -264
  395. package/src/tools/circle/index.js +0 -25
  396. package/src/tools/exponential/__tests__/component.test.jsx +0 -53
  397. package/src/tools/exponential/__tests__/index.test.js +0 -729
  398. package/src/tools/exponential/component.jsx +0 -23
  399. package/src/tools/exponential/index.js +0 -39
  400. package/src/tools/index.js +0 -48
  401. package/src/tools/line/__tests__/component.test.jsx +0 -37
  402. package/src/tools/line/component.jsx +0 -93
  403. package/src/tools/line/index.js +0 -4
  404. package/src/tools/parabola/__tests__/component.test.jsx +0 -48
  405. package/src/tools/parabola/__tests__/index.test.js +0 -470
  406. package/src/tools/parabola/component.jsx +0 -23
  407. package/src/tools/parabola/index.js +0 -31
  408. package/src/tools/point/__tests__/component.test.jsx +0 -349
  409. package/src/tools/point/__tests__/index.test.js +0 -241
  410. package/src/tools/point/component.jsx +0 -126
  411. package/src/tools/point/index.js +0 -11
  412. package/src/tools/polygon/__tests__/component.test.jsx +0 -471
  413. package/src/tools/polygon/__tests__/index.test.js +0 -294
  414. package/src/tools/polygon/__tests__/line.test.jsx +0 -35
  415. package/src/tools/polygon/__tests__/polygon.test.jsx +0 -61
  416. package/src/tools/polygon/component.jsx +0 -409
  417. package/src/tools/polygon/index.js +0 -52
  418. package/src/tools/polygon/line.jsx +0 -74
  419. package/src/tools/polygon/polygon.jsx +0 -110
  420. package/src/tools/ray/__tests__/component.test.jsx +0 -29
  421. package/src/tools/ray/component.jsx +0 -92
  422. package/src/tools/ray/index.js +0 -4
  423. package/src/tools/segment/__tests__/component.test.jsx +0 -28
  424. package/src/tools/segment/component.jsx +0 -65
  425. package/src/tools/segment/index.js +0 -4
  426. package/src/tools/shared/__tests__/arrow-head.test.jsx +0 -31
  427. package/src/tools/shared/arrow-head.jsx +0 -102
  428. package/src/tools/shared/icons/CorrectSVG.jsx +0 -32
  429. package/src/tools/shared/icons/IncorrectSVG.jsx +0 -30
  430. package/src/tools/shared/icons/MissingSVG.jsx +0 -31
  431. package/src/tools/shared/line/__tests__/index.test.jsx +0 -109
  432. package/src/tools/shared/line/__tests__/line-path.test.jsx +0 -53
  433. package/src/tools/shared/line/__tests__/with-root-edge.test.jsx +0 -73
  434. package/src/tools/shared/line/index.jsx +0 -487
  435. package/src/tools/shared/line/line-path.jsx +0 -80
  436. package/src/tools/shared/line/with-root-edge.jsx +0 -97
  437. package/src/tools/shared/point/__tests__/arrow-point.test.jsx +0 -91
  438. package/src/tools/shared/point/__tests__/base-point.test.jsx +0 -87
  439. package/src/tools/shared/point/arrow-point.jsx +0 -46
  440. package/src/tools/shared/point/arrow.jsx +0 -37
  441. package/src/tools/shared/point/base-point.jsx +0 -121
  442. package/src/tools/shared/point/index.jsx +0 -54
  443. package/src/tools/shared/styles.js +0 -27
  444. package/src/tools/shared/types.js +0 -10
  445. package/src/tools/sine/__tests__/component.test.jsx +0 -51
  446. package/src/tools/sine/component.jsx +0 -32
  447. package/src/tools/sine/index.js +0 -33
  448. package/src/tools/vector/__tests__/component.test.jsx +0 -25
  449. package/src/tools/vector/component.jsx +0 -56
  450. package/src/tools/vector/index.js +0 -4
  451. package/src/undo-redo.jsx +0 -45
  452. package/src/use-debounce.js +0 -13
  453. package/src/utils.js +0 -224
@@ -1,319 +0,0 @@
1
- import React from 'react';
2
- import { render, waitFor } from '@pie-lib/test-utils';
3
- import Root, { GraphContainer } from '../index';
4
- import { changeMarks } from '../actions';
5
-
6
- jest.mock('../../graph-with-controls', () => {
7
- return function GraphWithControls({ marks, onChangeMarks, onUndo, onRedo, onReset, disabled }) {
8
- return (
9
- <div data-testid="graph-with-controls">
10
- <div data-testid="marks-count">{marks?.length || 0}</div>
11
- {disabled && <div data-testid="disabled-indicator">Disabled</div>}
12
- <button data-testid="change-marks" onClick={() => onChangeMarks && onChangeMarks([{ id: 1 }])}>
13
- Change
14
- </button>
15
- <button data-testid="undo" onClick={onUndo}>
16
- Undo
17
- </button>
18
- <button data-testid="redo" onClick={onRedo}>
19
- Redo
20
- </button>
21
- <button data-testid="reset" onClick={onReset}>
22
- Reset
23
- </button>
24
- </div>
25
- );
26
- };
27
- });
28
-
29
- jest.mock('@pie-lib/drag', () => ({
30
- DragProvider: ({ children }) => <div data-testid="drag-provider">{children}</div>,
31
- }));
32
-
33
- describe('Container Root Component', () => {
34
- const defaultProps = {
35
- marks: [],
36
- onChangeMarks: jest.fn(),
37
- };
38
-
39
- const renderComponent = (props = {}) => {
40
- return render(<Root {...defaultProps} {...props} />);
41
- };
42
-
43
- describe('rendering', () => {
44
- it('renders without crashing', () => {
45
- const { container } = renderComponent();
46
- expect(container).toBeInTheDocument();
47
- });
48
-
49
- it('renders GraphWithControls', () => {
50
- const { getByTestId } = renderComponent();
51
- expect(getByTestId('graph-with-controls')).toBeInTheDocument();
52
- });
53
-
54
- it('renders with Provider when no correctness set', () => {
55
- const { container } = renderComponent({ marks: [{ id: 1, type: 'point' }] });
56
- expect(container.querySelector('[data-testid="graph-with-controls"]')).toBeInTheDocument();
57
- });
58
-
59
- it('renders directly when correctness is set', () => {
60
- const marks = [{ id: 1, type: 'point', correctness: { value: 'correct' } }];
61
- const { getByTestId } = renderComponent({ marks });
62
-
63
- expect(getByTestId('graph-with-controls')).toBeInTheDocument();
64
- expect(getByTestId('disabled-indicator')).toBeInTheDocument();
65
- });
66
-
67
- it('passes marks to GraphWithControls', () => {
68
- const marks = [{ id: 1 }, { id: 2 }];
69
- const { getByTestId } = renderComponent({ marks });
70
- expect(getByTestId('marks-count')).toHaveTextContent('2');
71
- });
72
- });
73
-
74
- describe('Redux store', () => {
75
- it('creates Redux store on mount', () => {
76
- const component = new Root({ marks: [], onChangeMarks: jest.fn() });
77
- expect(component.store).toBeDefined();
78
- expect(typeof component.store.getState).toBe('function');
79
- expect(typeof component.store.dispatch).toBe('function');
80
- });
81
-
82
- it('initializes store with marks from props', () => {
83
- const marks = [{ id: 1, type: 'point' }];
84
- const component = new Root({ marks, onChangeMarks: jest.fn() });
85
-
86
- const state = component.store.getState();
87
- expect(state.marks.present).toEqual(marks);
88
- });
89
-
90
- it('initializes store with empty marks', () => {
91
- const component = new Root({ marks: [], onChangeMarks: jest.fn() });
92
-
93
- const state = component.store.getState();
94
- expect(state.marks.present).toEqual([]);
95
- });
96
-
97
- it('subscribes to store changes', async () => {
98
- const onChangeMarks = jest.fn();
99
- const component = new Root({ marks: [], onChangeMarks });
100
-
101
- const newMarks = [{ id: 1 }];
102
- component.store.dispatch(changeMarks(newMarks));
103
-
104
- await waitFor(() => {
105
- expect(onChangeMarks).toHaveBeenCalledWith(newMarks);
106
- });
107
- });
108
- });
109
-
110
- describe('componentDidUpdate', () => {
111
- it('updates store when marks prop changes', () => {
112
- const onChangeMarks = jest.fn();
113
- const { rerender } = render(<Root marks={[]} onChangeMarks={onChangeMarks} />);
114
-
115
- const newMarks = [{ id: 1, type: 'point' }];
116
- rerender(<Root marks={newMarks} onChangeMarks={onChangeMarks} />);
117
-
118
- expect(onChangeMarks).not.toHaveBeenCalled();
119
- });
120
-
121
- it('does not update when marks are equal', () => {
122
- const marks = [{ id: 1, type: 'point' }];
123
- const onChangeMarks = jest.fn();
124
- const { rerender } = render(<Root marks={marks} onChangeMarks={onChangeMarks} />);
125
-
126
- onChangeMarks.mockClear();
127
-
128
- rerender(<Root marks={marks} onChangeMarks={onChangeMarks} />);
129
-
130
- expect(onChangeMarks).not.toHaveBeenCalled();
131
- });
132
-
133
- it('handles marks changing from empty to non-empty', () => {
134
- const onChangeMarks = jest.fn();
135
- const { rerender } = render(<Root marks={[]} onChangeMarks={onChangeMarks} />);
136
-
137
- const newMarks = [{ id: 1 }];
138
-
139
- expect(() => {
140
- rerender(<Root marks={newMarks} onChangeMarks={onChangeMarks} />);
141
- }).not.toThrow();
142
- });
143
-
144
- it('handles marks changing from non-empty to empty', () => {
145
- const onChangeMarks = jest.fn();
146
- const { rerender } = render(<Root marks={[{ id: 1 }]} onChangeMarks={onChangeMarks} />);
147
-
148
- expect(() => {
149
- rerender(<Root marks={[]} onChangeMarks={onChangeMarks} />);
150
- }).not.toThrow();
151
- });
152
- });
153
-
154
- describe('onStoreChange', () => {
155
- it('calls onChangeMarks when store state changes', async () => {
156
- const onChangeMarks = jest.fn();
157
- const component = new Root({ marks: [], onChangeMarks });
158
-
159
- const newMarks = [{ id: 1, type: 'point' }];
160
- component.store.dispatch(changeMarks(newMarks));
161
-
162
- await waitFor(() => {
163
- expect(onChangeMarks).toHaveBeenCalledWith(newMarks);
164
- });
165
- });
166
-
167
- it('does not call onChangeMarks when marks are equal', () => {
168
- const marks = [{ id: 1, type: 'point' }];
169
- const onChangeMarks = jest.fn();
170
- const component = new Root({ marks, onChangeMarks });
171
-
172
- onChangeMarks.mockClear();
173
-
174
- component.store.dispatch(changeMarks(marks));
175
-
176
- expect(onChangeMarks).not.toHaveBeenCalled();
177
- });
178
-
179
- it('handles multiple store changes', async () => {
180
- const onChangeMarks = jest.fn();
181
- const component = new Root({ marks: [], onChangeMarks });
182
-
183
- component.store.dispatch(changeMarks([{ id: 1 }]));
184
- component.store.dispatch(changeMarks([{ id: 2 }]));
185
- component.store.dispatch(changeMarks([{ id: 3 }]));
186
-
187
- await waitFor(() => {
188
- expect(onChangeMarks).toHaveBeenCalledTimes(3);
189
- });
190
- });
191
- });
192
-
193
- describe('correctness handling', () => {
194
- it('disables when any mark has correctness', () => {
195
- const marks = [
196
- { id: 1, type: 'point' },
197
- { id: 2, type: 'point', correctness: { value: 'correct' } },
198
- ];
199
- const { getByTestId } = renderComponent({ marks });
200
-
201
- expect(getByTestId('disabled-indicator')).toBeInTheDocument();
202
- });
203
-
204
- it('renders without Provider when correctness is set', () => {
205
- const marks = [{ id: 1, correctness: { value: 'correct' } }];
206
- const { container } = renderComponent({ marks });
207
-
208
- expect(container.querySelector('[data-testid="graph-with-controls"]')).toBeInTheDocument();
209
- });
210
-
211
- it('does not disable when no correctness is set', () => {
212
- const marks = [
213
- { id: 1, type: 'point' },
214
- { id: 2, type: 'line' },
215
- ];
216
- const { queryByTestId } = renderComponent({ marks });
217
-
218
- expect(queryByTestId('disabled-indicator')).not.toBeInTheDocument();
219
- });
220
-
221
- it('handles correctness with different values', () => {
222
- const marks = [{ id: 1, correctness: { value: 'incorrect' } }];
223
- const { getByTestId } = renderComponent({ marks });
224
-
225
- expect(getByTestId('disabled-indicator')).toBeInTheDocument();
226
- });
227
-
228
- it('handles empty correctness object', () => {
229
- const marks = [{ id: 1, correctness: {} }];
230
- const { getByTestId } = renderComponent({ marks });
231
-
232
- expect(getByTestId('disabled-indicator')).toBeInTheDocument();
233
- });
234
- });
235
-
236
- describe('props forwarding', () => {
237
- it('forwards additional props to GraphWithControls', () => {
238
- const { container } = renderComponent({
239
- className: 'custom-class',
240
- size: { width: 500, height: 500 },
241
- });
242
-
243
- expect(container.querySelector('[data-testid="graph-with-controls"]')).toBeInTheDocument();
244
- });
245
-
246
- it('does not forward onChangeMarks and marks to GraphWithControls', () => {
247
- const { getByTestId } = renderComponent({
248
- marks: [{ id: 1 }],
249
- onChangeMarks: jest.fn(),
250
- otherProp: 'test',
251
- });
252
-
253
- expect(getByTestId('graph-with-controls')).toBeInTheDocument();
254
- });
255
- });
256
-
257
- describe('edge cases', () => {
258
- it('handles empty marks array', () => {
259
- const { container } = renderComponent({ marks: [] });
260
- expect(container).toBeInTheDocument();
261
- });
262
-
263
- it('handles marks with complex structure', () => {
264
- const marks = [
265
- {
266
- id: 1,
267
- type: 'line',
268
- from: { x: 0, y: 0 },
269
- to: { x: 10, y: 10 },
270
- label: 'Line A',
271
- correctness: { value: 'correct', label: 'Correct!' },
272
- },
273
- ];
274
- const { getByTestId } = renderComponent({ marks });
275
- expect(getByTestId('graph-with-controls')).toBeInTheDocument();
276
- });
277
-
278
- it('handles switching between correctness states', () => {
279
- const { rerender } = render(<Root marks={[{ id: 1 }]} onChangeMarks={jest.fn()} />);
280
-
281
- rerender(<Root marks={[{ id: 1, correctness: { value: 'correct' } }]} onChangeMarks={jest.fn()} />);
282
-
283
- rerender(<Root marks={[{ id: 1 }]} onChangeMarks={jest.fn()} />);
284
-
285
- expect(document.querySelector('[data-testid="graph-with-controls"]')).toBeInTheDocument();
286
- });
287
- });
288
-
289
- describe('store synchronization', () => {
290
- it('keeps store and props in sync', async () => {
291
- const onChangeMarks = jest.fn();
292
- const component = new Root({ marks: [], onChangeMarks });
293
-
294
- const newMarks = [{ id: 1 }];
295
- component.store.dispatch(changeMarks(newMarks));
296
-
297
- await waitFor(() => {
298
- const state = component.store.getState();
299
- expect(state.marks.present).toEqual(newMarks);
300
- expect(onChangeMarks).toHaveBeenCalledWith(newMarks);
301
- });
302
- });
303
- });
304
- });
305
-
306
- describe('GraphContainer (connected component)', () => {
307
- it('is a connected component', () => {
308
- expect(GraphContainer).toBeDefined();
309
- expect(GraphContainer.displayName).toContain('Connect');
310
- });
311
-
312
- it('maps state to props', () => {
313
- expect(GraphContainer).toBeDefined();
314
- });
315
-
316
- it('maps dispatch to props', () => {
317
- expect(GraphContainer).toBeDefined();
318
- });
319
- });
@@ -1,172 +0,0 @@
1
- import marks from '../marks';
2
-
3
- describe('marks reducer', () => {
4
- describe('initial state', () => {
5
- it('returns empty array as initial state', () => {
6
- const state = marks(undefined, { type: 'INIT' });
7
- expect(state).toEqual([]);
8
- });
9
-
10
- it('handles no state parameter', () => {
11
- const state = marks(undefined, { type: 'UNKNOWN_ACTION' });
12
- expect(Array.isArray(state)).toBe(true);
13
- });
14
- });
15
-
16
- describe('CHANGE_MARKS action', () => {
17
- it('updates state with new marks', () => {
18
- const initialState = [];
19
- const newMarks = [{ id: 1, type: 'point' }];
20
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
21
-
22
- const state = marks(initialState, action);
23
- expect(state).toEqual(newMarks);
24
- });
25
-
26
- it('replaces existing marks', () => {
27
- const initialState = [{ id: 1, type: 'point' }];
28
- const newMarks = [{ id: 2, type: 'line' }];
29
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
30
-
31
- const state = marks(initialState, action);
32
- expect(state).toEqual(newMarks);
33
- expect(state.length).toBe(1);
34
- expect(state[0].id).toBe(2);
35
- });
36
-
37
- it('handles empty marks array', () => {
38
- const initialState = [{ id: 1, type: 'point' }];
39
- const action = { type: 'CHANGE_MARKS', marks: [] };
40
-
41
- const state = marks(initialState, action);
42
- expect(state).toEqual([]);
43
- });
44
-
45
- it('handles multiple marks', () => {
46
- const initialState = [];
47
- const newMarks = [
48
- { id: 1, type: 'point', x: 1, y: 2 },
49
- { id: 2, type: 'line', from: { x: 0, y: 0 }, to: { x: 5, y: 5 } },
50
- { id: 3, type: 'circle', center: { x: 3, y: 3 }, radius: 2 },
51
- ];
52
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
53
-
54
- const state = marks(initialState, action);
55
- expect(state).toEqual(newMarks);
56
- expect(state.length).toBe(3);
57
- });
58
-
59
- it('throws error when marks is not an array', () => {
60
- const initialState = [];
61
- const action = { type: 'CHANGE_MARKS', marks: 'not an array' };
62
-
63
- expect(() => marks(initialState, action)).toThrow('marks must be an array');
64
- });
65
-
66
- it('throws error when marks is null', () => {
67
- const initialState = [];
68
- const action = { type: 'CHANGE_MARKS', marks: null };
69
-
70
- expect(() => marks(initialState, action)).toThrow('marks must be an array');
71
- });
72
-
73
- it('throws error when marks is undefined', () => {
74
- const initialState = [];
75
- const action = { type: 'CHANGE_MARKS', marks: undefined };
76
-
77
- expect(() => marks(initialState, action)).toThrow('marks must be an array');
78
- });
79
-
80
- it('throws error when marks is an object', () => {
81
- const initialState = [];
82
- const action = { type: 'CHANGE_MARKS', marks: { id: 1 } };
83
-
84
- expect(() => marks(initialState, action)).toThrow('marks must be an array');
85
- });
86
-
87
- it('throws error when marks is a number', () => {
88
- const initialState = [];
89
- const action = { type: 'CHANGE_MARKS', marks: 123 };
90
-
91
- expect(() => marks(initialState, action)).toThrow('marks must be an array');
92
- });
93
-
94
- it('preserves mark properties', () => {
95
- const initialState = [];
96
- const newMarks = [
97
- {
98
- id: 1,
99
- type: 'point',
100
- x: 10,
101
- y: 20,
102
- label: 'A',
103
- correctness: { value: 'correct' },
104
- editable: true,
105
- interactive: true,
106
- },
107
- ];
108
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
109
-
110
- const state = marks(initialState, action);
111
- expect(state[0]).toEqual(newMarks[0]);
112
- expect(state[0].correctness).toBeDefined();
113
- expect(state[0].editable).toBe(true);
114
- });
115
- });
116
-
117
- describe('unknown actions', () => {
118
- it('returns current state for unknown action', () => {
119
- const initialState = [{ id: 1, type: 'point' }];
120
- const action = { type: 'UNKNOWN_ACTION' };
121
-
122
- const state = marks(initialState, action);
123
- expect(state).toBe(initialState);
124
- });
125
-
126
- it('returns current state for ADD_MARK action', () => {
127
- const initialState = [{ id: 1, type: 'point' }];
128
- const action = { type: 'ADD_MARK' };
129
-
130
- const state = marks(initialState, action);
131
- expect(state).toBe(initialState);
132
- });
133
-
134
- it('does not modify state for unknown actions', () => {
135
- const initialState = [{ id: 1, type: 'point' }];
136
- const action = { type: 'SOME_OTHER_ACTION', data: 'test' };
137
-
138
- const state = marks(initialState, action);
139
- expect(state).toEqual(initialState);
140
- });
141
- });
142
-
143
- describe('immutability', () => {
144
- it('does not mutate original state', () => {
145
- const initialState = [{ id: 1, type: 'point' }];
146
- const originalState = [...initialState];
147
- const newMarks = [{ id: 2, type: 'line' }];
148
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
149
-
150
- marks(initialState, action);
151
- expect(initialState).toEqual(originalState);
152
- });
153
-
154
- it('returns new array reference for CHANGE_MARKS', () => {
155
- const initialState = [{ id: 1, type: 'point' }];
156
- const newMarks = [{ id: 1, type: 'point' }];
157
- const action = { type: 'CHANGE_MARKS', marks: newMarks };
158
-
159
- const state = marks(initialState, action);
160
- expect(state).not.toBe(initialState);
161
- expect(state).toBe(newMarks);
162
- });
163
-
164
- it('returns same reference for unknown actions', () => {
165
- const initialState = [{ id: 1, type: 'point' }];
166
- const action = { type: 'UNKNOWN_ACTION' };
167
-
168
- const state = marks(initialState, action);
169
- expect(state).toBe(initialState);
170
- });
171
- });
172
- });