from UIAgents.Agent_RPA.prompts.general_prompt import OPERATION_GUIDANCE_PROMPT, FUNCTION_ACTIONS_PROMPT
from UIAgents.Agent_RPA.utils import JSON_models

PROMPT_TEMPLATE = ("""
You are an intelligent agent that operates a web browser for a user.

[Your Duty]
Examine the current screen and review historical execution data to assess task status.
Evaluate progress, update completed tasks, and devise an efficient plan.
Can the current page continue execution to complete the task? Respond with Y or N.
"""
+ FUNCTION_ACTIONS_PROMPT + OPERATION_GUIDANCE_PROMPT +
"""
[Output Format]
- observation: Summarize key input details and immediate screen observations. Include all obvious insights.
- completed_tasks: List completed tasks, each starting with a ✅.
- plan_reason: Briefly explain the rationale behind your plan.
- plan_list: List tasks to achieve the goal, each starting with a ⬜; if the goal is achieved, output "goal completed."
- to_continue: Output a single letter to indicate whether to continue — Y or N.

[Input Provided]
- Task Execution Trajectory:
{exec_trajs_str}

- The current html and screenshot:
{ui_content}
""")


def get_exec_evaluator_prompt(rpa_exec_traj: JSON_models.RPAExecTraj, ui_content: str) -> str:
  exec_traj_str = f"# The task is: {rpa_exec_traj.task}\n" \
                  f"# Here is the code should be executed:\n" \
                  f"{rpa_exec_traj.rpa_code}\n" \
                  f"\n# Executed Result:\n" \
                  f"The code did not complete the task.\n" \
                  f"The error message is: {rpa_exec_traj.exec_result.error_message}\n"
  traj_str = '\n# Here is the execution history:\n'
  traj_str += '\n'.join(rpa_exec_traj.action_history)
  exec_traj_str += traj_str
  return PROMPT_TEMPLATE.format(
    exec_trajs_str=exec_traj_str,
    ui_content=ui_content,
  )
