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