@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 +490 -438
- package/dist/taco.cjs.map +1 -1
- package/dist/taco.css +12 -6
- package/dist/taco.d.ts +111 -72
- package/dist/taco.js +490 -438
- package/dist/taco.js.map +1 -1
- package/package.json +2 -2
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$
|
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$
|
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
|
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
|
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
|
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$
|
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$
|
70217
|
-
y: cy + Math.sin(-RADIAN$
|
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$
|
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$
|
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
|
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
|
-
|
82901
|
-
const
|
82902
|
-
const
|
82903
|
-
|
82904
|
-
|
82905
|
-
|
82906
|
-
|
82907
|
-
|
82908
|
-
|
82909
|
-
|
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
|
82986
|
+
return color2 === "black" ? "white" : "black";
|
82960
82987
|
};
|
82961
|
-
|
82962
|
-
|
82963
|
-
|
82964
|
-
const
|
82965
|
-
|
82966
|
-
|
82967
|
-
|
82968
|
-
|
82969
|
-
|
82970
|
-
|
82971
|
-
|
82972
|
-
|
82973
|
-
|
82974
|
-
|
82975
|
-
|
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
|
-
|
82997
|
-
|
82998
|
-
|
82999
|
-
|
83000
|
-
|
83001
|
-
|
83002
|
-
|
83003
|
-
|
83004
|
-
|
83005
|
-
|
83006
|
-
|
83007
|
-
|
83008
|
-
|
83009
|
-
|
83010
|
-
|
83011
|
-
|
83012
|
-
|
83013
|
-
|
83014
|
-
|
83015
|
-
|
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
|
83051
|
-
});
|
83052
|
-
|
83053
|
-
|
83054
|
-
|
83055
|
-
|
83056
|
-
|
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
|
-
|
83037
|
+
nextState[name] = true;
|
83059
83038
|
}
|
83060
|
-
|
83061
|
-
|
83062
|
-
|
83063
|
-
|
83064
|
-
|
83065
|
-
|
83066
|
-
const
|
83067
|
-
|
83068
|
-
|
83069
|
-
|
83070
|
-
|
83071
|
-
|
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: {
|
83076
|
-
|
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, {
|
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
|
-
...
|
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
|
-
|
83130
|
+
XAxis,
|
83088
83131
|
{
|
83089
|
-
...
|
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
|
-
|
83138
|
+
YAxis,
|
83094
83139
|
{
|
83095
|
-
...
|
83096
|
-
|
83097
|
-
|
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(
|
83104
|
-
React.Children.map(children, (child) => /* @__PURE__ */ React.createElement(
|
83145
|
+
shapes.map((shape, index2) => /* @__PURE__ */ React.createElement(
|
83105
83146
|
Bar$1,
|
83106
83147
|
{
|
83107
|
-
|
83108
|
-
|
83109
|
-
|
83110
|
-
|
83111
|
-
|
83112
|
-
|
83113
|
-
|
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
|
-
|
83120
|
-
|
83156
|
+
showLabels ? /* @__PURE__ */ React.createElement(
|
83157
|
+
LabelList,
|
83121
83158
|
{
|
83122
|
-
|
83123
|
-
|
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
|
-
|
83130
|
-
|
83131
|
-
|
83132
|
-
|
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 (
|
83138
|
-
return
|
83174
|
+
if (index2 === length - 1) {
|
83175
|
+
return isHorizontal ? [0, 3, 3, 0] : [3, 3, 0, 0];
|
83139
83176
|
}
|
83140
|
-
|
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
|
-
|
83148
|
-
|
83149
|
-
|
83150
|
-
|
83151
|
-
|
83152
|
-
|
83153
|
-
|
83154
|
-
|
83155
|
-
|
83156
|
-
|
83157
|
-
|
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
|
83173
|
-
"bg-grey-200": isSelected
|
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
|
-
|
83180
|
-
|
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
|
-
|
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 =
|
83283
|
+
const DONUT_WIDTH = 24;
|
83213
83284
|
const HOVER_DONUT_WIDTH = 10;
|
83214
|
-
const CenteredLabel = ({ radius,
|
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:
|
83225
|
-
width:
|
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]
|
83255
|
-
opacity: 0.
|
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
|
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 =
|
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
|
-
}, [
|
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
|
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
|
-
|
83302
|
-
|
83303
|
-
|
83304
|
-
|
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 =
|
83366
|
+
const pieProps = data.find((item) => item.id === pieId);
|
83316
83367
|
onClick(pieProps);
|
83317
83368
|
}
|
83318
83369
|
},
|
83319
|
-
[onClick,
|
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 =
|
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
|
83333
|
-
}, [hoveredItem, selectedItem
|
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) =>
|
83389
|
+
return hoveredItem.map((itemId) => data.findIndex((element) => element.id === itemId));
|
83340
83390
|
}
|
83341
|
-
return selectedItem.map((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)
|
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
|
-
|
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
|
-
|
83362
|
-
|
83363
|
-
|
83364
|
-
|
83365
|
-
|
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
|
-
|
83467
|
+
XAxis,
|
83369
83468
|
{
|
83370
|
-
|
83371
|
-
|
83372
|
-
label,
|
83373
|
-
total,
|
83374
|
-
formatter,
|
83375
|
-
showLegend
|
83469
|
+
...getAxisProps(xAxisScale, xAxisTickFormatter, dataKey),
|
83470
|
+
hide: !showXAxis
|
83376
83471
|
}
|
83377
83472
|
),
|
83378
|
-
/* @__PURE__ */ React.createElement(
|
83379
|
-
|
83380
|
-
|
83381
|
-
|
83382
|
-
|
83383
|
-
|
83384
|
-
|
83385
|
-
|
83386
|
-
|
83387
|
-
|
83388
|
-
|
83389
|
-
|
83390
|
-
|
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
|
83433
|
-
|
83434
|
-
|
83435
|
-
|
83436
|
-
return
|
83437
|
-
|
83438
|
-
|
83439
|
-
|
83440
|
-
|
83441
|
-
|
83442
|
-
|
83443
|
-
|
83444
|
-
|
83445
|
-
|
83446
|
-
|
83447
|
-
|
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
|
-
|
83450
|
-
|
83451
|
-
|
83452
|
-
|
83453
|
-
|
83454
|
-
|
83455
|
-
|
83456
|
-
|
83457
|
-
|
83458
|
-
|
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;
|