"""
Orchestra Core - 问答类 Prompt

用于信息检索、问题回答等任务。
这类任务的特点是需要收集信息并给出最终答案。
"""
from __future__ import annotations

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

from orchestra_core.prompts.base import BasePromptBuilder


class QuestionAnsweringPrompt(BasePromptBuilder):
    """问答类 Prompt 构建器"""
    
    @staticmethod
    def build_prompt(
        instruction: str,
        meta: Dict[str, Any],
        tools_description: str,
        prior_context: str,
        attempt_index: int,
        max_attempts: int,
        sub_models: List[str],
        subtask_history: str = "",
        model_to_alias: Optional[Dict[str, str]] = None,
        price_getter: Optional[Callable[[str, str], float]] = None,
    ) -> str:
        """构建问答类 prompt"""
        remaining_attempts = max_attempts - attempt_index + 1
        
        # 构建可选组件
        model_pricing_table = BasePromptBuilder.build_model_pricing_table(
            sub_models, model_to_alias, price_getter
        )
        
        return f"""
[QUESTION ANSWERING TASK]
You are the MainAgent (Orchestrator). Your task is to solve the given QUESTION by decomposing it into subtasks and delegating each to a sub-agent.

DECISION PROCESS:
1. REVIEW the SUBTASK HISTORY below - check status, result, and key findings of each attempt
2. EVALUATE: Do the results SUFFICIENTLY answer the QUESTION?
   - If any subtask returned a valid result with status "done" → Consider using 'complete'
   - If subtask status is "incomplete" → Review its key findings to see what was accomplished
3. DECIDE next action:
   - Results sufficient → Use 'complete' with the answer
   - Need more work → Use 'delegate_task' for the REMAINING work (don't repeat what's done)

BUDGET AWARENESS:
- You have LIMITED attempts (see Progress below)
- Each delegation costs time and resources - choose models wisely
- If a result looks correct and was verified, trust it and complete

==== MODEL SELECTION GUIDE ====
{model_pricing_table}

Model Selection Strategy:
- Choose cheaper models for simple tasks
- Choose more capable models for complex reasoning

==== Progress ====
[Attempt {attempt_index}/{max_attempts}] Remaining {remaining_attempts} attempts
⚠️ Budget is limited. Make each attempt count.

==== QUESTION ====
{instruction}

==== SUBTASK HISTORY ====
{subtask_history if subtask_history else "No subtasks completed yet."}

==== AVAILABLE TOOLS ====
{tools_description}

==== OUTPUT ====
ANSWER FORMAT: Provide precise, concise answers. Do NOT include explanations in the answer field.

Return JSON:

If results are SUFFICIENT:
{{
  "action": "complete",
  "reasoning": "The subtask results show [X], which answers the question",
  "params": {{ "answer": "concise answer" }}
}}

If more work is NEEDED:
{{
  "action": "delegate_task", 
  "reasoning": "We have [X] from previous attempts, but still need [Y] to answer the question",
  "params": {{
    "task_instruction": "A SPECIFIC, ACTIONABLE subtask",
    "context": "Relevant findings from previous attempts",
    "model": "one of {sub_models}"
  }}
}}
""".strip()
