from typing import Optional

# Traj Summary
# Emphasize coherent narrative
# Show cause-effect between steps
# Highlight key decisions and reasons
# Be concise and avoid irrelevant info
# Emphasize clear task outcome

SUCCESSFUL_TRAJ_PROMPT = """
You are a concluder agent tasked with summarizing a successful screen operation trajectory with precision and clarity in one coherent paragraph.

[Guidelines]
You should follow the following workflow:
- Identify the minimal critical sequence of executed actions that directly led to achieving the goal.
- Focus on key actions that directly contributed to the goal, showing how each step led to the next.
- Highlight the reasoning behind critical decisions and their role in the task's success.
- Write a single coherent paragraph in natural language, emphasizing the causal relationships between actions.
- End with a clear statement showing how the final result fulfilled the user’s request.

General Guidelines (strictly follow):
- Do NOT summarize irrelevant steps or actions that did not contribute to achieving the final outcome.
- Directly output your summary without additional explanations.

[Input Provided]
- User goal/request: {goal}

- Completed Tasks (from Planner, may be inaccurate):
{completed_tasks}

- Action History & Execution Results:
{action_history}

- Final State Screen & UI elements:
{ui_info_str}
"""

FAILED_TRAJ_PROMPT = """
You are a concluder agent tasked with summarizing a failed screen operation trajectory and performing a critical reflection to prevent future errors.

[Output Format]
- Episode Conclusion: Provide a summary of the trajectory, clearly indicating where the failure occurred.
- Reflection: Identify and describe the key actions that failed, including specific reasoning for each failure (e.g., incorrect actions, UI misunderstandings, planner's incorrect judgment). State the primary cause(s) of failure. Provide clear, actionable steps to address these issues and achieve the task.

[Guidelines]
You should follow the following workflow in your thought:
1. Analyze Trajectory:
  - Identify and pinpoint exactly which step in the trajectory led to failure.
  - Clearly explain why this specific step failed (e.g., incorrect actions, misinterpretation of UI, planner’s inaccurate decision-making).
  - Highlight key decision points and provide specific reasoning behind each critical action.
2. Root Cause Analysis (RCA):
  - Clearly state the underlying cause(s) of the failure.
  - Highlight any misjudgments or missed opportunities for correction.
3. Formulate Corrective Guidelines:
  - Propose clear, actionable guidelines or improvements for avoiding similar failures in future attempts.
4. Summary Generation:
  - Focus on key actions that directly contributed to the goal, showing how each step led to the next.
  - Highlight the reasoning behind critical decisions and their role in the task's success.
  - Write a single coherent paragraph in natural language, emphasizing the causal relationships between actions.

General Guidelines (strictly follow):
- Avoid generic or unrelated descriptions; strictly avoid irrelevant or overly broad content.

[Input Provided]
- User goal/request: {goal}

- Completed Tasks (from Planner, may be inaccurate):
{completed_tasks}

- Action History & Execution Results:
{action_history}

- Final State Screen & UI elements:
{ui_info_str}

- Previous Reflections (if any):
{reflections}

- Environment Feedback:
{env_feedback}
"""


def get_concluder_prompt(
  goal: str,
  completed_tasks: str,
  action_history: list,
  ui_info_str: str,
  is_success: bool,
  reflection_history: Optional[list[str]] = None,
  env_feedback: str = ''
) -> str:
  if action_history:
    action_history = '\n'.join(action_history)
  else:
    action_history = 'You just started, no action has been performed yet.'
  
  if is_success:
    return SUCCESSFUL_TRAJ_PROMPT.format(
      goal=goal,
      completed_tasks=completed_tasks,
      action_history=action_history,
      ui_info_str=ui_info_str,
    )
  
  reflections = ''
  if reflection_history:
    for i in range(len(reflection_history)):
      reflections += f'## Reflection {i + 1}:\n' + reflection_history[i] + '\n'
  return FAILED_TRAJ_PROMPT.format(
    goal=goal,
    completed_tasks=completed_tasks,
    action_history=action_history,
    ui_info_str=ui_info_str,
    reflections=reflections,
    env_feedback=env_feedback,
  )
