"""
Action Space Definitions for ReAct* Agent

This module contains the base action space used by the ReAct* agent during exploration.
These prompts define the available actions that the agent can take.

Note: ReAct* only generates hardcoded actions during exploration.
Action translation (soft-coding) is handled by AutoRPA in the building phase.
"""

ACTIONS_PREFIX = """
[ADMISSIBLE ACTIONS]
UI elements in the screenshot are marked with numeric indexes (bounding boxes with numbers at their top left). Use these numbers to refer to elements.
Only use the actions listed below. Do not use any other actions.
"""

ACTIONS_PREFIX_COORDINATE = """
[ADMISSIBLE ACTIONS]
You can interact with the screen using pixel coordinates (x, y). Coordinates are measured from the top-left corner of the screen, where (0, 0) is the top-left corner.
To determine coordinates, you can:
1. Estimate from the screenshot based on the screen size and element positions
2. Use the UI elements list which may contain bounding box information (bbox_pixels) with x_min, y_min, x_max, y_max values
3. Calculate relative positions based on screen dimensions
Only use the actions listed below. Do not use any other actions.
"""

ACTIONS_PROMPT = """
### Page Operation Actions:
click(index: int) # Click/Tap an element. Output like `click(6)`. DO NOT output `click(index: 6)`
long_press(index: int) # Long press an element.
input_text(text: str, clear_text: Optional[bool] = True) # Type text into a field (inputs text, and presses Enter). If clear_text is set to True, existing text will be cleared. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
input_text(text: str, index: int, clear_text: Optional[bool] = True) # Type text into a field (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
swipe(direction: str, index: Optional[int] = None) # Swipe an element or the entire screen in one of ["up", "down", "left", "right"]. To view content at the bottom, the swipe direction should be set to "up". For example, swipe up the screen to open the app drawer; swipe down to open the notification panel. Optionally specify an index.
wait(seconds: float = 1.0) # Pause for specified seconds (default 1.0). Do not abuse.
keyboard_enter() # Simulate the Enter key.

### Page Navigation Actions:
open_app(app_name: str) # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
go_back() # Move to the previous screen.
go_home() # Return to the home screen.

### Completion Actions (must be issued alone):
stop(goal_status: str) # Mark the task as "complete" (or "N/A" if impossible).
answer(text: str) # Provide a final answer to the user's question.
"""

ACTIONS_PROMPT_WITH_SHELL = """
### Page Operation Actions:
click(index: int) # Click/Tap an element. Output like `click(6)`. DO NOT output `click(index: 6)`
long_press(index: int) # Long press an element.
input_text(text: str, clear_text: Optional[bool] = True) # Type text into a field (inputs text, and presses Enter). If clear_text is set to True, existing text will be cleared. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
input_text(text: str, index: int, clear_text: Optional[bool] = True) # Type text into a field (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
swipe(direction: str, index: Optional[int] = None) # Swipe an element or the entire screen in one of ["up", "down", "left", "right"]. To view content at the bottom, the swipe direction should be set to "up". For example, swipe up the screen to open the app drawer; swipe down to open the notification panel. Optionally specify an index.
wait(seconds: float = 1.0) # Pause for specified seconds (default 1.0). Do not abuse.
keyboard_enter() # Simulate the Enter key.

### Page Navigation Actions:
open_app(app_name: str) # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
go_back() # Move to the previous screen.
go_home() # Return to the home screen.

### System Shell Actions:
shell(command: str) # Execute a shell command on the Android device through ADB. Examples: 'settings put system screen_brightness 100', 'dumpsys battery', 'pm list packages'.
# USAGE GUIDELINES:
#    ✅ For SYSTEM-LEVEL operations: Prefer shell for directness and efficiency
#       - Settings: shell("settings put system screen_brightness 100")
#       - System queries: shell("dumpsys battery"), shell("wm size")
#       - Package info: shell("pm list packages | grep contacts")
#    ❌ For UI INTERACTIONS: Use actions listed above, NOT shell
#       - Opening apps: open_app("AppName") NOT shell("am start ...")
#       - Clicking: click() NOT shell("input tap ...")
#       - Typing: input_text() NOT shell("input text ...")

### Completion Actions (must be issued alone):
stop(goal_status: str) # Mark the task as "complete" (or "N/A" if impossible).
answer(text: str) # Provide a final answer to the user's question.
"""

ACTIONS_PROMPT_JSON = """
### Page Operation Actions:
{{"action_type": "click", "index": <target_index>}}  # Click/Tap an element.
{{"action_type": "long_press", "index": <target_index>}}  # Long press an element.
{{"action_type": "input_text", "text": "<text_input>", "clear_text": <true_or_false>}}  # Type text into a field (inputs text, and presses Enter). If clear_text is set to True, existing text will be cleared. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
{{"action_type": "input_text", "text": "<text_input>", "index": <target_index>, "clear_text": <true_or_false>}}  # Type text into a field (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
{{"action_type": "swipe", "direction": "<up|down|left|right>", "index": <optional_index>}}  # Swipe an element or the entire screen in one of ["up", "down", "left", "right"]. For example, swipe up the screen to open the app drawer; swipe down to open the notification panel. Optionally specify an index.
{{"action_type": "wait", "seconds": <optional_seconds>}}  # Pause for specified seconds (default 1.0). Omit "seconds" field to use default.
{{"action_type": "keyboard_enter"}}  # Simulate the Enter key.

### Page Navigation Actions:
{{"action_type": "open_app", "app_name": "<app_name>"}}  # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
{{"action_type": "go_back"}}  # Move to the previous screen.
{{"action_type": "go_home"}}  # Return to the home screen.

### Completion Actions (must be issued alone):
{{"action_type": "stop", "goal_status": "<complete|N/A>"}}  # Mark the task as "complete" (or "N/A" if impossible).
{{"action_type": "answer", "text": "<answer_text>"}}  # Provide a final answer to a user question.
"""

ACTIONS_PROMPT_JSON_WITH_SHELL = """
### Page Operation Actions:
{{"action_type": "click", "index": <target_index>}}  # Click/Tap an element.
{{"action_type": "long_press", "index": <target_index>}}  # Long press an element.
{{"action_type": "input_text", "text": "<text_input>", "clear_text": <true_or_false>}}  # Type text into a field (inputs text, and presses Enter). If clear_text is set to True, existing text will be cleared. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
{{"action_type": "input_text", "text": "<text_input>", "index": <target_index>, "clear_text": <true_or_false>}}  # Type text into a field (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
{{"action_type": "swipe", "direction": "<up|down|left|right>", "index": <optional_index>}}  # Swipe an element or the entire screen in one of ["up", "down", "left", "right"]. For example, swipe up the screen to open the app drawer; swipe down to open the notification panel. Optionally specify an index.
{{"action_type": "wait", "seconds": <optional_seconds>}}  # Pause for specified seconds (default 1.0). Omit "seconds" field to use default.
{{"action_type": "keyboard_enter"}}  # Simulate the Enter key.

### Page Navigation Actions:
{{"action_type": "open_app", "app_name": "<app_name>"}}  # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
{{"action_type": "go_back"}}  # Move to the previous screen.
{{"action_type": "go_home"}}  # Return to the home screen.

### System Shell Actions:
{{"action_type": "shell", "command": "<shell_command>"}}  # Execute shell commands. Examples: 'settings put system screen_brightness 100', 'dumpsys battery'.
# USAGE: Prefer shell for system operations, use actions listed above for UI interactions (see above guidelines).

### Completion Actions (must be issued alone):
{{"action_type": "stop", "goal_status": "<complete|N/A>"}}  # Mark the task as "complete" (or "N/A" if impossible).
{{"action_type": "answer", "text": "<answer_text>"}}  # Provide a final answer to a user question.
"""

ACTIONS_PROMPT_COORDINATE = """
### Page Operation Actions:
click(x: int, y: int) # Click/Tap at coordinates (x, y). Output like `click(100, 200)`. DO NOT output `click(x: 100, y: 200)`
long_press(x: int, y: int) # Long press at coordinates (x, y).
input_text(text: str, clear_text: Optional[bool] = True) # Type text at the current cursor position (inputs text and presses Enter). If clear_text is set to True, existing text will be cleared. Use this when the cursor is already in a text field. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
input_text(text: str, x: int, y: int, clear_text: Optional[bool] = True) # Type text into a field at coordinates (x, y) (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
swipe(direction: str) # Swipe the entire screen in one of ["up", "down", "left", "right"]. To view content at the bottom, the swipe direction should be set to "up". For example, swipe up the screen to open the app drawer; swipe down to open the notification panel.
swipe(start_x: int, start_y: int, end_x: int, end_y: int) # Swipe from (start_x, start_y) to (end_x, end_y). For example, swipe up the screen: `swipe(360, 800, 360, 200)`; swipe down: `swipe(360, 200, 360, 800)`.
wait(seconds: float = 1.0) # Pause for specified seconds (default 1.0). Do not abuse.
keyboard_enter() # Simulate the Enter key.

### Page Navigation Actions:
open_app(app_name: str) # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
go_back() # Move to the previous screen.
go_home() # Return to the home screen.

### Completion Actions (must be issued alone):
stop(goal_status: str) # Mark the task as "complete" (or "N/A" if impossible).
answer(text: str) # Provide a final answer to the user's question.
"""

ACTIONS_PROMPT_COORDINATE_WITH_SHELL = """
### Page Operation Actions:
click(x: int, y: int) # Click/Tap at coordinates (x, y). Output like `click(100, 200)`. DO NOT output `click(x: 100, y: 200)`
long_press(x: int, y: int) # Long press at coordinates (x, y).
input_text(text: str, clear_text: Optional[bool] = True) # Type text at the current cursor position (inputs text and presses Enter). If clear_text is set to True, existing text will be cleared. Use this when the cursor is already in a text field. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
input_text(text: str, x: int, y: int, clear_text: Optional[bool] = True) # Type text into a field at coordinates (x, y) (auto-clicks the field, inputs text, and presses Enter). The clear_text is set to True by default.
swipe(direction: str) # Swipe the entire screen in one of ["up", "down", "left", "right"]. To view content at the bottom, the swipe direction should be set to "up". For example, swipe up the screen to open the app drawer; swipe down to open the notification panel.
swipe(start_x: int, start_y: int, end_x: int, end_y: int) # Swipe from (start_x, start_y) to (end_x, end_y). For example, swipe up the screen: `swipe(360, 800, 360, 200)`; swipe down: `swipe(360, 200, 360, 800)`.
wait(seconds: float = 1.0) # Pause for specified seconds (default 1.0). Do not abuse.
keyboard_enter() # Simulate the Enter key.

### Page Navigation Actions:
open_app(app_name: str) # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
go_back() # Move to the previous screen.
go_home() # Return to the home screen.

### System Shell Actions:
shell(command: str) # Execute a shell command on the Android device through ADB. Examples: 'settings put system screen_brightness 100', 'dumpsys battery', 'pm list packages'.
# USAGE GUIDELINES:
#    ✅ For SYSTEM-LEVEL operations: Prefer shell for directness and efficiency
#       - Settings: shell("settings put system screen_brightness 100")
#       - System queries: shell("dumpsys battery"), shell("wm size")
#       - Package info: shell("pm list packages | grep contacts")
#    ❌ For UI INTERACTIONS: Use actions listed above, NOT shell
#       - Opening apps: open_app("AppName") NOT shell("am start ...")
#       - Clicking: click() NOT shell("input tap ...")
#       - Typing: input_text() NOT shell("input text ...")

### Completion Actions (must be issued alone):
stop(goal_status: str) # Mark the task as "complete" (or "N/A" if impossible).
answer(text: str) # Provide a final answer to the user's question.
"""

ACTIONS_PROMPT_JSON_COORDINATE = """
### Page Operation Actions:
{{"action_type": "click", "x": <x_coordinate>, "y": <y_coordinate>}}  # Click/Tap at coordinates (x, y).
{{"action_type": "long_press", "x": <x_coordinate>, "y": <y_coordinate>}}  # Long press at coordinates (x, y).
{{"action_type": "input_text", "text": "<text_input>", "clear_text": <true_or_false>}}  # Type text at the current cursor position (inputs text and presses Enter). If clear_text is set to True, existing text will be cleared. Use this when the cursor is already in a text field. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
{{"action_type": "input_text", "text": "<text_input>", "x": <x_coordinate>, "y": <y_coordinate>, "clear_text": <true_or_false>}}  # Type text into a field at coordinates (x, y) (auto-clicks the field, inputs text, and presses Enter). The clear_text is True by default.
{{"action_type": "swipe", "direction": "<up|down|left|right>"}}  # Swipe the entire screen in one of ["up", "down", "left", "right"]. For example, swipe up the screen to open the app drawer; swipe down to open the notification panel.
{{"action_type": "swipe", "start_x": <start_x>, "start_y": <start_y>, "end_x": <end_x>, "end_y": <end_y>}}  # Swipe from (start_x, start_y) to (end_x, end_y). For example, swipe up: {{"action_type": "swipe", "start_x": 360, "start_y": 800, "end_x": 360, "end_y": 200}}.
{{"action_type": "wait", "seconds": <optional_seconds>}}  # Pause for specified seconds (default 1.0). Omit "seconds" field to use default.
{{"action_type": "keyboard_enter"}}  # Simulate the Enter key.

### Page Navigation Actions:
{{"action_type": "open_app", "app_name": "<app_name>"}}  # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
{{"action_type": "go_back"}}  # Move to the previous screen.
{{"action_type": "go_home"}}  # Return to the home screen.

### Completion Actions (must be issued alone):
{{"action_type": "stop", "goal_status": "<complete|N/A>"}}  # Mark the task as "complete" (or "N/A" if impossible).
{{"action_type": "answer", "text": "<answer_text>"}}  # Provide a final answer to a user question.
"""

ACTIONS_PROMPT_JSON_COORDINATE_WITH_SHELL = """
### Page Operation Actions:
{{"action_type": "click", "x": <x_coordinate>, "y": <y_coordinate>}}  # Click/Tap at coordinates (x, y).
{{"action_type": "long_press", "x": <x_coordinate>, "y": <y_coordinate>}}  # Long press at coordinates (x, y).
{{"action_type": "input_text", "text": "<text_input>", "clear_text": <true_or_false>}}  # Type text at the current cursor position (inputs text and presses Enter). If clear_text is set to True, existing text will be cleared. Use this when the cursor is already in a text field. So you need to remember the existing text if you need to use it later. The clear_text is set to True by default.
{{"action_type": "input_text", "text": "<text_input>", "x": <x_coordinate>, "y": <y_coordinate>, "clear_text": <true_or_false>}}  # Type text into a field at coordinates (x, y) (auto-clicks the field, inputs text, and presses Enter). The clear_text is True by default.
{{"action_type": "swipe", "direction": "<up|down|left|right>"}}  # Swipe the entire screen in one of ["up", "down", "left", "right"]. For example, swipe up the screen to open the app drawer; swipe down to open the notification panel.
{{"action_type": "swipe", "start_x": <start_x>, "start_y": <start_y>, "end_x": <end_x>, "end_y": <end_y>}}  # Swipe from (start_x, start_y) to (end_x, end_y). For example, swipe up: {{"action_type": "swipe", "start_x": 360, "start_y": 800, "end_x": 360, "end_y": 200}}.
{{"action_type": "wait", "seconds": <optional_seconds>}}  # Pause for specified seconds (default 1.0). Omit "seconds" field to use default.
{{"action_type": "keyboard_enter"}}  # Simulate the Enter key.

### Page Navigation Actions:
{{"action_type": "open_app", "app_name": "<app_name>"}}  # Launch an application by name. MUST USE THIS with correct app_name TO OPEN APP.
{{"action_type": "go_back"}}  # Move to the previous screen.
{{"action_type": "go_home"}}  # Return to the home screen.

### System Shell Actions:
{{"action_type": "shell", "command": "<shell_command>"}}  # Execute shell commands. Examples: 'settings put system screen_brightness 100', 'dumpsys battery'.
# USAGE: Prefer shell for system operations, use actions listed above for UI interactions (see above guidelines).

### Completion Actions (must be issued alone):
{{"action_type": "stop", "goal_status": "<complete|N/A>"}}  # Mark the task as "complete" (or "N/A" if impossible).
{{"action_type": "answer", "text": "<answer_text>"}}  # Provide a final answer to a user question.
"""

# Combined prompts for convenience (without shell)
FUNCTION_ACTIONS_PROMPT = ACTIONS_PREFIX + ACTIONS_PROMPT
FUNCTION_ACTIONS_JSON_PROMPT = ACTIONS_PREFIX + ACTIONS_PROMPT_JSON
FUNCTION_ACTIONS_PROMPT_COORDINATE = ACTIONS_PREFIX_COORDINATE + ACTIONS_PROMPT_COORDINATE
FUNCTION_ACTIONS_JSON_PROMPT_COORDINATE = ACTIONS_PREFIX_COORDINATE + ACTIONS_PROMPT_JSON_COORDINATE

# Combined prompts with shell support
FUNCTION_ACTIONS_PROMPT_WITH_SHELL = ACTIONS_PREFIX + ACTIONS_PROMPT_WITH_SHELL
FUNCTION_ACTIONS_JSON_PROMPT_WITH_SHELL = ACTIONS_PREFIX + ACTIONS_PROMPT_JSON_WITH_SHELL
FUNCTION_ACTIONS_PROMPT_COORDINATE_WITH_SHELL = ACTIONS_PREFIX_COORDINATE + ACTIONS_PROMPT_COORDINATE_WITH_SHELL
FUNCTION_ACTIONS_JSON_PROMPT_COORDINATE_WITH_SHELL = ACTIONS_PREFIX_COORDINATE + ACTIONS_PROMPT_JSON_COORDINATE_WITH_SHELL

