@economic/taco 2.56.0 → 2.57.0-charts.1

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.
package/dist/taco.cjs CHANGED
@@ -19628,8 +19628,8 @@ function mixValues(target, follow, lead, progress2, shouldCrossfadeOpacity, isOn
19628
19628
  }
19629
19629
  for (var i3 = 0; i3 < numBorders; i3++) {
19630
19630
  var borderLabel = "border".concat(borders[i3], "Radius");
19631
- var followRadius = getRadius(follow, borderLabel);
19632
- var leadRadius = getRadius(lead, borderLabel);
19631
+ var followRadius = getRadius$1(follow, borderLabel);
19632
+ var leadRadius = getRadius$1(lead, borderLabel);
19633
19633
  if (followRadius === void 0 && leadRadius === void 0)
19634
19634
  continue;
19635
19635
  followRadius || (followRadius = 0);
@@ -19648,7 +19648,7 @@ function mixValues(target, follow, lead, progress2, shouldCrossfadeOpacity, isOn
19648
19648
  target.rotate = mix(follow.rotate || 0, lead.rotate || 0, progress2);
19649
19649
  }
19650
19650
  }
19651
- function getRadius(values, radiusName) {
19651
+ function getRadius$1(values, radiusName) {
19652
19652
  var _a;
19653
19653
  return (_a = values[radiusName]) !== null && _a !== void 0 ? _a : values.borderRadius;
19654
19654
  }
@@ -61563,7 +61563,7 @@ var symbolFactories = {
61563
61563
  symbolTriangle,
61564
61564
  symbolWye
61565
61565
  };
61566
- var RADIAN$2 = Math.PI / 180;
61566
+ var RADIAN$3 = Math.PI / 180;
61567
61567
  var getSymbolFactory = function getSymbolFactory2(type) {
61568
61568
  var name = "symbol".concat(upperFirst(type));
61569
61569
  return symbolFactories[name] || symbolCircle;
@@ -61580,7 +61580,7 @@ var calculateAreaSize = function calculateAreaSize2(size2, sizeType, type) {
61580
61580
  case "square":
61581
61581
  return size2 * size2;
61582
61582
  case "star": {
61583
- var angle = 18 * RADIAN$2;
61583
+ var angle = 18 * RADIAN$3;
61584
61584
  return 1.25 * size2 * size2 * (Math.tan(angle) - Math.tan(angle * 2) * Math.pow(Math.tan(angle), 2));
61585
61585
  }
61586
61586
  case "triangle":
@@ -64052,7 +64052,7 @@ function _iterableToArrayLimit$b(r2, l2) {
64052
64052
  function _arrayWithHoles$c(arr) {
64053
64053
  if (Array.isArray(arr)) return arr;
64054
64054
  }
64055
- var ResponsiveContainer$1 = /* @__PURE__ */ React.forwardRef(function(_ref, ref) {
64055
+ var ResponsiveContainer = /* @__PURE__ */ React.forwardRef(function(_ref, ref) {
64056
64056
  var aspect = _ref.aspect, _ref$initialDimension = _ref.initialDimension, initialDimension = _ref$initialDimension === void 0 ? {
64057
64057
  width: -1,
64058
64058
  height: -1
@@ -69190,7 +69190,7 @@ function _toPrimitive$y(t3, r2) {
69190
69190
  }
69191
69191
  return ("string" === r2 ? String : Number)(t3);
69192
69192
  }
69193
- var getLegendProps$1 = function getLegendProps(_ref) {
69193
+ var getLegendProps = function getLegendProps2(_ref) {
69194
69194
  var children = _ref.children, formattedGraphicalItems = _ref.formattedGraphicalItems, legendWidth = _ref.legendWidth, legendContent = _ref.legendContent;
69195
69195
  var legendItem = findChildByType(children, Legend$2);
69196
69196
  if (!legendItem) {
@@ -69533,7 +69533,7 @@ var getBarPosition = function getBarPosition2(_ref3) {
69533
69533
  var appendOffsetOfLegend = function appendOffsetOfLegend2(offset2, _unused, props, legendBox) {
69534
69534
  var children = props.children, width = props.width, margin = props.margin;
69535
69535
  var legendWidth = width - (margin.left || 0) - (margin.right || 0);
69536
- var legendProps = getLegendProps$1({
69536
+ var legendProps = getLegendProps({
69537
69537
  children,
69538
69538
  legendWidth
69539
69539
  });
@@ -70207,14 +70207,14 @@ function _iterableToArrayLimit$6(r2, l2) {
70207
70207
  function _arrayWithHoles$7(arr) {
70208
70208
  if (Array.isArray(arr)) return arr;
70209
70209
  }
70210
- var RADIAN$1 = Math.PI / 180;
70210
+ var RADIAN$2 = Math.PI / 180;
70211
70211
  var radianToDegree = function radianToDegree2(angleInRadian) {
70212
70212
  return angleInRadian * 180 / Math.PI;
70213
70213
  };
70214
70214
  var polarToCartesian = function polarToCartesian2(cx, cy, radius, angle) {
70215
70215
  return {
70216
- x: cx + Math.cos(-RADIAN$1 * angle) * radius,
70217
- y: cy + Math.sin(-RADIAN$1 * angle) * radius
70216
+ x: cx + Math.cos(-RADIAN$2 * angle) * radius,
70217
+ y: cy + Math.sin(-RADIAN$2 * angle) * radius
70218
70218
  };
70219
70219
  };
70220
70220
  var getMaxRadius = function getMaxRadius2(width, height) {
@@ -70722,7 +70722,7 @@ var getAttrsOfCartesianLabel = function getAttrsOfCartesianLabel2(props) {
70722
70722
  var isPolar = function isPolar2(viewBox) {
70723
70723
  return "cx" in viewBox && isNumber(viewBox.cx);
70724
70724
  };
70725
- function Label(_ref4) {
70725
+ function Label$1(_ref4) {
70726
70726
  var _ref4$offset = _ref4.offset, offset2 = _ref4$offset === void 0 ? 5 : _ref4$offset, restProps = _objectWithoutProperties$d(_ref4, _excluded$d);
70727
70727
  var props = _objectSpread$s({
70728
70728
  offset: offset2
@@ -70755,7 +70755,7 @@ function Label(_ref4) {
70755
70755
  breakAll: textBreakAll
70756
70756
  }), label);
70757
70757
  }
70758
- Label.displayName = "Label";
70758
+ Label$1.displayName = "Label";
70759
70759
  var parseViewBox = function parseViewBox2(props) {
70760
70760
  var cx = props.cx, cy = props.cy, angle = props.angle, startAngle = props.startAngle, endAngle = props.endAngle, r2 = props.r, radius = props.radius, innerRadius = props.innerRadius, outerRadius = props.outerRadius, x3 = props.x, y4 = props.y, top = props.top, left = props.left, width = props.width, height = props.height, clockWise = props.clockWise, labelViewBox = props.labelViewBox;
70761
70761
  if (labelViewBox) {
@@ -70808,40 +70808,40 @@ var parseLabel = function parseLabel2(label, viewBox) {
70808
70808
  return null;
70809
70809
  }
70810
70810
  if (label === true) {
70811
- return /* @__PURE__ */ React.createElement(Label, {
70811
+ return /* @__PURE__ */ React.createElement(Label$1, {
70812
70812
  key: "label-implicit",
70813
70813
  viewBox
70814
70814
  });
70815
70815
  }
70816
70816
  if (isNumOrStr(label)) {
70817
- return /* @__PURE__ */ React.createElement(Label, {
70817
+ return /* @__PURE__ */ React.createElement(Label$1, {
70818
70818
  key: "label-implicit",
70819
70819
  viewBox,
70820
70820
  value: label
70821
70821
  });
70822
70822
  }
70823
70823
  if (/* @__PURE__ */ React.isValidElement(label)) {
70824
- if (label.type === Label) {
70824
+ if (label.type === Label$1) {
70825
70825
  return /* @__PURE__ */ React.cloneElement(label, {
70826
70826
  key: "label-implicit",
70827
70827
  viewBox
70828
70828
  });
70829
70829
  }
70830
- return /* @__PURE__ */ React.createElement(Label, {
70830
+ return /* @__PURE__ */ React.createElement(Label$1, {
70831
70831
  key: "label-implicit",
70832
70832
  content: label,
70833
70833
  viewBox
70834
70834
  });
70835
70835
  }
70836
70836
  if (isFunction(label)) {
70837
- return /* @__PURE__ */ React.createElement(Label, {
70837
+ return /* @__PURE__ */ React.createElement(Label$1, {
70838
70838
  key: "label-implicit",
70839
70839
  content: label,
70840
70840
  viewBox
70841
70841
  });
70842
70842
  }
70843
70843
  if (isObject(label)) {
70844
- return /* @__PURE__ */ React.createElement(Label, _extends$o({
70844
+ return /* @__PURE__ */ React.createElement(Label$1, _extends$o({
70845
70845
  viewBox
70846
70846
  }, label, {
70847
70847
  key: "label-implicit"
@@ -70856,7 +70856,7 @@ var renderCallByParent$1 = function renderCallByParent(parentProps, viewBox) {
70856
70856
  }
70857
70857
  var children = parentProps.children;
70858
70858
  var parentViewBox = parseViewBox(parentProps);
70859
- var explicitChildren = findAllByType(children, Label).map(function(child, index2) {
70859
+ var explicitChildren = findAllByType(children, Label$1).map(function(child, index2) {
70860
70860
  return /* @__PURE__ */ React.cloneElement(child, {
70861
70861
  viewBox: viewBox || parentViewBox,
70862
70862
  // eslint-disable-next-line react/no-array-index-key
@@ -70869,8 +70869,8 @@ var renderCallByParent$1 = function renderCallByParent(parentProps, viewBox) {
70869
70869
  var implicitLabel = parseLabel(parentProps.label, viewBox || parentViewBox);
70870
70870
  return [implicitLabel].concat(_toConsumableArray$8(explicitChildren));
70871
70871
  };
70872
- Label.parseViewBox = parseViewBox;
70873
- Label.renderCallByParent = renderCallByParent$1;
70872
+ Label$1.parseViewBox = parseViewBox;
70873
+ Label$1.renderCallByParent = renderCallByParent$1;
70874
70874
  var lastExports = requireLast();
70875
70875
  const last = /* @__PURE__ */ getDefaultExportFromCjs(lastExports);
70876
70876
  function _typeof$w(o2) {
@@ -71007,11 +71007,11 @@ function LabelList(_ref) {
71007
71007
  var idProps = isNil(id2) ? {} : {
71008
71008
  id: "".concat(id2, "-").concat(index2)
71009
71009
  };
71010
- return /* @__PURE__ */ React.createElement(Label, _extends$n({}, filterProps(entry, true), others, idProps, {
71010
+ return /* @__PURE__ */ React.createElement(Label$1, _extends$n({}, filterProps(entry, true), others, idProps, {
71011
71011
  parentViewBox: entry.parentViewBox,
71012
71012
  value,
71013
71013
  textBreakAll,
71014
- viewBox: Label.parseViewBox(isNil(clockWise) ? entry : _objectSpread$r(_objectSpread$r({}, entry), {}, {
71014
+ viewBox: Label$1.parseViewBox(isNil(clockWise) ? entry : _objectSpread$r(_objectSpread$r({}, entry), {}, {
71015
71015
  clockWise
71016
71016
  })),
71017
71017
  key: "label-".concat(index2),
@@ -71140,12 +71140,12 @@ var getDeltaAngle2 = function getDeltaAngle3(startAngle, endAngle) {
71140
71140
  var getTangentCircle = function getTangentCircle2(_ref) {
71141
71141
  var cx = _ref.cx, cy = _ref.cy, radius = _ref.radius, angle = _ref.angle, sign2 = _ref.sign, isExternal = _ref.isExternal, cornerRadius = _ref.cornerRadius, cornerIsExternal = _ref.cornerIsExternal;
71142
71142
  var centerRadius = cornerRadius * (isExternal ? 1 : -1) + radius;
71143
- var theta = Math.asin(cornerRadius / centerRadius) / RADIAN$1;
71143
+ var theta = Math.asin(cornerRadius / centerRadius) / RADIAN$2;
71144
71144
  var centerAngle = cornerIsExternal ? angle : angle + sign2 * theta;
71145
71145
  var center = polarToCartesian(cx, cy, centerRadius, centerAngle);
71146
71146
  var circleTangency = polarToCartesian(cx, cy, radius, centerAngle);
71147
71147
  var lineTangencyAngle = cornerIsExternal ? angle - sign2 * theta : angle;
71148
- var lineTangency = polarToCartesian(cx, cy, centerRadius * Math.cos(theta * RADIAN$1), lineTangencyAngle);
71148
+ var lineTangency = polarToCartesian(cx, cy, centerRadius * Math.cos(theta * RADIAN$2), lineTangencyAngle);
71149
71149
  return {
71150
71150
  center,
71151
71151
  circleTangency,
@@ -73725,7 +73725,7 @@ var PolarRadiusAxis = /* @__PURE__ */ function(_PureComponent) {
73725
73725
  }
73726
73726
  return /* @__PURE__ */ React.createElement(Layer, {
73727
73727
  className: clsx("recharts-polar-radius-axis", this.props.className)
73728
- }, axisLine && this.renderAxisLine(), tick && this.renderTicks(), Label.renderCallByParent(this.props, this.getViewBox()));
73728
+ }, axisLine && this.renderAxisLine(), tick && this.renderTicks(), Label$1.renderCallByParent(this.props, this.getViewBox()));
73729
73729
  }
73730
73730
  }], [{
73731
73731
  key: "renderTickItem",
@@ -73895,7 +73895,7 @@ function _toPrimitive$l(t3, r2) {
73895
73895
  }
73896
73896
  return String(t3);
73897
73897
  }
73898
- var RADIAN = Math.PI / 180;
73898
+ var RADIAN$1 = Math.PI / 180;
73899
73899
  var eps = 1e-5;
73900
73900
  var PolarAngleAxis = /* @__PURE__ */ function(_PureComponent) {
73901
73901
  function PolarAngleAxis2() {
@@ -73935,7 +73935,7 @@ var PolarAngleAxis = /* @__PURE__ */ function(_PureComponent) {
73935
73935
  key: "getTickTextAnchor",
73936
73936
  value: function getTickTextAnchor(data) {
73937
73937
  var orientation = this.props.orientation;
73938
- var cos2 = Math.cos(-data.coordinate * RADIAN);
73938
+ var cos2 = Math.cos(-data.coordinate * RADIAN$1);
73939
73939
  var textAnchor;
73940
73940
  if (cos2 > eps) {
73941
73941
  textAnchor = orientation === "outer" ? "start" : "end";
@@ -74854,7 +74854,7 @@ var Pie = /* @__PURE__ */ function(_PureComponent) {
74854
74854
  ref: function ref(_ref3) {
74855
74855
  _this5.pieRef = _ref3;
74856
74856
  }
74857
- }, this.renderSectors(), label && this.renderLabels(sectors), Label.renderCallByParent(this.props, null, false), (!isAnimationActive || isAnimationFinished) && LabelList.renderCallByParent(this.props, sectors, false));
74857
+ }, this.renderSectors(), label && this.renderLabels(sectors), Label$1.renderCallByParent(this.props, null, false), (!isAnimationActive || isAnimationFinished) && LabelList.renderCallByParent(this.props, sectors, false));
74858
74858
  }
74859
74859
  }], [{
74860
74860
  key: "getDerivedStateFromProps",
@@ -77306,7 +77306,7 @@ function ReferenceLineImpl(props) {
77306
77306
  });
77307
77307
  return /* @__PURE__ */ React.createElement(Layer, {
77308
77308
  className: clsx("recharts-reference-line", className)
77309
- }, renderLine(shape, lineProps), Label.renderCallByParent(props, rectWithCoords({
77309
+ }, renderLine(shape, lineProps), Label$1.renderCallByParent(props, rectWithCoords({
77310
77310
  x1,
77311
77311
  y1,
77312
77312
  x2: x22,
@@ -77519,7 +77519,7 @@ var ReferenceDot = /* @__PURE__ */ function(_React$Component) {
77519
77519
  });
77520
77520
  return /* @__PURE__ */ React.createElement(Layer, {
77521
77521
  className: clsx("recharts-reference-dot", className)
77522
- }, ReferenceDot2.renderDot(shape, dotProps), Label.renderCallByParent(this.props, {
77522
+ }, ReferenceDot2.renderDot(shape, dotProps), Label$1.renderCallByParent(this.props, {
77523
77523
  x: cx - r2,
77524
77524
  y: cy - r2,
77525
77525
  width: 2 * r2,
@@ -77744,7 +77744,7 @@ var ReferenceArea = /* @__PURE__ */ function(_React$Component) {
77744
77744
  className: clsx("recharts-reference-area", className)
77745
77745
  }, ReferenceArea2.renderRect(shape, _objectSpread$7(_objectSpread$7({
77746
77746
  clipPath
77747
- }, filterProps(this.props, true)), rect)), Label.renderCallByParent(this.props, rect));
77747
+ }, filterProps(this.props, true)), rect)), Label$1.renderCallByParent(this.props, rect));
77748
77748
  }
77749
77749
  }]);
77750
77750
  }(React.Component);
@@ -78427,7 +78427,7 @@ var CartesianAxis = /* @__PURE__ */ function(_Component) {
78427
78427
  ref: function ref(_ref2) {
78428
78428
  _this3.layerReference = _ref2;
78429
78429
  }
78430
- }, axisLine && this.renderAxisLine(), this.renderTicks(finalTicks, this.state.fontSize, this.state.letterSpacing), Label.renderCallByParent(this.props));
78430
+ }, axisLine && this.renderAxisLine(), this.renderTicks(finalTicks, this.state.fontSize, this.state.letterSpacing), Label$1.renderCallByParent(this.props));
78431
78431
  }
78432
78432
  }], [{
78433
78433
  key: "renderTickItem",
@@ -81960,7 +81960,7 @@ var generateCategoricalChart = function generateCategoricalChart2(_ref6) {
81960
81960
  var _this$props2 = _this.props, children = _this$props2.children, width = _this$props2.width, height = _this$props2.height;
81961
81961
  var margin = _this.props.margin || {};
81962
81962
  var legendWidth = width - (margin.left || 0) - (margin.right || 0);
81963
- var props = getLegendProps$1({
81963
+ var props = getLegendProps({
81964
81964
  children,
81965
81965
  formattedGraphicalItems,
81966
81966
  legendWidth,
@@ -82725,7 +82725,7 @@ var BarChart$1 = generateCategoricalChart({
82725
82725
  }],
82726
82726
  formatAxisMap: formatAxisMap2
82727
82727
  });
82728
- var PieChart = generateCategoricalChart({
82728
+ var PieChart$1 = generateCategoricalChart({
82729
82729
  chartName: "PieChart",
82730
82730
  GraphicalChild: Pie,
82731
82731
  validateTooltipEventTypes: ["item"],
@@ -82761,6 +82761,79 @@ var AreaChart$1 = generateCategoricalChart({
82761
82761
  }],
82762
82762
  formatAxisMap: formatAxisMap2
82763
82763
  });
82764
+ function getAxisProps(scale2, tickFormatter, dataKey) {
82765
+ return {
82766
+ axisLine: false,
82767
+ dataKey,
82768
+ fontSize: 11,
82769
+ scale: scale2,
82770
+ tickLine: false,
82771
+ tickMargin: 8,
82772
+ tickFormatter
82773
+ };
82774
+ }
82775
+ function ChartContainer(props) {
82776
+ const { onSetWidth: handleSetWidth, ...attributes } = props;
82777
+ const ref = React.useRef(null);
82778
+ React.useLayoutEffect(() => {
82779
+ if (ref.current && typeof handleSetWidth === "function") {
82780
+ const rect = ref.current.getBoundingClientRect();
82781
+ handleSetWidth(rect.width);
82782
+ }
82783
+ }, [ref]);
82784
+ const className = clsx("flex justify-center mx-auto", attributes.className);
82785
+ return /* @__PURE__ */ React.createElement("div", { ...attributes, className, ref }, /* @__PURE__ */ React.createElement(ResponsiveContainer, null, props.children));
82786
+ }
82787
+ function Tooltip(props) {
82788
+ const { active, payload = [], style, title } = props;
82789
+ if (active && payload.length) {
82790
+ return /* @__PURE__ */ React.createElement("div", { className: "border-grey-300 z-20 flex flex-col gap-y-1 rounded-md border bg-white px-2 py-1.5 text-xs shadow-sm" }, title ? /* @__PURE__ */ React.createElement("span", { className: "font-bold" }, title) : null, /* @__PURE__ */ React.createElement("dl", { className: "m-0 grid grid-cols-[max-content_max-content] gap-x-4 gap-y-0.5", style }, payload.map((entry, index2) => {
82791
+ const color2 = entry.color ?? entry.payload.color;
82792
+ const formatter = entry.formatter ?? entry.payload.formatter;
82793
+ const unit2 = entry.unit ?? entry.payload.unit;
82794
+ return /* @__PURE__ */ React.createElement(React.Fragment, { key: `${entry.name}-${index2}` }, /* @__PURE__ */ React.createElement("dt", { className: "text-grey-700 mb-0 flex items-center gap-1 font-normal" }, /* @__PURE__ */ React.createElement("span", { className: "-mt-px h-2.5 w-2.5 rounded-sm", style: { background: color2 } }), entry.name), /* @__PURE__ */ React.createElement("dd", { className: "mb-0 text-right font-bold tabular-nums text-black" }, (formatter == null ? void 0 : formatter(entry.value ?? "", entry.name ?? "", entry, index2, entry.payload)) ?? entry.value, " ", unit2 ? /* @__PURE__ */ React.createElement("span", { className: "text-grey-700" }, unit2) : null));
82795
+ })));
82796
+ }
82797
+ return null;
82798
+ }
82799
+ function Legend$1(props) {
82800
+ const { hoverIndex, items, onHover: handleHover, onToggle: handleToggle } = props;
82801
+ const handleMouseEnter = (item, index2) => {
82802
+ if (item.isHidden) {
82803
+ return;
82804
+ }
82805
+ handleHover(index2);
82806
+ };
82807
+ const handleMouseLeave = () => handleHover(void 0);
82808
+ const handleClick = (item) => {
82809
+ if (!item.isHidden) {
82810
+ handleHover(void 0);
82811
+ }
82812
+ handleToggle(item.dataKey);
82813
+ };
82814
+ const moreButton = (moreButtonText) => /* @__PURE__ */ React.createElement(Button$4, { appearance: "transparent", className: "text-grey-700 !h-5 !min-h-[1.25rem] !px-1.5 text-xs" }, moreButtonText);
82815
+ return /* @__PURE__ */ React.createElement(OverflowGroup, { className: "w-full gap-x-1", moreButton }, items.map((item, index2) => {
82816
+ const className = clsx("mr-1 flex h-3 w-3 rounded-sm", {
82817
+ [`bg-${item.color}`]: !item.isHidden,
82818
+ border: item.isHidden
82819
+ });
82820
+ return /* @__PURE__ */ React.createElement(
82821
+ "button",
82822
+ {
82823
+ key: item.label,
82824
+ className: "hover:bg-grey-200 focus-visible:yt-focus flex items-center rounded px-1 !text-xs",
82825
+ onClick: (event) => {
82826
+ event == null ? void 0 : event.preventDefault();
82827
+ handleClick(item);
82828
+ },
82829
+ onMouseEnter: () => handleMouseEnter(item, index2),
82830
+ onMouseLeave: () => handleMouseLeave()
82831
+ },
82832
+ /* @__PURE__ */ React.createElement("span", { className }, hoverIndex === index2 ? /* @__PURE__ */ React.createElement(Icon$1, { name: "tick-bold", className: clsx("!h-full !w-full", { "text-white": !item.isHidden }) }) : null),
82833
+ item.label
82834
+ );
82835
+ }));
82836
+ }
82764
82837
  const THEME_COLORS = {
82765
82838
  transparent: "transparent",
82766
82839
  current: "currentColor",
@@ -82896,266 +82969,291 @@ const mapColor = (palette, prefix2 = "") => {
82896
82969
  }, {});
82897
82970
  };
82898
82971
  const colors = mapColor(THEME_COLORS);
82899
- const getThemeColor = (color2) => colors[color2];
82900
- function Legend$1(props) {
82901
- const { activeIndex, onMouseEnter, onMouseLeave, onClick, payload, layout, activeItems } = props;
82902
- const [hoverIndex, setHoverIndex] = React.useState(null);
82903
- const handleMouseEnter = (entry, index2) => {
82904
- setHoverIndex(index2);
82905
- if (activeItems[entry.dataKey]) onMouseEnter(entry, index2);
82906
- };
82907
- const handleMouseLeave = () => {
82908
- onMouseLeave();
82909
- setHoverIndex(null);
82910
- };
82911
- const moreButton = (moreButtonText) => /* @__PURE__ */ React.createElement(Button$4, { appearance: "transparent", className: "text-grey-700" }, moreButtonText);
82912
- return /* @__PURE__ */ React.createElement("div", { className: "mx-auto w-auto max-w-full overflow-hidden" }, /* @__PURE__ */ React.createElement("div", { className: clsx("mb-0 ml-0 flex justify-center", { "flex-col": layout === "vertical" }) }, /* @__PURE__ */ React.createElement(OverflowGroup, { className: "w-full items-center py-1", moreButton }, payload.map((entry, index2) => /* @__PURE__ */ React.createElement(
82913
- "span",
82914
- {
82915
- key: `${entry.dataKey}-${index2}`,
82916
- className: clsx(" hover:bg-grey-100 cursor-pointer px-[8px] py-[2px] hover:rounded-[4px]", {
82917
- "bg-grey-100 rounded": activeIndex === index2
82918
- }),
82919
- onMouseEnter: () => handleMouseEnter(entry, index2),
82920
- onMouseLeave: handleMouseLeave,
82921
- onClick: onClick ? () => onClick(entry) : void 0
82922
- },
82923
- /* @__PURE__ */ React.createElement("span", { className: "text-grey-700 flex items-center gap-[4px]" }, /* @__PURE__ */ React.createElement(
82924
- "span",
82925
- {
82926
- className: clsx("-mt-px ml-1 flex h-3 w-3 rounded-sm", {
82927
- "border-grey-300 border !bg-white": !activeItems[entry.dataKey]
82928
- }),
82929
- style: { backgroundColor: entry.color }
82930
- },
82931
- hoverIndex === index2 && activeItems[entry.dataKey] && /* @__PURE__ */ React.createElement(Icon$1, { name: "tick-bold", className: "!h-full !w-full text-white" })
82932
- ), entry.value)
82933
- )))));
82934
- }
82935
- const Tooltip = ({ active, formatter, payload, style, singlePieDonutChart }) => {
82936
- const getColor = (entry) => {
82937
- if (singlePieDonutChart) {
82938
- return getThemeColor(entry.payload.color);
82972
+ const getThemeColor = (color2, def = "") => colors[color2 ?? def];
82973
+ const getInverseThemeColor = (themeColor) => {
82974
+ const [color2, number2] = String(themeColor).split("-");
82975
+ const shade = Number(number2);
82976
+ if (shade) {
82977
+ if (shade > 500) {
82978
+ return getThemeColor(`${color2}-100`);
82979
+ } else {
82980
+ if (shade === 500 && (color2 === "red" || color2 === "blue" || color2 === "brown" || color2 === "purple" || color2 === "green")) {
82981
+ return "white";
82982
+ }
82983
+ return getThemeColor(`${color2}-900`);
82939
82984
  }
82940
- return entry.color ?? entry.payload.fill ?? "blue-500";
82941
- };
82942
- if (active && payload && payload.length) {
82943
- return /* @__PURE__ */ React.createElement(
82944
- "dl",
82945
- {
82946
- className: "z-20 grid grid-cols-[max-content_max-content] gap-x-4 rounded-md bg-white p-4 text-xs shadow-[0px_0px_1px_rgba(0,0,0,0.1),_0px_6px_18px_rgba(47,51,68,0.2)]",
82947
- style
82948
- },
82949
- payload.map((entry, index2) => /* @__PURE__ */ React.createElement(React.Fragment, { key: `${entry.name}-${index2}` }, /* @__PURE__ */ React.createElement(
82950
- "dt",
82951
- { className: "text-grey-700 mb-0 flex items-center gap-1 font-normal" },
82952
- /* @__PURE__ */ React.createElement("span", { className: "-mt-px h-2.5 w-2.5 rounded-sm", style: { background: getColor(entry) } }),
82953
- // We use entry.payload.label because the payload structure differs between a Donut chart with a single pie
82954
- // and one with multiple pies.
82955
- singlePieDonutChart ? entry.payload.label : entry.name
82956
- ), /* @__PURE__ */ React.createElement("dd", { className: "mb-0 text-right font-bold text-black " }, formatter ? formatter(entry.value) : entry.value)))
82957
- );
82958
82985
  }
82959
- return null;
82986
+ return color2 === "black" ? "white" : "black";
82960
82987
  };
82961
- const getCartesianGridProps = () => ({
82962
- vertical: false
82963
- });
82964
- const getXAxisProps = (props) => ({
82965
- axisLine: false,
82966
- dataKey: props.accessor,
82967
- fontSize: 12,
82968
- scale: props.xAxisScale,
82969
- tickLine: false,
82970
- tickFormatter: props.xAxisTickFormat
82971
- });
82972
- const getYAxisProps = (props) => ({
82973
- axisLine: false,
82974
- fontSize: 12,
82975
- scale: props.yAxisScale,
82976
- tickLine: false,
82977
- tickFormatter: props.yAxisTickFormat
82978
- });
82979
- const getLegendProps2 = (props) => ({
82980
- content: /* @__PURE__ */ React.createElement(Legend$1, { ...props })
82981
- });
82982
- const getTooltipProps = (props = void 0) => ({
82983
- content: /* @__PURE__ */ React.createElement(Tooltip, { ...props }),
82984
- wrapperStyle: { outline: "none" }
82985
- });
82986
- const ResponsiveContainer = (props) => /* @__PURE__ */ React.createElement(ResponsiveContainer$1, { className: "!h-[calc(100%-1px)] !w-[calc(100%-1px)]", ...props });
82987
- const Area = (_) => null;
82988
- const AreaChart = function AreaChart2(externalProps) {
82989
- const { children, data, formatter, ...props } = externalProps;
82990
- const [hoveredArea, setHoveredArea] = React.useState(null);
82991
- const [activeAreas, setActiveAreas] = React.useState(() => {
82992
- const areas = {};
82993
- React.Children.forEach(children, (child) => {
82994
- areas[child.props.accessor] = true;
82988
+ function useChart(children, options) {
82989
+ const [activeIndex, setActiveIndex] = React.useState();
82990
+ const [hiddenItems, toggleItem] = useChartDataHiddenState();
82991
+ const localization = useLocalization();
82992
+ const defaultFormatter2 = (value) => new Intl.NumberFormat(localization.locale).format(value);
82993
+ const { items, shapes } = React.useMemo(() => {
82994
+ const items2 = React.Children.toArray(children).filter((child) => React.isValidElement(child)).map((child) => {
82995
+ const dataKey = child.props.dataKey ?? child.props.label;
82996
+ return {
82997
+ ...child.props,
82998
+ dataKey,
82999
+ formatter: child.props.formatter ?? (options == null ? void 0 : options.formatter) ?? defaultFormatter2,
83000
+ isHidden: !!hiddenItems[dataKey],
83001
+ unit: child.props.unit ?? (options == null ? void 0 : options.unit)
83002
+ };
82995
83003
  });
82996
- return areas;
82997
- });
82998
- const handleLegendClick = (entry) => {
82999
- setHoveredArea(null);
83000
- setActiveAreas({ ...activeAreas, [entry.dataKey]: !activeAreas[entry.dataKey] });
83001
- };
83002
- return /* @__PURE__ */ React.createElement(ResponsiveContainer, null, /* @__PURE__ */ React.createElement(AreaChart$1, { data, margin: { top: 10, right: 0, left: -25, bottom: 0 } }, /* @__PURE__ */ React.createElement(CartesianGrid, { ...getCartesianGridProps() }), /* @__PURE__ */ React.createElement(XAxis, { ...getXAxisProps(props) }), /* @__PURE__ */ React.createElement(YAxis, { ...getYAxisProps(props) }), /* @__PURE__ */ React.createElement(
83003
- Legend$2,
83004
- {
83005
- ...getLegendProps2({
83006
- onClick: handleLegendClick,
83007
- onMouseEnter: (entry) => setHoveredArea(entry.dataKey),
83008
- onMouseLeave: () => setHoveredArea(null),
83009
- activeItems: activeAreas
83010
- })
83011
- }
83012
- ), /* @__PURE__ */ React.createElement(Tooltip$1, { ...getTooltipProps(), formatter }), React.Children.map(children, (child) => /* @__PURE__ */ React.createElement(
83013
- Area$1,
83014
- {
83015
- activeDot: {
83016
- fill: getThemeColor(child.props.color ?? "blue-300")
83017
- },
83018
- isAnimationActive: false,
83019
- dataKey: child.props.accessor,
83020
- dot: false,
83021
- fill: getThemeColor(child.props.color ?? "grey-100"),
83022
- name: child.props.label,
83023
- strokeWidth: 2,
83024
- stroke: getThemeColor(child.props.color ?? "grey-300"),
83025
- stackId: child.props.stackId,
83026
- hide: !activeAreas[child.props.accessor],
83027
- opacity: hoveredArea && child.props.accessor !== hoveredArea ? 0.3 : 1
83028
- }
83029
- ))));
83030
- };
83031
- AreaChart.Area = Area;
83032
- const Bar = (_) => null;
83033
- const getXAxisVerticalProps = (props) => ({
83034
- ...getXAxisProps(props),
83035
- ...{ type: "number", dataKey: void 0 }
83036
- });
83037
- const getYAxisVerticalProps = (props) => ({
83038
- ...getYAxisProps(props),
83039
- ...{ dataKey: props.accessor, type: "category" }
83040
- });
83041
- const BarChart = function BarChart2(externalProps) {
83042
- const { children, data, formatter, layout = "horizontal", ...props } = externalProps;
83043
- const [activeIndex, setActiveIndex] = React.useState(void 0);
83044
- const [hoveredBar, setHoveredBar] = React.useState(null);
83045
- const [activeBars, setActiveBars] = React.useState(() => {
83046
- const keys2 = {};
83047
- React.Children.forEach(children, (child) => {
83048
- keys2[child.props.accessor] = true;
83004
+ const shapes2 = items2.filter((item) => !hiddenItems[item.dataKey]).map((item) => {
83005
+ const color2 = getThemeColor(item.color, "blue-500");
83006
+ return {
83007
+ activeDot: {
83008
+ strokeWidth: 1
83009
+ },
83010
+ color: color2,
83011
+ dataKey: item.dataKey,
83012
+ dot: {
83013
+ fillOpacity: 0.6
83014
+ },
83015
+ isAnimationActive: false,
83016
+ fill: color2,
83017
+ fillOpacity: 0.65,
83018
+ formatter: item.formatter,
83019
+ name: item.label,
83020
+ stroke: color2,
83021
+ strokeWidth: 1.5,
83022
+ unit: item.unit
83023
+ };
83049
83024
  });
83050
- return keys2;
83051
- });
83052
- const stacks = {};
83053
- React.Children.forEach(children, (child) => {
83054
- if (child.props.stackId) {
83055
- if (!stacks[child.props.stackId]) {
83056
- stacks[child.props.stackId] = [child.props.accessor];
83025
+ return { items: items2, shapes: shapes2 };
83026
+ }, [children, hiddenItems]);
83027
+ return { items, shapes, activeIndex, setActiveIndex, toggleItem };
83028
+ }
83029
+ function useChartDataHiddenState() {
83030
+ const [state, setState] = React.useState({});
83031
+ function toggle(name) {
83032
+ setState((currentState) => {
83033
+ const nextState = { ...currentState };
83034
+ if (currentState[name]) {
83035
+ delete nextState[name];
83057
83036
  } else {
83058
- stacks[child.props.stackId].push(child.props.accessor);
83037
+ nextState[name] = true;
83059
83038
  }
83060
- }
83061
- });
83062
- const handleLegendClick = (entry) => {
83063
- setHoveredBar(null);
83064
- setActiveBars({ ...activeBars, [entry.dataKey]: !activeBars[entry.dataKey] });
83065
- };
83066
- const handleLegendHover = (entry, index2) => {
83067
- setHoveredBar(entry.dataKey);
83068
- setActiveIndex(index2);
83069
- };
83070
- return /* @__PURE__ */ React.createElement(ResponsiveContainer, null, /* @__PURE__ */ React.createElement(
83071
- BarChart$1,
83039
+ return nextState;
83040
+ });
83041
+ }
83042
+ return [state, toggle];
83043
+ }
83044
+ function AreaChart(props) {
83045
+ const {
83046
+ children,
83047
+ data,
83048
+ dataKey,
83049
+ showDots = false,
83050
+ showLegend = false,
83051
+ showXAxis = true,
83052
+ showYAxis = false,
83053
+ stacked = false,
83054
+ tooltipTitle,
83055
+ type = "natural",
83056
+ xAxisScale,
83057
+ xAxisTickFormatter,
83058
+ yAxisScale,
83059
+ yAxisTickFormatter,
83060
+ ...attributes
83061
+ } = props;
83062
+ const className = clsx("aspect-video", attributes.className);
83063
+ const { items, shapes, activeIndex, setActiveIndex, toggleItem } = useChart(children);
83064
+ return /* @__PURE__ */ React.createElement("div", { className: "relative", "data-taco": "chart-wrapper" }, /* @__PURE__ */ React.createElement(ChartContainer, { ...attributes, className, "data-taco": "chart-area" }, /* @__PURE__ */ React.createElement(
83065
+ AreaChart$1,
83072
83066
  {
83073
- layout,
83074
83067
  data,
83075
- margin: { top: 10, right: 0, left: layout === "vertical" ? 0 : -25, bottom: 0 },
83076
- onMouseMove: (chartState) => setActiveIndex(chartState.activeTooltipIndex),
83077
- onMouseLeave: () => setActiveIndex(void 0)
83068
+ margin: { bottom: 10, left: 10, right: 10, top: 10 },
83069
+ stackOffset: stacked === "expand" ? "expand" : void 0
83078
83070
  },
83079
- /* @__PURE__ */ React.createElement(CartesianGrid, { ...getCartesianGridProps() }),
83071
+ /* @__PURE__ */ React.createElement(CartesianGrid, { vertical: false }),
83072
+ /* @__PURE__ */ React.createElement(Tooltip$1, { content: /* @__PURE__ */ React.createElement(Tooltip, { title: tooltipTitle }) }),
83080
83073
  /* @__PURE__ */ React.createElement(
83081
83074
  XAxis,
83082
83075
  {
83083
- ...layout === "vertical" ? getXAxisVerticalProps(props) : getXAxisProps(props)
83076
+ ...getAxisProps(xAxisScale, xAxisTickFormatter, dataKey),
83077
+ hide: !showXAxis
83084
83078
  }
83085
83079
  ),
83080
+ /* @__PURE__ */ React.createElement(YAxis, { ...getAxisProps(yAxisScale, yAxisTickFormatter), hide: !showYAxis }),
83081
+ shapes.map((shape) => /* @__PURE__ */ React.createElement(
83082
+ Area$1,
83083
+ {
83084
+ key: shape.dataKey,
83085
+ ...shape,
83086
+ dot: showDots ? shape.dot : false,
83087
+ stackId: stacked ? "stack" : void 0,
83088
+ type
83089
+ }
83090
+ ))
83091
+ )), showLegend ? /* @__PURE__ */ React.createElement(Legend$1, { items, hoverIndex: activeIndex, onHover: setActiveIndex, onToggle: toggleItem }) : null);
83092
+ }
83093
+ function Area(_) {
83094
+ return null;
83095
+ }
83096
+ AreaChart.Area = Area;
83097
+ const BAR_WIDTH = 20;
83098
+ function BarChart(props) {
83099
+ const isHorizontal = props.layout === "horizontal";
83100
+ const {
83101
+ children,
83102
+ data,
83103
+ dataKey,
83104
+ showLabels = false,
83105
+ showLegend = false,
83106
+ showXAxis = !isHorizontal,
83107
+ showYAxis = isHorizontal,
83108
+ stacked = false,
83109
+ xAxisScale,
83110
+ xAxisTickFormatter,
83111
+ yAxisScale,
83112
+ yAxisTickFormatter,
83113
+ ...attributes
83114
+ } = props;
83115
+ const className = clsx("aspect-video", attributes.className);
83116
+ const { items, shapes, activeIndex, setActiveIndex, toggleItem } = useChart(children);
83117
+ return /* @__PURE__ */ React.createElement("div", { className: "relative", "data-taco": "chart-wrapper" }, /* @__PURE__ */ React.createElement(ChartContainer, { ...attributes, className, "data-taco": "chart-bar" }, /* @__PURE__ */ React.createElement(
83118
+ BarChart$1,
83119
+ {
83120
+ data,
83121
+ barCategoryGap: "15%",
83122
+ barGap: "7.5%",
83123
+ margin: { bottom: 10, left: isHorizontal ? -15 : 10, right: 10, top: 10 },
83124
+ layout: isHorizontal ? "vertical" : void 0,
83125
+ stackOffset: stacked === "expand" ? "expand" : void 0
83126
+ },
83127
+ /* @__PURE__ */ React.createElement(CartesianGrid, { horizontal: !isHorizontal, vertical: false }),
83128
+ /* @__PURE__ */ React.createElement(Tooltip$1, { content: /* @__PURE__ */ React.createElement(Tooltip, null) }),
83086
83129
  /* @__PURE__ */ React.createElement(
83087
- YAxis,
83130
+ XAxis,
83088
83131
  {
83089
- ...layout === "vertical" ? getYAxisVerticalProps(props) : getYAxisProps(props)
83132
+ ...getAxisProps(xAxisScale, xAxisTickFormatter, isHorizontal ? void 0 : dataKey),
83133
+ hide: !showXAxis,
83134
+ type: isHorizontal ? "number" : void 0
83090
83135
  }
83091
83136
  ),
83092
83137
  /* @__PURE__ */ React.createElement(
83093
- Legend$2,
83138
+ YAxis,
83094
83139
  {
83095
- ...getLegendProps2({
83096
- onClick: handleLegendClick,
83097
- onMouseEnter: handleLegendHover,
83098
- onMouseLeave: () => setHoveredBar(null),
83099
- activeItems: activeBars
83100
- })
83140
+ ...getAxisProps(yAxisScale, yAxisTickFormatter, isHorizontal ? dataKey : void 0),
83141
+ hide: !showYAxis,
83142
+ type: isHorizontal ? "category" : void 0
83101
83143
  }
83102
83144
  ),
83103
- /* @__PURE__ */ React.createElement(Tooltip$1, { ...getTooltipProps(), formatter }),
83104
- React.Children.map(children, (child) => /* @__PURE__ */ React.createElement(
83145
+ shapes.map((shape, index2) => /* @__PURE__ */ React.createElement(
83105
83146
  Bar$1,
83106
83147
  {
83107
- isAnimationActive: false,
83108
- barSize: 16,
83109
- dataKey: child.props.accessor,
83110
- name: child.props.label,
83111
- onMouseEnter: (_, index2) => setActiveIndex(index2),
83112
- onMouseLeave: () => setActiveIndex(void 0),
83113
- fill: getThemeColor(child.props.color ? `${child.props.color}` : `blue-300`),
83114
- radius: getBarRadius(stacks, child.props.accessor, child.props.stackId, activeBars),
83115
- stackId: child.props.stackId,
83116
- style: child.props.stackId ? { stroke: "#fff", strokeWidth: "2px" } : void 0,
83117
- hide: !activeBars[child.props.accessor]
83148
+ key: shape.dataKey,
83149
+ ...shape,
83150
+ activeBar: { fillOpacity: 1, strokeWidth: 0 },
83151
+ strokeWidth: 0,
83152
+ maxBarSize: BAR_WIDTH,
83153
+ radius: getRadius(index2, shapes.length, !!stacked, isHorizontal),
83154
+ stackId: stacked ? "stack" : void 0
83118
83155
  },
83119
- data.map((_, index2) => /* @__PURE__ */ React.createElement(
83120
- Cell,
83156
+ showLabels ? /* @__PURE__ */ React.createElement(
83157
+ LabelList,
83121
83158
  {
83122
- key: `cell-${index2}`,
83123
- opacity: hoveredBar && child.props.accessor !== hoveredBar || activeIndex !== void 0 && activeIndex !== index2 ? 0.3 : 1
83159
+ position: isHorizontal ? "insideRight" : "top",
83160
+ formatter: shape.formatter,
83161
+ offset: isHorizontal ? 6 : 8,
83162
+ fill: isHorizontal ? getInverseThemeColor(shape.color ?? "") : "black",
83163
+ fontSize: 11
83124
83164
  }
83125
- ))
83165
+ ) : null
83126
83166
  ))
83127
- ));
83128
- };
83129
- BarChart.Bar = Bar;
83130
- const getBarRadius = (stacks, accessor, stackId, activeBars) => {
83131
- if (stackId && Array.isArray(stacks[stackId])) {
83132
- const length = stacks[stackId].length - 1;
83133
- const index2 = stacks[stackId].indexOf(accessor);
83134
- if (Object.entries(activeBars).filter((item) => item[0] !== accessor).every((item) => !item[1])) {
83135
- return [3, 3, 0, 0];
83167
+ )), showLegend ? /* @__PURE__ */ React.createElement(Legend$1, { items, hoverIndex: activeIndex, onHover: setActiveIndex, onToggle: toggleItem }) : null);
83168
+ }
83169
+ function getRadius(index2, length, stacked, isHorizontal) {
83170
+ if (stacked) {
83171
+ if (index2 === 0) {
83172
+ return isHorizontal ? [3, 0, 0, 3] : [0, 0, 3, 3];
83136
83173
  }
83137
- if (activeBars[stacks[stackId][index2 + 1]] === false) {
83138
- return [index2 === 0 ? 0 : 3, index2 === 0 ? 0 : 3, index2 === length - 1 ? 0 : 3, index2 === length - 1 ? 0 : 3];
83174
+ if (index2 === length - 1) {
83175
+ return isHorizontal ? [0, 3, 3, 0] : [3, 3, 0, 0];
83139
83176
  }
83140
- if (index2 !== 0 && index2 !== length) {
83141
- return 0;
83142
- }
83143
- return [index2 === 0 ? 0 : 3, index2 === 0 ? 0 : 3, index2 === length ? 0 : 3, index2 === length ? 0 : 3];
83177
+ return 0;
83144
83178
  }
83145
83179
  return 3;
83146
- };
83147
- const Legend = ({
83148
- legendPosition,
83149
- hoveredItem,
83150
- selectedItem,
83151
- data,
83152
- onClick,
83153
- setHoveredItem,
83154
- formatter,
83155
- total,
83156
- visibleItems,
83157
- label
83158
- }) => {
83180
+ }
83181
+ function Bar(_) {
83182
+ return null;
83183
+ }
83184
+ BarChart.Bar = Bar;
83185
+ const PIE_ACTIVE_WIDTH = 10;
83186
+ const PIE_ACTIVE_WIDTH_OFFSET = 2;
83187
+ function usePieChart(children, options) {
83188
+ const { items, shapes, activeIndex, setActiveIndex, toggleItem } = useChart(children, options);
83189
+ const [radius, _setRadius] = React.useState(0);
83190
+ function setRadius(width) {
83191
+ _setRadius((width - 2 * (PIE_ACTIVE_WIDTH + PIE_ACTIVE_WIDTH_OFFSET)) / 2);
83192
+ }
83193
+ const pieProps = {
83194
+ activeIndex,
83195
+ activeShape: (props) => /* @__PURE__ */ React.createElement(ActiveShape$1, { ...props }),
83196
+ children: shapes.map((shape) => /* @__PURE__ */ React.createElement(Cell, { key: shape.dataKey, color: shape.color, fill: shape.fill })),
83197
+ // data props
83198
+ data: items.filter((item) => !item.isHidden),
83199
+ dataKey: "value",
83200
+ nameKey: "label",
83201
+ // style props
83202
+ isAnimationActive: false,
83203
+ startAngle: 90,
83204
+ endAngle: -270,
83205
+ stroke: "0",
83206
+ labelLine: false,
83207
+ outerRadius: radius
83208
+ };
83209
+ return { pieProps, radius, setRadius, items, activeIndex, setActiveIndex, toggleItem, shapes };
83210
+ }
83211
+ const PIE_CHART_HOVER = 10;
83212
+ const PIE_CHART_HOVER_OFFSET = 2;
83213
+ function ActiveShape$1(props) {
83214
+ const { outerRadius = 0, ...attributes } = props;
83215
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(Sector, { ...attributes, outerRadius }), /* @__PURE__ */ React.createElement(
83216
+ Sector,
83217
+ {
83218
+ ...attributes,
83219
+ innerRadius: outerRadius + PIE_CHART_HOVER_OFFSET,
83220
+ outerRadius: outerRadius + PIE_CHART_HOVER,
83221
+ opacity: 0.4
83222
+ }
83223
+ ));
83224
+ }
83225
+ const DONUT_WIDTH$1 = 20;
83226
+ function DonutChart(props) {
83227
+ const { children, formatter, showLegend = false, showTotal = false, tooltipTitle, unit: unit2, ...attributes } = props;
83228
+ const { pieProps, radius, setRadius, items, activeIndex, setActiveIndex, toggleItem } = usePieChart(children, {
83229
+ formatter,
83230
+ unit: unit2
83231
+ });
83232
+ const className = clsx("aspect-square", attributes.className);
83233
+ return /* @__PURE__ */ React.createElement("div", { className: "relative", "data-taco": "chart-wrapper" }, showTotal ? /* @__PURE__ */ React.createElement(
83234
+ Total,
83235
+ {
83236
+ formatter,
83237
+ items,
83238
+ unit: unit2,
83239
+ style: { top: radius / 2 - 2, width: radius + DONUT_WIDTH$1 }
83240
+ }
83241
+ ) : null, /* @__PURE__ */ React.createElement(ChartContainer, { ...attributes, className, "data-taco": "chart-donut", onSetWidth: setRadius }, /* @__PURE__ */ React.createElement(PieChart$1, null, /* @__PURE__ */ React.createElement(Tooltip$1, { content: /* @__PURE__ */ React.createElement(Tooltip, { title: tooltipTitle }) }), /* @__PURE__ */ React.createElement(Pie, { ...pieProps, innerRadius: radius - DONUT_WIDTH$1 }))), showLegend ? /* @__PURE__ */ React.createElement(Legend$1, { items, hoverIndex: activeIndex, onHover: setActiveIndex, onToggle: toggleItem }) : null);
83242
+ }
83243
+ function Segment$2(_) {
83244
+ return null;
83245
+ }
83246
+ DonutChart.Segment = Segment$2;
83247
+ function Total(props) {
83248
+ const { formatter, items, unit: unit2, ...attributes } = props;
83249
+ const localization = useLocalization();
83250
+ const total = React.useMemo(() => {
83251
+ const total2 = items.filter((item) => !item.isHidden).reduce((acc, curr) => acc + curr.value, 0);
83252
+ return (formatter == null ? void 0 : formatter(total2)) ?? new Intl.NumberFormat(localization.locale).format(total2);
83253
+ }, [items]);
83254
+ return /* @__PURE__ */ React.createElement("div", { ...attributes, className: "absolute-center-x flex aspect-square flex-col items-center justify-center rounded-full" }, /* @__PURE__ */ React.createElement("span", { className: "truncate text-2xl font-bold tabular-nums" }, total), unit2 ? /* @__PURE__ */ React.createElement("span", { className: "text-grey-700 -mb-1 -mt-0.5 truncate text-xs" }, unit2) : null);
83255
+ }
83256
+ const Legend = ({ hoveredItem, selectedItem, data, onClick, setHoveredItem, formatter, total, label }) => {
83159
83257
  const isTotalLegendSelected = selectedItem.length === data.length;
83160
83258
  const isTotalLegendHovered = hoveredItem.length === data.length;
83161
83259
  const handleMouseLeave = () => setHoveredItem([]);
@@ -83169,49 +83267,22 @@ const Legend = ({
83169
83267
  {
83170
83268
  key: isTotal ? "total" : `${itemData.label}-${index2}`,
83171
83269
  className: clsx("mr-2 flex cursor-pointer gap-2 rounded pl-0 pr-1", {
83172
- "bg-grey-100": isHovered && (!isTotal || legendPosition === "right"),
83173
- "bg-grey-200": isSelected && (!isTotal || legendPosition === "right")
83270
+ "bg-grey-100": isHovered,
83271
+ "bg-grey-200": isSelected
83174
83272
  }),
83175
83273
  onClick: () => onClick(isTotal ? data : itemData),
83176
83274
  onMouseEnter: () => setHoveredItem(isTotal ? data.map((item) => item.id) : [itemData.id]),
83177
83275
  onMouseLeave: handleMouseLeave
83178
83276
  },
83179
- legendPosition === "bottom" ? /* @__PURE__ */ React.createElement("div", { className: "flex items-center gap-1" }, /* @__PURE__ */ React.createElement(
83180
- "span",
83181
- {
83182
- className: clsx("ml-1 h-3 w-3 rounded-sm", {
83183
- "border-grey-300 border !bg-white": !visibleItems[itemData.id]
83184
- }),
83185
- style: { backgroundColor: getThemeColor(itemData.color) }
83186
- },
83187
- visibleItems[itemData.id] && isHovered && /* @__PURE__ */ React.createElement(Icon$1, { name: "tick-bold", className: "mb-2.5 !h-full !w-full text-white" })
83188
- ), /* @__PURE__ */ React.createElement("div", null, itemData.label)) : /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
83189
- "span",
83190
- {
83191
- className: "ml-1 mt-1 h-9 w-2 rounded-[1px]",
83192
- style: { backgroundColor: getThemeColor(itemData.color) }
83193
- }
83194
- ), /* @__PURE__ */ React.createElement("div", null, itemData.label, /* @__PURE__ */ React.createElement("span", { className: "-mt-1 flex w-full text-lg font-bold" }, formatter ? formatter(itemData.value) : itemData.value)))
83277
+ /* @__PURE__ */ React.createElement("span", { className: "ml-1 mt-1 h-9 w-2 rounded-[1px]", style: { backgroundColor: getThemeColor(itemData.color) } }),
83278
+ /* @__PURE__ */ React.createElement("div", null, itemData.label, /* @__PURE__ */ React.createElement("span", { className: "-mt-1 flex w-full text-lg font-bold" }, formatter ? formatter(itemData.value) : itemData.value))
83195
83279
  );
83196
83280
  };
83197
- const moreButton = (moreButtonText) => /* @__PURE__ */ React.createElement(Button$4, { appearance: "transparent", className: "text-grey-700" }, moreButtonText);
83198
- const className = clsx("flex-grow pl-4", {
83199
- "w-full": legendPosition === "bottom"
83200
- });
83201
- return /* @__PURE__ */ React.createElement("div", { className }, /* @__PURE__ */ React.createElement(
83202
- "ul",
83203
- {
83204
- className: clsx(
83205
- "mb-0 ml-0 mt-4 flex justify-center space-y-1",
83206
- legendPosition === "right" ? "flex-col gap-1" : "flex-row"
83207
- )
83208
- },
83209
- legendPosition === "right" ? /* @__PURE__ */ React.createElement(React.Fragment, null, renderLegendItem(null), data.map(renderLegendItem)) : /* @__PURE__ */ React.createElement(OverflowGroup, { className: "w-full items-center py-1", moreButton }, data.map(renderLegendItem))
83210
- ));
83281
+ return /* @__PURE__ */ React.createElement("div", { className: "flex-grow pl-4" }, /* @__PURE__ */ React.createElement("ul", { className: "mb-0 ml-0 mt-4 flex flex-col justify-center gap-1 space-y-1" }, renderLegendItem(null), data.map(renderLegendItem)));
83211
83282
  };
83212
- const DONUT_WIDTH = 16;
83283
+ const DONUT_WIDTH = 24;
83213
83284
  const HOVER_DONUT_WIDTH = 10;
83214
- const CenteredLabel = ({ radius, legendPosition, label, total, formatter, showLegend }) => {
83285
+ const CenteredLabel = ({ radius, label, total, formatter }) => {
83215
83286
  const totalInset = HOVER_DONUT_WIDTH + DONUT_WIDTH + DONUT_WIDTH;
83216
83287
  const diameter = radius * 2;
83217
83288
  return /* @__PURE__ */ React.createElement(
@@ -83221,8 +83292,8 @@ const CenteredLabel = ({ radius, legendPosition, label, total, formatter, showLe
83221
83292
  style: {
83222
83293
  top: `calc(${radius}px - (3rem / 2))`,
83223
83294
  // h-12 is 3rem
83224
- left: legendPosition === "right" ? `${totalInset}px` : `calc(50%-${diameter - 2 * totalInset})`,
83225
- width: showLegend ? `${diameter - 2 * totalInset}px` : `${diameter}px`
83295
+ left: `${totalInset}px`,
83296
+ width: `${diameter - 2 * totalInset}px`
83226
83297
  }
83227
83298
  },
83228
83299
  /* @__PURE__ */ React.createElement("span", { className: "w-full truncate text-lg font-bold" }, formatter ? formatter(total) : total),
@@ -83251,42 +83322,28 @@ const ActiveShape = (props) => {
83251
83322
  endAngle,
83252
83323
  innerRadius: outerRadius + 2,
83253
83324
  outerRadius: outerRadius + HOVER_DONUT_WIDTH,
83254
- fill: id2 !== void 0 ? getThemeColor(pieColors[id2]) ?? getThemeColor("blue-500") : getThemeColor("blue-500"),
83255
- opacity: 0.3
83325
+ fill: id2 !== void 0 ? getThemeColor(pieColors[id2], "blue-500") : getThemeColor("blue-500"),
83326
+ opacity: 0.4
83256
83327
  }
83257
83328
  ));
83258
83329
  };
83259
- const Segment = (_) => null;
83260
- const DonutChart = function DonutChart2({
83261
- children,
83262
- formatter,
83263
- onClick,
83264
- showLegend = false,
83265
- legendPosition = "bottom",
83266
- label
83267
- }) {
83330
+ const Segment$1 = (_) => null;
83331
+ const LegacyDonutChart = function LegacyDonutChart2({ children, formatter, onClick, label }) {
83268
83332
  const ref = React.useRef(null);
83269
83333
  const [radius, setRadius] = React.useState(0);
83270
83334
  const [hoveredItem, setHoveredItem] = React.useState([]);
83271
83335
  const [selectedItem, setSelectedItem] = React.useState([]);
83272
- const [visibleItems, setVisibleItems] = React.useState(() => {
83273
- const keys2 = {};
83274
- React.Children.forEach(children, (child) => {
83275
- keys2[child.props.id] = true;
83276
- });
83277
- return keys2;
83278
- });
83279
83336
  React.useEffect(() => {
83280
83337
  var _a;
83281
83338
  if (ref.current) {
83282
83339
  const rect = (_a = ref.current.parentElement) == null ? void 0 : _a.getBoundingClientRect();
83283
83340
  if (rect) {
83284
- const width = showLegend ? rect.width / 2 : rect.width;
83341
+ const width = rect.width / 2;
83285
83342
  const max2 = rect.height < width ? rect.height : width;
83286
83343
  setRadius(max2 / 2);
83287
83344
  }
83288
83345
  }
83289
- }, [showLegend]);
83346
+ }, [ref.current]);
83290
83347
  const diameter = radius * 2;
83291
83348
  const data = React.Children.map(children, (child) => ({
83292
83349
  id: child.props.id,
@@ -83294,34 +83351,27 @@ const DonutChart = function DonutChart2({
83294
83351
  label: child.props.label,
83295
83352
  value: child.props.value
83296
83353
  }));
83297
- const displayedData = data.filter((child) => visibleItems[child.id]);
83298
- const total = displayedData.reduce((accum, entry) => accum + entry.value, 0);
83299
- const showTooltip = (!showLegend || legendPosition === "bottom") && displayedData.length > 0;
83354
+ const total = data.reduce((accum, entry) => accum + entry.value, 0);
83300
83355
  const handleLegendClick = (entry) => {
83301
- if (legendPosition === "bottom" && !Array.isArray(entry)) {
83302
- setVisibleItems({ ...visibleItems, [entry.id]: !visibleItems[entry.id] });
83303
- } else {
83304
- const nextSelectedItem = Array.isArray(entry) ? entry.map((entryItem) => entryItem.id) : [entry.id];
83305
- const isCurrentSegmentActive = selectedItem.slice().sort().join(",") === nextSelectedItem.sort().join(",");
83306
- if (onClick && !isCurrentSegmentActive) {
83307
- onClick(entry);
83308
- }
83309
- setSelectedItem(isCurrentSegmentActive ? [] : nextSelectedItem);
83356
+ const nextSelectedItem = Array.isArray(entry) ? entry.map((entryItem) => entryItem.id) : [entry.id];
83357
+ const isCurrentSegmentActive = selectedItem.slice().sort().join(",") === nextSelectedItem.sort().join(",");
83358
+ if (onClick && !isCurrentSegmentActive) {
83359
+ onClick(entry);
83310
83360
  }
83361
+ setSelectedItem(isCurrentSegmentActive ? [] : nextSelectedItem);
83311
83362
  };
83312
83363
  const handlePieClick = React.useCallback(
83313
83364
  (pieId) => {
83314
83365
  if (onClick && pieId !== void 0) {
83315
- const pieProps = displayedData.find((item) => item.id === pieId);
83366
+ const pieProps = data.find((item) => item.id === pieId);
83316
83367
  onClick(pieProps);
83317
83368
  }
83318
83369
  },
83319
- [onClick, displayedData]
83370
+ [onClick, data]
83320
83371
  );
83321
- const singlePieDonutChart = displayedData.length === 1;
83322
83372
  const activeShapeColor = React.useMemo(() => {
83323
83373
  const getSegmentColor = (item) => item.reduce((colors2, itemId) => {
83324
- const visibleHoveredItem = displayedData.find((dataItem) => dataItem.id === itemId);
83374
+ const visibleHoveredItem = data.find((dataItem) => dataItem.id === itemId);
83325
83375
  if (visibleHoveredItem) {
83326
83376
  colors2[visibleHoveredItem.id] = visibleHoveredItem.color;
83327
83377
  }
@@ -83329,20 +83379,20 @@ const DonutChart = function DonutChart2({
83329
83379
  }, {});
83330
83380
  const hoveredSegmentColor = getSegmentColor(hoveredItem);
83331
83381
  const selectedSegmentColor = getSegmentColor(selectedItem);
83332
- return legendPosition === "bottom" || hoveredItem.length !== 0 ? hoveredSegmentColor : selectedSegmentColor;
83333
- }, [hoveredItem, selectedItem, legendPosition]);
83382
+ return hoveredItem.length !== 0 ? hoveredSegmentColor : selectedSegmentColor;
83383
+ }, [hoveredItem, selectedItem]);
83334
83384
  if (ref.current && !radius) {
83335
83385
  return null;
83336
83386
  }
83337
83387
  const getActiveIndex = () => {
83338
83388
  if (hoveredItem.length > 0) {
83339
- return hoveredItem.map((itemId) => displayedData.findIndex((element) => element.id === itemId));
83389
+ return hoveredItem.map((itemId) => data.findIndex((element) => element.id === itemId));
83340
83390
  }
83341
- return selectedItem.map((selectedItemId) => displayedData.findIndex((element) => element.id === selectedItemId));
83391
+ return selectedItem.map((selectedItemId) => data.findIndex((element) => element.id === selectedItemId));
83342
83392
  };
83343
83393
  const content = () => {
83344
83394
  const elements = React.Children.toArray(children).filter(
83345
- (child) => React.isValidElement(child) && visibleItems[child.props.id]
83395
+ (child) => React.isValidElement(child)
83346
83396
  );
83347
83397
  return elements.length > 0 ? elements.map((child, index2) => {
83348
83398
  return /* @__PURE__ */ React.createElement(
@@ -83355,112 +83405,112 @@ const DonutChart = function DonutChart2({
83355
83405
  );
83356
83406
  }) : /* @__PURE__ */ React.createElement(Cell, { key: "empty-chart", name: "", fill: getThemeColor("grey-200") });
83357
83407
  };
83358
- return /* @__PURE__ */ React.createElement(
83359
- "div",
83408
+ return /* @__PURE__ */ React.createElement("div", { className: "relative flex h-full w-full", ref }, /* @__PURE__ */ React.createElement(CenteredLabel, { radius, label, total, formatter }), /* @__PURE__ */ React.createElement(PieChart$1, { data, height: diameter, width: diameter, style: { transform: "rotate(90deg) scale(-1,1)" } }, /* @__PURE__ */ React.createElement(
83409
+ Pie,
83360
83410
  {
83361
- className: clsx("relative h-full w-full", {
83362
- [`flex `]: showLegend,
83363
- "flex-col items-center": legendPosition === "bottom"
83364
- }),
83365
- ref
83411
+ isAnimationActive: false,
83412
+ activeIndex: getActiveIndex(),
83413
+ activeShape: /* @__PURE__ */ React.createElement(ActiveShape, { pieColors: activeShapeColor, onClick: handlePieClick }),
83414
+ data: data.length > 0 ? data : [],
83415
+ dataKey: "value",
83416
+ innerRadius: radius - HOVER_DONUT_WIDTH - DONUT_WIDTH,
83417
+ onMouseEnter: (segment) => data.length > 0 && setHoveredItem([segment.id]),
83418
+ onMouseLeave: () => setHoveredItem([]),
83419
+ outerRadius: radius - HOVER_DONUT_WIDTH,
83420
+ stroke: "0",
83421
+ rootTabIndex: -1
83366
83422
  },
83423
+ content()
83424
+ )), /* @__PURE__ */ React.createElement(
83425
+ Legend,
83426
+ {
83427
+ data,
83428
+ onClick: handleLegendClick,
83429
+ total,
83430
+ setHoveredItem,
83431
+ label,
83432
+ hoveredItem,
83433
+ selectedItem,
83434
+ formatter
83435
+ }
83436
+ ));
83437
+ };
83438
+ LegacyDonutChart.Segment = Segment$1;
83439
+ function LineChart(props) {
83440
+ const {
83441
+ children,
83442
+ data,
83443
+ dataKey,
83444
+ showDots = false,
83445
+ showLegend = false,
83446
+ showXAxis = true,
83447
+ showYAxis = false,
83448
+ tooltipTitle,
83449
+ type = "natural",
83450
+ xAxisScale,
83451
+ xAxisTickFormatter,
83452
+ yAxisScale,
83453
+ yAxisTickFormatter,
83454
+ ...attributes
83455
+ } = props;
83456
+ const className = clsx("aspect-video", attributes.className);
83457
+ const { items, shapes, activeIndex, setActiveIndex, toggleItem } = useChart(children);
83458
+ return /* @__PURE__ */ React.createElement("div", { className: "relative", "data-taco": "chart-wrapper" }, /* @__PURE__ */ React.createElement(ChartContainer, { ...attributes, className, "data-taco": "chart-area" }, /* @__PURE__ */ React.createElement(
83459
+ LineChart$1,
83460
+ {
83461
+ data,
83462
+ margin: { bottom: 10, left: 10, right: 10, top: 10 }
83463
+ },
83464
+ /* @__PURE__ */ React.createElement(CartesianGrid, { vertical: false }),
83465
+ /* @__PURE__ */ React.createElement(Tooltip$1, { content: /* @__PURE__ */ React.createElement(Tooltip, { title: tooltipTitle }) }),
83367
83466
  /* @__PURE__ */ React.createElement(
83368
- CenteredLabel,
83467
+ XAxis,
83369
83468
  {
83370
- radius,
83371
- legendPosition,
83372
- label,
83373
- total,
83374
- formatter,
83375
- showLegend
83469
+ ...getAxisProps(xAxisScale, xAxisTickFormatter, dataKey),
83470
+ hide: !showXAxis
83376
83471
  }
83377
83472
  ),
83378
- /* @__PURE__ */ React.createElement(PieChart, { data, height: diameter, width: diameter, style: { transform: "rotate(90deg) scale(-1,1)" } }, showTooltip ? /* @__PURE__ */ React.createElement(
83379
- Tooltip$1,
83380
- {
83381
- ...getTooltipProps({
83382
- style: { transform: "rotate(90deg) scale(-1,1)" },
83383
- singlePieDonutChart
83384
- })
83385
- }
83386
- ) : null, /* @__PURE__ */ React.createElement(
83387
- Pie,
83388
- {
83389
- isAnimationActive: false,
83390
- activeIndex: getActiveIndex(),
83391
- activeShape: /* @__PURE__ */ React.createElement(ActiveShape, { pieColors: activeShapeColor, onClick: handlePieClick }),
83392
- data: displayedData.length > 0 ? displayedData : [],
83393
- dataKey: "value",
83394
- innerRadius: radius - HOVER_DONUT_WIDTH - DONUT_WIDTH,
83395
- onMouseEnter: (segment) => displayedData.length > 0 && setHoveredItem([segment.id]),
83396
- onMouseLeave: () => setHoveredItem([]),
83397
- outerRadius: radius - HOVER_DONUT_WIDTH,
83398
- paddingAngle: 2,
83399
- rootTabIndex: -1
83400
- },
83401
- content()
83402
- )),
83403
- showLegend && /* @__PURE__ */ React.createElement(
83404
- Legend,
83405
- {
83406
- data,
83407
- visibleItems,
83408
- onClick: handleLegendClick,
83409
- total,
83410
- setHoveredItem,
83411
- label,
83412
- legendPosition,
83413
- hoveredItem,
83414
- selectedItem,
83415
- formatter
83416
- }
83417
- )
83418
- );
83419
- };
83420
- DonutChart.Segment = Segment;
83421
- const Line = (_) => null;
83422
- const LineChart = function LineChart2(externalProps) {
83423
- const { children, data, formatter, ...props } = externalProps;
83424
- const [hoveredLine, setHoveredLine] = React.useState(null);
83425
- const [activeLines, setActiveLines] = React.useState(() => {
83426
- const keys2 = {};
83427
- React.Children.forEach(children, (child) => {
83428
- keys2[child.props.accessor] = true;
83429
- });
83430
- return keys2;
83473
+ /* @__PURE__ */ React.createElement(YAxis, { ...getAxisProps(yAxisScale, yAxisTickFormatter), hide: !showYAxis }),
83474
+ shapes.map((shape) => /* @__PURE__ */ React.createElement(Line$1, { key: shape.dataKey, ...shape, dot: showDots ? shape.dot : false, type }))
83475
+ )), showLegend ? /* @__PURE__ */ React.createElement(Legend$1, { items, hoverIndex: activeIndex, onHover: setActiveIndex, onToggle: toggleItem }) : null);
83476
+ }
83477
+ function Line(_) {
83478
+ return null;
83479
+ }
83480
+ LineChart.Line = Line;
83481
+ function PieChart(props) {
83482
+ const { children, formatter, showLabels = false, showLegend = false, tooltipTitle, unit: unit2, ...attributes } = props;
83483
+ const { pieProps, setRadius, items, activeIndex, setActiveIndex, toggleItem } = usePieChart(children, {
83484
+ formatter,
83485
+ unit: unit2
83431
83486
  });
83432
- const handleLegendClick = (entry) => {
83433
- setHoveredLine(null);
83434
- setActiveLines({ ...activeLines, [entry.dataKey]: !activeLines[entry.dataKey] });
83435
- };
83436
- return /* @__PURE__ */ React.createElement(ResponsiveContainer, null, /* @__PURE__ */ React.createElement(LineChart$1, { data, margin: { top: 10, right: 0, left: -25, bottom: 0 } }, /* @__PURE__ */ React.createElement(CartesianGrid, { ...getCartesianGridProps() }), /* @__PURE__ */ React.createElement(XAxis, { ...getXAxisProps(props) }), /* @__PURE__ */ React.createElement(YAxis, { ...getYAxisProps(props) }), /* @__PURE__ */ React.createElement(
83437
- Legend$2,
83438
- {
83439
- ...getLegendProps2({
83440
- onClick: handleLegendClick,
83441
- onMouseEnter: (entry) => setHoveredLine(entry.dataKey),
83442
- onMouseLeave: () => setHoveredLine(null),
83443
- activeItems: activeLines
83444
- })
83445
- }
83446
- ), /* @__PURE__ */ React.createElement(Tooltip$1, { ...getTooltipProps(), formatter }), React.Children.map(children, (child) => /* @__PURE__ */ React.createElement(
83447
- Line$1,
83487
+ const className = clsx("aspect-square", attributes.className);
83488
+ return /* @__PURE__ */ React.createElement("div", { className: "relative", "data-taco": "chart-wrapper" }, /* @__PURE__ */ React.createElement(ChartContainer, { ...attributes, className, "data-taco": "chart-pie", onSetWidth: setRadius }, /* @__PURE__ */ React.createElement(PieChart$1, null, /* @__PURE__ */ React.createElement(Tooltip$1, { content: /* @__PURE__ */ React.createElement(Tooltip, { title: tooltipTitle }) }), /* @__PURE__ */ React.createElement(Pie, { ...pieProps, label: showLabels ? /* @__PURE__ */ React.createElement(Label, null) : void 0 }))), showLegend ? /* @__PURE__ */ React.createElement(Legend$1, { items, hoverIndex: activeIndex, onHover: setActiveIndex, onToggle: toggleItem }) : null);
83489
+ }
83490
+ function Segment(_) {
83491
+ return null;
83492
+ }
83493
+ PieChart.Segment = Segment;
83494
+ const RADIAN = Math.PI / 180;
83495
+ function Label(props) {
83496
+ var _a, _b;
83497
+ const { cx, cy, midAngle, name, innerRadius, outerRadius } = props;
83498
+ const radius = innerRadius + (outerRadius - innerRadius) * 0.7;
83499
+ const x3 = cx + radius * Math.cos(-midAngle * RADIAN);
83500
+ const y4 = cy + radius * Math.sin(-midAngle * RADIAN);
83501
+ return /* @__PURE__ */ React.createElement(
83502
+ "text",
83448
83503
  {
83449
- activeDot: {
83450
- fill: getThemeColor(child.props.color ?? "blue-300")
83451
- },
83452
- dataKey: child.props.accessor,
83453
- isAnimationActive: false,
83454
- dot: false,
83455
- name: child.props.label,
83456
- stroke: getThemeColor(child.props.color ?? "blue-300"),
83457
- strokeWidth: 2,
83458
- hide: !activeLines[child.props.accessor],
83459
- opacity: hoveredLine && child.props.accessor !== hoveredLine ? 0.3 : 1
83460
- }
83461
- ))));
83462
- };
83463
- LineChart.Line = Line;
83504
+ x: x3,
83505
+ y: y4,
83506
+ fontSize: 12,
83507
+ fill: getInverseThemeColor(((_b = (_a = props.payload) == null ? void 0 : _a.payload) == null ? void 0 : _b.color) ?? ""),
83508
+ textAnchor: "middle",
83509
+ dominantBaseline: "middle"
83510
+ },
83511
+ name
83512
+ );
83513
+ }
83464
83514
  const Button3 = React.forwardRef(function Button23(props, ref) {
83465
83515
  const { ...attributes } = props;
83466
83516
  const className = clsx(getButtonClasses(), props.className);
@@ -84329,6 +84379,7 @@ exports.Icon = Icon$1;
84329
84379
  exports.IconButton = IconButton;
84330
84380
  exports.Input = Input;
84331
84381
  exports.Layout = Layout;
84382
+ exports.LegacyDonutChart = LegacyDonutChart;
84332
84383
  exports.LineChart = LineChart;
84333
84384
  exports.List = List$1;
84334
84385
  exports.Listbox = Listbox;
@@ -84342,6 +84393,7 @@ exports.Navigation2 = Navigation24;
84342
84393
  exports.OverflowGroup = OverflowGroup;
84343
84394
  exports.PaginatedTable = PaginatedTable;
84344
84395
  exports.Pagination = Pagination;
84396
+ exports.PieChart = PieChart;
84345
84397
  exports.Popover = Popover;
84346
84398
  exports.Progress = Progress;
84347
84399
  exports.Provider = Provider;