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
Jari Kolehmainen 1d0815abd2
Lens app source code (#119)
Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com>
2020-03-15 09:52:02 +02:00

63 lines
1.9 KiB
TypeScript

import "./pie-chart.scss";
import * as React from "react";
import * as ChartJS from "chart.js";
import { ChartData, ChartOptions } from "chart.js";
import { Chart, ChartProps } from "./chart";
import { cssNames } from "../../utils";
import { themeStore } from "../../theme.store";
interface Props extends ChartProps {
data: ChartData;
title?: string;
}
export class PieChart extends React.Component<Props> {
render() {
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: () => "",
label: (tooltipItem, data) => {
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 }) => {
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 }) {
return position;
};