"""
Environment Adapter for React* agent.

This module provides an adapter to wrap external environment operations
(like autorpa.EnvOperation) into a clean interface that react_star can use.
"""

from typing import Any, Dict, List, Optional


class EnvironmentAdapter:
    """
    Adapter to wrap external environment operations.
    
    This allows react_star to work with different environment implementations
    without directly depending on them.
    """
    
    def __init__(self, env_op: Any):
        """
        Initialize adapter with an environment operation object.
        
        Args:
            env_op: Environment operation object (e.g., autorpa.EnvOperation)
        """
        self._env_op = env_op
    
    @property
    def raw_env(self) -> Any:
        """Get the raw environment."""
        return getattr(self._env_op, 'raw_env', None)
    
    @property
    def cur_obs(self) -> Any:
        """Get current observation."""
        return getattr(self._env_op, 'cur_obs', None)
    
    @property
    def before_obs(self) -> Any:
        """Get observation before last action."""
        return getattr(self._env_op, 'before_obs', None)
    
    @property
    def action_history(self) -> List[str]:
        """Get action history."""
        return getattr(self._env_op, 'action_history', [])
    
    @property
    def env_op_traj(self) -> List[Any]:
        """Get environment operation trajectory."""
        return getattr(self._env_op, 'env_op_traj', [])
    
    @property
    def executed_element_index(self) -> List[int]:
        """Get executed element indices."""
        return getattr(self._env_op, 'executed_element_index', [])
    
    @property
    def done(self) -> bool:
        """Check if task is done."""
        return getattr(self._env_op, 'done', False)
    
    def execute_code(
        self,
        code: str,
        vars: Optional[Dict[str, Any]] = None,
        save_path: Optional[str] = None
    ) -> tuple[List[Any], Any]:
        """
        Execute action code.
        
        Args:
            code: Action code to execute
            vars: Variables to use in execution
            save_path: Path to save execution logs
            
        Returns:
            Tuple of (trajectory, execution_result)
        """
        if hasattr(self._env_op, 'execute_code'):
            return self._env_op.execute_code(code, vars=vars or {}, save_path=save_path or '')
        else:
            raise NotImplementedError("Environment does not support execute_code")
    
    def mark_target_index(
        self,
        screenshot: Any,
        ui_elements: List[Any],
        target_index: int
    ) -> Any:
        """
        Mark target element on screenshot.
        
        Args:
            screenshot: Screenshot image
            ui_elements: List of UI elements
            target_index: Index of target element
            
        Returns:
            Modified screenshot with marked target
        """
        if hasattr(self._env_op, 'mark_target_index'):
            return self._env_op.mark_target_index(screenshot, ui_elements, target_index)
        else:
            return screenshot
    
    def update_obs(self, file_prefix: str = None) -> Any:
        """
        Update current observation by taking a new screenshot.
        
        Args:
            file_prefix: Optional file prefix for saved screenshots
            
        Returns:
            Updated ScreenObs object
        """
        if hasattr(self._env_op, 'update_obs'):
            return self._env_op.update_obs(file_prefix)
        return None


class AgentAdapter:
    """
    Adapter to wrap Agent_RPA for use with react_star.
    
    This allows react_star to access necessary Agent_RPA functionality
    without tightly coupling to it.
    """
    
    def __init__(self, agent_rpa: Any):
        """
        Initialize adapter with an Agent_RPA instance.
        
        Args:
            agent_rpa: Agent_RPA instance
        """
        self._agent = agent_rpa
    
    @property
    def llm(self) -> Any:
        """Get the LLM wrapper."""
        return getattr(self._agent, 'llm', None)
    
    @property
    def log_task_path(self) -> str:
        """Get log task path."""
        return getattr(self._agent, 'log_task_path', '')
    
    @property
    def cur_task(self) -> str:
        """Get current task."""
        return getattr(self._agent, 'cur_task', '')
    
    @cur_task.setter
    def cur_task(self, value: str):
        """Set current task."""
        if hasattr(self._agent, 'cur_task'):
            self._agent.cur_task = value
    
    @property
    def reflection(self) -> Optional[str]:
        """Get reflection."""
        return getattr(self._agent, 'reflection', None)
    
    @reflection.setter
    def reflection(self, value: Optional[str]):
        """Set reflection."""
        if hasattr(self._agent, 'reflection'):
            self._agent.reflection = value
    
    @property
    def previous_plan(self) -> str:
        """Get previous plan."""
        return getattr(self._agent, 'previous_plan', '')
    
    @previous_plan.setter
    def previous_plan(self, value: str):
        """Set previous plan."""
        if hasattr(self._agent, 'previous_plan'):
            self._agent.previous_plan = value
    
    @property
    def completed_tasks(self) -> List[str]:
        """Get completed tasks."""
        return getattr(self._agent, 'completed_tasks', [])
    
    @property
    def screen_changes(self) -> str:
        """Get screen changes."""
        return getattr(self._agent, 'screen_changes', '')
    
    @screen_changes.setter
    def screen_changes(self, value: str):
        """Set screen changes."""
        if hasattr(self._agent, 'screen_changes'):
            self._agent.screen_changes = value
    
    @property
    def additional_guidelines(self) -> str:
        """Get additional guidelines."""
        return getattr(self._agent, 'additional_guidelines', '')
    
    @property
    def action_history(self) -> List[str]:
        """Get action history."""
        return getattr(self._agent, 'action_history', [])
    
    @property
    def agent_traj(self) -> List[Any]:
        """Get agent trajectory."""
        return getattr(self._agent, 'agent_traj', [])
    
    @property
    def flag_done(self) -> bool:
        """Get done flag."""
        return getattr(self._agent, 'flag_done', False)
    
    @flag_done.setter
    def flag_done(self, value: bool):
        """Set done flag."""
        if hasattr(self._agent, 'flag_done'):
            self._agent.flag_done = value
    
    @property
    def record_token(self) -> Any:
        """Get token record."""
        return getattr(self._agent, 'record_token', None)
    
    @property
    def env_op(self) -> Any:
        """Get environment operation."""
        return getattr(self._agent, 'env_op', None)
    
    @env_op.setter
    def env_op(self, value: Any):
        """Set environment operation."""
        if hasattr(self._agent, 'env_op'):
            self._agent.env_op = value
    
    def reset(self, task: Any, log_task_path: str, to_init_task: bool = True) -> int:
        """Reset the agent."""
        if hasattr(self._agent, 'reset'):
            return self._agent.reset(task, log_task_path, to_init_task)
        return 0
    
    def Concluder_Agent(self, goal: str, log_task_path: str, episode_results: Any) -> Any:
        """Call Concluder agent."""
        if hasattr(self._agent, 'Concluder_Agent'):
            return self._agent.Concluder_Agent(goal, log_task_path, episode_results)
        return None

