import os
from pathlib import Path
import cv2
import numpy as np


def compute_dark_mask_from_rgb(rgb: np.ndarray, threshold: int = 50, kernel_size: int = 9) -> np.ndarray:
    if rgb is None:
        raise ValueError("RGB image is None")

    if rgb.ndim == 2:
        dark = rgb <= threshold
    else:
        dark = np.all(rgb <= threshold, axis=2)

    kernel = np.ones((kernel_size, kernel_size), np.uint8)
    dark_u8 = (dark.astype(np.uint8) * 255)
    cleaned = cv2.morphologyEx(dark_u8, cv2.MORPH_OPEN, kernel)
    return cleaned > 0


def load_or_create_dark_mask(image_path: str, mask_path: str, threshold: int = 50, kernel_size: int = 9) -> np.ndarray:
    mask_file = Path(mask_path)
    if mask_file.exists():
        return np.load(mask_file)

    rgb = cv2.imread(image_path, cv2.IMREAD_COLOR)
    if rgb is None:
        raise FileNotFoundError(f"Could not load image: {image_path}")

    dark_mask = compute_dark_mask_from_rgb(rgb, threshold=threshold, kernel_size=kernel_size)

    os.makedirs(mask_file.parent, exist_ok=True)
    np.save(mask_file, dark_mask)
    return dark_mask


def _hex_to_rgb(hex_color: str) -> tuple[int, int, int]:
    hex_color = hex_color.strip().lstrip("#")
    if len(hex_color) != 6:
        raise ValueError(f"Invalid hex color: {hex_color}")
    r = int(hex_color[0:2], 16)
    g = int(hex_color[2:4], 16)
    b = int(hex_color[4:6], 16)
    return r, g, b


def label_mask_from_hex(label_bgr: np.ndarray, hex_color: str) -> np.ndarray:
    if label_bgr is None:
        raise ValueError("Label image is None")

    rgb = _hex_to_rgb(hex_color)
    bgr = (rgb[2], rgb[1], rgb[0])
    if label_bgr.ndim == 2:
        return np.zeros_like(label_bgr, dtype=bool)

    return np.all(label_bgr == np.array(bgr, dtype=label_bgr.dtype), axis=2)
