import logging


class IndentedFormatter(logging.Formatter):
    """Custom Formatter that adds indentation to all lines in a multiline message"""
    def format(self, record):
        message = super().format(record)  # Get the formatted message
        indented_message = '\t' + message.replace('\n', '\n\t')  # Add \t before each line
        return indented_message + '\n'


def setup_logger(log_file, debug_file):
    # Main logger (with timestamp and log level)
    main_logger = logging.getLogger("main")
    main_logger.setLevel(logging.INFO)

    main_formatter = logging.Formatter('%(levelname)s:\t%(message)s\n')

    file_handler_main = logging.FileHandler(log_file, encoding="utf-8")
    file_handler_main.setFormatter(main_formatter)

    file_handler_debug = logging.FileHandler(debug_file, encoding="utf-8")
    file_handler_debug.setFormatter(main_formatter)

    stream_handler_main = logging.StreamHandler()
    stream_handler_main.setFormatter(main_formatter)

    main_logger.addHandler(file_handler_main)
    main_logger.addHandler(file_handler_debug)
    main_logger.addHandler(stream_handler_main)

    # Sub logger (with automatic indentation)
    sub_logger = logging.getLogger("sub")
    sub_logger.setLevel(logging.INFO)

    sub_formatter = IndentedFormatter('%(message)s')
    stream_handler_sub = logging.StreamHandler()
    stream_handler_sub.setFormatter(sub_formatter)

    file_handler_sub = logging.FileHandler(log_file, encoding="utf-8")
    file_handler_sub.setFormatter(sub_formatter)

    file_handler_sub_debug = logging.FileHandler(debug_file, encoding="utf-8")
    file_handler_sub_debug.setFormatter(sub_formatter)

    sub_logger.addHandler(file_handler_sub)
    sub_logger.addHandler(file_handler_sub_debug)
    sub_logger.addHandler(stream_handler_sub)

    # Debug logger
    debug_logger = logging.getLogger("debug")
    debug_logger.setLevel(logging.INFO)

    debug_formatter = logging.Formatter('%(message)s\n')
    file_handler_debug = logging.FileHandler(debug_file, encoding="utf-8")
    file_handler_debug.setFormatter(debug_formatter)

    debug_logger.addHandler(file_handler_debug)  # Only writing to file

    return main_logger, sub_logger, debug_logger
