#!/usr/bin/env python3
"""
Example usage of the JSONConverter class
"""

from converter import JSONConverter
import json


def example_usage():
    """Demonstrate how to use the JSONConverter class."""
    
    # Example 1: Convert from JSON object
    print("Example 1: Converting from JSON object")
    print("-" * 40)
    
    sample_graph = {
        "nodes": [
            {"name": "searcher", "function": "searcher"},
            {"name": "browser", "function": "browser"},
            {"name": "summarizer", "function": "summarizer"}
        ],
        "edges": [
            ["START", "searcher"],
            ["searcher", "browser"],
            ["browser", "summarizer"],
            ["summarizer", "END"]
        ],
        "conditional_edges": []
    }
    
    converter = JSONConverter()
    generated_code = converter.convert(sample_graph)
    print("Generated code:")
    print(generated_code)
    
    print("\n" + "="*50 + "\n")
    
    # Example 2: Convert from file
    print("Example 2: Converting from JSON file")
    print("-" * 40)
    
    # This would convert the sample_graph.json file
    json_file_path = "../../agents/openai/sample_graph.json"
    try:
        generated_code = converter.convert_from_file(json_file_path)
        print(f"Successfully converted {json_file_path}")
        print(f"Generated code length: {len(generated_code)} characters")
        
        # Save to output file
        output_path = "converted_graph.py"
        converter.save_to_file(
            converter.convert_from_file(json_file_path), 
            output_path
        )
        print(f"Saved generated code to {output_path}")
        
    except FileNotFoundError:
        print(f"File {json_file_path} not found")
    except Exception as e:
        print(f"Error: {e}")


def demonstrate_features():
    """Demonstrate specific features of the converter."""
    
    print("JSONConverter Features:")
    print("=" * 30)
    
    print("✅ Converts JSON graph definitions to executable langgraph code")
    print("✅ Supports nodes with custom configurations")
    print("✅ Generates wrapper functions for configured nodes")
    print("✅ Handles regular edges between nodes")
    print("✅ Generates routing functions for conditional edges")
    print("✅ Supports START and END special nodes")
    print("✅ Can load from JSON files or Python dictionaries")
    print("✅ Can save generated code to files")
    
    print("\nSupported JSON Structure:")
    print("-" * 25)
    
    structure = {
        "nodes": [
            {
                "name": "node_name",
                "function": "function_name",
                "config": {  # Optional
                    "param1": "value1",
                    "param2": "value2"
                }
            }
        ],
        "edges": [
            ["from_node", "to_node"],
            ["START", "first_node"],
            ["last_node", "END"]
        ],
        "conditional_edges": [
            {
                "from": "decision_node",
                "condition": "state.get('some_field')",
                "routes": {
                    "true": "path_a",
                    "false": "path_b"
                }
            }
        ]
    }
    
    print(json.dumps(structure, indent=2))


if __name__ == "__main__":
    example_usage()
    print("\n" + "="*80 + "\n")
    demonstrate_features()
