import json
import os
import re
from typing import List, Dict, Any


from typing import Dict, Any

def generate_image_prompt(question_data: Dict[str, Any]) -> str:
    """
    Generate a structured image prompt based on question scene data.
    
    Args:
        question_data: A dictionary containing stage2_output with scenes.
    
    Returns:
        str: A formatted prompt for consistent image generation across scenes.
    """
    # Extract scenes from stage2_output.scenes
    scenes = question_data.get("scenes", [])
    num_scenes = len(scenes)

    if num_scenes == 0:
        return "Error: No scenes provided."
    
    
    
    prefix = f"""############################## sys prompt ############################################
        You are a skilled and consistent image generator working on a sequential, multi-scene visual task. You must follow these HARD CONSTRAINTS across the entire session:

        =========================
        ***GLOBAL RULES*** (NO EXCEPTIONS):

        1. You will be given a list of {num_scenes} distinct scene descriptions.
        2. You MUST generate exactly ONE image per scene, and generate them in the exact order they are listed: from Scene 1 to Scene {num_scenes}.
        3. You MUST NOT:
            - Skip any scene.
            - Repeat or regenerate a previously generated scene.
            - Merge multiple scenes into a single image.
            - Generate scenes out of order.
        4. Each image must match ONLY that scene's description.
        5. Every image must:
            - Follow a clean, picture-story illustration style with consistent visual tone.
            - Match all specified visual quantities, character features, spatial arrangements, and objects exactly.
        6. Do NOT invent visual elements. Do NOT carry over any elements from previous scenes unless explicitly instructed.
        7. Maintain strict consistency in:
            - Character design (clothing, hairstyle, expression).
            - Background tone and layout.
            - Lighting and color saturation.

        =========================
        ***GENERATION STRATEGY***:

        - Begin with Scene 1. Read and understand the description carefully.
        - Generate the image only for Scene 1.
        - Then, and only then, proceed to Scene 2. After finish Scene2 , then Scene3 image generation.
        - Repeat until all {num_scenes} scenes have been generated, each as a separate image.
        - Never repeat or jump scenes. Never combine or blend content between scenes.

        ##########################################################################
        
        MUST FOLLOW ALL THE INSTRUTION!!!
        
        I WILL GIVE YOU ALL SCENE DESCRIPTION ONCE.
        
        PLEASE WAIT FOR ALL SCENES INPUT:

        """

    prompt = f"""  # CASE {question_data.get("question_id", "")}
    
You are a **skilled and consistent image illustrator**. You will continuously generate **{num_scenes} distinct and separate images**, each corresponding to exactly one of the scenes described below. You must follow the detailed instructions and generation process with no exception.

***STRICT GENERATION RULES:***
- You MUST generate **exactly one image per scene**.
- You MUST generate the images in the exact given order: from **Scene 1** to **Scene {num_scenes}**.
- You MUST NOT generate multiple images for the same scene.
- You MUST NOT skip any scenes.
- You MUST NOT repeat or regenerate previously generated scenes.


***IMAGE STYLE & FORMAT RULES:***
- All {num_scenes} images must follow a  **Pixar-style** with clear, sharp, and naturally lit rendering — **no warm tints, soft color haze, textures, or yellow glow**.
- Use consistent character design, background tone, and visual quality across all scenes.
- Every image must **strictly match all numeric and descriptive details** from its corresponding scene.
- Each image must be **square format (exactly 1024 × 1024 pixels (square, 1:1))**.
---

Now begin generating the images **scene by scene**, in strict order.
Generate the image corresponding to the current scene.
Each new image must correspond to the **next numbered scene** and must not duplicate any earlier scenes.
Scene 1 Special Start Instruction:
Before generating Scene 1 image, explicitly output: "Now generating Scene 1 image (Pixar-style, at exactly 1024 × 1024 pixels (square, 1:1)). "
Then explicitly output the Scene 1 description in full.
After that, generate Scene 1 image.

After finishing any scene image, explicitly output: Scene X image finished, now generate Scene X+1 image (Pixar-style, at exactly 1024 × 1024 pixels (square, 1:1)).

Then explicitly output the Scene X+1 description in full.
After that, generate Scene X+1 image.

After all scenes images generated, explicitly output: All finished!

#######################################

The {num_scenes} scenes are described below:\n\n
"""
    # Scene descriptions - combine object, composition, action
    for i, scene in enumerate(scenes, 1):
        object = scene.get("object", "").strip()
        composition = scene.get("composition", "").strip()
        action = scene.get("action", "").strip()
        
        # Combine the three components into a complete description
        description_parts = []
        if object:
            description_parts.append(f"Objects:\n{object}")
        if composition:
            description_parts.append(f"Composition:\n{composition}")
        if action:
            description_parts.append(f"Action:\n{action}")
        
        description = "\n\n".join(description_parts)
        
        prompt += f"**Scene {i} of {num_scenes}**:\n{description}\n\n\n"
        
    # prompt = prefix + prompt

    return prompt, prefix


def process_modified_scenes(
    input_file: str = "a.json",
    output_dir: str = "data/gen_prompt/",
        output_filename: str = "gen_prompt_time_span.json"
    ) -> None:
    """
    Process web output scenes and generate image prompts.
    
    Args:
        input_file: Path to the web output JSON file
        output_dir: Directory to save the output JSON
        output_filename: Name of the output JSON file
    """
    # Create output directory if it doesn't exist
    os.makedirs(output_dir, exist_ok=True)
    
    # Load web output data
    try:
        with open(input_file, "r", encoding="utf-8") as f:
            web_output_data = json.load(f)
            print(f"Loaded {len(web_output_data)} questions from {input_file}")
    except (json.JSONDecodeError, FileNotFoundError) as e:
        print(f" Error loading input file: {e}")
        return
    
    # Prepare result data
    result_data = []
    
    # Process each question
    for question_data in web_output_data:
        question_id = question_data.get("question_id", "unknown")
        original_question = question_data.get("original_question", "")
        math_ground_truth = question_data.get("math_ground_truth", "")
        


        try:
            # Generate image prompt
            generate_prompt, prefix = generate_image_prompt(question_data)
            
            # Create result entry
            result_entry = {
                "question_id": question_id,
                "original_question": original_question,
                "math_ground_truth": math_ground_truth,
                "generate_prompt": generate_prompt,
            }
            
            result_data.append(result_entry)
            print(f"Generated image prompt for question ID {question_id}")
            
        except Exception as e:
            print(f"Error generating prompt for question ID {question_id}: {e}")
     
    # Save results to output file
    output_path = os.path.join(output_dir, output_filename)
    with open(output_path, "w", encoding="utf-8") as f:
        json.dump(result_data, f, ensure_ascii=False, indent=2)
    
    print(f"Saved {len(result_data)} image prompts to {output_path}")

if __name__ == "__main__":
    # Run the processing function
    process_modified_scenes()