from __future__ import annotations
import logging
from pathlib import Path

def setup_logging(level: str = "INFO", log_dir: str | None = None, logger_name: str = "clustered_if") -> logging.Logger:
    lvl = getattr(logging, level.upper(), logging.INFO)
    
    # Create a new logger with the given name
    logger = logging.getLogger(logger_name)
    
    # Reset logger if it already exists
    if logger.handlers:
        for handler in logger.handlers[:]:
            logger.removeHandler(handler)
    
    # Set level for this logger
    logger.setLevel(lvl)
    
    # Create console handler
    console_handler = logging.StreamHandler()
    console_handler.setLevel(lvl)
    console_handler.setFormatter(logging.Formatter('[%(levelname)s] %(message)s'))
    logger.addHandler(console_handler)
    
    # Add file handler if log_dir is provided
    if log_dir:
        Path(log_dir).mkdir(parents=True, exist_ok=True)
        file_handler = logging.FileHandler(Path(log_dir) / 'run2.log', mode='w')
        file_handler.setLevel(logging.DEBUG)
        file_handler.setFormatter(logging.Formatter('%(asctime)s [%(levelname)s] %(message)s'))
        logger.addHandler(file_handler)
    
    # Don't propagate to the root logger
    logger.propagate = False
    
    return logger
