@pie-lib/charting 7.0.4-next.30 → 7.0.4-next.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/CHANGELOG.json +17 -0
  2. package/CHANGELOG.md +1116 -0
  3. package/LICENSE.md +5 -0
  4. package/lib/actions-button.js +145 -0
  5. package/lib/actions-button.js.map +1 -0
  6. package/lib/axes.js +643 -0
  7. package/lib/axes.js.map +1 -0
  8. package/lib/bars/bar.js +58 -0
  9. package/lib/bars/bar.js.map +1 -0
  10. package/lib/bars/common/bars.js +277 -0
  11. package/lib/bars/common/bars.js.map +1 -0
  12. package/lib/bars/common/correct-check-icon.js +54 -0
  13. package/lib/bars/common/correct-check-icon.js.map +1 -0
  14. package/lib/bars/histogram.js +59 -0
  15. package/lib/bars/histogram.js.map +1 -0
  16. package/lib/chart-setup.js +382 -0
  17. package/lib/chart-setup.js.map +1 -0
  18. package/lib/chart-type.js +80 -0
  19. package/lib/chart-type.js.map +1 -0
  20. package/lib/chart-types.js +22 -0
  21. package/lib/chart-types.js.map +1 -0
  22. package/lib/chart.js +384 -0
  23. package/lib/chart.js.map +1 -0
  24. package/lib/common/correctness-indicators.js +156 -0
  25. package/lib/common/correctness-indicators.js.map +1 -0
  26. package/lib/common/drag-handle.js +160 -0
  27. package/lib/common/drag-handle.js.map +1 -0
  28. package/lib/common/drag-icon.js +52 -0
  29. package/lib/common/drag-icon.js.map +1 -0
  30. package/lib/common/styles.js +22 -0
  31. package/lib/common/styles.js.map +1 -0
  32. package/lib/grid.js +112 -0
  33. package/lib/grid.js.map +1 -0
  34. package/lib/index.js +42 -0
  35. package/lib/index.js.map +1 -0
  36. package/lib/key-legend.js +87 -0
  37. package/lib/key-legend.js.map +1 -0
  38. package/lib/line/common/drag-handle.js +146 -0
  39. package/lib/line/common/drag-handle.js.map +1 -0
  40. package/lib/line/common/line.js +214 -0
  41. package/lib/line/common/line.js.map +1 -0
  42. package/lib/line/line-cross.js +214 -0
  43. package/lib/line/line-cross.js.map +1 -0
  44. package/lib/line/line-dot.js +158 -0
  45. package/lib/line/line-dot.js.map +1 -0
  46. package/lib/mark-label.js +237 -0
  47. package/lib/mark-label.js.map +1 -0
  48. package/lib/plot/common/plot.js +349 -0
  49. package/lib/plot/common/plot.js.map +1 -0
  50. package/lib/plot/dot.js +110 -0
  51. package/lib/plot/dot.js.map +1 -0
  52. package/lib/plot/line.js +140 -0
  53. package/lib/plot/line.js.map +1 -0
  54. package/lib/tool-menu.js +106 -0
  55. package/lib/tool-menu.js.map +1 -0
  56. package/lib/utils.js +189 -0
  57. package/lib/utils.js.map +1 -0
  58. package/package.json +28 -39
  59. package/src/__tests__/actions-button.test.jsx +280 -0
  60. package/src/__tests__/axes.test.jsx +667 -0
  61. package/src/__tests__/chart-setup.test.jsx +532 -0
  62. package/src/__tests__/chart-type.test.jsx +23 -0
  63. package/src/__tests__/chart.test.jsx +86 -0
  64. package/src/__tests__/grid.test.jsx +37 -0
  65. package/src/__tests__/key-legend.test.jsx +223 -0
  66. package/src/__tests__/mark-label.test.jsx +33 -0
  67. package/src/__tests__/tool-menu.test.jsx +522 -0
  68. package/src/__tests__/utils.js +36 -0
  69. package/src/__tests__/utils.test.js +100 -0
  70. package/src/actions-button.jsx +115 -0
  71. package/src/axes.jsx +594 -0
  72. package/src/bars/__tests__/bar.test.jsx +45 -0
  73. package/src/bars/__tests__/histogram.test.jsx +45 -0
  74. package/src/bars/__tests__/utils.js +30 -0
  75. package/src/bars/bar.js +28 -0
  76. package/src/bars/common/__tests__/bars.test.jsx +68 -0
  77. package/src/bars/common/__tests__/utils.js +30 -0
  78. package/src/bars/common/bars.jsx +249 -0
  79. package/src/bars/common/correct-check-icon.jsx +25 -0
  80. package/src/bars/histogram.js +28 -0
  81. package/src/chart-setup.jsx +356 -0
  82. package/src/chart-type.js +59 -0
  83. package/src/chart-types.js +8 -0
  84. package/src/chart.jsx +357 -0
  85. package/src/common/__tests__/correctness-indicators.test.jsx +720 -0
  86. package/src/common/__tests__/drag-handle.test.jsx +58 -0
  87. package/src/common/__tests__/utils.js +30 -0
  88. package/src/common/correctness-indicators.jsx +128 -0
  89. package/src/common/drag-handle.jsx +125 -0
  90. package/src/common/drag-icon.jsx +36 -0
  91. package/src/common/styles.js +19 -0
  92. package/src/grid.jsx +80 -0
  93. package/src/index.js +7 -0
  94. package/src/key-legend.jsx +77 -0
  95. package/src/line/__tests__/line-cross.test.jsx +463 -0
  96. package/src/line/__tests__/line-dot.test.jsx +41 -0
  97. package/src/line/__tests__/utils.js +36 -0
  98. package/src/line/common/__tests__/drag-handle.test.jsx +62 -0
  99. package/src/line/common/__tests__/line.test.jsx +79 -0
  100. package/src/line/common/__tests__/utils.js +30 -0
  101. package/src/line/common/drag-handle.jsx +114 -0
  102. package/src/line/common/line.jsx +171 -0
  103. package/src/line/line-cross.js +144 -0
  104. package/src/line/line-dot.js +111 -0
  105. package/src/mark-label.jsx +238 -0
  106. package/src/plot/__tests__/dot.test.jsx +344 -0
  107. package/src/plot/__tests__/line.test.jsx +375 -0
  108. package/src/plot/__tests__/utils.js +30 -0
  109. package/src/plot/common/__tests__/plot.test.jsx +69 -0
  110. package/src/plot/common/__tests__/utils.js +30 -0
  111. package/src/plot/common/plot.jsx +358 -0
  112. package/src/plot/dot.js +74 -0
  113. package/src/plot/line.js +98 -0
  114. package/src/tool-menu.jsx +85 -0
  115. package/src/utils.js +201 -0
  116. package/dist/_virtual/_rolldown/runtime.js +0 -23
  117. package/dist/actions-button.d.ts +0 -26
  118. package/dist/actions-button.js +0 -84
  119. package/dist/autosize-input.d.ts +0 -10
  120. package/dist/autosize-input.js +0 -66
  121. package/dist/axes.d.ts +0 -84
  122. package/dist/axes.js +0 -376
  123. package/dist/bars/bar.d.ts +0 -47
  124. package/dist/bars/bar.js +0 -27
  125. package/dist/bars/common/bars.d.ts +0 -98
  126. package/dist/bars/common/bars.js +0 -174
  127. package/dist/bars/common/correct-check-icon.d.ts +0 -18
  128. package/dist/bars/common/correct-check-icon.js +0 -50
  129. package/dist/bars/histogram.d.ts +0 -47
  130. package/dist/bars/histogram.js +0 -28
  131. package/dist/chart-setup.d.ts +0 -29
  132. package/dist/chart-setup.js +0 -231
  133. package/dist/chart-type.d.ts +0 -32
  134. package/dist/chart-type.js +0 -68
  135. package/dist/chart-types.d.ts +0 -41
  136. package/dist/chart-types.js +0 -17
  137. package/dist/chart.d.ts +0 -88
  138. package/dist/chart.js +0 -250
  139. package/dist/common/correctness-indicators.d.ts +0 -70
  140. package/dist/common/correctness-indicators.js +0 -106
  141. package/dist/common/drag-handle.d.ts +0 -129
  142. package/dist/common/drag-handle.js +0 -120
  143. package/dist/common/drag-icon.d.ts +0 -23
  144. package/dist/common/drag-icon.js +0 -45
  145. package/dist/common/styles.d.ts +0 -23
  146. package/dist/common/styles.js +0 -17
  147. package/dist/grid.d.ts +0 -45
  148. package/dist/grid.js +0 -56
  149. package/dist/index.d.ts +0 -14
  150. package/dist/index.js +0 -6
  151. package/dist/key-legend.d.ts +0 -19
  152. package/dist/key-legend.js +0 -46
  153. package/dist/line/common/drag-handle.d.ts +0 -120
  154. package/dist/line/common/drag-handle.js +0 -92
  155. package/dist/line/common/line.d.ts +0 -96
  156. package/dist/line/common/line.js +0 -114
  157. package/dist/line/line-cross.d.ts +0 -47
  158. package/dist/line/line-cross.js +0 -133
  159. package/dist/line/line-dot.d.ts +0 -47
  160. package/dist/line/line-dot.js +0 -101
  161. package/dist/mark-label.d.ts +0 -55
  162. package/dist/mark-label.js +0 -138
  163. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Axis.js +0 -101
  164. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisBottom.js +0 -46
  165. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisLeft.js +0 -47
  166. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/AxisRenderer.js +0 -63
  167. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/axis/Ticks.js +0 -44
  168. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/constants/orientation.js +0 -9
  169. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/createPoint.js +0 -14
  170. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getAxisRangePaddingConfig.js +0 -21
  171. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getLabelTransform.js +0 -16
  172. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickFormatter.js +0 -8
  173. package/dist/node_modules/.bun/@visx_axis@3.12.0_f4eacebf2041cd4f/node_modules/@visx/axis/esm/utils/getTickPosition.js +0 -15
  174. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridColumns.js +0 -79
  175. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/grids/GridRows.js +0 -79
  176. package/dist/node_modules/.bun/@visx_grid@3.12.0_f4eacebf2041cd4f/node_modules/@visx/grid/esm/utils/getScaleBandwidth.js +0 -6
  177. package/dist/node_modules/.bun/@visx_group@3.12.0_f4eacebf2041cd4f/node_modules/@visx/group/esm/Group.js +0 -50
  178. package/dist/node_modules/.bun/@visx_point@3.12.0/node_modules/@visx/point/esm/Point.js +0 -18
  179. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/align.js +0 -6
  180. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/base.js +0 -6
  181. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/clamp.js +0 -6
  182. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/constant.js +0 -6
  183. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/domain.js +0 -6
  184. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/exponent.js +0 -6
  185. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/interpolate.js +0 -10
  186. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/nice.js +0 -37
  187. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/padding.js +0 -6
  188. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/range.js +0 -6
  189. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/reverse.js +0 -9
  190. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/round.js +0 -7
  191. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/scaleOperator.js +0 -58
  192. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/unknown.js +0 -6
  193. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/operators/zero.js +0 -9
  194. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/scales/band.js +0 -9
  195. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/scales/point.js +0 -9
  196. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/coerceNumber.js +0 -10
  197. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/createColorInterpolator.js +0 -29
  198. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/getTicks.js +0 -9
  199. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/isUtcScale.js +0 -7
  200. package/dist/node_modules/.bun/@visx_scale@3.12.0/node_modules/@visx/scale/esm/utils/toString.js +0 -6
  201. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Bar.js +0 -29
  202. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Circle.js +0 -29
  203. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/Line.js +0 -47
  204. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/shapes/LinePath.js +0 -50
  205. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/D3ShapeFactories.js +0 -9
  206. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/esm/util/setNumberOrNumberAccessor.js +0 -6
  207. package/dist/node_modules/.bun/@visx_shape@3.12.0_f4eacebf2041cd4f/node_modules/@visx/shape/lib/shapes/Line.js +0 -53
  208. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/Text.js +0 -57
  209. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/hooks/useText.js +0 -91
  210. package/dist/node_modules/.bun/@visx_text@3.12.0_f4eacebf2041cd4f/node_modules/@visx/text/esm/util/getStringWidth.js +0 -21
  211. package/dist/node_modules/.bun/@visx_vendor@3.12.0/node_modules/@visx/vendor/esm/d3-interpolate.js +0 -8
  212. package/dist/node_modules/.bun/@visx_vendor@3.12.0/node_modules/@visx/vendor/esm/d3-scale.js +0 -8
  213. package/dist/node_modules/.bun/@visx_vendor@3.12.0/node_modules/@visx/vendor/esm/d3-time.js +0 -8
  214. package/dist/node_modules/.bun/balanced-match@0.4.2/node_modules/balanced-match/index.js +0 -32
  215. package/dist/node_modules/.bun/balanced-match@1.0.2/node_modules/balanced-match/index.js +0 -33
  216. package/dist/node_modules/.bun/classnames@2.5.1/node_modules/classnames/index.js +0 -32
  217. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +0 -16
  218. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Hash.js +0 -21
  219. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_ListCache.js +0 -21
  220. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Map.js +0 -10
  221. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_MapCache.js +0 -21
  222. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_Symbol.js +0 -9
  223. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_assocIndexOf.js +0 -14
  224. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseGetTag.js +0 -15
  225. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_baseIsNative.js +0 -16
  226. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_coreJsData.js +0 -9
  227. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_freeGlobal.js +0 -8
  228. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getMapData.js +0 -14
  229. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getNative.js +0 -15
  230. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getRawTag.js +0 -19
  231. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_getValue.js +0 -11
  232. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashClear.js +0 -13
  233. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashDelete.js +0 -12
  234. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashGet.js +0 -18
  235. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashHas.js +0 -14
  236. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_hashSet.js +0 -14
  237. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isKeyable.js +0 -12
  238. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_isMasked.js +0 -16
  239. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheClear.js +0 -11
  240. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheDelete.js +0 -14
  241. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheGet.js +0 -14
  242. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheHas.js +0 -13
  243. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_listCacheSet.js +0 -14
  244. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheClear.js +0 -19
  245. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheDelete.js +0 -14
  246. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheGet.js +0 -13
  247. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheHas.js +0 -13
  248. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_mapCacheSet.js +0 -14
  249. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_nativeCreate.js +0 -9
  250. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_objectToString.js +0 -12
  251. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_root.js +0 -10
  252. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/_toSource.js +0 -20
  253. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/eq.js +0 -11
  254. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isFunction.js +0 -16
  255. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/isObject.js +0 -12
  256. package/dist/node_modules/.bun/lodash@4.18.1/node_modules/lodash/memoize.js +0 -20
  257. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/formula_evaluator.js +0 -37
  258. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/lexer.js +0 -509
  259. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/math_function.js +0 -108
  260. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix.js +0 -31
  261. package/dist/node_modules/.bun/math-expression-evaluator@1.4.0/node_modules/math-expression-evaluator/src/postfix_evaluator.js +0 -45
  262. package/dist/node_modules/.bun/reduce-css-calc@1.3.0/node_modules/reduce-css-calc/index.js +0 -49
  263. package/dist/node_modules/.bun/reduce-function-call@1.0.3/node_modules/reduce-function-call/index.js +0 -34
  264. package/dist/plot/common/plot.d.ts +0 -103
  265. package/dist/plot/common/plot.js +0 -227
  266. package/dist/plot/dot.d.ts +0 -47
  267. package/dist/plot/dot.js +0 -62
  268. package/dist/plot/line.d.ts +0 -47
  269. package/dist/plot/line.js +0 -84
  270. package/dist/tool-menu.d.ts +0 -31
  271. package/dist/utils.d.ts +0 -39
  272. package/dist/utils.js +0 -101
package/lib/chart.js ADDED
@@ -0,0 +1,384 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = exports.Chart = void 0;
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
13
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
14
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
+ var _react = _interopRequireDefault(require("react"));
17
+ var _propTypes = _interopRequireDefault(require("prop-types"));
18
+ var _styles = require("@mui/material/styles");
19
+ var _debug = _interopRequireDefault(require("debug"));
20
+ var _lodashEs = require("lodash-es");
21
+ var _plot = require("@pie-lib/plot");
22
+ var _configUi = require("@pie-lib/config-ui");
23
+ var _grid = _interopRequireDefault(require("./grid"));
24
+ var _axes = _interopRequireDefault(require("./axes"));
25
+ var _utils = require("./utils");
26
+ var _chartTypes = _interopRequireDefault(require("./chart-types"));
27
+ var _actionsButton = _interopRequireDefault(require("./actions-button"));
28
+ var _translator = _interopRequireDefault(require("@pie-lib/translator"));
29
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
30
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
31
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
32
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
33
+ var translator = _translator["default"].translator;
34
+ var log = (0, _debug["default"])('pie-lib:charts:chart');
35
+ var StyledChartContainer = (0, _styles.styled)('div')(function () {
36
+ return {
37
+ width: 'min-content'
38
+ };
39
+ });
40
+ var Chart = exports.Chart = /*#__PURE__*/function (_React$Component) {
41
+ function Chart(props) {
42
+ var _this;
43
+ (0, _classCallCheck2["default"])(this, Chart);
44
+ _this = _callSuper(this, Chart, [props]);
45
+ (0, _defineProperty2["default"])(_this, "state", {
46
+ charts: [_chartTypes["default"].Bar(), _chartTypes["default"].Histogram(), _chartTypes["default"].LineDot(), _chartTypes["default"].LineCross(), _chartTypes["default"].DotPlot(), _chartTypes["default"].LinePlot()],
47
+ autoFocus: false
48
+ });
49
+ (0, _defineProperty2["default"])(_this, "handleAlertDialog", function (open, callback) {
50
+ return _this.setState({
51
+ dialog: {
52
+ open: open
53
+ }
54
+ }, callback);
55
+ });
56
+ (0, _defineProperty2["default"])(_this, "getChart", function () {
57
+ var charts = _this.props.charts || _this.state.charts;
58
+ var chartType = _this.props.chartType;
59
+ var ChartComponent = null;
60
+ var chart = null;
61
+ if (chartType) {
62
+ chart = charts && charts.find(function (chart) {
63
+ return chart.type === chartType;
64
+ });
65
+ ChartComponent = chart && chart.Component;
66
+ } else {
67
+ chart = charts && charts[0];
68
+ ChartComponent = chart && chart.Component;
69
+ chartType = chart && chart.type;
70
+ }
71
+ return {
72
+ type: chartType,
73
+ ChartComponent: ChartComponent
74
+ };
75
+ });
76
+ (0, _defineProperty2["default"])(_this, "changeData", function (data) {
77
+ var onDataChange = _this.props.onDataChange;
78
+ onDataChange(data);
79
+ });
80
+ (0, _defineProperty2["default"])(_this, "changeCategory", function (index, newCategory) {
81
+ var integerIndex = parseInt(index, 10);
82
+ if (integerIndex >= 0) {
83
+ var _this$props = _this.props,
84
+ data = _this$props.data,
85
+ onDataChange = _this$props.onDataChange;
86
+ data[integerIndex] = _objectSpread(_objectSpread({}, data[integerIndex]), newCategory);
87
+ onDataChange(data);
88
+ }
89
+ });
90
+ (0, _defineProperty2["default"])(_this, "addCategory", function () {
91
+ var _this$props2 = _this.props,
92
+ onDataChange = _this$props2.onDataChange,
93
+ data = _this$props2.data,
94
+ categoryDefaultLabel = _this$props2.categoryDefaultLabel,
95
+ defineChart = _this$props2.defineChart,
96
+ categoryDefaults = _this$props2.categoryDefaults,
97
+ language = _this$props2.language;
98
+ if ((data || []).length > 19) {
99
+ _this.setState({
100
+ dialog: {
101
+ open: true,
102
+ title: translator.t('common:warning', {
103
+ lng: language
104
+ }),
105
+ text: translator.t('charting.reachedLimit_other', {
106
+ count: 20,
107
+ lng: language
108
+ }),
109
+ onConfirm: function onConfirm() {
110
+ return _this.handleAlertDialog(false);
111
+ }
112
+ }
113
+ });
114
+ } else {
115
+ _this.setState({
116
+ autoFocus: true
117
+ });
118
+ onDataChange([].concat((0, _toConsumableArray2["default"])(data), [{
119
+ inDefineChart: defineChart,
120
+ label: categoryDefaultLabel || translator.t('charting.newLabel', {
121
+ lng: language
122
+ }),
123
+ value: 0,
124
+ deletable: true,
125
+ editable: categoryDefaults ? categoryDefaults === null || categoryDefaults === void 0 ? void 0 : categoryDefaults.editable : true,
126
+ interactive: categoryDefaults ? categoryDefaults === null || categoryDefaults === void 0 ? void 0 : categoryDefaults.interactive : true
127
+ }]));
128
+ }
129
+ });
130
+ (0, _defineProperty2["default"])(_this, "deleteCategory", function (index) {
131
+ var _this$props3 = _this.props,
132
+ data = _this$props3.data,
133
+ onDataChange = _this$props3.onDataChange;
134
+ if (typeof index !== 'number' || index < 0) {
135
+ return;
136
+ }
137
+ if (data && data.length > 0) {
138
+ onDataChange(data.filter(function (_, i) {
139
+ return i !== index;
140
+ }));
141
+ }
142
+ });
143
+ (0, _defineProperty2["default"])(_this, "getFilteredCategories", function () {
144
+ var _this$props4 = _this.props,
145
+ data = _this$props4.data,
146
+ defineChart = _this$props4.defineChart;
147
+ return data ? data.map(function (d) {
148
+ return _objectSpread(_objectSpread({}, d), {}, {
149
+ deletable: defineChart || d.deletable
150
+ });
151
+ }) : [];
152
+ });
153
+ (0, _defineProperty2["default"])(_this, "resetAutoFocus", function () {
154
+ _this.setState({
155
+ autoFocus: false
156
+ });
157
+ });
158
+ _this.state = {
159
+ dialog: {
160
+ open: false
161
+ },
162
+ actionsAnchorEl: null
163
+ };
164
+ _this.maskUid = _this.generateMaskId();
165
+ return _this;
166
+ }
167
+ (0, _inherits2["default"])(Chart, _React$Component);
168
+ return (0, _createClass2["default"])(Chart, [{
169
+ key: "generateMaskId",
170
+ value: function generateMaskId() {
171
+ return 'chart-' + (Math.random() * 10000).toFixed();
172
+ }
173
+ }, {
174
+ key: "render",
175
+ value: function render() {
176
+ var _this2 = this;
177
+ var _this$props5 = this.props,
178
+ _this$props5$domain = _this$props5.domain,
179
+ domain = _this$props5$domain === void 0 ? {} : _this$props5$domain,
180
+ _this$props5$range = _this$props5.range,
181
+ range = _this$props5$range === void 0 ? {} : _this$props5$range,
182
+ chartingOptions = _this$props5.chartingOptions,
183
+ size = _this$props5.size,
184
+ title = _this$props5.title,
185
+ onChangeTitle = _this$props5.onChangeTitle,
186
+ onChangeLabels = _this$props5.onChangeLabels,
187
+ labelsPlaceholders = _this$props5.labelsPlaceholders,
188
+ titlePlaceholder = _this$props5.titlePlaceholder,
189
+ addCategoryEnabled = _this$props5.addCategoryEnabled,
190
+ changeInteractiveEnabled = _this$props5.changeInteractiveEnabled,
191
+ changeEditableEnabled = _this$props5.changeEditableEnabled,
192
+ showPixelGuides = _this$props5.showPixelGuides,
193
+ error = _this$props5.error,
194
+ _this$props5$mathMlOp = _this$props5.mathMlOptions,
195
+ mathMlOptions = _this$props5$mathMlOp === void 0 ? {} : _this$props5$mathMlOp,
196
+ language = _this$props5.language,
197
+ labelsCharactersLimit = _this$props5.labelsCharactersLimit,
198
+ correctData = _this$props5.correctData;
199
+ var chartType = this.props.chartType;
200
+ var dialog = this.state.dialog;
201
+ var defineChart = this.props.defineChart || false;
202
+ var _ref = size || {},
203
+ width = _ref.width,
204
+ height = _ref.height;
205
+ var labels = {
206
+ left: (range === null || range === void 0 ? void 0 : range.label) || '',
207
+ bottom: (domain === null || domain === void 0 ? void 0 : domain.label) || ''
208
+ };
209
+ var _this$getChart = this.getChart(),
210
+ ChartComponent = _this$getChart.ChartComponent;
211
+ var categories = this.getFilteredCategories();
212
+ var correctValues = (0, _utils.getDomainAndRangeByChartType)(domain, range, chartType);
213
+ var _getGridLinesAndAxisB = (0, _utils.getGridLinesAndAxisByChartType)(correctValues.range, chartType),
214
+ verticalLines = _getGridLinesAndAxisB.verticalLines,
215
+ horizontalLines = _getGridLinesAndAxisB.horizontalLines,
216
+ leftAxis = _getGridLinesAndAxisB.leftAxis;
217
+ var common = {
218
+ graphProps: (0, _plot.createGraphProps)(correctValues.domain, correctValues.range, size, function () {
219
+ return _this2.rootNode;
220
+ })
221
+ };
222
+ log('[render] common:', common);
223
+ var maskSize = {
224
+ x: -10,
225
+ y: -75,
226
+ width: width + 20,
227
+ height: height + 130
228
+ };
229
+ var scale = common.graphProps.scale;
230
+ var xBand = (0, _utils.dataToXBand)(scale.x, categories, width, chartType);
231
+ var bandWidth = xBand.bandwidth();
232
+ // for chartType "line", bandWidth will be 0, so we have to calculate it
233
+ var barWidth = bandWidth || scale.x(correctValues.domain.max) / categories.length;
234
+ var increaseHeight = defineChart ? 160 : 60;
235
+
236
+ // if there are many categories, we have to rotate their names in order to fit
237
+ // and we have to add extra value on top of some items
238
+ var top = (0, _utils.getTopPadding)(barWidth);
239
+ var rootCommon = (0, _lodashEs.cloneDeep)(common);
240
+ rootCommon.graphProps.size.height += top + increaseHeight;
241
+
242
+ // for plot evaluations we need extra space because we render correctness icon below x axis
243
+ var isPlotEvaluation = (chartType === 'dotPlot' || chartType === 'linePlot') && (correctData === null || correctData === void 0 ? void 0 : correctData.length);
244
+ var needsExtraHeight = isPlotEvaluation && labels.bottom;
245
+ if (needsExtraHeight) {
246
+ rootCommon.graphProps.size.height += 25;
247
+ }
248
+ return /*#__PURE__*/_react["default"].createElement(StyledChartContainer, null, /*#__PURE__*/_react["default"].createElement(_plot.Root, (0, _extends2["default"])({
249
+ title: title,
250
+ onChangeTitle: onChangeTitle,
251
+ disabledTitle: !defineChart,
252
+ showTitle: true,
253
+ showLabels: true,
254
+ labels: labels,
255
+ onChangeLabels: onChangeLabels,
256
+ labelsPlaceholders: labelsPlaceholders,
257
+ titlePlaceholder: titlePlaceholder,
258
+ defineChart: defineChart,
259
+ disabledLabels: !defineChart,
260
+ isChart: true,
261
+ showPixelGuides: showPixelGuides,
262
+ rootRef: function rootRef(r) {
263
+ return _this2.rootNode = r;
264
+ },
265
+ mathMlOptions: mathMlOptions,
266
+ labelsCharactersLimit: labelsCharactersLimit
267
+ }, rootCommon), /*#__PURE__*/_react["default"].createElement(_grid["default"], (0, _extends2["default"])({}, common, {
268
+ xBand: xBand,
269
+ rowTickValues: horizontalLines,
270
+ columnTickValues: verticalLines
271
+ })), /*#__PURE__*/_react["default"].createElement(_axes["default"], (0, _extends2["default"])({
272
+ autoFocus: this.state.autoFocus,
273
+ onAutoFocusUsed: this.resetAutoFocus
274
+ }, common, {
275
+ defineChart: defineChart,
276
+ categories: categories,
277
+ xBand: xBand,
278
+ leftAxis: leftAxis,
279
+ onChange: this.changeData,
280
+ onChangeCategory: this.changeCategory,
281
+ chartingOptions: chartingOptions,
282
+ changeInteractiveEnabled: changeInteractiveEnabled,
283
+ changeEditableEnabled: changeEditableEnabled,
284
+ top: top,
285
+ error: error,
286
+ showCorrectness: chartType === 'linePlot' || chartType === 'dotPlot'
287
+ })), addCategoryEnabled ? /*#__PURE__*/_react["default"].createElement("foreignObject", {
288
+ x: width,
289
+ y: height - 16,
290
+ width: width,
291
+ height: height
292
+ }, /*#__PURE__*/_react["default"].createElement("div", {
293
+ xmlns: "http://www.w3.org/1999/xhtml",
294
+ style: {
295
+ display: 'flex',
296
+ justifyContent: 'flex-start'
297
+ }
298
+ }, /*#__PURE__*/_react["default"].createElement(_actionsButton["default"], {
299
+ categories: categories,
300
+ addCategory: this.addCategory,
301
+ deleteCategory: this.deleteCategory,
302
+ language: language
303
+ }))) : null, /*#__PURE__*/_react["default"].createElement("mask", {
304
+ id: "".concat(this.maskUid)
305
+ }, /*#__PURE__*/_react["default"].createElement("rect", (0, _extends2["default"])({}, maskSize, {
306
+ fill: "white"
307
+ }))), /*#__PURE__*/_react["default"].createElement("g", {
308
+ id: "marks",
309
+ mask: "url('#".concat(this.maskUid, "')")
310
+ }, ChartComponent && /*#__PURE__*/_react["default"].createElement(ChartComponent, (0, _extends2["default"])({}, common, {
311
+ data: categories,
312
+ height: rootCommon.graphProps.size.height,
313
+ defineChart: defineChart,
314
+ onChange: this.changeData,
315
+ onChangeCategory: this.changeCategory,
316
+ correctData: correctData
317
+ })))), /*#__PURE__*/_react["default"].createElement(_configUi.AlertDialog, {
318
+ open: dialog.open,
319
+ title: dialog.title,
320
+ text: dialog.text,
321
+ onClose: dialog.onClose,
322
+ onConfirm: dialog.onConfirm
323
+ }));
324
+ }
325
+ }]);
326
+ }(_react["default"].Component);
327
+ (0, _defineProperty2["default"])(Chart, "propTypes", {
328
+ className: _propTypes["default"].string,
329
+ chartType: _propTypes["default"].string.isRequired,
330
+ size: _propTypes["default"].shape({
331
+ width: _propTypes["default"].number,
332
+ height: _propTypes["default"].number
333
+ }),
334
+ domain: _propTypes["default"].shape({
335
+ label: _propTypes["default"].string,
336
+ min: _propTypes["default"].number,
337
+ max: _propTypes["default"].number,
338
+ axisLabel: _propTypes["default"].string
339
+ }),
340
+ data: _propTypes["default"].arrayOf(_propTypes["default"].shape({
341
+ label: _propTypes["default"].string,
342
+ value: _propTypes["default"].number
343
+ })),
344
+ range: _propTypes["default"].shape({
345
+ label: _propTypes["default"].string,
346
+ min: _propTypes["default"].number,
347
+ max: _propTypes["default"].number,
348
+ step: _propTypes["default"].number,
349
+ labelStep: _propTypes["default"].number,
350
+ axisLabel: _propTypes["default"].string
351
+ }),
352
+ charts: _propTypes["default"].array,
353
+ labelsPlaceholders: _propTypes["default"].object,
354
+ title: _propTypes["default"].string,
355
+ titlePlaceholder: _propTypes["default"].string,
356
+ onDataChange: _propTypes["default"].func,
357
+ onChangeLabels: _propTypes["default"].func,
358
+ onChangeTitle: _propTypes["default"].func,
359
+ error: _propTypes["default"].any,
360
+ addCategoryEnabled: _propTypes["default"].bool,
361
+ showPixelGuides: _propTypes["default"].bool,
362
+ categoryDefaultLabel: _propTypes["default"].string,
363
+ categoryDefaults: _propTypes["default"].object,
364
+ defineChart: _propTypes["default"].bool,
365
+ theme: _propTypes["default"].object,
366
+ chartingOptions: _propTypes["default"].object,
367
+ changeInteractiveEnabled: _propTypes["default"].bool,
368
+ changeEditableEnabled: _propTypes["default"].bool,
369
+ language: _propTypes["default"].string,
370
+ mathMlOptions: _propTypes["default"].object,
371
+ labelsCharactersLimit: _propTypes["default"].number,
372
+ correctData: _propTypes["default"].arrayOf(_propTypes["default"].shape({
373
+ label: _propTypes["default"].string,
374
+ value: _propTypes["default"].number
375
+ }))
376
+ });
377
+ (0, _defineProperty2["default"])(Chart, "defaultProps", {
378
+ size: {
379
+ width: 480,
380
+ height: 480
381
+ }
382
+ });
383
+ var _default = exports["default"] = Chart;
384
+ //# sourceMappingURL=chart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chart.js","names":["_react","_interopRequireDefault","require","_propTypes","_styles","_debug","_lodashEs","_plot","_configUi","_grid","_axes","_utils","_chartTypes","_actionsButton","_translator","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","translator","Translator","log","debug","StyledChartContainer","styled","width","Chart","exports","_React$Component","props","_this","_classCallCheck2","charts","chartTypes","Bar","Histogram","LineDot","LineCross","DotPlot","LinePlot","autoFocus","open","callback","setState","dialog","state","chartType","ChartComponent","chart","find","type","Component","data","onDataChange","index","newCategory","integerIndex","parseInt","_this$props","_this$props2","categoryDefaultLabel","defineChart","categoryDefaults","language","title","lng","text","count","onConfirm","handleAlertDialog","concat","_toConsumableArray2","inDefineChart","label","value","deletable","editable","interactive","_this$props3","_","i","_this$props4","map","d","actionsAnchorEl","maskUid","generateMaskId","_inherits2","_createClass2","key","Math","random","toFixed","render","_this2","_this$props5","_this$props5$domain","domain","_this$props5$range","range","chartingOptions","size","onChangeTitle","onChangeLabels","labelsPlaceholders","titlePlaceholder","addCategoryEnabled","changeInteractiveEnabled","changeEditableEnabled","showPixelGuides","error","_this$props5$mathMlOp","mathMlOptions","labelsCharactersLimit","correctData","_ref","height","labels","left","bottom","_this$getChart","getChart","categories","getFilteredCategories","correctValues","getDomainAndRangeByChartType","_getGridLinesAndAxisB","getGridLinesAndAxisByChartType","verticalLines","horizontalLines","leftAxis","common","graphProps","createGraphProps","rootNode","maskSize","x","y","scale","xBand","dataToXBand","bandWidth","bandwidth","barWidth","max","increaseHeight","top","getTopPadding","rootCommon","cloneDeep","isPlotEvaluation","needsExtraHeight","createElement","Root","_extends2","disabledTitle","showTitle","showLabels","disabledLabels","isChart","rootRef","rowTickValues","columnTickValues","onAutoFocusUsed","resetAutoFocus","onChange","changeData","onChangeCategory","changeCategory","showCorrectness","xmlns","style","display","justifyContent","addCategory","deleteCategory","id","fill","mask","AlertDialog","onClose","React","className","PropTypes","string","isRequired","shape","number","min","axisLabel","arrayOf","step","labelStep","array","object","func","any","bool","theme","_default"],"sources":["../src/chart.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport debug from 'debug';\nimport { cloneDeep } from 'lodash-es';\n\nimport { createGraphProps, Root } from '@pie-lib/plot';\nimport { AlertDialog } from '@pie-lib/config-ui';\nimport ChartGrid from './grid';\nimport ChartAxes from './axes';\nimport { dataToXBand, getDomainAndRangeByChartType, getGridLinesAndAxisByChartType, getTopPadding } from './utils';\nimport chartTypes from './chart-types';\nimport ActionsButton from './actions-button';\nimport Translator from '@pie-lib/translator';\n\nconst { translator } = Translator;\n\nconst log = debug('pie-lib:charts:chart');\n\nconst StyledChartContainer = styled('div')(() => ({\n width: 'min-content',\n}));\n\nexport class Chart extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n dialog: {\n open: false,\n },\n actionsAnchorEl: null,\n };\n this.maskUid = this.generateMaskId();\n }\n\n static propTypes = {\n className: PropTypes.string,\n chartType: PropTypes.string.isRequired,\n size: PropTypes.shape({\n width: PropTypes.number,\n height: PropTypes.number,\n }),\n domain: PropTypes.shape({\n label: PropTypes.string,\n min: PropTypes.number,\n max: PropTypes.number,\n axisLabel: PropTypes.string,\n }),\n data: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.number })),\n range: PropTypes.shape({\n label: PropTypes.string,\n min: PropTypes.number,\n max: PropTypes.number,\n step: PropTypes.number,\n labelStep: PropTypes.number,\n axisLabel: PropTypes.string,\n }),\n charts: PropTypes.array,\n labelsPlaceholders: PropTypes.object,\n title: PropTypes.string,\n titlePlaceholder: PropTypes.string,\n onDataChange: PropTypes.func,\n onChangeLabels: PropTypes.func,\n onChangeTitle: PropTypes.func,\n error: PropTypes.any,\n addCategoryEnabled: PropTypes.bool,\n showPixelGuides: PropTypes.bool,\n categoryDefaultLabel: PropTypes.string,\n categoryDefaults: PropTypes.object,\n defineChart: PropTypes.bool,\n theme: PropTypes.object,\n chartingOptions: PropTypes.object,\n changeInteractiveEnabled: PropTypes.bool,\n changeEditableEnabled: PropTypes.bool,\n language: PropTypes.string,\n mathMlOptions: PropTypes.object,\n labelsCharactersLimit: PropTypes.number,\n correctData: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string,\n value: PropTypes.number,\n }),\n ),\n };\n\n static defaultProps = {\n size: {\n width: 480,\n height: 480,\n },\n };\n\n state = {\n charts: [\n chartTypes.Bar(),\n chartTypes.Histogram(),\n chartTypes.LineDot(),\n chartTypes.LineCross(),\n chartTypes.DotPlot(),\n chartTypes.LinePlot(),\n ],\n autoFocus: false,\n };\n\n generateMaskId() {\n return 'chart-' + (Math.random() * 10000).toFixed();\n }\n\n handleAlertDialog = (open, callback) =>\n this.setState(\n {\n dialog: { open },\n },\n callback,\n );\n\n getChart = () => {\n const charts = this.props.charts || this.state.charts;\n let { chartType } = this.props;\n let ChartComponent = null;\n let chart = null;\n\n if (chartType) {\n chart = charts && charts.find((chart) => chart.type === chartType);\n ChartComponent = chart && chart.Component;\n } else {\n chart = charts && charts[0];\n ChartComponent = chart && chart.Component;\n chartType = chart && chart.type;\n }\n\n return {\n type: chartType,\n ChartComponent,\n };\n };\n\n changeData = (data) => {\n const { onDataChange } = this.props;\n\n onDataChange(data);\n };\n\n changeCategory = (index, newCategory) => {\n const integerIndex = parseInt(index, 10);\n\n if (integerIndex >= 0) {\n const { data, onDataChange } = this.props;\n data[integerIndex] = {\n ...data[integerIndex],\n ...newCategory,\n };\n\n onDataChange(data);\n }\n };\n\n addCategory = () => {\n const { onDataChange, data, categoryDefaultLabel, defineChart, categoryDefaults, language } = this.props;\n\n if ((data || []).length > 19) {\n this.setState({\n dialog: {\n open: true,\n title: translator.t('common:warning', { lng: language }),\n text: translator.t('charting.reachedLimit_other', { count: 20, lng: language }),\n onConfirm: () => this.handleAlertDialog(false),\n },\n });\n } else {\n this.setState({ autoFocus: true });\n onDataChange([\n ...data,\n {\n inDefineChart: defineChart,\n label: categoryDefaultLabel || translator.t('charting.newLabel', { lng: language }),\n value: 0,\n deletable: true,\n editable: categoryDefaults ? categoryDefaults?.editable : true,\n interactive: categoryDefaults ? categoryDefaults?.interactive : true,\n },\n ]);\n }\n };\n\n deleteCategory = (index) => {\n const { data, onDataChange } = this.props;\n\n if (typeof index !== 'number' || index < 0) {\n return;\n }\n\n if (data && data.length > 0) {\n onDataChange(data.filter((_, i) => i !== index));\n }\n };\n\n getFilteredCategories = () => {\n const { data, defineChart } = this.props;\n\n return data\n ? data.map((d) => ({\n ...d,\n deletable: defineChart || d.deletable,\n }))\n : [];\n };\n\n resetAutoFocus = () => {\n this.setState({ autoFocus: false });\n };\n\n render() {\n const {\n domain = {},\n range = {},\n chartingOptions,\n size,\n title,\n onChangeTitle,\n onChangeLabels,\n labelsPlaceholders,\n titlePlaceholder,\n addCategoryEnabled,\n changeInteractiveEnabled,\n changeEditableEnabled,\n showPixelGuides,\n error,\n mathMlOptions = {},\n language,\n labelsCharactersLimit,\n correctData,\n } = this.props;\n let { chartType } = this.props;\n\n const { dialog } = this.state;\n const defineChart = this.props.defineChart || false;\n\n const { width, height } = size || {};\n const labels = { left: range?.label || '', bottom: domain?.label || '' };\n\n const { ChartComponent } = this.getChart();\n const categories = this.getFilteredCategories();\n\n const correctValues = getDomainAndRangeByChartType(domain, range, chartType);\n\n const { verticalLines, horizontalLines, leftAxis } = getGridLinesAndAxisByChartType(correctValues.range, chartType);\n const common = {\n graphProps: createGraphProps(correctValues.domain, correctValues.range, size, () => this.rootNode),\n };\n\n log('[render] common:', common);\n\n const maskSize = { x: -10, y: -75, width: width + 20, height: height + 130 };\n const { scale } = common.graphProps;\n const xBand = dataToXBand(scale.x, categories, width, chartType);\n\n const bandWidth = xBand.bandwidth();\n // for chartType \"line\", bandWidth will be 0, so we have to calculate it\n const barWidth = bandWidth || scale.x(correctValues.domain.max) / categories.length;\n const increaseHeight = defineChart ? 160 : 60;\n\n // if there are many categories, we have to rotate their names in order to fit\n // and we have to add extra value on top of some items\n const top = getTopPadding(barWidth);\n const rootCommon = cloneDeep(common);\n rootCommon.graphProps.size.height += top + increaseHeight;\n\n // for plot evaluations we need extra space because we render correctness icon below x axis\n const isPlotEvaluation = (chartType === 'dotPlot' || chartType === 'linePlot') && correctData?.length;\n const needsExtraHeight = isPlotEvaluation && labels.bottom;\n\n if (needsExtraHeight) {\n rootCommon.graphProps.size.height += 25;\n }\n\n return (\n <StyledChartContainer>\n <Root\n title={title}\n onChangeTitle={onChangeTitle}\n disabledTitle={!defineChart}\n showTitle={true}\n showLabels={true}\n labels={labels}\n onChangeLabels={onChangeLabels}\n labelsPlaceholders={labelsPlaceholders}\n titlePlaceholder={titlePlaceholder}\n defineChart={defineChart}\n disabledLabels={!defineChart}\n isChart={true}\n showPixelGuides={showPixelGuides}\n rootRef={(r) => (this.rootNode = r)}\n mathMlOptions={mathMlOptions}\n labelsCharactersLimit={labelsCharactersLimit}\n {...rootCommon}\n >\n <ChartGrid {...common} xBand={xBand} rowTickValues={horizontalLines} columnTickValues={verticalLines} />\n <ChartAxes\n autoFocus={this.state.autoFocus}\n onAutoFocusUsed={this.resetAutoFocus}\n {...common}\n defineChart={defineChart}\n categories={categories}\n xBand={xBand}\n leftAxis={leftAxis}\n onChange={this.changeData}\n onChangeCategory={this.changeCategory}\n chartingOptions={chartingOptions}\n changeInteractiveEnabled={changeInteractiveEnabled}\n changeEditableEnabled={changeEditableEnabled}\n top={top}\n error={error}\n showCorrectness={chartType === 'linePlot' || chartType === 'dotPlot'}\n />\n {addCategoryEnabled ? (\n <foreignObject x={width} y={height - 16} width={width} height={height}>\n <div xmlns=\"http://www.w3.org/1999/xhtml\" style={{ display: 'flex', justifyContent: 'flex-start' }}>\n <ActionsButton\n categories={categories}\n addCategory={this.addCategory}\n deleteCategory={this.deleteCategory}\n language={language}\n />\n </div>\n </foreignObject>\n ) : null}\n <mask id={`${this.maskUid}`}>\n <rect {...maskSize} fill=\"white\" />\n </mask>\n <g id=\"marks\" mask={`url('#${this.maskUid}')`}>\n {ChartComponent && (\n <ChartComponent\n {...common}\n data={categories}\n height={rootCommon.graphProps.size.height}\n defineChart={defineChart}\n onChange={this.changeData}\n onChangeCategory={this.changeCategory}\n correctData={correctData}\n />\n )}\n </g>\n </Root>\n <AlertDialog\n open={dialog.open}\n title={dialog.title}\n text={dialog.text}\n onClose={dialog.onClose}\n onConfirm={dialog.onConfirm}\n />\n </StyledChartContainer>\n );\n }\n}\n\nexport default Chart;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.TickCorrectnessIndicator = exports.SmallCorrectPointIndicator = exports.CorrectnessIndicator = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _propTypes = _interopRequireDefault(require("prop-types"));
10
+ var _styles = require("@mui/material/styles");
11
+ var _Check = _interopRequireDefault(require("@mui/icons-material/Check"));
12
+ var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
13
+ var _renderUi = require("@pie-lib/render-ui");
14
+ var StyledCorrectIcon = (0, _styles.styled)(_Check["default"])(function (_ref) {
15
+ var theme = _ref.theme;
16
+ return {
17
+ borderRadius: theme.spacing(2),
18
+ color: _renderUi.color.defaults.WHITE,
19
+ fontSize: '16px',
20
+ width: '16px',
21
+ height: '16px',
22
+ padding: '2px',
23
+ border: "1px solid ".concat(_renderUi.color.defaults.WHITE),
24
+ stroke: 'initial',
25
+ boxSizing: 'unset',
26
+ // to override the default border-box in IBX
27
+ backgroundColor: _renderUi.color.correct(),
28
+ display: 'block',
29
+ '&.small': {
30
+ fontSize: '10px',
31
+ width: '10px',
32
+ height: '10px'
33
+ }
34
+ };
35
+ });
36
+ var StyledIncorrectIcon = (0, _styles.styled)(_Close["default"])(function (_ref2) {
37
+ var theme = _ref2.theme;
38
+ return {
39
+ borderRadius: theme.spacing(2),
40
+ color: _renderUi.color.defaults.WHITE,
41
+ fontSize: '16px',
42
+ width: '16px',
43
+ height: '16px',
44
+ padding: '2px',
45
+ border: "1px solid ".concat(_renderUi.color.defaults.WHITE),
46
+ stroke: 'initial',
47
+ boxSizing: 'unset',
48
+ // to override the default border-box in IBX
49
+ backgroundColor: _renderUi.color.incorrectWithIcon(),
50
+ display: 'block',
51
+ '&.small': {
52
+ fontSize: '10px',
53
+ width: '10px',
54
+ height: '10px'
55
+ }
56
+ };
57
+ });
58
+ var CorrectnessIndicator = exports.CorrectnessIndicator = function CorrectnessIndicator(_ref3) {
59
+ var scale = _ref3.scale,
60
+ x = _ref3.x,
61
+ y = _ref3.y,
62
+ correctness = _ref3.correctness,
63
+ interactive = _ref3.interactive;
64
+ if (!correctness || !interactive) return null;
65
+ var cx = scale ? scale.x(x) : x;
66
+ var cy = scale ? scale.y(y) : y;
67
+ var isCorrect = correctness.value === 'correct';
68
+
69
+ // the icon is 16px + 2px padding + 1px border, so total size is 22px
70
+ return /*#__PURE__*/_react["default"].createElement("foreignObject", {
71
+ x: cx - 11,
72
+ y: cy - 11,
73
+ width: 22,
74
+ height: 22
75
+ }, isCorrect ? /*#__PURE__*/_react["default"].createElement(StyledCorrectIcon, {
76
+ title: correctness.label
77
+ }) : /*#__PURE__*/_react["default"].createElement(StyledIncorrectIcon, {
78
+ title: correctness.label
79
+ }));
80
+ };
81
+ var SmallCorrectPointIndicator = exports.SmallCorrectPointIndicator = function SmallCorrectPointIndicator(_ref4) {
82
+ var scale = _ref4.scale,
83
+ x = _ref4.x,
84
+ correctness = _ref4.correctness,
85
+ correctData = _ref4.correctData,
86
+ label = _ref4.label;
87
+ if (correctness && correctness.value === 'incorrect') {
88
+ var _correctData$find;
89
+ var correctVal = parseFloat((_correctData$find = correctData.find(function (d) {
90
+ return d.label === label;
91
+ })) === null || _correctData$find === void 0 ? void 0 : _correctData$find.value);
92
+ if (isNaN(correctVal)) return null;
93
+ var correctPxY = scale.y(correctVal);
94
+ var yToRender = correctPxY - 7.5;
95
+ var xToRender = scale.x(x) - 7.5;
96
+
97
+ // small circle has 10px font + 2px padding + 1px border, so total size is 15px
98
+ return /*#__PURE__*/_react["default"].createElement("foreignObject", {
99
+ x: xToRender,
100
+ y: yToRender,
101
+ width: 15,
102
+ height: 15
103
+ }, /*#__PURE__*/_react["default"].createElement(StyledCorrectIcon, {
104
+ className: "small",
105
+ title: correctness.label
106
+ }));
107
+ }
108
+ return null;
109
+ };
110
+ var TickCorrectnessIndicator = exports.TickCorrectnessIndicator = function TickCorrectnessIndicator(_ref5) {
111
+ var correctness = _ref5.correctness,
112
+ interactive = _ref5.interactive;
113
+ if (!correctness || !interactive) return null;
114
+ return correctness.value === 'correct' ? /*#__PURE__*/_react["default"].createElement(StyledCorrectIcon, {
115
+ title: correctness.label
116
+ }) : /*#__PURE__*/_react["default"].createElement(StyledIncorrectIcon, {
117
+ title: correctness.label
118
+ });
119
+ };
120
+ CorrectnessIndicator.propTypes = {
121
+ scale: _propTypes["default"].shape({
122
+ x: _propTypes["default"].func,
123
+ y: _propTypes["default"].func
124
+ }),
125
+ x: _propTypes["default"].number.isRequired,
126
+ y: _propTypes["default"].number.isRequired,
127
+ correctness: _propTypes["default"].shape({
128
+ value: _propTypes["default"].string,
129
+ label: _propTypes["default"].string
130
+ }),
131
+ interactive: _propTypes["default"].bool
132
+ };
133
+ SmallCorrectPointIndicator.propTypes = {
134
+ scale: _propTypes["default"].shape({
135
+ x: _propTypes["default"].func,
136
+ y: _propTypes["default"].func
137
+ }).isRequired,
138
+ x: _propTypes["default"].number.isRequired,
139
+ correctness: _propTypes["default"].shape({
140
+ value: _propTypes["default"].string,
141
+ label: _propTypes["default"].string
142
+ }),
143
+ correctData: _propTypes["default"].arrayOf(_propTypes["default"].shape({
144
+ label: _propTypes["default"].string,
145
+ value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
146
+ })),
147
+ label: _propTypes["default"].string
148
+ };
149
+ TickCorrectnessIndicator.propTypes = {
150
+ correctness: _propTypes["default"].shape({
151
+ value: _propTypes["default"].string,
152
+ label: _propTypes["default"].string
153
+ }),
154
+ interactive: _propTypes["default"].bool
155
+ };
156
+ //# sourceMappingURL=correctness-indicators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"correctness-indicators.js","names":["_react","_interopRequireDefault","require","_propTypes","_styles","_Check","_Close","_renderUi","StyledCorrectIcon","styled","Check","_ref","theme","borderRadius","spacing","color","enumColor","defaults","WHITE","fontSize","width","height","padding","border","concat","stroke","boxSizing","backgroundColor","correct","display","StyledIncorrectIcon","Close","_ref2","incorrectWithIcon","CorrectnessIndicator","exports","_ref3","scale","x","y","correctness","interactive","cx","cy","isCorrect","value","createElement","title","label","SmallCorrectPointIndicator","_ref4","correctData","_correctData$find","correctVal","parseFloat","find","d","isNaN","correctPxY","yToRender","xToRender","className","TickCorrectnessIndicator","_ref5","propTypes","PropTypes","shape","func","number","isRequired","string","bool","arrayOf","oneOfType"],"sources":["../../src/common/correctness-indicators.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport Check from '@mui/icons-material/Check';\nimport Close from '@mui/icons-material/Close';\nimport { color as enumColor } from '@pie-lib/render-ui';\n\nconst StyledCorrectIcon = styled(Check)(({ theme }) => ({\n borderRadius: theme.spacing(2),\n color: enumColor.defaults.WHITE,\n fontSize: '16px',\n width: '16px',\n height: '16px',\n padding: '2px',\n border: `1px solid ${enumColor.defaults.WHITE}`,\n stroke: 'initial',\n boxSizing: 'unset', // to override the default border-box in IBX\n backgroundColor: enumColor.correct(),\n display: 'block',\n '&.small': {\n fontSize: '10px',\n width: '10px',\n height: '10px',\n },\n}));\n\nconst StyledIncorrectIcon = styled(Close)(({ theme }) => ({\n borderRadius: theme.spacing(2),\n color: enumColor.defaults.WHITE,\n fontSize: '16px',\n width: '16px',\n height: '16px',\n padding: '2px',\n border: `1px solid ${enumColor.defaults.WHITE}`,\n stroke: 'initial',\n boxSizing: 'unset', // to override the default border-box in IBX\n backgroundColor: enumColor.incorrectWithIcon(),\n display: 'block',\n '&.small': {\n fontSize: '10px',\n width: '10px',\n height: '10px',\n },\n}));\n\nexport const CorrectnessIndicator = ({ scale, x, y, correctness, interactive }) => {\n if (!correctness || !interactive) return null;\n const cx = scale ? scale.x(x) : x;\n const cy = scale ? scale.y(y) : y;\n const isCorrect = correctness.value === 'correct';\n\n // the icon is 16px + 2px padding + 1px border, so total size is 22px\n return (\n <foreignObject x={cx - 11} y={cy - 11} width={22} height={22}>\n {isCorrect ? <StyledCorrectIcon title={correctness.label} /> : <StyledIncorrectIcon title={correctness.label} />}\n </foreignObject>\n );\n};\n\nexport const SmallCorrectPointIndicator = ({ scale, x, correctness, correctData, label }) => {\n if (correctness && correctness.value === 'incorrect') {\n const correctVal = parseFloat(correctData.find((d) => d.label === label)?.value);\n if (isNaN(correctVal)) return null;\n const correctPxY = scale.y(correctVal);\n const yToRender = correctPxY - 7.5;\n const xToRender = scale.x(x) - 7.5;\n\n // small circle has 10px font + 2px padding + 1px border, so total size is 15px\n return (\n <foreignObject x={xToRender} y={yToRender} width={15} height={15}>\n <StyledCorrectIcon className=\"small\" title={correctness.label} />\n </foreignObject>\n );\n }\n\n return null;\n};\n\nexport const TickCorrectnessIndicator = ({ correctness, interactive }) => {\n if (!correctness || !interactive) return null;\n\n return correctness.value === 'correct' ? (\n <StyledCorrectIcon title={correctness.label} />\n ) : (\n <StyledIncorrectIcon title={correctness.label} />\n );\n};\n\nCorrectnessIndicator.propTypes = {\n scale: PropTypes.shape({\n x: PropTypes.func,\n y: PropTypes.func,\n }),\n x: PropTypes.number.isRequired,\n y: PropTypes.number.isRequired,\n correctness: PropTypes.shape({\n value: PropTypes.string,\n label: PropTypes.string,\n }),\n interactive: PropTypes.bool,\n};\n\nSmallCorrectPointIndicator.propTypes = {\n scale: PropTypes.shape({\n x: PropTypes.func,\n y: PropTypes.func,\n }).isRequired,\n x: PropTypes.number.isRequired,\n correctness: PropTypes.shape({\n value: PropTypes.string,\n label: PropTypes.string,\n }),\n correctData: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string,\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n }),\n ),\n label: PropTypes.string,\n};\n\nTickCorrectnessIndicator.propTypes = {\n correctness: PropTypes.shape({\n value: PropTypes.string,\n label: PropTypes.string,\n }),\n interactive: PropTypes.bool,\n};\n"],"mappings":"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","ignoreList":[]}