@pie-lib/graphing 4.0.4 → 4.0.5-next.0

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 (475) hide show
  1. package/dist/_virtual/_rolldown/runtime.js +23 -0
  2. package/dist/axis/arrow.d.ts +13 -0
  3. package/dist/axis/arrow.js +34 -0
  4. package/dist/axis/axes.d.ts +132 -0
  5. package/dist/axis/axes.js +214 -0
  6. package/dist/axis/index.d.ts +10 -0
  7. package/dist/bg.d.ts +51 -0
  8. package/dist/bg.js +44 -0
  9. package/dist/container/actions.d.ts +15 -0
  10. package/dist/container/actions.js +7 -0
  11. package/dist/container/index.d.ts +26 -0
  12. package/dist/container/index.js +50 -0
  13. package/dist/container/marks.d.ts +10 -0
  14. package/dist/container/marks.js +11 -0
  15. package/dist/container/middleware.d.ts +10 -0
  16. package/dist/container/middleware.js +4 -0
  17. package/dist/container/reducer.d.ts +12 -0
  18. package/dist/container/reducer.js +7 -0
  19. package/dist/coordinates-label.d.ts +50 -0
  20. package/dist/coordinates-label.js +46 -0
  21. package/dist/graph-with-controls.d.ts +88 -0
  22. package/dist/graph-with-controls.js +154 -0
  23. package/dist/graph.d.ts +126 -0
  24. package/dist/graph.js +209 -0
  25. package/dist/grid-setup.d.ts +27 -0
  26. package/dist/grid-setup.js +307 -0
  27. package/dist/grid.d.ts +43 -0
  28. package/dist/grid.js +59 -0
  29. package/dist/index.d.ts +15 -0
  30. package/dist/index.js +7 -0
  31. package/dist/key-legend.d.ts +21 -0
  32. package/dist/key-legend.js +231 -0
  33. package/dist/label-svg-icon.d.ts +18 -0
  34. package/dist/label-svg-icon.js +42 -0
  35. package/dist/labels.d.ts +37 -0
  36. package/dist/labels.js +152 -0
  37. package/dist/mark-label.d.ts +58 -0
  38. package/dist/mark-label.js +172 -0
  39. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js +7 -0
  40. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/defineProperty.js +12 -0
  41. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/extends.js +12 -0
  42. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js +7 -0
  43. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/objectSpread2.js +25 -0
  44. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +12 -0
  45. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js +8 -0
  46. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/toPrimitive.js +14 -0
  47. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js +9 -0
  48. package/dist/node_modules/.bun/@babel_runtime@7.29.7/node_modules/@babel/runtime/helpers/esm/typeof.js +11 -0
  49. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Axis.js +100 -0
  50. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisRenderer.js +61 -0
  51. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Ticks.js +42 -0
  52. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/constants/orientation.js +9 -0
  53. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/createPoint.js +14 -0
  54. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getAxisRangePaddingConfig.js +21 -0
  55. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getLabelTransform.js +16 -0
  56. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickFormatter.js +8 -0
  57. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickPosition.js +15 -0
  58. package/dist/node_modules/.bun/@visx_curve@3.12.0/node_modules/@visx/curve/esm/index.js +2 -0
  59. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/Grid.js +78 -0
  60. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridColumns.js +79 -0
  61. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridRows.js +79 -0
  62. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/utils/getScaleBandwidth.js +6 -0
  63. package/dist/node_modules/.bun/@visx_group@3.12.0_f4eacebf2041cd4f/node_modules/@visx/group/esm/Group.js +49 -0
  64. package/dist/node_modules/.bun/@visx_point@3.12.0/node_modules/@visx/point/esm/Point.js +18 -0
  65. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/coerceNumber.js +10 -0
  66. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/getTicks.js +9 -0
  67. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/toString.js +6 -0
  68. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Line.js +46 -0
  69. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/LinePath.js +49 -0
  70. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/D3ShapeFactories.js +9 -0
  71. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/setNumberOrNumberAccessor.js +6 -0
  72. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/lib/shapes/Line.js +52 -0
  73. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/Text.js +57 -0
  74. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/hooks/useText.js +91 -0
  75. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/util/getStringWidth.js +21 -0
  76. package/dist/node_modules/.bun/balanced-match@0.4.2/node_modules/balanced-match/index.js +32 -0
  77. package/dist/node_modules/.bun/balanced-match@1.0.2/node_modules/balanced-match/index.js +33 -0
  78. package/dist/node_modules/.bun/hoist-non-react-statics@3.3.2/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js +68 -0
  79. package/dist/node_modules/.bun/invariant@2.2.4/node_modules/invariant/browser.js +28 -0
  80. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Hash.js +21 -0
  81. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_ListCache.js +21 -0
  82. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Map.js +10 -0
  83. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_MapCache.js +21 -0
  84. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Symbol.js +9 -0
  85. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_assocIndexOf.js +14 -0
  86. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseGetTag.js +15 -0
  87. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseIsNative.js +16 -0
  88. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_coreJsData.js +9 -0
  89. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_freeGlobal.js +8 -0
  90. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getMapData.js +14 -0
  91. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getNative.js +15 -0
  92. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getRawTag.js +19 -0
  93. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getValue.js +11 -0
  94. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashClear.js +13 -0
  95. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashDelete.js +12 -0
  96. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashGet.js +18 -0
  97. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashHas.js +14 -0
  98. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashSet.js +14 -0
  99. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isKeyable.js +12 -0
  100. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isMasked.js +16 -0
  101. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheClear.js +11 -0
  102. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheDelete.js +14 -0
  103. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheGet.js +14 -0
  104. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheHas.js +13 -0
  105. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheSet.js +14 -0
  106. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheClear.js +19 -0
  107. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheDelete.js +14 -0
  108. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheGet.js +13 -0
  109. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheHas.js +13 -0
  110. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheSet.js +14 -0
  111. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_nativeCreate.js +9 -0
  112. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_objectToString.js +12 -0
  113. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_root.js +10 -0
  114. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_toSource.js +20 -0
  115. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/eq.js +11 -0
  116. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isFunction.js +16 -0
  117. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isObject.js +12 -0
  118. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/memoize.js +20 -0
  119. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/formula_evaluator.js +37 -0
  120. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/lexer.js +509 -0
  121. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/math_function.js +108 -0
  122. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix.js +31 -0
  123. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix_evaluator.js +45 -0
  124. package/dist/node_modules/.bun/react-input-autosize@2.2.2_f4eacebf2041cd4f/node_modules/react-input-autosize/lib/AutosizeInput.js +216 -0
  125. package/dist/node_modules/.bun/react-is@16.13.1/node_modules/react-is/cjs/react-is.development.js +82 -0
  126. package/dist/node_modules/.bun/react-is@16.13.1/node_modules/react-is/cjs/react-is.production.min.js +62 -0
  127. package/dist/node_modules/.bun/react-is@16.13.1/node_modules/react-is/index.js +10 -0
  128. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/components/Context.js +5 -0
  129. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/components/Provider.js +47 -0
  130. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/components/connectAdvanced.js +95 -0
  131. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/connect.js +52 -0
  132. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/mapDispatchToProps.js +23 -0
  133. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/mapStateToProps.js +13 -0
  134. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/mergeProps.js +26 -0
  135. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/selectorFactory.js +41 -0
  136. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/verifySubselectors.js +11 -0
  137. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/connect/wrapMapToProps.js +28 -0
  138. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/index.js +4 -0
  139. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/utils/isPlainObject.js +10 -0
  140. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/utils/shallowEqual.js +15 -0
  141. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/utils/verifyPlainObject.js +8 -0
  142. package/dist/node_modules/.bun/react-redux@6.0.1_926323a638b43722/node_modules/react-redux/es/utils/warning.js +9 -0
  143. package/dist/node_modules/.bun/reduce-css-calc@1.3.0/node_modules/reduce-css-calc/index.js +49 -0
  144. package/dist/node_modules/.bun/reduce-function-call@1.0.3/node_modules/reduce-function-call/index.js +34 -0
  145. package/dist/node_modules/.bun/redux-undo@1.1.0/node_modules/redux-undo/dist/redux-undo.js +185 -0
  146. package/dist/node_modules/.bun/redux@4.2.1/node_modules/redux/es/redux.js +225 -0
  147. package/dist/toggle-bar.d.ts +40 -0
  148. package/dist/toggle-bar.js +155 -0
  149. package/dist/tool-menu.d.ts +29 -0
  150. package/dist/tool-menu.js +41 -0
  151. package/dist/tools/absolute/component.d.ts +16 -0
  152. package/dist/tools/absolute/component.js +15 -0
  153. package/dist/tools/absolute/index.d.ts +20 -0
  154. package/dist/tools/absolute/index.js +32 -0
  155. package/dist/tools/circle/bg-circle.d.ts +116 -0
  156. package/dist/tools/circle/bg-circle.js +72 -0
  157. package/dist/tools/circle/component.d.ts +83 -0
  158. package/dist/tools/circle/component.js +195 -0
  159. package/dist/tools/circle/index.d.ts +20 -0
  160. package/dist/tools/circle/index.js +22 -0
  161. package/dist/tools/exponential/component.d.ts +16 -0
  162. package/dist/tools/exponential/component.js +14 -0
  163. package/dist/tools/exponential/index.d.ts +20 -0
  164. package/dist/tools/exponential/index.js +32 -0
  165. package/dist/tools/index.d.ts +27 -0
  166. package/dist/tools/index.js +55 -0
  167. package/dist/tools/line/component.d.ts +124 -0
  168. package/dist/tools/line/component.js +72 -0
  169. package/dist/tools/line/index.d.ts +13 -0
  170. package/dist/tools/line/index.js +6 -0
  171. package/dist/tools/parabola/component.d.ts +16 -0
  172. package/dist/tools/parabola/component.js +14 -0
  173. package/dist/tools/parabola/index.d.ts +20 -0
  174. package/dist/tools/parabola/index.js +32 -0
  175. package/dist/tools/point/component.d.ts +50 -0
  176. package/dist/tools/point/component.js +85 -0
  177. package/dist/tools/point/index.d.ts +15 -0
  178. package/dist/tools/point/index.js +13 -0
  179. package/dist/tools/polygon/component.d.ts +117 -0
  180. package/dist/tools/polygon/component.js +262 -0
  181. package/dist/tools/polygon/index.d.ts +19 -0
  182. package/dist/tools/polygon/index.js +55 -0
  183. package/dist/tools/polygon/line.d.ts +125 -0
  184. package/dist/tools/polygon/line.js +63 -0
  185. package/dist/tools/polygon/polygon.d.ts +122 -0
  186. package/dist/tools/polygon/polygon.js +74 -0
  187. package/dist/tools/ray/component.d.ts +101 -0
  188. package/dist/tools/ray/component.js +71 -0
  189. package/dist/tools/ray/index.d.ts +13 -0
  190. package/dist/tools/ray/index.js +6 -0
  191. package/dist/tools/segment/component.d.ts +100 -0
  192. package/dist/tools/segment/component.js +52 -0
  193. package/dist/tools/segment/index.d.ts +13 -0
  194. package/dist/tools/segment/index.js +6 -0
  195. package/dist/tools/shared/arrow-head.d.ts +51 -0
  196. package/dist/tools/shared/arrow-head.js +63 -0
  197. package/dist/tools/shared/icons/CorrectSVG.d.ts +26 -0
  198. package/dist/tools/shared/icons/CorrectSVG.js +29 -0
  199. package/dist/tools/shared/icons/IncorrectSVG.d.ts +26 -0
  200. package/dist/tools/shared/icons/IncorrectSVG.js +27 -0
  201. package/dist/tools/shared/icons/MissingSVG.d.ts +26 -0
  202. package/dist/tools/shared/icons/MissingSVG.js +28 -0
  203. package/dist/tools/shared/line/index.d.ts +245 -0
  204. package/dist/tools/shared/line/index.js +319 -0
  205. package/dist/tools/shared/line/line-path.d.ts +57 -0
  206. package/dist/tools/shared/line/line-path.js +71 -0
  207. package/dist/tools/shared/line/with-root-edge.d.ts +142 -0
  208. package/dist/tools/shared/line/with-root-edge.js +73 -0
  209. package/dist/tools/shared/point/arrow-point.d.ts +56 -0
  210. package/dist/tools/shared/point/arrow-point.js +41 -0
  211. package/dist/tools/shared/point/arrow.d.ts +45 -0
  212. package/dist/tools/shared/point/arrow.js +35 -0
  213. package/dist/tools/shared/point/base-point.d.ts +52 -0
  214. package/dist/tools/shared/point/base-point.js +103 -0
  215. package/dist/tools/shared/point/index.d.ts +216 -0
  216. package/dist/tools/shared/point/index.js +45 -0
  217. package/dist/tools/shared/styles.d.ts +29 -0
  218. package/dist/tools/shared/styles.js +20 -0
  219. package/dist/tools/shared/types.d.ts +21 -0
  220. package/dist/tools/shared/types.js +11 -0
  221. package/dist/tools/sine/component.d.ts +16 -0
  222. package/dist/tools/sine/component.js +22 -0
  223. package/dist/tools/sine/index.d.ts +20 -0
  224. package/dist/tools/sine/index.js +32 -0
  225. package/dist/tools/vector/component.d.ts +100 -0
  226. package/dist/tools/vector/component.js +44 -0
  227. package/dist/tools/vector/index.d.ts +13 -0
  228. package/dist/tools/vector/index.js +6 -0
  229. package/dist/undo-redo.d.ts +22 -0
  230. package/dist/undo-redo.js +47 -0
  231. package/dist/use-debounce.d.ts +9 -0
  232. package/dist/use-debounce.js +13 -0
  233. package/dist/utils.d.ts +61 -0
  234. package/dist/utils.js +75 -0
  235. package/package.json +35 -25
  236. package/CHANGELOG.json +0 -1
  237. package/CHANGELOG.md +0 -1469
  238. package/LICENSE.md +0 -5
  239. package/lib/axis/arrow.js +0 -79
  240. package/lib/axis/arrow.js.map +0 -1
  241. package/lib/axis/axes.js +0 -329
  242. package/lib/axis/axes.js.map +0 -1
  243. package/lib/axis/index.js +0 -21
  244. package/lib/axis/index.js.map +0 -1
  245. package/lib/bg.js +0 -114
  246. package/lib/bg.js.map +0 -1
  247. package/lib/container/actions.js +0 -18
  248. package/lib/container/actions.js.map +0 -1
  249. package/lib/container/index.js +0 -118
  250. package/lib/container/index.js.map +0 -1
  251. package/lib/container/marks.js +0 -22
  252. package/lib/container/marks.js.map +0 -1
  253. package/lib/container/middleware.js +0 -19
  254. package/lib/container/middleware.js.map +0 -1
  255. package/lib/container/reducer.js +0 -18
  256. package/lib/container/reducer.js.map +0 -1
  257. package/lib/coordinates-label.js +0 -79
  258. package/lib/coordinates-label.js.map +0 -1
  259. package/lib/graph-with-controls.js +0 -294
  260. package/lib/graph-with-controls.js.map +0 -1
  261. package/lib/graph.js +0 -327
  262. package/lib/graph.js.map +0 -1
  263. package/lib/grid-setup.js +0 -414
  264. package/lib/grid-setup.js.map +0 -1
  265. package/lib/grid.js +0 -131
  266. package/lib/grid.js.map +0 -1
  267. package/lib/index.js +0 -47
  268. package/lib/index.js.map +0 -1
  269. package/lib/key-legend.js +0 -201
  270. package/lib/key-legend.js.map +0 -1
  271. package/lib/label-svg-icon.js +0 -50
  272. package/lib/label-svg-icon.js.map +0 -1
  273. package/lib/labels.js +0 -243
  274. package/lib/labels.js.map +0 -1
  275. package/lib/mark-label.js +0 -285
  276. package/lib/mark-label.js.map +0 -1
  277. package/lib/toggle-bar.js +0 -252
  278. package/lib/toggle-bar.js.map +0 -1
  279. package/lib/tool-menu.js +0 -78
  280. package/lib/tool-menu.js.map +0 -1
  281. package/lib/tools/absolute/component.js +0 -29
  282. package/lib/tools/absolute/component.js.map +0 -1
  283. package/lib/tools/absolute/index.js +0 -50
  284. package/lib/tools/absolute/index.js.map +0 -1
  285. package/lib/tools/circle/bg-circle.js +0 -123
  286. package/lib/tools/circle/bg-circle.js.map +0 -1
  287. package/lib/tools/circle/component.js +0 -321
  288. package/lib/tools/circle/component.js.map +0 -1
  289. package/lib/tools/circle/index.js +0 -41
  290. package/lib/tools/circle/index.js.map +0 -1
  291. package/lib/tools/exponential/component.js +0 -28
  292. package/lib/tools/exponential/component.js.map +0 -1
  293. package/lib/tools/exponential/index.js +0 -56
  294. package/lib/tools/exponential/index.js.map +0 -1
  295. package/lib/tools/index.js +0 -86
  296. package/lib/tools/index.js.map +0 -1
  297. package/lib/tools/line/component.js +0 -97
  298. package/lib/tools/line/component.js.map +0 -1
  299. package/lib/tools/line/index.js +0 -11
  300. package/lib/tools/line/index.js.map +0 -1
  301. package/lib/tools/parabola/component.js +0 -28
  302. package/lib/tools/parabola/component.js.map +0 -1
  303. package/lib/tools/parabola/index.js +0 -50
  304. package/lib/tools/parabola/index.js.map +0 -1
  305. package/lib/tools/point/component.js +0 -148
  306. package/lib/tools/point/component.js.map +0 -1
  307. package/lib/tools/point/index.js +0 -24
  308. package/lib/tools/point/index.js.map +0 -1
  309. package/lib/tools/polygon/component.js +0 -437
  310. package/lib/tools/polygon/component.js.map +0 -1
  311. package/lib/tools/polygon/index.js +0 -89
  312. package/lib/tools/polygon/index.js.map +0 -1
  313. package/lib/tools/polygon/line.js +0 -112
  314. package/lib/tools/polygon/line.js.map +0 -1
  315. package/lib/tools/polygon/polygon.js +0 -130
  316. package/lib/tools/polygon/polygon.js.map +0 -1
  317. package/lib/tools/ray/component.js +0 -95
  318. package/lib/tools/ray/component.js.map +0 -1
  319. package/lib/tools/ray/index.js +0 -11
  320. package/lib/tools/ray/index.js.map +0 -1
  321. package/lib/tools/segment/component.js +0 -71
  322. package/lib/tools/segment/component.js.map +0 -1
  323. package/lib/tools/segment/index.js +0 -11
  324. package/lib/tools/segment/index.js.map +0 -1
  325. package/lib/tools/shared/arrow-head.js +0 -111
  326. package/lib/tools/shared/arrow-head.js.map +0 -1
  327. package/lib/tools/shared/icons/CorrectSVG.js +0 -40
  328. package/lib/tools/shared/icons/CorrectSVG.js.map +0 -1
  329. package/lib/tools/shared/icons/IncorrectSVG.js +0 -40
  330. package/lib/tools/shared/icons/IncorrectSVG.js.map +0 -1
  331. package/lib/tools/shared/icons/MissingSVG.js +0 -39
  332. package/lib/tools/shared/icons/MissingSVG.js.map +0 -1
  333. package/lib/tools/shared/line/index.js +0 -550
  334. package/lib/tools/shared/line/index.js.map +0 -1
  335. package/lib/tools/shared/line/line-path.js +0 -118
  336. package/lib/tools/shared/line/line-path.js.map +0 -1
  337. package/lib/tools/shared/line/with-root-edge.js +0 -121
  338. package/lib/tools/shared/line/with-root-edge.js.map +0 -1
  339. package/lib/tools/shared/point/arrow-point.js +0 -72
  340. package/lib/tools/shared/point/arrow-point.js.map +0 -1
  341. package/lib/tools/shared/point/arrow.js +0 -67
  342. package/lib/tools/shared/point/arrow.js.map +0 -1
  343. package/lib/tools/shared/point/base-point.js +0 -157
  344. package/lib/tools/shared/point/base-point.js.map +0 -1
  345. package/lib/tools/shared/point/index.js +0 -68
  346. package/lib/tools/shared/point/index.js.map +0 -1
  347. package/lib/tools/shared/styles.js +0 -33
  348. package/lib/tools/shared/styles.js.map +0 -1
  349. package/lib/tools/shared/types.js +0 -16
  350. package/lib/tools/shared/types.js.map +0 -1
  351. package/lib/tools/sine/component.js +0 -40
  352. package/lib/tools/sine/component.js.map +0 -1
  353. package/lib/tools/sine/index.js +0 -50
  354. package/lib/tools/sine/index.js.map +0 -1
  355. package/lib/tools/vector/component.js +0 -68
  356. package/lib/tools/vector/component.js.map +0 -1
  357. package/lib/tools/vector/index.js +0 -11
  358. package/lib/tools/vector/index.js.map +0 -1
  359. package/lib/undo-redo.js +0 -86
  360. package/lib/undo-redo.js.map +0 -1
  361. package/lib/use-debounce.js +0 -25
  362. package/lib/use-debounce.js.map +0 -1
  363. package/lib/utils.js +0 -229
  364. package/lib/utils.js.map +0 -1
  365. package/src/__tests__/bg.test.jsx +0 -250
  366. package/src/__tests__/coordinates-label.test.jsx +0 -243
  367. package/src/__tests__/graph-with-controls.test.jsx +0 -198
  368. package/src/__tests__/graph.test.jsx +0 -721
  369. package/src/__tests__/grid-setup.test.jsx +0 -645
  370. package/src/__tests__/grid.test.jsx +0 -22
  371. package/src/__tests__/key-legend.test.jsx +0 -260
  372. package/src/__tests__/label-svg-icon.test.jsx +0 -278
  373. package/src/__tests__/labels.test.jsx +0 -55
  374. package/src/__tests__/mark-label.test.jsx +0 -63
  375. package/src/__tests__/toggle-bar.test.jsx +0 -146
  376. package/src/__tests__/tool-menu.test.jsx +0 -115
  377. package/src/__tests__/undo-redo.test.jsx +0 -24
  378. package/src/__tests__/use-debounce.test.js +0 -21
  379. package/src/__tests__/utils.js +0 -41
  380. package/src/__tests__/utils.test.js +0 -105
  381. package/src/axis/__tests__/arrow.test.jsx +0 -38
  382. package/src/axis/__tests__/axes.test.jsx +0 -216
  383. package/src/axis/arrow.jsx +0 -57
  384. package/src/axis/axes.jsx +0 -285
  385. package/src/axis/index.js +0 -3
  386. package/src/bg.jsx +0 -96
  387. package/src/container/__tests__/actions.test.js +0 -105
  388. package/src/container/__tests__/index.test.jsx +0 -319
  389. package/src/container/__tests__/marks.test.js +0 -172
  390. package/src/container/__tests__/middleware.test.js +0 -235
  391. package/src/container/__tests__/reducer.test.js +0 -324
  392. package/src/container/actions.js +0 -8
  393. package/src/container/index.jsx +0 -83
  394. package/src/container/marks.js +0 -14
  395. package/src/container/middleware.js +0 -7
  396. package/src/container/reducer.js +0 -5
  397. package/src/coordinates-label.jsx +0 -63
  398. package/src/graph-with-controls.jsx +0 -239
  399. package/src/graph.jsx +0 -303
  400. package/src/grid-setup.jsx +0 -432
  401. package/src/grid.jsx +0 -133
  402. package/src/index.js +0 -7
  403. package/src/key-legend.jsx +0 -142
  404. package/src/label-svg-icon.jsx +0 -39
  405. package/src/labels.jsx +0 -207
  406. package/src/mark-label.jsx +0 -244
  407. package/src/toggle-bar.jsx +0 -224
  408. package/src/tool-menu.jsx +0 -49
  409. package/src/tools/absolute/__tests__/component.test.jsx +0 -53
  410. package/src/tools/absolute/component.jsx +0 -23
  411. package/src/tools/absolute/index.js +0 -31
  412. package/src/tools/circle/__tests__/bg-circle.test.jsx +0 -26
  413. package/src/tools/circle/__tests__/component.test.jsx +0 -494
  414. package/src/tools/circle/__tests__/index.test.js +0 -480
  415. package/src/tools/circle/bg-circle.jsx +0 -81
  416. package/src/tools/circle/component.jsx +0 -264
  417. package/src/tools/circle/index.js +0 -25
  418. package/src/tools/exponential/__tests__/component.test.jsx +0 -53
  419. package/src/tools/exponential/__tests__/index.test.js +0 -729
  420. package/src/tools/exponential/component.jsx +0 -23
  421. package/src/tools/exponential/index.js +0 -39
  422. package/src/tools/index.js +0 -48
  423. package/src/tools/line/__tests__/component.test.jsx +0 -37
  424. package/src/tools/line/component.jsx +0 -93
  425. package/src/tools/line/index.js +0 -4
  426. package/src/tools/parabola/__tests__/component.test.jsx +0 -48
  427. package/src/tools/parabola/__tests__/index.test.js +0 -470
  428. package/src/tools/parabola/component.jsx +0 -23
  429. package/src/tools/parabola/index.js +0 -31
  430. package/src/tools/point/__tests__/component.test.jsx +0 -349
  431. package/src/tools/point/__tests__/index.test.js +0 -241
  432. package/src/tools/point/component.jsx +0 -126
  433. package/src/tools/point/index.js +0 -11
  434. package/src/tools/polygon/__tests__/component.test.jsx +0 -471
  435. package/src/tools/polygon/__tests__/index.test.js +0 -294
  436. package/src/tools/polygon/__tests__/line.test.jsx +0 -35
  437. package/src/tools/polygon/__tests__/polygon.test.jsx +0 -61
  438. package/src/tools/polygon/component.jsx +0 -409
  439. package/src/tools/polygon/index.js +0 -52
  440. package/src/tools/polygon/line.jsx +0 -74
  441. package/src/tools/polygon/polygon.jsx +0 -110
  442. package/src/tools/ray/__tests__/component.test.jsx +0 -29
  443. package/src/tools/ray/component.jsx +0 -92
  444. package/src/tools/ray/index.js +0 -4
  445. package/src/tools/segment/__tests__/component.test.jsx +0 -28
  446. package/src/tools/segment/component.jsx +0 -65
  447. package/src/tools/segment/index.js +0 -4
  448. package/src/tools/shared/__tests__/arrow-head.test.jsx +0 -31
  449. package/src/tools/shared/arrow-head.jsx +0 -102
  450. package/src/tools/shared/icons/CorrectSVG.jsx +0 -32
  451. package/src/tools/shared/icons/IncorrectSVG.jsx +0 -30
  452. package/src/tools/shared/icons/MissingSVG.jsx +0 -31
  453. package/src/tools/shared/line/__tests__/index.test.jsx +0 -109
  454. package/src/tools/shared/line/__tests__/line-path.test.jsx +0 -53
  455. package/src/tools/shared/line/__tests__/with-root-edge.test.jsx +0 -73
  456. package/src/tools/shared/line/index.jsx +0 -487
  457. package/src/tools/shared/line/line-path.jsx +0 -80
  458. package/src/tools/shared/line/with-root-edge.jsx +0 -97
  459. package/src/tools/shared/point/__tests__/arrow-point.test.jsx +0 -91
  460. package/src/tools/shared/point/__tests__/base-point.test.jsx +0 -87
  461. package/src/tools/shared/point/arrow-point.jsx +0 -46
  462. package/src/tools/shared/point/arrow.jsx +0 -37
  463. package/src/tools/shared/point/base-point.jsx +0 -121
  464. package/src/tools/shared/point/index.jsx +0 -54
  465. package/src/tools/shared/styles.js +0 -27
  466. package/src/tools/shared/types.js +0 -10
  467. package/src/tools/sine/__tests__/component.test.jsx +0 -51
  468. package/src/tools/sine/component.jsx +0 -32
  469. package/src/tools/sine/index.js +0 -33
  470. package/src/tools/vector/__tests__/component.test.jsx +0 -25
  471. package/src/tools/vector/component.jsx +0 -56
  472. package/src/tools/vector/index.js +0 -4
  473. package/src/undo-redo.jsx +0 -45
  474. package/src/use-debounce.js +0 -13
  475. 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
- });