import Chart from '@/lib/chartjs-config';
import { toBn } from '@/lib/utils';
import { Candidate } from '@/type/candidate.type';
import { useEffect, useRef } from 'react';

export const CaseTypeChart = ({ selectedData }: { selectedData: Candidate[] }) => {
  const chartRef = useRef<HTMLCanvasElement>(null);
  const chartInstance = useRef<any>(null);

  useEffect(() => {
    if (chartRef.current && !chartInstance.current) {
      const ctx = chartRef.current.getContext('2d');
      if (ctx) {
        chartInstance.current = new Chart(ctx, {
          type: 'bar',
          data: { labels: [], datasets: [] },
          options: {
            indexAxis: 'y',
            responsive: true,
            maintainAspectRatio: false,
            plugins: {
              legend: { display: false },
              tooltip: {
                callbacks: {
                  label: (ctx: any) => ` ${toBn(ctx.raw)} টি মামলা`,
                },
                bodyFont: { family: "'Hind Siliguri', sans-serif" },
              },
            },
            scales: {
              x: {
                beginAtZero: true,
                grid: { color: '#eff6ff' },
                ticks: {
                  font: { family: "'Hind Siliguri', sans-serif", size: 9 },
                  callback: (value: any) => toBn(value),
                },
              },
              y: {
                grid: { display: false },
                ticks: { font: { family: "'Hind Siliguri', sans-serif", size: 10 } },
              },
            },
          },
        });
      }
    }

    return () => {
      if (chartInstance.current) {
        chartInstance.current.destroy();
        chartInstance.current = null;
      }
    };
  }, []);

  useEffect(() => {
    if (selectedData.length === 0 || !chartInstance.current) return;

    const labels = selectedData.map((c) => c.name_bn);
    const totalCases = selectedData.map((c) => (c.criminal_cases ? c.criminal_cases.length : 0));

    chartInstance.current.data.labels = labels;
    chartInstance.current.data.datasets = [
      {
        label: 'মোট মামলা',
        data: totalCases,
        backgroundColor: selectedData.map((_, i) => ['#ef4444', '#f97316', '#eab308'][i % 3]),
        borderRadius: 4,
        barThickness: 15,
      },
    ];
    chartInstance.current.update();
  }, [selectedData]);

  return (
    <div className="chart-card bg-white p-3 md:p-3.5 rounded-3xl shadow-sm border border-blue-100">
      <h4 className="font-bold text-blue-950 mb-2 md:mb-6 flex items-center gap-1.5">
        <span className="material-symbols-outlined text-red-500 text-lg">gavel</span>
        মামলার পরিমাণ
      </h4>
      <div className="chart-container">
        <canvas ref={chartRef}></canvas>
      </div>
      <p className="text-xs text-gray-400 mt-4 text-center">* রাজনৈতিক ও ফৌজদারি মামলা</p>
    </div>
  );
};
