from UIAgents.Agent_RPA.prompts.general_prompt import OPERATION_GUIDANCE_PROMPT, \
  FUNCTION_ACTIONS_PROMPT

PROMPT_HEADER = """[system]
You are an intelligent agent that operates an Android phone for a user.
Observe the screen and take the appropriate one-step action to achieve the goal.

[user]
"""

OUTPUT_FORMAT_TEMPLATE = """
Your output format must strictly match the [Output format] below.

[Output Format]
Your output should consist of the following things:
### Observations:
Summarize key input details and immediate screen observations. Include all obvious insights.
### Completed Tasks:
List completed tasks, each starting with a ✅.
### Next Action Justification:
Explain why the next action is chosen.
### Action:
Output the next action code (one action, one line). Use only [ADMISSIBLE ACTIONS] and DO NOT use `env_op.find_element()`.
"""
# ### Soft-coded Action:
# Output the code with the replaced xpath according to [XPath Replacement] (three lines: kwargs=, xpath=, and Action). Always include this section.

WORKFLOW_ONE_STEP_ACTOR = ("""
[Your Workflow]
1. Understand Goal: Read and interpret the given goal (e.g., "Click the 'Ok' button") to determine the intended action.
2. Analyze UI: Inspect the current screen information to find the UI element relevant to the goal.
3. Evaluate Progress: Check if the goal is achieved; if so, stop. Otherwise, update completed tasks.
4. Generate Next Action: Choose the next logical action that advances the goal.
""")
# 5. Generate Soft-coded Action: Use dynamic element matching (via `env_op.find_element`) to replace hardcoded xpath.

ONE_STEP_ACTOR_EXAMPLE = """
[Sample Output]
User goal/request is: Click the "Ok" button.
OBSERVING...
### Observations:
The current screen displays an HTML page with various elements, including a button labeled "Ok." The button appears clickable based on its styling and position, as seen in the screenshot.
### Completed Tasks:
...
### Next Action Justification:
Clicking the "Ok" button directly satisfies the user's request and is the simplest action required to complete the task.
### Action:
```python
env_op.click_xpath('//button[text()="Ok"]')
```
"""
# ### Soft-coded Action:
# ```python
# kwargs = {{"key_dom": {{"text": "Ok", "tag": "button"}}, "target_description": "Button labeled 'Ok' for confirming actions"}}
# xpath = env_op.find_element(**kwargs)
# env_op.click(xpath)
# ```

WORK_GUIDELINES = """
[Guidelines]
- Your code must be directly executable in the given environment. I won't implement any placeholders in your code for you. After you output the code, the code will be executed.
- Interact only with verified UI elements.
"""

INPUT_TEMPLATE = ("""
# User goal/request: {goal}

[Input Provided]
- Action History & Execution Result:
{action_history}

- Current html and screenshot:
{ui_content}
""")

PROMPT_TEMPLATE = PROMPT_HEADER  + FUNCTION_ACTIONS_PROMPT + OPERATION_GUIDANCE_PROMPT + OUTPUT_FORMAT_TEMPLATE + WORKFLOW_ONE_STEP_ACTOR + WORK_GUIDELINES + ONE_STEP_ACTOR_EXAMPLE + INPUT_TEMPLATE


def get_one_step_actor_prompt(
  goal: str,
  action_history: list = None,
  ui_content: str = '',
) -> str:
  if action_history:
    action_history = '\n'.join(action_history)
  else:
    action_history = 'You just started, no action has been performed yet.'
  
  return PROMPT_TEMPLATE.format(goal=goal, action_history=action_history, ui_content=ui_content)
