#!/usr/bin/env python3
"""
Generate an ICLR-style introduction and compile the PDF.
All paths are anonymized via ANON_PROJECT_ROOT.
"""

import re
import json
import tqdm  # type: ignore
import argparse
import requests  # type: ignore
import random
import os
from loguru import logger  # type: ignore
from concurrent.futures import ThreadPoolExecutor
from create_util import *
from create_cite import *

# ----------  Arg Parsing  ----------
parser_manager = ArgParser()
args = parser_manager.add_topic_args().add_model_args().parse()

topic: str = args.topic
topic_description: str = args.topic_description
model_name: str = args.model_name

# ----------  Anonymous Base Directory  ----------
BASE_DIR = os.environ.get("ANON_PROJECT_ROOT", "./anonymous_root")
WORK_DIR = os.path.join(BASE_DIR, topic, topic_description)
INTRO_TEX = os.path.join(WORK_DIR, "latex", "content", "introduction.tex")
BIB_FILE = os.path.join(WORK_DIR, "latex", "iclr2025_conference.bib")

# ----------  Load Data  ----------
IDEAS_JSON = os.path.join(WORK_DIR, "ideas.json")
with open(IDEAS_JSON, "r", encoding="utf-8") as f:
    paper_information = json.load(f)

META_JSON = os.path.join(BASE_DIR, topic, "paper_info.json")
with open(META_JSON, "r", encoding="utf-8") as f:
    other_paper = json.load(f)

related_work = [
    {"citation_key": item["citation_key"], "summary": item["summary"]}
    for item in other_paper
]

ABSTRACT_TEX = os.path.join(WORK_DIR, "latex", "content", "abstract.tex")
with open(ABSTRACT_TEX, "r", encoding="utf-8") as f:
    abstract = f.read()

# ----------  Prompt for Introduction Generation  ----------
prompt = f"""
Write the introduction of the paper in ICLR style.

Guidelines:
- Expand the abstract into a full introduction.
- Clarify what the paper tries to achieve and why it matters.
- Explain why the problem is challenging.
- Describe the proposed solution and contributions.
- Summarize the experimental validation and key results.
- List contributions explicitly if possible.
- Use natural paragraphs instead of itemized lists.
- Apply correct citation commands (\\cite, \\citet, \\citep); avoid bare "et al."
- Output only LaTeX code inside ```latex```.

#### Abstract ####
{abstract}
#### Paper Information ####
{paper_information}
#### Related Work for Citation ####
{related_work}
"""

# ----------  Skip if Introduction Already Exists  ----------
if os.path.exists(INTRO_TEX) and os.path.getsize(INTRO_TEX) > 100:
    logger.info("Introduction already generated; skipping.")
    exit()

# ----------  Generate Introduction  ----------
latex_output = ""
while len(latex_output) < 10:
    model = ChatAgent(model_name)
    latex_output = model.chat_with_latex_retry(prompt)

# ----------  Handle Citations  ----------
get_cite_from_llm_and_arxiv(latex_output, BIB_FILE)
delete_cite(latex_output, INTRO_TEX)

with open(INTRO_TEX, "w", encoding="utf-8") as f:
    f.write(latex_output)

logger.info(f"Introduction written to {INTRO_TEX}")

# ----------  Compile PDF  ----------
from create_pdf import create_pdf
create_pdf(topic, topic_description)