@elliemae/ds-dataviz 3.14.4 → 3.14.7

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 (165) hide show
  1. package/dist/cjs/graphs/Chart/ChartContext.js.map +2 -2
  2. package/dist/cjs/graphs/Chart/config/useChart.js +5 -2
  3. package/dist/cjs/graphs/Chart/config/useChart.js.map +2 -2
  4. package/dist/cjs/graphs/Chart/config/useGetters.js +4 -4
  5. package/dist/cjs/graphs/Chart/config/useGetters.js.map +2 -2
  6. package/dist/cjs/graphs/Chart/config/useInternalMargins.js +2 -2
  7. package/dist/cjs/graphs/Chart/config/useInternalMargins.js.map +2 -2
  8. package/dist/cjs/graphs/Chart/config/useKeyboardNavigation.js +4 -4
  9. package/dist/cjs/graphs/Chart/config/useKeyboardNavigation.js.map +2 -2
  10. package/dist/cjs/graphs/Chart/config/useScales.js +54 -38
  11. package/dist/cjs/graphs/Chart/config/useScales.js.map +2 -2
  12. package/dist/cjs/graphs/Chart/helpers/index.js +9 -7
  13. package/dist/cjs/graphs/Chart/helpers/index.js.map +2 -2
  14. package/dist/cjs/graphs/Chart/helpers/useUniqueData.js +5 -5
  15. package/dist/cjs/graphs/Chart/helpers/useUniqueData.js.map +2 -2
  16. package/dist/cjs/graphs/Chart/helpers/useVirtualizedSeries.js +4 -4
  17. package/dist/cjs/graphs/Chart/helpers/useVirtualizedSeries.js.map +2 -2
  18. package/dist/cjs/graphs/Chart/parts/Axis/Axis.js +47 -0
  19. package/dist/cjs/graphs/Chart/parts/Axis/Axis.js.map +7 -0
  20. package/dist/cjs/graphs/Chart/parts/Axis/AxisBottom.js +88 -71
  21. package/dist/cjs/graphs/Chart/parts/Axis/AxisBottom.js.map +2 -2
  22. package/dist/cjs/graphs/Chart/parts/Axis/AxisLeft.js +88 -58
  23. package/dist/cjs/graphs/Chart/parts/Axis/AxisLeft.js.map +3 -3
  24. package/dist/cjs/graphs/Chart/parts/Axis/AxisRight.js +91 -56
  25. package/dist/cjs/graphs/Chart/parts/Axis/AxisRight.js.map +3 -3
  26. package/dist/cjs/graphs/Chart/parts/{Labels/BottomLabel.js → Axis/GridLine.js} +7 -26
  27. package/dist/cjs/graphs/Chart/parts/Axis/GridLine.js.map +7 -0
  28. package/dist/cjs/graphs/Chart/parts/{Labels/LeftLabel.js → Axis/Tick.js} +12 -25
  29. package/dist/cjs/graphs/Chart/parts/Axis/Tick.js.map +7 -0
  30. package/dist/cjs/graphs/Chart/parts/ChartContainer.js +2 -2
  31. package/dist/cjs/graphs/Chart/parts/ChartContainer.js.map +2 -2
  32. package/dist/cjs/graphs/Chart/parts/Labels/Label.js +3 -18
  33. package/dist/cjs/graphs/Chart/parts/Labels/Label.js.map +3 -3
  34. package/dist/cjs/graphs/Chart/parts/Labels/index.js +102 -0
  35. package/dist/cjs/graphs/Chart/parts/Labels/index.js.map +7 -0
  36. package/dist/cjs/graphs/Chart/parts/Scrapper/Scrapper.js +5 -5
  37. package/dist/cjs/graphs/Chart/parts/Scrapper/Scrapper.js.map +2 -2
  38. package/dist/cjs/graphs/Chart/parts/Scrapper/ScrapperLine.js +1 -1
  39. package/dist/cjs/graphs/Chart/parts/Scrapper/ScrapperLine.js.map +2 -2
  40. package/dist/cjs/graphs/Chart/parts/Scrapper/VerticalScrapperLine.js +3 -3
  41. package/dist/cjs/graphs/Chart/parts/Scrapper/VerticalScrapperLine.js.map +2 -2
  42. package/dist/cjs/graphs/Chart/parts/Scroller/Controllers.js +1 -1
  43. package/dist/cjs/graphs/Chart/parts/Scroller/Controllers.js.map +2 -2
  44. package/dist/cjs/graphs/Chart/parts/Scroller/ScrollableContainerX.js +5 -5
  45. package/dist/cjs/graphs/Chart/parts/Scroller/ScrollableContainerX.js.map +2 -2
  46. package/dist/cjs/graphs/Chart/parts/TrendHighlight.js +1 -1
  47. package/dist/cjs/graphs/Chart/parts/TrendHighlight.js.map +1 -1
  48. package/dist/cjs/graphs/Chart/react-desc-prop-types.js.map +2 -2
  49. package/dist/cjs/graphs/Chart/scales/index.js +186 -0
  50. package/dist/cjs/graphs/Chart/scales/index.js.map +7 -0
  51. package/dist/cjs/graphs/Chart/series/Area.js +5 -5
  52. package/dist/cjs/graphs/Chart/series/Area.js.map +2 -2
  53. package/dist/cjs/graphs/Chart/series/Bars.js +7 -4
  54. package/dist/cjs/graphs/Chart/series/Bars.js.map +2 -2
  55. package/dist/cjs/graphs/Chart/series/HorizontalBars.js +4 -4
  56. package/dist/cjs/graphs/Chart/series/HorizontalBars.js.map +2 -2
  57. package/dist/cjs/graphs/Chart/series/HorizontalStackedBars.js +3 -3
  58. package/dist/cjs/graphs/Chart/series/HorizontalStackedBars.js.map +2 -2
  59. package/dist/cjs/graphs/Chart/series/Line.js +2 -2
  60. package/dist/cjs/graphs/Chart/series/Line.js.map +2 -2
  61. package/dist/cjs/graphs/Chart/series/Points.js +2 -2
  62. package/dist/cjs/graphs/Chart/series/Points.js.map +2 -2
  63. package/dist/cjs/graphs/Chart/series/Rect.js +1 -1
  64. package/dist/cjs/graphs/Chart/series/Rect.js.map +2 -2
  65. package/dist/cjs/graphs/Chart/series/StackedBar.js +3 -3
  66. package/dist/cjs/graphs/Chart/series/StackedBar.js.map +2 -2
  67. package/dist/cjs/graphs/Chart/styles.js +4 -26
  68. package/dist/cjs/graphs/Chart/styles.js.map +2 -2
  69. package/dist/esm/graphs/Chart/ChartContext.js.map +2 -2
  70. package/dist/esm/graphs/Chart/config/useChart.js +5 -2
  71. package/dist/esm/graphs/Chart/config/useChart.js.map +2 -2
  72. package/dist/esm/graphs/Chart/config/useGetters.js +4 -4
  73. package/dist/esm/graphs/Chart/config/useGetters.js.map +2 -2
  74. package/dist/esm/graphs/Chart/config/useInternalMargins.js +2 -2
  75. package/dist/esm/graphs/Chart/config/useInternalMargins.js.map +2 -2
  76. package/dist/esm/graphs/Chart/config/useKeyboardNavigation.js +4 -4
  77. package/dist/esm/graphs/Chart/config/useKeyboardNavigation.js.map +2 -2
  78. package/dist/esm/graphs/Chart/config/useScales.js +54 -38
  79. package/dist/esm/graphs/Chart/config/useScales.js.map +2 -2
  80. package/dist/esm/graphs/Chart/helpers/index.js +9 -7
  81. package/dist/esm/graphs/Chart/helpers/index.js.map +2 -2
  82. package/dist/esm/graphs/Chart/helpers/useUniqueData.js +5 -5
  83. package/dist/esm/graphs/Chart/helpers/useUniqueData.js.map +2 -2
  84. package/dist/esm/graphs/Chart/helpers/useVirtualizedSeries.js +4 -4
  85. package/dist/esm/graphs/Chart/helpers/useVirtualizedSeries.js.map +2 -2
  86. package/dist/esm/graphs/Chart/parts/Axis/Axis.js +21 -0
  87. package/dist/esm/graphs/Chart/parts/Axis/Axis.js.map +7 -0
  88. package/dist/esm/graphs/Chart/parts/Axis/AxisBottom.js +90 -73
  89. package/dist/esm/graphs/Chart/parts/Axis/AxisBottom.js.map +2 -2
  90. package/dist/esm/graphs/Chart/parts/Axis/AxisLeft.js +89 -59
  91. package/dist/esm/graphs/Chart/parts/Axis/AxisLeft.js.map +3 -3
  92. package/dist/esm/graphs/Chart/parts/Axis/AxisRight.js +92 -57
  93. package/dist/esm/graphs/Chart/parts/Axis/AxisRight.js.map +3 -3
  94. package/dist/esm/graphs/Chart/parts/Axis/GridLine.js +8 -0
  95. package/dist/esm/graphs/Chart/parts/Axis/GridLine.js.map +7 -0
  96. package/dist/esm/graphs/Chart/parts/Axis/Tick.js +13 -0
  97. package/dist/esm/graphs/Chart/parts/Axis/Tick.js.map +7 -0
  98. package/dist/esm/graphs/Chart/parts/ChartContainer.js +2 -2
  99. package/dist/esm/graphs/Chart/parts/ChartContainer.js.map +2 -2
  100. package/dist/esm/graphs/Chart/parts/Labels/Label.js +4 -19
  101. package/dist/esm/graphs/Chart/parts/Labels/Label.js.map +3 -3
  102. package/dist/esm/graphs/Chart/parts/Labels/index.js +76 -0
  103. package/dist/esm/graphs/Chart/parts/Labels/index.js.map +7 -0
  104. package/dist/esm/graphs/Chart/parts/Scrapper/Scrapper.js +5 -5
  105. package/dist/esm/graphs/Chart/parts/Scrapper/Scrapper.js.map +2 -2
  106. package/dist/esm/graphs/Chart/parts/Scrapper/ScrapperLine.js +1 -1
  107. package/dist/esm/graphs/Chart/parts/Scrapper/ScrapperLine.js.map +2 -2
  108. package/dist/esm/graphs/Chart/parts/Scrapper/VerticalScrapperLine.js +3 -3
  109. package/dist/esm/graphs/Chart/parts/Scrapper/VerticalScrapperLine.js.map +2 -2
  110. package/dist/esm/graphs/Chart/parts/Scroller/Controllers.js +1 -1
  111. package/dist/esm/graphs/Chart/parts/Scroller/Controllers.js.map +2 -2
  112. package/dist/esm/graphs/Chart/parts/Scroller/ScrollableContainerX.js +5 -5
  113. package/dist/esm/graphs/Chart/parts/Scroller/ScrollableContainerX.js.map +2 -2
  114. package/dist/esm/graphs/Chart/parts/TrendHighlight.js +1 -1
  115. package/dist/esm/graphs/Chart/parts/TrendHighlight.js.map +1 -1
  116. package/dist/esm/graphs/Chart/react-desc-prop-types.js.map +2 -2
  117. package/dist/esm/graphs/Chart/scales/index.js +160 -0
  118. package/dist/esm/graphs/Chart/scales/index.js.map +7 -0
  119. package/dist/esm/graphs/Chart/series/Area.js +5 -5
  120. package/dist/esm/graphs/Chart/series/Area.js.map +2 -2
  121. package/dist/esm/graphs/Chart/series/Bars.js +7 -4
  122. package/dist/esm/graphs/Chart/series/Bars.js.map +2 -2
  123. package/dist/esm/graphs/Chart/series/HorizontalBars.js +4 -4
  124. package/dist/esm/graphs/Chart/series/HorizontalBars.js.map +2 -2
  125. package/dist/esm/graphs/Chart/series/HorizontalStackedBars.js +3 -3
  126. package/dist/esm/graphs/Chart/series/HorizontalStackedBars.js.map +2 -2
  127. package/dist/esm/graphs/Chart/series/Line.js +2 -2
  128. package/dist/esm/graphs/Chart/series/Line.js.map +2 -2
  129. package/dist/esm/graphs/Chart/series/Points.js +2 -2
  130. package/dist/esm/graphs/Chart/series/Points.js.map +2 -2
  131. package/dist/esm/graphs/Chart/series/Rect.js +1 -1
  132. package/dist/esm/graphs/Chart/series/Rect.js.map +2 -2
  133. package/dist/esm/graphs/Chart/series/StackedBar.js +3 -3
  134. package/dist/esm/graphs/Chart/series/StackedBar.js.map +2 -2
  135. package/dist/esm/graphs/Chart/styles.js +4 -26
  136. package/dist/esm/graphs/Chart/styles.js.map +2 -2
  137. package/dist/types/graphs/Chart/ChartContext.d.ts +12 -4
  138. package/dist/types/graphs/Chart/config/useChart.d.ts +6 -6
  139. package/dist/types/graphs/Chart/config/useGetters.d.ts +2 -2
  140. package/dist/types/graphs/Chart/config/useScales.d.ts +6 -5
  141. package/dist/types/graphs/Chart/helpers/index.d.ts +1 -1
  142. package/dist/types/graphs/Chart/parts/Axis/Axis.d.ts +26 -0
  143. package/dist/types/graphs/Chart/parts/Axis/AxisLeft.d.ts +2 -1
  144. package/dist/types/graphs/Chart/parts/Axis/AxisRight.d.ts +2 -1
  145. package/dist/types/graphs/Chart/parts/Axis/GridLine.d.ts +9 -0
  146. package/dist/types/graphs/Chart/parts/Axis/Tick.d.ts +15 -0
  147. package/dist/types/graphs/Chart/parts/Labels/Label.d.ts +10 -1
  148. package/dist/types/graphs/Chart/parts/Labels/index.d.ts +1 -0
  149. package/dist/types/graphs/Chart/react-desc-prop-types.d.ts +3 -2
  150. package/dist/types/graphs/Chart/scales/index.d.ts +53 -0
  151. package/dist/types/graphs/Chart/styles.d.ts +1 -2
  152. package/package.json +4 -4
  153. package/dist/cjs/graphs/Chart/parts/Labels/BottomLabel.js.map +0 -7
  154. package/dist/cjs/graphs/Chart/parts/Labels/LeftLabel.js.map +0 -7
  155. package/dist/cjs/graphs/Chart/parts/Labels/RightLabel.js +0 -56
  156. package/dist/cjs/graphs/Chart/parts/Labels/RightLabel.js.map +0 -7
  157. package/dist/esm/graphs/Chart/parts/Labels/BottomLabel.js +0 -27
  158. package/dist/esm/graphs/Chart/parts/Labels/BottomLabel.js.map +0 -7
  159. package/dist/esm/graphs/Chart/parts/Labels/LeftLabel.js +0 -26
  160. package/dist/esm/graphs/Chart/parts/Labels/LeftLabel.js.map +0 -7
  161. package/dist/esm/graphs/Chart/parts/Labels/RightLabel.js +0 -30
  162. package/dist/esm/graphs/Chart/parts/Labels/RightLabel.js.map +0 -7
  163. package/dist/types/graphs/Chart/parts/Labels/BottomLabel.d.ts +0 -1
  164. package/dist/types/graphs/Chart/parts/Labels/LeftLabel.d.ts +0 -1
  165. package/dist/types/graphs/Chart/parts/Labels/RightLabel.d.ts +0 -1
@@ -29,70 +29,100 @@ __export(AxisLeft_exports, {
29
29
  module.exports = __toCommonJS(AxisLeft_exports);
30
30
  var React = __toESM(require("react"));
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
- var import_react = require("react");
33
- var import_d3 = require("d3");
34
- var import_styles = require("../../styles");
32
+ var import_react = __toESM(require("react"));
35
33
  var import_ChartContext = require("../../ChartContext");
36
- var import_helpers = require("../../helpers");
37
- const AxisLeft = () => {
34
+ var import_Axis = require("./Axis");
35
+ var import_Tick = require("./Tick");
36
+ var import_GridLine = require("./GridLine");
37
+ var import_colorPallet = require("../../helpers/colorPallet");
38
+ const AxisLeft = import_react.default.memo(() => {
38
39
  const {
39
40
  props: { yAxis },
40
41
  innerHeight,
41
- innerWidth,
42
- yScale,
43
- chartId,
44
42
  height,
43
+ yScale,
44
+ innerWidth,
45
45
  setAxisLeftRef
46
46
  } = (0, import_react.useContext)(import_ChartContext.ChartContext);
47
- const ref = (0, import_react.useRef)(null);
48
- const gridRef = (0, import_react.useRef)(null);
49
- const { tickValues, color: tickColor, tickFormat, overwriteTicks, tickRotation, tickCount } = yAxis.tick || {};
50
- const ticks = yScale.ticks?.(tickCount ?? height / 80);
51
- const { type, showGrid, color: axisColor } = yAxis;
52
- (0, import_react.useEffect)(() => {
53
- const axis = (0, import_d3.axisLeft)(yScale).tickSizeOuter(0);
54
- const grid = (0, import_d3.axisLeft)(yScale).tickFormat((_) => "").tickSize(showGrid ? -innerWidth : 0).tickSizeOuter(0);
55
- if (tickValues && ticks) {
56
- const finalTicks = overwriteTicks ? tickValues : [...ticks, ...tickValues];
57
- axis.tickValues(finalTicks);
58
- } else {
59
- axis.tickValues(ticks);
60
- grid.tickValues(ticks);
61
- }
62
- if (tickFormat) {
63
- if (typeof tickFormat === "string") {
64
- const formatGenerator = (0, import_helpers.getFormatGenerator)(type ?? "linear");
65
- axis.tickFormat((d) => formatGenerator(tickFormat)(d));
66
- }
67
- if (typeof tickFormat === "function") {
68
- axis.tickFormat(tickFormat);
47
+ const { tickRotation } = yAxis.tick || {};
48
+ const { showGrid } = yAxis;
49
+ const textProps = (0, import_react.useMemo)(() => {
50
+ const commomProps = { fill: import_colorPallet.COLOR_PALLET[yAxis?.tick?.color] || yAxis?.tick?.color };
51
+ if (!tickRotation)
52
+ return { ...commomProps, x: -10, dy: "0.32em" };
53
+ return {
54
+ ...commomProps,
55
+ dy: ".30em",
56
+ dx: "-.10em",
57
+ x: Math.trunc(-(11.5 - 2.5 * (tickRotation / 15) * (tickRotation > 0 ? 1 : -1))),
58
+ transform: `rotate(${tickRotation})`
59
+ };
60
+ }, [tickRotation, yAxis?.tick?.color]);
61
+ const style = (0, import_react.useMemo)(
62
+ () => ({
63
+ textAnchor: "end"
64
+ }),
65
+ []
66
+ );
67
+ const GridRenderer = (0, import_react.useCallback)(
68
+ (props) => {
69
+ if (!showGrid)
70
+ return null;
71
+ const { position, ...rest } = props;
72
+ const gridLineCoords = {
73
+ x1: 0,
74
+ x2: innerWidth,
75
+ y1: position,
76
+ y2: position
77
+ };
78
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_GridLine.GridLine, { ...gridLineCoords, ...rest });
79
+ },
80
+ [showGrid, innerWidth]
81
+ );
82
+ const TickRenderer = (0, import_react.useCallback)(
83
+ (props) => {
84
+ const { position, tickValue, ...rest } = props;
85
+ const tickLineCoords = {
86
+ x2: -5,
87
+ stroke: import_colorPallet.COLOR_PALLET[yAxis?.tick?.color] || yAxis?.tick?.color
88
+ };
89
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
90
+ import_Tick.Tick,
91
+ {
92
+ ...tickLineCoords,
93
+ xTranslate: 0,
94
+ yTranslate: position,
95
+ textProps,
96
+ textStyle: style,
97
+ tickValue: yScale.getTickFormatted(tickValue),
98
+ ...rest
99
+ }
100
+ );
101
+ },
102
+ [style, textProps, yAxis?.tick?.color, yScale]
103
+ );
104
+ const axisColor = (0, import_react.useMemo)(() => import_colorPallet.COLOR_PALLET[yAxis.color] || yAxis.color, [yAxis.color]);
105
+ return (0, import_react.useMemo)(() => {
106
+ if (yAxis.hideAxis)
107
+ return null;
108
+ const lineCoords = {
109
+ x1: 0,
110
+ x2: 0,
111
+ y1: 0,
112
+ y2: innerHeight
113
+ };
114
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
115
+ import_Axis.Axis,
116
+ {
117
+ lineCoords,
118
+ scale: yScale,
119
+ innerRef: setAxisLeftRef,
120
+ dimension: height,
121
+ GridRenderer,
122
+ TickRenderer,
123
+ color: axisColor
69
124
  }
70
- }
71
- if (ref?.current && gridRef?.current) {
72
- (0, import_d3.select)(gridRef.current).call(grid);
73
- const axisNode = (0, import_d3.select)(ref.current);
74
- axisNode.call(axis);
75
- if (tickRotation)
76
- axisNode.selectAll("text").style("text-anchor", "end").attr("dx", "-.8em").attr("dy", ".15em").attr("transform", `rotate(-${tickRotation})`);
77
- }
78
- }, [
79
- innerHeight,
80
- innerWidth,
81
- overwriteTicks,
82
- showGrid,
83
- tickFormat,
84
- tickRotation,
85
- tickValues,
86
- ticks,
87
- type,
88
- yAxis,
89
- yScale
90
- ]);
91
- if (yAxis.hideAxis)
92
- return null;
93
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("g", { children: [
94
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { mask: `url(#mask-${chartId})`, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledGrid, { ref: gridRef }) }),
95
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { ref: setAxisLeftRef, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledAxis, { axisColor, ref, tickColor, className: "axis-left" }) })
96
- ] });
97
- };
125
+ );
126
+ }, [GridRenderer, TickRenderer, axisColor, height, innerHeight, setAxisLeftRef, yAxis.hideAxis, yScale]);
127
+ });
98
128
  //# sourceMappingURL=AxisLeft.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/graphs/Chart/parts/Axis/AxisLeft.tsx", "../../../../../../../../scripts/build/transpile/react-shim.js"],
4
- "sourcesContent": ["/* eslint-disable max-statements */\n/* eslint-disable complexity */\nimport React, { useContext, useEffect, useRef } from 'react';\nimport { select, axisLeft } from 'd3';\nimport { StyledAxis, StyledGrid } from '../../styles';\nimport { ChartContext } from '../../ChartContext';\nimport { getFormatGenerator } from '../../helpers';\n\nexport const AxisLeft = () => {\n const {\n props: { yAxis },\n innerHeight,\n innerWidth,\n yScale,\n chartId,\n height,\n setAxisLeftRef,\n } = useContext(ChartContext);\n\n const ref = useRef<SVGSVGElement>(null);\n const gridRef = useRef<SVGSVGElement>(null);\n const { tickValues, color: tickColor, tickFormat, overwriteTicks, tickRotation, tickCount } = yAxis.tick || {};\n\n const ticks = yScale.ticks?.(tickCount ?? height / 80);\n\n const { type, showGrid, color: axisColor } = yAxis;\n\n useEffect(() => {\n const axis = axisLeft(yScale).tickSizeOuter(0);\n\n const grid = axisLeft(yScale)\n .tickFormat((_) => '')\n .tickSize(showGrid ? -innerWidth : 0)\n .tickSizeOuter(0);\n\n if (tickValues && ticks) {\n const finalTicks = overwriteTicks ? tickValues : [...ticks, ...tickValues];\n axis.tickValues(finalTicks);\n } else {\n axis.tickValues(ticks);\n grid.tickValues(ticks);\n }\n\n if (tickFormat) {\n if (typeof tickFormat === 'string') {\n const formatGenerator = getFormatGenerator(type ?? 'linear');\n\n axis.tickFormat((d) => formatGenerator(tickFormat)(d));\n }\n if (typeof tickFormat === 'function') {\n axis.tickFormat(tickFormat);\n }\n }\n if (ref?.current && gridRef?.current) {\n select(gridRef.current).call(grid);\n const axisNode = select(ref.current);\n axisNode.call(axis);\n if (tickRotation)\n axisNode\n .selectAll('text')\n .style('text-anchor', 'end')\n .attr('dx', '-.8em')\n .attr('dy', '.15em')\n .attr('transform', `rotate(-${tickRotation})`);\n }\n }, [\n innerHeight,\n innerWidth,\n overwriteTicks,\n showGrid,\n tickFormat,\n tickRotation,\n tickValues,\n ticks,\n type,\n yAxis,\n yScale,\n ]);\n\n if (yAxis.hideAxis) return null;\n\n return (\n <g>\n <g mask={`url(#mask-${chartId})`}>\n <StyledGrid ref={gridRef}></StyledGrid>\n </g>\n <g ref={setAxisLeftRef}>\n <StyledAxis axisColor={axisColor} ref={ref} tickColor={tickColor} className=\"axis-left\"></StyledAxis>\n </g>\n </g>\n );\n};\n", "import * as React from 'react';\nexport { React };\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADkFnB;AAhFJ,mBAAqD;AACrD,gBAAiC;AACjC,oBAAuC;AACvC,0BAA6B;AAC7B,qBAAmC;AAE5B,MAAM,WAAW,MAAM;AAC5B,QAAM;AAAA,IACJ,OAAO,EAAE,MAAM;AAAA,IACf;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,QAAI,yBAAW,gCAAY;AAE3B,QAAM,UAAM,qBAAsB,IAAI;AACtC,QAAM,cAAU,qBAAsB,IAAI;AAC1C,QAAM,EAAE,YAAY,OAAO,WAAW,YAAY,gBAAgB,cAAc,UAAU,IAAI,MAAM,QAAQ,CAAC;AAE7G,QAAM,QAAQ,OAAO,QAAQ,aAAa,SAAS,EAAE;AAErD,QAAM,EAAE,MAAM,UAAU,OAAO,UAAU,IAAI;AAE7C,8BAAU,MAAM;AACd,UAAM,WAAO,oBAAS,MAAM,EAAE,cAAc,CAAC;AAE7C,UAAM,WAAO,oBAAS,MAAM,EACzB,WAAW,CAAC,MAAM,EAAE,EACpB,SAAS,WAAW,CAAC,aAAa,CAAC,EACnC,cAAc,CAAC;AAElB,QAAI,cAAc,OAAO;AACvB,YAAM,aAAa,iBAAiB,aAAa,CAAC,GAAG,OAAO,GAAG,UAAU;AACzE,WAAK,WAAW,UAAU;AAAA,IAC5B,OAAO;AACL,WAAK,WAAW,KAAK;AACrB,WAAK,WAAW,KAAK;AAAA,IACvB;AAEA,QAAI,YAAY;AACd,UAAI,OAAO,eAAe,UAAU;AAClC,cAAM,sBAAkB,mCAAmB,QAAQ,QAAQ;AAE3D,aAAK,WAAW,CAAC,MAAM,gBAAgB,UAAU,EAAE,CAAC,CAAC;AAAA,MACvD;AACA,UAAI,OAAO,eAAe,YAAY;AACpC,aAAK,WAAW,UAAU;AAAA,MAC5B;AAAA,IACF;AACA,QAAI,KAAK,WAAW,SAAS,SAAS;AACpC,4BAAO,QAAQ,OAAO,EAAE,KAAK,IAAI;AACjC,YAAM,eAAW,kBAAO,IAAI,OAAO;AACnC,eAAS,KAAK,IAAI;AAClB,UAAI;AACF,iBACG,UAAU,MAAM,EAChB,MAAM,eAAe,KAAK,EAC1B,KAAK,MAAM,OAAO,EAClB,KAAK,MAAM,OAAO,EAClB,KAAK,aAAa,WAAW,eAAe;AAAA,IACnD;AAAA,EACF,GAAG;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,MAAI,MAAM;AAAU,WAAO;AAE3B,SACE,6CAAC,OACC;AAAA,gDAAC,OAAE,MAAM,aAAa,YACpB,sDAAC,4BAAW,KAAK,SAAS,GAC5B;AAAA,IACA,4CAAC,OAAE,KAAK,gBACN,sDAAC,4BAAW,WAAsB,KAAU,WAAsB,WAAU,aAAY,GAC1F;AAAA,KACF;AAEJ;",
6
- "names": []
4
+ "sourcesContent": ["/* eslint-disable max-statements */\n/* eslint-disable complexity */\nimport React, { type CSSProperties, useCallback, useContext, useMemo } from 'react';\nimport { ChartContext } from '../../ChartContext';\nimport type { DSChartT } from '../../react-desc-prop-types';\nimport { Axis, type TickRenderPropsT, type GridRenderPropsT } from './Axis';\nimport { Tick } from './Tick';\nimport { GridLine } from './GridLine';\nimport { COLOR_PALLET } from '../../helpers/colorPallet';\n\nexport const AxisLeft = React.memo(() => {\n const {\n props: { yAxis },\n innerHeight,\n height,\n yScale,\n innerWidth,\n setAxisLeftRef,\n } = useContext(ChartContext);\n\n const { tickRotation } = yAxis.tick || ({} as DSChartT.AxisTickT);\n const { showGrid } = yAxis;\n\n const textProps = useMemo(() => {\n const commomProps = { fill: COLOR_PALLET[yAxis?.tick?.color as keyof typeof COLOR_PALLET] || yAxis?.tick?.color };\n if (!tickRotation) return { ...commomProps, x: -10, dy: '0.32em' };\n return {\n ...commomProps,\n dy: '.30em',\n dx: '-.10em',\n x: Math.trunc(-(11.5 - 2.5 * (tickRotation / 15) * (tickRotation > 0 ? 1 : -1))),\n transform: `rotate(${tickRotation})`,\n };\n }, [tickRotation, yAxis?.tick?.color]);\n\n const style: CSSProperties = useMemo(\n () => ({\n textAnchor: 'end',\n }),\n [],\n );\n\n const GridRenderer = useCallback(\n (props: GridRenderPropsT) => {\n if (!showGrid) return null;\n const { position, ...rest } = props;\n const gridLineCoords = {\n x1: 0,\n x2: innerWidth,\n y1: position,\n y2: position,\n };\n return <GridLine {...gridLineCoords} {...rest} />;\n },\n [showGrid, innerWidth],\n );\n\n const TickRenderer = useCallback(\n (props: TickRenderPropsT) => {\n const { position, tickValue, ...rest } = props;\n const tickLineCoords = {\n x2: -5,\n stroke: COLOR_PALLET[yAxis?.tick?.color as keyof typeof COLOR_PALLET] || yAxis?.tick?.color,\n };\n return (\n <Tick\n {...tickLineCoords}\n xTranslate={0}\n yTranslate={position}\n textProps={textProps}\n textStyle={style}\n tickValue={yScale.getTickFormatted(tickValue)}\n {...rest}\n />\n );\n },\n [style, textProps, yAxis?.tick?.color, yScale],\n );\n\n const axisColor = useMemo(() => COLOR_PALLET[yAxis.color as keyof typeof COLOR_PALLET] || yAxis.color, [yAxis.color]);\n\n return useMemo(() => {\n if (yAxis.hideAxis) return null;\n const lineCoords = {\n x1: 0,\n x2: 0,\n y1: 0,\n y2: innerHeight,\n };\n\n return (\n <Axis\n lineCoords={lineCoords}\n scale={yScale}\n innerRef={setAxisLeftRef}\n dimension={height}\n GridRenderer={GridRenderer}\n TickRenderer={TickRenderer}\n color={axisColor}\n />\n );\n }, [GridRenderer, TickRenderer, axisColor, height, innerHeight, setAxisLeftRef, yAxis.hideAxis, yScale]);\n});\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADoDV;AAlDb,mBAA4E;AAC5E,0BAA6B;AAE7B,kBAAmE;AACnE,kBAAqB;AACrB,sBAAyB;AACzB,yBAA6B;AAEtB,MAAM,WAAW,aAAAA,QAAM,KAAK,MAAM;AACvC,QAAM;AAAA,IACJ,OAAO,EAAE,MAAM;AAAA,IACf;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,QAAI,yBAAW,gCAAY;AAE3B,QAAM,EAAE,aAAa,IAAI,MAAM,QAAS,CAAC;AACzC,QAAM,EAAE,SAAS,IAAI;AAErB,QAAM,gBAAY,sBAAQ,MAAM;AAC9B,UAAM,cAAc,EAAE,MAAM,gCAAa,OAAO,MAAM,UAAuC,OAAO,MAAM,MAAM;AAChH,QAAI,CAAC;AAAc,aAAO,EAAE,GAAG,aAAa,GAAG,KAAK,IAAI,SAAS;AACjE,WAAO;AAAA,MACL,GAAG;AAAA,MACH,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,GAAG,KAAK,MAAM,EAAE,OAAO,OAAO,eAAe,OAAO,eAAe,IAAI,IAAI,IAAI;AAAA,MAC/E,WAAW,UAAU;AAAA,IACvB;AAAA,EACF,GAAG,CAAC,cAAc,OAAO,MAAM,KAAK,CAAC;AAErC,QAAM,YAAuB;AAAA,IAC3B,OAAO;AAAA,MACL,YAAY;AAAA,IACd;AAAA,IACA,CAAC;AAAA,EACH;AAEA,QAAM,mBAAe;AAAA,IACnB,CAAC,UAA4B;AAC3B,UAAI,CAAC;AAAU,eAAO;AACtB,YAAM,EAAE,aAAa,KAAK,IAAI;AAC9B,YAAM,iBAAiB;AAAA,QACrB,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,MACN;AACA,aAAO,4CAAC,4BAAU,GAAG,gBAAiB,GAAG,MAAM;AAAA,IACjD;AAAA,IACA,CAAC,UAAU,UAAU;AAAA,EACvB;AAEA,QAAM,mBAAe;AAAA,IACnB,CAAC,UAA4B;AAC3B,YAAM,EAAE,UAAU,cAAc,KAAK,IAAI;AACzC,YAAM,iBAAiB;AAAA,QACrB,IAAI;AAAA,QACJ,QAAQ,gCAAa,OAAO,MAAM,UAAuC,OAAO,MAAM;AAAA,MACxF;AACA,aACE;AAAA,QAAC;AAAA;AAAA,UACE,GAAG;AAAA,UACJ,YAAY;AAAA,UACZ,YAAY;AAAA,UACZ;AAAA,UACA,WAAW;AAAA,UACX,WAAW,OAAO,iBAAiB,SAAS;AAAA,UAC3C,GAAG;AAAA;AAAA,MACN;AAAA,IAEJ;AAAA,IACA,CAAC,OAAO,WAAW,OAAO,MAAM,OAAO,MAAM;AAAA,EAC/C;AAEA,QAAM,gBAAY,sBAAQ,MAAM,gCAAa,MAAM,UAAuC,MAAM,OAAO,CAAC,MAAM,KAAK,CAAC;AAEpH,aAAO,sBAAQ,MAAM;AACnB,QAAI,MAAM;AAAU,aAAO;AAC3B,UAAM,aAAa;AAAA,MACjB,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,OAAO;AAAA,QACP,UAAU;AAAA,QACV,WAAW;AAAA,QACX;AAAA,QACA;AAAA,QACA,OAAO;AAAA;AAAA,IACT;AAAA,EAEJ,GAAG,CAAC,cAAc,cAAc,WAAW,QAAQ,aAAa,gBAAgB,MAAM,UAAU,MAAM,CAAC;AACzG,CAAC;",
6
+ "names": ["React"]
7
7
  }
@@ -29,68 +29,103 @@ __export(AxisRight_exports, {
29
29
  module.exports = __toCommonJS(AxisRight_exports);
30
30
  var React = __toESM(require("react"));
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
- var import_react = require("react");
33
- var import_d3 = require("d3");
34
- var import_styles = require("../../styles");
32
+ var import_react = __toESM(require("react"));
35
33
  var import_ChartContext = require("../../ChartContext");
36
- var import_helpers = require("../../helpers");
37
- const AxisRight = () => {
34
+ var import_Axis = require("./Axis");
35
+ var import_Tick = require("./Tick");
36
+ var import_GridLine = require("./GridLine");
37
+ var import_colorPallet = require("../../helpers/colorPallet");
38
+ const AxisRight = import_react.default.memo(() => {
38
39
  const {
39
40
  props: { y2Axis },
40
41
  innerHeight,
41
- innerWidth,
42
42
  y2Scale,
43
- chartId,
44
- height,
43
+ innerWidth,
45
44
  setAxisRightRef
46
45
  } = (0, import_react.useContext)(import_ChartContext.ChartContext);
47
- const ref = (0, import_react.useRef)(null);
48
- const gridRef = (0, import_react.useRef)(null);
49
- const { tickValues, color: tickColor, tickFormat, overwriteTicks, tickRotation, tickCount } = y2Axis.tick || {};
50
- const ticks = y2Scale.ticks?.(tickCount ?? height / 80);
51
- const { type, showGrid, color: axisColor } = y2Axis;
52
- (0, import_react.useEffect)(() => {
53
- const axis = (0, import_d3.axisRight)(y2Scale).tickSizeOuter(0);
54
- const grid = (0, import_d3.axisRight)(y2Scale).tickFormat((_) => "").tickSize(showGrid ? -innerWidth : 0).tickSizeOuter(0);
55
- if (tickValues && ticks) {
56
- const finalTicks = overwriteTicks ? tickValues : [...ticks, ...tickValues];
57
- axis.tickValues(finalTicks);
58
- } else {
59
- axis.tickValues(ticks);
60
- grid.tickValues(ticks);
61
- }
62
- if (tickFormat) {
63
- if (typeof tickFormat === "string") {
64
- const formatGenerator = (0, import_helpers.getFormatGenerator)(type ?? "linear");
65
- axis.tickFormat((d) => formatGenerator(tickFormat)(d));
46
+ const { tickRotation } = y2Axis?.tick || {};
47
+ const { showGrid } = y2Axis;
48
+ const textProps = (0, import_react.useMemo)(() => {
49
+ const commomProps = { fill: import_colorPallet.COLOR_PALLET[y2Axis?.tick?.color] || y2Axis?.tick?.color };
50
+ if (!tickRotation)
51
+ return { ...commomProps, x: 10, dy: "0.32em" };
52
+ return {
53
+ ...commomProps,
54
+ dx: 8 * Math.sin(Math.PI * (tickRotation / 180)),
55
+ dy: ".71em",
56
+ y: 11.5 - 2.5 * (tickRotation / 15) * (tickRotation > 0 ? 1 : -1),
57
+ transform: `rotate(${tickRotation})`
58
+ };
59
+ }, [tickRotation, y2Axis?.tick?.color]);
60
+ const style = (0, import_react.useMemo)(() => {
61
+ if (!tickRotation)
62
+ return {
63
+ textAnchor: "start"
64
+ };
65
+ return { textAnchor: tickRotation > 0 ? "start" : "end" };
66
+ }, [tickRotation]);
67
+ const GridRenderer = (0, import_react.useCallback)(
68
+ (props) => {
69
+ if (!showGrid)
70
+ return null;
71
+ const { position, ...rest } = props;
72
+ const gridLineCoords = {
73
+ x1: 0,
74
+ x2: innerWidth,
75
+ y1: position,
76
+ y2: position
77
+ };
78
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_GridLine.GridLine, { ...gridLineCoords, ...rest });
79
+ },
80
+ [innerWidth, showGrid]
81
+ );
82
+ const TickRenderer = (0, import_react.useCallback)(
83
+ (props) => {
84
+ const { position, tickValue, ...rest } = props;
85
+ const tickLineCoords = {
86
+ x2: 5,
87
+ stroke: import_colorPallet.COLOR_PALLET[y2Axis?.tick?.color] || y2Axis?.tick?.color
88
+ };
89
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
90
+ import_Tick.Tick,
91
+ {
92
+ ...tickLineCoords,
93
+ yTranslate: position,
94
+ xTranslate: innerWidth,
95
+ textProps,
96
+ textStyle: style,
97
+ tickValue: y2Scale.getTickFormatted(tickValue),
98
+ ...rest
99
+ }
100
+ );
101
+ },
102
+ [innerWidth, style, textProps, y2Axis?.tick?.color, y2Scale]
103
+ );
104
+ const axisColor = (0, import_react.useMemo)(
105
+ () => import_colorPallet.COLOR_PALLET[y2Axis.color] || y2Axis.color,
106
+ [y2Axis.color]
107
+ );
108
+ return (0, import_react.useMemo)(() => {
109
+ if (y2Axis?.hideAxis)
110
+ return null;
111
+ const lineCoords = {
112
+ x1: innerWidth,
113
+ x2: innerWidth,
114
+ y1: 0,
115
+ y2: innerHeight
116
+ };
117
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
118
+ import_Axis.Axis,
119
+ {
120
+ lineCoords,
121
+ scale: y2Scale,
122
+ innerRef: setAxisRightRef,
123
+ dimension: innerHeight,
124
+ GridRenderer,
125
+ TickRenderer,
126
+ color: axisColor
66
127
  }
67
- if (typeof tickFormat === "function") {
68
- axis.tickFormat(tickFormat);
69
- }
70
- }
71
- if (ref?.current && gridRef?.current) {
72
- (0, import_d3.select)(gridRef.current).call(grid);
73
- const axisNode = (0, import_d3.select)(ref.current);
74
- axisNode.call(axis);
75
- }
76
- }, [
77
- innerHeight,
78
- innerWidth,
79
- overwriteTicks,
80
- showGrid,
81
- tickFormat,
82
- tickRotation,
83
- tickValues,
84
- ticks,
85
- type,
86
- y2Axis,
87
- y2Scale
88
- ]);
89
- if (y2Axis.hideAxis)
90
- return null;
91
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("g", { transform: `translate(${innerWidth},0)`, children: [
92
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { mask: `url(#mask-${chartId})`, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledGrid, { ref: gridRef }) }),
93
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { ref: setAxisRightRef, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledAxis, { axisColor, ref, tickColor, className: "axis-right" }) })
94
- ] });
95
- };
128
+ );
129
+ }, [GridRenderer, TickRenderer, axisColor, innerHeight, innerWidth, setAxisRightRef, y2Axis?.hideAxis, y2Scale]);
130
+ });
96
131
  //# sourceMappingURL=AxisRight.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../src/graphs/Chart/parts/Axis/AxisRight.tsx", "../../../../../../../../scripts/build/transpile/react-shim.js"],
4
- "sourcesContent": ["/* eslint-disable max-statements */\n/* eslint-disable complexity */\nimport React, { useContext, useEffect, useRef } from 'react';\nimport { select, axisRight } from 'd3';\nimport { StyledAxis, StyledGrid } from '../../styles';\nimport { ChartContext } from '../../ChartContext';\nimport { getFormatGenerator } from '../../helpers';\n\nexport const AxisRight = () => {\n const {\n props: { y2Axis },\n innerHeight,\n innerWidth,\n y2Scale,\n chartId,\n height,\n setAxisRightRef,\n } = useContext(ChartContext);\n\n const ref = useRef<SVGSVGElement>(null);\n const gridRef = useRef<SVGSVGElement>(null);\n const { tickValues, color: tickColor, tickFormat, overwriteTicks, tickRotation, tickCount } = y2Axis.tick || {};\n\n const ticks = y2Scale.ticks?.(tickCount ?? height / 80);\n\n const { type, showGrid, color: axisColor } = y2Axis;\n\n useEffect(() => {\n const axis = axisRight(y2Scale).tickSizeOuter(0);\n\n const grid = axisRight(y2Scale)\n .tickFormat((_) => '')\n .tickSize(showGrid ? -innerWidth : 0)\n .tickSizeOuter(0);\n\n if (tickValues && ticks) {\n const finalTicks = overwriteTicks ? tickValues : [...ticks, ...tickValues];\n axis.tickValues(finalTicks);\n } else {\n axis.tickValues(ticks);\n grid.tickValues(ticks);\n }\n\n if (tickFormat) {\n if (typeof tickFormat === 'string') {\n const formatGenerator = getFormatGenerator(type ?? 'linear');\n\n axis.tickFormat((d) => formatGenerator(tickFormat)(d));\n }\n if (typeof tickFormat === 'function') {\n axis.tickFormat(tickFormat);\n }\n }\n if (ref?.current && gridRef?.current) {\n select(gridRef.current).call(grid);\n const axisNode = select(ref.current);\n axisNode.call(axis);\n }\n }, [\n innerHeight,\n innerWidth,\n overwriteTicks,\n showGrid,\n tickFormat,\n tickRotation,\n tickValues,\n ticks,\n type,\n y2Axis,\n y2Scale,\n ]);\n\n if (y2Axis.hideAxis) return null;\n\n return (\n <g transform={`translate(${innerWidth},0)`}>\n <g mask={`url(#mask-${chartId})`}>\n <StyledGrid ref={gridRef}></StyledGrid>\n </g>\n <g ref={setAxisRightRef}>\n <StyledAxis axisColor={axisColor} ref={ref} tickColor={tickColor} className=\"axis-right\"></StyledAxis>\n </g>\n </g>\n );\n};\n", "import * as React from 'react';\nexport { React };\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;AD2EnB;AAzEJ,mBAAqD;AACrD,gBAAkC;AAClC,oBAAuC;AACvC,0BAA6B;AAC7B,qBAAmC;AAE5B,MAAM,YAAY,MAAM;AAC7B,QAAM;AAAA,IACJ,OAAO,EAAE,OAAO;AAAA,IAChB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,QAAI,yBAAW,gCAAY;AAE3B,QAAM,UAAM,qBAAsB,IAAI;AACtC,QAAM,cAAU,qBAAsB,IAAI;AAC1C,QAAM,EAAE,YAAY,OAAO,WAAW,YAAY,gBAAgB,cAAc,UAAU,IAAI,OAAO,QAAQ,CAAC;AAE9G,QAAM,QAAQ,QAAQ,QAAQ,aAAa,SAAS,EAAE;AAEtD,QAAM,EAAE,MAAM,UAAU,OAAO,UAAU,IAAI;AAE7C,8BAAU,MAAM;AACd,UAAM,WAAO,qBAAU,OAAO,EAAE,cAAc,CAAC;AAE/C,UAAM,WAAO,qBAAU,OAAO,EAC3B,WAAW,CAAC,MAAM,EAAE,EACpB,SAAS,WAAW,CAAC,aAAa,CAAC,EACnC,cAAc,CAAC;AAElB,QAAI,cAAc,OAAO;AACvB,YAAM,aAAa,iBAAiB,aAAa,CAAC,GAAG,OAAO,GAAG,UAAU;AACzE,WAAK,WAAW,UAAU;AAAA,IAC5B,OAAO;AACL,WAAK,WAAW,KAAK;AACrB,WAAK,WAAW,KAAK;AAAA,IACvB;AAEA,QAAI,YAAY;AACd,UAAI,OAAO,eAAe,UAAU;AAClC,cAAM,sBAAkB,mCAAmB,QAAQ,QAAQ;AAE3D,aAAK,WAAW,CAAC,MAAM,gBAAgB,UAAU,EAAE,CAAC,CAAC;AAAA,MACvD;AACA,UAAI,OAAO,eAAe,YAAY;AACpC,aAAK,WAAW,UAAU;AAAA,MAC5B;AAAA,IACF;AACA,QAAI,KAAK,WAAW,SAAS,SAAS;AACpC,4BAAO,QAAQ,OAAO,EAAE,KAAK,IAAI;AACjC,YAAM,eAAW,kBAAO,IAAI,OAAO;AACnC,eAAS,KAAK,IAAI;AAAA,IACpB;AAAA,EACF,GAAG;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,MAAI,OAAO;AAAU,WAAO;AAE5B,SACE,6CAAC,OAAE,WAAW,aAAa,iBACzB;AAAA,gDAAC,OAAE,MAAM,aAAa,YACpB,sDAAC,4BAAW,KAAK,SAAS,GAC5B;AAAA,IACA,4CAAC,OAAE,KAAK,iBACN,sDAAC,4BAAW,WAAsB,KAAU,WAAsB,WAAU,cAAa,GAC3F;AAAA,KACF;AAEJ;",
6
- "names": []
4
+ "sourcesContent": ["/* eslint-disable max-statements */\n/* eslint-disable complexity */\nimport React, { type CSSProperties, useCallback, useContext, useMemo } from 'react';\nimport { ChartContext } from '../../ChartContext';\nimport type { DSChartT } from '../../react-desc-prop-types';\nimport { Axis, type TickRenderPropsT, type GridRenderPropsT } from './Axis';\nimport { Tick } from './Tick';\nimport { GridLine } from './GridLine';\nimport { COLOR_PALLET } from '../../helpers/colorPallet';\n\nexport const AxisRight = React.memo(() => {\n const {\n props: { y2Axis },\n innerHeight,\n y2Scale,\n innerWidth,\n setAxisRightRef,\n } = useContext(ChartContext);\n\n const { tickRotation } = y2Axis?.tick || ({} as DSChartT.AxisTickT);\n const { showGrid } = y2Axis;\n const textProps = useMemo(() => {\n const commomProps = { fill: COLOR_PALLET[y2Axis?.tick?.color as keyof typeof COLOR_PALLET] || y2Axis?.tick?.color };\n\n if (!tickRotation) return { ...commomProps, x: 10, dy: '0.32em' };\n return {\n ...commomProps,\n dx: 8 * Math.sin(Math.PI * (tickRotation / 180)),\n dy: '.71em',\n y: 11.5 - 2.5 * (tickRotation / 15) * (tickRotation > 0 ? 1 : -1),\n transform: `rotate(${tickRotation})`,\n };\n }, [tickRotation, y2Axis?.tick?.color]);\n\n const style: CSSProperties = useMemo(() => {\n if (!tickRotation)\n return {\n textAnchor: 'start',\n };\n return { textAnchor: tickRotation > 0 ? 'start' : 'end' };\n }, [tickRotation]);\n\n const GridRenderer = useCallback(\n (props: GridRenderPropsT) => {\n if (!showGrid) return null;\n const { position, ...rest } = props;\n const gridLineCoords = {\n x1: 0,\n x2: innerWidth,\n y1: position,\n y2: position,\n };\n return <GridLine {...gridLineCoords} {...rest} />;\n },\n [innerWidth, showGrid],\n );\n\n const TickRenderer = useCallback(\n (props: TickRenderPropsT) => {\n const { position, tickValue, ...rest } = props;\n const tickLineCoords = {\n x2: 5,\n stroke: COLOR_PALLET[y2Axis?.tick?.color as keyof typeof COLOR_PALLET] || y2Axis?.tick?.color,\n };\n return (\n <Tick\n {...tickLineCoords}\n yTranslate={position}\n xTranslate={innerWidth}\n textProps={textProps}\n textStyle={style}\n tickValue={y2Scale.getTickFormatted(tickValue)}\n {...rest}\n />\n );\n },\n [innerWidth, style, textProps, y2Axis?.tick?.color, y2Scale],\n );\n\n const axisColor = useMemo(\n () => COLOR_PALLET[y2Axis.color as keyof typeof COLOR_PALLET] || y2Axis.color,\n [y2Axis.color],\n );\n\n return useMemo(() => {\n if (y2Axis?.hideAxis) return null;\n const lineCoords = {\n x1: innerWidth,\n x2: innerWidth,\n y1: 0,\n y2: innerHeight,\n };\n\n return (\n <Axis\n lineCoords={lineCoords}\n scale={y2Scale}\n innerRef={setAxisRightRef}\n dimension={innerHeight}\n GridRenderer={GridRenderer}\n TickRenderer={TickRenderer}\n color={axisColor}\n />\n );\n }, [GridRenderer, TickRenderer, axisColor, innerHeight, innerWidth, setAxisRightRef, y2Axis?.hideAxis, y2Scale]);\n});\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADoDV;AAlDb,mBAA4E;AAC5E,0BAA6B;AAE7B,kBAAmE;AACnE,kBAAqB;AACrB,sBAAyB;AACzB,yBAA6B;AAEtB,MAAM,YAAY,aAAAA,QAAM,KAAK,MAAM;AACxC,QAAM;AAAA,IACJ,OAAO,EAAE,OAAO;AAAA,IAChB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,QAAI,yBAAW,gCAAY;AAE3B,QAAM,EAAE,aAAa,IAAI,QAAQ,QAAS,CAAC;AAC3C,QAAM,EAAE,SAAS,IAAI;AACrB,QAAM,gBAAY,sBAAQ,MAAM;AAC9B,UAAM,cAAc,EAAE,MAAM,gCAAa,QAAQ,MAAM,UAAuC,QAAQ,MAAM,MAAM;AAElH,QAAI,CAAC;AAAc,aAAO,EAAE,GAAG,aAAa,GAAG,IAAI,IAAI,SAAS;AAChE,WAAO;AAAA,MACL,GAAG;AAAA,MACH,IAAI,IAAI,KAAK,IAAI,KAAK,MAAM,eAAe,IAAI;AAAA,MAC/C,IAAI;AAAA,MACJ,GAAG,OAAO,OAAO,eAAe,OAAO,eAAe,IAAI,IAAI;AAAA,MAC9D,WAAW,UAAU;AAAA,IACvB;AAAA,EACF,GAAG,CAAC,cAAc,QAAQ,MAAM,KAAK,CAAC;AAEtC,QAAM,YAAuB,sBAAQ,MAAM;AACzC,QAAI,CAAC;AACH,aAAO;AAAA,QACL,YAAY;AAAA,MACd;AACF,WAAO,EAAE,YAAY,eAAe,IAAI,UAAU,MAAM;AAAA,EAC1D,GAAG,CAAC,YAAY,CAAC;AAEjB,QAAM,mBAAe;AAAA,IACnB,CAAC,UAA4B;AAC3B,UAAI,CAAC;AAAU,eAAO;AACtB,YAAM,EAAE,aAAa,KAAK,IAAI;AAC9B,YAAM,iBAAiB;AAAA,QACrB,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,MACN;AACA,aAAO,4CAAC,4BAAU,GAAG,gBAAiB,GAAG,MAAM;AAAA,IACjD;AAAA,IACA,CAAC,YAAY,QAAQ;AAAA,EACvB;AAEA,QAAM,mBAAe;AAAA,IACnB,CAAC,UAA4B;AAC3B,YAAM,EAAE,UAAU,cAAc,KAAK,IAAI;AACzC,YAAM,iBAAiB;AAAA,QACrB,IAAI;AAAA,QACJ,QAAQ,gCAAa,QAAQ,MAAM,UAAuC,QAAQ,MAAM;AAAA,MAC1F;AACA,aACE;AAAA,QAAC;AAAA;AAAA,UACE,GAAG;AAAA,UACJ,YAAY;AAAA,UACZ,YAAY;AAAA,UACZ;AAAA,UACA,WAAW;AAAA,UACX,WAAW,QAAQ,iBAAiB,SAAS;AAAA,UAC5C,GAAG;AAAA;AAAA,MACN;AAAA,IAEJ;AAAA,IACA,CAAC,YAAY,OAAO,WAAW,QAAQ,MAAM,OAAO,OAAO;AAAA,EAC7D;AAEA,QAAM,gBAAY;AAAA,IAChB,MAAM,gCAAa,OAAO,UAAuC,OAAO;AAAA,IACxE,CAAC,OAAO,KAAK;AAAA,EACf;AAEA,aAAO,sBAAQ,MAAM;AACnB,QAAI,QAAQ;AAAU,aAAO;AAC7B,UAAM,aAAa;AAAA,MACjB,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,OAAO;AAAA,QACP,UAAU;AAAA,QACV,WAAW;AAAA,QACX;AAAA,QACA;AAAA,QACA,OAAO;AAAA;AAAA,IACT;AAAA,EAEJ,GAAG,CAAC,cAAc,cAAc,WAAW,aAAa,YAAY,iBAAiB,QAAQ,UAAU,OAAO,CAAC;AACjH,CAAC;",
6
+ "names": ["React"]
7
7
  }
@@ -22,32 +22,13 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
22
22
  mod
23
23
  ));
24
24
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
25
- var BottomLabel_exports = {};
26
- __export(BottomLabel_exports, {
27
- BottomLabel: () => BottomLabel
25
+ var GridLine_exports = {};
26
+ __export(GridLine_exports, {
27
+ GridLine: () => GridLine
28
28
  });
29
- module.exports = __toCommonJS(BottomLabel_exports);
29
+ module.exports = __toCommonJS(GridLine_exports);
30
30
  var React = __toESM(require("react"));
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
- var import_react = require("react");
33
- var import_ChartContext = require("../../ChartContext");
34
- var import_styles = require("../../styles");
35
- const BottomLabel = () => {
36
- const {
37
- internalMargin,
38
- setBottomLabel,
39
- innerHeight,
40
- innerWidth,
41
- axisBottomHeight,
42
- props: { xAxis }
43
- } = (0, import_react.useContext)(import_ChartContext.ChartContext);
44
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
45
- "g",
46
- {
47
- ref: setBottomLabel,
48
- transform: `translate(${innerWidth / 2 + internalMargin.left},${innerHeight + axisBottomHeight + internalMargin.top})`,
49
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledAxisLabel, { className: "axis-label", textAnchor: "middle", children: xAxis?.label })
50
- }
51
- );
52
- };
53
- //# sourceMappingURL=BottomLabel.js.map
32
+ var import_react = __toESM(require("react"));
33
+ const GridLine = import_react.default.memo(({ x1 = 0, y1 = 0, x2 = 0, y2 = 0 }) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)("line", { x1, x2, y1, y2, stroke: "black", style: { opacity: 0.2 } }));
34
+ //# sourceMappingURL=GridLine.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/graphs/Chart/parts/Axis/GridLine.tsx", "../../../../../../../../scripts/build/transpile/react-shim.js"],
4
+ "sourcesContent": ["import React from 'react';\n\ninterface GridLineT {\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n}\nexport const GridLine: React.ComponentType<GridLineT> = React.memo(({ x1 = 0, y1 = 0, x2 = 0, y2 = 0 }) => (\n <line x1={x1} x2={x2} y1={y1} y2={y2} stroke=\"black\" style={{ opacity: 0.2 }} />\n));\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADSrB;AATF,mBAAkB;AAQX,MAAM,WAA2C,aAAAA,QAAM,KAAK,CAAC,EAAE,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,EAAE,MACnG,4CAAC,UAAK,IAAQ,IAAQ,IAAQ,IAAQ,QAAO,SAAQ,OAAO,EAAE,SAAS,IAAI,GAAG,CAC/E;",
6
+ "names": ["React"]
7
+ }
@@ -22,31 +22,18 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
22
22
  mod
23
23
  ));
24
24
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
25
- var LeftLabel_exports = {};
26
- __export(LeftLabel_exports, {
27
- LeftLabel: () => LeftLabel
25
+ var Tick_exports = {};
26
+ __export(Tick_exports, {
27
+ Tick: () => Tick
28
28
  });
29
- module.exports = __toCommonJS(LeftLabel_exports);
29
+ module.exports = __toCommonJS(Tick_exports);
30
30
  var React = __toESM(require("react"));
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
- var import_react = require("react");
33
- var import_ChartContext = require("../../ChartContext");
34
- var import_styles = require("../../styles");
35
- const LeftLabel = () => {
36
- const {
37
- innerHeight,
38
- internalMargin,
39
- setLeftLabel,
40
- leftLegendWidth,
41
- leftLabelWidth,
42
- props: { yAxis }
43
- } = (0, import_react.useContext)(import_ChartContext.ChartContext);
44
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { ref: setLeftLabel, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
45
- "g",
46
- {
47
- transform: `translate(${leftLegendWidth + leftLabelWidth},${innerHeight / 2 + internalMargin.top}) rotate(-90)`,
48
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledAxisLabel, { className: "axis-label", textAnchor: "middle", children: yAxis?.label })
49
- }
50
- ) });
51
- };
52
- //# sourceMappingURL=LeftLabel.js.map
32
+ var import_react = __toESM(require("react"));
33
+ const Tick = import_react.default.memo(
34
+ ({ tickValue, stroke, textProps, xTranslate = 0, yTranslate = 0, textStyle, ...rest }) => /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("g", { transform: `translate(${xTranslate},${yTranslate})`, children: [
35
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("line", { ...rest, stroke: stroke || "black" }),
36
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("text", { fill: "black", ...textProps, style: textStyle, children: tickValue.toString() })
37
+ ] })
38
+ );
39
+ //# sourceMappingURL=Tick.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/graphs/Chart/parts/Axis/Tick.tsx", "../../../../../../../../scripts/build/transpile/react-shim.js"],
4
+ "sourcesContent": ["import React, { type SVGAttributes, type CSSProperties } from 'react';\n\nexport interface TickT {\n xTranslate?: number;\n yTranslate?: number;\n x1?: number;\n y1?: number;\n x2?: number;\n y2?: number;\n size?: number;\n stroke?: string;\n tickValue: string | number | Date;\n textProps: Partial<SVGAttributes<SVGTextElement>>;\n textStyle: CSSProperties;\n}\nexport const Tick: React.ComponentType<TickT> = React.memo(\n ({ tickValue, stroke, textProps, xTranslate = 0, yTranslate = 0, textStyle, ...rest }) => (\n <g transform={`translate(${xTranslate},${yTranslate})`}>\n <line {...rest} stroke={stroke || 'black'} />\n <text fill=\"black\" {...textProps} style={textStyle}>\n {tickValue.toString()}\n </text>\n </g>\n ),\n);\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB;ADiBnB;AAjBJ,mBAA8D;AAevD,MAAM,OAAmC,aAAAA,QAAM;AAAA,EACpD,CAAC,EAAE,WAAW,QAAQ,WAAW,aAAa,GAAG,aAAa,GAAG,cAAc,KAAK,MAClF,6CAAC,OAAE,WAAW,aAAa,cAAc,eACvC;AAAA,gDAAC,UAAM,GAAG,MAAM,QAAQ,UAAU,SAAS;AAAA,IAC3C,4CAAC,UAAK,MAAK,SAAS,GAAG,WAAW,OAAO,WACtC,oBAAU,SAAS,GACtB;AAAA,KACF;AAEJ;",
6
+ "names": ["React"]
7
+ }
@@ -34,7 +34,7 @@ var import_styles = require("../styles");
34
34
  var import_ChartContext = require("../ChartContext");
35
35
  var import_useKeyboardNavigation = require("../config/useKeyboardNavigation");
36
36
  var import_Legend = require("./Legend/Legend");
37
- var import_Label = require("./Labels/Label");
37
+ var import_Labels = require("./Labels");
38
38
  var import_BlurMask = require("./Scroller/BlurMask");
39
39
  var import_ClipPaths = require("./ClipPaths");
40
40
  var import_ScrollableContainerX = require("./Scroller/ScrollableContainerX");
@@ -192,7 +192,7 @@ const ChartContainer = () => {
192
192
  /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("g", { children: [
193
193
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Controllers.Controllers, {}),
194
194
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Legend.Legend, {}),
195
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Label.Label, {})
195
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Labels.Labels, {})
196
196
  ] }),
197
197
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { className: "container", transform: `translate(${internalMargin.left},${internalMargin.top})`, children: render })
198
198
  ] })
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/graphs/Chart/parts/ChartContainer.tsx", "../../../../../../../scripts/build/transpile/react-shim.js"],
4
- "sourcesContent": ["import React, { useContext, useMemo, useCallback, useEffect } from 'react';\nimport { StyledSVGWrapper } from '../styles';\n\nimport { ChartContext } from '../ChartContext';\nimport { useKeyboardNavigation } from '../config/useKeyboardNavigation';\nimport { Legend } from './Legend/Legend';\nimport { Label } from './Labels/Label';\nimport { BlurMask } from './Scroller/BlurMask';\nimport { ClipPaths } from './ClipPaths';\nimport { ScrollableContainerX } from './Scroller/ScrollableContainerX';\nimport { ScrollableContainerY } from './Scroller/ScrollableContainerY';\n\nimport { AxisBottom } from './Axis/AxisBottom';\nimport { AxisRight } from './Axis/AxisRight';\nimport { AxisLeft } from './Axis/AxisLeft';\nimport { SeriesFactory } from './SeriesFactory';\nimport { Scrapper } from './Scrapper/Scrapper';\nimport { VerticalScrapper } from './Scrapper/VerticalScrapper';\nimport { Controllers } from './Scroller/Controllers';\nexport const ChartContainer = () => {\n const {\n props: { y2Axis, yScroll, xScroll, scrapper, xAxis, width: userWidth },\n activePoint,\n internalMargin,\n setScrapperPosY,\n setScrapperPosX,\n setContainerRef,\n svgRef,\n isGrabbed,\n setIsGrabbed,\n startPosition,\n innerWidth,\n innerHeight,\n setActivePoint,\n setXScrollbarPosition,\n xScrollbarPosition,\n containerRatio,\n lastPosition,\n setIsScrollbarVisible,\n currentData,\n setStartPosition,\n width,\n height,\n } = useContext(ChartContext);\n\n // const xScroll = xAxis.advanced?.pointSpacing?.value > 1;\n // const yScroll = yAxis.advanced?.pointSpacing?.value > 1;\n const { onInputKeyDown, handleOnKeyUp, handleOnBlur, handleOnFocus } = useKeyboardNavigation();\n\n const onMouseEnterHandler = useCallback(() => {\n setIsScrollbarVisible(true);\n setActivePoint(null);\n }, [setActivePoint, setIsScrollbarVisible]);\n const onMouseLeaveHandler = useCallback(() => {\n setScrapperPosY('');\n setScrapperPosX('');\n setIsScrollbarVisible(false);\n setIsGrabbed(false);\n }, [setIsGrabbed, setIsScrollbarVisible, setScrapperPosX, setScrapperPosY]);\n\n const handleOnTouchStart: React.TouchEventHandler = useCallback(\n (e) => {\n e.stopPropagation();\n setScrapperPosX('');\n setIsGrabbed(true);\n setStartPosition(e.touches[0].clientX);\n e.preventDefault();\n },\n [setIsGrabbed, setScrapperPosX, setStartPosition],\n );\n const handleOnTouchEnd = useCallback(() => {\n lastPosition.current = xScrollbarPosition;\n setIsGrabbed(false);\n }, [setIsGrabbed, xScrollbarPosition, lastPosition]);\n const handleMouseMove: React.MouseEventHandler = useCallback(\n (e) => {\n if (!isGrabbed) return;\n e.preventDefault();\n const clientX = e.clientX ?? e.touches[0].clientX;\n const clientY = e.clientY ?? e.touches[0].clientY;\n\n setActivePoint(null);\n if (xScroll) {\n const newPosition = lastPosition?.current + clientX - startPosition;\n if (newPosition < 0) setXScrollbarPosition(0);\n else if (newPosition > innerWidth - innerWidth / containerRatio)\n setXScrollbarPosition(innerWidth - innerWidth / containerRatio);\n else setXScrollbarPosition(newPosition);\n }\n if (yScroll) {\n const newPosition = lastPosition?.current + clientY - startPosition;\n\n if (newPosition < 0) setXScrollbarPosition(0);\n else if (newPosition > innerHeight - innerHeight / containerRatio)\n setXScrollbarPosition(innerHeight - innerHeight / containerRatio);\n else setXScrollbarPosition(newPosition);\n }\n },\n [\n isGrabbed,\n setActivePoint,\n xScroll,\n yScroll,\n lastPosition,\n startPosition,\n setXScrollbarPosition,\n innerWidth,\n containerRatio,\n innerHeight,\n ],\n );\n const handleMouseUp = useCallback(() => {\n lastPosition.current = xScrollbarPosition;\n setIsGrabbed(false);\n }, [lastPosition, setIsGrabbed, xScrollbarPosition]);\n\n // const key = useMemo(\n // () => `${width},${internalMargin.left},${internalMargin.top},${internalMargin.right},${internalMargin.bottom}`,\n // [internalMargin, width],\n // );\n\n const render = useMemo(() => {\n if (currentData.length === 0) return null;\n if (xScroll || xAxis.advanced?.pointSpacing?.value > 1) {\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisLeft />\n <ScrollableContainerX />\n </>\n );\n }\n if (yScroll) {\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisBottom />\n <ScrollableContainerY />\n </>\n );\n }\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisLeft />\n <AxisBottom />\n <SeriesFactory />\n {scrapper?.type === 'horizontal' ? <Scrapper /> : null}\n {scrapper?.type === 'vertical' ? <VerticalScrapper /> : null}\n </>\n );\n }, [currentData.length, scrapper?.type, xAxis.advanced?.pointSpacing?.value, xScroll, y2Axis, yScroll]);\n return (\n <StyledSVGWrapper\n ref={setContainerRef}\n onKeyDown={onInputKeyDown}\n onKeyUp={handleOnKeyUp}\n tabIndex={activePoint ? -1 : 0}\n onBlur={handleOnBlur}\n onFocus={handleOnFocus}\n onTouchMove={handleMouseMove}\n onTouchStart={handleOnTouchStart}\n onTouchEnd={handleOnTouchEnd}\n onMouseEnter={onMouseEnterHandler}\n onMouseLeave={onMouseLeaveHandler}\n onMouseMove={handleMouseMove}\n onMouseUp={handleMouseUp}\n onMouseDown={(e) => e.preventDefault()}\n isGrabbed={isGrabbed}\n style={{ width: userWidth, height }}\n >\n {width !== 0 ? (\n <svg ref={svgRef} width={width} height={height}>\n {/* this clipaths for animations and focus ring.. need to give a deeper look */}\n <ClipPaths />\n <BlurMask />\n <g>\n <g>\n <Controllers />\n <Legend />\n <Label />\n </g>\n <g className=\"container\" transform={`translate(${internalMargin.left},${internalMargin.top})`}>\n {render}\n {/* <ActivePoint/> @todo */}\n </g>\n </g>\n </svg>\n ) : null}\n </StyledSVGWrapper>\n );\n};\n", "import * as React from 'react';\nexport { React };\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import React, { useContext, useMemo, useCallback } from 'react';\nimport { StyledSVGWrapper } from '../styles';\n\nimport { ChartContext } from '../ChartContext';\nimport { useKeyboardNavigation } from '../config/useKeyboardNavigation';\nimport { Legend } from './Legend/Legend';\nimport { Labels } from './Labels';\nimport { BlurMask } from './Scroller/BlurMask';\nimport { ClipPaths } from './ClipPaths';\nimport { ScrollableContainerX } from './Scroller/ScrollableContainerX';\nimport { ScrollableContainerY } from './Scroller/ScrollableContainerY';\n\nimport { AxisBottom } from './Axis/AxisBottom';\nimport { AxisRight } from './Axis/AxisRight';\nimport { AxisLeft } from './Axis/AxisLeft';\nimport { SeriesFactory } from './SeriesFactory';\nimport { Scrapper } from './Scrapper/Scrapper';\nimport { VerticalScrapper } from './Scrapper/VerticalScrapper';\nimport { Controllers } from './Scroller/Controllers';\nexport const ChartContainer = () => {\n const {\n props: { y2Axis, yScroll, xScroll, scrapper, xAxis, width: userWidth },\n activePoint,\n internalMargin,\n setScrapperPosY,\n setScrapperPosX,\n setContainerRef,\n svgRef,\n isGrabbed,\n setIsGrabbed,\n startPosition,\n innerWidth,\n innerHeight,\n setActivePoint,\n setXScrollbarPosition,\n xScrollbarPosition,\n containerRatio,\n lastPosition,\n setIsScrollbarVisible,\n currentData,\n setStartPosition,\n width,\n height,\n } = useContext(ChartContext);\n\n // const xScroll = xAxis.advanced?.pointSpacing?.value > 1;\n // const yScroll = yAxis.advanced?.pointSpacing?.value > 1;\n const { onInputKeyDown, handleOnKeyUp, handleOnBlur, handleOnFocus } = useKeyboardNavigation();\n\n const onMouseEnterHandler = useCallback(() => {\n setIsScrollbarVisible(true);\n setActivePoint(null);\n }, [setActivePoint, setIsScrollbarVisible]);\n const onMouseLeaveHandler = useCallback(() => {\n setScrapperPosY('');\n setScrapperPosX('');\n setIsScrollbarVisible(false);\n setIsGrabbed(false);\n }, [setIsGrabbed, setIsScrollbarVisible, setScrapperPosX, setScrapperPosY]);\n\n const handleOnTouchStart: React.TouchEventHandler = useCallback(\n (e) => {\n e.stopPropagation();\n setScrapperPosX('');\n setIsGrabbed(true);\n setStartPosition(e.touches[0].clientX);\n e.preventDefault();\n },\n [setIsGrabbed, setScrapperPosX, setStartPosition],\n );\n const handleOnTouchEnd = useCallback(() => {\n lastPosition.current = xScrollbarPosition;\n setIsGrabbed(false);\n }, [setIsGrabbed, xScrollbarPosition, lastPosition]);\n const handleMouseMove: React.MouseEventHandler = useCallback(\n (e) => {\n if (!isGrabbed) return;\n e.preventDefault();\n const clientX = e.clientX ?? e.touches[0].clientX;\n const clientY = e.clientY ?? e.touches[0].clientY;\n\n setActivePoint(null);\n if (xScroll) {\n const newPosition = lastPosition?.current + clientX - startPosition;\n if (newPosition < 0) setXScrollbarPosition(0);\n else if (newPosition > innerWidth - innerWidth / containerRatio)\n setXScrollbarPosition(innerWidth - innerWidth / containerRatio);\n else setXScrollbarPosition(newPosition);\n }\n if (yScroll) {\n const newPosition = lastPosition?.current + clientY - startPosition;\n\n if (newPosition < 0) setXScrollbarPosition(0);\n else if (newPosition > innerHeight - innerHeight / containerRatio)\n setXScrollbarPosition(innerHeight - innerHeight / containerRatio);\n else setXScrollbarPosition(newPosition);\n }\n },\n [\n isGrabbed,\n setActivePoint,\n xScroll,\n yScroll,\n lastPosition,\n startPosition,\n setXScrollbarPosition,\n innerWidth,\n containerRatio,\n innerHeight,\n ],\n );\n const handleMouseUp = useCallback(() => {\n lastPosition.current = xScrollbarPosition;\n setIsGrabbed(false);\n }, [lastPosition, setIsGrabbed, xScrollbarPosition]);\n\n const render = useMemo(() => {\n if (currentData.length === 0) return null;\n if (xScroll || xAxis.advanced?.pointSpacing?.value > 1) {\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisLeft />\n <ScrollableContainerX />\n </>\n );\n }\n if (yScroll) {\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisBottom />\n <ScrollableContainerY />\n </>\n );\n }\n return (\n <>\n {y2Axis ? <AxisRight /> : null}\n <AxisLeft />\n <AxisBottom />\n <SeriesFactory />\n {scrapper?.type === 'horizontal' ? <Scrapper /> : null}\n {scrapper?.type === 'vertical' ? <VerticalScrapper /> : null}\n </>\n );\n }, [currentData.length, scrapper?.type, xAxis.advanced?.pointSpacing?.value, xScroll, y2Axis, yScroll]);\n return (\n <StyledSVGWrapper\n ref={setContainerRef}\n onKeyDown={onInputKeyDown}\n onKeyUp={handleOnKeyUp}\n tabIndex={activePoint ? -1 : 0}\n onBlur={handleOnBlur}\n onFocus={handleOnFocus}\n onTouchMove={handleMouseMove}\n onTouchStart={handleOnTouchStart}\n onTouchEnd={handleOnTouchEnd}\n onMouseEnter={onMouseEnterHandler}\n onMouseLeave={onMouseLeaveHandler}\n onMouseMove={handleMouseMove}\n onMouseUp={handleMouseUp}\n onMouseDown={(e) => e.preventDefault()}\n isGrabbed={isGrabbed}\n style={{ width: userWidth, height }}\n >\n {width !== 0 ? (\n <svg ref={svgRef} width={width} height={height}>\n {/* this clipaths for animations and focus ring.. need to give a deeper look */}\n <ClipPaths />\n <BlurMask />\n <g>\n <g>\n <Controllers />\n <Legend />\n <Labels />\n </g>\n <g className=\"container\" transform={`translate(${internalMargin.left},${internalMargin.top})`}>\n {render}\n {/* <ActivePoint/> @todo */}\n </g>\n </g>\n </svg>\n ) : null}\n </StyledSVGWrapper>\n );\n};\n", "import * as React from 'react';\nexport { React };\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -29,22 +29,7 @@ __export(Label_exports, {
29
29
  module.exports = __toCommonJS(Label_exports);
30
30
  var React = __toESM(require("react"));
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
- var import_react = require("react");
33
- var import_ChartContext = require("../../ChartContext");
34
- var import_RightLabel = require("./RightLabel");
35
- var import_LeftLabel = require("./LeftLabel");
36
- var import_BottomLabel = require("./BottomLabel");
37
- const Label = () => {
38
- const {
39
- props: { xAxis, yAxis, y2Axis }
40
- } = (0, import_react.useContext)(import_ChartContext.ChartContext);
41
- return (0, import_react.useMemo)(
42
- () => /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("g", { children: [
43
- y2Axis?.label ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_RightLabel.RightLabel, {}) : "",
44
- yAxis?.label ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_LeftLabel.LeftLabel, {}) : "",
45
- xAxis?.label ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_BottomLabel.BottomLabel, {}) : ""
46
- ] }),
47
- [xAxis?.label, y2Axis?.label, yAxis?.label]
48
- );
49
- };
32
+ var import_react = __toESM(require("react"));
33
+ var import_styles = require("../../styles");
34
+ const Label = import_react.default.memo(({ innerRef, x, y, label, rotateDegrees = 0 }) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { ref: innerRef, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("g", { transform: `translate(${x},${y}) rotate(${rotateDegrees})`, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_styles.StyledAxisLabel, { className: "axis-label", textAnchor: "middle", children: label }) }) }));
50
35
  //# sourceMappingURL=Label.js.map