#!/usr/bin/env python3
"""
Annotations Translator: translate annotations into natural language descriptions.

Used to translate the `annotations` field in `plotting_code` into readable English descriptions.
"""

from typing import Dict, List, Any, Optional


def translate_annotations(annotations: Dict[str, Any]) -> str:
    """
    Translate the annotations dictionary into a natural language description.
    
    Args:
        annotations: annotations dictionary, including keys such as
        right_angles, length_of_line, measure_of_angle, etc.
    
    Returns:
        A string containing the translated natural language description.
    """
    if not annotations:
        return ""
    
    descriptions = []
    
    # Translate right angle annotations
    right_angles = annotations.get("right_angles", [])
    if right_angles:
        right_angle_descs = []
        for entry in right_angles:
            if isinstance(entry, (list, tuple)) and len(entry) == 3:
                p1, vertex, p2 = entry  # Format: [p1, vertex, p2], vertex is in the middle
                desc = f"∠{p1.upper()}{vertex.upper()}{p2.upper()} = 90°"
                right_angle_descs.append(desc)
        if right_angle_descs:
            descriptions.append("Right angle annotations: " + ", ".join(right_angle_descs))
    
    # Translate length annotations
    length_of_line = annotations.get("length_of_line", [])
    if length_of_line:
        length_descs = []
        for entry in length_of_line:
            if isinstance(entry, (list, tuple)) and len(entry) == 2:
                segment, value = entry
                if isinstance(segment, (list, tuple)) and len(segment) == 2:
                    p1, p2 = segment
                    desc = f"{p1.upper()}{p2.upper()} = {value}"
                    length_descs.append(desc)
        if length_descs:
            descriptions.append("Length annotations: " + ", ".join(length_descs))
    
    # Translate angle measure annotations
    measure_of_angle = annotations.get("measure_of_angle", [])
    if measure_of_angle:
        angle_descs = []
        for entry in measure_of_angle:
            if isinstance(entry, (list, tuple)) and len(entry) == 2:
                angle, value = entry
                if isinstance(angle, (list, tuple)) and len(angle) == 3:
                    p1, vertex, p2 = angle
                    # Process the angle value, add degree symbol if it is numeric
                    value_str = str(value)
                    if value_str.replace(".", "").replace("-", "").isdigit():
                        value_str = f"{value_str}°"
                    desc = f"∠{p1.upper()}{vertex.upper()}{p2.upper()} = {value_str}"
                    angle_descs.append(desc)
        if angle_descs:
            descriptions.append("Angle measure annotations: " + ", ".join(angle_descs))
    
    return "; ".join(descriptions) if descriptions else ""
    
    
def translate_annotations_to_dict(annotations: Dict[str, Any]) -> Dict[str, List[str]]:
    """
    Translate annotations into a structured dictionary format.
    
    Args:
        annotations: annotations dictionary
    
    Returns:
        A dictionary containing translated descriptions, with the format:
        {
            "right_angles": ["∠BAC = 90°", ...],
            "length_of_line": ["AB = 3", ...],
            "measure_of_angle": ["∠ABC = 45°", ...]
        }
    """
    result = {
        "right_angles": [],
        "length_of_line": [],
        "measure_of_angle": []
    }
    
    if not annotations:
        return result
    
    # Translate right angle annotations
    right_angles = annotations.get("right_angles", [])
    for entry in right_angles:
        if isinstance(entry, (list, tuple)) and len(entry) == 3:
            p1, vertex, p2 = entry  # Format: [p1, vertex, p2], vertex is in the middle
            desc = f"∠{p1.upper()}{vertex.upper()}{p2.upper()} = 90°"
            result["right_angles"].append(desc)
    
    # Translate length annotations
    length_of_line = annotations.get("length_of_line", [])
    for entry in length_of_line:
        if isinstance(entry, (list, tuple)) and len(entry) == 2:
            segment, value = entry
            if isinstance(segment, (list, tuple)) and len(segment) == 2:
                p1, p2 = segment
                desc = f"{p1.upper()}{p2.upper()} = {value}"
                result["length_of_line"].append(desc)
    
    # Translate angle measure annotations
    measure_of_angle = annotations.get("measure_of_angle", [])
    for entry in measure_of_angle:
        if isinstance(entry, (list, tuple)) and len(entry) == 2:
            angle, value = entry
            if isinstance(angle, (list, tuple)) and len(angle) == 3:
                p1, vertex, p2 = angle
                value_str = str(value)
                if value_str.replace(".", "").replace("-", "").isdigit():
                    value_str = f"{value_str}°"
                desc = f"∠{p1.upper()}{vertex.upper()}{p2.upper()} = {value_str}"
                result["measure_of_angle"].append(desc)
    
    return result
    
    
if __name__ == "__main__":
    # Simple test example
    test_annotations = {
        "right_angles": [["B", "A", "C"]],
        "length_of_line": [[["A", "B"], "3"], [["A", "C"], "6"]],
        "measure_of_angle": []
    }
    
    print("Test translation function:")
    print(translate_annotations(test_annotations))
    print("\nStructured output:")
    print(translate_annotations_to_dict(test_annotations))
    
    