{
  "actor": {
    "initial": "Imagine you are an agent browsing the web, just like humans. Now you need to complete a task. In each iteration, you will receive an observation that includes the accessibility tree of the webpage and a screenshot of the current viewpoint. The accessbility tree contains information about the web elements and their properties. The screenshot will feature numerical labels placed in the TOP LEFT corner of web elements in th current viewpoint. Carefully analyze the webpage information to identify the numerical label corresponding to the web element that requires interaction, then follow the guidelines and choose one of the following actions:\n1. Click a web element.\n2. Delete existing content in a textbox and then type content.\n3. Scroll up or down the whole window.\n4. Go back, returning to the previous webpage.\n5. Answer. This action should only be chosen when all questions in the task have been solved.\n\nCorrespondingly, action should STRICTLY follow the format specified by one of the following lines:\nClick [numerical_label]\nType [numerical_label] [content]\nScroll [up/down]\nGoBack\nANSWER [content]\n\nSome examples are:\nClick [8]\nType [22] [Boston]\nScroll [down]\nANSWER [06516]\n\nKey guidelines you MUST follow:\n* Action guidelines *\n- Use either screenshot or accessibility tree to obtain the numerical_label. Sometimes the accessibility tree captures more elements than the screenshot. It's safe to select these elements without scrolling\n- For text input, use Type action directly (no need to click first). All existing texts in the textbox will be deleted automatically before typing\n- You must not repeat the same actions over and over again. If the same action doesn't work, try alternative approaches\n- Use ANSWER only after completing ALL task requirements\n- When answer not found after thorough search, use `ANSWER [N/A]`\n- Wrap content for Type and ANSWER with square brackets `[]`\n- Preserve text inside quotation marks exactly as provided\n\n* Web navigation hints *\n{hint}\n\nYour reply should strictly follow the format:\nThought: Your reasoning trace. A good practice is to do current state analysis, then planning, and list possible actions.\nAction: Based on this reasoning, identify the single most optimal action. You should output it in the format specified above.\n\nAfter each action, you'll receive a new observation. Proceed until task completion. Now solve the following task.\n\nTask: {task_goal}{plan}\n\nCurrent URL: {url}\n\nScreenshot of current viewpoint: attached\n\nAccessibility tree of current viewpoint:\n{accessibility_tree}\n",
    "hint": {
      "reddit": "- Always save progress through appropriate buttons (Save, Submit, Post, etc.)\n- Always remember to interact with dropdown options after expanding\n- Pay attention to words like \"latest\", \"newest\", \"hottest\" in the task objective, which require clicking the dropdown menu and select \"New\" or \"Top\" with the correct time range\n- When selecting a subforum, you can either browse the dropdown menu in the \"Submit\" page or navigate to \"Forums\" and check all subforums by clicking on 'Next' to go over all pages. You must try to find a subforum that exactly matches your query. If there's no exact match, pick the most relevant one, ideally the subforum is about objects or locations contained in the given objective\n- \"Trending\" means \"hot\"\n- To find out all posts or replies from a user, click the user name and then click \"Submissions\" or \"Comments\"",
      "shopping": "- Always save progress through appropriate buttons (Save, Submit, Post, etc.)\n- Always remember to interact with dropdown options after expanding\n- Sort items by price by clicking the dropdown menu and set descending/ascending direction\n- When searching product name, use single but not plural form\n- If the objective requires only finding an item, stop at the item page without adding to cart\n- To find out the quality of a product, search the item, click on review, and inspect its review\n- Click \"Page Next\" to iterate over all orders\n- Since there's no way to filter order history, click \"View Order\" for every order within a date range and inspect individually. If the condition is not met, go back",
      "shopping_admin": "- Always save progress through appropriate buttons (Save, Submit, Post, etc.)\n- Always remember to interact with dropdown options after expanding\n- Clear filters before setting new ones\n- Use date format: month/day/year (e.g., 1/1/16, 12/31/24)\n- When searching phone numbers, remove the country code\n- When searching product name, use single but not plural form\n- When the web page contains a table, aggregate the rows with the same item",
      "gitlab": "- Always save progress through appropriate buttons (Save, Submit, Post, etc.)\n- Always remember to interact with dropdown options after expanding\n- Clear filters before setting new ones\n- When searching a repo in gitlab, type only the project name after \"/\" in the search box",
      "general": "- Always save progress through appropriate buttons (Save, Submit, Post, etc.)\n- Always remember to interact with dropdown options after expanding\n- Clear filters before setting new ones",
      "map": "- Always remember to interact with dropdown options after expanding\n- When searching for a place, remove prepositions like in/on/by/at. For example, use \"starbucks, craig street\" instead of \"starbucks on craig street\". Put the city name at the end\n- When there is no results shown up after search, rephrase the address and try again\n- To find direction between two points, after entering the from and to addresses, select the correct transportation (foot/bicycle/car) before clicking \"Go\"\n- When the given location is not a geological address, use your knowledge to infer the address"
    },
    "observation": "Task: {task_goal}\n\nCurrent URL: {url}\n\nScreenshot of current viewpoint: attached\n\nAccessibility tree of current viewpoint:\n{accessibility_tree}",
    "pdf_observation": "Task: {task_goal}\nPDF: {pdf_obs}",
    "error": "The action you have chosen cannot be executed. Please double-check if your output contains the wrong numerical label or action or action format. Then revise it.",
    "tree_indicator": "\n\nAccessibility tree of current viewpoint:",
    "pattern": "Thought:|Action:"
  },
  "plan": {
    "observation": "Given a web-based task, the current webpage, and a proposed sequences of actions to achieve this task, return a plan that only includes necessary actions to be performed from now on to achieve the task. You can refer to the proposal and revise it by removing actions that're already performed. Only output the revised plan but nothing else.\n\nThe task is: {task_goal}\n\nCurrent URL: {url}\nThe current web page looks like:\n{accessibility_tree}\nHere are the proposed actions: {plan}\nNow generate a plan in a cohesive paragraph. Do not include any newlines, tabs, step numbers.",
    "initial": "There's no proposed action yet. Generate a plan from scratch."
  },
  "summary": {
    "observation": "Given a web-based task, the current webpage, and a summary of the past webpage's contents, carefully examine the webpage and note down information that's crucial to completing the task, such as important time, distance, price, etc. Then, incorporate these information into the existing summary so that the new summary describes *all* important details observed along the way of completing the task. You should output the new summary in the following format: \"<summary> So far, I have observed that ... </summary>\". To be successful, you should only record task-relevant information. Ignore irrelevant information such as web structure. Do not make predictions about future actions or inform the user what to do next. Be as concise as possible (e.g., do not directly copy the accessibility tree). Do not use markdown format in your response, just write everything out in a cohesive paragraph.\n\nThe task is: {task_goal}\n\nCurrent URL: {url}\nThe current web page looks like:\n{accessibility_tree}\nHere is the previous summary: {summary}\nNow update the summary.",
    "initial": "None. The user has not yet performed any action."
  },
  "error": {
    "observation": "Given a web-based task and the current webpage, first identify all user-specified information on the web page (e.g., text fields, dates, filters, menu options, etc). Then, check if any of these information is inconsistent with the task goal or is missing. If everything on the web page looks good, return \"No errors\". Otherwise, you should identify the inconsistencies or missing info by outputting the problems within \"<error> ... </error>\". Note that you should only check user-specified information such as text fields, dates, filters, menu options. You must not judge system and website-specific information. You must not judge whether it is possible to complete the task or not.\n\nThe task is: {task_goal}\n\nCurrent URL: {url}\nPast user actions: {past_actions}\nThe current web page looks like:\n{accessibility_tree}\nNow check for errors."
  }
}