from models.base_model import ObservationPrompt


def get_observation_prompt(observation):
    image_paths = observation.image_paths
    current_role = 'red' if observation.agent_id == 0 else 'blue'
    rules = (
        "1. The Coin Dilemma is a general-sum game played on a 5x5 grid board with two players (red and blue) and two types of coins (red and blue).\n"
        "2. Players receive rewards on different events:\n"
        "    a. A player collects one coin of its own color: the player +1 point.\n"
        "    b. A player collects one coin of the other player's color: the player +1 point, the other player -2 points.\n"
        "3. New coins spawn randomly on the board after each collection.")
    information_visual_obs = (
        f"1. You are the {current_role} player.\n"
        f"2. The recent {len(image_paths)} game frames are given in chronological order, with the most recent frame at the end. "
        "Each frame contains a snapshot of the game board on the left, and a table of events and counters on the right.\n"
        "3. The red and blue players are represented by a red and blue pacman icon, respectively. "
        "The red and blue coins are represented by red and blue coin icons, respectively. "
        "If both players are in the same position, they are represented by a half-red-half-blue pacman icon.")
    information_no_image = (f"1. You are the {current_role} player.\n"
                            f"2. The position [0 0] is the bottom-left corner, and the position [4 4] is the top-right corner.\n"
                            f"3. Your position is: {observation.obs[0:2]}.\n"
                            f"4. The other player's position is: {observation.obs[2:4]}.\n"
                            f"5. The coin of your color is at: {observation.obs[4:6]}.\n"
                            f"6. The coin of the other player's color is at: {observation.obs[6:8]}.\n")
    # additional prompt for persona experiments, don't use it in other experiments
    strategy_guidelines = (
        # "Consider the common welfare and collect only coins of your own color to avoid harming the other player's score."   # Common welfare
        "Consider only your own welfare and collect coins of all colors to maximize your score."     # Self-interest
    )
    control = ("1. <UP>: move one step upward.\n"
               "2. <DOWN>: move one step downward.\n"
               "3. <LEFT>: move one step left.\n"
               "4. <RIGHT>: move one step right.\n"
               "5. <STAY>: stay in the current position.")
    text = (f"GAME RULES:\n{rules}\n\n"
            f"PLAYER INFORMATION:\n{information_visual_obs if image_paths else information_no_image}\n\n"
            # f"STRATEGY GUIDELINES:\n{strategy_guidelines}\n\n"
            f"LEGAL ACTIONS:\n{control}")
    observation_prompt = ObservationPrompt(text=text, image_paths=image_paths)
    return observation_prompt
