1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/dashboard/client/components/chart/pie-chart.tsx
Sebastian Malton b1ff34879a cleanup Lens repo with tighter linting
Signed-off-by: Sebastian Malton <smalton@mirantis.com>
2020-07-09 17:00:23 -04:00

66 lines
2.0 KiB
TypeScript

import "./pie-chart.scss";
import * as React from "react";
import ChartJS from "chart.js";
import { ChartOptions } from "chart.js";
import { Chart, ChartProps } from "./chart";
import { cssNames } from "../../utils";
import { themeStore } from "../../theme.store";
interface Props extends ChartProps {
title?: string;
}
export class PieChart extends React.Component<Props> {
render(): JSX.Element {
const { data, className, options, ...settings } = this.props;
const { contentColor } = themeStore.activeTheme.colors;
const cutouts = [88, 76, 63];
const opts: ChartOptions = this.props.showChart === false ? {} : {
maintainAspectRatio: false,
tooltips: {
mode: "index",
callbacks: {
title: (): string => "",
label: (tooltipItem, data): string => {
const dataset: any = data["datasets"][tooltipItem.datasetIndex];
const metaData = Object.values<{ total: number }>(dataset["_meta"])[0];
const percent = Math.round((dataset["data"][tooltipItem["index"]] / metaData.total) * 100);
if (isNaN(percent)) {
return "N/A";
}
return percent + "%";
},
},
filter: ({ datasetIndex, index }, { datasets }): boolean => {
const { data } = datasets[datasetIndex];
if (datasets.length === 1) {
return true;
}
return index !== data.length - 1;
},
position: "cursor",
},
elements: {
arc: {
borderWidth: 1,
borderColor: contentColor
},
},
cutoutPercentage: cutouts[data.datasets.length - 1] || 50,
responsive: true,
...options
};
return (
<Chart
className={cssNames("PieChart flex column align-center", className)}
data={data}
options={opts}
{...settings}
/>
);
}
}
ChartJS.Tooltip.positioners.cursor = function (elements: any, position: { x: number; y: number }): {x: number; y: number } {
return position;
};