import os

os.environ.setdefault("MPLCONFIGDIR", "/tmp/matplotlib")

from pathlib import Path

import matplotlib.pyplot as plt
import pandas as pd
import seaborn as sns


def _resolve_paths():
    base_dir = (
        Path(__file__).resolve().parent if "__file__" in globals() else Path.cwd()
    )
    root_dir = base_dir
    while root_dir != root_dir.parent and not (root_dir / "final_results").is_dir():
        root_dir = root_dir.parent
    drawing_dir = base_dir
    results_dir = root_dir / "final_results"
    rank_dir_nlp_cv = results_dir / "ranking" / "nlp_cv"
    rank_dir_tabular = results_dir / "ranking" / "tabular"
    fig_dir = results_dir / "figures"
    fig_dir.mkdir(parents=True, exist_ok=True)
    return (
        root_dir,
        drawing_dir,
        results_dir,
        rank_dir_nlp_cv,
        rank_dir_tabular,
        fig_dir,
    )


PROJECT_DIR, DRAWING_DIR, RESULTS_DIR, RANK_DIR_NLP_CV, RANK_DIR_TABULAR, FIG_DIR = (
    _resolve_paths()
)


def draw_boxplot_metric(file_path, output_path, metric_col, y_label):
    data = pd.read_csv(file_path)
    if metric_col not in data.columns:
        raise ValueError(f"Missing column '{metric_col}' in {file_path}")

    relevant_data = data[["Model", metric_col]].copy()

    group_mapping = {
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Traditional",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Deep Learning",
        : "Proposed",
    }
    relevant_data["Group"] = relevant_data["Model"].map(group_mapping)

    group_order = ["Traditional", "Deep Learning", "Proposed"]
    model_order = []
    for group in group_order:
        models = relevant_data[relevant_data["Group"] == group]["Model"].unique()
        model_order.extend(models)

    relevant_data["Model"] = pd.Categorical(
        relevant_data["Model"], categories=model_order, ordered=True
    )

    group_colors = {
        : "#ADD8E6",
        : "#98FB98",
        : "#FFB6C1",
    }

    traditional_models = relevant_data[relevant_data["Group"] == "Traditional"][
        
    ].unique()
    deep_learning_models = relevant_data[relevant_data["Group"] == "Deep Learning"][
        
    ].unique()

    traditional_palette = sns.color_palette("Blues", len(traditional_models))
    deep_learning_palette = sns.color_palette("Greens", len(deep_learning_models))

    palette = {}
    for model in traditional_models:
        palette[model] = traditional_palette[list(traditional_models).index(model)]
    for model in deep_learning_models:
        palette[model] = deep_learning_palette[list(deep_learning_models).index(model)]
    palette["DVM-AD"] = "#FFB6C1"

    plt.figure(figsize=(14, 6))
    ax = sns.boxplot(
        data=relevant_data,
        x="Model",
        y=metric_col,
        hue="Model",
        palette=palette,
        dodge=False,
    )
    if ax.get_legend() is not None:
        ax.get_legend().remove()

    current_x = -0.5
    for group in group_order:
        count = relevant_data[relevant_data["Group"] == group]["Model"].nunique()
        plt.axvspan(
            current_x, current_x + count, color=group_colors[group], alpha=0.3, lw=0
        )
        current_x += count

    plt.ylabel(y_label, fontsize=12)
    plt.xlabel("Models", fontsize=12)
    plt.xticks(rotation=45, ha="right")
    plt.tight_layout()

    os.makedirs(os.path.dirname(output_path), exist_ok=True)
    plt.savefig(output_path, dpi=300)
    plt.close()

    print(f"Plot saved to {output_path}")


RANK_FILES = {
    : (RANK_DIR_NLP_CV, "dvmad_result_nlp_cv_10_datasets_rank.csv"),
    : (RANK_DIR_NLP_CV, "dvmad_result_tabular_47_datasets_rank.csv"),
    : (
        RANK_DIR_TABULAR,
        ,
    ),
    : (
        RANK_DIR_TABULAR,
        ,
    ),
    : (
        RANK_DIR_TABULAR,
        ,
    ),
    : (
        RANK_DIR_TABULAR,
        ,
    ),
}

for label, (rank_dir, filename) in RANK_FILES.items():
    file_path = rank_dir / filename
    if not file_path.exists():
        print(f"Missing file: {file_path}")
        continue

    
    draw_boxplot_metric(
        file_path, FIG_DIR / f"Box_AUROC_{label}.png", "AUCROC", "AUROC (%)"
    )
    draw_boxplot_metric(
        file_path, FIG_DIR / f"Box_AUPRC_{label}.png", "AUCPR", "AUPRC (%)"
    )








