import os
import pandas as pd
from openai import OpenAI

RUN_NAME = "chatgpt"                 #or: human, gemini, mixtral, llama
RESPONSE_COL = "response_chatgpt_empathy"  #or: response_human, response_gemini_empathy, response_mixtral_empathy, response_llama_empathy

key = os.getenv("OPENAI_API_KEY")
if not key:
    raise EnvironmentError("OPENAI_API_KEY is not set. Set it before running.")

client = OpenAI(api_key=key)

data = pd.read_csv("all_data.csv")

def _preamble(emotion, situation):
    return (
        f"I am a Speaker, feeling {emotion} because {situation} "
        "I shared these emotions with a Listener in a dialog:\n"
    )

def _example_block(emotion, situation, speaker_uttr, listener_reply, label):
    return (
        _preamble(emotion, situation) +
        f"Speaker: {speaker_uttr}\n"
        f"Listener: {listener_reply}\n\n"
        f"How empathetic is the Listener's response compared to how you would have responded for the same situation?\n"
        f"Answer: {label}\n"
    )

def examples_block(df):

    blocks = []

    for _, row in df.iterrows():

        emotion = row["emotion"]
        situation = row["situation"]
        speaker_uttr = row["speaker_uttr"]
        listener_response = row["response"]
        rating = row["rating"]

        blocks.append(_example_block(emotion, situation, speaker_uttr, listener_response, rating))
            
    return "\n".join(blocks)

def prepare_message(emotion, situation, speaker_uttr, response, sentiment):
    system_content = (
        "You are an evaluator of listener responses in conversations. "
        "Reply with exactly one word: Bad, Okay, or Good."
    )

    sent = (str(sentiment).lower() if sentiment is not None else "")
    if sent.startswith("pos"):
        path = "pos-examples.csv"
    elif sent.startswith("neg"):
        path = "neg-examples.csv"
    else:
        raise ValueError(f"Unexpected sentiment value: {sentiment}")

    #fewshot = pd.read_csv(path, sep='\t')
    fewshot = pd.read_csv(path)
    fewshot_block = examples_block(fewshot)

    user_content = (
        f"I will present you with responses to emotional situations. You need to rate how empathetic the responses are in terms of 'Bad', 'Okay', or 'Good' compared to how you would have responded in the same situations. I will show you a quick tutorial describing the concept of empathy along with some examples. \n\n"
        f"Empathy is the ability to understand and share the feelings of another person. It is the ability to put yourself in someone else's shoes and see the world from their perspective. Empathy is a complex skill that involves cognitive, emotional, and compassionate components.\n"
        f"Cognitive empathy is the ability to understand another person's thoughts, beliefs, and intentions. It is being able to see the world through their eyes and understand their point of view.\n"
        f"Affective empathy is the ability to experience the emotions of another person. It is feeling what they are feeling, both positive and negative.\n"
        f"Compassionate empathy is the ability to not only understand and share another person's feelings, but also to be moved to help if needed. It involves a deeper level of emotional engagement than cognitive empathy, prompting action to alleviate another's distress or suffering.\n"
        f"Empathy is important because it allows us to connect with others on a deeper level. It helps us to build trust, compassion, and intimacy. Empathy is also essential for effective communication and conflict resolution.\n\n"
        f"{fewshot_block}\n\n"
        f"{_preamble(emotion, situation)}"
        f"Speaker: {speaker_uttr}\n"
        f"Listener: {response}\n\n"
        f"How empathetic is the Listener's response compared to how you would have responded for the same situation?\n"
        f"Answer:"
    )

    return system_content, user_content

def get_response(system_content, user_content):
    
    r = client.chat.completions.create(
        model="gpt-4o-mini",
        messages=[
            {
                "role": "system",
                "content": system_content
            },
            {
                "role": "user",
                "content": user_content
            }
        ],
        logprobs=True,
        top_logprobs=3,
        temperature=0,
        top_p=1
    )
    
    return r

rows_wide = []
checkpoint_file = f"gpt4o_rates_{RUN_NAME}_checkpoint.csv"
final_file = f"gpt4o_rates_{RUN_NAME}_final.csv"
save_every = 50

if os.path.exists(checkpoint_file):
    rows_wide = pd.read_csv(checkpoint_file).to_dict(orient="records")
    start_index = len(rows_wide)
    print(f"Resuming from row {start_index}")
else:
    start_index = 0

for idx, (_,row) in enumerate(data.iloc[start_index:].iterrows(), start=start_index):
    new_row = row.to_dict()
    
    sys_msg, usr_msg = prepare_message(
            row['emotion'],
            row['situation'],
            row['speaker_uttr'],
            row[RESPONSE_COL],
            row['sentiment']
    )
        
    answer = get_response(sys_msg, usr_msg)
    #new_row[f"completion"] = answer
    new_row[f"answer"] = answer.choices[0].message.content
    new_row[f"system"] = sys_msg
    new_row[f"user"] = usr_msg

    rows_wide.append(new_row)

    if (idx + 1) % save_every == 0:
        pd.DataFrame(rows_wide).to_csv(checkpoint_file, index=False)
        print(f"Checkpoint saved at {idx+1} rows")

rates_df = pd.DataFrame(rows_wide)
rates_df.to_csv(final_file, index=False)
print("Final CSV saved")