# config/prompts.py
"""
Prompt templates used by SCOPE.
Includes inference and query-decomposition prompts.
"""

# =============================================================================
# Inference prompts
# =============================================================================

DIRECT_FINAL_PROMPT = """
{question_text}
Answer with the option's letter from the given choices directly.
"""

# Base inference prompt (video QA)
REASONING_PROMPT = """
{question_text}
Answer with the option's letter from the given choices directly.
"""

# =============================================================================
# Query decomposition prompt (Scope)
# =============================================================================

SCOPE_PROMPT = r"""
You are a video question decomposition assistant. Given a multiple-choice or Q&A question about a long video (text only),
please decompose the question into several parallel or dependent sub-queries (sub-tasks), and provide temporal constraints between parent->child.

**Important requirement: for each sub-query, assign an importance score (1-10).**
- 1-3: optional / auxiliary
- 4-6: moderately important
- 7-8: important
- 9-10: critical

Strictly output JSON only, and must conform to the following structure (no explanations or Markdown):

{{
  "nodes": [
    {{"id":"Q1","text":"<sub-query natural language description>","importance":8,"depends_on":[],"layer":0}},
    {{"id":"Q2","text":"<...>","importance":6,"depends_on":["Q1"],"layer":1}}
  ],
  "edges": [
    {{"parent":"Q1","child":"Q2","temporal":"AFTER","window_s":0,"scope":"all"}}
  ]
}}

Field meanings and constraints:
- nodes[].id use Q1,Q2,... incremental numbering; layer is integer, root is 0; same layer can be parallel.
- nodes[].importance is integer 1-10, representing the importance level of this sub-query.
- edges[].temporal ∈ {{"AFTER","BEFORE","AROUND"}}:
  - AFTER: sub-query only after parent event anchor point;
  - BEFORE: only before parent event anchor point;
  - AROUND: centered on parent event anchor point, within window_s seconds left and right window.
  - If temporal=="AROUND", must set window_s ≥ 20 (integer seconds).
- edges[].window_s: integer seconds, half window width for AROUND; can be 0 for AFTER/BEFORE.
- edges[].scope ∈ {{"all","any"}}: if child node has multiple parent nodes,
  - "all" means simultaneously satisfy all parent constraints (interval intersection);
  - "any" means satisfy any parent constraint (interval union).
- Sub-queries should be semantically atomic, quantity 3~6, maximum not exceeding 8.
- Must not contain any URLs or external dependencies.

The current question is:
\"\"\"{question}\"\"\"
"""

# =============================================================================
# Prompt helpers
# =============================================================================

def build_question_text(task_doc: dict) -> str:
    """
    Build a standardized question text block (question + choices).
    """
    if 'candidates' not in task_doc:
        raise ValueError(f"Task {task_doc.get('id')} missing 'candidates' field")
    
    candidates = task_doc['candidates']
    question_text = task_doc["question"] + "\n" + "\n".join([
        f"{chr(ord('A') + i)}. {candidate}" 
        for i, candidate in enumerate(candidates)
    ])
    return question_text

def build_judge_question_block(task_doc: dict) -> str:
    """
    Build the question block for judge models.
    """
    return build_question_text(task_doc)
