import argparse
import json
import os


def format_model_name(model_name):
    return model_name.split("/")[-1]


def get_scene_names(stats_data):
    scene_names = []
    for key in stats_data.keys():
        if key != "overall":
            scene_names.append(key)
    return sorted(scene_names)


def generate_tikz_radar(stats_data):
    scene_names = get_scene_names(stats_data)
    num_scenes = len(scene_names)

    if num_scenes == 0:
        return ""

    models = []
    for model in stats_data["overall"].keys():
        models.append(model)

    colors = [
        "blue",
        "red",
        "green",
        "orange",
        "purple",
        "brown",
        "pink",
        "olive",
        "cyan",
        "magenta",
    ]

    lines = []
    lines.append("\\begin{tikzpicture}[scale=0.25]")
    lines.append("    \\coordinate (origin) at (0, 0);")
    lines.append("")
    lines.append("    \\def\\maxscale{10}")
    lines.append("")

    scene_list = "{" + ", ".join(scene_names) + "}"
    lines.append(f"    \\foreach[count=\\i] \\dim in {scene_list}{{")
    lines.append(
        f"        \\draw[gray!50] (origin) -- (\\i * 360 / {num_scenes}: \\maxscale);"
    )
    lines.append(
        f"        \\node (title) at (\\i * 360 / {num_scenes}: 11) {{\\small\\dim}};"
    )
    lines.append("")
    lines.append("        \\foreach \\r in {2,4,6,8,10}{")
    lines.append(
        f"            \\draw[gray!30, very thin] (\\i * 360 / {num_scenes}: \\r) arc (\\i * 360 / {num_scenes}:\\i * 360 / {num_scenes} + 360/{num_scenes}:\\r);"
    )
    lines.append("        }")
    lines.append("    }")
    lines.append("")
    lines.append("    \\foreach \\r in {2,4,6,8,10}{")
    lines.append("        \\draw[gray!30, dotted] (0,0) circle (\\r);")
    lines.append("    }")
    lines.append("")

    legend_y = -15
    legend_col = 0

    for model_idx, model in enumerate(models):
        color = colors[model_idx % len(colors)]
        display_name = format_model_name(model)

        coordinates = []
        for scene_idx, scene in enumerate(scene_names):
            if scene in stats_data and model in stats_data[scene]:
                value = stats_data[scene][model]["pass_1"] * 10
            else:
                value = 0.0
            coordinates.append(
                f"(p{model_idx}_{scene_idx + 1}) at ({scene_idx + 1} * 360 / {num_scenes}: {value:.1f})"
            )

        for coord in coordinates:
            lines.append(f"    \\coordinate {coord};")
        lines.append("")

        coord_refs = [f"(p{model_idx}_{i + 1})" for i in range(num_scenes)]
        coord_chain = " -- ".join(coord_refs) + " -- cycle"
        lines.append(
            f"    \\draw[thick, {color}, fill={color}!20, opacity=.7] {coord_chain};"
        )
        lines.append("")

        legend_x = -10 if legend_col == 0 else 2
        legend_x_end = -9 if legend_col == 0 else 3
        legend_text_x = -8.5 if legend_col == 0 else 3.5

        lines.append(
            f"    \\draw[fill={color}!20, opacity=.7] ({legend_x},{legend_y}) rectangle ({legend_x_end},{legend_y + 1});"
        )
        lines.append(
            f"    \\node[anchor=west] at ({legend_text_x},{legend_y + 0.5}) {{\\footnotesize {display_name}}};"
        )
        lines.append("")

        legend_y -= 2
        if legend_y < -23:
            legend_y = -15
            legend_col = 1

    lines.append("\\end{tikzpicture}")

    return "\n".join(lines)


def main():
    parser = argparse.ArgumentParser(description="Generate TikZ radar chart")
    parser.add_argument(
        "--stats-json", type=str, default="stats.json", help="Path to stats JSON file"
    )

    args = parser.parse_args()

    if not os.path.exists(args.stats_json):
        raise FileNotFoundError(f"Stats file not found: {args.stats_json}")

    with open(args.stats_json, "r") as f:
        stats_data = json.load(f)

    tikz_chart = generate_tikz_radar(stats_data)
    print(tikz_chart)


if __name__ == "__main__":
    main()
