import re
import pdb
import os, sys
from os import path
from PIL import Image
from pathlib import Path
from camel.models import ModelFactory
from camel.agents import ChatAgent
from camel.messages import BaseMessage
from camel.types import ModelPlatformType
ROOT = os.path.dirname(os.path.abspath(__file__))
sys.path.insert(0, os.path.join(ROOT, "Paper2Poster"))
from utils.wei_utils import get_agent_config


def subtitle_cursor_gen(slide_imgs_dir, prompt_path, model_config):
    model = ModelFactory.create(
        model_platform=model_config["model_platform"],
        model_type=model_config["model_type"],
        model_config_dict=model_config.get("model_config"),
        url=model_config.get("url", None),)
    agent = ChatAgent(model=model, system_message="",)
    
    with open(prompt_path, 'r', encoding='utf-8') as f_prompt: task_prompt = f_prompt.read()
    slide_image_list = [path.join(slide_imgs_dir, name) for name in os.listdir(slide_imgs_dir)]
    slide_image_list = sorted(slide_image_list, key=lambda x: int(re.search(r'\d+', x).group()))
    
    images = []
    for idx, img_path in enumerate(slide_image_list): images.append(Image.open(img_path))    
    messages = BaseMessage.make_user_message(role_name="user", content=task_prompt, image_list=images, meta_dict={})
    response = agent.step(messages)
    subtitle = response.msg.content.strip()
    return subtitle, response.info["usage"]

    ## generate slide step by step
    # slide_subtitle = []
    # cursor = []
    # for idx, img_path in enumerate(slide_image_list):
    #     image = Image.open(img_path).convert("RGB")
    #     if idx == 0:
    #         full_prompt = f"{task_prompt}\nNow generate subtitle for Slide {idx+1}."
    #     else:
    #         context = "\n".join([f"Slide {i+1}: {sub}" for i, sub in enumerate(slide_subtitle)])
    #         full_prompt = (
    #             f"{task_prompt}\n"
    #             f"Previous subtitles:\n{context}\n"
    #             f"Now generate subtitle for Slide {idx+1}.")
    #     messages = BaseMessage.make_user_message(role_name="user", content=full_prompt,  meta_dict={"image": image})
    #     response = agent.step(messages)
    #     subtitle = response.msg.content.strip()
    #     slide_subtitle.append(subtitle)
    return slide_subtitle


if __name__ == "__main__":
    os.environ["GEMINI_API_KEY"] = ""
    model_type = "gemini"
    slide_imgs_dir = "result/slide_imgs"
    prompt_path = "prompts/slide_subtitle_cursor_prompt.txt"
    model_config = get_agent_config(model_type)
    model_config["model_type"]
    
    import camel
    print("camel location:", camel.__file__)
    pdb.set_trace()
    slide_subtitle = subtitle_cursor_gen(slide_imgs_dir, prompt_path, model_config)
    print(slide_subtitle)
    
    

