import uuid
import json
import logging
from typing import List, Dict, Any

from rich.console import Console
from rich.table import Table
from rich.panel import Panel
from rich.tree import Tree
from rich.text import Text
from rich import box


logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
logging.getLogger('requests').setLevel(logging.WARNING)
logging.getLogger('httpx').setLevel(logging.WARNING)
logger = logging.getLogger(__name__)

class WorkEnvironment:
    """
    system state container

    Maintains for objective, tools, scratchpads, task_history, and active_registry.
    """

    def __init__(self):
        self.objective: List[str] = []
        self.tools: List[Dict] = []
        self.scratchpads: List[str] = []       
        self.task_history: List[Dict] = []     
        self.active_registry: List[Dict] = []  

        self.thinking_history: List[str] = []
        self.dispatch_list_history: List[Dict] = []

    def register_executor(self, context: str) -> str:
        executor_id = str(uuid.uuid4())
        
        entry = {
            "executor_id": executor_id,
            "context": context
        }
        self.active_registry.append(entry)
        
        # todo
        
        return executor_id

    def unregister_executor(self, executor_return: Dict):

        context_to_remove = executor_return.get("context")
        fc_content = executor_return.get("fc_content")
        result = executor_return.get("result")

        initial_len = len(self.active_registry)
        self.active_registry = [
            item for item in self.active_registry 
            if item["context"] != context_to_remove
        ]
        
        # if len(self.active_registry) == initial_len:
        #     logger.warning(f"Context not found in registry during unregister: {context_to_remove[:50]}...")
        
        history_entry = {
            "context": context_to_remove,
            "fc_content": fc_content,
            "result": result
        }
        self.task_history.append(history_entry)
        

    def debug_print_executors(self):
        print("\n--- WorkEnvironment Debug Info ---")
        print(f"Objective: {self.objective}")
        print(f"Active Executors ({len(self.active_registry)}):")
        for item in self.active_registry:
            print(f"  - ID: {item['executor_id']}, Context Preview: {item['context']}")
        print(f"Task History ({len(self.task_history)}):")
        for item in self.task_history:
            print(f"  - Result Preview: {str(item['result'])}")
        for item in self.scratchpads:
            print(f"  - Scratchpad Preview: {item}")
        print("----------------------------------\n")

    # by gemini-3-pro
    def print_status(self):
        console = Console()
        
        obj_tree = Tree("🎯 [bold green]Current Objectives[/bold green]")
        if not self.objective:
            obj_tree.add("[italic dim]No objectives set[/italic dim]")
        else:
            for obj in self.objective:
                obj_tree.add(f"[green]{obj}[/green]")

        active_table = Table(box=box.ROUNDED, show_header=True, header_style="bold yellow")
        active_table.add_column("Executor ID", style="cyan")
        active_table.add_column("Current Context", style="white")
        
        if not self.active_registry:
            active_table.add_row("-", "[italic dim]No active executors[/italic dim]")
        else:
            for item in self.active_registry:
                active_table.add_row(item.get("executor_id", "N/A"), item.get("context", ""))

        board_table = Table(box=box.SIMPLE, show_header=True, title="📌 Task Board (Pending)", title_style="bold blue")
        board_table.add_column("ID", style="magenta", width=4)
        board_table.add_column("Description")
        
        if not self.task_board:
            board_table.add_row("-", "[italic dim]Empty[/italic dim]")
        else:
            for task in self.task_board:
                board_table.add_row(str(task.get("id")), task.get("description"))

        history_table = Table(box=box.MINIMAL, show_header=True, title="📜 History (Completed)", title_style="bold white")
        history_table.add_column("Context", style="dim")
        history_table.add_column("Tool Call", style="cyan")
        history_table.add_column("Result (Truncated)", style="dim")

        if not self.task_history:
            history_table.add_row("-", "-", "-")
        else:
            for h in self.task_history:
                result_str = str(h.get("result", ""))
                truncated_result = (result_str[:40] + '...') if len(result_str) > 40 else result_str
                history_table.add_row(
                    h.get("context", ""),
                    h.get("fc_content", ""),
                    truncated_result
                )

        tool_names = [t.get("function", {}).get("name", "unknown") for t in self.tools]
        tool_text = Text(", ".join(tool_names), style="italic magenta")

        console.print()
        console.rule("[bold cyan]Agent Internal State System[/bold cyan]")
        console.print(obj_tree)
        console.print()
        
        console.print("[bold yellow]🚀 Active Executors:[/bold yellow]")
        console.print(active_table)
        
        console.print()
        console.print(board_table)
        
        console.print()
        console.print(history_table)
        
        console.print()
        console.print(Panel(tool_text, title="🛠️ Available Tools", border_style="magenta"))
        console.rule("[bold cyan]End State[/bold cyan]")
        console.print()