@mantine᜵charts-umd

UMD build of @mantine/charts

This script should not be not be installed directly. It is a library for other scripts to include with the meta directive // @require https://update.greasyfork.org/scripts/518747/1490441/%40mantine%E1%9C%B5charts-umd.js

(function (global, factory) {
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react/jsx-runtime'), require('@mantine/core'), require('react'), require('recharts'), require('@mantine/hooks')) :
  typeof define === 'function' && define.amd ? define(['exports', 'react/jsx-runtime', '@mantine/core', 'react', 'recharts', '@mantine/hooks'], factory) :
  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.MantineCharts = {}, global.ReactJSXRuntime, global.MantineCore, global.React, global.Recharts, global.MantineHooks));
})(this, (function (exports, jsxRuntime, core, react, recharts, hooks) { 'use strict';

  function getSeriesLabels(series) {
    if (!series) {
      return {};
    }
    return series.reduce((acc, item) => {
      const matchFound = item.name.search(/\./);
      if (matchFound >= 0) {
        const key = item.name.substring(matchFound + 1);
        acc[key] = item.label;
        return acc;
      }
      acc[item.name] = item.label;
      return acc;
    }, {});
  }

  var classes = { "tooltip": "m_e4d36c9b", "tooltipLabel": "m_7f4bcb19", "tooltipBody": "m_3de554dd", "tooltipItemColor": "m_b30369b5", "tooltipItem": "m_3de8964e", "tooltipItemBody": "m_50186d10", "tooltipItemName": "m_501dadf9", "tooltipItemData": "m_50192318" };

  function updateChartTooltipPayload(payload) {
    return payload.map((item) => {
      if (!item.payload || item.payload[item.name]) {
        return item;
      }
      const matchFound = item.name.search(/\./);
      if (matchFound >= 0) {
        const newDataKey = item.name.substring(0, matchFound);
        const nestedPayload = { ...item.payload[newDataKey] };
        const shallowPayload = Object.entries(item.payload).reduce((acc, current) => {
          const [k, v] = current;
          return k === newDataKey ? acc : { ...acc, [k]: v };
        }, {});
        return {
          ...item,
          name: item.name.substring(matchFound + 1),
          payload: {
            ...shallowPayload,
            ...nestedPayload
          }
        };
      }
      return item;
    });
  }
  function getFilteredChartTooltipPayload(payload, segmentId) {
    const duplicatesFilter = updateChartTooltipPayload(
      payload.filter((item) => item.fill !== "none" || !item.color)
    );
    if (!segmentId) {
      return duplicatesFilter;
    }
    return duplicatesFilter.filter((item) => item.name === segmentId);
  }
  function getData(item, type) {
    if (type === "radial" || type === "scatter") {
      if (Array.isArray(item.value)) {
        return item.value[1] - item.value[0];
      }
      return item.value;
    }
    if (Array.isArray(item.payload[item.dataKey])) {
      return item.payload[item.dataKey][1] - item.payload[item.dataKey][0];
    }
    return item.payload[item.name];
  }
  var defaultProps = {
    type: "area",
    showColor: true
  };
  var ChartTooltip = core.factory((_props, ref) => {
    const props = core.useProps("ChartTooltip", defaultProps, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      payload,
      label,
      unit,
      type,
      segmentId,
      mod,
      series,
      valueFormatter,
      showColor,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "ChartTooltip",
      classes,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled
    });
    if (!payload) {
      return null;
    }
    const filteredPayload = getFilteredChartTooltipPayload(payload, segmentId);
    const scatterLabel = type === "scatter" ? payload[0]?.payload?.name : null;
    const labels = getSeriesLabels(series);
    const _label = label || scatterLabel;
    const items = filteredPayload.map((item) =>  jsxRuntime.jsxs("div", { "data-type": type, ...getStyles("tooltipItem"), children: [
       jsxRuntime.jsxs("div", { ...getStyles("tooltipItemBody"), children: [
        showColor &&  jsxRuntime.jsx("svg", { ...getStyles("tooltipItemColor"), children:  jsxRuntime.jsx(
          "circle",
          {
            r: 6,
            fill: core.getThemeColor(item.color, theme),
            width: 12,
            height: 12,
            cx: 6,
            cy: 6
          }
        ) }),
         jsxRuntime.jsx("div", { ...getStyles("tooltipItemName"), children: labels[item.name] || item.name })
      ] }),
       jsxRuntime.jsxs("div", { ...getStyles("tooltipItemData"), children: [
        typeof valueFormatter === "function" ? valueFormatter(getData(item, type)) : getData(item, type),
        unit || item.unit
      ] })
    ] }, item?.key ?? item.name));
    return  jsxRuntime.jsxs(core.Box, { ...getStyles("tooltip"), mod: [{ type }, mod], ref, ...others, children: [
      _label &&  jsxRuntime.jsx("div", { ...getStyles("tooltipLabel"), children: _label }),
       jsxRuntime.jsx("div", { ...getStyles("tooltipBody"), children: items })
    ] });
  });
  ChartTooltip.displayName = "@mantine/charts/ChartTooltip";

  var classes2 = { "legend": "m_847eaf", "legendItem": "m_17da7e62", "legendItemColor": "m_6e236e21", "legendItemName": "m_8ff56c0d" };

  function updateChartLegendPayload(payload) {
    return payload.map((item) => {
      const newDataKey = item.dataKey?.split(".").pop();
      return {
        ...item,
        dataKey: newDataKey,
        payload: {
          ...item.payload,
          name: newDataKey,
          dataKey: newDataKey
        }
      };
    });
  }
  function getFilteredChartLegendPayload(payload) {
    return updateChartLegendPayload(payload.filter((item) => item.color !== "none"));
  }
  var defaultProps2 = {};
  var ChartLegend = core.factory((_props, ref) => {
    const props = core.useProps("ChartLegend", defaultProps2, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      payload,
      onHighlight,
      legendPosition,
      mod,
      series,
      showColor,
      centered,
      ...others
    } = props;
    const getStyles = core.useStyles({
      name: "ChartLegend",
      classes: classes2,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled
    });
    if (!payload) {
      return null;
    }
    const filteredPayload = getFilteredChartLegendPayload(payload);
    const labels = getSeriesLabels(series);
    const items = filteredPayload.map((item, index) =>  jsxRuntime.jsxs(
      "div",
      {
        ...getStyles("legendItem"),
        onMouseEnter: () => onHighlight(item.dataKey),
        onMouseLeave: () => onHighlight(null),
        "data-without-color": showColor === false || void 0,
        children: [
           jsxRuntime.jsx(
            core.ColorSwatch,
            {
              color: item.color,
              size: 12,
              ...getStyles("legendItemColor"),
              withShadow: false
            }
          ),
           jsxRuntime.jsx("p", { ...getStyles("legendItemName"), children: labels[item.dataKey] || item.dataKey })
        ]
      },
      index
    ));
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        mod: [{ position: legendPosition, centered }, mod],
        ...getStyles("legend"),
        ...others,
        children: items
      }
    );
  });
  ChartLegend.displayName = "@mantine/charts/ChartLegend";
  function PointLabel({ x, y, value }) {
    return  jsxRuntime.jsx("g", { transform: `translate(${x},${y})`, children:  jsxRuntime.jsx(
      "text",
      {
        x: 0,
        y: 0,
        dy: -8,
        dx: -10,
        textAnchor: "top",
        fill: "var(--chart-text-color, var(--mantine-color-dimmed))",
        fontSize: 8,
        children: value
      }
    ) });
  }
  function AreaGradient({ color, id, withGradient, fillOpacity }) {
    return  jsxRuntime.jsx(jsxRuntime.Fragment, { children: withGradient ?  jsxRuntime.jsxs("linearGradient", { id, x1: "0", y1: "0", x2: "0", y2: "1", children: [
       jsxRuntime.jsx("stop", { offset: "0%", stopColor: color, stopOpacity: fillOpacity }),
       jsxRuntime.jsx("stop", { offset: "100%", stopColor: color, stopOpacity: 0.01 })
    ] }) :  jsxRuntime.jsx("linearGradient", { id, x1: "0", y1: "0", x2: "0", y2: "1", children:  jsxRuntime.jsx("stop", { stopColor: color, stopOpacity: fillOpacity ?? 0.2 }) }) });
  }
  AreaGradient.displayName = "@mantine/charts/AreaGradient";
  function AreaSplit({ offset, id, colors, fillOpacity }) {
    const theme = core.useMantineTheme();
    return  jsxRuntime.jsxs("linearGradient", { id, x1: "0", y1: "0", x2: "0", y2: "1", children: [
       jsxRuntime.jsx(
        "stop",
        {
          offset,
          stopColor: core.getThemeColor(colors[0], theme),
          stopOpacity: fillOpacity ?? 0.2
        }
      ),
       jsxRuntime.jsx(
        "stop",
        {
          offset,
          stopColor: core.getThemeColor(colors[1], theme),
          stopOpacity: fillOpacity ?? 0.2
        }
      )
    ] });
  }
  AreaSplit.displayName = "@mantine/charts/AreaSplit";

  function getSplitOffset({ data, dataKey }) {
    const dataMax = Math.max(...data.map((item) => item[dataKey]));
    const dataMin = Math.min(...data.map((item) => item[dataKey]));
    if (dataMax <= 0) {
      return 0;
    }
    if (dataMin >= 0) {
      return 1;
    }
    return dataMax / (dataMax - dataMin);
  }
  function getDefaultSplitOffset({ data, series }) {
    if (series.length === 1) {
      const dataKey = series[0].name;
      return getSplitOffset({ data, dataKey });
    }
    return 0.5;
  }

  var classes3 = { "root": "m_a50f3e58", "container": "m_af9188cb", "grid": "m_a50a48bc", "axis": "m_a507a517", "axisLabel": "m_2293801d", "tooltip": "m_92b296cd" };

  function valueToPercent(value) {
    return `${(value * 100).toFixed(0)}%`;
  }
  var defaultProps3 = {
    withXAxis: true,
    withYAxis: true,
    withDots: true,
    withTooltip: true,
    connectNulls: true,
    strokeWidth: 2,
    tooltipAnimationDuration: 0,
    fillOpacity: 0.2,
    tickLine: "y",
    strokeDasharray: "5 5",
    curveType: "monotone",
    gridAxis: "x",
    type: "default",
    splitColors: ["green.7", "red.7"],
    orientation: "horizontal"
  };
  var varsResolver = core.createVarsResolver((theme, { textColor, gridColor }) => ({
    root: {
      "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
      "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0
    }
  }));
  var AreaChart = core.factory((_props, ref) => {
    const props = core.useProps("AreaChart", defaultProps3, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      series,
      withGradient,
      dataKey,
      withXAxis,
      withYAxis,
      curveType,
      gridProps,
      withDots,
      tickLine,
      strokeDasharray,
      gridAxis,
      unit,
      yAxisProps,
      xAxisProps,
      dotProps,
      activeDotProps,
      strokeWidth,
      tooltipAnimationDuration,
      type,
      legendProps,
      tooltipProps,
      withLegend,
      withTooltip,
      areaChartProps,
      fillOpacity,
      splitColors,
      splitOffset,
      connectNulls,
      onMouseLeave,
      orientation,
      referenceLines,
      dir,
      valueFormatter,
      children,
      areaProps,
      xAxisLabel,
      yAxisLabel,
      withRightYAxis,
      rightYAxisLabel,
      rightYAxisProps,
      withPointLabels,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const baseId = react.useId();
    const splitId = `${baseId}-split`;
    const withXTickLine = gridAxis !== "none" && (tickLine === "x" || tickLine === "xy");
    const withYTickLine = gridAxis !== "none" && (tickLine === "y" || tickLine === "xy");
    const isAnimationActive = (tooltipAnimationDuration || 0) > 0;
    const _withGradient = typeof withGradient === "boolean" ? withGradient : type === "default";
    const stacked = type === "stacked" || type === "percent";
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const shouldHighlight = highlightedArea !== null;
    const handleMouseLeave = (event) => {
      setHighlightedArea(null);
      onMouseLeave?.(event);
    };
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const getStyles = core.useStyles({
      name: "AreaChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver
    });
    const dotsAreas = series.map((item) => {
      const color = core.getThemeColor(item.color, theme);
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      return  react.createElement(
        recharts.Area,
        {
          ...getStyles("area"),
          activeDot: { fill: theme.white, stroke: color, strokeWidth: 2, r: 4, ...activeDotProps },
          dot: { fill: color, fillOpacity: dimmed ? 0 : 1, strokeWidth: 2, r: 4, ...dotProps },
          key: item.name,
          name: item.name,
          type: curveType,
          dataKey: item.name,
          fill: "none",
          strokeWidth,
          stroke: "none",
          isAnimationActive: false,
          connectNulls,
          stackId: stacked ? "stack-dots" : void 0,
          yAxisId: item.yAxisId || "left",
          ...typeof areaProps === "function" ? areaProps(item) : areaProps
        }
      );
    });
    const areas = series.map((item) => {
      const id = `${baseId}-${item.color.replace(/[^a-zA-Z0-9]/g, "")}`;
      const color = core.getThemeColor(item.color, theme);
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      return  jsxRuntime.jsxs(react.Fragment, { children: [
         jsxRuntime.jsx("defs", { children:  jsxRuntime.jsx(
          AreaGradient,
          {
            color,
            withGradient: _withGradient,
            id,
            fillOpacity
          }
        ) }),
         jsxRuntime.jsx(
          recharts.Area,
          {
            ...getStyles("area"),
            activeDot: false,
            dot: false,
            name: item.name,
            type: curveType,
            dataKey: item.name,
            fill: type === "split" ? `url(#${splitId})` : `url(#${id})`,
            strokeWidth,
            stroke: color,
            isAnimationActive: false,
            connectNulls,
            stackId: stacked ? "stack" : void 0,
            fillOpacity: dimmed ? 0 : 1,
            strokeOpacity: dimmed ? 0.5 : 1,
            strokeDasharray: item.strokeDasharray,
            yAxisId: item.yAxisId || "left",
            label: withPointLabels ?  jsxRuntime.jsx(PointLabel, {}) : void 0,
            ...typeof areaProps === "function" ? areaProps(item) : areaProps
          }
        )
      ] }, item.name);
    });
    const referenceLinesItems = referenceLines?.map((line, index) => {
      const color = core.getThemeColor(line.color, theme);
      return  jsxRuntime.jsx(
        recharts.ReferenceLine,
        {
          stroke: line.color ? color : "var(--chart-grid-color)",
          strokeWidth: 1,
          yAxisId: line.yAxisId || "left",
          ...line,
          label: {
            value: line.label,
            fill: line.color ? color : "currentColor",
            fontSize: 12,
            position: line.labelPosition ?? "insideBottomLeft"
          },
          ...getStyles("referenceLine")
        },
        index
      );
    });
    const tickFormatter = type === "percent" ? valueToPercent : valueFormatter;
    const sharedYAxisProps = {
      axisLine: false,
      ...orientation === "vertical" ? { dataKey, type: "category" } : { type: "number" },
      tickLine: withYTickLine ? { stroke: "currentColor" } : false,
      allowDecimals: true,
      unit,
      tickFormatter: orientation === "vertical" ? void 0 : tickFormatter,
      ...getStyles("axis")
    };
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        ...getStyles("root"),
        onMouseLeave: handleMouseLeave,
        dir: dir || "ltr",
        ...others,
        children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(
          recharts.AreaChart,
          {
            data,
            stackOffset: type === "percent" ? "expand" : void 0,
            layout: orientation,
            margin: {
              bottom: xAxisLabel ? 30 : void 0,
              left: yAxisLabel ? 10 : void 0,
              right: yAxisLabel ? 5 : void 0
            },
            ...areaChartProps,
            children: [
              referenceLinesItems,
              withLegend &&  jsxRuntime.jsx(
                recharts.Legend,
                {
                  verticalAlign: "top",
                  content: (payload) =>  jsxRuntime.jsx(
                    ChartLegend,
                    {
                      payload: payload.payload,
                      onHighlight: setHighlightedArea,
                      legendPosition: legendProps?.verticalAlign || "top",
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series
                    }
                  ),
                  ...legendProps
                }
              ),
               jsxRuntime.jsx(
                recharts.CartesianGrid,
                {
                  strokeDasharray,
                  vertical: gridAxis === "y" || gridAxis === "xy",
                  horizontal: gridAxis === "x" || gridAxis === "xy",
                  ...getStyles("grid"),
                  ...gridProps
                }
              ),
               jsxRuntime.jsxs(
                recharts.XAxis,
                {
                  hide: !withXAxis,
                  ...orientation === "vertical" ? { type: "number" } : { dataKey },
                  tick: { transform: "translate(0, 10)", fontSize: 12, fill: "currentColor" },
                  stroke: "",
                  interval: "preserveStartEnd",
                  tickLine: withXTickLine ? { stroke: "currentColor" } : false,
                  minTickGap: 5,
                  tickFormatter: orientation === "vertical" ? tickFormatter : void 0,
                  ...getStyles("axis"),
                  ...xAxisProps,
                  children: [
                    xAxisLabel &&  jsxRuntime.jsx(recharts.Label, { position: "insideBottom", offset: -20, fontSize: 12, ...getStyles("axisLabel"), children: xAxisLabel }),
                    xAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "left",
                  orientation: "left",
                  tick: { transform: "translate(-10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withYAxis,
                  ...sharedYAxisProps,
                  ...yAxisProps,
                  children: [
                    yAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideLeft",
                        angle: -90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: yAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "right",
                  orientation: "right",
                  tick: { transform: "translate(10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withRightYAxis,
                  ...sharedYAxisProps,
                  ...rightYAxisProps,
                  children: [
                    rightYAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideRight",
                        angle: 90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: rightYAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
              withTooltip &&  jsxRuntime.jsx(
                recharts.Tooltip,
                {
                  animationDuration: tooltipAnimationDuration,
                  isAnimationActive,
                  position: orientation === "vertical" ? {} : { y: 0 },
                  cursor: {
                    stroke: "var(--chart-grid-color)",
                    strokeWidth: 1,
                    strokeDasharray
                  },
                  content: ({ label, payload }) =>  jsxRuntime.jsx(
                    ChartTooltip,
                    {
                      label,
                      payload,
                      unit,
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      valueFormatter
                    }
                  ),
                  ...tooltipProps
                }
              ),
              type === "split" &&  jsxRuntime.jsx("defs", { children:  jsxRuntime.jsx(
                AreaSplit,
                {
                  colors: splitColors,
                  id: splitId,
                  offset: splitOffset ?? getDefaultSplitOffset({ data, series }),
                  fillOpacity
                }
              ) }),
              areas,
              withDots && dotsAreas,
              children
            ]
          }
        ) })
      }
    );
  });
  AreaChart.classes = classes3;
  AreaChart.displayName = "@mantine/charts/AreaChart";
  function BarLabel({
    value,
    valueFormatter,
    textBreakAll,
    parentViewBox,
    orientation,
    viewBox,
    width,
    height,
    ...others
  }) {
    return  jsxRuntime.jsx(
      "text",
      {
        ...others,
        dy: orientation === "vertical" ? height / 2 + 4 : -10,
        dx: orientation === "vertical" ? width - 30 : 0,
        fontSize: 12,
        fill: "var(--chart-bar-label-color, var(--mantine-color-dimmed))",
        children: typeof valueFormatter === "function" ? valueFormatter(value) : value
      }
    );
  }

  function valueToPercent2(value) {
    return `${(value * 100).toFixed(0)}%`;
  }
  var defaultProps4 = {
    withXAxis: true,
    withYAxis: true,
    withTooltip: true,
    tooltipAnimationDuration: 0,
    fillOpacity: 1,
    tickLine: "y",
    strokeDasharray: "5 5",
    gridAxis: "x",
    type: "default"
  };
  var varsResolver2 = core.createVarsResolver(
    (theme, { textColor, gridColor, cursorFill, barLabelColor }) => ({
      root: {
        "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
        "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0,
        "--chart-cursor-fill": cursorFill ? core.getThemeColor(cursorFill, theme) : void 0,
        "--chart-bar-label-color": barLabelColor ? core.getThemeColor(barLabelColor, theme) : void 0
      }
    })
  );
  function calculateCumulativeTotal(waterfallData, dataKey) {
    let start = 0;
    let end = 0;
    return waterfallData.map((item) => {
      if (item.standalone) {
        for (const prop in item) {
          if (typeof item[prop] === "number" && prop !== dataKey) {
            item[prop] = [0, item[prop]];
          }
        }
      } else {
        for (const prop in item) {
          if (typeof item[prop] === "number" && prop !== dataKey) {
            end += item[prop];
            item[prop] = [start, end];
            start = end;
          }
        }
      }
      return item;
    });
  }
  function getBarFill(barProps, series) {
    if (typeof barProps === "function") {
      return barProps(series).fill;
    }
    return barProps?.fill;
  }
  var BarChart = core.factory((_props, ref) => {
    const props = core.useProps("BarChart", defaultProps4, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withLegend,
      legendProps,
      series,
      onMouseLeave,
      dataKey,
      withTooltip,
      withXAxis,
      withYAxis,
      gridAxis,
      tickLine,
      xAxisProps,
      yAxisProps,
      unit,
      tooltipAnimationDuration,
      strokeDasharray,
      gridProps,
      tooltipProps,
      referenceLines,
      fillOpacity,
      barChartProps,
      type,
      orientation,
      dir,
      valueFormatter,
      children,
      barProps,
      xAxisLabel,
      yAxisLabel,
      withBarValueLabel,
      withRightYAxis,
      rightYAxisLabel,
      rightYAxisProps,
      minBarSize,
      maxBarWidth,
      mod,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const withXTickLine = gridAxis !== "none" && (tickLine === "x" || tickLine === "xy");
    const withYTickLine = gridAxis !== "none" && (tickLine === "y" || tickLine === "xy");
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const shouldHighlight = highlightedArea !== null;
    const stacked = type === "stacked" || type === "percent";
    const handleMouseLeave = (event) => {
      setHighlightedArea(null);
      onMouseLeave?.(event);
    };
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const inputData = type === "waterfall" ? calculateCumulativeTotal(data, dataKey) : data;
    const getStyles = core.useStyles({
      name: "BarChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver2
    });
    const bars = series.map((item) => {
      const color = core.getThemeColor(item.color, theme);
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      return  react.createElement(
        recharts.Bar,
        {
          ...getStyles("bar"),
          key: item.name,
          name: item.name,
          dataKey: item.name,
          fill: color,
          stroke: color,
          isAnimationActive: false,
          fillOpacity: dimmed ? 0.1 : fillOpacity,
          strokeOpacity: dimmed ? 0.2 : 0,
          stackId: stacked ? "stack" : item.stackId || void 0,
          label: withBarValueLabel ?  jsxRuntime.jsx(BarLabel, { valueFormatter, orientation }) : void 0,
          yAxisId: item.yAxisId || "left",
          minPointSize: minBarSize,
          ...typeof barProps === "function" ? barProps(item) : barProps
        },
        inputData.map((entry, index) =>  jsxRuntime.jsx(
          recharts.Cell,
          {
            fill: entry.color ? core.getThemeColor(entry.color, theme) : getBarFill(barProps, item) || color
          },
          `cell-${index}`
        ))
      );
    });
    const referenceLinesItems = referenceLines?.map((line, index) => {
      const color = core.getThemeColor(line.color, theme);
      return  jsxRuntime.jsx(
        recharts.ReferenceLine,
        {
          stroke: line.color ? color : "var(--chart-grid-color)",
          strokeWidth: 1,
          yAxisId: line.yAxisId || "left",
          ...line,
          label: {
            value: line.label,
            fill: line.color ? color : "currentColor",
            fontSize: 12,
            position: line.labelPosition ?? "insideBottomLeft"
          },
          ...getStyles("referenceLine")
        },
        index
      );
    });
    const tickFormatter = type === "percent" ? valueToPercent2 : valueFormatter;
    const sharedYAxisProps = {
      axisLine: false,
      ...orientation === "vertical" ? { dataKey, type: "category" } : { type: "number" },
      tickLine: withYTickLine ? { stroke: "currentColor" } : false,
      allowDecimals: true,
      unit,
      tickFormatter: orientation === "vertical" ? void 0 : tickFormatter,
      ...getStyles("axis")
    };
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        ...getStyles("root"),
        onMouseLeave: handleMouseLeave,
        dir: dir || "ltr",
        mod: [{ orientation }, mod],
        ...others,
        children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(
          recharts.BarChart,
          {
            data: inputData,
            stackOffset: type === "percent" ? "expand" : void 0,
            layout: orientation,
            maxBarSize: maxBarWidth,
            margin: {
              bottom: xAxisLabel ? 30 : void 0,
              left: yAxisLabel ? 10 : void 0,
              right: yAxisLabel ? 5 : void 0
            },
            ...barChartProps,
            children: [
              withLegend &&  jsxRuntime.jsx(
                recharts.Legend,
                {
                  verticalAlign: "top",
                  content: (payload) =>  jsxRuntime.jsx(
                    ChartLegend,
                    {
                      payload: payload.payload,
                      onHighlight: setHighlightedArea,
                      legendPosition: legendProps?.verticalAlign || "top",
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      showColor: type !== "waterfall"
                    }
                  ),
                  ...legendProps
                }
              ),
               jsxRuntime.jsxs(
                recharts.XAxis,
                {
                  hide: !withXAxis,
                  ...orientation === "vertical" ? { type: "number" } : { dataKey },
                  tick: { transform: "translate(0, 10)", fontSize: 12, fill: "currentColor" },
                  stroke: "",
                  interval: "preserveStartEnd",
                  tickLine: withXTickLine ? { stroke: "currentColor" } : false,
                  minTickGap: 5,
                  tickFormatter: orientation === "vertical" ? tickFormatter : void 0,
                  ...getStyles("axis"),
                  ...xAxisProps,
                  children: [
                    xAxisLabel &&  jsxRuntime.jsx(recharts.Label, { position: "insideBottom", offset: -20, fontSize: 12, ...getStyles("axisLabel"), children: xAxisLabel }),
                    xAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "left",
                  orientation: "left",
                  tick: { transform: "translate(-10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withYAxis,
                  ...sharedYAxisProps,
                  ...yAxisProps,
                  children: [
                    yAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideLeft",
                        angle: -90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: yAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "right",
                  orientation: "right",
                  tick: { transform: "translate(10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withRightYAxis,
                  ...sharedYAxisProps,
                  ...rightYAxisProps,
                  children: [
                    rightYAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideRight",
                        angle: 90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: rightYAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsx(
                recharts.CartesianGrid,
                {
                  strokeDasharray,
                  vertical: gridAxis === "y" || gridAxis === "xy",
                  horizontal: gridAxis === "x" || gridAxis === "xy",
                  ...getStyles("grid"),
                  ...gridProps
                }
              ),
              withTooltip &&  jsxRuntime.jsx(
                recharts.Tooltip,
                {
                  animationDuration: tooltipAnimationDuration,
                  isAnimationActive: tooltipAnimationDuration !== 0,
                  position: orientation === "vertical" ? {} : { y: 0 },
                  cursor: {
                    stroke: "var(--chart-grid-color)",
                    strokeWidth: 1,
                    strokeDasharray,
                    fill: "var(--chart-cursor-fill)"
                  },
                  content: ({ label, payload }) =>  jsxRuntime.jsx(
                    ChartTooltip,
                    {
                      label,
                      payload,
                      type: type === "waterfall" ? "scatter" : void 0,
                      unit,
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      valueFormatter
                    }
                  ),
                  ...tooltipProps
                }
              ),
              bars,
              referenceLinesItems,
              children
            ]
          }
        ) })
      }
    );
  });
  BarChart.displayName = "@mantine/charts/BarChart";
  BarChart.classes = classes3;
  var defaultProps5 = {
    withXAxis: true,
    withYAxis: true,
    withTooltip: true,
    tooltipAnimationDuration: 0,
    fillOpacity: 1,
    tickLine: "y",
    strokeDasharray: "5 5",
    gridAxis: "x",
    withDots: true,
    connectNulls: true,
    strokeWidth: 2,
    curveType: "monotone",
    gradientStops: [
      { offset: 0, color: "red" },
      { offset: 100, color: "blue" }
    ]
  };
  var varsResolver3 = core.createVarsResolver((theme, { textColor, gridColor }) => ({
    root: {
      "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
      "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0
    }
  }));
  var LineChart = core.factory((_props, ref) => {
    const props = core.useProps("LineChart", defaultProps5, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withLegend,
      legendProps,
      series,
      onMouseLeave,
      dataKey,
      withTooltip,
      withXAxis,
      withYAxis,
      gridAxis,
      tickLine,
      xAxisProps,
      yAxisProps,
      unit,
      tooltipAnimationDuration,
      strokeDasharray,
      gridProps,
      tooltipProps,
      referenceLines,
      withDots,
      dotProps,
      activeDotProps,
      strokeWidth,
      lineChartProps,
      connectNulls,
      fillOpacity,
      curveType,
      orientation,
      dir,
      valueFormatter,
      children,
      lineProps,
      xAxisLabel,
      yAxisLabel,
      type,
      gradientStops,
      withRightYAxis,
      rightYAxisLabel,
      rightYAxisProps,
      withPointLabels,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const withXTickLine = gridAxis !== "none" && (tickLine === "x" || tickLine === "xy");
    const withYTickLine = gridAxis !== "none" && (tickLine === "y" || tickLine === "xy");
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const shouldHighlight = highlightedArea !== null;
    const handleMouseLeave = (event) => {
      setHighlightedArea(null);
      onMouseLeave?.(event);
    };
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const getStyles = core.useStyles({
      name: "LineChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver3
    });
    const id = hooks.useId();
    const gradientId = `line-chart-gradient-${id}`;
    const stops = gradientStops?.map((stop) =>  jsxRuntime.jsx(
      "stop",
      {
        offset: `${stop.offset}%`,
        stopColor: core.getThemeColor(stop.color, theme)
      },
      stop.color
    ));
    const lines = series.map((item) => {
      const color = core.getThemeColor(item.color, theme);
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      return  react.createElement(
        recharts.Line,
        {
          ...getStyles("line"),
          key: item.name,
          name: item.name,
          dataKey: item.name,
          dot: withDots ? {
            fillOpacity: dimmed ? 0 : 1,
            strokeOpacity: dimmed ? 0 : 1,
            strokeWidth: 1,
            fill: type === "gradient" ? "var(--mantine-color-gray-7)" : color,
            stroke: type === "gradient" ? "white" : color,
            ...dotProps
          } : false,
          activeDot: withDots ? {
            fill: type === "gradient" ? "var(--mantine-color-gray-7)" : color,
            stroke: type === "gradient" ? "white" : color,
            ...activeDotProps
          } : false,
          fill: color,
          stroke: type === "gradient" ? `url(#${gradientId})` : color,
          strokeWidth,
          isAnimationActive: false,
          fillOpacity: dimmed ? 0 : fillOpacity,
          strokeOpacity: dimmed ? 0.5 : fillOpacity,
          connectNulls,
          type: curveType,
          strokeDasharray: item.strokeDasharray,
          yAxisId: item.yAxisId || "left",
          label: withPointLabels ?  jsxRuntime.jsx(PointLabel, {}) : void 0,
          ...typeof lineProps === "function" ? lineProps(item) : lineProps
        }
      );
    });
    const referenceLinesItems = referenceLines?.map((line, index) => {
      const color = core.getThemeColor(line.color, theme);
      return  jsxRuntime.jsx(
        recharts.ReferenceLine,
        {
          stroke: line.color ? color : "var(--chart-grid-color)",
          strokeWidth: 1,
          yAxisId: line.yAxisId || "left",
          ...line,
          label: {
            value: line.label,
            fill: line.color ? color : "currentColor",
            fontSize: 12,
            position: line.labelPosition ?? "insideBottomLeft"
          },
          ...getStyles("referenceLine")
        },
        index
      );
    });
    const sharedYAxisProps = {
      axisLine: false,
      ...orientation === "vertical" ? { dataKey, type: "category" } : { type: "number" },
      tickLine: withYTickLine ? { stroke: "currentColor" } : false,
      allowDecimals: true,
      unit,
      tickFormatter: orientation === "vertical" ? void 0 : valueFormatter,
      ...getStyles("axis")
    };
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        ...getStyles("root"),
        onMouseLeave: handleMouseLeave,
        dir: dir || "ltr",
        ...others,
        children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(
          recharts.LineChart,
          {
            data,
            layout: orientation,
            margin: {
              bottom: xAxisLabel ? 30 : void 0,
              left: yAxisLabel ? 10 : void 0,
              right: yAxisLabel ? 5 : void 0
            },
            ...lineChartProps,
            children: [
              type === "gradient" &&  jsxRuntime.jsx("defs", { children:  jsxRuntime.jsx("linearGradient", { id: gradientId, x1: "0", y1: "0", x2: "0", y2: "1", children: stops }) }),
              withLegend &&  jsxRuntime.jsx(
                recharts.Legend,
                {
                  verticalAlign: "top",
                  content: (payload) =>  jsxRuntime.jsx(
                    ChartLegend,
                    {
                      payload: payload.payload,
                      onHighlight: setHighlightedArea,
                      legendPosition: legendProps?.verticalAlign || "top",
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      showColor: type !== "gradient"
                    }
                  ),
                  ...legendProps
                }
              ),
               jsxRuntime.jsxs(
                recharts.XAxis,
                {
                  hide: !withXAxis,
                  ...orientation === "vertical" ? { type: "number" } : { dataKey },
                  tick: { transform: "translate(0, 10)", fontSize: 12, fill: "currentColor" },
                  stroke: "",
                  interval: "preserveStartEnd",
                  tickLine: withXTickLine ? { stroke: "currentColor" } : false,
                  minTickGap: 5,
                  tickFormatter: orientation === "vertical" ? valueFormatter : void 0,
                  ...getStyles("axis"),
                  ...xAxisProps,
                  children: [
                    xAxisLabel &&  jsxRuntime.jsx(recharts.Label, { position: "insideBottom", offset: -20, fontSize: 12, ...getStyles("axisLabel"), children: xAxisLabel }),
                    xAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "left",
                  orientation: "left",
                  tick: { transform: "translate(-10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withYAxis,
                  ...sharedYAxisProps,
                  ...yAxisProps,
                  children: [
                    yAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideLeft",
                        angle: -90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: yAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "right",
                  orientation: "right",
                  tick: { transform: "translate(10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withRightYAxis,
                  ...sharedYAxisProps,
                  ...rightYAxisProps,
                  children: [
                    rightYAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideRight",
                        angle: 90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: rightYAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsx(
                recharts.CartesianGrid,
                {
                  strokeDasharray,
                  vertical: gridAxis === "y" || gridAxis === "xy",
                  horizontal: gridAxis === "x" || gridAxis === "xy",
                  ...getStyles("grid"),
                  ...gridProps
                }
              ),
              withTooltip &&  jsxRuntime.jsx(
                recharts.Tooltip,
                {
                  animationDuration: tooltipAnimationDuration,
                  isAnimationActive: tooltipAnimationDuration !== 0,
                  position: orientation === "vertical" ? {} : { y: 0 },
                  cursor: {
                    stroke: "var(--chart-grid-color)",
                    strokeWidth: 1,
                    strokeDasharray
                  },
                  content: ({ label, payload }) =>  jsxRuntime.jsx(
                    ChartTooltip,
                    {
                      label,
                      payload,
                      unit,
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      valueFormatter,
                      showColor: type !== "gradient"
                    }
                  ),
                  ...tooltipProps
                }
              ),
              lines,
              referenceLinesItems,
              children
            ]
          }
        ) })
      }
    );
  });
  LineChart.displayName = "@mantine/charts/LineChart";
  LineChart.classes = classes3;
  var classes4 = {};
  var defaultProps6 = {
    withGradient: true,
    connectNulls: true,
    fillOpacity: 0.6,
    strokeWidth: 2,
    curveType: "linear"
  };
  function getTrendColor(data, trendColors) {
    const first = data[0];
    const last = data[data.length - 1];
    if (first === null || last === null) {
      return trendColors.neutral || trendColors.positive;
    }
    if (first < last) {
      return trendColors.positive;
    }
    if (first > last) {
      return trendColors.negative;
    }
    return trendColors.neutral || trendColors.positive;
  }
  var varsResolver4 = core.createVarsResolver(
    (theme, { color, data, trendColors }) => ({
      root: {
        "--chart-color": trendColors ? core.getThemeColor(getTrendColor(data, trendColors), theme) : color ? core.getThemeColor(color, theme) : void 0
      }
    })
  );
  var Sparkline = core.factory((_props, ref) => {
    const props = core.useProps("Sparkline", defaultProps6, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withGradient,
      fillOpacity,
      curveType,
      strokeWidth,
      trendColors,
      connectNulls,
      areaProps,
      ...others
    } = props;
    const getStyles = core.useStyles({
      name: "Sparkline",
      classes: classes4,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver4
    });
    const id = react.useId();
    const mappedData = react.useMemo(() => data.map((value, index) => ({ value, index })), [data]);
    return  jsxRuntime.jsx(core.Box, { ref, ...getStyles("root"), ...others, dir: "ltr", children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(recharts.AreaChart, { data: mappedData, children: [
       jsxRuntime.jsx(
        recharts.Area,
        {
          dataKey: "value",
          type: curveType,
          fill: `url(#${id})`,
          stroke: "var(--chart-color, var(--mantine-color-blue-filled))",
          isAnimationActive: false,
          connectNulls,
          strokeWidth,
          fillOpacity: 1,
          ...areaProps
        }
      ),
       jsxRuntime.jsx("defs", { children:  jsxRuntime.jsx(
        AreaGradient,
        {
          id,
          color: "var(--chart-color, var(--mantine-color-blue-filled))",
          fillOpacity,
          withGradient
        }
      ) })
    ] }) }) });
  });
  Sparkline.displayName = "@mantine/charts/Sparkline";
  Sparkline.classes = classes4;

  var classes5 = { "root": "m_a410e613", "label": "m_ddb0bfe3" };

  var defaultProps7 = {
    withTooltip: true,
    withLabelsLine: true,
    paddingAngle: 0,
    thickness: 20,
    size: 160,
    strokeWidth: 1,
    startAngle: 0,
    endAngle: 360,
    tooltipDataSource: "all"
  };
  var varsResolver5 = core.createVarsResolver(
    (theme, { strokeColor, labelColor, withLabels, size }) => ({
      root: {
        "--chart-stroke-color": strokeColor ? core.getThemeColor(strokeColor, theme) : void 0,
        "--chart-labels-color": labelColor ? core.getThemeColor(labelColor, theme) : void 0,
        "--chart-size": withLabels ? core.rem(size + 80) : core.rem(size)
      }
    })
  );
  var DonutChart = core.factory((_props, ref) => {
    const props = core.useProps("DonutChart", defaultProps7, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withTooltip,
      tooltipAnimationDuration,
      tooltipProps,
      pieProps,
      paddingAngle,
      withLabels,
      withLabelsLine,
      size,
      thickness,
      strokeWidth,
      startAngle,
      endAngle,
      tooltipDataSource,
      chartLabel,
      children,
      pieChartProps,
      valueFormatter,
      strokeColor,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "DonutChart",
      classes: classes5,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver5
    });
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const cells = data.map((item, index) =>  jsxRuntime.jsx(
      recharts.Cell,
      {
        fill: core.getThemeColor(item.color, theme),
        stroke: "var(--chart-stroke-color, var(--mantine-color-body))",
        strokeWidth
      },
      index
    ));
    return  jsxRuntime.jsx(core.Box, { ref, size, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(recharts.PieChart, { ...pieChartProps, children: [
       jsxRuntime.jsx(
        recharts.Pie,
        {
          data,
          innerRadius: size / 2 - thickness,
          outerRadius: size / 2,
          dataKey: "value",
          isAnimationActive: false,
          paddingAngle,
          startAngle,
          endAngle,
          label: withLabels ? {
            fill: "var(--chart-labels-color, var(--mantine-color-dimmed))",
            fontSize: 12,
            fontFamily: "var(--mantine-font-family)"
          } : false,
          labelLine: withLabelsLine ? {
            stroke: "var(--chart-label-color, var(--mantine-color-dimmed))",
            strokeWidth: 1
          } : false,
          ...pieProps,
          children: cells
        }
      ),
      chartLabel &&  jsxRuntime.jsx(
        "text",
        {
          x: "50%",
          y: "50%",
          textAnchor: "middle",
          dominantBaseline: "middle",
          ...getStyles("label"),
          children: chartLabel
        }
      ),
      withTooltip &&  jsxRuntime.jsx(
        recharts.Tooltip,
        {
          animationDuration: tooltipAnimationDuration,
          isAnimationActive: false,
          content: ({ payload }) =>  jsxRuntime.jsx(
            ChartTooltip,
            {
              payload: data,
              classNames: resolvedClassNames,
              styles: resolvedStyles,
              type: "radial",
              segmentId: tooltipDataSource === "segment" ? payload?.[0]?.name : void 0,
              valueFormatter
            }
          ),
          ...tooltipProps
        }
      ),
      children
    ] }) }) });
  });
  DonutChart.displayName = "@mantine/charts/DonutChart";
  DonutChart.classes = classes5;

  var classes6 = { "root": "m_cd8943fd" };

  var defaultProps8 = {
    withTooltip: false,
    withLabelsLine: true,
    paddingAngle: 0,
    size: 160,
    strokeWidth: 1,
    startAngle: 0,
    endAngle: 360,
    tooltipDataSource: "all",
    labelsPosition: "outside",
    labelsType: "value"
  };
  var varsResolver6 = core.createVarsResolver(
    (theme, { strokeColor, labelColor, withLabels, size, labelsPosition }) => ({
      root: {
        "--chart-stroke-color": strokeColor ? core.getThemeColor(strokeColor, theme) : void 0,
        "--chart-labels-color": labelColor ? core.getThemeColor(labelColor, theme) : void 0,
        "--chart-size": withLabels && labelsPosition === "outside" ? core.rem(size + 80) : core.rem(size)
      }
    })
  );
  var getLabelValue = (labelsType, value, percent, valueFormatter) => {
    if (labelsType === "percent") {
      return `${(percent * 100).toFixed(0)}%`;
    }
    if (typeof valueFormatter === "function") {
      return valueFormatter(value);
    }
    return value;
  };
  var getInsideLabel = (labelsType, valueFormatter) => ({ cx, cy, midAngle, innerRadius, outerRadius, value, percent }) => {
    const RADIAN = Math.PI / 180;
    const radius = innerRadius + (outerRadius - innerRadius) * 0.5;
    const x = cx + radius * Math.cos(-midAngle * RADIAN);
    const y = cy + radius * Math.sin(-midAngle * RADIAN);
    return  jsxRuntime.jsx(
      "text",
      {
        x,
        y,
        textAnchor: x > cx ? "start" : "end",
        dominantBaseline: "central",
        className: classes6.label,
        children: getLabelValue(labelsType, value, percent, valueFormatter)
      }
    );
  };
  var getOutsideLabel = (labelsType, valueFormatter) => ({ x, y, cx, cy, percent, value }) =>  jsxRuntime.jsx(
    "text",
    {
      x,
      y,
      cx,
      cy,
      textAnchor: x > cx ? "start" : "end",
      fill: "var(--chart-labels-color, var(--mantine-color-dimmed))",
      fontFamily: "var(--mantine-font-family)",
      fontSize: 12,
      children:  jsxRuntime.jsx("tspan", { x, children: getLabelValue(labelsType, value, percent, valueFormatter) })
    }
  );
  var PieChart2 = core.factory((_props, ref) => {
    const props = core.useProps("PieChart", defaultProps8, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withTooltip,
      tooltipAnimationDuration,
      tooltipProps,
      pieProps,
      paddingAngle,
      withLabels,
      withLabelsLine,
      size,
      strokeWidth,
      startAngle,
      endAngle,
      tooltipDataSource,
      children,
      pieChartProps,
      labelsPosition,
      valueFormatter,
      labelsType,
      strokeColor,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "PieChart",
      classes: classes6,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver6
    });
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const cells = data.map((item, index) =>  jsxRuntime.jsx(
      recharts.Cell,
      {
        fill: core.getThemeColor(item.color, theme),
        stroke: "var(--chart-stroke-color, var(--mantine-color-body))",
        strokeWidth
      },
      index
    ));
    return  jsxRuntime.jsx(core.Box, { ref, size, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(recharts.PieChart, { ...pieChartProps, children: [
       jsxRuntime.jsx(
        recharts.Pie,
        {
          data,
          innerRadius: 0,
          outerRadius: size / 2,
          dataKey: "value",
          isAnimationActive: false,
          paddingAngle,
          startAngle,
          endAngle,
          label: withLabels ? labelsPosition === "inside" ? getInsideLabel(labelsType || "value", valueFormatter) : getOutsideLabel(labelsType || "value", valueFormatter) : false,
          labelLine: withLabelsLine && labelsPosition === "outside" ? {
            stroke: "var(--chart-label-color, var(--mantine-color-dimmed))",
            strokeWidth: 1
          } : false,
          ...pieProps,
          children: cells
        }
      ),
      withTooltip &&  jsxRuntime.jsx(
        recharts.Tooltip,
        {
          animationDuration: tooltipAnimationDuration,
          isAnimationActive: false,
          content: ({ payload }) =>  jsxRuntime.jsx(
            ChartTooltip,
            {
              payload: data,
              classNames: resolvedClassNames,
              styles: resolvedStyles,
              type: "radial",
              segmentId: tooltipDataSource === "segment" ? payload?.[0]?.name : void 0,
              valueFormatter
            }
          ),
          ...tooltipProps
        }
      ),
      children
    ] }) }) });
  });
  PieChart2.displayName = "@mantine/charts/PieChart";
  PieChart2.classes = classes6;

  var classes7 = { "root": "m_1f271cf7", "container": "m_cf06f58c" };

  var defaultProps9 = {
    withPolarGrid: true,
    withPolarAngleAxis: true,
    withPolarRadiusAxis: false
  };
  var varsResolver7 = core.createVarsResolver((theme, { gridColor, textColor }) => ({
    root: {
      "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0,
      "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0
    }
  }));
  var RadarChart = core.factory((_props, ref) => {
    const props = core.useProps("RadarChart", defaultProps9, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      series,
      dataKey,
      gridColor,
      textColor,
      radarProps,
      radarChartProps,
      polarGridProps,
      polarAngleAxisProps,
      polarRadiusAxisProps,
      withPolarGrid,
      withPolarAngleAxis,
      withPolarRadiusAxis,
      children,
      withLegend,
      legendProps,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "RadarChart",
      classes: classes7,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver7
    });
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const radars = series.map((item, index) =>  jsxRuntime.jsx(
      recharts.Radar,
      {
        name: item.name,
        dataKey: item.name,
        stroke: core.getThemeColor(item.strokeColor || item.color, theme),
        fill: core.getThemeColor(item.color, theme),
        fillOpacity: highlightedArea ? highlightedArea === item.name ? item.opacity || 0.4 : 0.05 : item.opacity || 0.4,
        strokeOpacity: highlightedArea ? highlightedArea === item.name ? 1 : 0.1 : 1,
        isAnimationActive: false,
        ...typeof radarProps === "function" ? radarProps(item) : radarProps
      },
      index
    ));
    return  jsxRuntime.jsx(core.Box, { ref, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(recharts.RadarChart, { data, ...radarChartProps, children: [
      withPolarGrid &&  jsxRuntime.jsx(recharts.PolarGrid, { stroke: "var(--chart-grid-color)", ...polarGridProps }),
      withPolarAngleAxis &&  jsxRuntime.jsx(recharts.PolarAngleAxis, { dataKey, ...polarAngleAxisProps }),
      withPolarRadiusAxis &&  jsxRuntime.jsx(recharts.PolarRadiusAxis, { stroke: "var(--chart-grid-color)", ...polarRadiusAxisProps }),
      radars,
      withLegend &&  jsxRuntime.jsx(
        recharts.Legend,
        {
          verticalAlign: "bottom",
          content: (payload) =>  jsxRuntime.jsx(
            ChartLegend,
            {
              payload: payload.payload,
              onHighlight: setHighlightedArea,
              legendPosition: legendProps?.verticalAlign || "bottom",
              classNames: resolvedClassNames,
              styles: resolvedStyles,
              series,
              centered: true
            }
          ),
          ...legendProps
        }
      ),
      children
    ] }) }) });
  });
  RadarChart.displayName = "@mantine/charts/RadarChart";
  RadarChart.classes = classes7;
  function getAxis(key, dataKey) {
    return key === dataKey.x ? "x" : "y";
  }
  var defaultProps10 = {
    withXAxis: true,
    withYAxis: true,
    withTooltip: true,
    tooltipAnimationDuration: 0,
    tickLine: "y",
    strokeDasharray: "5 5",
    gridAxis: "x"
  };
  var varsResolver8 = core.createVarsResolver((theme, { textColor, gridColor }) => ({
    root: {
      "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
      "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0
    }
  }));
  var ScatterChart = core.factory((_props, ref) => {
    const props = core.useProps("ScatterChart", defaultProps10, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      referenceLines,
      dir,
      withLegend,
      withTooltip,
      withXAxis,
      withYAxis,
      xAxisProps,
      yAxisProps,
      orientation,
      scatterChartProps,
      legendProps,
      data,
      gridAxis,
      tickLine,
      strokeDasharray,
      gridProps,
      tooltipAnimationDuration,
      tooltipProps,
      children,
      onMouseLeave,
      dataKey,
      textColor,
      gridColor,
      xAxisLabel,
      yAxisLabel,
      unit,
      labels,
      valueFormatter,
      scatterProps,
      pointLabels,
      ...others
    } = props;
    const getFormatter = (axis) => typeof valueFormatter === "function" ? valueFormatter : valueFormatter?.[axis];
    const xFormatter = getFormatter("x");
    const yFormatter = getFormatter("y");
    const theme = core.useMantineTheme();
    const mappedData = data.map((item) => ({
      ...item,
      data: item.data.map((point) => ({ ...point, name: item.name }))
    }));
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const getStyles = core.useStyles({
      name: "ScatterChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver8
    });
    const withXTickLine = gridAxis !== "none" && (tickLine === "x" || tickLine === "xy");
    const withYTickLine = gridAxis !== "none" && (tickLine === "y" || tickLine === "xy");
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const shouldHighlight = highlightedArea !== null;
    const handleMouseLeave = (event) => {
      setHighlightedArea(null);
      onMouseLeave?.(event);
    };
    const referenceLinesItems = referenceLines?.map((line, index) => {
      const color = core.getThemeColor(line.color, theme);
      return  jsxRuntime.jsx(
        recharts.ReferenceLine,
        {
          stroke: line.color ? color : "var(--chart-grid-color)",
          strokeWidth: 1,
          ...line,
          label: {
            value: line.label,
            fill: line.color ? color : "currentColor",
            fontSize: 12,
            position: line.labelPosition ?? "insideBottomLeft"
          },
          ...getStyles("referenceLine")
        },
        index
      );
    });
    const scatters = mappedData.map((item, index) => {
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      return  jsxRuntime.jsxs(
        recharts.Scatter,
        {
          data: item.data,
          fill: core.getThemeColor(item.color, theme),
          isAnimationActive: false,
          fillOpacity: dimmed ? 0.1 : 1,
          ...scatterProps,
          children: [
            pointLabels &&  jsxRuntime.jsx(recharts.LabelList, { dataKey: dataKey[pointLabels], fontSize: 8, dy: 10 }),
            scatterProps?.children
          ]
        },
        index
      );
    });
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        ...getStyles("root"),
        onMouseLeave: handleMouseLeave,
        dir: dir || "ltr",
        ...others,
        children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(
          recharts.ScatterChart,
          {
            margin: {
              bottom: xAxisLabel ? 30 : void 0,
              left: yAxisLabel ? 10 : void 0,
              right: yAxisLabel ? 5 : void 0
            },
            ...scatterChartProps,
            children: [
               jsxRuntime.jsx(
                recharts.CartesianGrid,
                {
                  strokeDasharray,
                  vertical: gridAxis === "y" || gridAxis === "xy",
                  horizontal: gridAxis === "x" || gridAxis === "xy",
                  ...getStyles("grid"),
                  ...gridProps
                }
              ),
               jsxRuntime.jsxs(
                recharts.XAxis,
                {
                  type: "number",
                  hide: !withXAxis,
                  dataKey: dataKey.x,
                  tick: { transform: "translate(0, 10)", fontSize: 12, fill: "currentColor" },
                  stroke: "",
                  interval: "preserveStartEnd",
                  tickLine: withXTickLine ? { stroke: "currentColor" } : false,
                  minTickGap: 5,
                  unit: unit?.x,
                  tickFormatter: xFormatter,
                  ...getStyles("axis"),
                  ...xAxisProps,
                  children: [
                    xAxisLabel &&  jsxRuntime.jsx(recharts.Label, { position: "insideBottom", offset: -20, fontSize: 12, ...getStyles("axisLabel"), children: xAxisLabel }),
                    xAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  type: "number",
                  hide: !withYAxis,
                  axisLine: false,
                  dataKey: dataKey.y,
                  tickLine: withYTickLine ? { stroke: "currentColor" } : false,
                  tick: { transform: "translate(-10, 0)", fontSize: 12, fill: "currentColor" },
                  allowDecimals: true,
                  unit: unit?.y,
                  tickFormatter: yFormatter,
                  ...getStyles("axis"),
                  ...yAxisProps,
                  children: [
                    yAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideLeft",
                        angle: -90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: yAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
              withTooltip &&  jsxRuntime.jsx(
                recharts.Tooltip,
                {
                  animationDuration: tooltipAnimationDuration,
                  isAnimationActive: tooltipAnimationDuration !== 0,
                  position: { y: 0 },
                  cursor: {
                    stroke: "var(--chart-grid-color)",
                    strokeWidth: 1,
                    strokeDasharray
                  },
                  content: ({ label, payload }) =>  jsxRuntime.jsx(
                    ChartTooltip,
                    {
                      type: "scatter",
                      label,
                      payload: labels ? payload?.map((item) => ({
                        ...item,
                        name: labels[getAxis(item.name, dataKey)] || item.name,
                        value: getFormatter(getAxis(item.name, dataKey))?.(item.value) ?? item.value
                      })) : payload?.map((item) => ({
                        ...item,
                        value: getFormatter(getAxis(item.name, dataKey))?.(item.value) ?? item.value
                      })),
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series: data
                    }
                  ),
                  ...tooltipProps
                }
              ),
              withLegend &&  jsxRuntime.jsx(
                recharts.Legend,
                {
                  verticalAlign: "top",
                  content: (payload) =>  jsxRuntime.jsx(
                    ChartLegend,
                    {
                      payload: payload.payload?.map((item, index) => ({
                        ...item,
                        dataKey: data[index].name
                      })),
                      onHighlight: setHighlightedArea,
                      legendPosition: legendProps?.verticalAlign || "top",
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series: data
                    }
                  ),
                  height: 44,
                  ...legendProps
                }
              ),
              referenceLinesItems,
              scatters
            ]
          }
        ) })
      }
    );
  });
  ScatterChart.displayName = "@mantine/charts/ScatterChart";
  ScatterChart.classes = classes3;
  function getDomain(data, key) {
    const values = data.map((item) => item[key]);
    return [Math.min(...values), Math.max(...values)];
  }
  function BubbleChartTooltip({
    active,
    payload,
    getStyles,
    dataKey,
    valueFormatter
  }) {
    if (active && payload && payload.length) {
      const data = payload[0] && payload[0].payload;
      return  jsxRuntime.jsx("div", { ...getStyles("tooltip"), children:  jsxRuntime.jsxs(core.Group, { justify: "space-between", children: [
         jsxRuntime.jsx(core.Text, { fz: "sm", children: data[dataKey.x] }),
         jsxRuntime.jsx(core.Text, { fz: "sm", children: valueFormatter ? valueFormatter(data[dataKey.z]) : data[dataKey.z] })
      ] }) });
    }
    return null;
  }
  var defaultProps11 = {
    color: "blue.6",
    withTooltip: true
  };
  var varsResolver9 = core.createVarsResolver((theme, { textColor, gridColor }) => ({
    root: {
      "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
      "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0
    }
  }));
  var BubbleChart = core.factory((_props, ref) => {
    const props = core.useProps("BubbleChart", defaultProps11, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      xAxisProps,
      yAxisProps,
      zAxisProps,
      tooltipProps,
      scatterProps,
      color,
      label,
      withTooltip,
      dataKey,
      range,
      valueFormatter,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "BubbleChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver9
    });
    return  jsxRuntime.jsx(core.Box, { ref, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(recharts.ScatterChart, { children: [
       jsxRuntime.jsx(
        recharts.XAxis,
        {
          type: "category",
          dataKey: dataKey.x,
          interval: 0,
          tick: { fontSize: 12, fill: "currentColor" },
          tickLine: { transform: "translate(0, -6)", stroke: "currentColor" },
          stroke: "currentColor",
          ...getStyles("axis"),
          ...xAxisProps
        }
      ),
       jsxRuntime.jsx(
        recharts.YAxis,
        {
          type: "number",
          dataKey: dataKey.y,
          height: 10,
          width: label ? void 0 : 0,
          tick: false,
          tickLine: false,
          axisLine: false,
          label: { value: label, position: "insideRight", fontSize: 12, fill: "currentColor" },
          ...getStyles("axis"),
          ...yAxisProps
        }
      ),
       jsxRuntime.jsx(
        recharts.ZAxis,
        {
          type: "number",
          dataKey: dataKey.z,
          domain: getDomain(data, dataKey.z),
          range,
          ...zAxisProps
        }
      ),
      withTooltip &&  jsxRuntime.jsx(
        recharts.Tooltip,
        {
          animationDuration: 100,
          isAnimationActive: false,
          cursor: { stroke: "var(--chart-grid-color)", strokeWidth: 1, strokeDasharray: "3 3" },
          content: (payload) =>  jsxRuntime.jsx(
            BubbleChartTooltip,
            {
              dataKey,
              active: payload.active,
              payload: payload.payload,
              getStyles,
              valueFormatter
            }
          ),
          ...tooltipProps
        }
      ),
       jsxRuntime.jsx(
        recharts.Scatter,
        {
          data,
          fill: core.getThemeColor(color, theme),
          isAnimationActive: false,
          ...scatterProps
        }
      )
    ] }) }) });
  });
  BubbleChart.displayName = "@mantine/charts/BubbleChart";
  BubbleChart.classes = classes3;
  var defaultProps12 = {
    withXAxis: true,
    withYAxis: true,
    withTooltip: true,
    tooltipAnimationDuration: 0,
    tickLine: "y",
    strokeDasharray: "5 5",
    gridAxis: "x",
    withDots: true,
    connectNulls: true,
    strokeWidth: 2,
    curveType: "monotone"
  };
  var varsResolver10 = core.createVarsResolver(
    (theme, { textColor, gridColor }) => ({
      root: {
        "--chart-text-color": textColor ? core.getThemeColor(textColor, theme) : void 0,
        "--chart-grid-color": gridColor ? core.getThemeColor(gridColor, theme) : void 0
      }
    })
  );
  var CompositeChart = core.factory((_props, ref) => {
    const props = core.useProps("CompositeChart", defaultProps12, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withLegend,
      legendProps,
      series,
      onMouseLeave,
      dataKey,
      withTooltip,
      withXAxis,
      withYAxis,
      gridAxis,
      tickLine,
      xAxisProps,
      yAxisProps,
      unit,
      tooltipAnimationDuration,
      strokeDasharray,
      gridProps,
      tooltipProps,
      referenceLines,
      withDots,
      dotProps,
      activeDotProps,
      strokeWidth,
      connectNulls,
      curveType,
      dir,
      valueFormatter,
      children,
      lineProps,
      xAxisLabel,
      yAxisLabel,
      withRightYAxis,
      rightYAxisLabel,
      rightYAxisProps,
      withPointLabels,
      areaProps,
      barProps,
      withBarValueLabel,
      minBarSize,
      maxBarWidth,
      composedChartProps,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const withXTickLine = gridAxis !== "none" && (tickLine === "x" || tickLine === "xy");
    const withYTickLine = gridAxis !== "none" && (tickLine === "y" || tickLine === "xy");
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const shouldHighlight = highlightedArea !== null;
    const handleMouseLeave = (event) => {
      setHighlightedArea(null);
      onMouseLeave?.(event);
    };
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    const getStyles = core.useStyles({
      name: "CompositeChart",
      classes: classes3,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver10
    });
    const lines = series.map((item) => {
      const color = core.getThemeColor(item.color, theme);
      const dimmed = shouldHighlight && highlightedArea !== item.name;
      if (item.type === "line") {
        return  react.createElement(
          recharts.Line,
          {
            ...getStyles("line"),
            key: item.name,
            name: item.name,
            dataKey: item.name,
            dot: withDots ? {
              fillOpacity: dimmed ? 0 : 1,
              strokeOpacity: dimmed ? 0 : 1,
              strokeWidth: 1,
              fill: color,
              stroke: color,
              ...dotProps
            } : false,
            activeDot: withDots ? { fill: "var(--mantine-color-white)", stroke: color, ...activeDotProps } : false,
            fill: color,
            stroke: color,
            strokeWidth,
            isAnimationActive: false,
            fillOpacity: dimmed ? 0 : 1,
            strokeOpacity: dimmed ? 0.5 : 1,
            connectNulls,
            type: curveType,
            strokeDasharray: item.strokeDasharray,
            yAxisId: item.yAxisId || "left",
            label: withPointLabels ?  jsxRuntime.jsx(PointLabel, {}) : void 0,
            ...typeof lineProps === "function" ? lineProps(item) : lineProps
          }
        );
      }
      if (item.type === "area") {
        return  react.createElement(
          recharts.Area,
          {
            ...getStyles("area"),
            key: item.name,
            name: item.name,
            type: curveType,
            dataKey: item.name,
            fill: color,
            strokeWidth,
            stroke: color,
            isAnimationActive: false,
            connectNulls,
            dot: withDots ? {
              fillOpacity: dimmed ? 0 : 1,
              strokeOpacity: dimmed ? 0 : 1,
              strokeWidth: 1,
              fill: color,
              stroke: color,
              ...dotProps
            } : false,
            activeDot: withDots ? {
              fill: theme.white,
              stroke: color,
              strokeWidth: 2,
              r: 4,
              ...activeDotProps
            } : false,
            fillOpacity: dimmed ? 0 : 0.2,
            strokeOpacity: dimmed ? 0.5 : 1,
            strokeDasharray: item.strokeDasharray,
            yAxisId: item.yAxisId || "left",
            label: withPointLabels ?  jsxRuntime.jsx(PointLabel, {}) : void 0,
            ...typeof areaProps === "function" ? areaProps(item) : areaProps
          }
        );
      }
      if (item.type === "bar") {
        return  react.createElement(
          recharts.Bar,
          {
            ...getStyles("bar"),
            key: item.name,
            name: item.name,
            dataKey: item.name,
            fill: color,
            stroke: color,
            isAnimationActive: false,
            fillOpacity: dimmed ? 0.1 : 1,
            strokeOpacity: dimmed ? 0.2 : 0,
            label: withBarValueLabel ?  jsxRuntime.jsx(BarLabel, { valueFormatter }) : void 0,
            yAxisId: item.yAxisId || "left",
            minPointSize: minBarSize,
            ...typeof barProps === "function" ? barProps(item) : barProps
          }
        );
      }
      return null;
    });
    const referenceLinesItems = referenceLines?.map((line, index) => {
      const color = core.getThemeColor(line.color, theme);
      return  jsxRuntime.jsx(
        recharts.ReferenceLine,
        {
          stroke: line.color ? color : "var(--chart-grid-color)",
          strokeWidth: 1,
          yAxisId: line.yAxisId || "left",
          ...line,
          label: {
            value: line.label,
            fill: line.color ? color : "currentColor",
            fontSize: 12,
            position: line.labelPosition ?? "insideBottomLeft"
          },
          ...getStyles("referenceLine")
        },
        index
      );
    });
    const sharedYAxisProps = {
      axisLine: false,
      type: "number",
      tickLine: withYTickLine ? { stroke: "currentColor" } : false,
      allowDecimals: true,
      unit,
      tickFormatter: valueFormatter,
      ...getStyles("axis")
    };
    return  jsxRuntime.jsx(
      core.Box,
      {
        ref,
        ...getStyles("root"),
        onMouseLeave: handleMouseLeave,
        dir: dir || "ltr",
        ...others,
        children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { ...getStyles("container"), children:  jsxRuntime.jsxs(
          recharts.ComposedChart,
          {
            data,
            maxBarSize: maxBarWidth,
            margin: {
              bottom: xAxisLabel ? 30 : void 0,
              left: yAxisLabel ? 10 : void 0,
              right: yAxisLabel ? 5 : void 0
            },
            ...composedChartProps,
            children: [
              withLegend &&  jsxRuntime.jsx(
                recharts.Legend,
                {
                  verticalAlign: "top",
                  content: (payload) =>  jsxRuntime.jsx(
                    ChartLegend,
                    {
                      payload: payload.payload,
                      onHighlight: setHighlightedArea,
                      legendPosition: legendProps?.verticalAlign || "top",
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series
                    }
                  ),
                  ...legendProps
                }
              ),
               jsxRuntime.jsxs(
                recharts.XAxis,
                {
                  hide: !withXAxis,
                  dataKey,
                  tick: { transform: "translate(0, 10)", fontSize: 12, fill: "currentColor" },
                  stroke: "",
                  interval: "preserveStartEnd",
                  tickLine: withXTickLine ? { stroke: "currentColor" } : false,
                  minTickGap: 5,
                  ...getStyles("axis"),
                  ...xAxisProps,
                  children: [
                    xAxisLabel &&  jsxRuntime.jsx(recharts.Label, { position: "insideBottom", offset: -20, fontSize: 12, ...getStyles("axisLabel"), children: xAxisLabel }),
                    xAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "left",
                  orientation: "left",
                  tick: { transform: "translate(-10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withYAxis,
                  ...sharedYAxisProps,
                  ...yAxisProps,
                  children: [
                    yAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideLeft",
                        angle: -90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: yAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsxs(
                recharts.YAxis,
                {
                  yAxisId: "right",
                  orientation: "right",
                  tick: { transform: "translate(10, 0)", fontSize: 12, fill: "currentColor" },
                  hide: !withRightYAxis,
                  ...sharedYAxisProps,
                  ...rightYAxisProps,
                  children: [
                    rightYAxisLabel &&  jsxRuntime.jsx(
                      recharts.Label,
                      {
                        position: "insideRight",
                        angle: 90,
                        textAnchor: "middle",
                        fontSize: 12,
                        offset: -5,
                        ...getStyles("axisLabel"),
                        children: rightYAxisLabel
                      }
                    ),
                    yAxisProps?.children
                  ]
                }
              ),
               jsxRuntime.jsx(
                recharts.CartesianGrid,
                {
                  strokeDasharray,
                  vertical: gridAxis === "y" || gridAxis === "xy",
                  horizontal: gridAxis === "x" || gridAxis === "xy",
                  ...getStyles("grid"),
                  ...gridProps
                }
              ),
              withTooltip &&  jsxRuntime.jsx(
                recharts.Tooltip,
                {
                  animationDuration: tooltipAnimationDuration,
                  isAnimationActive: tooltipAnimationDuration !== 0,
                  position: { y: 0 },
                  cursor: {
                    stroke: "var(--chart-grid-color)",
                    strokeWidth: 1,
                    strokeDasharray
                  },
                  content: ({ label, payload }) =>  jsxRuntime.jsx(
                    ChartTooltip,
                    {
                      label,
                      payload,
                      unit,
                      classNames: resolvedClassNames,
                      styles: resolvedStyles,
                      series,
                      valueFormatter
                    }
                  ),
                  ...tooltipProps
                }
              ),
              lines,
              referenceLinesItems,
              children
            ]
          }
        ) })
      }
    );
  });
  CompositeChart.displayName = "@mantine/charts/CompositeChart";
  CompositeChart.classes = classes3;

  var classes8 = { "root": "m_cd2bd9e5", "tooltip": "m_6bcc3420" };

  var defaultProps13 = {
    barSize: 20,
    startAngle: 90,
    endAngle: -270,
    withBackground: true,
    withTooltip: true
  };
  var varsResolver11 = core.createVarsResolver(
    (theme, { emptyBackgroundColor }) => ({
      root: {
        "--chart-empty-background": emptyBackgroundColor ? core.getThemeColor(emptyBackgroundColor, theme) : void 0
      }
    })
  );
  var RadialBarChart = core.factory((_props, ref) => {
    const props = core.useProps("RadialBarChart", defaultProps13, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      barSize,
      withBackground,
      dataKey,
      radialBarProps,
      radialBarChartProps,
      withLabels,
      withLegend,
      legendProps,
      withTooltip,
      tooltipProps,
      startAngle,
      endAngle,
      ...others
    } = props;
    const [highlightedArea, setHighlightedArea] = react.useState(null);
    const getStyles = core.useStyles({
      name: "RadialBarChart",
      classes: classes8,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver11
    });
    const theme = core.useMantineTheme();
    const dataWithResolvedColor = data.map(({ color, ...item }) => {
      const resolvedColor = core.getThemeColor(color, theme);
      return {
        ...item,
        fill: resolvedColor,
        fillOpacity: highlightedArea ? highlightedArea === item.name ? item.opacity || 1 : 0.05 : item.opacity || 1
      };
    });
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    return  jsxRuntime.jsx(core.Box, { ref, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(
      recharts.RadialBarChart,
      {
        margin: { top: 0, bottom: 0, left: 0, right: 0 },
        innerRadius: "10%",
        outerRadius: "100%",
        cx: "50%",
        cy: "50%",
        barSize,
        startAngle,
        endAngle,
        data: dataWithResolvedColor,
        ...radialBarChartProps,
        children: [
           jsxRuntime.jsx(
            recharts.RadialBar,
            {
              label: withLabels ? {
                position: "insideStart",
                fill: "var(--mantine-color-white)",
                fontSize: 12
              } : void 0,
              background: withBackground ? { fill: "var(--chart-empty-background)" } : void 0,
              dataKey,
              isAnimationActive: false,
              ...radialBarProps
            }
          ),
          withLegend &&  jsxRuntime.jsx(
            recharts.Legend,
            {
              verticalAlign: "bottom",
              content: (payload) =>  jsxRuntime.jsx(
                ChartLegend,
                {
                  payload: payload.payload?.map((item) => ({
                    ...item,
                    dataKey: item.payload?.name
                  })),
                  onHighlight: setHighlightedArea,
                  legendPosition: legendProps?.verticalAlign || "bottom",
                  classNames: resolvedClassNames,
                  styles: resolvedStyles,
                  centered: true
                }
              ),
              ...legendProps
            }
          ),
          withTooltip &&  jsxRuntime.jsx(
            recharts.Tooltip,
            {
              animationDuration: 0,
              isAnimationActive: false,
              cursor: { stroke: "var(--chart-cursor-color)" },
              content: ({ payload }) =>  jsxRuntime.jsxs(core.Paper, { ...getStyles("tooltip"), children: [
                 jsxRuntime.jsxs(core.Group, { gap: "sm", children: [
                   jsxRuntime.jsx(core.ColorSwatch, { color: payload?.[0]?.payload.fill, size: 12, withShadow: false }),
                   jsxRuntime.jsx("span", { children: payload?.[0]?.payload.name })
                ] }),
                 jsxRuntime.jsx("span", { children: payload?.[0]?.payload[dataKey] })
              ] }),
              ...tooltipProps
            }
          )
        ]
      }
    ) }) });
  });
  RadialBarChart.displayName = "@mantine/core/RadialBarChart";
  RadialBarChart.classes = classes8;

  var classes9 = { "root": "m_80d531e7" };

  var defaultProps14 = {
    withTooltip: true,
    size: 300,
    strokeWidth: 1,
    withLabels: false,
    labelsPosition: "right",
    tooltipDataSource: "all"
  };
  var varsResolver12 = core.createVarsResolver(
    (theme, { strokeColor, labelColor, size }) => ({
      root: {
        "--chart-stroke-color": strokeColor ? core.getThemeColor(strokeColor, theme) : void 0,
        "--chart-labels-color": labelColor ? core.getThemeColor(labelColor, theme) : void 0,
        "--chart-size": core.rem(size)
      }
    })
  );
  var FunnelChart = core.factory((_props, ref) => {
    const props = core.useProps("FunnelChart", defaultProps14, _props);
    const {
      classNames,
      className,
      style,
      styles,
      unstyled,
      vars,
      data,
      withTooltip,
      tooltipAnimationDuration,
      tooltipProps,
      strokeWidth,
      withLabels,
      size,
      valueFormatter,
      children,
      funnelChartProps,
      funnelProps,
      labelsPosition,
      tooltipDataSource,
      ...others
    } = props;
    const theme = core.useMantineTheme();
    const getStyles = core.useStyles({
      name: "FunnelChart",
      classes: classes9,
      props,
      className,
      style,
      classNames,
      styles,
      unstyled,
      vars,
      varsResolver: varsResolver12
    });
    const { resolvedClassNames, resolvedStyles } = core.useResolvedStylesApi({
      classNames,
      styles,
      props
    });
    return  jsxRuntime.jsx(core.Box, { ref, size, ...getStyles("root"), ...others, children:  jsxRuntime.jsx(recharts.ResponsiveContainer, { children:  jsxRuntime.jsxs(recharts.FunnelChart, { ...funnelChartProps, children: [
       jsxRuntime.jsxs(
        recharts.Funnel,
        {
          data,
          dataKey: "value",
          isAnimationActive: false,
          stroke: "var(--chart-stroke-color, var(--mantine-color-body))",
          strokeWidth,
          ...funnelProps,
          children: [
            withLabels &&  jsxRuntime.jsx(
              recharts.LabelList,
              {
                position: labelsPosition,
                fill: labelsPosition === "inside" ? "var(--chart-labels-color, var(--mantine-color-white))" : "var(--chart-labels-color, var(--mantine-color-dimmed))",
                stroke: "none",
                fontFamily: "var(--mantine-font-family)",
                fontSize: 14,
                dataKey: (entry) => {
                  return typeof valueFormatter === "function" ? valueFormatter(entry.value) : entry.value;
                }
              }
            ),
            data.map((entry, index) =>  jsxRuntime.jsx(
              recharts.Cell,
              {
                fill: core.getThemeColor(entry.color, theme),
                stroke: "var(--chart-stroke-color, var(--mantine-color-body))",
                strokeWidth
              },
              index
            ))
          ]
        }
      ),
      withTooltip &&  jsxRuntime.jsx(
        recharts.Tooltip,
        {
          animationDuration: tooltipAnimationDuration,
          isAnimationActive: false,
          content: ({ payload }) =>  jsxRuntime.jsx(
            ChartTooltip,
            {
              payload: data,
              classNames: resolvedClassNames,
              styles: resolvedStyles,
              type: "radial",
              segmentId: tooltipDataSource === "segment" ? payload?.[0]?.name : void 0,
              valueFormatter
            }
          ),
          ...tooltipProps
        }
      ),
      children
    ] }) }) });
  });
  FunnelChart.displayName = "@mantine/charts/FunnelChart";
  FunnelChart.classes = classes9;
  exports.AreaChart = AreaChart;
  exports.AreaGradient = AreaGradient;
  exports.BarChart = BarChart;
  exports.BubbleChart = BubbleChart;
  exports.ChartLegend = ChartLegend;
  exports.ChartTooltip = ChartTooltip;
  exports.CompositeChart = CompositeChart;
  exports.DonutChart = DonutChart;
  exports.FunnelChart = FunnelChart;
  exports.LineChart = LineChart;
  exports.PieChart = PieChart2;
  exports.RadarChart = RadarChart;
  exports.RadialBarChart = RadialBarChart;
  exports.ScatterChart = ScatterChart;
  exports.Sparkline = Sparkline;
  exports.getFilteredChartLegendPayload = getFilteredChartLegendPayload;
  exports.getFilteredChartTooltipPayload = getFilteredChartTooltipPayload;
  exports.getSplitOffset = getSplitOffset;
}));