"""
Utility module for color handling and logging that works for both console and text file output.
"""

import os
import sys
from typing import Optional
import logging

def setup_logging(log_file_path, use_colors_in_console=True, worker_id=None):
    """Setup logging configuration with proper color handling."""
    # Create formatters
    if worker_id:
        file_formatter = logging.Formatter(f'%(asctime)s - Worker-{worker_id} - %(levelname)s - %(message)s')
        console_formatter = logging.Formatter(f'%(asctime)s - Worker-{worker_id} - %(levelname)s - %(message)s')
    else:
        file_formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
        console_formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
    
    # Create handlers
    file_handler = logging.FileHandler(log_file_path)
    file_handler.setFormatter(file_formatter)
    
    console_handler = logging.StreamHandler()
    console_handler.setFormatter(console_formatter)
    
    # Create logger with unique name for worker processes
    if worker_id:
        logger_name = f"{__name__}_worker_{worker_id}"
    else:
        logger_name = __name__
    
    logger = logging.getLogger(logger_name)
    logger.setLevel(logging.INFO)
    
    # Remove existing handlers
    for handler in logger.handlers[:]:
        logger.removeHandler(handler)
    
    # Add new handlers
    logger.addHandler(file_handler)
    logger.addHandler(console_handler)
    
    # Disable colors for file output, enable for console
    if use_colors_in_console:
        # Create a custom formatter that strips colors for file output
        class ColorStrippingFormatter(logging.Formatter):
            def format(self, record):
                # Strip ANSI color codes for file output
                message = super().format(record)
                import re
                # Remove ANSI escape sequences
                ansi_escape = re.compile(r'\x1B(?:[@-Z\\-_]|\[[0-?]*[ -/]*[@-~])')
                return ansi_escape.sub('', message)
        
        if worker_id:
            file_handler.setFormatter(ColorStrippingFormatter(f'%(asctime)s - Worker-{worker_id} - %(levelname)s - %(message)s'))
        else:
            file_handler.setFormatter(ColorStrippingFormatter('%(asctime)s - %(levelname)s - %(message)s'))
    
    return logger

class Colors:
    """Color codes for terminal output."""
    RED = '\033[91m'
    GREEN = '\033[92m'
    YELLOW = '\033[93m'
    BLUE = '\033[94m'
    MAGENTA = '\033[95m'
    CYAN = '\033[96m'
    WHITE = '\033[97m'
    BOLD = '\033[1m'
    UNDERLINE = '\033[4m'
    END = '\033[0m'

class ColorFormatter:
    """Formatter that handles colors for both console and file output."""
    
    def __init__(self, use_colors: Optional[bool] = None):
        """
        Initialize the color formatter.
        
        Args:
            use_colors: If None, auto-detect. If True/False, force colors on/off.
        """
        if use_colors is None:
            # Auto-detect: use colors if output is to terminal
            self.use_colors = self._is_terminal_output()
        else:
            self.use_colors = use_colors
    
    def disable_colors(self):
        """Disable colors (useful for file logging)."""
        self.use_colors = False
    
    def enable_colors(self):
        """Enable colors (useful for console output)."""
        self.use_colors = True
    
    def _is_terminal_output(self) -> bool:
        """Check if output is going to a terminal."""
        # Check if stdout is connected to a terminal
        if hasattr(sys.stdout, 'isatty') and sys.stdout.isatty():
            return True
        
        # Check environment variables
        if 'TERM' in os.environ and os.environ['TERM'] != 'dumb':
            return True
        
        # Check if running in common IDEs that support colors
        if any(ide in os.environ.get('TERM_PROGRAM', '') for ide in ['iTerm', 'Apple_Terminal']):
            return True
        
        # Check if running in Jupyter/IPython
        try:
            import IPython
            if IPython.get_ipython() is not None:
                return True
        except ImportError:
            pass
        
        # Check if running in a notebook environment
        if 'JUPYTER_RUNTIME_DIR' in os.environ:
            return True
        
        # Check if running in VS Code terminal
        if 'VSCODE_PID' in os.environ:
            return True
        
        return False
    
    def format(self, text: str, color: str) -> str:
        """
        Format text with color if colors are enabled.
        
        Args:
            text: The text to format
            color: The color code from Colors class
            
        Returns:
            Formatted text
        """
        if self.use_colors:
            return f"{color}{text}{Colors.END}"
        else:
            return text
    
    def red(self, text: str) -> str:
        return self.format(text, Colors.RED)
    
    def green(self, text: str) -> str:
        return self.format(text, Colors.GREEN)
    
    def yellow(self, text: str) -> str:
        return self.format(text, Colors.YELLOW)
    
    def blue(self, text: str) -> str:
        return self.format(text, Colors.BLUE)
    
    def magenta(self, text: str) -> str:
        return self.format(text, Colors.MAGENTA)
    
    def cyan(self, text: str) -> str:
        return self.format(text, Colors.CYAN)
    
    def bold(self, text: str) -> str:
        return self.format(text, Colors.BOLD)
    
    def underline(self, text: str) -> str:
        return self.format(text, Colors.UNDERLINE)

# Global formatter instance
formatter = ColorFormatter()

# Convenience functions that check if we're logging to a file
def _should_use_colors():
    """Check if we should use colors based on the current logging context."""
    # If we're in a file logging context, don't use colors
    import logging
    logger = logging.getLogger()
    for handler in logger.handlers:
        if isinstance(handler, logging.FileHandler):
            return False
    return formatter.use_colors

def red(text: str) -> str:
    return formatter.red(text) if _should_use_colors() else text

def green(text: str) -> str:
    return formatter.green(text) if _should_use_colors() else text

def yellow(text: str) -> str:
    return formatter.yellow(text) if _should_use_colors() else text

def blue(text: str) -> str:
    return formatter.blue(text) if _should_use_colors() else text

def magenta(text: str) -> str:
    return formatter.magenta(text) if _should_use_colors() else text

def cyan(text: str) -> str:
    return formatter.cyan(text) if _should_use_colors() else text

def bold(text: str) -> str:
    return formatter.bold(text) if _should_use_colors() else text

def underline(text: str) -> str:
    return formatter.underline(text) if _should_use_colors() else text

# For backward compatibility, keep the Colors class accessible
__all__ = ['Colors', 'ColorFormatter', 'formatter', 
           'red', 'green', 'yellow', 'blue', 'magenta', 'cyan', 'bold', 'underline']