"""
State management for the document QA system
"""

import logging
from typing import Callable, Dict, List, Optional

logger = logging.getLogger(__name__)

class DocumentQAState:
    """Tracks the state of the thinking process and document operations."""
    
    def __init__(self, callback: Optional[Callable[[str], None]] = None):
        self.current_step = 0
        self.steps = []
        self.retrieved_docs = {}
        self.retrieved_context = {}  # Store context for verification
        self.data_structure = {}
        self.extracted_info = {}
        self.verification_results = {}
        self.thought_process = []
        self.temporary_thoughts = []  # Track which thoughts are temporary
        self.document_store = None
        self.document_metadata = {}
        self.document_chunks = []  # Store all document chunks
        self.callback = callback  # Callback function to stream output
        self.step_answers = {}  # Store answers for each step
    
    def add_thought(self, agent_type: str, thought: str, temporary: bool = False):
        """Record a thought from an agent with appropriate flag.
        
        Args:
            agent_type: The type of agent adding the thought
            thought: The thought content
            temporary: If True, this is a temporary status message that should be hidden when new messages arrive
        """
        flag_map = {
            "planner": "[THINKING]",
            "retriever": "[SEARCH]",
            "extractor": "[EXTRACT]",
            "verifier": "[VERIFY]",
            "decision": "[DECISION]",
            "refinement": "[REFINE]",
            "synthesizer": "[DECISION]"
        }
        flag = flag_map.get(agent_type, "")
        thought_entry = f"{flag} {thought}"
        self.thought_process.append(thought_entry)
        
        # Track if this thought is temporary
        if temporary:
            self.temporary_thoughts.append(thought_entry)
            
        logger.info(f"ADD_THOUGHT: {thought_entry} {'(temporary)' if temporary else ''}")  # Add debug log
        
        # Stream the thought in real-time using the callback
        if self.callback:
            try:
                # Include a flag to indicate if this is a temporary thought
                self.callback(thought_entry, temporary=temporary)
                logger.info(f"CALLBACK_SENT: Successfully sent thought to callback")  # Add callback success log
            except Exception as e:
                logger.error(f"CALLBACK_ERROR: Error in callback: {str(e)}")  # Add callback failure log
        else:
            # Default to printing if no callback provided
            print(thought_entry)
    
    
    def add_temp_thought(self, thought: str):
        """Record a temporary thought."""
        self.add_thought("thinking", thought, temporary=True)
    
    def get_thought_trail(self) -> str:
        """Returns the full thought process trail."""
        return "\n".join(self.thought_process)
    
    def add_step_answer(self, step_num: int, answer: str):
        """Store the answer for a specific step."""
        self.step_answers[step_num] = answer
        logger.info(f"Step {step_num} answer stored.")
    
    def get_dependent_answers(self, step_info: Dict) -> Dict[int, str]:
        """Get answers from steps this step depends on."""
        dependencies = step_info.get("depends_on_steps", [])
        dependent_answers = {}
        
        for dep_step in dependencies:
            if dep_step in self.step_answers:
                dependent_answers[dep_step] = self.step_answers[dep_step]
            else:
                logger.warning(f"Dependency on step {dep_step} requested but answer not found")
        
        return dependent_answers 