import { Chart as ChartJS, Filler, Legend, LineElement, PointElement, RadialLinearScale, Tooltip, } from 'chart.js'; import { t } from 'i18next'; import React from 'react'; import { Radar } from 'react-chartjs-2'; ChartJS.register( RadialLinearScale, PointElement, LineElement, Filler, Tooltip, Legend, ); type CIAData = { subject: string; current: 0 | 1 | 2; target: 0 | 1 | 2; }; type Props = { data: CIAData[]; }; export const CIATriadChart: React.FC = ({ data }) => { if (!data.length) { return (

{t('err.noMatchingRecords')}

); } const chartData = { labels: data.map(d => d.subject), datasets: [ { label: 'Average', data: data.map(d => d.current), backgroundColor: 'rgba(130, 202, 157, 0.5)', borderColor: 'rgb(130, 202, 157)', borderWidth: 1, }, ], }; const options = { responsive: true, maintainAspectRatio: false, scales: { r: { angleLines: { display: true, color: 'rgba(255, 255, 255, 0.1)', }, suggestedMin: 0, suggestedMax: 2, ticks: { stepSize: 1, callback: (value: number | string) => { if (value === 0) { return 'None'; } if (value === 1) { return 'Low'; } if (value === 2) { return 'High'; } return value; }, display: true, color: 'black' as const, }, pointLabels: { font: { size: 14, }, color: 'white' as const, }, grid: { color: 'rgba(255, 255, 255, 0.1)' as const, }, }, }, plugins: { legend: { position: 'bottom' as const, title: { display: true, text: t('filters'), color: 'white' as const, font: { weight: 'bold' as const, size: 15, }, }, labels: { color: 'white' as const, boxWidth: 20, padding: 20, }, }, datalabels: { formatter: () => '', }, tooltip: { backgroundColor: 'rgba(0, 0, 0, 0.8)' as const, titleColor: 'white' as const, bodyColor: 'white' as const, borderColor: 'white' as const, borderWidth: 1, }, }, }; return (
); };