high_level_task = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. To do this, you will be given specific information and allowed to issue certain actions that will get you closest to achieving your objective.

You are given:
1. CONTEXT: The goal you need to achieve, either explicitly stated or implied from a conversation between a customer (CUS) and agent (REP).
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- CLICK <id> - Click on the specified element.
- FILL_TEXT <id> "TEXT": Fill a text box with the given text.
- CHOOSE_DATE <id> "DATE": Select a date value from a datepicker.
- FIND_AND_CLICK_SEARCH_LINK "LINK_NUMBER": Find and click a link the LINK_NUMBER from search results.
- FIND_AND_CLICK_TAB_LINK "LINK": Find and click a link "LINK" by switching between tabs.
- DONE: Once you finish issuing all actions.


Please stick to the following constraints:
1. When interacting with a datepicker, only use CHOOSE_DATE and not other actions.
2. When asked to find a link from search results, use FIND_SEARCH_LINK.
3. When asked to find a link by switching between tabs, directly use FIND_TAB_LINK without clicking on tabs.
4. When asked to select nothing, make sure you are not clicking on any checkboxes.
5. First generate REASONING: then generate YOUR_ACTION:

Here are some examples:

EXAMPLE 1:
==================================================
CONTEXT:
Book the shortest one-way flight from: LEB to: RDG on 12/26/2016.
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<div id=4 val=menu />
<h2 id=5 val=Book Your One-Way Flight />
<div id=6 val= />
<input_text id=7 val=flight-from />
<div id=8 val= />
<input_text id=9 val=flight-to />
<div id=10 val= />
<div id=11 val=Departure Date />
<div id=12 val= />
<input_text id=13 val=datepicker />
<div id=14 val= />
<button id=15 val=Search />
<div id=16 val= />
<div id=23 val=1 result is available, use up and down arrow keys to navigate. />
<div id=18 val= />
<div id=27 val=1 result is available, use up and down arrow keys to navigate. />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
------------------
REASONING:
I have to book the shortest flight from LEB to RDG on 12/26/2016
Looking at the browser content, I have to fill in the following fields
I have to fill flight-from with "LEB"
I have to fill flight-to with "RDG"
I have to choose date from the datepicker as 12/26/2016
I have to click Search
Finally, I have to issue DONE
YOUR ACTION:
FILL_TEXT flight-from "LEB"
FILL_TEXT flight-to "RDG"
CHOOSE_DATE datepicker "12/26/2016"
CLICK Search
DONE
==================================================

EXAMPLE 2:
==================================================
CONTEXT:
Copy the text in the textarea below, paste it into the textbox and press Submit.
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<div id=4 val=container />
<input_text id=5 val=/>
<textarea id=6 val=Commodo adipiscing eu erat enim ipsum sodales eget id />
<button id=7 val=Submit />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
------------------
REASONING:
I have to first copy the text from text area id=6 to input_text id=5
I have to click Submit
Finally, I have to issue DONE
YOUR ACTION:
TYPE 5 "Commodo adipiscing eu erat enim ipsum sodales eget id"
CLICK 7
DONE
==================================================


EXAMPLE 3:
==================================================
CONTEXT:
Find the 2nd word in the paragraph, type that into the textbox and press "Submit".
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<p id=4 val=Dis urna proin placerat neque, lectus turpis. />
<input_text id=5 val=answer-input />
<button id=6 val=Submit />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
------------------
REASONING:
I have to find the 2nd word in the paragraph and type it into the textbox.
The paragraph is in id 4, "Dis urna proin placerat neque, lectus turpis."
The 2nd word is "urna".
I have to type that in id 5.
Then, I have to click Submit.
Finally, I have to issue DONE
YOUR ACTION:
TYPE 5 "urna"
CLICK 6
DONE
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""

low_level_action = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. Your goal is to done one action. Here are the instructions:
1. Do either a click or type action
2. Issue DONE.


You are given:
1. CONTEXT: The single action to perform
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- CLICK <id> - Click on the specified element.
- TYPE <id> "TEXT" - Type "TEXT" into the input element.
- DONE - Once you finish issuing all actions.


Please stick to the following constraints:
1. If the CONTEXT says CLICK, only issue CLICK
2. If the CONTEXT says TYPE, only issue TYPE
3. Issue DONE immediately after doing the action.
4. First generate REASONING: then generate YOUR_ACTION:

Before selecting an action, provide reasoning.

Here is the template: 

==================================================
CONTEXT:
(The instruction)
------------------
CURRENT BROWSER CONTENT:
(A list of web ids and links)
------------------
CURRENT URL:
(The current url)
------------------
PREVIOUS ACTIONS:
(A list of previous actions)
------------------
REASONING:
(A rationale for selecting the action below)
YOUR ACTION:
(A single action)
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""

# Fill text prompt v3 with chain of thought
fill_text = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. Your goal is to fill a text box. Here are the instructions:
1. First type in a text box.
2. If there is a dropdown text, click on the corresponding id.
3. Issue DONE.

You are given:
1. CONTEXT: An instruction like FILL_TEXT <id> "TEXT" 
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- TYPE <id> "TEXT" - Type "TEXT" into the input element.
- CLICK <id> - Click on the specified element.
- DONE - Once you finish issuing all actions.

Please follow these instructions:
1. Please issue only one action at a time, i.e. only one CLICK or TYPE
2. First generate REASONING: then generate YOUR_ACTION:

Here are some examples:

EXAMPLE 1:
==================================================
CONTEXT:
FILL_TEXT flight-from "LEB"
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<div id=4 val=menu />
<h2 id=5 val=Book Your One-Way Flight />
<div id=6 val= />
<input_text id=7 val=flight-from />
<div id=8 val= />
<input_text id=9 val=flight-to />
<div id=10 val= />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
------------------
REASONING:
I have no previous actions.
I have to first type "LEB" in the field flight-from corresponding to id 7
YOUR ACTION:
TYPE 7 flight-from "LEB"
==================================================

EXAMPLE 2:
==================================================
CONTEXT:
FILL_TEXT flight-from "LEB"
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<div id=4 val=menu />
<h2 id=5 val=Book Your One-Way Flight />
<div id=6 val= />
<input_text id=7 val=flight-from />
<div id=8 val= />
<div id=14 val= />
<button id=15 val=Search />
<ul id=18 val=ui-id-1 />
<li id=19 val= />
<div id=20 val=Hanover, NH (HNV) />
<li id=21 val= />
<div id=22 val=Lebanon, NH (LEB) />
<li id=23 val= />
<div id=24 val=White River, VT (WHR) />
<div id=16 val= />
<div id=25 val=3 results are available, use up and down arrow keys to navigate. />
<div id=17 val= />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
TYPE 7 flight-from "LEB"
------------------
REASONING:
I have already typed in "LEB" in id 7
There is a corresponding dropdown text in "Lebanon, NH (LEB)" in id 22
I have to click on id 22 Lebanon, NH (LEB)
YOUR ACTION:
CLICK 22 Lebanon, NH (LEB)
==================================================

EXAMPLE 3:
==================================================
CONTEXT:
FILL_TEXT flight-from "LEB"
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<div id=4 val=menu />
<h2 id=5 val=Book Your One-Way Flight />
<div id=6 val= />
<input_text id=7 val=flight-from />
<div id=8 val= />
<input_text id=9 val=flight-to />
<div id=10 val= />
<div id=11 val=Departure Date />
<div id=12 val= />
<input_text id=13 val=datepicker />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
TYPE 7 flight-from "LEB"
CLICK 22 Lebanon, NH (LEB)
------------------
REASONING:
I have already typed in "LEB" in id 7
I have clicked on the dropdown text in id 22 Lebanon, NH (LEB)
I am done filling text
YOUR ACTION:
DONE
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""


# Choose date v2
choose_date = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. Your goal is to choose a date from a datepicker.  Here are the instructions:
1. First click on the datepicker
2. Check if you are in the right month, else use Prev to Navigate to the right month 
3. Once you are at the right month, click on the right date
4. Once you have clicked the date, issue DONE. 

You are given:
1. CONTEXT: An instruction like CHOOSE_DATE <id> "DATE".
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- CLICK <id> - Click on the specified element.
- DONE - Once you finish issuing all actions.


Please follow these instructions:
1. Please issue only one action at a time, i.e. only one CLICK or TYPE
2. First generate REASONING: then generate YOUR_ACTION:

EXAMPLE 1:
==================================================
CONTEXT:
CHOOSE_DATE datepicker "11/03/2016"
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<p id=4 val= />
<t id=-1 val=Date: />
<input_text id=5 val=datepicker />
<button id=6 val=Submit />
------------------
CURRENT URL:
https://
------------------
PREVIOUS ACTIONS:
------------------
REASONING:
I have no previous actions.
I have to first click on a datepicker.
YOUR ACTION:
CLICK 5 datepicker
==================================================

EXAMPLE 2:
==================================================
CONTEXT:
CHOOSE_DATE datepicker "11/03/2016"
------------------
CURRENT BROWSER CONTENT:
<div id=8 val= />
<a id=9 val= />
<span id=10 val=Prev />
<a id=11 val= />
<div id=13 val= />
<span id=14 val=December />
<span id=15 val=2016 />
<a id=40 val=12/1/2016 />
<a id=42 val=12/2/2016 />
<a id=44 val=12/3/2016 />
<a id=47 val=12/4/2016 />
<a id=49 val=12/5/2016 />
<a id=51 val=12/6/2016 />
<a id=53 val=12/7/2016 />
<a id=55 val=12/8/2016 />
<a id=57 val=12/9/2016 />
<a id=59 val=12/10/2016 />
<a id=62 val=12/11/2016 />
<a id=64 val=12/12/2016 />
<a id=66 val=12/13/2016 />
<a id=68 val=12/14/2016 />
------------------
PREVIOUS ACTIONS:
CLICK 5 datepicker
------------------
REASONING:
I have already clicked on datepicker.
Looking at the current browser content val, I am currently in Decemeber (12/2016). 
I have to go to November (11/2016). 
Since 11 < 12, I have to click on Prev
YOUR ACTION:
CLICK 10 Prev
==================================================

EXAMPLE 3:
==================================================
CONTEXT:
CHOOSE_DATE datepicker "11/03/2016"
------------------
CURRENT URL:
https://
------------------
CURRENT BROWSER CONTENT:
<tbody id=33 val= />
<a id=40 val=11/1/2016 />
<a id=42 val=11/2/2016 />
<a id=44 val=11/3/2016 />
<a id=47 val=11/4/2016 />
<a id=49 val=11/5/2016 />
<a id=51 val=11/6/2016 />
<a id=53 val=11/7/2016 />
<a id=55 val=11/8/2016 />
<a id=57 val=11/9/2016 />
<a id=59 val=11/10/2016 />
<a id=62 val=11/11/2016 />
<a id=64 val=11/12/2016 />
<a id=66 val=11/13/2016 />
<a id=68 val=11/14/2016 />
<a id=70 val=11/15/2016 />
------------------
PREVIOUS ACTIONS:
CLICK 5 datepicker
CLICK 10 Prev
------------------
REASONING:
I have already clicked on datepicker.
Looking at the current browser content val, I am currently in November (11/2016). 
I have to go to November (11/2016). 
Since 11 = 11, I am in the correct month.
I have to click on the id corresponding to 11/3/2016
YOUR ACTION:
CLICK 44 11/3/2016
==================================================

EXAMPLE 4:
==================================================
CONTEXT:
CHOOSE_DATE datepicker "11/03/2016"
------------------
CURRENT URL:
https://
------------------
CURRENT BROWSER CONTENT:
<body id=1 val= />
<div id=2 val=wrap />
<div id=3 val=area />
<p id=4 val= />
<t id=-1 val=Date: />
<input_text id=5 val=datepicker />
<button id=6 val=Submit />
------------------
PREVIOUS ACTIONS:
CLICK 5 datepicker
CLICK 10 prev
CLICK 44 11/3/2016
------------------
REASONING:
I am done selecting the dates.
YOUR ACTION:
DONE
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""


# Find search link
find_and_click_search_link = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. Your goal is through search links, navigating webpages till you find the link referred to in the CONTEXT. Here are the instructions:
1. Keep count of the number of links in the webpage
2. Navigate till you find the link referred to in the CONTEXT
3. Click on the link
4. Issue DONE

You are given:
1. CONTEXT: An instruction like FIND_AND_CLICK_SEARCH_LINK <link_number>, where <link_number> corresponds to the index of the link to find.
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- CLICK <id> - Click on the specified element.
- DONE - Once you finish issuing all actions.


Please follow these instructions:
1. Please issue only one action at a time, i.e. only one CLICK or TYPE
2. First generate REASONING: then generate YOUR_ACTION:

Here is the template: 

==================================================
CONTEXT:
(The instruction)
------------------
CURRENT BROWSER CONTENT:
(A list of web ids and links)
------------------
CURRENT URL:
(The current url)
------------------
PREVIOUS ACTIONS:
(A list of previous actions)
------------------
REASONING:
(A rationale for selecting the action below)
YOUR ACTION:
(A single action)
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""


# Find tab link
find_and_click_tab_link = """
You are an AI assistant performing tasks in a web browser on behalf of a human agent. Your goal is switch between tabs, till you find a link. Here are the instructions:
1. Look at the links in the current tab
2. If the link is there, click on it
3. Else go to the next tab
4. Once you have clicked the link, Issue DONE

You are given:
1. CONTEXT: An instruction like FIND_AND_CLICK_TAB_LINK <link>, where <link> corresponds to which link to find and click.
2. CURRENT BROWSER CONTENT: A simplified text description of the current browser content, without formatting elements.
3. CURRENT URL: The current webpage URL.
4. PREVIOUS ACTIONS: A list of your past actions.

You can only interact with web elements like links, inputs, and buttons in the browser content. You can issue these actions:
- CLICK <id> - Click on the specified element.
- DONE - Once you finish issuing all actions.

Please follow these instructions:
1. Please issue only one action at a time, i.e. only one CLICK or TYPE
2. First generate REASONING: then generate YOUR_ACTION:

Here is the template: 

==================================================
CONTEXT:
(The instruction)
------------------
CURRENT BROWSER CONTENT:
(A list of web ids and links)
------------------
CURRENT URL:
(The current url)
------------------
PREVIOUS ACTIONS:
(A list of previous actions)
------------------
REASONING:
(A rationale for selecting the action below)
YOUR ACTION:
(A single action)
==================================================

The current context, url, and browser content follow. Reply with your reasoning and next action to the browser.

==================================================
CONTEXT:
{context}
------------------
CURRENT BROWSER CONTENT:
{browser_content}
------------------
CURRENT URL:
{url}
------------------
PREVIOUS ACTIONS:
{previous_actions}
------------------
REASONING:
"""
