#!/usr/bin/env python3

from __future__ import annotations

import logging
import os
from rich.logging import RichHandler
from rich.text import Text


class DimmedFuncNameRichHandler(RichHandler):
    def __init__(
        self, 
        *args, 
        show_name: bool = True, 
        show_func_name: bool = True,
        **kwargs):
        super().__init__(*args, **kwargs)
        self.show_name = show_name
        self.show_func_name = show_func_name

    def render_message(self, record, message) -> Text:
        base = super().render_message(record, message)
        header = Text.from_markup("| ")
        if self.show_name or self.show_func_name:
            if self.show_func_name:
                func_name = f"{record.funcName:<25}"
                header.append(Text.from_markup(f"[dim]{func_name}[/dim] | "))
            if self.show_name:
                name = f"{record.name:<25}"
                header.append(Text.from_markup(f"[dim]{name}[/dim] | "))
        return header + base


def setup_logging(
    verbose: bool = False, 
    debug: bool = False,
    show_name: bool = True,
    show_func_name: bool = True,
) -> logging.Logger:
    log_dir = os.path.join(os.path.dirname(__file__), '..', 'logs')
    os.makedirs(log_dir, exist_ok=True)
    log_file = os.path.join(log_dir, 'rescue.log')

    logging_level = logging.DEBUG if debug else logging.INFO if verbose else logging.CRITICAL

    # Clear existing handlers
    logging.getLogger().handlers.clear()

    # File handler (plain and aligned)
    file_handler = logging.FileHandler(log_file)
    file_handler.setLevel(logging.DEBUG)
    file_formatter = logging.Formatter(
        "%(asctime)s | %(levelname)-8s | %(name)-25s | %(funcName)-25s | %(message)s",
        "%Y-%m-%d %H:%M:%S"
    )
    file_handler.setFormatter(file_formatter)

    # Rich handler with func and filename included in the format
    console_handler = DimmedFuncNameRichHandler(
        show_time=True,
        omit_repeated_times=False,
        show_level=True,
        show_path=False, 
        rich_tracebacks=True,
        markup=True,
        enable_link_path=True,
        show_func_name=show_func_name,
        show_name=show_name,
    )
    console_handler.setLevel(logging_level)

    # NOTE: Injecting our format so RichHandler honors it
    logging.basicConfig(
        level=logging.DEBUG,
        handlers=[file_handler, console_handler],
        format="%(message)s",
        datefmt="%Y-%m-%d %H:%M:%S"
    )

    logger = logging.getLogger()
    if verbose or debug:
        logger.info("Logging initialized.")
        if debug:
            logger.debug("Debug mode is ON.")
    return logger

