import { useState } from 'react';
import { Box, Paper, Typography, ToggleButton, ToggleButtonGroup, CircularProgress, Alert } from '@mui/material';
import ArrowUpwardIcon from '@mui/icons-material/ArrowUpward';
import ArrowDownwardIcon from '@mui/icons-material/ArrowDownward';
import RemoveIcon from '@mui/icons-material/Remove';
import type { CotizacionBolsa } from '../models/mercadoModels';
import { formatCurrency2Decimal, formatCurrency } from '../utils/formatters';
import { HistoricalChartWidget } from './HistoricalChartWidget';
import { useApiData } from '../hooks/useApiData';
import { useIsHoliday } from '../hooks/useIsHoliday'; // <-- Importamos el hook
import { HolidayAlert } from './common/HolidayAlert';   // <-- Importamos la alerta
/**
 * Sub-componente para la variación del índice.
 */
const VariacionMerval = ({ actual, anterior }: { actual: number, anterior: number }) => {
    if (anterior === 0) return null;
    const variacionPuntos = actual - anterior;
    const variacionPorcentaje = (variacionPuntos / anterior) * 100;
    const isPositive = variacionPuntos > 0;
    const isNegative = variacionPuntos < 0;
    const color = isPositive ? 'success.main' : isNegative ? 'error.main' : 'text.secondary';
    const Icon = isPositive ? ArrowUpwardIcon : isNegative ? ArrowDownwardIcon : RemoveIcon;
    return (
        
            
            
                
                    {formatCurrency(variacionPuntos)}
                
                
                    ({variacionPorcentaje.toFixed(2)}%)
                
            
        
    );
};
/**
 * Widget autónomo para la tarjeta de héroe del S&P Merval.
 */
export const MervalHeroCard = () => {
    // Cada widget gestiona sus propias llamadas a la API
    const { data: allLocalData, loading: dataLoading, error: dataError } = useApiData('/mercados/bolsa/local');
    const isHoliday = useIsHoliday('BA');
    
    // Estado interno para el gráfico
    const [dias, setDias] = useState(30);
    const handleRangoChange = ( _event: React.MouseEvent, nuevoRango: number | null ) => {
        if (nuevoRango !== null) { setDias(nuevoRango); }
    };
    
    // Filtramos el dato específico que este widget necesita
    const mervalData = allLocalData?.find(d => d.ticker === '^MERV');
    
    // --- LÓGICA DE RENDERIZADO CORREGIDA ---
    
    // El estado de carga depende de AMBAS llamadas a la API.
    const isLoading = dataLoading || isHoliday === null;
    if (isLoading) {
        return ;
    }
    if (dataError) {
        return {dataError};
    }
    // Si no hay datos del Merval, es un estado final.
    if (!mervalData) {
        // Si no hay datos PERO sabemos que es feriado, la alerta de feriado es más informativa.
        if (isHoliday) {
            return ;
        }
        return No se encontraron datos para el índice MERVAL.;
    }
    // Si llegamos aquí, SÍ tenemos datos para mostrar.
    return (
        
            {/* Si es feriado, mostramos la alerta como un AVISO encima del contenido. */}
            {isHoliday && (
                
                    
                
            )}
            {/* El contenido principal del widget siempre se muestra si hay datos. */}
            
                
                    
                        Índice S&P MERVAL
                        {formatCurrency2Decimal(mervalData.precioActual)}
                    
                    
                        
                    
                
                
                    
                        
                            Semanal
                            Mensual
                            Anual
                        
                    
                    
                
            
        
    );
};