"""Enhanced orchestrator with intelligent synthesis and confidence calibration"""

from typing import Dict, List, Optional, Any, Tuple
from dataclasses import dataclass
from enum import Enum
from pydantic import BaseModel, Field
from langchain_core.prompts import ChatPromptTemplate
from langchain_core.language_models import BaseLanguageModel

from .state import MultiAgentState, Finding, AgentAnalysis


class QueryType(str, Enum):
    """Types of medical queries"""
    DIAGNOSTIC = "diagnostic"  # Yes/No questions
    MEASUREMENT = "measurement"  # Quantitative measurements
    COMPARISON = "comparison"  # Compare with prior
    COMPREHENSIVE = "comprehensive"  # Full assessment
    LOCALIZATION = "localization"  # Where is X?


class QueryAnalysisResult(BaseModel):
    """Enhanced query analysis with priorities and dependencies"""
    primary_agents: List[str] = Field(description="Must-have agents for this query")
    secondary_agents: List[str] = Field(description="Optional agents based on findings")
    agent_priorities: Dict[str, float] = Field(description="Priority scores (0-1) for each agent")
    execution_order: List[str] = Field(description="Optimal execution sequence")
    query_type: QueryType = Field(description="Type of medical query")
    expected_outputs: List[str] = Field(description="Expected findings or measurements")
    confidence_threshold: float = Field(description="Minimum confidence for reliable answer")
    requires_comparison: bool = Field(description="Whether prior image comparison needed")
