shiplightai 0.1.73 → 0.1.74

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,8 +1,8 @@
1
- var Al=Object.defineProperty;var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var ut=(e,t)=>{for(var i in t)Al(e,i,{get:t[i],enumerable:!0})};import*as xi from"fs";import*as He from"path";import Mc from"dotenv";function Ic(){return globalThis[yo]}function Pc(e){globalThis[yo]=e}function Wn(e){let t=[],i=He.resolve(e),a=He.resolve(process.cwd());for(;;){let n=He.join(i,".env");if(xi.existsSync(n)&&t.push(n),i===a)break;let o=He.dirname(i);if(o===i)break;i=o}return t}function xo(e){let t=Wn(e),i={};for(let[a,n]of Object.entries(process.env))n!==void 0&&(i[a]=n);for(let a=t.length-1;a>=0;a--)Object.assign(i,Mc.parse(xi.readFileSync(t[a])));Pc(i)}function vi(){let e=Ic();return e===void 0?process.env:e}var yo,_i=v(()=>{"use strict";yo="__shiplightDotenvCache__"});function vo(e,t){let i=t?.trim();return i?i.endsWith("/")?i.slice(0,-1):i:e.startsWith(Cc)?Oc:Lc}var Cc,Oc,Lc,_o=v(()=>{"use strict";Cc="shp_",Oc="https://nova-api.shiplight.ai",Lc="https://api.shiplight.ai"});var Un={};ut(Un,{lookupActionStores:()=>Rc,updateActionStores:()=>Fc});function ko(){let e=vi(),t=e.SHIPLIGHT_API_TOKEN;return t?{apiUrl:vo(t,e.SHIPLIGHT_API_URL),apiToken:t}:null}async function Rc(e){let t=ko();if(!t||e.length===0)return new Map;try{let i=new AbortController,a=setTimeout(()=>i.abort(),Nc),n=await fetch(`${t.apiUrl}/action-entity-cache/lookup`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({test_paths:e}),signal:i.signal});if(clearTimeout(a),!n.ok)return console.warn(`[shiplight] Cache lookup failed: HTTP ${n.status}`),new Map;let o=await n.json(),r=new Map;for(let[s,l]of Object.entries(o.stores??{}))r.set(s,l);return r}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache lookup error:",i.message),new Map}}async function Fc(e){let t=ko();if(!t||e.size===0)return 0;try{let i=new AbortController,a=setTimeout(()=>i.abort(),Dc),n={};for(let[s,l]of e)n[s]=l;let o=await fetch(`${t.apiUrl}/action-entity-cache/update`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({stores:n}),signal:i.signal});return clearTimeout(a),o.ok?(await o.json()).updated??0:(console.warn(`[shiplight] Cache update failed: HTTP ${o.status}`),0)}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache update error:",i.message),0}}var Nc,Dc,Bn=v(()=>{"use strict";_o();_i();Nc=2e3,Dc=5e3});function To(e){Kn.updateConfig(e)}function G(){return Kn.getConfig()}var Vc,Kn,ki,te=v(()=>{"use strict";Vc=class{constructor(){this.config=this.getDefaultConfig()}getDefaultConfig(){return{logLevel:1,debugAgent:!1,testResultsJsonPath:void 0,consoleLogsPath:void 0}}getConfig(){return{...this.config}}updateConfig(e){this.config={...this.config,...e}}resetConfig(){this.config=this.getDefaultConfig()}get(e){return this.config[e]}set(e,t){this.config[e]=t}},Kn=new Vc,ki=Kn});var Xc,Yc,u,R=v(()=>{"use strict";te();Xc=class{getLevel(){return ki.get("logLevel")}isStderrOnly(){return ki.get("stderrOnly")===!0}debug(...e){this.getLevel()<=0&&(this.isStderrOnly()?console.error("[DEBUG]",...e):console.log("[DEBUG]",...e))}info(...e){this.getLevel()<=1&&(this.isStderrOnly()?console.error("[INFO]",...e):console.log("[INFO]",...e))}log(...e){this.info(...e)}warn(...e){this.getLevel()<=2&&console.warn("[WARN]",...e)}error(...e){this.getLevel()<=3&&console.error("[ERROR]",...e)}setLevel(e){ki.set("logLevel",e)}},Yc=new Xc,u=Yc});import{zodToJsonSchema as Jc}from"zod-to-json-schema";function Si(e){let t=Jc(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return pt(t),t}function pt(e){if(!(typeof e!="object"||e===null)){if(e.type==="object"&&(e.additionalProperties=!1,e.properties)){let t=Object.keys(e.properties);e.required=t;for(let i of Object.values(e.properties))pt(i)}e.type==="array"&&e.items&&pt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(pt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&pt(i)}}var gt=v(()=>{"use strict"});var zn,Ei=v(()=>{"use strict";gt();zn=class{constructor(e){this.registry=e}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.openai).map(e=>({type:"function",function:{name:e.name,description:e.description,parameters:Si(e.schema),strict:!0}}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.openai).map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:Si(i.schema),strict:!0}}))}toJSON(){return this.getToolDefinitions()}getToolDefinition(e){let t=this.registry.get(e);if(t)return{type:"function",function:{name:t.name,description:t.description,parameters:Si(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});import{appendFileSync as Ao}from"fs";var qc,w,ie=v(()=>{"use strict";te();qc=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{Ao(e,`
1
+ var $l=Object.defineProperty;var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var ut=(e,t)=>{for(var i in t)$l(e,i,{get:t[i],enumerable:!0})};import*as xi from"fs";import*as He from"path";import Ic from"dotenv";function Pc(){return globalThis[xo]}function Cc(e){globalThis[xo]=e}function Un(e){let t=[],i=He.resolve(e),a=He.resolve(process.cwd());for(;;){let n=He.join(i,".env");if(xi.existsSync(n)&&t.push(n),i===a)break;let o=He.dirname(i);if(o===i)break;i=o}return t}function vo(e){let t=Un(e),i={};for(let[a,n]of Object.entries(process.env))n!==void 0&&(i[a]=n);for(let a=t.length-1;a>=0;a--)Object.assign(i,Ic.parse(xi.readFileSync(t[a])));Cc(i)}function vi(){let e=Pc();return e===void 0?process.env:e}var xo,_i=v(()=>{"use strict";xo="__shiplightDotenvCache__"});function _o(e,t){let i=t?.trim();return i?i.endsWith("/")?i.slice(0,-1):i:e.startsWith(Oc)?Lc:Nc}var Oc,Lc,Nc,ko=v(()=>{"use strict";Oc="shp_",Lc="https://nova-api.shiplight.ai",Nc="https://api.shiplight.ai"});var Bn={};ut(Bn,{lookupActionStores:()=>Fc,updateActionStores:()=>Hc});function So(){let e=vi(),t=e.SHIPLIGHT_API_TOKEN;return t?{apiUrl:_o(t,e.SHIPLIGHT_API_URL),apiToken:t}:null}async function Fc(e){let t=So();if(!t||e.length===0)return new Map;try{let i=new AbortController,a=setTimeout(()=>i.abort(),Dc),n=await fetch(`${t.apiUrl}/action-entity-cache/lookup`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({test_paths:e}),signal:i.signal});if(clearTimeout(a),!n.ok)return console.warn(`[shiplight] Cache lookup failed: HTTP ${n.status}`),new Map;let o=await n.json(),r=new Map;for(let[s,l]of Object.entries(o.stores??{}))r.set(s,l);return r}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache lookup error:",i.message),new Map}}async function Hc(e){let t=So();if(!t||e.size===0)return 0;try{let i=new AbortController,a=setTimeout(()=>i.abort(),Rc),n={};for(let[s,l]of e)n[s]=l;let o=await fetch(`${t.apiUrl}/action-entity-cache/update`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.apiToken}`},body:JSON.stringify({stores:n}),signal:i.signal});return clearTimeout(a),o.ok?(await o.json()).updated??0:(console.warn(`[shiplight] Cache update failed: HTTP ${o.status}`),0)}catch(i){return i instanceof Error&&i.name!=="AbortError"&&console.warn("[shiplight] Cache update error:",i.message),0}}var Dc,Rc,Gn=v(()=>{"use strict";ko();_i();Dc=2e3,Rc=5e3});function Ao(e){zn.updateConfig(e)}function G(){return zn.getConfig()}var Yc,zn,ki,te=v(()=>{"use strict";Yc=class{constructor(){this.config=this.getDefaultConfig()}getDefaultConfig(){return{logLevel:1,debugAgent:!1,testResultsJsonPath:void 0,consoleLogsPath:void 0}}getConfig(){return{...this.config}}updateConfig(e){this.config={...this.config,...e}}resetConfig(){this.config=this.getDefaultConfig()}get(e){return this.config[e]}set(e,t){this.config[e]=t}},zn=new Yc,ki=zn});var Jc,qc,u,R=v(()=>{"use strict";te();Jc=class{getLevel(){return ki.get("logLevel")}isStderrOnly(){return ki.get("stderrOnly")===!0}debug(...e){this.getLevel()<=0&&(this.isStderrOnly()?console.error("[DEBUG]",...e):console.log("[DEBUG]",...e))}info(...e){this.getLevel()<=1&&(this.isStderrOnly()?console.error("[INFO]",...e):console.log("[INFO]",...e))}log(...e){this.info(...e)}warn(...e){this.getLevel()<=2&&console.warn("[WARN]",...e)}error(...e){this.getLevel()<=3&&console.error("[ERROR]",...e)}setLevel(e){ki.set("logLevel",e)}},qc=new Jc,u=qc});import{zodToJsonSchema as Zc}from"zod-to-json-schema";function Si(e){let t=Zc(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return mt(t),t}function mt(e){if(!(typeof e!="object"||e===null)){if(e.type==="object"&&(e.additionalProperties=!1,e.properties)){let t=Object.keys(e.properties);e.required=t;for(let i of Object.values(e.properties))mt(i)}e.type==="array"&&e.items&&mt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(mt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&mt(i)}}var gt=v(()=>{"use strict"});var Vn,Ei=v(()=>{"use strict";gt();Vn=class{constructor(e){this.registry=e}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.openai).map(e=>({type:"function",function:{name:e.name,description:e.description,parameters:Si(e.schema),strict:!0}}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.openai).map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:Si(i.schema),strict:!0}}))}toJSON(){return this.getToolDefinitions()}getToolDefinition(e){let t=this.registry.get(e);if(t)return{type:"function",function:{name:t.name,description:t.description,parameters:Si(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});import{appendFileSync as $o}from"fs";var Qc,w,ie=v(()=>{"use strict";te();Qc=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{$o(e,`
2
2
  === Agent Execution Log ===
3
3
  Started: ${new Date().toISOString()}
4
4
 
5
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=G().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();Ao(t,`[${i}] ${e}
5
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=G().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();$o(t,`[${i}] ${e}
6
6
  `)}catch{}}}section(e){this.log(`
7
7
  ${"=".repeat(60)}
8
8
  ${e}
@@ -11,9 +11,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
11
11
  ${e}`),this.log(`
12
12
  User Prompt:
13
13
  ${t}`)}response(e){this.log(`LLM Response:
14
- ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!G().agentLogPath}},w=new qc});var Ti,Zc,Qc,ed,td,$o,Ai,Vn,Mo,Xn,Yn,me=v(()=>{"use strict";Ti=Object.defineProperty,Zc=Object.getOwnPropertyDescriptor,Qc=Object.getOwnPropertyNames,ed=Object.prototype.hasOwnProperty,td=(e,t,i)=>t in e?Ti(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,$o=(e,t)=>()=>(e&&(t=e(e=0)),t),Ai=(e,t)=>{for(var i in t)Ti(e,i,{get:t[i],enumerable:!0})},Vn=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Qc(t))!ed.call(e,n)&&n!==i&&Ti(e,n,{get:()=>t[n],enumerable:!(a=Zc(t,n))||a.enumerable});return e},Mo=(e,t,i)=>(Vn(e,t,"default"),i&&Vn(i,t,"default")),Xn=e=>Vn(Ti({},"__esModule",{value:!0}),e),Yn=(e,t,i)=>td(e,typeof t!="symbol"?t+"":t,i)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??qn}function id(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function Jn(e,t=[]){let i=e;for(let a of t){let n=await i.locator(a).elementHandle();if(!n)return null;let o=await n.contentFrame();if(await n.dispose(),!o)return null;i=o}return i}function nd(e){let t={action_data:e.action_data};return e.locator&&(t.locator=e.locator),e.xpath&&(t.xpath=e.xpath),e.frame_path&&(t.frame_path=e.frame_path),t}function ad(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function od(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Le(e){let t=ad(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=od(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var $i,ft,qn,pe,I,F=v(()=>{"use strict";me();$i={};Ai($i,{ACTION_TIMEOUT:()=>qn,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>ft,getActionTimeoutMs:()=>P,getFrameContext:()=>Jn,getLocator:()=>O,getMinimalActionEntity:()=>nd,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>id});I=$o(()=>{ft=5e3,qn=1e4,pe=2e4})});async function Zn(e,t,i=[],a=[]){try{let n=await Jn(e,i);if(!n)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(a.length>0){let s=a[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=n.locator(`xpath=${Io(s)}`),c=rd(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${Io(t)}`)).elementHandle({timeout:ft}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await n.locator(`xpath=${t}`).elementHandle({timeout:ft}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await n.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(n){return u.error(`Error in pickBestLocator: ${n}`),null}}async function Qn(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(a=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(a):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}function Io(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function rd(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),a=[];for(let n of i){let o=n.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";a.push(`${r}${s}`)}return a.join(" > ")}var We=v(()=>{"use strict";R();F();I()});async function wt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let a=await e.screenshot({type:"png",fullPage:!1}),{default:n}=await import("sharp"),o=n(a),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():a).toString("base64")}async function ve(e,t,i){let a=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),n=a.asElement();if(!n)throw await a.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await n.boundingBox();if(!o)throw await a.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:n}}async function Mi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(n=>{let o=[],r=n;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),a=await Qn(e,t);return{xpath:i??void 0,locator:a??void 0,frame_path:[]}}function Ii(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var Ve=v(()=>{"use strict";ie();We()});function Pi(e,t){let i=t?.trim();return i?dd(i):e.startsWith(sd)?ld:cd}function Po(e,t){return`${Pi(e,t)}/llm/v1`}function Co(e,t){return`${Pi(e,t)}/llm/v1`}function Oo(e,t){return`${Pi(e,t)}/llm/v1beta`}function Lo(e,t){return`${Pi(e,t)}/llm`}function dd(e){return e.endsWith("/")?e.slice(0,-1):e}var sd,ld,cd,Ne=v(()=>{"use strict";sd="shp_",ld="https://nova-api.shiplight.ai",cd="https://api.shiplight.ai"});import{createGoogleGenerativeAI as No}from"@ai-sdk/google";import{createVertex as ud}from"@ai-sdk/google-vertex";function Ci(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ro(e){let t=G().env||{};if(Ci()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${o}`),ud({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),No({apiKey:i})(e);let a=t.SHIPLIGHT_API_TOKEN;if(a){let n=Oo(a,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${n}`),No({apiKey:a,baseURL:n})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Fo(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},a={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Do.MEDIA_RESOLUTION_HIGH},n;switch(t){case"gemini-3-flash-preview":n={...a};break;default:n={...i},e===1&&(n.mediaResolution=Do.MEDIA_RESOLUTION_HIGH)}return Ci()?{vertex:n}:{google:n}}var Do,Xe=v(()=>{"use strict";Ne();R();te();Do={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as hd,Environment as md}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function gd(e,t,i,a,n){let o=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=ge(i.x,a),l=ge(i.y,n),c=ge(i.destination_x,a),d=ge(i.destination_y,n),h=await ve(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Mi(e,r)}}async function Wo(e){let{statement:t,page:i,screenshotB64:a,viewportWidth:n,viewportHeight:o,modelId:r}=e,s=r||fd,l=G(),c;if(Ci()){let x=l.env?.GOOGLE_CLOUD_PROJECT;if(!x)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:x,location:S}}else{let x=l.env?.GOOGLE_API_KEY;if(x)u.debug(`Using Google AI provider (API key): model=${s}`),c={apiKey:x};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let E=Lo(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${E}`),c={apiKey:S,httpOptions:{baseUrl:E}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new hd(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:a}}]}],config:{tools:[{computerUse:{environment:md.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:pd}],temperature:.1}});w.log("Received response from Gemini CUA");let p=h.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(x=>x.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(x=>x.text).map(x=>x.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:y}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(y)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(y)}`);let{action_data:b,locatorInfo:m}=await gd(i,f,y,n,o);return b?{status:"success",actionEntity:Ii(t,b,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Ho,pd,fd,Oi=v(()=>{"use strict";Ve();ie();Xe();Ne();R();te();Ho={type:"object",properties:{x:{type:"integer",description:"X coordinate in the 0-1000 normalized space."},y:{type:"integer",description:"Y coordinate in the 0-1000 normalized space."}},required:["x","y"]},pd=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Ho},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Ho}];fd="gemini-3-flash-preview"});function Bo(e){return e!=null&&typeof e=="object"}function Ye(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Uo(e){return typeof e=="string"?e:void 0}function wd(e){let t,i;return Array.isArray(e)?(t=Ye(e[0]),i=Ye(e[1])):Bo(e)&&(t=Ye(e.x),i=Ye(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Go(e){if(!Bo(e))return{};let t=Array.isArray(e.path)?e.path.map(wd).filter(i=>i!==null):void 0;return{type:Uo(e.type),x:Ye(e.x),y:Ye(e.y),button:Uo(e.button),path:t}}var Li=v(()=>{"use strict"});import bd from"openai";async function yd(e,t){let i=Go(t),a=null,n=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ve(e,i.x,i.y);a={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ve(e,i.x,i.y);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ve(e,o.x,o.y);a={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},n=s.element;break}}return{action_data:a,locatorInfo:await Mi(e,n)}}async function Ko(e){let{statement:t,page:i,viewportWidth:a,viewportHeight:n,modelId:o}=e,r=o||xd,s=await wt(i,a,n),l=G(),c=l.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=l.env?.OPENAI_BASE_URL,h=new bd({apiKey:c,...d&&{baseURL:d}}),p=h.responses.create.bind(h.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function f(S,E){let A={model:r,tools:[vd],input:S,temperature:.1};return E&&(A.previous_response_id=E),p(A)}let y=await f(g,void 0),b;for(let S=0;S<jo;S++){w.log(`Received response from OpenAI CUA (turn ${S+1})`);let E=y.output.find(L=>L.type==="computer_call");if(!E)return{status:"error",reasoning:y.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&w.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;s=await wt(i,a,n);let $=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];y=await f($,y.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${jo} turns`};w.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:m,locatorInfo:x}=await yd(i,b);return m?{status:"success",actionEntity:Ii(t,m,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var xd,vd,jo,Ni=v(()=>{"use strict";Ve();Li();ie();te();xd="gpt-5.4",vd={type:"computer"},jo=4});import{createAnthropic as zo}from"@ai-sdk/anthropic";import{createVertexAnthropic as _d}from"@ai-sdk/google-vertex/anthropic";function kd(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Sd(){return kd(G().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Vo(e){let t=G();if(Sd()){let n=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return u.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${n}, location=${o}`),_d({project:n,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),zo({apiKey:i})(e);let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=Co(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${n}`),zo({apiKey:a,baseURL:n})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function ea(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var bt=v(()=>{"use strict";Ne();R();te()});import{createOpenAI as Xo}from"@ai-sdk/openai";function Yo(e){let t=G(),i=t.env?.OPENAI_API_KEY;if(i){let n=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),Xo({apiKey:i,baseURL:n})(e)}let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=Po(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${n}`),Xo({apiKey:a,baseURL:n})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Jo(e){return{}}var yt=v(()=>{"use strict";Ne();R();te()});function Zo(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Ed.test(e))return"openai"}function Di(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Td.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function _e(e){let{provider:t,modelId:i}=Di(e),a=t??Zo(i);if(!a)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${a}:gpt-5.4-mini").`);let n=qo[a];if(!n)throw new Error(`Provider "${a}" is not yet implemented. Supported providers: ${Object.keys(qo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return n(i)}function ke(e,t){let{provider:i,modelId:a}=Di(e),n=i??Zo(a);return n==="anthropic"||n==="vertex"?ea(a):n==="openai"||n==="azure"?Jo(a):n==="bedrock"?a.startsWith("anthropic.")?ea(a):{}:Fo(t,a)}var Ed,Td,qo,Se=v(()=>{"use strict";bt();Xe();yt();Ed=/^(gpt-|o\d|chatgpt-)/;Td=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);qo={anthropic:Vo,google:Ro,openai:Yo}});function $d(e){return e.startsWith("gemini-")?"google":"openai"}async function Je(e,t,i={}){let{page:a}=t,n=a.viewportSize();if(!n)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=n;w.log(`Viewport: ${o}x${r}`);let s=await wt(a,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Di(l),d=$d(c),h=Ad[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:a,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(p)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Ad,qe=v(()=>{"use strict";Oi();Ni();Ve();ie();Se();Ad={google:Wo,openai:Ko}});function Md(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let a=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,n=[],o=0,r;for(;(r=a.exec(e))!==null;){let l=e.slice(o,r.index);l&&n.push({type:"text",text:l});let c=r[2];i.has(c)?n.push({type:"image",image:new URL(i.get(c))}):n.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&n.push({type:"text",text:s}),n.length===0&&n.push({type:"text",text:e}),n}function Id(e){let t=[];for(let i of e){let a=i.content||"",n=i.images||[],o=Md(a,n);t.length>0&&o.length>0&&t.push({type:"text",text:`
14
+ ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!G().agentLogPath}},w=new Qc});var Ti,ed,td,id,nd,Mo,Ai,Xn,Io,Yn,Jn,pe=v(()=>{"use strict";Ti=Object.defineProperty,ed=Object.getOwnPropertyDescriptor,td=Object.getOwnPropertyNames,id=Object.prototype.hasOwnProperty,nd=(e,t,i)=>t in e?Ti(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Mo=(e,t)=>()=>(e&&(t=e(e=0)),t),Ai=(e,t)=>{for(var i in t)Ti(e,i,{get:t[i],enumerable:!0})},Xn=(e,t,i,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of td(t))!id.call(e,n)&&n!==i&&Ti(e,n,{get:()=>t[n],enumerable:!(a=ed(t,n))||a.enumerable});return e},Io=(e,t,i)=>(Xn(e,t,"default"),i&&Xn(i,t,"default")),Yn=e=>Xn(Ti({},"__esModule",{value:!0}),e),Jn=(e,t,i)=>nd(e,typeof t!="symbol"?t+"":t,i)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Zn}function ad(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function qn(e,t=[]){let i=e;for(let a of t){let n=await i.locator(a).elementHandle();if(!n)return null;let o=await n.contentFrame();if(await n.dispose(),!o)return null;i=o}return i}function od(e){let t={action_data:e.action_data};return e.locator&&(t.locator=e.locator),e.xpath&&(t.xpath=e.xpath),e.frame_path&&(t.frame_path=e.frame_path),t}function rd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function sd(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Le(e){let t=rd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=sd(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var $i,ft,Zn,me,I,F=v(()=>{"use strict";pe();$i={};Ai($i,{ACTION_TIMEOUT:()=>Zn,GOTO_TIMEOUT:()=>me,LOCATOR_TIMEOUT:()=>ft,getActionTimeoutMs:()=>P,getFrameContext:()=>qn,getLocator:()=>O,getMinimalActionEntity:()=>od,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>ad});I=Mo(()=>{ft=5e3,Zn=1e4,me=2e4})});async function Qn(e,t,i=[],a=[]){try{let n=await qn(e,i);if(!n)return u.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(a.length>0){let s=a[0];if(!s)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=n.locator(`xpath=${Po(s)}`),c=ld(t);if(o=await(c?l.locator(`css=${c}`):l.locator(`xpath=${Po(t)}`)).elementHandle({timeout:ft}),!o)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await n.locator(`xpath=${t}`).elementHandle({timeout:ft}),!o)return u.warn(`Could not find element with xpath: ${t}`),null;let r=await n.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(u.debug(`Generated locator for ${t}: ${r}`),r):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(n){return u.error(`Error in pickBestLocator: ${n}`),null}}async function ea(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(a=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(a):null,t);return await t.dispose(),i?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}function Po(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function ld(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),a=[];for(let n of i){let o=n.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";a.push(`${r}${s}`)}return a.join(" > ")}var We=v(()=>{"use strict";R();F();I()});async function wt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let a=await e.screenshot({type:"png",fullPage:!1}),{default:n}=await import("sharp"),o=n(a),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():a).toString("base64")}async function ve(e,t,i){let a=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),n=a.asElement();if(!n)throw await a.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await n.boundingBox();if(!o)throw await a.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:n}}async function Mi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(n=>{let o=[],r=n;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),a=await ea(e,t);return{xpath:i??void 0,locator:a??void 0,frame_path:[]}}function Ii(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var Ve=v(()=>{"use strict";ie();We()});function Pi(e,t){let i=t?.trim();return i?hd(i):e.startsWith(cd)?dd:ud}function Co(e,t){return`${Pi(e,t)}/llm/v1`}function Oo(e,t){return`${Pi(e,t)}/llm/v1`}function Lo(e,t){return`${Pi(e,t)}/llm/v1beta`}function No(e,t){return`${Pi(e,t)}/llm`}function hd(e){return e.endsWith("/")?e.slice(0,-1):e}var cd,dd,ud,Ne=v(()=>{"use strict";cd="shp_",dd="https://nova-api.shiplight.ai",ud="https://api.shiplight.ai"});import{createGoogleGenerativeAI as Do}from"@ai-sdk/google";import{createVertex as pd}from"@ai-sdk/google-vertex";function Ci(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Fo(e){let t=G().env||{};if(Ci()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return u.debug(`Using Vertex AI provider: model=${e}, location=${o}`),pd({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),Do({apiKey:i})(e);let a=t.SHIPLIGHT_API_TOKEN;if(a){let n=Lo(a,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${n}`),Do({apiKey:a,baseURL:n})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Ho(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},a={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ro.MEDIA_RESOLUTION_HIGH},n;switch(t){case"gemini-3-flash-preview":n={...a};break;default:n={...i},e===1&&(n.mediaResolution=Ro.MEDIA_RESOLUTION_HIGH)}return Ci()?{vertex:n}:{google:n}}var Ro,Xe=v(()=>{"use strict";Ne();R();te();Ro={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as md,Environment as gd}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function wd(e,t,i,a,n){let o=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let s=ge(i.x,a),l=ge(i.y,n),c=await ve(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let s=ge(i.x,a),l=ge(i.y,n),c=ge(i.destination_x,a),d=ge(i.destination_y,n),h=await ve(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:c-s,delta_y:d-l}},r=h.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Mi(e,r)}}async function Uo(e){let{statement:t,page:i,screenshotB64:a,viewportWidth:n,viewportHeight:o,modelId:r}=e,s=r||bd,l=G(),c;if(Ci()){let x=l.env?.GOOGLE_CLOUD_PROJECT;if(!x)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:x,location:S}}else{let x=l.env?.GOOGLE_API_KEY;if(x)u.debug(`Using Google AI provider (API key): model=${s}`),c={apiKey:x};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let E=No(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${E}`),c={apiKey:S,httpOptions:{baseUrl:E}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new md(c);w.log(`Sending request to Gemini CUA (model=${s})...`);let h=await d.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:a}}]}],config:{tools:[{computerUse:{environment:gd.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:fd}],temperature:.1}});w.log("Received response from Gemini CUA");let m=h.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(x=>x.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(x=>x.text).map(x=>x.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:y}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(y)}`),u.debug(`Generated function call: ${f} with args ${JSON.stringify(y)}`);let{action_data:b,locatorInfo:p}=await wd(i,f,y,n,o);return b?{status:"success",actionEntity:Ii(t,b,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Wo,fd,bd,Oi=v(()=>{"use strict";Ve();ie();Xe();Ne();R();te();Wo={type:"object",properties:{x:{type:"integer",description:"X coordinate in the 0-1000 normalized space."},y:{type:"integer",description:"Y coordinate in the 0-1000 normalized space."}},required:["x","y"]},fd=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Wo},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Wo}];bd="gemini-3-flash-preview"});function Go(e){return e!=null&&typeof e=="object"}function Ye(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Bo(e){return typeof e=="string"?e:void 0}function yd(e){let t,i;return Array.isArray(e)?(t=Ye(e[0]),i=Ye(e[1])):Go(e)&&(t=Ye(e.x),i=Ye(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function jo(e){if(!Go(e))return{};let t=Array.isArray(e.path)?e.path.map(yd).filter(i=>i!==null):void 0;return{type:Bo(e.type),x:Ye(e.x),y:Ye(e.y),button:Bo(e.button),path:t}}var Li=v(()=>{"use strict"});import xd from"openai";async function vd(e,t){let i=jo(t),a=null,n=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ve(e,i.x,i.y);a={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ve(e,i.x,i.y);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ve(e,o.x,o.y);a={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},n=s.element;break}}return{action_data:a,locatorInfo:await Mi(e,n)}}async function zo(e){let{statement:t,page:i,viewportWidth:a,viewportHeight:n,modelId:o}=e,r=o||_d,s=await wt(i,a,n),l=G(),c=l.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=l.env?.OPENAI_BASE_URL,h=new xd({apiKey:c,...d&&{baseURL:d}}),m=h.responses.create.bind(h.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function f(S,E){let A={model:r,tools:[kd],input:S,temperature:.1};return E&&(A.previous_response_id=E),m(A)}let y=await f(g,void 0),b;for(let S=0;S<Ko;S++){w.log(`Received response from OpenAI CUA (turn ${S+1})`);let E=y.output.find(L=>L.type==="computer_call");if(!E)return{status:"error",reasoning:y.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&w.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;s=await wt(i,a,n);let M=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];y=await f(M,y.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ko} turns`};w.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:p,locatorInfo:x}=await vd(i,b);return p?{status:"success",actionEntity:Ii(t,p,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var _d,kd,Ko,Ni=v(()=>{"use strict";Ve();Li();ie();te();_d="gpt-5.4",kd={type:"computer"},Ko=4});import{createAnthropic as Vo}from"@ai-sdk/anthropic";import{createVertexAnthropic as Sd}from"@ai-sdk/google-vertex/anthropic";function Ed(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Td(){return Ed(G().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Xo(e){let t=G();if(Td()){let n=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return u.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${n}, location=${o}`),Sd({project:n,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),Vo({apiKey:i})(e);let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=Oo(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${n}`),Vo({apiKey:a,baseURL:n})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function ta(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var bt=v(()=>{"use strict";Ne();R();te()});import{createOpenAI as Yo}from"@ai-sdk/openai";function Jo(e){let t=G(),i=t.env?.OPENAI_API_KEY;if(i){let n=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),Yo({apiKey:i,baseURL:n})(e)}let a=t.env?.SHIPLIGHT_API_TOKEN;if(a){let n=Co(a,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${n}`),Yo({apiKey:a,baseURL:n})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function qo(e){return{}}var yt=v(()=>{"use strict";Ne();R();te()});function Qo(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Ad.test(e))return"openai"}function Di(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if($d.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function _e(e){let{provider:t,modelId:i}=Di(e),a=t??Qo(i);if(!a)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${a}:gpt-5.4-mini").`);let n=Zo[a];if(!n)throw new Error(`Provider "${a}" is not yet implemented. Supported providers: ${Object.keys(Zo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return n(i)}function ke(e,t){let{provider:i,modelId:a}=Di(e),n=i??Qo(a);return n==="anthropic"||n==="vertex"?ta(a):n==="openai"||n==="azure"?qo(a):n==="bedrock"?a.startsWith("anthropic.")?ta(a):{}:Ho(t,a)}var Ad,$d,Zo,Se=v(()=>{"use strict";bt();Xe();yt();Ad=/^(gpt-|o\d|chatgpt-)/;$d=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Zo={anthropic:Xo,google:Fo,openai:Jo}});function Id(e){return e.startsWith("gemini-")?"google":"openai"}async function Je(e,t,i={}){let{page:a}=t,n=a.viewportSize();if(!n)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=n;w.log(`Viewport: ${o}x${r}`);let s=await wt(a,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Di(l),d=Id(c),h=Md[d];w.log(`Using CUA provider: ${d} (model: ${c})`);let m={statement:e,page:a,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:c};try{return await h(m)}catch(g){return w.error(`CUA provider "${d}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Md,qe=v(()=>{"use strict";Oi();Ni();Ve();ie();Se();Md={google:Uo,openai:zo}});function Pd(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let a=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,n=[],o=0,r;for(;(r=a.exec(e))!==null;){let l=e.slice(o,r.index);l&&n.push({type:"text",text:l});let c=r[2];i.has(c)?n.push({type:"image",image:new URL(i.get(c))}):n.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&n.push({type:"text",text:s}),n.length===0&&n.push({type:"text",text:e}),n}function Cd(e){let t=[];for(let i of e){let a=i.content||"",n=i.images||[],o=Pd(a,n);t.length>0&&o.length>0&&t.push({type:"text",text:`
15
15
 
16
- `}),t.push(...o)}return t}function Ri(e,t=Qo){if(t){let i=Id(e);if(i.length===0)return[];let a={type:"text",text:`
16
+ `}),t.push(...o)}return t}function Ri(e,t=er){if(t){let i=Cd(e);if(i.length===0)return[];let a={type:"text",text:`
17
17
 
18
18
  <retrieved_knowledge>
19
19
 
@@ -33,7 +33,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
33
33
 
34
34
  </retrieved_knowledge>
35
35
 
36
- `}]:[]}}function er(e,t=Qo){if(!t)return 0;let i=0;for(let a of e)a.images&&(i+=a.images.length);return i}var Qo,xt=v(()=>{"use strict";Qo=!1});function Pd(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(d=>d.type==="year").value,a=t.find(d=>d.type==="month").value,n=t.find(d=>d.type==="day").value,o=t.find(d=>d.type==="hour").value,r=t.find(d=>d.type==="minute").value,s=t.find(d=>d.type==="second").value,l=t.find(d=>d.type==="timeZoneName").value,c=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${a}-${n} ${o}:${r}:${s}.${c} ${l}`}function tr(e){return`# Your Role
36
+ `}]:[]}}function tr(e,t=er){if(!t)return 0;let i=0;for(let a of e)a.images&&(i+=a.images.length);return i}var er,xt=v(()=>{"use strict";er=!1});function Od(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(d=>d.type==="year").value,a=t.find(d=>d.type==="month").value,n=t.find(d=>d.type==="day").value,o=t.find(d=>d.type==="hour").value,r=t.find(d=>d.type==="minute").value,s=t.find(d=>d.type==="second").value,l=t.find(d=>d.type==="timeZoneName").value,c=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${a}-${n} ${o}:${r}:${s}.${c} ${l}`}function ir(e){return`# Your Role
37
37
  You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
38
38
 
39
39
  # Rules
@@ -93,11 +93,11 @@ Example of empty action when the target element is not on the page, or the instr
93
93
  "action": {}, // empty action object to indicate the instruction cannot be completed
94
94
  "completes_instruction": false
95
95
  }
96
- `}function Cd(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,a],n)=>{t+=`(${n+1}) Description: ${i}
96
+ `}function Ld(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,a],n)=>{t+=`(${n+1}) Description: ${i}
97
97
  Feedback: ${a}
98
98
  `}),`## Additional context
99
99
  You just executed following steps in order:
100
- ${t}`}function ir(e,t,i,a,n,o,r=!1,s=Pd(),l=!1,c){let d=[],h=`
100
+ ${t}`}function nr(e,t,i,a,n,o,r=!1,s=Od(),l=!1,c){let d=[],h=`
101
101
  # Instruction
102
102
  "${t}"
103
103
 
@@ -117,9 +117,9 @@ ${e.tabsText}
117
117
 
118
118
  ## Interactive elements from current page:
119
119
  ${e.elementsText}
120
- `;if(d.push({type:"text",text:h}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)d.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),d.push({type:"image",image:g});else o&&(d.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),d.push({type:"image",image:o}));if(n&&n.length>0){let g=Ri(n,l);d.push(...g)}let p="";if(p+=`
120
+ `;if(d.push({type:"text",text:h}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)d.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),d.push({type:"image",image:g});else o&&(d.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),d.push({type:"image",image:o}));if(n&&n.length>0){let g=Ri(n,l);d.push(...g)}let m="";if(m+=`
121
121
  Current local time is ${s}.
122
- `,i&&Object.keys(i).length>0){let g=[];for(let f of Object.keys(i))if(c?.has(f))g.push(` - ${f}: [SENSITIVE - value hidden]`);else{let y=i[f],b=typeof y=="string"?y:JSON.stringify(y);g.push(` - ${f}: "${b}"`)}p+=`
122
+ `,i&&Object.keys(i).length>0){let g=[];for(let f of Object.keys(i))if(c?.has(f))g.push(` - ${f}: [SENSITIVE - value hidden]`);else{let y=i[f],b=typeof y=="string"?y:JSON.stringify(y);g.push(` - ${f}: "${b}"`)}m+=`
123
123
  ## Available Data Placeholders
124
124
  The following placeholders are available for use in your actions:
125
125
  ${g.join(`
@@ -130,25 +130,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
130
130
  - Do NOT use the actual value directly
131
131
  - The values shown are for context only to help you understand what data is available
132
132
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
133
- `}if(a&&a.length>0){let g=Cd(a);p+=`
134
- `+g}return p+=`
133
+ `}if(a&&a.length>0){let g=Ld(a);m+=`
134
+ `+g}return m+=`
135
135
  Based on the above information, please determine the right action to accomplish the task.
136
- `,d.push({type:"text",text:p}),d}var Fi=v(()=>{"use strict";xt()});async function Od(e){let t=e.context().pages(),i=null,a=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),a.push(l)}let n=a.length>0?a.join(`
136
+ `,d.push({type:"text",text:m}),d}var Fi=v(()=>{"use strict";xt()});async function Nd(e){let t=e.context().pages(),i=null,a=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),a.push(l)}let n=a.length>0?a.join(`
137
137
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
138
- `:"",tabsText:n}}async function Ld(e,t){let{currentTabText:i,tabsText:a}=await Od(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:a}}async function Hi(e,t){let{page:i,domService:a,agentServices:n}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=n.getInteractiveClassNames(),s=n.getIframeFallbackDomains(),{domState:l,screenshotBase64:c,slicedScreenshotsBase64:d}=await a.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),h=l.elementTree.clickableElementsToString(),p=await Ld(i,h);return d&&(p.slicedScreenshotsBase64=d),{domTree:h,screenshotBase64:c,slicedScreenshotsBase64:d,domState:l,pageContext:p}}var vt=v(()=>{"use strict"});function Wi(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var _t=v(()=>{"use strict"});import{z as de}from"zod";var ta,H,Ee=v(()=>{"use strict";ta=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let a=this.tools.get(e);if(!a)throw new Error(`Tool not found: ${e}`);try{let n=t?.description,o={...t};delete o.description;let r=a.schema.parse(o),s={...i,actionDescription:n};return await a.execute(r,s)}catch(n){if(n instanceof de.ZodError){let o=n.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw n}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),a=this.getTools().filter(n=>i.has(n.name));return this.buildUnionSchemaFromTools(a,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return de.object({done:de.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof de.ZodObject){let l=s._def.shape();s=de.object({...l,description:de.string().describe("Semantic, human-readable description of the action")})}if(s instanceof de.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=de.object({_empty:de.boolean().optional()}))}return de.object({[r.name]:s})});if(i.length===1)return i[0];let[a,n,...o]=i;return de.union([a,n,...o])}},H=new ta});async function W(e,t){if(t<0)return;let{page:i,domService:a}=e;return(e.domState||await a.getClickableElements(i)).selectorMap.get(t)}function Nd(e){let t=e.split("/").filter(n=>n);if(t.length===0)return"*";let i=t[t.length-1],a=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(a){let[,n,o]=a;return o?`${n}:nth-of-type(${o})`:n}return i}function Dd(e,t=!0){try{let i=Nd(e.xpath);if(e.attributes.class&&t){let n=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&n.test(r)&&(i+=`.${r}`)}let a=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(n=>a.add(n));for(let[n,o]of Object.entries(e.attributes)){if(n==="class"||!n.trim()||!a.has(n))continue;let r=n.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
138
+ `:"",tabsText:n}}async function Dd(e,t){let{currentTabText:i,tabsText:a}=await Nd(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:a}}async function Hi(e,t){let{page:i,domService:a,agentServices:n}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=n.getInteractiveClassNames(),s=n.getIframeFallbackDomains(),{domState:l,screenshotBase64:c,slicedScreenshotsBase64:d}=await a.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),h=l.elementTree.clickableElementsToString(),m=await Dd(i,h);return d&&(m.slicedScreenshotsBase64=d),{domTree:h,screenshotBase64:c,slicedScreenshotsBase64:d,domState:l,pageContext:m}}var vt=v(()=>{"use strict"});function Wi(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var _t=v(()=>{"use strict"});import{z as de}from"zod";var ia,H,Ee=v(()=>{"use strict";ia=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let a=this.tools.get(e);if(!a)throw new Error(`Tool not found: ${e}`);try{let n=t?.description,o={...t};delete o.description;let r=a.schema.parse(o),s={...i,actionDescription:n};return await a.execute(r,s)}catch(n){if(n instanceof de.ZodError){let o=n.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw n}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),a=this.getTools().filter(n=>i.has(n.name));return this.buildUnionSchemaFromTools(a,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return de.object({done:de.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof de.ZodObject){let l=s._def.shape();s=de.object({...l,description:de.string().describe("Semantic, human-readable description of the action")})}if(s instanceof de.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=de.object({_empty:de.boolean().optional()}))}return de.object({[r.name]:s})});if(i.length===1)return i[0];let[a,n,...o]=i;return de.union([a,n,...o])}},H=new ia});async function W(e,t){if(t<0)return;let{page:i,domService:a}=e;return(e.domState||await a.getClickableElements(i)).selectorMap.get(t)}function Rd(e){let t=e.split("/").filter(n=>n);if(t.length===0)return"*";let i=t[t.length-1],a=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(a){let[,n,o]=a;return o?`${n}:nth-of-type(${o})`:n}return i}function Fd(e,t=!0){try{let i=Rd(e.xpath);if(e.attributes.class&&t){let n=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&n.test(r)&&(i+=`.${r}`)}let a=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(n=>a.add(n));for(let[n,o]of Object.entries(e.attributes)){if(n==="class"||!n.trim()||!a.has(n))continue;let r=n.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
139
139
  `)&&(s=o.split(`
140
- `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Rd(e){let t=e.attributes;if(t.title)return`iframe[title="${t.title.replace(/"/g,'\\"')}"]`;if(t.id)return`iframe#${t.id}`;if(t.name)return`iframe[name="${t.name.replace(/"/g,'\\"')}"]`;if(t.src){try{let i=new URL(t.src);if(i.protocol==="chrome-extension:")return`iframe[src^="${i.origin}"]`}catch{}return`iframe[src="${t.src.replace(/"/g,'\\"')}"]`}return Dd(e,!1)}function nr(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let a=[],n=t.filter(o=>o.tagName==="iframe");for(let o of n){let r=Rd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),a.push(r)}return a}async function N(e,t){let i=null,a=nr(t);return t.xpath&&(i=await Zn(e,t.xpath,a,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:a}}var j=v(()=>{"use strict";We();R()});import{generateText as Fd,Output as Hd}from"ai";import{z as Ui}from"zod";function Wd(e){let t=e.toLowerCase();return[/\b(type|enter|input|fill|write|set)\b/,/\b(text|value|field|box)\b.*\b(to|with|as)\b/,/\b(username|password|email|search|query)\b/].some(i=>i.test(t))?"input":[/\bscroll\b/,/\b(scroll|swipe)\s*(up|down|left|right)\b/,/\b(page|move)\s*(down|up)\b/].some(i=>i.test(t))?"scroll":[/\b(click|tap|press|select|choose|pick|check|toggle)\b/,/\b(open|close|submit|confirm|cancel|dismiss)\b/,/\b(button|link|menu|dropdown|checkbox|radio)\b/].some(i=>i.test(t))?"click":"all"}function Ud(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}function Bd(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=Ud(a);if(n)return{type:"image",file:n};let o=typeof a=="string"?a:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function ar(e,t,i={}){let{page:a,agentServices:n}=t,o=n.getModel(),r=i.temperature??0,s=n.retrieveKnowledges(e).catch(X=>(w.log(`Failed to retrieve knowledges: ${X.message}`),[])),l=n.isSlicedScreenshotsEnabled(),c=n.isResizeSlicedScreenshotsEnabled(),d=n.isKnowledgeImagesEnabled(),h=n.isAccessibilityTreeEnabled(),p=n.isActionIntentFilteringEnabled(),g=p?Wd(e):"all";p&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:y,pageContext:b}=await Hi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:c,useAccessibilityTree:h,actionIntent:g});t.domState=y;let m=new zn(H).getToolDefinitions().map(X=>{let Be=X.function;return`${Be.name}: ${Be.description}
140
+ `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Hd(e){let t=e.attributes;if(t.title)return`iframe[title="${t.title.replace(/"/g,'\\"')}"]`;if(t.id)return`iframe#${t.id}`;if(t.name)return`iframe[name="${t.name.replace(/"/g,'\\"')}"]`;if(t.src){try{let i=new URL(t.src);if(i.protocol==="chrome-extension:")return`iframe[src^="${i.origin}"]`}catch{}return`iframe[src="${t.src.replace(/"/g,'\\"')}"]`}return Fd(e,!1)}function ar(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let a=[],n=t.filter(o=>o.tagName==="iframe");for(let o of n){let r=Hd(o);u.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),a.push(r)}return a}async function N(e,t){let i=null,a=ar(t);return t.xpath&&(i=await Qn(e,t.xpath,a,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:a}}var j=v(()=>{"use strict";We();R()});import{generateText as Wd,Output as Ud}from"ai";import{z as Ui}from"zod";function Bd(e){let t=e.toLowerCase();return[/\b(type|enter|input|fill|write|set)\b/,/\b(text|value|field|box)\b.*\b(to|with|as)\b/,/\b(username|password|email|search|query)\b/].some(i=>i.test(t))?"input":[/\bscroll\b/,/\b(scroll|swipe)\s*(up|down|left|right)\b/,/\b(page|move)\s*(down|up)\b/].some(i=>i.test(t))?"scroll":[/\b(click|tap|press|select|choose|pick|check|toggle)\b/,/\b(open|close|submit|confirm|cancel|dismiss)\b/,/\b(button|link|menu|dropdown|checkbox|radio)\b/].some(i=>i.test(t))?"click":"all"}function Gd(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}function jd(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=Gd(a);if(n)return{type:"image",file:n};let o=typeof a=="string"?a:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function or(e,t,i={}){let{page:a,agentServices:n}=t,o=n.getModel(),r=i.temperature??0,s=n.retrieveKnowledges(e).catch(X=>(w.log(`Failed to retrieve knowledges: ${X.message}`),[])),l=n.isSlicedScreenshotsEnabled(),c=n.isResizeSlicedScreenshotsEnabled(),d=n.isKnowledgeImagesEnabled(),h=n.isAccessibilityTreeEnabled(),m=n.isActionIntentFilteringEnabled(),g=m?Bd(e):"all";m&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:y,pageContext:b}=await Hi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:c,useAccessibilityTree:h,actionIntent:g});t.domState=y;let p=new Vn(H).getToolDefinitions().map(X=>{let Be=X.function;return`${Be.name}: ${Be.description}
141
141
  Parameters: ${JSON.stringify(Be.parameters,null,2)}`}).join(`
142
142
 
143
- `),x=tr(m),S=await s,E=ir(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?A.push({role:"user",content:X.content}):X.role==="assistant"&&A.push({role:"assistant",content:X.content})}),A.push({role:"user",content:E});let $=Bd(A),L=H.buildActionUnionSchema(),D=Ui.object({thought:Ui.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ui.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:Ui.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),C=Array.isArray(E)?E.filter(X=>X.type==="image").length:0,V=ke(o,C),ee=await Fd({model:_e(o),system:x,messages:A,temperature:r,output:Hd.object({schema:D}),providerOptions:V}),be=ee.reasoningText;u.info(`Action Generation Reasoning: ${be}`);let z=ee.output,Y=JSON.stringify(z,null,2);u.info(`Generate Action Raw Output: ${Y}`);let ye=[],Re=Wi(ee.usage,o);Re&&ye.push(Re);let Ie={systemPrompt:x,userPrompt:$,rawLlmResponse:Y,tokenUsages:ye},Pe=z.thought||"",Ce=z.description||"",U=z.action||{},J=z.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Pe||Ce||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Ie};let q=Object.keys(U)[0];if(q==="done")return{status:"error",reasoning:Pe||Ce||"Task marked as done",goalAccomplished:J,error:"Agent indicated task is done without generating an action",debugInfo:Ie};if(q==="perform_accurate_operation")return await Je(e,t,i);if(!J){let X="Can't complete the instruction in one action";return{status:"error",reasoning:Pe||Ce||X,goalAccomplished:!1,error:X,debugInfo:Ie}}let se=U[q]||{},Da={};if(typeof se.element_index=="number"){let X=se.element_index;if(X<0)return{status:"error",reasoning:Pe||Ce||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Ie};let Be=y.selectorMap.get(X);Be&&(Da=await N(a,Be))}let Ra=Ce;return q==="verify"&&(Ra=e,se.statement=e),{status:"success",actionEntity:{...Da,action_description:Ra||Pe||`${q}(${JSON.stringify(se)})`,action_data:{action_name:q,kwargs:se}},reasoning:Pe||Ce,goalAccomplished:J,debugInfo:Ie}}var Bi=v(()=>{"use strict";Ei();qe();Fi();vt();_t();Ee();ie();Se();j();R()});import{generateText as Gd,Output as jd}from"ai";import{z as Gi}from"zod";function Kd(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}async function ia(e,t,i={}){return i.usePureVision?Je(e,t,i):ar(e,t,i)}function Vd(){let e=new Date,t=e.toLocaleDateString("en-US",{weekday:"long",year:"numeric",month:"long",day:"numeric",timeZone:"America/Los_Angeles"}),i=e.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",second:"2-digit",fractionalSecondDigits:3,timeZoneName:"short",timeZone:"America/Los_Angeles"});return{dateString:t,timeString:i}}function Xd(){return`# Role
143
+ `),x=ir(p),S=await s,E=nr(b,e,t.variables,t.executionHistory,S.length>0?S:void 0,f,l,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?A.push({role:"user",content:X.content}):X.role==="assistant"&&A.push({role:"assistant",content:X.content})}),A.push({role:"user",content:E});let M=jd(A),L=H.buildActionUnionSchema(),D=Ui.object({thought:Ui.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ui.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:Ui.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),C=Array.isArray(E)?E.filter(X=>X.type==="image").length:0,V=ke(o,C),ee=await Wd({model:_e(o),system:x,messages:A,temperature:r,output:Ud.object({schema:D}),providerOptions:V}),be=ee.reasoningText;u.info(`Action Generation Reasoning: ${be}`);let z=ee.output,Y=JSON.stringify(z,null,2);u.info(`Generate Action Raw Output: ${Y}`);let ye=[],Re=Wi(ee.usage,o);Re&&ye.push(Re);let Ie={systemPrompt:x,userPrompt:M,rawLlmResponse:Y,tokenUsages:ye},Pe=z.thought||"",Ce=z.description||"",U=z.action||{},J=z.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Pe||Ce||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Ie};let q=Object.keys(U)[0];if(q==="done")return{status:"error",reasoning:Pe||Ce||"Task marked as done",goalAccomplished:J,error:"Agent indicated task is done without generating an action",debugInfo:Ie};if(q==="perform_accurate_operation")return await Je(e,t,i);if(!J){let X="Can't complete the instruction in one action";return{status:"error",reasoning:Pe||Ce||X,goalAccomplished:!1,error:X,debugInfo:Ie}}let se=U[q]||{},Ra={};if(typeof se.element_index=="number"){let X=se.element_index;if(X<0)return{status:"error",reasoning:Pe||Ce||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Ie};let Be=y.selectorMap.get(X);Be&&(Ra=await N(a,Be))}let Fa=Ce;return q==="verify"&&(Fa=e,se.statement=e),{status:"success",actionEntity:{...Ra,action_description:Fa||Pe||`${q}(${JSON.stringify(se)})`,action_data:{action_name:q,kwargs:se}},reasoning:Pe||Ce,goalAccomplished:J,debugInfo:Ie}}var Bi=v(()=>{"use strict";Ei();qe();Fi();vt();_t();Ee();ie();Se();j();R()});import{generateText as Kd,Output as zd}from"ai";import{z as Gi}from"zod";function Vd(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}async function na(e,t,i={}){return i.usePureVision?Je(e,t,i):or(e,t,i)}function Yd(){let e=new Date,t=e.toLocaleDateString("en-US",{weekday:"long",year:"numeric",month:"long",day:"numeric",timeZone:"America/Los_Angeles"}),i=e.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",second:"2-digit",fractionalSecondDigits:3,timeZoneName:"short",timeZone:"America/Los_Angeles"});return{dateString:t,timeString:i}}function Jd(){return`# Role
144
144
  You are an experienced QA person for web applications.
145
145
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
146
- `}async function or(e,t,i={}){let{page:a,executionHistory:n}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:f}=await Hi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:c});t.domState=g;let y="";n&&n.length>0&&(y=`
146
+ `}async function rr(e,t,i={}){let{page:a,executionHistory:n}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:h,slicedScreenshotsBase64:m,domState:g,pageContext:f}=await Hi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:c});t.domState=g;let y="";n&&n.length>0&&(y=`
147
147
  # Previous actions in this session:
148
148
  ${n.map(([U,J],q)=>`${q+1}. Action: ${U}
149
149
  Result: ${J}`).join(`
150
150
  `)}
151
- `);let{dateString:b,timeString:m}=Vd(),x=`
151
+ `);let{dateString:b,timeString:p}=Yd(),x=`
152
152
  # User statement
153
153
  "${e}"
154
154
 
@@ -166,7 +166,7 @@ ${f.tabsText}
166
166
  ${d}
167
167
 
168
168
  ## Screenshot
169
- ${r&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
169
+ ${r&&m?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
170
170
  `,S="";if(t.variables&&Object.keys(t.variables).length>0){let U=[];for(let J of Object.keys(t.variables))if(!t.sensitiveKeys?.has(J)){let q=t.variables[J],se=typeof q=="string"?q:JSON.stringify(q);U.push(` - ${J}: "${se}"`)}U.length>0&&(S=`
171
171
  ## Available Variables
172
172
  The following non-sensitive variables are available:
@@ -175,14 +175,14 @@ ${U.join(`
175
175
  ${S}
176
176
  ${y}
177
177
 
178
- Today is ${b}. Current local time is ${m}.
178
+ Today is ${b}. Current local time is ${p}.
179
179
  Based on the above information, please determine if the statement is true.
180
- `,A=await t.agentServices.retrieveKnowledges(e),$=[{type:"text",text:x}],L=0;if(r&&p&&p.length>0)for(let U of p)$.push({type:"image",image:U}),L++;else $.push({type:"image",image:h}),L=1;if(A&&A.length>0){let U=Ri(A,l);$.push(...U)}$.push({type:"text",text:E});let D=A?er(A,l):0,C=L+D,V=ke(o,C),ee=Xd(),be=await Gd({model:_e(o),system:ee,messages:[{role:"user",content:$}],output:jd.object({schema:zd}),temperature:0,providerOptions:V}),{conclusion:z,explanation:Y}=be.output,ye=JSON.stringify(be.output,null,2),Re=[],Ie=Wi(be.usage,o);Ie&&Re.push(Ie);let Pe=[{role:"user",content:$.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let J=U.image,q=Kd(J);if(q)return{type:"image",file:q};let se=typeof J=="string"?J:"";return{type:"image",file:se.startsWith("data:")?se:`data:image/png;base64,${se}`}}return{type:"text",text:"[unknown content type]"}})}],Ce={systemPrompt:ee,userPrompt:Pe,rawLlmResponse:ye,screenshotWithSom:h,tokenUsages:Re,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:d};return{success:z==="true",explanation:Y,debugInfo:Ce}}catch(r){return{success:!1,error:r.message}}}var zd,ji=v(()=>{"use strict";Bi();qe();vt();_t();xt();Se();zd=Gi.object({screenshotDescription:Gi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
180
+ `,A=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:x}],L=0;if(r&&m&&m.length>0)for(let U of m)M.push({type:"image",image:U}),L++;else M.push({type:"image",image:h}),L=1;if(A&&A.length>0){let U=Ri(A,l);M.push(...U)}M.push({type:"text",text:E});let D=A?tr(A,l):0,C=L+D,V=ke(o,C),ee=Jd(),be=await Kd({model:_e(o),system:ee,messages:[{role:"user",content:M}],output:zd.object({schema:Xd}),temperature:0,providerOptions:V}),{conclusion:z,explanation:Y}=be.output,ye=JSON.stringify(be.output,null,2),Re=[],Ie=Wi(be.usage,o);Ie&&Re.push(Ie);let Pe=[{role:"user",content:M.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let J=U.image,q=Vd(J);if(q)return{type:"image",file:q};let se=typeof J=="string"?J:"";return{type:"image",file:se.startsWith("data:")?se:`data:image/png;base64,${se}`}}return{type:"text",text:"[unknown content type]"}})}],Ce={systemPrompt:ee,userPrompt:Pe,rawLlmResponse:ye,screenshotWithSom:h,tokenUsages:Re,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:d};return{success:z==="true",explanation:Y,debugInfo:Ce}}catch(r){return{success:!1,error:r.message}}}var Xd,ji=v(()=>{"use strict";Bi();qe();vt();_t();xt();Se();Xd=Gi.object({screenshotDescription:Gi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
181
181
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
182
182
  [45] A modal dialog titled "Confirmation",
183
- in the center of the screen`),explanation:Gi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Gi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function sr(){let{default:e}=await import("sharp");return e}async function na(e,t){let i=await sr(),a=await i(e).metadata(),n=a.width||0,o=a.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((n-r)/2),c=Math.max(0,n-r),d=(f,y)=>{let b=i(e).extract({left:f,top:0,width:y,height:r});return t?.resize&&(b=b.resize(rr,rr)),b.png().toBuffer()},[h,p,g]=await Promise.all([d(s,Math.min(r,n)),d(l,Math.min(r,n-l)),d(c,Math.min(r,n-c))]);return[h,p,g]}async function lr(e){let t=(await sr())(e),i=await t.metadata(),a=i.width||0,n=i.height||0;if(a===0||n===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<n;s++){r[s]=[];for(let l=0;l<a;l++)r[s][l]=o[s*a+l]}return{pixels:r,width:a,height:n}}var rr,kt=v(()=>{"use strict";rr=768});var aa,oa,ra,sa,St=v(()=>{"use strict";aa=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),oa=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),ra=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],sa=500});function cr(e,t){return e.length>t?e.slice(0,t)+"...":e}var Et=v(()=>{"use strict"});var dr,ur,Tt=v(()=>{"use strict";dr=["title","type","checked","name","role","value","placeholder","data-date-format","alt","aria-label","aria-expanded","data-state","aria-checked","data-id","data-testid","data-test-id","data-handlepos","data-item-id"],ur={"react-flow__(\\S+)":"$1"}});var hr,At,Te,Ze=v(()=>{"use strict";Et();Tt();hr=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},At=class extends hr{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},Te=class Ki extends hr{constructor(t,i,a,n,o,r=!1,s=!1,l=!1,c=!1,d=!1,h=!1,p=null,g=null,f=null,y=null,b=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=a,this.children=n,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=h,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=f,this.viewportInfo=y,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],a=(n,o)=>{if(!(t!==-1&&o>t)&&!(n instanceof Ki&&n!==this&&n.highlightIndex!==null)){if(n instanceof At)i.push(n.text);else if(n instanceof Ki)for(let r of n.children)a(r,o+1)}};return a(this,0),i.join(`
184
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??dr,a=t?.includeClassesWithRename??ur,n=[],o=(r,s)=>{let l=s,c=" ".repeat(s);if(r instanceof Ki){if(r.highlightIndex!==null){l+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let A=r.attributes[E].trim();A!==""&&(m[E]=A)}let x=i.filter(E=>E in m);if(x.length>1){let E=new Set,A={};for(let $ of x){let L=m[$];L.length>5&&(L in A?E.add($):A[L]=$)}for(let $ of E)delete m[$]}r.tagName===m.role&&delete m.role;let S=["aria-label","placeholder","title"];for(let E of S)m[E]&&m[E].trim().toLowerCase()===d.trim().toLowerCase()&&delete m[E];Object.keys(m).length>0&&(h=Object.entries(m).map(([E,A])=>`${E}=${cr(A,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(a).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let x of m)for(let[S,E]of Object.entries(a))try{let A=new RegExp(`^${S}$`);if(x.match(A)){let $=x.replace(A,E);$&&g.push($);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",y=r.markAsClickable?" (CLICKABLE)":"",b=`${c}${p}${f}${y}<${r.tagName}`;if(g.length>0&&(b+=` ${g.join(" ")}`),h&&(b+=` ${h}`),d){let m=d.trim();h||(b+=" "),b+=`>${m}`}else h||(b+=" ");b+=" />",n.push(b)}else{let d=["data-testid","data-test-id"].filter(h=>r.attributes[h]);d.length>0&&(l+=1,n.push(`${c}<${r.tagName} ${d.map(h=>`${h}="${r.attributes[h]}"`).join(" ")} />`))}for(let d of r.children)o(d,l)}else if(r instanceof At){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&n.push(`${c}${r.text}`)}};return o(this,0),n.join(`
185
- `)}}});function qd(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Yd,Jd,fe,Ue=v(()=>{"use strict";kt();St();Ze();R();Yd=`(
183
+ in the center of the screen`),explanation:Gi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Gi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function lr(){let{default:e}=await import("sharp");return e}async function aa(e,t){let i=await lr(),a=await i(e).metadata(),n=a.width||0,o=a.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((n-r)/2),c=Math.max(0,n-r),d=(f,y)=>{let b=i(e).extract({left:f,top:0,width:y,height:r});return t?.resize&&(b=b.resize(sr,sr)),b.png().toBuffer()},[h,m,g]=await Promise.all([d(s,Math.min(r,n)),d(l,Math.min(r,n-l)),d(c,Math.min(r,n-c))]);return[h,m,g]}async function cr(e){let t=(await lr())(e),i=await t.metadata(),a=i.width||0,n=i.height||0;if(a===0||n===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<n;s++){r[s]=[];for(let l=0;l<a;l++)r[s][l]=o[s*a+l]}return{pixels:r,width:a,height:n}}var sr,kt=v(()=>{"use strict";sr=768});var oa,ra,sa,la,St=v(()=>{"use strict";oa=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),ra=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),sa=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],la=500});function dr(e,t){return e.length>t?e.slice(0,t)+"...":e}var Et=v(()=>{"use strict"});var ur,hr,Tt=v(()=>{"use strict";ur=["title","type","checked","name","role","value","placeholder","data-date-format","alt","aria-label","aria-expanded","data-state","aria-checked","data-id","data-testid","data-test-id","data-handlepos","data-item-id"],hr={"react-flow__(\\S+)":"$1"}});var pr,At,Te,Ze=v(()=>{"use strict";Et();Tt();pr=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},At=class extends pr{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},Te=class Ki extends pr{constructor(t,i,a,n,o,r=!1,s=!1,l=!1,c=!1,d=!1,h=!1,m=null,g=null,f=null,y=null,b=[],p=null){super(o,p),this.tagName=t,this.xpath=i,this.attributes=a,this.children=n,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=h,this.highlightIndex=m,this.viewportCoordinates=g,this.pageCoordinates=f,this.viewportInfo=y,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],a=(n,o)=>{if(!(t!==-1&&o>t)&&!(n instanceof Ki&&n!==this&&n.highlightIndex!==null)){if(n instanceof At)i.push(n.text);else if(n instanceof Ki)for(let r of n.children)a(r,o+1)}};return a(this,0),i.join(`
184
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??ur,a=t?.includeClassesWithRename??hr,n=[],o=(r,s)=>{let l=s,c=" ".repeat(s);if(r instanceof Ki){if(r.highlightIndex!==null){l+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let p={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let A=r.attributes[E].trim();A!==""&&(p[E]=A)}let x=i.filter(E=>E in p);if(x.length>1){let E=new Set,A={};for(let M of x){let L=p[M];L.length>5&&(L in A?E.add(M):A[L]=M)}for(let M of E)delete p[M]}r.tagName===p.role&&delete p.role;let S=["aria-label","placeholder","title"];for(let E of S)p[E]&&p[E].trim().toLowerCase()===d.trim().toLowerCase()&&delete p[E];Object.keys(p).length>0&&(h=Object.entries(p).map(([E,A])=>`${E}=${dr(A,200)}`).join(" "))}let m=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(a).length>0&&r.attributes.class){let p=r.attributes.class.split(/\s+/);for(let x of p)for(let[S,E]of Object.entries(a))try{let A=new RegExp(`^${S}$`);if(x.match(A)){let M=x.replace(A,E);M&&g.push(M);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",y=r.markAsClickable?" (CLICKABLE)":"",b=`${c}${m}${f}${y}<${r.tagName}`;if(g.length>0&&(b+=` ${g.join(" ")}`),h&&(b+=` ${h}`),d){let p=d.trim();h||(b+=" "),b+=`>${p}`}else h||(b+=" ");b+=" />",n.push(b)}else{let d=["data-testid","data-test-id"].filter(h=>r.attributes[h]);d.length>0&&(l+=1,n.push(`${c}<${r.tagName} ${d.map(h=>`${h}="${r.attributes[h]}"`).join(" ")} />`))}for(let d of r.children)o(d,l)}else if(r instanceof At){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&n.push(`${c}${r.text}`)}};return o(this,0),n.join(`
185
+ `)}}});function Qd(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var qd,Zd,fe,Ue=v(()=>{"use strict";kt();St();Ze();R();qd=`(
186
186
  args = {
187
187
  doHighlightElements: true,
188
188
  focusHighlightIndex: -1,
@@ -1950,7 +1950,7 @@ Based on the above information, please determine if the statement is true.
1950
1950
 
1951
1951
  return { rootId, map: DOM_HASH_MAP };
1952
1952
  }
1953
- `,Jd=`((args = {
1953
+ `,Zd=`((args = {
1954
1954
  doHighlightElements: true,
1955
1955
  focusHighlightIndex: -1,
1956
1956
  viewportExpansion: 0,
@@ -3998,7 +3998,7 @@ Based on the above information, please determine if the statement is true.
3998
3998
  // Return element data from boxes phase for use in labels phase
3999
3999
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4000
4000
  };
4001
- })`;fe=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let a of t){let n=this.normalizeDomain(a);if(n&&(i===n||i.endsWith(`.${n}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Jd:Yd}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:a=-1,viewportExpansion:n=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:c="all"}=t,[d,h]=await this.buildDomTree(e,i,a,n,o,r,s,l,c);return{elementTree:d,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let a=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let n=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await na(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){u.warn("Failed to slice screenshot:",r)}return{domState:a,screenshotBase64:n,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let a=await e.context().newCDPSession(e),{nodes:n}=await a.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${n.length} AXNodes from accessibility tree`);let o=n.filter(m=>{if(m.ignored)return!1;let x=m.role?.value;return!(!x||!aa.has(x)||m.properties?.find(S=>S.name==="disabled")?.value?.value||!m.backendDOMNodeId)});u.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=n.filter(m=>m.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let x=[];m.ignored&&x.push("ignored"),m.backendDOMNodeId||x.push("no-backendDOMNodeId"),m.properties?.find(S=>S.name==="disabled")?.value?.value&&x.push("disabled"),u.debug(` - "${m.name?.value||"(no name)"}" ${x.length>0?`[SKIPPED: ${x.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(a,t.eventListenerLimit??500),c=0;for(let m of l)s.has(m.backendNodeId)||(o.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),c++);u.debug(`\u{1F3AF} Added ${c} elements from event listeners (total: ${o.length})`);let d=await this.resolveAXNodesToDOM(a,o),h=d.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=d.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){u.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let x=[];m.isVisible||x.push("not-visible"),m.isInViewport||x.push("not-in-viewport"),m.isTopElement||x.push("not-top-element"),m.boundingRect||x.push("no-bounding-rect"),u.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${x.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:f}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await a.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let y=i.toString("base64"),b;if(t.useSlicedScreenshots)try{b=(await na(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){u.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:y,screenshot:i,slicedScreenshotsBase64:b}}async resolveAXNodesToDOM(e,t){let i=[],a=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(a.length===0)return i;let n=[];for(let o of a)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});n.push(r.objectId||null)}catch{n.push(null)}for(let o=0;o<t.length;o++){let r=t[o],s=n[o];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4001
+ })`;fe=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let a of t){let n=this.normalizeDomain(a);if(n&&(i===n||i.endsWith(`.${n}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Zd:qd}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:a=-1,viewportExpansion:n=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:c="all"}=t,[d,h]=await this.buildDomTree(e,i,a,n,o,r,s,l,c);return{elementTree:d,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let a=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let n=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await aa(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){u.warn("Failed to slice screenshot:",r)}return{domState:a,screenshotBase64:n,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let a=await e.context().newCDPSession(e),{nodes:n}=await a.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${n.length} AXNodes from accessibility tree`);let o=n.filter(p=>{if(p.ignored)return!1;let x=p.role?.value;return!(!x||!oa.has(x)||p.properties?.find(S=>S.name==="disabled")?.value?.value||!p.backendDOMNodeId)});u.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=n.filter(p=>p.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let p of r){let x=[];p.ignored&&x.push("ignored"),p.backendDOMNodeId||x.push("no-backendDOMNodeId"),p.properties?.find(S=>S.name==="disabled")?.value?.value&&x.push("disabled"),u.debug(` - "${p.name?.value||"(no name)"}" ${x.length>0?`[SKIPPED: ${x.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(p=>p.backendDOMNodeId)),l=await this.getElementsWithEventListeners(a,t.eventListenerLimit??500),c=0;for(let p of l)s.has(p.backendNodeId)||(o.push({nodeId:`synthetic-${p.backendNodeId}`,ignored:!1,backendDOMNodeId:p.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:p.eventTypes.join(",")}}]}),s.add(p.backendNodeId),c++);u.debug(`\u{1F3AF} Added ${c} elements from event listeners (total: ${o.length})`);let d=await this.resolveAXNodesToDOM(a,o),h=d.filter(p=>p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect),m=d.filter(p=>!(p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect));if(m.length>0){u.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let p of m){let x=[];p.isVisible||x.push("not-visible"),p.isInViewport||x.push("not-in-viewport"),p.isTopElement||x.push("not-top-element"),p.boundingRect||x.push("no-bounding-rect"),u.debug(` - <${p.tagName}> "${p.axNode.name?.value||""}" [${x.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:f}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await a.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let y=i.toString("base64"),b;if(t.useSlicedScreenshots)try{b=(await aa(i,{resize:t.resizeSlicedScreenshots})).map(p=>p.toString("base64"))}catch(p){u.warn("Failed to slice screenshot:",p)}return{domState:g,screenshotBase64:y,screenshot:i,slicedScreenshotsBase64:b}}async resolveAXNodesToDOM(e,t){let i=[],a=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(a.length===0)return i;let n=[];for(let o of a)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});n.push(r.objectId||null)}catch{n.push(null)}for(let o=0;o<t.length;o++){let r=t[o],s=n[o];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4002
4002
  const el = this;
4003
4003
  const rect = el.getBoundingClientRect();
4004
4004
  const rects = el.getClientRects();
@@ -4082,36 +4082,36 @@ Based on the above information, please determine if the statement is true.
4082
4082
  } : null,
4083
4083
  clientRects: clientRectsArray
4084
4084
  };
4085
- }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=sa){let i=[];try{let{root:a}=await e.send("DOM.getDocument",{depth:0}),n=ra.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:a.nodeId,selector:n});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),c=l.filter(d=>oa.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(a){u.warn("Failed to get elements with event listeners:",a)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Te("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),a=0;for(let n of e){let o=n.axNode.role?.value||"",r=n.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new Te(n.tagName,n.xpath,n.attributes,[],n.isVisible,!0,o==="scrollbar",s,n.isTopElement,n.isInViewport,!1,a,n.boundingRect?{topLeft:{x:n.boundingRect.x,y:n.boundingRect.y},topRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y},bottomLeft:{x:n.boundingRect.x,y:n.boundingRect.y+n.boundingRect.height},bottomRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y+n.boundingRect.height},center:{x:n.boundingRect.x+n.boundingRect.width/2,y:n.boundingRect.y+n.boundingRect.height/2},width:n.boundingRect.width,height:n.boundingRect.height}:null,null,null,[],i);if(r){let c=new At(r,!0,l);l.children.push(c)}i.children.push(l),t.set(a,l),a++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:a}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:a,colors:n})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),a.forEach((s,l)=>{if(!s.boundingRect)return;let c=n[l%n.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${f}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let a=document.getElementById("playwright-highlight-container");a&&a.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(n=>n()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(a){u.warn("Failed to remove highlights:",a.message)}for(let a of e.frames()){let n=a.url();if(!(!n.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(n,t)))try{await a.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>l.hostname.includes(c))}catch{return!1}},a=e.url(),n=new URL(a).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==n&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,a,n,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(qd(e.url()))return[new Te("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:a,debugMode:!1,interactiveClassNames:n,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await lr(x);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let $={...c,phase:"labels",grayscaleImage:h,elementData:m.elementData};d=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:$}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:x,argsObj:S})=>new Function("return "+x)()(S),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:m})=>new Function("return "+b)()(m),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:x})=>new Function("return "+m)()(x),{code:this.jsCode,argsObj:b})}let p=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[b,m]of p){let x=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,m]of Object.entries(d.map)){let x=m;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&f.push({nodeId:b,src:x.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let m of Object.values(d.map)){let x=m;x.highlightIndex!=null&&(b=Math.max(b,x.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let m=0;m<f.length;m++){let{nodeId:x,src:S}=f[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${S}`);let E=D=>{try{let C=new URL(D);if(C.protocol==="chrome-extension:"&&C.hostname)return`chrome-extension://${C.hostname}`;let V=C.origin;return V==="null"?null:V}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let $=null,L=e.frames().find(D=>{let C=D.url();if(C===S)return $="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${C}`),!0;let V=E(C);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${C} origin=${V??"null"} vs srcOrigin=${A??"null"}`),A&&V===A?($="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${C}`),!0):!1});if(!L){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(D=>D.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${L.url()})`);try{let D={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${D.initialHighlightIndex}`);let C=await L.evaluate(({code:z,argsObj:Y})=>new Function("return "+z)()(Y),{code:this.jsCode,argsObj:D});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(C?.map??{}).length} rootId=${C?.rootId}`),!C?.map||!C.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(C.map).filter(z=>z.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${V.length}`);for(let z of V){let Y=z;u.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let z of Object.values(C.map)){let Y=z;Y.highlightIndex!=null&&(b=Math.max(b,Y.highlightIndex))}let ee=`ext_${m}_`;for(let[z,Y]of Object.entries(C.map)){let ye={...Y};ye.children&&(ye.children=ye.children.map(Re=>`${ee}${Re}`)),d.map[`${ee}${z}`]=ye}let be=d.map[x];be?(be.children=[...be.children||[],`${ee}${C.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(D){u.warn(`Failed to process fallback iframe ${S}:`,D)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&m++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${m}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),y}async constructDomTree(e){let t=e.map,i=e.rootId,a=new Map,n=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(n.set(s,c),o.set(s,d),c instanceof Te&&c.highlightIndex!==null&&a.set(c.highlightIndex,c))}for(let[s,l]of o){let c=n.get(s);if(c instanceof Te)for(let d of l){let h=n.get(d);h&&(h.parent=c,c.children.push(h))}}let r=n.get(i);if(!r||!(r instanceof Te))throw new Error("Failed to parse HTML to dictionary");return[r,a]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new At(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],a=new Te(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),n=e.children||[];return[a,n]}}});import{z as Zd}from"zod";var mr,Eb,zi=v(()=>{"use strict";mr=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Eb=Zd.object({})});var pr,Vi=v(()=>{"use strict";F();I();pr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(n,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Le(e);if(!t){let n=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",a=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]}}});import*as Qd from"playwright/test";import{default as eu}from"playwright/test";var Qe,$t=v(()=>{"use strict";me();Qe={};Ai(Qe,{default:()=>eu});Mo(Qe,Qd)});import{z as gr}from"zod";var fr,Db,Xi=v(()=>{"use strict";$t();fr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
4085
+ }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=la){let i=[];try{let{root:a}=await e.send("DOM.getDocument",{depth:0}),n=sa.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:a.nodeId,selector:n});u.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),c=l.filter(d=>ra.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(a){u.warn("Failed to get elements with event listeners:",a)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Te("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),a=0;for(let n of e){let o=n.axNode.role?.value||"",r=n.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new Te(n.tagName,n.xpath,n.attributes,[],n.isVisible,!0,o==="scrollbar",s,n.isTopElement,n.isInViewport,!1,a,n.boundingRect?{topLeft:{x:n.boundingRect.x,y:n.boundingRect.y},topRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y},bottomLeft:{x:n.boundingRect.x,y:n.boundingRect.y+n.boundingRect.height},bottomRight:{x:n.boundingRect.x+n.boundingRect.width,y:n.boundingRect.y+n.boundingRect.height},center:{x:n.boundingRect.x+n.boundingRect.width/2,y:n.boundingRect.y+n.boundingRect.height/2},width:n.boundingRect.width,height:n.boundingRect.height}:null,null,null,[],i);if(r){let c=new At(r,!0,l);l.children.push(c)}i.children.push(l),t.set(a,l),a++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:a}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:a,colors:n})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),a.forEach((s,l)=>{if(!s.boundingRect)return;let c=n[l%n.length],d=s.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${c}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${d.y}px`,h.style.left=`${d.x}px`,h.style.width=`${d.width}px`,h.style.height=`${d.height}px`,r.appendChild(h);let m=document.createElement("div");m.style.position="fixed",m.style.background=c,m.style.color="white",m.style.padding="1px 4px",m.style.borderRadius="4px",m.style.fontSize=l>=100?"8px":"12px",m.textContent=String(l);let g=Math.max(0,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${f}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let a=document.getElementById("playwright-highlight-container");a&&a.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(n=>n()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),u.debug("\u2705 Highlights removed from page")}catch(a){u.warn("Failed to remove highlights:",a.message)}for(let a of e.frames()){let n=a.url();if(!(!n.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(n,t)))try{await a.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>l.hostname.includes(c))}catch{return!1}},a=e.url(),n=new URL(a).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let c=new URL(l).hostname;c&&c!==n&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,a,n,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Qd(e.url()))return[new Te("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:a,debugMode:!1,interactiveClassNames:n,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,h=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:b});u.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),E=await cr(x);h=E.pixels;let A=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:h,elementData:p.elementData};d=await e.evaluate(({code:L,argsObj:D})=>new Function("return "+L)()(D),{code:this.jsCode,argsObj:M}),d.map=p.map,d.rootId=p.rootId,d.highlightCount=p.highlightCount,d.perfMetrics=p.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){u.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),h=null;let p={...c,grayscaleImage:null};d=await e.evaluate(({code:x,argsObj:S})=>new Function("return "+x)()(S),{code:this.jsCode,argsObj:p}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:p})=>new Function("return "+b)()(p),{code:this.jsCode,argsObj:c}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw u.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw u.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw u.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&d.highlightCount===0){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:p,argsObj:x})=>new Function("return "+p)()(x),{code:this.jsCode,argsObj:b})}let m=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[b,p]of m){let x=p;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let b of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let f=[];for(let[b,p]of Object.entries(d.map)){let x=p;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&f.push({nodeId:b,src:x.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){u.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let p of Object.values(d.map)){let x=p;x.highlightIndex!=null&&(b=Math.max(b,x.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let p=0;p<f.length;p++){let{nodeId:x,src:S}=f[p];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let E=D=>{try{let C=new URL(D);if(C.protocol==="chrome-extension:"&&C.hostname)return`chrome-extension://${C.hostname}`;let V=C.origin;return V==="null"?null:V}catch{return null}},A=E(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,L=e.frames().find(D=>{let C=D.url();if(C===S)return M="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${C}`),!0;let V=E(C);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${C} origin=${V??"null"} vs srcOrigin=${A??"null"}`),A&&V===A?(M="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${C}`),!0):!1});if(!L){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(D=>D.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${L.url()})`);try{let D={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${D.initialHighlightIndex}`);let C=await L.evaluate(({code:z,argsObj:Y})=>new Function("return "+z)()(Y),{code:this.jsCode,argsObj:D});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(C?.map??{}).length} rootId=${C?.rootId}`),!C?.map||!C.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(C.map).filter(z=>z.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${V.length}`);for(let z of V){let Y=z;u.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let z of Object.values(C.map)){let Y=z;Y.highlightIndex!=null&&(b=Math.max(b,Y.highlightIndex))}let ee=`ext_${p}_`;for(let[z,Y]of Object.entries(C.map)){let ye={...Y};ye.children&&(ye.children=ye.children.map(Re=>`${ee}${Re}`)),d.map[`${ee}${z}`]=ye}let be=d.map[x];be?(be.children=[...be.children||[],`${ee}${C.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(D){u.warn(`Failed to process fallback iframe ${S}:`,D)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(d.map)for(let S of Object.values(d.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${p}/${b}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(d);return u.debug("\u2705 TypeScript DOM tree construction completed"),y}async constructDomTree(e){let t=e.map,i=e.rootId,a=new Map,n=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[c,d]=this.parseNode(l);c!==null&&(n.set(s,c),o.set(s,d),c instanceof Te&&c.highlightIndex!==null&&a.set(c.highlightIndex,c))}for(let[s,l]of o){let c=n.get(s);if(c instanceof Te)for(let d of l){let h=n.get(d);h&&(h.parent=c,c.children.push(h))}}let r=n.get(i);if(!r||!(r instanceof Te))throw new Error("Failed to parse HTML to dictionary");return[r,a]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new At(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],a=new Te(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),n=e.children||[];return[a,n]}}});import{z as eu}from"zod";var mr,Ab,zi=v(()=>{"use strict";mr=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Ab=eu.object({})});var gr,Vi=v(()=>{"use strict";F();I();gr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(n,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Le(e);if(!t){let n=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(n)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",a=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]}}});import*as tu from"playwright/test";import{default as iu}from"playwright/test";var Qe,$t=v(()=>{"use strict";pe();Qe={};Ai(Qe,{default:()=>iu});Io(Qe,tu)});import{z as fr}from"zod";var wr,Fb,Xi=v(()=>{"use strict";$t();wr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
4086
4086
  return (async () => {
4087
4087
  ${n}
4088
4088
  })();
4089
4089
  `)(e,Qe.expect,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],a=t.split(`
4090
- `);for(let n of a)i.push(` ${n}`);return i.push("}"),i}},Db=gr.object({code:gr.string().describe("JavaScript code to execute in the browser context")})});var wr,Yi=v(()=>{"use strict";F();I();wr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var br,Ji=v(()=>{"use strict";br=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.generateFunctionCallCode(a.kwargs);if(!n)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4090
+ `);for(let n of a)i.push(` ${n}`);return i.push("}"),i}},Fb=fr.object({code:fr.string().describe("JavaScript code to execute in the browser context")})});var br,Yi=v(()=>{"use strict";F();I();br=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var yr,Ji=v(()=>{"use strict";yr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.generateFunctionCallCode(a.kwargs);if(!n)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4091
4091
  return (async () => {
4092
4092
  ${n}
4093
4093
  })();
4094
- `)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let a=["page","testContext","request","agent"],n=["undefined","null","true","false"],o=i.map(r=>a.includes(r)||n.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var yr,qi=v(()=>{"use strict";yr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4094
+ `)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let a=["page","testContext","request","agent"],n=["undefined","null","true","false"],o=i.map(r=>a.includes(r)||n.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var xr,qi=v(()=>{"use strict";xr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.code;if(!n)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4095
4095
  return (async () => {
4096
4096
  ${n}
4097
4097
  })();
4098
4098
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4099
- `):["// Skipping js_action: missing code"]}}});var xr,Zi=v(()=>{"use strict";F();I();xr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var vr,Qi=v(()=>{"use strict";F();I();vr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.dblclick(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var _r,en=v(()=>{"use strict";F();I();_r=class{async execute(e,t,i){let a=i.getActionSettings().drag_drop_steps??10,n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await l).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,h=c.y+o.relative_y+c.height/2,p=d+o.delta_x,g=h+o.delta_y;await e.mouse.move(d,h),await e.mouse.down(),a>0?await e.mouse.move(p,g,{steps:a}):await e.mouse.move(p,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,c]=r,[d,h]=s;await e.mouse.move(l,c),await e.mouse.down(),a>0?await e.mouse.move(d,h,{steps:a}):await e.mouse.move(d,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return typeof t.relative_x=="number"&&(a.relative_x=t.relative_x),typeof t.relative_y=="number"&&(a.relative_y=t.relative_y),typeof t.delta_x=="number"&&(a.delta_x=t.delta_x),typeof t.delta_y=="number"&&(a.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(a.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(a.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(a.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(a.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(n=>` ${n},`),"});"]}}});var tn=v(()=>{"use strict";Ze()});var kr,et=v(()=>{"use strict";kr=(e=>(e[e.DEBUG=0]="DEBUG",e[e.INFO=1]="INFO",e[e.WARN=2]="WARN",e[e.ERROR=3]="ERROR",e[e.SILENT=4]="SILENT",e))(kr||{})});var tt={};ut(tt,{evaluateStatement:()=>at,executeAction:()=>Mt,executeStep:()=>nt,generateActionStep:()=>It,runTask:()=>ot});var it=v(()=>{"use strict";Pt();ji();Bi();Ei();qe();Oi();Ni();Ve();Li();Fi();vt();_t();Ee();gt();xt();tn();Ue();kt();St();Ze();Et();Tt();ie();Se();bt();Xe();yt();Ne();j();We();R();te();et();F();me()});import{z as Sr}from"zod";var Er,Wy,nn=v(()=>{"use strict";Er=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_action");let o=a.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(it(),tt)),s=await r(n,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]}},Wy=Sr.object({statement:Sr.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Tr}from"zod";var Ar,jy,an=v(()=>{"use strict";Ar=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(it(),tt)),r=await o(n,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},jy=Tr.object({statement:Tr.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as $r}from"zod";function Ir(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:tu,async execute(i,a){let{timeout_seconds:n=10}=i,{page:o,agentServices:r}=a;try{let s={action_description:`Wait for download to complete (timeout: ${n}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}},feedback:s.message}}}}})}var Mr,tu,Ct=v(()=>{"use strict";Mr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,n)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},tu=$r.object({timeout_seconds:$r.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as la}from"zod";function Cr(e,t){e.register({name:"ai_wait_until",description:'Wait until a specific condition is met on the page (e.g., "page loads", "spinner disappears", "button becomes enabled"). Use this instead of wait when the goal is to wait for something to happen rather than waiting a fixed duration.',schema:iu,async execute(i,a){let{condition:n,timeout_seconds:o=60}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Wait until: ${n}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${n} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}},feedback:l.message}}}}})}var Pr,iu,Ot=v(()=>{"use strict";Pr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.condition;if(!n)throw new Error("Missing condition for ai_wait_until");let o=(a.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(it(),tt));for(;Date.now()-s<o;){if((await l(n,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${n}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},iu=la.object({condition:la.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:la.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Lt}from"zod";async function nu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Or(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Nr(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:au,usesElementIndex:!0,async execute(i,a){let{element_index:n,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Element with index ${n} not found`,actionEntity:Or(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})};let d=await nu("scroll_on_element",`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${n} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Or(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})}}}})}var Lr,au,Nt=v(()=>{"use strict";j();F();I();Lr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.delta_x||0,o=a.kwargs.delta_y||0,r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(n,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(e);if(!t){let n=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${n}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${a});`]}};au=Lt.object({element_index:Lt.number().int().describe("Index of the scrollable element"),delta_x:Lt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Lt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Lt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Dr}from"zod";function Fr(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:ou,async execute(i,a){let{text:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Scroll to text "${n}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${n}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:n}},feedback:l.message}}}}})}var Rr,ou,Dt=v(()=>{"use strict";Rr=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.text;if(a)await e.getByText(a,{exact:!1}).first().scrollIntoViewIfNeeded(),await e.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(e){let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},ou=Dr.object({text:Dr.string().describe("Text to scroll to on the page")})});import{z as on}from"zod";async function ru(e,t,i,a){return{...await N(t,e),action_description:a||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Hr(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"select_dropdown_option",kwargs:t},feedback:"Element not found in DOM"}}function Ur(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:su,usesElementIndex:!0,async execute(i,a){let{element_index:n,option:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:Hr(l||`Select option in dropdown ${n}`,{index:n,option:o})};let d=await ru(c,r,o,l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:Hr(`Select option in dropdown ${n}`,{index:n,option:o})}}}})}var Wr,su,Rt=v(()=>{"use strict";j();F();I();Wr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text||a.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&n)await o.selectOption(n,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(a=>` ${a},`),"});"]}};su=on.object({element_index:on.number().int().describe("Index of the dropdown/select element"),option:on.string().describe("Option value, label, or index to select"),timeout_ms:on.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as rn}from"zod";async function lu(e,t,i,a){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:a}}}}function ca(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"set_date_for_native_date_picker",kwargs:t},feedback:"Element not found in DOM"}}function Gr(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4099
+ `):["// Skipping js_action: missing code"]}}});var vr,Zi=v(()=>{"use strict";F();I();vr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.move(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var _r,Qi=v(()=>{"use strict";F();I();_r=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");if(typeof a.kwargs.relative_x=="number"&&typeof a.kwargs.relative_y=="number"){let n=O(e,t);if(n){await n.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await n.boundingBox();if(o){let r=o.x+a.kwargs.relative_x+o.width/2,s=o.y+a.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof a.kwargs.x=="number"&&typeof a.kwargs.y=="number")await e.mouse.dblclick(a.kwargs.x,a.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(a=>` ${a},`),"});"]}}});var kr,en=v(()=>{"use strict";F();I();kr=class{async execute(e,t,i){let a=i.getActionSettings().drag_drop_steps??10,n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await l).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,h=c.y+o.relative_y+c.height/2,m=d+o.delta_x,g=h+o.delta_y;await e.mouse.move(d,h),await e.mouse.down(),a>0?await e.mouse.move(m,g,{steps:a}):await e.mouse.move(m,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,c]=r,[d,h]=s;await e.mouse.move(l,c),await e.mouse.down(),a>0?await e.mouse.move(d,h,{steps:a}):await e.mouse.move(d,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return typeof t.relative_x=="number"&&(a.relative_x=t.relative_x),typeof t.relative_y=="number"&&(a.relative_y=t.relative_y),typeof t.delta_x=="number"&&(a.delta_x=t.delta_x),typeof t.delta_y=="number"&&(a.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(a.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(a.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(a.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(a.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(n=>` ${n},`),"});"]}}});var tn=v(()=>{"use strict";Ze()});var Sr,et=v(()=>{"use strict";Sr=(e=>(e[e.DEBUG=0]="DEBUG",e[e.INFO=1]="INFO",e[e.WARN=2]="WARN",e[e.ERROR=3]="ERROR",e[e.SILENT=4]="SILENT",e))(Sr||{})});var tt={};ut(tt,{evaluateStatement:()=>at,executeAction:()=>Mt,executeStep:()=>nt,generateActionStep:()=>It,runTask:()=>ot});var it=v(()=>{"use strict";Pt();ji();Bi();Ei();qe();Oi();Ni();Ve();Li();Fi();vt();_t();Ee();gt();xt();tn();Ue();kt();St();Ze();Et();Tt();ie();Se();bt();Xe();yt();Ne();j();We();R();te();et();F();pe()});import{z as Er}from"zod";var Tr,By,nn=v(()=>{"use strict";Tr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_action");let o=a.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(it(),tt)),s=await r(n,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]}},By=Er.object({statement:Er.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Ar}from"zod";var $r,zy,an=v(()=>{"use strict";$r=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.statement;if(!n)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(it(),tt)),r=await o(n,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},zy=Ar.object({statement:Ar.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Mr}from"zod";function Pr(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:nu,async execute(i,a){let{timeout_seconds:n=10}=i,{page:o,agentServices:r}=a;try{let s={action_description:`Wait for download to complete (timeout: ${n}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:n}},feedback:s.message}}}}})}var Ir,nu,Ct=v(()=>{"use strict";Ir=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,n)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},nu=Mr.object({timeout_seconds:Mr.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as ca}from"zod";function Or(e,t){e.register({name:"ai_wait_until",description:'Wait until a specific condition is met on the page (e.g., "page loads", "spinner disappears", "button becomes enabled"). Use this instead of wait when the goal is to wait for something to happen rather than waiting a fixed duration.',schema:au,async execute(i,a){let{condition:n,timeout_seconds:o=60}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Wait until: ${n}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${n} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:n,timeout_seconds:o}},feedback:l.message}}}}})}var Cr,au,Ot=v(()=>{"use strict";Cr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.condition;if(!n)throw new Error("Missing condition for ai_wait_until");let o=(a.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(it(),tt));for(;Date.now()-s<o;){if((await l(n,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${n}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},au=ca.object({condition:ca.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:ca.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Lt}from"zod";async function ou(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Lr(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Dr(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:ru,usesElementIndex:!0,async execute(i,a){let{element_index:n,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Element with index ${n} not found`,actionEntity:Lr(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})};let d=await ou("scroll_on_element",`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,c,s,{delta_x:o,delta_y:r});return await t.execute(s,d,l),{success:!0,actionEntity:d,message:`Scrolled on element ${n} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Lr(`Scroll on element ${n} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:n,delta_x:o,delta_y:r})}}}})}var Nr,ru,Nt=v(()=>{"use strict";j();F();I();Nr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.delta_x||0,o=a.kwargs.delta_y||0,r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(n,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(e);if(!t){let n=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${n}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${a});`]}};ru=Lt.object({element_index:Lt.number().int().describe("Index of the scrollable element"),delta_x:Lt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Lt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Lt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Rr}from"zod";function Hr(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:su,async execute(i,a){let{text:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Scroll to text "${n}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${n}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:n}},feedback:l.message}}}}})}var Fr,su,Dt=v(()=>{"use strict";Fr=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.text;if(a)await e.getByText(a,{exact:!1}).first().scrollIntoViewIfNeeded(),await e.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(e){let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},su=Rr.object({text:Rr.string().describe("Text to scroll to on the page")})});import{z as on}from"zod";async function lu(e,t,i,a){return{...await N(t,e),action_description:a||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Wr(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"select_dropdown_option",kwargs:t},feedback:"Element not found in DOM"}}function Br(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:cu,usesElementIndex:!0,async execute(i,a){let{element_index:n,option:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:Wr(l||`Select option in dropdown ${n}`,{index:n,option:o})};let d=await lu(c,r,o,l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:Wr(`Select option in dropdown ${n}`,{index:n,option:o})}}}})}var Ur,cu,Rt=v(()=>{"use strict";j();F();I();Ur=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text||a.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&n)await o.selectOption(n,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(a=>` ${a},`),"});"]}};cu=on.object({element_index:on.number().int().describe("Index of the dropdown/select element"),option:on.string().describe("Option value, label, or index to select"),timeout_ms:on.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as rn}from"zod";async function du(e,t,i,a){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:a}}}}function da(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"set_date_for_native_date_picker",kwargs:t},feedback:"Element not found in DOM"}}function jr(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4100
4100
 
4101
4101
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4102
4102
  Do NOT use it for custom/non-native date pickers
4103
4103
 
4104
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:cu,usesElementIndex:!0,async execute(i,a){let{element_index:n,date:o}=i,{page:r,agentServices:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Date picker element with index ${n} not found`,actionEntity:ca(`Set date to ${o} on element ${n}`,{index:n,date:o})};let c=l.attributes.type;if(c!=="date")return{success:!1,error:`Element ${n} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:ca(`Set date to ${o} on element ${n}`,{index:n,date:o})};let d=await lu(`Set date to ${o} on element ${n}`,l,r,o);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:ca(`Set date to ${o} on element ${n}`,{index:n,date:o})}}}})}var Br,cu,Ft=v(()=>{"use strict";j();F();I();Br=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.date;if(!n)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(n))throw new Error(`Invalid date format: ${n}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(n)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(a=>` ${a},`),"});"]}};cu=rn.object({element_index:rn.number().int().describe("Index of the native date picker input element"),date:rn.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:rn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as jr}from"zod";function zr(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:du,async execute(i,a){let n=i.tab_index,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Switch to tab ${n}`,action_data:{action_name:"switch_tab",kwargs:{page_id:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${n}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:n}},feedback:l.message}}}}})}var Kr,du,Ht=v(()=>{"use strict";Kr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.page_id??a.kwargs.tab_index??0;if(typeof n=="number"){let o=e.context().pages(),r=n===-1?o.length-1:n;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},du=jr.object({tab_index:jr.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import uu from"fs";import hu from"path";async function Vr(e,t,i,a,n,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(d=>{if(d.startsWith("/")||d.match(/^[A-Za-z]:\\/))return d;let h=a.testDataDir||process.cwd();return hu.join(h,d)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,c={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let d=i.selector;await sn(e,d,s,c);return}if(i.selector&&typeof i.selector=="string"){let d=i.selector,h=(d.startsWith("xpath="),e.locator(d));await sn(e,h,s,c);return}if(n){let d=r.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${d} to ${i.targetDescription}`:h=`Upload ${d}`,u.info(`Using AI to handle file upload: ${h}`),await n(e,h,o)}else throw new Error("No selector provided and AI action execution is not available")}async function sn(e,t,i,a){let{useFileInput:n,timeout:o,mockShowOpenFilePicker:r}=a;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(uu.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(n)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Wt=v(()=>{"use strict";R()});import{z as De}from"zod";async function mu(e,t,i={},a){return{...await N(t,e),action_description:a||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Xr(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"upload_file",kwargs:t},feedback:"Element not found in DOM"}}function Jr(e,t){e.register({name:"upload_file",description:'Click on target element (usually contains hints like "Upload file" or "Choose file" etc.) to trigger the file upload dialog, and choose the files to upload',schema:pu,usesElementIndex:!0,async execute(i,a){let{element_index:n,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`File input element with index ${n} not found`,actionEntity:Xr(l||`Upload file to element ${n}`,{index:n,paths:o})};let d=await mu(c,r,{paths:o},l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Uploaded file to element ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:Xr(l||`Upload file to element ${n}`,{index:n,paths:o})}}}})}var Yr,pu,$x,Ut=v(()=>{"use strict";Wt();j();F();I();Yr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=[];if(a.kwargs.paths?n=Array.isArray(a.kwargs.paths)?a.kwargs.paths:[a.kwargs.paths]:a.kwargs.path&&(n=Array.isArray(a.kwargs.path)?a.kwargs.path:[a.kwargs.path]),n.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(n);let o=n.map(c=>i.getTestDataFilePath(c)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=a.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await sn(e,r,o,{useFileInput:s,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return t.paths?a.paths=t.paths:t.path&&(a.path=t.path),t.use_file_input&&(a.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(n=>` ${n},`),"});"]}};pu=De.object({element_index:De.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:De.string().describe("Paths to the files to upload"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});$x=De.object({element_index:De.number().int().describe("Index of the file input element"),paths:De.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as qr}from"zod";function Qr(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:gu,async execute(i,a){let{seconds:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Wait ${n} seconds`,action_data:{action_name:"wait",kwargs:{seconds:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${n} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${n} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:n}},feedback:l.message}}}}})}var Zr,gu,Bt=v(()=>{"use strict";Zr=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.seconds||1;await e.waitForTimeout(a*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},gu=qr.object({seconds:qr.number().positive().describe("Number of seconds to wait")})});import{z as es}from"zod";function ts(e,t){e.register({name:"press",description:"Press a single keyboard key or key combination. Supports combinations like `Control+A` for select all. Does NOT support sequences - call this action multiple times to press keys in sequence.",schema:fu,async execute(i,a){let{keys:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Press keys "${n}"`,action_data:{action_name:"press",kwargs:{keys:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${n}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:n}},feedback:l.message}}}}})}var da,fu,Gt=v(()=>{"use strict";da=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(a),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},fu=es.object({keys:es.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as wu}from"zod";function ns(e,t){e.register({name:"reload_page",description:"Reload the current page. WARNING: This will reset any in-progress forms or multi-step flows (like login). Only use when you need to refresh stale data or clear a stuck state. Do NOT use during login, checkout, or form submission flows.",schema:bu,async execute(i,a){let{page:n,agentServices:o}=a;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(n,r,o),{success:!0,actionEntity:r,message:`Reloaded ${n.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var is,bu,jt=v(()=>{"use strict";F();I();is=class{async execute(e,t){await e.reload({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},bu=wu.object({})});import{z as ua}from"zod";async function yu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function as(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function os(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:xu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:as(`Right-click element ${n}`,"right_click",{index:n})};let c=s||`Right-click element ${n}`,d=await yu("right_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:as(`Right-click element ${n}`,"right_click",{index:n})}}}})}var ha,xu,Kt=v(()=>{"use strict";j();F();I();ha=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({button:"right",timeout:n});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};xu=ua.object({element_index:ua.number().int().describe("Index of the element to right-click"),timeout_ms:ua.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ma}from"zod";function ss(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:vu,async execute(i,a){let{name:n,value:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Save variable "${n}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:n,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${n}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:n,value:o}},feedback:l.message}}}}})}var rs,vu,zt=v(()=>{"use strict";rs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.name,o=a.kwargs.value;if(!n||o===void 0)throw new Error("Missing variable name or value for save_variable");n.startsWith("$")&&(n=n.slice(1)),i.saveVariable(n,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},vu=ma.object({name:ma.string().describe("Variable name to save"),value:ma.string().describe("Value to save in the variable")})});import{z as pa}from"zod";async function _u(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function ku(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function ls(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:Su,async execute(i,a){let{down:n,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=l||`Scroll ${n?"down":"up"} ${o} page(s)`,d=await _u("scroll",c,{down:n,num_pages:o});return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Scrolled ${n?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:ku(l||`Scroll ${n?"down":"up"} ${o} page(s)`,"scroll",{down:n,num_pages:o})}}}})}var Vt,Su,Xt=v(()=>{"use strict";Vt=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.down??!0,n=i.kwargs.num_pages??1,o=a?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${n} * ${o})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Su=pa.object({down:pa.boolean().describe("True to scroll down, False to scroll up"),num_pages:pa.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as cs}from"zod";function us(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:Eu,async execute(i,a){let{otp_secret_key:n}=i,{page:o,agentServices:r}=a;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:n}},feedback:s.message}}}}})}var ds,Eu,Yt=v(()=>{"use strict";ds=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.otp_secret_key;if(!n)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(n)),r=await i.generate2faCode(o);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Eu=cs.object({otp_secret_key:cs.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as hs}from"zod";async function Tu(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function ms(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:t},feedback:"Element not found in DOM"}}function gs(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Au,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:ms(s||`Get options from dropdown ${n}`,{index:n})};let c=await Tu(l,o,s);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:ms(s||`Get options from dropdown ${n}`,{index:n})}}}})}var ps,Au,Jt=v(()=>{"use strict";j();ps=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let a=[];for(let n of e.frames())try{let o=await n.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}a.push(...r)}}catch{}if(a.length>0){let n=a.join(`
4104
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:uu,usesElementIndex:!0,async execute(i,a){let{element_index:n,date:o}=i,{page:r,agentServices:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Date picker element with index ${n} not found`,actionEntity:da(`Set date to ${o} on element ${n}`,{index:n,date:o})};let c=l.attributes.type;if(c!=="date")return{success:!1,error:`Element ${n} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:da(`Set date to ${o} on element ${n}`,{index:n,date:o})};let d=await du(`Set date to ${o} on element ${n}`,l,r,o);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:da(`Set date to ${o} on element ${n}`,{index:n,date:o})}}}})}var Gr,uu,Ft=v(()=>{"use strict";j();F();I();Gr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.date;if(!n)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(n))throw new Error(`Invalid date format: ${n}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(n)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(a=>` ${a},`),"});"]}};uu=rn.object({element_index:rn.number().int().describe("Index of the native date picker input element"),date:rn.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:rn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Kr}from"zod";function Vr(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:hu,async execute(i,a){let n=i.tab_index,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Switch to tab ${n}`,action_data:{action_name:"switch_tab",kwargs:{page_id:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${n}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:n}},feedback:l.message}}}}})}var zr,hu,Ht=v(()=>{"use strict";zr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.page_id??a.kwargs.tab_index??0;if(typeof n=="number"){let o=e.context().pages(),r=n===-1?o.length-1:n;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},hu=Kr.object({tab_index:Kr.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import pu from"fs";import mu from"path";async function Xr(e,t,i,a,n,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(d=>{if(d.startsWith("/")||d.match(/^[A-Za-z]:\\/))return d;let h=a.testDataDir||process.cwd();return mu.join(h,d)});u.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,c={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let d=i.selector;await sn(e,d,s,c);return}if(i.selector&&typeof i.selector=="string"){let d=i.selector,h=(d.startsWith("xpath="),e.locator(d));await sn(e,h,s,c);return}if(n){let d=r.map(m=>`"${m}"`).join(", "),h="";i.targetDescription?h=`Upload ${d} to ${i.targetDescription}`:h=`Upload ${d}`,u.info(`Using AI to handle file upload: ${h}`),await n(e,h,o)}else throw new Error("No selector provided and AI action execution is not available")}async function sn(e,t,i,a){let{useFileInput:n,timeout:o,mockShowOpenFilePicker:r}=a;if(r){u.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(pu.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(n)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Wt=v(()=>{"use strict";R()});import{z as De}from"zod";async function gu(e,t,i={},a){return{...await N(t,e),action_description:a||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Yr(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"upload_file",kwargs:t},feedback:"Element not found in DOM"}}function qr(e,t){e.register({name:"upload_file",description:'Click on target element (usually contains hints like "Upload file" or "Choose file" etc.) to trigger the file upload dialog, and choose the files to upload',schema:fu,usesElementIndex:!0,async execute(i,a){let{element_index:n,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`File input element with index ${n} not found`,actionEntity:Yr(l||`Upload file to element ${n}`,{index:n,paths:o})};let d=await gu(c,r,{paths:o},l);return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Uploaded file to element ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:Yr(l||`Upload file to element ${n}`,{index:n,paths:o})}}}})}var Jr,fu,Ix,Ut=v(()=>{"use strict";Wt();j();F();I();Jr=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=[];if(a.kwargs.paths?n=Array.isArray(a.kwargs.paths)?a.kwargs.paths:[a.kwargs.paths]:a.kwargs.path&&(n=Array.isArray(a.kwargs.path)?a.kwargs.path:[a.kwargs.path]),n.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(n);let o=n.map(c=>i.getTestDataFilePath(c)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=a.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await sn(e,r,o,{useFileInput:s,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],a={};return t.paths?a.paths=t.paths:t.path&&(a.path=t.path),t.use_file_input&&(a.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(n=>` ${n},`),"});"]}};fu=De.object({element_index:De.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:De.string().describe("Paths to the files to upload"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Ix=De.object({element_index:De.number().int().describe("Index of the file input element"),paths:De.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Zr}from"zod";function es(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:wu,async execute(i,a){let{seconds:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Wait ${n} seconds`,action_data:{action_name:"wait",kwargs:{seconds:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${n} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${n} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:n}},feedback:l.message}}}}})}var Qr,wu,Bt=v(()=>{"use strict";Qr=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.seconds||1;await e.waitForTimeout(a*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},wu=Zr.object({seconds:Zr.number().positive().describe("Number of seconds to wait")})});import{z as ts}from"zod";function is(e,t){e.register({name:"press",description:"Press a single keyboard key or key combination. Supports combinations like `Control+A` for select all. Does NOT support sequences - call this action multiple times to press keys in sequence.",schema:bu,async execute(i,a){let{keys:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Press keys "${n}"`,action_data:{action_name:"press",kwargs:{keys:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${n}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:n}},feedback:l.message}}}}})}var ua,bu,Gt=v(()=>{"use strict";ua=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(a),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},bu=ts.object({keys:ts.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as yu}from"zod";function as(e,t){e.register({name:"reload_page",description:"Reload the current page. WARNING: This will reset any in-progress forms or multi-step flows (like login). Only use when you need to refresh stale data or clear a stuck state. Do NOT use during login, checkout, or form submission flows.",schema:xu,async execute(i,a){let{page:n,agentServices:o}=a;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(n,r,o),{success:!0,actionEntity:r,message:`Reloaded ${n.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var ns,xu,jt=v(()=>{"use strict";F();I();ns=class{async execute(e,t){await e.reload({timeout:me}),await e.waitForLoadState("load",{timeout:me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},xu=yu.object({})});import{z as ha}from"zod";async function vu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function os(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function rs(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:_u,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:os(`Right-click element ${n}`,"right_click",{index:n})};let c=s||`Right-click element ${n}`,d=await vu("right_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:os(`Right-click element ${n}`,"right_click",{index:n})}}}})}var pa,_u,Kt=v(()=>{"use strict";j();F();I();pa=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({button:"right",timeout:n});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};_u=ha.object({element_index:ha.number().int().describe("Index of the element to right-click"),timeout_ms:ha.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ma}from"zod";function ls(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:ku,async execute(i,a){let{name:n,value:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Save variable "${n}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:n,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${n}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${n}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:n,value:o}},feedback:l.message}}}}})}var ss,ku,zt=v(()=>{"use strict";ss=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.name,o=a.kwargs.value;if(!n||o===void 0)throw new Error("Missing variable name or value for save_variable");n.startsWith("$")&&(n=n.slice(1)),i.saveVariable(n,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},ku=ma.object({name:ma.string().describe("Variable name to save"),value:ma.string().describe("Value to save in the variable")})});import{z as ga}from"zod";async function Su(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Eu(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function cs(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:Tu,async execute(i,a){let{down:n,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=l||`Scroll ${n?"down":"up"} ${o} page(s)`,d=await Su("scroll",c,{down:n,num_pages:o});return await t.execute(r,d,s),{success:!0,actionEntity:d,message:`Scrolled ${n?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:Eu(l||`Scroll ${n?"down":"up"} ${o} page(s)`,"scroll",{down:n,num_pages:o})}}}})}var Vt,Tu,Xt=v(()=>{"use strict";Vt=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let a=i.kwargs.down??!0,n=i.kwargs.num_pages??1,o=a?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${n} * ${o})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Tu=ga.object({down:ga.boolean().describe("True to scroll down, False to scroll up"),num_pages:ga.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as ds}from"zod";function hs(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:Au,async execute(i,a){let{otp_secret_key:n}=i,{page:o,agentServices:r}=a;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:n}},feedback:s.message}}}}})}var us,Au,Yt=v(()=>{"use strict";us=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.otp_secret_key;if(!n)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(n)),r=await i.generate2faCode(o);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Au=ds.object({otp_secret_key:ds.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as ps}from"zod";async function $u(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function ms(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:t},feedback:"Element not found in DOM"}}function fs(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Mu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Dropdown element with index ${n} not found`,actionEntity:ms(s||`Get options from dropdown ${n}`,{index:n})};let c=await $u(l,o,s);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:ms(s||`Get options from dropdown ${n}`,{index:n})}}}})}var gs,Mu,Jt=v(()=>{"use strict";j();gs=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let a=[];for(let n of e.frames())try{let o=await n.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}a.push(...r)}}catch{}if(a.length>0){let n=a.join(`
4105
4105
  `);n+=`
4106
- Use the exact text string in select_dropdown_option`,i.addNote(n)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Au=hs.object({element_index:hs.number().int().describe("Index of the dropdown/select element")})});import{z as $u}from"zod";function ws(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Mu,async execute(i,a){let{page:n,agentServices:o,actionDescription:r}=a;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(n,s,o),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var fs,Mu,qt=v(()=>{"use strict";F();I();fs=class{async execute(e,t){await e.goBack({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Mu=$u.object({})});import{z as ln}from"zod";function bs(e,t){e.register({name:"go_to_url",description:"Navigate to a specific URL. Use this to visit web pages. Set new_tab=true to open in a new tab.",schema:Iu,async execute(i,a){let{url:n,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:c}=a,d={url:n,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${n} in new tab`:`Navigate to ${n}`,g={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${n} in new tab`:`Navigated to ${n}`)+h}}catch(p){let g=o?`Open ${n} in new tab`:`Navigate to ${n}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var ga,Iu,Zt=v(()=>{"use strict";F();I();ga=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.url;if(!n)throw new Error("Missing URL for go_to_url action");let o=a.kwargs.new_tab===!0,r=i.replaceVariables(String(n));if(r.startsWith("/")){let c=e.url(),d=null;try{let h=new URL(c);h.origin&&h.origin!=="null"&&(d=h.origin)}catch{}d&&(r=d+r)}let s=a.kwargs.timeout_seconds?a.kwargs.timeout_seconds*1e3:pe,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,a=e.action_data?.kwargs?.timeout_seconds,n=[`url: ${JSON.stringify(t)}`];return i&&n.push("new_tab: true"),a&&n.push(`timeout_seconds: ${a}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${n.join(", ")} } },`,"});"]}},Iu=ln.object({url:ln.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:ln.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:ln.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as fa}from"zod";async function Pu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function ys(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function xs(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Cu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:ys(`Hover element ${n}`,"hover",{index:n})};let c=s||`Hover over element ${n}`,d=await Pu("hover",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:ys(`Hover element ${n}`,"hover",{index:n})}}}})}var wa,Cu,Qt=v(()=>{"use strict";j();F();I();wa=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a){await a.waitFor({state:"attached",timeout:n});let o=await a.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};Cu=fa.object({element_index:fa.number().int().describe("Index of the element to hover over"),timeout_ms:fa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as cn}from"zod";async function Ou(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function vs(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function _s(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Lu,usesElementIndex:!0,async execute(i,a){let{element_index:n,text:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Input element with index ${n} not found`,actionEntity:vs(l||`Input text to element ${n}`,"input_text",{index:n,text:o})};let d=l||`Input text to element ${n}`,h=await Ou("input_text",d,c,r,{text:o});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:vs(`Input text to element ${n}`,"input_text",{index:n,text:o})}}}})}var ba,Lu,ei=v(()=>{"use strict";j();F();I();ba=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text??a.kwargs.value??"",o=i.replaceVariables(String(n)),r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(o,{delay:l}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(a=>` ${a},`),"});"]}};Lu=cn.object({element_index:cn.number().int().describe("Index of the input element"),text:cn.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:cn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ya}from"zod";async function Nu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function ks(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Es(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Du,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Input element with index ${n} not found`,actionEntity:ks(s||`Clear element ${n}`,"clear_input",{index:n})};let c=s||`Clear element ${n}`,d=await Nu("clear_input",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:ks(`Clear element ${n}`,"clear_input",{index:n})}}}})}var Ss,Du,ti=v(()=>{"use strict";j();F();I();Ss=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({timeout:n}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};Du=ya.object({element_index:ya.number().int().describe("Index of the input element to clear"),timeout_ms:ya.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as xa}from"zod";async function Ru(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Ts(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function As(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Fu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:Ts(`Click element ${n}`,"click",{index:n})};let c=s||`Click element ${n}`,d=await Ru("click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ts(`Click element ${n}`,"click",{index:n})}}}})}var dn,Fu,ii=v(()=>{"use strict";j();F();I();dn=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({timeout:n});else throw new Error("No locator found for click action")}transpile(e){let t=Le(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Fu=xa.object({element_index:xa.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:xa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as $s}from"zod";function Is(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Hu,async execute(i,a){let{index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Close tab ${n}`,action_data:{action_name:"close_tab",kwargs:{page_id:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Ms,Hu,ni=v(()=>{"use strict";Ms=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.page_id??a.kwargs.index;if(n===void 0&&(n=e.context().pages().indexOf(e)),typeof n=="number"){if(n===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(n)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Hu=$s.object({index:$s.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as va}from"zod";function Cs(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Wu,async execute(i,a){let{page:n,agentServices:o}=a;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(n,r,o),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var Ps,Wu,ai=v(()=>{"use strict";Ps=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Wu=va.object({success:va.boolean().describe("Whether the task was completed successfully"),summary:va.string().describe("Summary of what was accomplished or why it failed")})});import{z as _a}from"zod";async function Uu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Os(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ls(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Bu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:Os(`Double-click element ${n}`,"double_click",{index:n})};let c=s||`Double-click element ${n}`,d=await Uu("double_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:Os(`Double-click element ${n}`,"double_click",{index:n})}}}})}var ka,Bu,oi=v(()=>{"use strict";j();F();I();ka=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.dblclick({timeout:n});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};Bu=_a.object({element_index:_a.number().int().describe("Index of the element to double-click"),timeout_ms:_a.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as Gu}from"@babel/parser";function Ns(e){if(!e.trim())return!1;try{return Gu(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var un=v(()=>{"use strict"});import{z as Ds}from"zod";function Rs(e,t){e.register({name:"verify",description:"Verify that a statement is true based on the current page state. Use this to check assertions about the page content, element visibility, or any condition.",schema:ju,async execute(i,a){let{statement:n}=i,{page:o,agentServices:r}=a;try{let s={action_description:`${n}`,action_data:{action_name:"verify",kwargs:{statement:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${n}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${n} (failed)`,action_data:{action_name:"verify",kwargs:{statement:n}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var hn,ju,ri=v(()=>{"use strict";$t();un();R();hn=class{async execute(e,t,i){let a=t.action_data?.kwargs,n=typeof a?.code=="string",o=n?a?.statement||t.action_description:t.action_description||a?.statement;if(n&&o){let d=Date.now();try{await this.executeJSAssertion(e,a.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(h){let p=((Date.now()-d)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${o}`)}}else if(n){let d=Date.now();await this.executeJSAssertion(e,a.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),c=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}async executeJSAssertion(e,t,i){let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4106
+ Use the exact text string in select_dropdown_option`,i.addNote(n)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Mu=ps.object({element_index:ps.number().int().describe("Index of the dropdown/select element")})});import{z as Iu}from"zod";function bs(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Pu,async execute(i,a){let{page:n,agentServices:o,actionDescription:r}=a;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(n,s,o),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var ws,Pu,qt=v(()=>{"use strict";F();I();ws=class{async execute(e,t){await e.goBack({timeout:me}),await e.waitForLoadState("load",{timeout:me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Pu=Iu.object({})});import{z as ln}from"zod";function ys(e,t){e.register({name:"go_to_url",description:"Navigate to a specific URL. Use this to visit web pages. Set new_tab=true to open in a new tab.",schema:Cu,async execute(i,a){let{url:n,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:c}=a,d={url:n,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let h=r?` (timeout: ${r}s)`:"";try{let m=o?`Open ${n} in new tab`:`Navigate to ${n}`,g={action_description:c||m,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${n} in new tab`:`Navigated to ${n}`)+h}}catch(m){let g=o?`Open ${n} in new tab`:`Navigate to ${n}`;return{success:!1,error:m.message,actionEntity:{action_description:(c||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:m.message}}}}})}var fa,Cu,Zt=v(()=>{"use strict";F();I();fa=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.url;if(!n)throw new Error("Missing URL for go_to_url action");let o=a.kwargs.new_tab===!0,r=i.replaceVariables(String(n));if(r.startsWith("/")){let c=e.url(),d=null;try{let h=new URL(c);h.origin&&h.origin!=="null"&&(d=h.origin)}catch{}d&&(r=d+r)}let s=a.kwargs.timeout_seconds?a.kwargs.timeout_seconds*1e3:me,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,a=e.action_data?.kwargs?.timeout_seconds,n=[`url: ${JSON.stringify(t)}`];return i&&n.push("new_tab: true"),a&&n.push(`timeout_seconds: ${a}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${n.join(", ")} } },`,"});"]}},Cu=ln.object({url:ln.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:ln.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:ln.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as wa}from"zod";async function Ou(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function xs(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function vs(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Lu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:xs(`Hover element ${n}`,"hover",{index:n})};let c=s||`Hover over element ${n}`,d=await Ou("hover",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:xs(`Hover element ${n}`,"hover",{index:n})}}}})}var ba,Lu,Qt=v(()=>{"use strict";j();F();I();ba=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a){await a.waitFor({state:"attached",timeout:n});let o=await a.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};Lu=wa.object({element_index:wa.number().int().describe("Index of the element to hover over"),timeout_ms:wa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as cn}from"zod";async function Nu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function _s(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function ks(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Du,usesElementIndex:!0,async execute(i,a){let{element_index:n,text:o}=i,{page:r,agentServices:s,actionDescription:l}=a;try{let c=await W(a,n);if(!c)return{success:!1,error:`Input element with index ${n} not found`,actionEntity:_s(l||`Input text to element ${n}`,"input_text",{index:n,text:o})};let d=l||`Input text to element ${n}`,h=await Nu("input_text",d,c,r,{text:o});return await t.execute(r,h,s),{success:!0,actionEntity:h,message:`Input text to element ${n}`}}catch(c){return{success:!1,error:c.message,actionEntity:_s(`Input text to element ${n}`,"input_text",{index:n,text:o})}}}})}var ya,Du,ei=v(()=>{"use strict";j();F();I();ya=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.text??a.kwargs.value??"",o=i.replaceVariables(String(n)),r=O(e,t),s=P(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(o,{delay:l}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(a=>` ${a},`),"});"]}};Du=cn.object({element_index:cn.number().int().describe("Index of the input element"),text:cn.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:cn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as xa}from"zod";async function Ru(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Ss(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ts(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Fu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Input element with index ${n} not found`,actionEntity:Ss(s||`Clear element ${n}`,"clear_input",{index:n})};let c=s||`Clear element ${n}`,d=await Ru("clear_input",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ss(`Clear element ${n}`,"clear_input",{index:n})}}}})}var Es,Fu,ti=v(()=>{"use strict";j();F();I();Es=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({timeout:n}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};Fu=xa.object({element_index:xa.number().int().describe("Index of the input element to clear"),timeout_ms:xa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as va}from"zod";async function Hu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function As(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function $s(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Wu,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:As(`Click element ${n}`,"click",{index:n})};let c=s||`Click element ${n}`,d=await Hu("click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:As(`Click element ${n}`,"click",{index:n})}}}})}var dn,Wu,ii=v(()=>{"use strict";j();F();I();dn=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.click({timeout:n});else throw new Error("No locator found for click action")}transpile(e){let t=Le(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Wu=va.object({element_index:va.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:va.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Ms}from"zod";function Ps(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Uu,async execute(i,a){let{index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l={action_description:s||`Close tab ${n}`,action_data:{action_name:"close_tab",kwargs:{page_id:n}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Is,Uu,ni=v(()=>{"use strict";Is=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.page_id??a.kwargs.index;if(n===void 0&&(n=e.context().pages().indexOf(e)),typeof n=="number"){if(n===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(n)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},Uu=Ms.object({index:Ms.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as _a}from"zod";function Os(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Bu,async execute(i,a){let{page:n,agentServices:o}=a;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(n,r,o),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var Cs,Bu,ai=v(()=>{"use strict";Cs=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Bu=_a.object({success:_a.boolean().describe("Whether the task was completed successfully"),summary:_a.string().describe("Summary of what was accomplished or why it failed")})});import{z as ka}from"zod";async function Gu(e,t,i,a,n={}){return{...await N(a,i),action_description:t,action_data:{action_name:e,kwargs:{...n}}}}function Ls(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ns(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:ju,usesElementIndex:!0,async execute(i,a){let{element_index:n}=i,{page:o,agentServices:r,actionDescription:s}=a;try{let l=await W(a,n);if(!l)return{success:!1,error:`Element with index ${n} not found.`,actionEntity:Ls(`Double-click element ${n}`,"double_click",{index:n})};let c=s||`Double-click element ${n}`,d=await Gu("double_click",c,l,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${n}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ls(`Double-click element ${n}`,"double_click",{index:n})}}}})}var Sa,ju,oi=v(()=>{"use strict";j();F();I();Sa=class{async execute(e,t,i){let a=O(e,t),n=P(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.dblclick({timeout:n});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};ju=ka.object({element_index:ka.number().int().describe("Index of the element to double-click"),timeout_ms:ka.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as Ku}from"@babel/parser";function Ds(e){if(!e.trim())return!1;try{return Ku(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var un=v(()=>{"use strict"});import{z as Rs}from"zod";function Fs(e,t){e.register({name:"verify",description:"Verify that a statement is true based on the current page state. Use this to check assertions about the page content, element visibility, or any condition.",schema:zu,async execute(i,a){let{statement:n}=i,{page:o,agentServices:r}=a;try{let s={action_description:`${n}`,action_data:{action_name:"verify",kwargs:{statement:n}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${n}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${n} (failed)`,action_data:{action_name:"verify",kwargs:{statement:n}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var hn,zu,ri=v(()=>{"use strict";$t();un();R();hn=class{async execute(e,t,i){let a=t.action_data?.kwargs,n=typeof a?.code=="string",o=n?a?.statement||t.action_description:t.action_description||a?.statement;if(n&&o){let d=Date.now();try{await this.executeJSAssertion(e,a.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(h){let m=((Date.now()-d)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${o}`)}}else if(n){let d=Date.now();await this.executeJSAssertion(e,a.code,i),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();u.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),c=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}async executeJSAssertion(e,t,i){let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4107
4107
  return (async () => {
4108
4108
  ${t}
4109
4109
  })();
4110
- `)(e,Qe.expect,a)}catch(n){throw new Error(`Assertion failed: ${n instanceof Error?n.message:String(n)}`)}}transpile(e,t){let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(a){let r=i.code;if(!Ns(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(n){let s=r.split(`
4110
+ `)(e,Qe.expect,a)}catch(n){throw new Error(`Assertion failed: ${n instanceof Error?n.message:String(n)}`)}}transpile(e,t){let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(a){let r=i.code;if(!Ds(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(n){let s=r.split(`
4111
4111
  `),l=JSON.stringify(n);return["{ const _t = Date.now(); try {",...s.map(c=>` ${c}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${o});`,"} }"]}return r.split(`
4112
- `)}return n?[`await agent.assert(page, ${JSON.stringify(n)}, ${o});`]:["// Skipping verify: missing statement or code"]}},ju=Ds.object({statement:Ds.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as Sa}from"zod";function Hs(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:Ku,async execute(i,a){let{element_description:n,variable_name:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Extract ${n} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${n} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${n} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Fs,Ku,si=v(()=>{"use strict";Fs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.element_description,o=a.kwargs.variable_name;if(!n||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${n} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]}},Ku=Sa.object({element_description:Sa.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Sa.string().describe("Name of the variable to store the extracted value")})});var zu,Vu,mn,pn=v(()=>{"use strict";zu=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Vu=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],mn=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:zu.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let a=i.element_description,n=i.variable_name;return a&&n?`Extract ${a} and save to ${n}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Vu.includes(t)}}});var Ea,Ta,Aa,$a=v(()=>{"use strict";zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();si();pn();F();me();Ea=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new ga),T.registerAction("go_back",new fs),T.registerAction("reload_page",new is),T.registerAction("close_tab",new Ms),T.registerAction("switch_tab",new Kr),T.registerAction("click",new dn),T.registerAction("hover",new wa),T.registerAction("right_click",new ha),T.registerAction("double_click",new ka),T.registerAction("click_by_coordinates",new xr),T.registerAction("right_click_by_coordinates",new wr),T.registerAction("double_click_by_coordinates",new vr),T.registerAction("drag_drop",new _r),T.registerAction("input_text",new ba),T.registerAction("clear_input",new Ss),T.registerAction("press",new da),T.registerAction("send_keys_on_element",new pr),T.registerAction("scroll_on_element",new Lr),T.registerAction("scroll_to_text",new Rr),T.registerAction("scroll",new Vt),T.registerAction("upload_file",new Yr),T.registerAction("wait_for_download_complete",new Mr),T.registerAction("get_dropdown_options",new ps),T.registerAction("select_dropdown_option",new Wr),T.registerAction("set_date_for_native_date_picker",new Br),T.registerAction("verify",new hn),T.registerAction("ai_action",new Er),T.registerAction("ai_extract",new Fs),T.registerAction("ai_step",new Ar),T.registerAction("ai_wait_until",new Pr),T.registerAction("generate_2fa_code",new ds),T.registerAction("wait",new Zr),T.registerAction("wait_for_page_ready",new mr),T.registerAction("save_variable",new rs),T.registerAction("js_code",new fr),T.registerAction("js_action",new yr),T.registerAction("function",new br),T.registerAction("done",new Ps),T.registerAction("click_element",new dn),T.registerAction("click_element_by_index",new dn),T.registerAction("hover_element_by_index",new wa),T.registerAction("right_click_on_element",new ha),T.registerAction("double_click_on_element",new ka),T.registerAction("scroll_down",new Vt),T.registerAction("scroll_up",new Vt),T.registerAction("scroll_element",new Vt),T.registerAction("send_keys",new da),T.registerAction("open_tab",new ga),T.registerAction("fill",new ba),T.registerAction("ai_assert",new hn),T.registerAction("assert",new hn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,a){if(!a)throw new Error("AgentServices not found");let n=i.action_data?.action_name;if(!n)throw new Error("Action name not found in action_data");let o=this.getAction(n);if(!o)throw new Error(`Unknown action: ${n}`);await o.execute(t,i,a)}transpile(t,i,a){let{sanitizeForComment:n}=(I(),Xn($i)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(mn.isAiAction(t))return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);",...l];let c=JSON.stringify(o),d=l.map(g=>` ${g}`),h=mn.canSelfHeal(t),p=a?JSON.stringify(a):"undefined";return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,a=!1,n=!1,o){let{sanitizeForComment:r}=(I(),Xn($i));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(n){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${a});`]}};Ea.actions=new Map,Ea.initialized=!1;Ta=Ea,Aa=Ta});var rt={};ut(rt,{ActionHandler:()=>Ta,default:()=>Aa});var st=v(()=>{"use strict";$a();zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();$t();si();un();Wt();j();We();R();te();et();pn();F();me()});import{z as li}from"zod";function gn(e,t,i){let a=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4113
- ${e.stepHistory.slice(-3).map(l=>{let c=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((d,h)=>{let p=d.action_description||"Unknown action";c+=`
4114
- \u2192 Action ${h+1}: ${p}`});else if(l.actions.length===1){let d=l.actions[0]?.action_description||"Unknown action";c+=`
4112
+ `)}return n?[`await agent.assert(page, ${JSON.stringify(n)}, ${o});`]:["// Skipping verify: missing statement or code"]}},zu=Rs.object({statement:Rs.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as Ea}from"zod";function Ws(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:Vu,async execute(i,a){let{element_description:n,variable_name:o}=i,{page:r,agentServices:s}=a;try{let l={action_description:`Extract ${n} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${n} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${n} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:n,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Hs,Vu,si=v(()=>{"use strict";Hs=class{async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=a.kwargs.element_description,o=a.kwargs.variable_name;if(!n||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${n} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(it(),tt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]}},Vu=Ea.object({element_description:Ea.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Ea.string().describe("Name of the variable to store the extracted value")})});var Xu,Yu,pn,mn=v(()=>{"use strict";Xu=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Yu=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],pn=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Xu.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let a=i.element_description,n=i.variable_name;return a&&n?`Extract ${a} and save to ${n}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Yu.includes(t)}}});var Ta,Aa,$a,Ma=v(()=>{"use strict";zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();si();mn();F();pe();Ta=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new fa),T.registerAction("go_back",new ws),T.registerAction("reload_page",new ns),T.registerAction("close_tab",new Is),T.registerAction("switch_tab",new zr),T.registerAction("click",new dn),T.registerAction("hover",new ba),T.registerAction("right_click",new pa),T.registerAction("double_click",new Sa),T.registerAction("click_by_coordinates",new vr),T.registerAction("right_click_by_coordinates",new br),T.registerAction("double_click_by_coordinates",new _r),T.registerAction("drag_drop",new kr),T.registerAction("input_text",new ya),T.registerAction("clear_input",new Es),T.registerAction("press",new ua),T.registerAction("send_keys_on_element",new gr),T.registerAction("scroll_on_element",new Nr),T.registerAction("scroll_to_text",new Fr),T.registerAction("scroll",new Vt),T.registerAction("upload_file",new Jr),T.registerAction("wait_for_download_complete",new Ir),T.registerAction("get_dropdown_options",new gs),T.registerAction("select_dropdown_option",new Ur),T.registerAction("set_date_for_native_date_picker",new Gr),T.registerAction("verify",new hn),T.registerAction("ai_action",new Tr),T.registerAction("ai_extract",new Hs),T.registerAction("ai_step",new $r),T.registerAction("ai_wait_until",new Cr),T.registerAction("generate_2fa_code",new us),T.registerAction("wait",new Qr),T.registerAction("wait_for_page_ready",new mr),T.registerAction("save_variable",new ss),T.registerAction("js_code",new wr),T.registerAction("js_action",new xr),T.registerAction("function",new yr),T.registerAction("done",new Cs),T.registerAction("click_element",new dn),T.registerAction("click_element_by_index",new dn),T.registerAction("hover_element_by_index",new ba),T.registerAction("right_click_on_element",new pa),T.registerAction("double_click_on_element",new Sa),T.registerAction("scroll_down",new Vt),T.registerAction("scroll_up",new Vt),T.registerAction("scroll_element",new Vt),T.registerAction("send_keys",new ua),T.registerAction("open_tab",new fa),T.registerAction("fill",new ya),T.registerAction("ai_assert",new hn),T.registerAction("assert",new hn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,a){if(!a)throw new Error("AgentServices not found");let n=i.action_data?.action_name;if(!n)throw new Error("Action name not found in action_data");let o=this.getAction(n);if(!o)throw new Error(`Unknown action: ${n}`);await o.execute(t,i,a)}transpile(t,i,a){let{sanitizeForComment:n}=(I(),Yn($i)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(pn.isAiAction(t))return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);",...l];let c=JSON.stringify(o),d=l.map(g=>` ${g}`),h=pn.canSelfHeal(t),m=a?JSON.stringify(a):"undefined";return[`// ${i}: ${n(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${m}, ${h});`]}transpileUncachedAction(t,i,a=!1,n=!1,o){let{sanitizeForComment:r}=(I(),Yn($i));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(n){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${a});`]}};Ta.actions=new Map,Ta.initialized=!1;Aa=Ta,$a=Aa});var rt={};ut(rt,{ActionHandler:()=>Aa,default:()=>$a});var st=v(()=>{"use strict";Ma();zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();$t();si();un();Wt();j();We();R();te();et();mn();F();pe()});import{z as li}from"zod";function gn(e,t,i){let a=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4113
+ ${e.stepHistory.slice(-3).map(l=>{let c=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((d,h)=>{let m=d.action_description||"Unknown action";c+=`
4114
+ \u2192 Action ${h+1}: ${m}`});else if(l.actions.length===1){let d=l.actions[0]?.action_description||"Unknown action";c+=`
4115
4115
  \u2192 ${d}`}if(!l.outcome.success&&l.outcome.error){let d=l.outcome.error.substring(0,100);c+=`
4116
4116
  Error: ${d}${l.outcome.error.length>100?"...":""}`}return l.evaluation&&(c+=`
4117
4117
  Eval: ${l.evaluation}`),c}).join(`
@@ -4129,7 +4129,7 @@ ${e.memory.map((l,c)=>`${c+1}. ${l}`).join(`
4129
4129
  **Current URL**: ${i}
4130
4130
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4131
4131
 
4132
- ${o()}${r()}${n()}${a()}${s()}`.trim()}function Ws(){return`
4132
+ ${o()}${r()}${n()}${a()}${s()}`.trim()}function Us(){return`
4133
4133
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4134
4134
 
4135
4135
  This is your last step. You MUST use the "done" action now.
@@ -4138,7 +4138,7 @@ This is your last step. You MUST use the "done" action now.
4138
4138
  - If the task is incomplete or partially complete, set success=false
4139
4139
  - Include everything you've accomplished in the done action's text field
4140
4140
  - No other actions are allowed on this step
4141
- `.trim()}function Xu(){let e=H.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let a="";if(i.schema instanceof li.ZodObject){let n=i.schema.shape,o=[];Object.keys(n).forEach(r=>{let s=n[r],l="any";s instanceof li.ZodNumber?l="number":s instanceof li.ZodString?l="string":s instanceof li.ZodBoolean?l="boolean":s instanceof li.ZodEnum&&(l=s._def.values.map(c=>`"${c}"`).join(" | ")),o.push(`${r}: ${l}`)}),a=`{${o.join(", ")}}`}return{name:i.name,description:i.description,params:a}}).sort((i,a)=>i.name.localeCompare(a.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4141
+ `.trim()}function Ju(){let e=H.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let a="";if(i.schema instanceof li.ZodObject){let n=i.schema.shape,o=[];Object.keys(n).forEach(r=>{let s=n[r],l="any";s instanceof li.ZodNumber?l="number":s instanceof li.ZodString?l="string":s instanceof li.ZodBoolean?l="boolean":s instanceof li.ZodEnum&&(l=s._def.values.map(c=>`"${c}"`).join(" | ")),o.push(`${r}: ${l}`)}),a=`{${o.join(", ")}}`}return{name:i.name,description:i.description,params:a}}).sort((i,a)=>i.name.localeCompare(a.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4142
4142
  `)}function fn(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:a=!0,useEvaluation:n=!0,useMultiAction:o=!0}=t,r=n?`
4143
4143
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4144
4144
  - "success: <reason>" if the goal was fully achieved
@@ -4161,7 +4161,7 @@ This is your last step. You MUST use the "done" action now.
4161
4161
  `:"",c=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
4162
4162
  `:"",d=n?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
4163
4163
  `:"",h=a?` "memory": "<important facts to remember>", // Update only when learning something new
4164
- `:"",p=o?` "actions": [ // Can be single action or multiple actions in sequence
4164
+ `:"",m=o?` "actions": [ // Can be single action or multiple actions in sequence
4165
4165
  {
4166
4166
  "description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
4167
4167
  "action_name": "<name of action to execute>",
@@ -4246,7 +4246,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4246
4246
 
4247
4247
  When stuck, call \`done\` with success=false and explain what happened.
4248
4248
 
4249
- ${Xu()}
4249
+ ${Ju()}
4250
4250
  ## Reasoning Rules
4251
4251
 
4252
4252
  Use the \`thinking\` field to reason about each step:
@@ -4264,7 +4264,7 @@ You must ALWAYS respond with a valid JSON in this exact format:
4264
4264
  \`\`\`json
4265
4265
  {
4266
4266
  ${c}${d}${h} "current_goal": "State the current goal. Include only what to achieve, not how to achieve it.",
4267
- ${p}
4267
+ ${m}
4268
4268
  "completes_instruction": true | false // Is the entire task complete?
4269
4269
  }
4270
4270
  \`\`\`
@@ -4282,7 +4282,7 @@ ${p}
4282
4282
  **Current Goal Examples:**
4283
4283
  - "Add the product to the cart"
4284
4284
  - "Find more product listings and extract details from the next 5 items on the page"
4285
- ${g}`.trim()}var wn=v(()=>{"use strict";Ee()});var bn,Ma=v(()=>{"use strict";wn();ie();bn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,a,n,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:c,finalStepWarning:d}=o,h=[],p=gn(n,e,t);if(h.push({type:"text",text:p}),h.push({type:"text",text:`## CURRENT PAGE STATE
4285
+ ${g}`.trim()}var wn=v(()=>{"use strict";Ee()});var bn,Ia=v(()=>{"use strict";wn();ie();bn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,a,n,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:c,finalStepWarning:d}=o,h=[],m=gn(n,e,t);if(h.push({type:"text",text:m}),h.push({type:"text",text:`## CURRENT PAGE STATE
4286
4286
 
4287
4287
  **Interactive Elements**:
4288
4288
  ${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([f,y],b)=>`${b+1}. ${f} \u2192 ${y}`);h.push({type:"text",text:`## EXECUTION HISTORY (from test)
@@ -4298,9 +4298,9 @@ ${g.join(`
4298
4298
  `,a+=`- Use the EXACT placeholder name as shown above
4299
4299
  `,a+=`- Do NOT use the actual value directly in the action
4300
4300
  `,a+=`- The values shown are for context only to help you understand what data is available
4301
- `,a+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',a}}});var lt=v(()=>{"use strict"});async function Qu(e,t){let i=new Set,a=Date.now(),n=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=h=>{let p=h.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=h=>{let p=h.resourceType(),g=h.url();if(!n.has(p)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),a=Date.now())},c=async h=>{let p=h.request();if(!i.has(p))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(y=>g.includes(y))){i.delete(p);return}if(![...o].some(y=>g.startsWith(y))){i.delete(p);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),a=Date.now()},d=Date.now()-Zu;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),f=h.timing();n.has(p)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),a=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),p=qu;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-a>=p){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",c)}}async function Ae(e,t=Ju,i=Yu){let a=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Qu(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let n=Date.now()-a,o=Math.max(i-n,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Yu,Ju,qu,Zu,$e=v(()=>{"use strict";lt();R();Yu=.5*1e3,Ju=30*1e3,qu=1*1e3,Zu=3*1e3});import{generateText as eh}from"ai";function th(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}async function Gs(e,t,i={}){let a=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let n=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new fe(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${n}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:n,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=fn(i.customPrompt),p=new bn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",y=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:n});c.currentStep<n;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${n}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Ae(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let m;try{w.log("Preparing context (DOM + screenshot)...");let L=l.agentServices.getInteractiveClassNames(),D=l.agentServices.getIframeFallbackDomains();m=await Bs(l.page,l.domService,L,D),w.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Ae(l.page);let D=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();m=await Bs(l.page,l.domService,D,C)}else throw w.error("Error preparing context",L),L}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===n-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await nh(p,r,i,m.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&d.push(...x.tokenUsages),!x.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=x.stepOutput;sh(c.currentStep,n,S);let E=await oh(S,l,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,x.debugInfo);y.push(...E.actionEntities);let A=rh(c.currentStep,S,E,c,b,x.debugInfo,x.tokenUsages),$=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:$}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=n&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-a}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${y.length}, tokens=${d.length}`),lh(c,y,g,f,a,d,r)}catch(b){let m=b.message;return w.error(`Task execution failed: ${m}`,b),i.onEvent?.({type:"error",error:m,recoverable:!1}),ch(c,m,a,d,r)}}async function Bs(e,t,i,a){let{domState:n,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a}),r=n.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:n}}function ih(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=typeof a=="string"?a:"";return{type:"image",file:n.startsWith("data:")?n:`data:image/png;base64,${n}`}}return{type:"text",text:i.text}}):t.content}))}async function nh(e,t,i,a){let n=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(p=>p.type==="image").length);let l=ke(t,s),c={model:_e(t),system:o,messages:r,temperature:n,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let p=Date.now();w.log(`Calling LLM (${t})...`);let g=await eh(c),f=Date.now()-p,y=g,b=y.usage;w.llmCall(t,f,b);let m=y.reasoningText;m&&(w.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:ih(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:a},S=[],E=th(b,t);E&&S.push(E);let A=ah(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise($=>setTimeout($,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:S};return{stepOutput:A,debugInfo:x,tokenUsages:S}}catch(p){if(h<d-1){w.log(`Attempt ${h+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function ah(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let a of i.actions){if(!a.action_name)return w.error("Action missing required field: action_name"),null;if(!a.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function oh(e,t,i,a,n,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},p=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},y=g.kwargs?.element_index??g.kwargs?.index;if(typeof y=="number"){let m=i.selectorMap.get(y);m&&(f=await N(t.page,m))}let b={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(b=m.actionEntity);let x=await h.agentServices.getCurrentPage();if(x&&(h.page=x,t.page=h.page),m?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}s.push(b),n?.({type:"action",action_entity:b,step:a,debugInfo:r})}catch(m){l=!1,c=m.message,w.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function rh(e,t,i,a,n,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:n,duration:Date.now()-n,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(a.lastGoal=t.current_goal,t.evaluation_previous_goal&&(a.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();a.memory.includes(l)||(a.memory.push(l),a.memory.length>10&&(a.memory=a.memory.slice(-10)))}return i.allSuccess?(a.consecutiveFailures=0,a.lastFailReason=null):(a.consecutiveFailures++,a.lastFailReason=i.failReason),a.stepHistory.push(s),s}function sh(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let a=i.actions[0];w.log(`Action: ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((a,n)=>{w.log(` ${n+1}. ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)})}function lh(e,t,i,a,n,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+h.total_tokens,0);return{success:!0,completed:i,summary:a,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-n,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function ch(e,t,i,a,n){let o=a.reduce((l,c)=>l+c.prompt_tokens,0),r=a.reduce((l,c)=>l+c.completion_tokens,0),s=a.reduce((l,c)=>l+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:n,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:a}}}var js=v(()=>{"use strict";Ma();wn();Ee();Ue();ie();$e();Se();j()});var Ks={};ut(Ks,{TaskMessageManager:()=>bn,formatFinalStepWarning:()=>Ws,formatTaskContext:()=>gn,getBrowserTaskJSONPrompt:()=>fn,runTaskLoop:()=>Gs});var zs=v(()=>{"use strict";js();Ma();wn();Ee();tn();Ue();kt();St();Ze();Et();Tt();ie();$e();lt();Se();bt();Xe();yt();Ne();j();We();R();te();et();F();me()});async function Mt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:a}=e.action_data;if(H.has(i)){let n=await H.execute(i,a,t),o=n?.success!==!1,r=n?.error||n?.message;return{success:o,error:o?void 0:r}}else{let{page:n,agentServices:o}=t;return await(await dh()).execute(n,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function dh(){if(yn)return yn;let e=await Promise.resolve().then(()=>(st(),rt));return yn=new e.default,yn}async function It(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await ia(r,o,a);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function nt(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await ia(r,o,a);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:c,goalAccomplished:d,debugInfo:h}=s,p=await Mt(l,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function at(e,t,i,a={}){let n={page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},o=i.replaceVariables(e);return a.useCleanScreenshotForAssertion??(a.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),or(o,n,a)}async function ot(e,t,i,a,n={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(zs(),Ks)),r=a?l=>{a(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},{maxSteps:n.maxSteps,onEvent:r,abortSignal:n.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var yn,Pt=v(()=>{"use strict";ji();Ee();Ue();yn=null});import"uuid";import{z as k}from"zod";import"yaml";import"uuid";import"yaml";function Ia(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,a=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},n=e;return n=n.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n=n.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n}var dl,US,ul,yh,xh,vn,BS,GS,_n,hl,ml,vh,cl,_h,ci,kh,Sh,Eh,re,Th,Ah,VS,aE,ct=v(()=>{"use strict";me();dl=112,US=1080-dl,ul=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ul||{}),yh={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}},xh={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},vn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),xh[e].map(a=>yh[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))},BS={desktop:{label:"Desktop",type:"desktop",devices:vn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:vn("mobile")}},GS={desktop:{label:"Desktop",type:"desktop",devices:vn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:vn("mobile",!0)}},_n=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(_n||{}),hl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(hl||{}),ml=class pl{constructor(){Yn(this,"data",{}),Yn(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,a=!1){this.data[t]=i,a?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,a]of Object.entries(t.getAll()))this.set(i,a,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new pl;if(t.data){let a=new Set(t.sensitiveKeys||[]);for(let[n,o]of Object.entries(t.data))i.set(n,o,a.has(n))}return i}},vh=k.enum(["JS_CODE","AI_MODE"]),cl=k.object({type:vh,expression:k.string()}),_h=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ci=k.object({uid:k.string(),type:_h,comment:k.string().optional()}),kh=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),Sh=ci.extend({type:k.literal("DRAFT"),description:k.string()}),Eh=ci.extend({type:k.literal("ACTION"),description:k.string(),action_entity:kh.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),re=k.lazy(()=>k.union([Sh,Eh,ci.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(re),reference_id:k.number().optional(),template_path:k.string().optional(),template_params:k.record(k.string()).optional()}),ci.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:cl,then:k.array(re),else:k.array(re).optional()}),ci.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:cl,body:k.array(re),timeout_ms:k.number().optional()})])),Th=k.object({name:k.string(),statements:k.array(re),teardown:k.array(re).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),Ah=k.object({tests:k.array(Th).min(1),beforeAll:k.array(re).optional(),afterAll:k.array(re).optional(),beforeEach:k.array(re).optional(),afterEach:k.array(re).optional()}),VS=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(re).optional(),teardown:k.array(re).optional(),last_modified_at:k.string().optional(),testGroup:Ah.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),aE=1024*1024});async function gl(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,a=`
4301
+ `,a+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',a}}});var lt=v(()=>{"use strict"});async function th(e,t){let i=new Set,a=Date.now(),n=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=h=>{let m=h.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=h=>{let m=h.resourceType(),g=h.url();if(!n.has(m)||s(g))return;let f=h.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(h),a=Date.now())},c=async h=>{let m=h.request();if(!i.has(m))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(y=>g.includes(y))){i.delete(m);return}if(![...o].some(y=>g.startsWith(y))){i.delete(m);return}let f=h.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),a=Date.now()},d=Date.now()-eh;for(let h of await e.requests()){let m=h.resourceType(),g=h.url(),f=h.timing();n.has(m)&&!s(g)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(h),a=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",c);try{let h=Date.now(),m=Qu;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-a>=m){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",c)}}async function Ae(e,t=Zu,i=qu){let a=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),th(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let n=Date.now()-a,o=Math.max(i-n,0);o>0&&await new Promise(r=>setTimeout(r,o))}var qu,Zu,Qu,eh,$e=v(()=>{"use strict";lt();R();qu=.5*1e3,Zu=30*1e3,Qu=1*1e3,eh=3*1e3});import{generateText as ih}from"ai";function nh(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}async function js(e,t,i={}){let a=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let n=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new fe(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${n}`),w.log(`Model: ${r}`);let c={currentStep:0,maxSteps:n,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],h=fn(i.customPrompt),m=new bn(h);w.log(`System prompt length: ${h.length} chars`);let g=!1,f="",y=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:n});c.currentStep<n;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();w.section(`Step ${c.currentStep}/${n}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{w.log("Waiting for page to stabilize..."),await Ae(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let p;try{w.log("Preparing context (DOM + screenshot)...");let L=l.agentServices.getInteractiveClassNames(),D=l.agentServices.getIframeFallbackDomains();p=await Gs(l.page,l.domService,L,D),w.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Ae(l.page);let D=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();p=await Gs(l.page,l.domService,D,C)}else throw w.error("Error preparing context",L),L}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,c,{isFinalStep:c.currentStep===n-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await oh(m,r,i,p.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&d.push(...x.tokenUsages),!x.stepOutput){if(w.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=x.stepOutput;ch(c.currentStep,n,S);let E=await sh(S,l,p.domState,c.currentStep,i.onEvent,p.screenshotBase64,x.debugInfo);y.push(...E.actionEntities);let A=lh(c.currentStep,S,E,c,b,x.debugInfo,x.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){w.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){g=E.doneResult.success,f=E.doneResult.summary;break}if(E.completesInstruction){g=!0,f="Instruction completed";break}}return c.currentStep>=n&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-a}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${y.length}, tokens=${d.length}`),dh(c,y,g,f,a,d,r)}catch(b){let p=b.message;return w.error(`Task execution failed: ${p}`,b),i.onEvent?.({type:"error",error:p,recoverable:!1}),uh(c,p,a,d,r)}}async function Gs(e,t,i,a){let{domState:n,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a}),r=n.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:n}}function ah(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let a=i.image,n=typeof a=="string"?a:"";return{type:"image",file:n.startsWith("data:")?n:`data:image/png;base64,${n}`}}return{type:"text",text:i.text}}):t.content}))}async function oh(e,t,i,a){let n=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let h of r)Array.isArray(h.content)&&(s+=h.content.filter(m=>m.type==="image").length);let l=ke(t,s),c={model:_e(t),system:o,messages:r,temperature:n,providerOptions:l},d=3;for(let h=0;h<d;h++)try{let m=Date.now();w.log(`Calling LLM (${t})...`);let g=await ih(c),f=Date.now()-m,y=g,b=y.usage;w.llmCall(t,f,b);let p=y.reasoningText;p&&(w.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:ah(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:a},S=[],E=nh(b,t);E&&S.push(E);let A=rh(g.text);if(!A)if(h<d-1){w.log(`Attempt ${h+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(M=>setTimeout(M,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:S};return{stepOutput:A,debugInfo:x,tokenUsages:S}}catch(m){if(h<d-1){w.log(`Attempt ${h+1}/${d}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function rh(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let a of i.actions){if(!a.action_name)return w.error("Action missing required field: action_name"),null;if(!a.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function sh(e,t,i,a,n,o,r){let s=[],l=!0,c=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,h={...t,domState:i},m=o;for(let g of e.actions){if(g.action_name==="done"){d={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},y=g.kwargs?.element_index??g.kwargs?.index;if(typeof y=="number"){let p=i.selectorMap.get(y);p&&(f=await N(t.page,p))}let b={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await H.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(b=p.actionEntity);let x=await h.agentServices.getCurrentPage();if(x&&(h.page=x,t.page=h.page),p?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),c=p.error||"Action execution failed";break}s.push(b),n?.({type:"action",action_entity:b,step:a,debugInfo:r})}catch(p){l=!1,c=p.message,w.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:c,actionEntities:s,doneResult:d,completesInstruction:e.completes_instruction??!1}}function lh(e,t,i,a,n,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:n,duration:Date.now()-n,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(a.lastGoal=t.current_goal,t.evaluation_previous_goal&&(a.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();a.memory.includes(l)||(a.memory.push(l),a.memory.length>10&&(a.memory=a.memory.slice(-10)))}return i.allSuccess?(a.consecutiveFailures=0,a.lastFailReason=null):(a.consecutiveFailures++,a.lastFailReason=i.failReason),a.stepHistory.push(s),s}function ch(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let a=i.actions[0];w.log(`Action: ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((a,n)=>{w.log(` ${n+1}. ${a.action_name}(${JSON.stringify(a.kwargs)}) - ${a.description}`)})}function dh(e,t,i,a,n,o,r){let s=o.reduce((d,h)=>d+h.prompt_tokens,0),l=o.reduce((d,h)=>d+h.completion_tokens,0),c=o.reduce((d,h)=>d+h.total_tokens,0);return{success:!0,completed:i,summary:a,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-n,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:c,tokenUsages:o}}}function uh(e,t,i,a,n){let o=a.reduce((l,c)=>l+c.prompt_tokens,0),r=a.reduce((l,c)=>l+c.completion_tokens,0),s=a.reduce((l,c)=>l+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:n,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:a}}}var Ks=v(()=>{"use strict";Ia();wn();Ee();Ue();ie();$e();Se();j()});var zs={};ut(zs,{TaskMessageManager:()=>bn,formatFinalStepWarning:()=>Us,formatTaskContext:()=>gn,getBrowserTaskJSONPrompt:()=>fn,runTaskLoop:()=>js});var Vs=v(()=>{"use strict";Ks();Ia();wn();Ee();tn();Ue();kt();St();Ze();Et();Tt();ie();$e();lt();Se();bt();Xe();yt();Ne();j();We();R();te();et();F();pe()});async function Mt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:a}=e.action_data;if(H.has(i)){let n=await H.execute(i,a,t),o=n?.success!==!1,r=n?.error||n?.message;return{success:o,error:o?void 0:r}}else{let{page:n,agentServices:o}=t;return await(await hh()).execute(n,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function hh(){if(yn)return yn;let e=await Promise.resolve().then(()=>(st(),rt));return yn=new e.default,yn}async function It(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await na(r,o,a);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function nt(e,t,i,a={},n){let o=n||{page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},r=i.replaceVariables(e),s=await na(r,o,a);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:c,goalAccomplished:d,debugInfo:h}=s,m=await Mt(l,o);return m.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[l],explanation:c,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:h}}async function at(e,t,i,a={}){let n={page:t,agentServices:i,domService:new fe(i.getDomServiceOptions()),executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},o=i.replaceVariables(e);return a.useCleanScreenshotForAssertion??(a.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),rr(o,n,a)}async function ot(e,t,i,a,n={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Vs(),zs)),r=a?l=>{a(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},{maxSteps:n.maxSteps,onEvent:r,abortSignal:n.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var yn,Pt=v(()=>{"use strict";ji();Ee();Ue();yn=null});import"uuid";import{z as k}from"zod";import"yaml";import"uuid";import"yaml";function Pa(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,a=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},n=e;return n=n.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n=n.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=a(r.trim());return s!==void 0?s:o}),n=n.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=a(r);return s!==void 0?s:o}),n}var ul,GS,hl,vh,_h,vn,jS,KS,_n,pl,ml,kh,dl,Sh,ci,Eh,Th,Ah,re,$h,Mh,YS,rE,ct=v(()=>{"use strict";pe();ul=112,GS=1080-ul,hl=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(hl||{}),vh={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}},_h={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},vn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),_h[e].map(a=>vh[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))},jS={desktop:{label:"Desktop",type:"desktop",devices:vn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:vn("mobile")}},KS={desktop:{label:"Desktop",type:"desktop",devices:vn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:vn("mobile",!0)}},_n=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(_n||{}),pl=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(pl||{}),ml=class gl{constructor(){Jn(this,"data",{}),Jn(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,a=!1){this.data[t]=i,a?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,a]of Object.entries(t.getAll()))this.set(i,a,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new gl;if(t.data){let a=new Set(t.sensitiveKeys||[]);for(let[n,o]of Object.entries(t.data))i.set(n,o,a.has(n))}return i}},kh=k.enum(["JS_CODE","AI_MODE"]),dl=k.object({type:kh,expression:k.string()}),Sh=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ci=k.object({uid:k.string(),type:Sh,comment:k.string().optional()}),Eh=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),Th=ci.extend({type:k.literal("DRAFT"),description:k.string()}),Ah=ci.extend({type:k.literal("ACTION"),description:k.string(),action_entity:Eh.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),re=k.lazy(()=>k.union([Th,Ah,ci.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(re),reference_id:k.number().optional(),template_path:k.string().optional(),template_params:k.record(k.string()).optional()}),ci.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:dl,then:k.array(re),else:k.array(re).optional()}),ci.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:dl,body:k.array(re),timeout_ms:k.number().optional()})])),$h=k.object({name:k.string(),statements:k.array(re),teardown:k.array(re).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),Mh=k.object({tests:k.array($h).min(1),beforeAll:k.array(re).optional(),afterAll:k.array(re).optional(),beforeEach:k.array(re).optional(),afterEach:k.array(re).optional()}),YS=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(re).optional(),teardown:k.array(re).optional(),last_modified_at:k.string().optional(),testGroup:Mh.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),rE=1024*1024});async function fl(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,a=`
4302
4302
  return await (${t});
4303
- `;return await new i("page",a)(e)}async function di(e,t,i){let a=[],n=[];for(let o of t){let r=!1;try{let s=`page.${o}`;w.log(`Checking element existence: ${s}`),a.push(`Checking element existence: ${s}`);try{await gl(e,`${s}.waitFor({ state: 'attached', timeout: ${Oh} })`),w.log(`Element is attached: ${s}`),a.push(`Element is attached: ${s}`),r=!0}catch{await gl(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),a.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),a.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),a.push(`Error checking element: ${s.message}`),r=!1}if(n.push(r),!r&&i)break}return{successResults:n,logs:a}}async function Pa(e,t,i=!0){let{successResults:a,logs:n}=await di(e,t,i);return{success:a.length===t.length&&a.every(o=>o),logs:n}}async function ui(e,t){if(!t||t.length===0)return w.log("No validation expressions provided, cannot validate login"),!1;w.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:a}=await Pa(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${a.join(", ")}`),i}async function Ca(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let a=await i.newContext(),n=await a.newPage();return await n.goto(t),await Ae(n,Lh),{context:a,page:n,close:async()=>{await n.close(),await a.close()}}}async function Oa(e,t,i,a,n,o){let r=`
4303
+ `;return await new i("page",a)(e)}async function di(e,t,i){let a=[],n=[];for(let o of t){let r=!1;try{let s=`page.${o}`;w.log(`Checking element existence: ${s}`),a.push(`Checking element existence: ${s}`);try{await fl(e,`${s}.waitFor({ state: 'attached', timeout: ${Nh} })`),w.log(`Element is attached: ${s}`),a.push(`Element is attached: ${s}`),r=!0}catch{await fl(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),a.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),a.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),a.push(`Error checking element: ${s.message}`),r=!1}if(n.push(r),!r&&i)break}return{successResults:n,logs:a}}async function Ca(e,t,i=!0){let{successResults:a,logs:n}=await di(e,t,i);return{success:a.length===t.length&&a.every(o=>o),logs:n}}async function ui(e,t){if(!t||t.length===0)return w.log("No validation expressions provided, cannot validate login"),!1;w.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:a}=await Ca(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${a.join(", ")}`),i}async function Oa(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let a=await i.newContext(),n=await a.newPage();return await n.goto(t),await Ae(n,Dh),{context:a,page:n,close:async()=>{await n.close(),await a.close()}}}async function La(e,t,i,a,n,o){let r=`
4304
4304
  Based on the current page status, generate ${n} Playwright locators in JavaScript code that can
4305
4305
  be used by a program to verify the page is signed in.
4306
4306
  Each expression should yield a locator object that can be used for waiting and checking visibility.
@@ -4344,33 +4344,33 @@ ${a}
4344
4344
  Remember, you must have the javascript code block in your final response.
4345
4345
  `,w.log("Agent generating validation locators"),w.log(`Prompt:
4346
4346
  ${r}`);let s=await o(e,r);if(!s.success)throw new Error(s.details||"Agent failed to generate verification code");let l=(s.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
4347
- `).map(c=>c.trim()).filter(c=>c.length>0).map(c=>(c.startsWith("page.")&&(c=c.slice(5)),c))}async function kn(e,t,i,a,n){let o=null;try{o=await Ca(e,t);let r=await n(o.page),s=3,l="";for(let c=0;c<s;c++)try{let d=await Oa(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,a);w.log(`Generated validation locators: ${JSON.stringify(d)}`);{let{successResults:h,logs:p}=await di(e,d,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4348
- ${p.join(`
4347
+ `).map(c=>c.trim()).filter(c=>c.length>0).map(c=>(c.startsWith("page.")&&(c=c.slice(5)),c))}async function kn(e,t,i,a,n){let o=null;try{o=await Oa(e,t);let r=await n(o.page),s=3,l="";for(let c=0;c<s;c++)try{let d=await La(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,a);w.log(`Generated validation locators: ${JSON.stringify(d)}`);{let{successResults:h,logs:m}=await di(e,d,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4348
+ ${m.join(`
4349
4349
  `)}
4350
4350
 
4351
4351
  `,!h.every(g=>g)){w.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(h)}`),w.log(`Validation logs:
4352
- ${p.join(`
4353
- `)}`);continue}}{w.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:h,logs:p}=await di(o.page,d,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4354
- ${p.join(`
4352
+ ${m.join(`
4353
+ `)}`);continue}}{w.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:h,logs:m}=await di(o.page,d,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4354
+ ${m.join(`
4355
4355
  `)}
4356
4356
 
4357
4357
  `,h.some(g=>g)){w.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(h)}`),w.log(`Validation logs:
4358
- ${p.join(`
4359
- `)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var Oh,Lh,Sn=v(()=>{"use strict";ie();$e();Oh=5e3,Lh=1e4});var kl={};ut(kl,{LoginType:()=>_n,checkLocators:()=>di,createUnsignedInContext:()=>Ca,generateAndValidateLoginLocators:()=>kn,generateValidationLocators:()=>Oa,validateLogin:()=>ui,validateLoginLocators:()=>Pa});var Sl=v(()=>{"use strict";Sn();ie();ct();$e();lt();R();te();et();me()});import Bc from"dotenv";import{defineConfig as Gc}from"@playwright/test";import{readFileSync as fo,statSync as kc,existsSync as wo}from"fs";import{resolve as Hn,relative as Sc}from"path";import{globSync as Ec}from"glob";import{v4 as Xh}from"uuid";import{z as _}from"zod";var Fa=_.enum(["JS_CODE","AI_MODE"]),En=_.object({type:Fa,expression:_.string()}),Ha=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ge=_.object({uid:_.string(),type:Ha,comment:_.string().optional()}),Wa=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Ua=Ge.extend({type:_.literal("DRAFT"),description:_.string()}),Ba=Ge.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Wa.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ne=_.lazy(()=>_.union([Ua,Ba,Ge.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ne),reference_id:_.number().optional(),template_path:_.string().optional(),template_params:_.record(_.string()).optional()}),Ge.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:En,then:_.array(ne),else:_.array(ne).optional()}),Ge.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:En,body:_.array(ne),timeout_ms:_.number().optional()})])),Ga=_.object({name:_.string(),statements:_.array(ne),teardown:_.array(ne).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),mi=_.object({tests:_.array(Ga).min(1),beforeAll:_.array(ne).optional(),afterAll:_.array(ne).optional(),beforeEach:_.array(ne).optional(),afterEach:_.array(ne).optional()}),Tn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ne).optional(),teardown:_.array(ne).optional(),last_modified_at:_.string().optional(),testGroup:mi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"});import{stringify as em,parse as $l,parseAllDocuments as tm,parseDocument as Ml,Document as im,isMap as pi,isSeq as je}from"yaml";import{v4 as le}from"uuid";function An(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(An);let t=e,i=Object.keys(t);if(i.length===1){let n=i[0];if(n.startsWith("{ ")&&n.endsWith(" }")&&t[n]===null)return`{{${n.slice(2,-2)}}}`}let a={};for(let[n,o]of Object.entries(t))a[n]=An(o);return a}var ja=1024*1024;function xe(e){if(e.length>ja)throw new Error(`YAML input too large (${e.length} bytes, max ${ja})`);let t=An($l(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Il(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:oe(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=oe(t.teardown));let a=Tn.safeParse(i);if(!a.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(a.error.errors)}`);let n=a.data;return Va(e,n),n}function Il(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let n={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:oe(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=oe(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(n.beforeAll=oe(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(n.afterAll=oe(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(n.beforeEach=oe(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(n.afterEach=oe(t.afterEach));let o=mi.safeParse(n);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function oe(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Pl)}function Pl(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return Cl(t);if("WHILE"in t)return Ol(t);if("STEP"in t)return Ll(t);if("VERIFY"in t){let i=t.VERIFY,a={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(a.code=t.js),{uid:le(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:a}}}}if("URL"in t){let i=t.URL,a=t.new_tab===!0?!0:void 0,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return a&&(o.new_tab=!0),n!==void 0&&(o.timeout_seconds=n),{uid:le(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:le(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:a}}}}}if("WAIT"in t){let i=t.WAIT,a=typeof t.seconds=="number"?t.seconds:3;return{uid:le(),type:"ACTION",description:typeof i=="string"?i:`Wait ${a}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${a}s`,action_data:{action_name:"wait",kwargs:{seconds:a}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let a=typeof t.description=="string"?t.description:"Code block";return{uid:le(),type:"ACTION",description:a,action_entity:{action_description:a,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",a=t.js;return{uid:le(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof a=="string"?a:String(a)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...a}=t;return Ka({...a,action:"function",functionName:i})}if("action"in t)return Ka(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:le(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function za(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function Cl(e){let t=za(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let a={uid:le(),type:"IF_ELSE",condition:t,then:oe(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(a.else=oe(e.ELSE)),a}function Ol(e){let t=za(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let a={uid:le(),type:"WHILE_LOOP",condition:t,body:oe(i)};return typeof e.timeout_ms=="number"&&(a.timeout_ms=e.timeout_ms),a}function Ll(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:le(),type:"STEP",description:t,statements:oe(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let a=e.template_params,n={};for(let[o,r]of Object.entries(a))n[o]=String(r);i.template_params=n}return i}var Nl=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function Ka(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",a=typeof e.locator=="string"?e.locator:void 0,n=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))Nl.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};a&&(s.locator=a),n&&(s.xpath=n);let l={uid:le(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Va(e,t){let i;try{i=Ml(e)}catch{return}let a=i.contents;if(!a||!pi(a))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=a.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let n=a,o=n.get("statements",!0);je(o)&&t.statements&&Ke(o,t.statements);let r=n.get("teardown",!0);je(r)&&t.teardown&&Ke(r,t.teardown)}function Ke(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let a=e.items[i];a.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=a.commentBefore);let n=t[i];if(n.type==="STEP"&&pi(a)){let o=a.get("statements",!0);je(o)&&Ke(o,n.statements)}else if(n.type==="IF_ELSE"&&pi(a)){let o=a.get("THEN",!0);je(o)&&Ke(o,n.then);let r=a.get("ELSE",!0);je(r)&&n.else&&Ke(r,n.else)}else if(n.type==="WHILE_LOOP"&&pi(a)){let o=a.get("DO",!0);je(o)&&Ke(o,n.body)}}}import{parse as sm,stringify as lm}from"yaml";var $n=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t};var gi=e=>{let t=[],i=a=>{for(let n of a){t.push(n);let o=$n(n);for(let r of o)i(r.statements)}};return i(e),t};var Dl=.5,Xa=5,Ya=3,qa=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function Za(e){let t=0,i=0;for(let a of e)if(a.type==="DRAFT")i++;else if(a.type==="ACTION"){let n=a.action_entity?.action_data?.action_name??"";qa.has(n)||t++}return{action:t,draft:i}}function Rl(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Ja(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Fl(e){let t=e.split(/\r?\n/).map(o=>o.trim()).filter(o=>o.length>0&&!o.startsWith("//")),i=t.length,a=t.join(`
4360
- `).match(/\bawait\b/g),n=a?a.length:0;return i<=Xa&&n<=Ya?null:`${i} non-blank line(s), ${n} await(s) \u2014 limits are ${Xa} lines and ${Ya} awaits. The VERIFY js: field is a cache for one natural-language assertion, not a place for multi-step logic. Break this into multiple statements \u2014 one VERIFY per assertion \u2014 so each step is visible in the debugger and self-healable. For freeform setup code (mocking, storage), use the description: + js: escape hatch, which has no complexity cap.`}function Mn(e,t){let i=t?.coverageThreshold??Dl,a=[],n=[],o;try{o=xe(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||a.push('Missing required field: "goal"'),o.statements?.length||a.push('Missing required field: "statements"');let r=[...gi(o.statements??[]),...o.teardown?gi(o.teardown):[]],{action:s,draft:l}=Za(r),c="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of r){let g=p;if(g.reference_id!==void 0){let f=g.description||p.uid;a.push(`Unresolved cloud template reference on statement "${f}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(p.type==="ACTION"){let f=p,y=f.action_entity?.action_data?.action_name??"";if(y==="js_code"||y==="js_action"||y==="verify"||y==="ai_assert"){let b=f.action_entity?.action_data?.kwargs?.code;if(typeof b=="string"){let m=Rl(b);if(m){let x=f.description||y;a.push(`Invalid JS in "${x}": ${m}. ${c}`)}else if(y==="verify"){let x=Fl(b);if(x){let S=f.description||y;a.push(`JS cache for "${S}" is too complex: ${x}`)}}}}}if(p.type==="IF_ELSE"){let f=p;if(f.condition.type==="JS_CODE"){let y=Ja(f.condition.expression);y&&a.push(`Invalid JS in IF condition "${f.condition.expression}": ${y}. ${c}`)}}if(p.type==="WHILE_LOOP"){let f=p;if(f.condition.type==="JS_CODE"){let y=Ja(f.condition.expression);y&&a.push(`Invalid JS in WHILE condition "${f.condition.expression}": ${y}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&n.push(`Low action coverage: ${s}/${d} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:a.length===0,errors:a,warnings:n,stats:{total:d,action:s,draft:l,coverage:h}}}var Qa=112;var Wl=1080-Qa;var eo={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var to={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},ht=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),to[e].map(a=>eo[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))};var Ul={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile")}},Bl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile",!0)}};function In(){return{version:"1.0",entries:{}}}var ce=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ce||{});var Pn=18e4;import{stringify as jl}from"yaml";import{createHash as lc}from"crypto";import{parse as cc,stringify as uo}from"yaml";import{readFileSync as dc,existsSync as uc}from"fs";import{resolve as On,dirname as hc}from"path";import{parse as oo,stringify as mc}from"yaml";import{readFileSync as Hg,writeFileSync as xc,mkdirSync as vc}from"fs";import{dirname as _c}from"path";var Ln=5e3;function ue(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function B(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function Kl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function zl(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function wi(e){let t=Kl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=zl(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Vl=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Xl=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function io(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Vl.includes(t)}function Yl(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Xl.includes(t)}var Z=new Map;function M(e,t){Z.set(e,t)}function Jl(e){return Z.get(e)}function Fe(e,t,i=[]){let a=[...i];return t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`),a.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}M("click",e=>{let t=wi(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Ln;return[`await ${t}.click({ timeout: ${i} });`]});M("click_element",Z.get("click"));M("click_element_by_index",Z.get("click"));M("double_click",e=>Fe("double_click",e));M("double_click_on_element",Z.get("double_click"));M("right_click",e=>Fe("right_click",e));M("right_click_on_element",Z.get("right_click"));M("hover",e=>Fe("hover",e));M("hover_element_by_index",Z.get("hover"));M("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Fe("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});M("fill",Z.get("input_text"));M("clear_input",e=>Fe("clear_input",e));M("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});M("send_keys",Z.get("press"));M("send_keys_on_element",e=>{let t=wi(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let a=e.action_data?.kwargs?.timeout_ms??Ln;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]});M("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Fe("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});M("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});M("scroll_down",Z.get("scroll"));M("scroll_up",Z.get("scroll"));M("scroll_element",Z.get("scroll"));M("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});M("scroll_on_element",e=>Fe("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));M("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});M("open_tab",Z.get("go_to_url"));M("go_back",()=>['await agent.execAction("go_back", page, {});']);M("reload_page",()=>['await agent.execAction("reload_page", page, {});']);M("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);M("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);M("verify",(e,t)=>{let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement;if(a&&n){let r=i.code.split(`
4358
+ ${m.join(`
4359
+ `)}`);continue}}return w.log("Generated validation locators passed dual validation"),d}catch(d){w.log(`Failed to generate validation expressions (attempt ${c+1}/${s}): ${d.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var Nh,Dh,Sn=v(()=>{"use strict";ie();$e();Nh=5e3,Dh=1e4});var Sl={};ut(Sl,{LoginType:()=>_n,checkLocators:()=>di,createUnsignedInContext:()=>Oa,generateAndValidateLoginLocators:()=>kn,generateValidationLocators:()=>La,validateLogin:()=>ui,validateLoginLocators:()=>Ca});var El=v(()=>{"use strict";Sn();ie();ct();$e();lt();R();te();et();pe()});import Gc from"dotenv";import{defineConfig as jc}from"@playwright/test";import{readFileSync as wo,statSync as Sc,existsSync as bo}from"fs";import{resolve as Wn,relative as Ec}from"path";import{globSync as Tc}from"glob";import{v4 as Jh}from"uuid";import{z as _}from"zod";var Ha=_.enum(["JS_CODE","AI_MODE"]),En=_.object({type:Ha,expression:_.string()}),Wa=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ge=_.object({uid:_.string(),type:Wa,comment:_.string().optional()}),Ua=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Ba=Ge.extend({type:_.literal("DRAFT"),description:_.string()}),Ga=Ge.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Ua.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ne=_.lazy(()=>_.union([Ba,Ga,Ge.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ne),reference_id:_.number().optional(),template_path:_.string().optional(),template_params:_.record(_.string()).optional()}),Ge.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:En,then:_.array(ne),else:_.array(ne).optional()}),Ge.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:En,body:_.array(ne),timeout_ms:_.number().optional()})])),ja=_.object({name:_.string(),statements:_.array(ne),teardown:_.array(ne).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),pi=_.object({tests:_.array(ja).min(1),beforeAll:_.array(ne).optional(),afterAll:_.array(ne).optional(),beforeEach:_.array(ne).optional(),afterEach:_.array(ne).optional()}),Tn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ne).optional(),teardown:_.array(ne).optional(),last_modified_at:_.string().optional(),testGroup:pi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"});import{stringify as ip,parse as Ml,parseAllDocuments as np,parseDocument as Il,Document as ap,isMap as mi,isSeq as je}from"yaml";import{v4 as le}from"uuid";function An(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(An);let t=e,i=Object.keys(t);if(i.length===1){let n=i[0];if(n.startsWith("{ ")&&n.endsWith(" }")&&t[n]===null)return`{{${n.slice(2,-2)}}}`}let a={};for(let[n,o]of Object.entries(t))a[n]=An(o);return a}var Ka=1024*1024;function xe(e){if(e.length>Ka)throw new Error(`YAML input too large (${e.length} bytes, max ${Ka})`);let t=An(Ml(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Pl(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:oe(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=oe(t.teardown));let a=Tn.safeParse(i);if(!a.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(a.error.errors)}`);let n=a.data;return Xa(e,n),n}function Pl(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let n={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:oe(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=oe(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(n.beforeAll=oe(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(n.afterAll=oe(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(n.beforeEach=oe(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(n.afterEach=oe(t.afterEach));let o=pi.safeParse(n);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function oe(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Cl)}function Cl(e){if(typeof e=="string")throw new Error(`Plain string statements are not supported. Use an object with a "desc" key instead. Example: { "desc": "${e}" }`);if(typeof e!="object"||e===null)throw new Error(`Invalid statement: expected object, got ${typeof e}`);let t=e;if("IF"in t)return Ol(t);if("WHILE"in t)return Ll(t);if("STEP"in t)return Nl(t);if("VERIFY"in t){let i=t.VERIFY,a={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(a.code=t.js),{uid:le(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:a}}}}if("URL"in t){let i=t.URL,a=t.new_tab===!0?!0:void 0,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return a&&(o.new_tab=!0),n!==void 0&&(o.timeout_seconds=n),{uid:le(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:le(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:a}}}}}if("WAIT"in t){let i=t.WAIT,a=typeof t.seconds=="number"?t.seconds:3;return{uid:le(),type:"ACTION",description:typeof i=="string"?i:`Wait ${a}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${a}s`,action_data:{action_name:"wait",kwargs:{seconds:a}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let a=typeof t.description=="string"?t.description:"Code block";return{uid:le(),type:"ACTION",description:a,action_entity:{action_description:a,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",a=t.js;return{uid:le(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof a=="string"?a:String(a)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...a}=t;return za({...a,action:"function",functionName:i})}if("action"in t)return za(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:le(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Va(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function Ol(e){let t=Va(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let a={uid:le(),type:"IF_ELSE",condition:t,then:oe(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(a.else=oe(e.ELSE)),a}function Ll(e){let t=Va(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let a={uid:le(),type:"WHILE_LOOP",condition:t,body:oe(i)};return typeof e.timeout_ms=="number"&&(a.timeout_ms=e.timeout_ms),a}function Nl(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:le(),type:"STEP",description:t,statements:oe(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let a=e.template_params,n={};for(let[o,r]of Object.entries(a))n[o]=String(r);i.template_params=n}return i}var Dl=new Set(["action","intent","desc","locator","xpath","use_pure_vision"]);function za(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",a=typeof e.locator=="string"?e.locator:void 0,n=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))Dl.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};a&&(s.locator=a),n&&(s.xpath=n);let l={uid:le(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Xa(e,t){let i;try{i=Il(e)}catch{return}let a=i.contents;if(!a||!mi(a))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=a.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let n=a,o=n.get("statements",!0);je(o)&&t.statements&&Ke(o,t.statements);let r=n.get("teardown",!0);je(r)&&t.teardown&&Ke(r,t.teardown)}function Ke(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let a=e.items[i];a.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=a.commentBefore);let n=t[i];if(n.type==="STEP"&&mi(a)){let o=a.get("statements",!0);je(o)&&Ke(o,n.statements)}else if(n.type==="IF_ELSE"&&mi(a)){let o=a.get("THEN",!0);je(o)&&Ke(o,n.then);let r=a.get("ELSE",!0);je(r)&&n.else&&Ke(r,n.else)}else if(n.type==="WHILE_LOOP"&&mi(a)){let o=a.get("DO",!0);je(o)&&Ke(o,n.body)}}}import{parse as cp,stringify as dp}from"yaml";var $n=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t};var gi=e=>{let t=[],i=a=>{for(let n of a){t.push(n);let o=$n(n);for(let r of o)i(r.statements)}};return i(e),t};var Rl=.5,Ya=5,Ja=3,Za=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"]);function Qa(e){let t=0,i=0;for(let a of e)if(a.type==="DRAFT")i++;else if(a.type==="ACTION"){let n=a.action_entity?.action_data?.action_name??"";Za.has(n)||t++}return{action:t,draft:i}}function Fl(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function qa(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Hl(e){let t=e.split(/\r?\n/).map(o=>o.trim()).filter(o=>o.length>0&&!o.startsWith("//")),i=t.length,a=t.join(`
4360
+ `).match(/\bawait\b/g),n=a?a.length:0;return i<=Ya&&n<=Ja?null:`${i} non-blank line(s), ${n} await(s) \u2014 limits are ${Ya} lines and ${Ja} awaits. The VERIFY js: field is a cache for one natural-language assertion, not a place for multi-step logic. Break this into multiple statements \u2014 one VERIFY per assertion \u2014 so each step is visible in the debugger and self-healable. For freeform setup code (mocking, storage), use the description: + js: escape hatch, which has no complexity cap.`}function Mn(e,t){let i=t?.coverageThreshold??Rl,a=[],n=[],o;try{o=xe(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||a.push('Missing required field: "goal"'),o.statements?.length||a.push('Missing required field: "statements"');let r=[...gi(o.statements??[]),...o.teardown?gi(o.teardown):[]],{action:s,draft:l}=Qa(r),c="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let m of r){let g=m;if(g.reference_id!==void 0){let f=g.description||m.uid;a.push(`Unresolved cloud template reference on statement "${f}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(m.type==="ACTION"){let f=m,y=f.action_entity?.action_data?.action_name??"";if(y==="js_code"||y==="js_action"||y==="verify"||y==="ai_assert"){let b=f.action_entity?.action_data?.kwargs?.code;if(typeof b=="string"){let p=Fl(b);if(p){let x=f.description||y;a.push(`Invalid JS in "${x}": ${p}. ${c}`)}else if(y==="verify"){let x=Hl(b);if(x){let S=f.description||y;a.push(`JS cache for "${S}" is too complex: ${x}`)}}}}}if(m.type==="IF_ELSE"){let f=m;if(f.condition.type==="JS_CODE"){let y=qa(f.condition.expression);y&&a.push(`Invalid JS in IF condition "${f.condition.expression}": ${y}. ${c}`)}}if(m.type==="WHILE_LOOP"){let f=m;if(f.condition.type==="JS_CODE"){let y=qa(f.condition.expression);y&&a.push(`Invalid JS in WHILE condition "${f.condition.expression}": ${y}. ${c}`)}}}let d=s+l,h=d>0?Math.round(s/d*100):0;return d>0&&h/100<i&&n.push(`Low action coverage: ${s}/${d} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:a.length===0,errors:a,warnings:n,stats:{total:d,action:s,draft:l,coverage:h}}}var eo=112;var Ul=1080-eo;var to={"Blackberry PlayBook":{name:"Blackberry PlayBook",userAgent:"Mozilla/5.0 (PlayBook; U; RIM Tablet OS 2.1.0; en-US) AppleWebKit/536.2+ (KHTML like Gecko) Version/26.0 Safari/536.2+",screen:{width:600,height:1024},viewport:{width:600,height:1024},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"BlackBerry Z30":{name:"BlackBerry Z30",userAgent:"Mozilla/5.0 (BB10; Touch) AppleWebKit/537.10+ (KHTML, like Gecko) Version/26.0 Mobile Safari/537.10+",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note 3":{name:"Galaxy Note 3",userAgent:"Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy Note II":{name:"Galaxy Note II",userAgent:"Mozilla/5.0 (Linux; U; Android 4.1; en-us; GT-N7100 Build/JRO03C) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S III":{name:"Galaxy S III",userAgent:"Mozilla/5.0 (Linux; U; Android 4.0; en-us; GT-I9300 Build/IMM76D) AppleWebKit/534.30 (KHTML, like Gecko) Version/26.0 Mobile Safari/534.30",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Galaxy S5":{name:"Galaxy S5",userAgent:"Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S8":{name:"Galaxy S8",userAgent:"Mozilla/5.0 (Linux; Android 7.0; SM-G950U Build/NRD90M) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:740},viewport:{width:360,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S9+":{name:"Galaxy S9+",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; SM-G965U Build/R16NW) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:320,height:658},viewport:{width:320,height:658},deviceScaleFactor:4.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy S24":{name:"Galaxy S24",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-S921U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:780},viewport:{width:360,height:780},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy A55":{name:"Galaxy A55",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-A556B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:480,height:1040},viewport:{width:480,height:1040},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S4":{name:"Galaxy Tab S4",userAgent:"Mozilla/5.0 (Linux; Android 8.1.0; SM-T837A) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:712,height:1138},viewport:{width:712,height:1138},deviceScaleFactor:2.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Galaxy Tab S9":{name:"Galaxy Tab S9",userAgent:"Mozilla/5.0 (Linux; Android 14; SM-X710) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:640,height:1024},viewport:{width:640,height:1024},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"iPad (gen 5)":{name:"iPad (gen 5)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 6)":{name:"iPad (gen 6)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 7)":{name:"iPad (gen 7)",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:810,height:1080},viewport:{width:810,height:1080},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad (gen 11)":{name:"iPad (gen 11)",userAgent:"Mozilla/5.0 (iPad; CPU OS 18_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/604.1",screen:{width:656,height:944},viewport:{width:656,height:944},deviceScaleFactor:2.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Mini":{name:"iPad Mini",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:768,height:1024},viewport:{width:768,height:1024},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPad Pro 11":{name:"iPad Pro 11",userAgent:"Mozilla/5.0 (iPad; CPU OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:834,height:1194},viewport:{width:834,height:1194},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6":{name:"iPhone 6",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 6 Plus":{name:"iPhone 6 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7":{name:"iPhone 7",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 7 Plus":{name:"iPhone 7 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8":{name:"iPhone 8",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 8 Plus":{name:"iPhone 8 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:414,height:736},viewport:{width:414,height:736},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE":{name:"iPhone SE",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_1 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/14E304 Safari/602.1",screen:{width:320,height:568},viewport:{width:320,height:568},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone SE (3rd gen)":{name:"iPhone SE (3rd gen)",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 18_5 like Mac OS X) AppleWebKit/603.1.30 (KHTML, like Gecko) Version/26.0 Mobile/19E241 Safari/602.1",screen:{width:375,height:667},viewport:{width:375,height:667},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone X":{name:"iPhone X",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/26.0 Mobile/15A372 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:812},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone XR":{name:"iPhone XR",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:896},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11":{name:"iPhone 11",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro":{name:"iPhone 11 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:635},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 11 Pro Max":{name:"iPhone 11 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:414,height:896},viewport:{width:414,height:715},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12":{name:"iPhone 12",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro":{name:"iPhone 12 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Pro Max":{name:"iPhone 12 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 12 Mini":{name:"iPhone 12 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 14_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13":{name:"iPhone 13",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro":{name:"iPhone 13 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Pro Max":{name:"iPhone 13 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 13 Mini":{name:"iPhone 13 Mini",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 15_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:375,height:812},viewport:{width:375,height:629},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14":{name:"iPhone 14",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:390,height:844},viewport:{width:390,height:664},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Plus":{name:"iPhone 14 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:428,height:926},viewport:{width:428,height:746},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro":{name:"iPhone 14 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:660},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 14 Pro Max":{name:"iPhone 14 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:740},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15":{name:"iPhone 15",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Plus":{name:"iPhone 15 Plus",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro":{name:"iPhone 15 Pro",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:393,height:852},viewport:{width:393,height:659},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"iPhone 15 Pro Max":{name:"iPhone 15 Pro Max",userAgent:"Mozilla/5.0 (iPhone; CPU iPhone OS 17_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Mobile/15E148 Safari/604.1",screen:{width:430,height:932},viewport:{width:430,height:739},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Kindle Fire HDX":{name:"Kindle Fire HDX",userAgent:"Mozilla/5.0 (Linux; U; en-us; KFAPWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.13 Safari/535.19 Silk-Accelerated=true",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"LG Optimus L70":{name:"LG Optimus L70",userAgent:"Mozilla/5.0 (Linux; U; Android 4.4.2; en-us; LGMS323 Build/KOT49I.MS32310c) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:1.25,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 550":{name:"Microsoft Lumia 550",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 550) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Microsoft Lumia 950":{name:"Microsoft Lumia 950",userAgent:"Mozilla/5.0 (Windows Phone 10.0; Android 4.2.1; Microsoft; Lumia 950) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36 Edge/14.14263",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:4,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 10":{name:"Nexus 10",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 10 Build/MOB31T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:800,height:1280},viewport:{width:800,height:1280},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 4":{name:"Nexus 4",userAgent:"Mozilla/5.0 (Linux; Android 4.4.2; Nexus 4 Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:384,height:640},viewport:{width:384,height:640},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5":{name:"Nexus 5",userAgent:"Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 5X":{name:"Nexus 5X",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 5X Build/OPR4.170623.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6":{name:"Nexus 6",userAgent:"Mozilla/5.0 (Linux; Android 7.1.1; Nexus 6 Build/N6F26U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 6P":{name:"Nexus 6P",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Nexus 6P Build/OPP3.170518.006) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:732},viewport:{width:412,height:732},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nexus 7":{name:"Nexus 7",userAgent:"Mozilla/5.0 (Linux; Android 6.0.1; Nexus 7 Build/MOB30X) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:600,height:960},viewport:{width:600,height:960},deviceScaleFactor:2,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia Lumia 520":{name:"Nokia Lumia 520",userAgent:"Mozilla/5.0 (compatible; MSIE 10.0; Windows Phone 8.0; Trident/6.0; IEMobile/10.0; ARM; Touch; NOKIA; Lumia 520)",screen:{width:320,height:533},viewport:{width:320,height:533},deviceScaleFactor:1.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Nokia N9":{name:"Nokia N9",userAgent:"Mozilla/5.0 (MeeGo; NokiaN9) AppleWebKit/534.13 (KHTML, like Gecko) NokiaBrowser/8.5.0 Mobile Safari/534.13",screen:{width:480,height:854},viewport:{width:480,height:854},deviceScaleFactor:1,isMobile:!0,hasTouch:!0,defaultBrowserType:"webkit"},"Pixel 2":{name:"Pixel 2",userAgent:"Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:731},viewport:{width:411,height:731},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 2 XL":{name:"Pixel 2 XL",userAgent:"Mozilla/5.0 (Linux; Android 8.0.0; Pixel 2 XL Build/OPD1.170816.004) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:411,height:823},viewport:{width:411,height:823},deviceScaleFactor:3.5,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 3":{name:"Pixel 3",userAgent:"Mozilla/5.0 (Linux; Android 9; Pixel 3 Build/PQ1A.181105.017.A1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:786},viewport:{width:393,height:786},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4":{name:"Pixel 4",userAgent:"Mozilla/5.0 (Linux; Android 10; Pixel 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:353,height:745},viewport:{width:353,height:745},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 4a (5G)":{name:"Pixel 4a (5G)",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 4a (5G)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:892},viewport:{width:412,height:765},deviceScaleFactor:2.63,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 5":{name:"Pixel 5",userAgent:"Mozilla/5.0 (Linux; Android 11; Pixel 5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:393,height:851},viewport:{width:393,height:727},deviceScaleFactor:2.75,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Pixel 7":{name:"Pixel 7",userAgent:"Mozilla/5.0 (Linux; Android 14; Pixel 7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:412,height:915},viewport:{width:412,height:839},deviceScaleFactor:2.625,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Moto G4":{name:"Moto G4",userAgent:"Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Mobile Safari/537.36",screen:{width:360,height:640},viewport:{width:360,height:640},deviceScaleFactor:3,isMobile:!0,hasTouch:!0,defaultBrowserType:"chromium"},"Desktop Chrome HiDPI":{name:"Desktop Chrome HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge HiDPI":{name:"Desktop Edge HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Firefox HiDPI":{name:"Desktop Firefox HiDPI",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"},"Desktop Safari":{name:"Desktop Safari",userAgent:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.0 Safari/605.1.15",screen:{width:1792,height:1120},viewport:{width:1280,height:720},deviceScaleFactor:2,isMobile:!1,hasTouch:!1,defaultBrowserType:"webkit"},"Desktop Chrome":{name:"Desktop Chrome",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome Medium Resolution":{name:"Desktop Chrome Medium Resolution",displayName:"Playwright Chromium",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Chrome (Branded)":{name:"Desktop Chrome (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Chrome Medium Resolution (Branded)":{name:"Desktop Chrome Medium Resolution (Branded)",displayName:"Google Chrome",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"chrome"},"Desktop Edge":{name:"Desktop Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium"},"Desktop Edge (Branded)":{name:"Desktop Edge (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1920,height:1080},viewport:{width:1920,height:1080},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Edge Medium Resolution (Branded)":{name:"Desktop Edge Medium Resolution (Branded)",displayName:"Microsoft Edge",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/141.0.7390.16 Safari/537.36 Edg/141.0.7390.16",screen:{width:1280,height:720},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"chromium",channel:"msedge"},"Desktop Firefox":{name:"Desktop Firefox",userAgent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:142.0.1) Gecko/20100101 Firefox/142.0.1",screen:{width:1920,height:1080},viewport:{width:1280,height:720},deviceScaleFactor:1,isMobile:!1,hasTouch:!1,defaultBrowserType:"firefox"}};var io={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},ht=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),io[e].map(a=>to[a]).filter(a=>a.defaultBrowserType&&i.includes(a.defaultBrowserType))};var Bl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile")}},Gl={desktop:{label:"Desktop",type:"desktop",devices:ht("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ht("mobile",!0)}};function In(){return{version:"1.0",entries:{}}}var ce=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ce||{});var Pn=18e4;import{stringify as Kl}from"yaml";import{createHash as cc}from"crypto";import{parse as dc,stringify as ho}from"yaml";import{readFileSync as uc,existsSync as hc}from"fs";import{resolve as On,dirname as pc}from"path";import{parse as ro,stringify as mc}from"yaml";import{readFileSync as Ug,writeFileSync as vc,mkdirSync as _c}from"fs";import{dirname as kc}from"path";var Ln=5e3;function ue(e){return e.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(/\n/g,"\\n").replace(/\r/g,"\\r").replace(/\t/g,"\\t")}function B(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function zl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Vl(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function wi(e){let t=zl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let a=Vl(e);if(a){let n=JSON.stringify(a);return`${t}.locator(${n}).first()`}return null}var Xl=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Yl=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"];function no(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:Xl.includes(t)}function Jl(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!Yl.includes(t)}var Z=new Map;function $(e,t){Z.set(e,t)}function ql(e){return Z.get(e)}function Fe(e,t,i=[]){let a=[...i];return t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`),a.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}$("click",e=>{let t=wi(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Ln;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",Z.get("click"));$("click_element_by_index",Z.get("click"));$("double_click",e=>Fe("double_click",e));$("double_click_on_element",Z.get("double_click"));$("right_click",e=>Fe("right_click",e));$("right_click_on_element",Z.get("right_click"));$("hover",e=>Fe("hover",e));$("hover_element_by_index",Z.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Fe("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",Z.get("input_text"));$("clear_input",e=>Fe("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",Z.get("press"));$("send_keys_on_element",e=>{let t=wi(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let a=e.action_data?.kwargs?.timeout_ms??Ln;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${a} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Fe("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",Z.get("scroll"));$("scroll_up",Z.get("scroll"));$("scroll_element",Z.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Fe("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",Z.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,a=typeof i?.code=="string",n=a?i?.statement||e.action_description:e.action_description||i?.statement;if(a&&n){let r=i.code.split(`
4361
4361
  `),s=JSON.stringify(n);return["{ const _t = Date.now(); try {",...r.map(l=>` ${l}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${s}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${s}\`);`,` await agent.assert(page, ${s}, ${JSON.stringify(t||"")});`,"} }"]}return a?i.code.split(`
4362
- `):n?[`await agent.assert(page, ${JSON.stringify(n)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});M("ai_assert",Z.get("verify"));M("assert",Z.get("verify"));M("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]});M("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});M("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]});M("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});M("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});M("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],a=t.split(`
4363
- `);for(let n of a)i.push(` ${n}`);return i.push("}"),i});M("function",(e,t,i)=>{let a=e.action_data?.kwargs||{},n=a.functionName;if(n&&n.includes("#")){let[r,s]=n.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${s} } from '${l}';`;i?.imports?.add(c);let d={...a,functionName:s},h=no(d);return h?[h.endsWith(";")?h:`${h};`]:["// Skipping function: invalid export pattern"]}}let o=no(a);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});M("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});M("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],a={};return t.paths?a.paths=t.paths:t.path&&(a.path=t.path),t.use_file_input&&(a.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(n=>` ${n},`),"});"]});M("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);M("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);M("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});M("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(a=>` ${a},`),"});"]});M("done",()=>["// Done - no action needed"]);M("extract_email_content",e=>{let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]});M("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4364
- `):["// Skipping js_action: missing code"]});function no(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let a=["page","testContext","request","agent"],n=["undefined","null","true","false"],o=i.map(r=>a.includes(r)||n.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}function he(e,t,i,a="main"){let n=[];for(let o=0;o<e.length;o++){let r=e[o],s=`${a}.${o}`,l=ql(r,t,s,i);l.length>0&&(n.push(...l),o<e.length-1&&n.push(""))}return n}function ql(e,t,i,a){let n=" ".repeat(t);switch(e.type){case"DRAFT":return Zl(e,t,i,a);case"ACTION":return Ql(e,t,i,a);case"STEP":return ec(e,t,i,a);case"IF_ELSE":return tc(e,t,i,a);case"WHILE_LOOP":return ic(e,t,i,a);default:return[`${n}// Unknown statement type: ${e.type}`]}}function Zl(e,t,i,a){let n=" ".repeat(t),o=e.description?.trim()||"";if(!o)return[`${n}// ${i}: Skipping - no description`];if(a.noAgent)return[`${n}// ${i}: ${B(o)}`,`${n}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let r=JSON.stringify(o);return[`${n}// ${i}: ${B(o)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.run(page, ${r}, '${i}');`]}function Ql(e,t,i,a){let n=" ".repeat(t),o=e.description,r=e.uid,l=a.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!l){if(!o)return[`${n}// ${i}: Skipping - no description`];if(a.noAgent)return[`${n}// ${i}: ${B(o)}`,`${n}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let S=JSON.stringify(o),E=!!e.use_pure_vision;return[`${n}// ${i}: ${B(o)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.execute(page, ${S}, '${i}', ${E});`]}let c=e.locator?{...l,locator:e.locator}:l;o&&o!==c.action_description&&(c={...c,action_description:o});let d=c.action_data?.action_name||"",h=c.action_description||"",p=Jl(d);if(!p)return[`${n}// ${i}: Unknown action: ${d}`];let g={imports:a.imports},f=p(c,i,g);if(a.noAgent){if(io(c))return[`${n}// ${i}: ${B(h)}`,`${n}// AI action: ${B(h)} (requires agent - skipped in hook)`];let S=nc(c,d,n,i);return S||[`${n}// ${i}: ${B(h)}`,...f.map(E=>`${n}${E}`)]}if(io(c))return[`${n}// ${i}: ${B(h)}`,`${n}page = agent.agentServices.validatePage(page);`,...f.map(S=>`${n}${S}`)];let y=JSON.stringify(h),b=f.map(S=>`${n} ${S}`),m=Yl(c),x=r?`'${r}'`:"undefined";return[`${n}// ${i}: ${B(h)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.step(page, async () => {`,...b,`${n}}, ${y}, '${i}', ${x}, ${m});`]}function ec(e,t,i,a){let n=" ".repeat(t),o=[];e.description&&e.description.trim()&&o.push(`${n}// Step: ${B(e.description)}`);let r=he(e.statements,t,a,i);return o.push(...r),o}function tc(e,t,i,a){let n=" ".repeat(t),o=[];if(o.push(`${n}// ${i}: Conditional check`),e.condition.type==="JS_CODE")o.push(`${n}if (${e.condition.expression}) {`);else{o.push(`${n}// AI Condition: ${B(e.condition.expression)}`);let s=JSON.stringify(e.condition.expression);o.push(`${n}if (await agent.evaluate(page, ${s}, "${i}")) {`)}let r=he(e.then,t+1,a,`${i}.then`);if(o.push(...r),e.else&&e.else.length>0){o.push(`${n}} else {`);let s=he(e.else,t+1,a,`${i}.else`);o.push(...s)}return o.push(`${n}}`),o}function ic(e,t,i,a){let n=" ".repeat(t),o=[];o.push(`${n}// ${i}: Loop`);let r=e.timeout_ms??Pn,s=r/1e3,l=e.timeout_ms?`While loop exceeded timeout of ${s}s`:`While loop exceeded default timeout of ${s}s`,c=`loop_${i.replace(/\./g,"_")}`;if(o.push(`${n}const ${c}_start = Date.now();`),o.push(`${n}const ${c}_timeout = ${r};`),o.push(`${n}const ${c}_check = () => {`),o.push(`${n} if (Date.now() - ${c}_start > ${c}_timeout) {`),o.push(`${n} throw new Error('${l}');`),o.push(`${n} }`),o.push(`${n} return true;`),o.push(`${n}};`),e.condition.type==="JS_CODE")o.push(`${n}while (${c}_check() && (${e.condition.expression})) {`);else{o.push(`${n}// AI Loop Condition: ${B(e.condition.expression)}`);let h=JSON.stringify(e.condition.expression);o.push(`${n}while (${c}_check() && await agent.evaluate(page, ${h}, "${i}")) {`)}let d=he(e.body,t+1,a,`${i}.body`);return o.push(...d),o.push(`${n}}`),o}function nc(e,t,i,a){let n=e.action_description||"",o=e.action_data?.kwargs||{},r=o.timeout_ms??Ln;switch(t){case"go_to_url":case"open_tab":{let s=o.url||"";return[`${i}// ${a}: ${B(n)}`,`${i}await page.goto(${JSON.stringify(s)}, { waitUntil: 'domcontentloaded' });`]}case"go_back":return[`${i}// ${a}: ${B(n)}`,`${i}await page.goBack();`];case"go_forward":return[`${i}// ${a}: ${B(n)}`,`${i}await page.goForward();`];case"input_text":{let s=o.text||"",l=wi(e);return l?[`${i}// ${a}: ${B(n)}`,`${i}await ${l}.fill(${JSON.stringify(s)}, { timeout: ${r} });`]:null}case"select_dropdown_option":{let s=o.text||o.label||"",l=wi(e);return l?[`${i}// ${a}: ${B(n)}`,`${i}await ${l}.selectOption({ label: ${JSON.stringify(s)} }, { timeout: ${r} });`]:null}default:return null}}function ac(e,t){let i=[],a=t?.version||"unknown";i.push(`// @generated by shiplightai v${a}`),i.push(...lo()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let n=new Set,o={imports:n,actionEntityStore:t?.actionEntityStore};t?.beforeEach&&t.beforeEach.length>0&&(i.push(...ao("beforeEach",t.beforeEach,o)),i.push(""));let r=t?.timeout||t?.skip!==void 0||t?.fail!==void 0||t?.only||t?.slow?{timeout:t.timeout,skip:t.skip,fail:t.fail,only:t.only,slow:t.slow}:void 0;if(t?.parameters&&t.parameters.length>0){let s=t?.testName||e.goal||"Generated test",l=Cn(t?.tags);for(let c of t.parameters)i.push(...yi(e,`${l}${ue(s)} [${ue(c.name)}]`,o,0,r,c.name,c.values)),i.push("")}else{let s=t?.testName||e.goal||"Generated test",l=Cn(t?.tags);i.push(...yi(e,`${l}${ue(s)}`,o,0,r))}return t?.afterEach&&t.afterEach.length>0&&(i.push(""),i.push(...ao("afterEach",t.afterEach,o))),co(i,n),i.join(`
4365
- `)}function oc(e,t){let i=[],a=t?.version||"unknown";i.push(`// @generated by shiplightai v${a}`),i.push(...lo()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let n=new Set,o={imports:n,actionEntityStore:t?.actionEntityStore},r=t?.testName||"Test Suite",s=Cn(t?.tags);i.push(`test.describe.serial('${s}${ue(r)}', () => {`),e.beforeAll&&e.beforeAll.length>0&&(i.push(...fi("beforeAll",e.beforeAll,o,1)),i.push("")),e.beforeEach&&e.beforeEach.length>0&&(i.push(...fi("beforeEach",e.beforeEach,o,1)),i.push(""));for(let c=0;c<e.tests.length;c++){let d=e.tests[c],h=d.timeout||d.skip!==void 0||d.fail!==void 0||d.only||d.slow?{timeout:d.timeout,skip:d.skip,fail:d.fail,only:d.only,slow:d.slow}:void 0;if(d.parameters&&d.parameters.length>0)for(let p of d.parameters)i.push(...yi(d.testFlow,`${ue(d.name)} [${ue(p.name)}]`,o,1,h,p.name,p.values)),i.push("");else i.push(...yi(d.testFlow,ue(d.name),o,1,h)),(c<e.tests.length-1||e.afterEach||e.afterAll)&&i.push("")}return e.afterEach&&e.afterEach.length>0&&(i.push(...fi("afterEach",e.afterEach,o,1)),i.push("")),e.afterAll&&e.afterAll.length>0&&i.push(...fi("afterAll",e.afterAll,o,1)),i.push("});"),co(i,n),i.join(`
4366
- `)}function Cn(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}var rc=["testContext","request"];function bi(e){let t=new Set;function i(a){for(let n of a)switch(n.type){case ce.ACTION:{let r=n.action_entity?.action_data?.kwargs;if(r?.args&&Array.isArray(r.args))for(let s of r.args)typeof s=="string"&&rc.includes(s)&&t.add(s);break}case ce.STEP:i(n.statements);break;case ce.IF_ELSE:{let o=n;i(o.then),o.else&&i(o.else);break}case ce.WHILE_LOOP:i(n.body);break}}return i(e),t}function sc(e){let t=bi(e.statements??[]);if(e.teardown)for(let i of bi(e.teardown))t.add(i);return t}function Nn(e){return`{ ${["page","agent",...Array.from(e).sort()].join(", ")} }`}function yi(e,t,i,a=0,n,o,r){let s=" ".repeat(a),l=[],c=sc(e),d=Nn(c),h=n?.only?"test.only":"test",p=o?`, { tag: '@${ue(o)}' }`:"";if(l.push(`${s}${h}('${t}'${p}, async (${d}) => {`),n?.skip===!0?l.push(`${s} test.skip();`):typeof n?.skip=="string"&&l.push(`${s} test.skip(true, '${ue(n.skip)}');`),n?.fail===!0?l.push(`${s} test.fail();`):typeof n?.fail=="string"&&l.push(`${s} test.fail(true, '${ue(n.fail)}');`),n?.slow&&l.push(`${s} test.slow();`),n?.timeout&&l.push(`${s} test.setTimeout(${n.timeout});`),r){for(let[y,b]of Object.entries(r))l.push(`${s} agent.agentServices.saveVariable(${JSON.stringify(y)}, ${JSON.stringify(b)});`);l.push("")}let g=e.teardown&&e.teardown.length>0,f=a+1;if(g){if(l.push(`${s} try {`),e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let b=he(e.statements,f+1,i);l.push(...b)}l.push(`${s} } finally {`),l.push(`${s} // Teardown`);let y=he(e.teardown,f+1,i,"teardown");l.push(...y),l.push(`${s} }`)}else if(e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let y=he(e.statements,f,i);l.push(...y)}return l.push(`${s}});`),l}function ao(e,t,i){let a=[],n=so(t),o=bi(n),r=Nn(o);return a.push(`test.${e}(async (${r}) => {`),a.push(...he(n,1,i,e)),a.push("});"),a}function fi(e,t,i,a){let n=" ".repeat(a),o=[],r=so(t);if(e==="beforeAll"||e==="afterAll"){let l={...i,noAgent:!0};o.push(`${n}test.${e}(async ({ browser }, workerInfo) => {`),o.push(`${n} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),o.push(...he(r,a+1,l,e)),o.push(`${n} await page.close();`),o.push(`${n}});`)}else{let l=bi(r),c=Nn(l);o.push(`${n}test.${e}(async (${c}) => {`),o.push(...he(r,a+1,i,e)),o.push(`${n}});`)}return o}function so(e){let i=jl({goal:"_hook",statements:e});return xe(i).statements??[]}function lo(){return["import { test, expect } from 'shiplightai/fixture';"]}function co(e,t){if(t.size>0){let i=0;for(let n=0;n<e.length;n++)e[n].startsWith("import ")&&(i=n+1);let a=Array.from(t);e.splice(i,0,...a)}}var ro=5;function ho(e,t,i){let a={expandingPaths:new Set([On(t)]),depth:0,referencedPaths:new Set,basePath:i},n={...e};Array.isArray(n.statements)&&(n.statements=Oe(n.statements,t,a)),Array.isArray(n.teardown)&&(n.teardown=Oe(n.teardown,t,a));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[o])&&(n[o]=Oe(n[o],t,a));return{doc:n,referencedTemplatePaths:Array.from(a.referencedPaths)}}function Oe(e,t,i){let a=[];for(let n of e)if(pc(n)){let o=gc(n,t,i);a.push(o)}else a.push(fc(n,t,i));return a}function pc(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function gc(e,t,i){if(i.depth>=ro)throw new Error(`Template expansion exceeded maximum depth of ${ro}. Check for deeply nested or circular template references.`);let a=On(hc(t),e.template),n=!uc(a)&&i.basePath?On(i.basePath,e.template):a;if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let o;try{o=dc(n,"utf-8")}catch(f){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${f.message}`)}let r=oo(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let s=r.params||[],l=e.params||{};for(let f of s)if(!(f in l))throw new Error(`Template ${e.template} requires param "${f}" but it was not provided. Required params: [${s.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(l).length>0){let y=mc(c);for(let[b,m]of Object.entries(l))y=y.split(`<<${b}>>`).join(String(m));c=oo(y)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths},h=Oe(c,n,d),g={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:h};return Object.keys(l).length>0&&(g.template_params=l),g}function fc(e,t,i){if(typeof e!="object"||e===null)return e;let a={...e};return Array.isArray(a.statements)&&(a.statements=Oe(a.statements,t,i)),Array.isArray(a.THEN)&&(a.THEN=Oe(a.THEN,t,i)),Array.isArray(a.ELSE)&&(a.ELSE=Oe(a.ELSE,t,i)),Array.isArray(a.DO)&&(a.DO=Oe(a.DO,t,i)),a}var Dn=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}};function Rn(e,t,i){let a=cc(e),n=a?.name,o=a?.tags,r=a?.use;if(a&&(a.name!==void 0||a.tags!==void 0||a.use!==void 0)&&(delete a.name,delete a.tags,delete a.use),a?.suite){if(a.goal||a.statements)throw new Dn('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return bc(a,n,o,r,t,i)}return wc(a,n,o,r,t,i)}function wc(e,t,i,a,n,o){let r=e?.beforeEach,s=e?.afterEach,l=mo(e?.parameters),c=e?.timeout,d=e?.skip,h=e?.fail,p=e?.only,g=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new Dn(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let f=[];if(n&&e&&typeof e=="object"){let m=ho(e,n,o);e=m.doc,f=m.referencedTemplatePaths}let y=uo(e),b=xe(y);return n&&(ze(b.statements??[],n,"main"),b.teardown&&ze(b.teardown,n,"teardown")),{testFlow:b,name:t,tags:i,use:a,beforeEach:r,afterEach:s,parameters:l,timeout:c,skip:d,fail:h,only:p,slow:g,referencedTemplatePaths:f}}function bc(e,t,i,a,n,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let s=r.beforeAll,l=r.afterAll,c=r.beforeEach,d=r.afterEach,h=[],p=r.tests.map(y=>{if(!y.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(y.statements)||y.statements.length===0)throw new Error(`Suite test "${y.name}" must have a non-empty "statements" array.`);let b={goal:y.name,statements:y.statements};y.teardown&&(b.teardown=y.teardown);let m=[],x=b;if(n&&typeof b=="object"){let $=ho(b,n,o);x=$.doc,m=$.referencedTemplatePaths,h.push(...m)}let S=uo(x),E=xe(S),A=mo(y.parameters);return{testFlow:E,name:y.name,tags:Array.isArray(y.tags)?y.tags:void 0,parameters:A,timeout:y.timeout,skip:y.skip,fail:y.fail,only:y.only,slow:y.slow}}),g=r.base_url,f=g?{...a,baseURL:g}:a;return{suite:{beforeAll:s,afterAll:l,beforeEach:c,afterEach:d,tests:p},name:t,tags:i,use:f,referencedTemplatePaths:h}}function mo(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function ze(e,t,i){for(let a=0;a<e.length;a++){let n=e[a],o=`${i}.${a}`,r=n.description||"";if(n.uid=yc(t,o,r),n.type===ce.STEP)ze(n.statements,t,o);else if(n.type===ce.IF_ELSE){let s=n;ze(s.then,t,`${o}.then`),s.else&&ze(s.else,t,`${o}.else`)}else n.type===ce.WHILE_LOOP&&ze(n.body,t,`${o}.body`)}}function yc(e,t,i){let a=lc("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${a.slice(0,8)}-${a.slice(8,12)}-${a.slice(12,16)}-${a.slice(16,20)}-${a.slice(20,32)}`}function po(e,t,i){let a=/\btemplate:\s/.test(e),n=/^suite:/m.test(e),o=a||n?null:Mn(e);if(o&&!o.valid)return{valid:!1,errors:o.errors,warnings:[],stats:o.stats};let r,s,l=[];try{let c=i?.parsed??Rn(e,t);l=c.referencedTemplatePaths;let d={version:i?.version,actionEntityStore:i?.actionEntityStore},h=c.testFlow?.baseURL?{...c.use,baseURL:c.testFlow.baseURL}:c.use;c.suite?r=oc(c.suite,{...d,testName:c.name,tags:c.tags,use:c.use}):r=ac(c.testFlow,{...d,testName:c.name,tags:c.tags,use:h,beforeEach:c.beforeEach,afterEach:c.afterEach,parameters:c.parameters,timeout:c.timeout,skip:c.skip,fail:c.fail,only:c.only,slow:c.slow});let p=r.split(`
4362
+ `):n?[`await agent.assert(page, ${JSON.stringify(n)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",Z.get("verify"));$("assert",Z.get("verify"));$("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let a=JSON.stringify(i),n=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${a}, '${t||""}', ${n});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,a=e.action_data?.kwargs?.variable_name;if(!i||!a)return["// Skipping ai_extract: missing element_description or variable_name"];let n=JSON.stringify(i),o=JSON.stringify(a);return[`await agent.extract(page, ${n}, ${o}, '${t||""}');`]});$("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,a=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${a}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});$("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],a=t.split(`
4363
+ `);for(let n of a)i.push(` ${n}`);return i.push("}"),i});$("function",(e,t,i)=>{let a=e.action_data?.kwargs||{},n=a.functionName;if(n&&n.includes("#")){let[r,s]=n.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${s} } from '${l}';`;i?.imports?.add(c);let d={...a,functionName:s},h=ao(d);return h?[h.endsWith(";")?h:`${h};`]:["// Skipping function: invalid export pattern"]}}let o=ao(a);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],a={};return t.paths?a.paths=t.paths:t.path&&(a.path=t.path),t.use_file_input&&(a.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(a)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(n=>` ${n},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(a=>` ${a},`),"});"]});$("done",()=>["// Done - no action needed"]);function Nn(e,t){let i=t.action_data?.kwargs||{},a=[];return typeof i.relative_x=="number"&&typeof i.relative_y=="number"?(a.push(`action_data: { kwargs: { relative_x: ${i.relative_x}, relative_y: ${i.relative_y} } }`),t.locator?a.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&a.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(t.frame_path)}`)):typeof i.x=="number"&&typeof i.y=="number"&&a.push(`action_data: { kwargs: { x: ${i.x}, y: ${i.y} } }`),[`await agent.execAction("${e}", page, {`,...a.map(n=>` ${n},`),"});"]}$("click_by_coordinates",e=>Nn("click_by_coordinates",e));$("right_click_by_coordinates",e=>Nn("right_click_by_coordinates",e));$("double_click_by_coordinates",e=>Nn("double_click_by_coordinates",e));$("drag_drop",e=>{let t=e.action_data?.kwargs||{},i={};typeof t.relative_x=="number"&&(i.relative_x=t.relative_x),typeof t.relative_y=="number"&&(i.relative_y=t.relative_y),typeof t.delta_x=="number"&&(i.delta_x=t.delta_x),typeof t.delta_y=="number"&&(i.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(i.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(i.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(i.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(i.coord_target_y=t.coord_target_y);let a=[`action_data: { kwargs: ${JSON.stringify(i)} }`];return e.locator?a.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&a.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&a.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...a.map(n=>` ${n},`),"});"]});$("get_dropdown_options",e=>{let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]});$("extract_email_content",e=>{let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]});$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4364
+ `):["// Skipping js_action: missing code"]});function ao(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let a=["page","testContext","request","agent"],n=["undefined","null","true","false"],o=i.map(r=>a.includes(r)||n.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}function he(e,t,i,a="main"){let n=[];for(let o=0;o<e.length;o++){let r=e[o],s=`${a}.${o}`,l=Zl(r,t,s,i);l.length>0&&(n.push(...l),o<e.length-1&&n.push(""))}return n}function Zl(e,t,i,a){let n=" ".repeat(t);switch(e.type){case"DRAFT":return Ql(e,t,i,a);case"ACTION":return ec(e,t,i,a);case"STEP":return tc(e,t,i,a);case"IF_ELSE":return ic(e,t,i,a);case"WHILE_LOOP":return nc(e,t,i,a);default:return[`${n}// Unknown statement type: ${e.type}`]}}function Ql(e,t,i,a){let n=" ".repeat(t),o=e.description?.trim()||"";if(!o)return[`${n}// ${i}: Skipping - no description`];if(a.noAgent)return[`${n}// ${i}: ${B(o)}`,`${n}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let r=JSON.stringify(o);return[`${n}// ${i}: ${B(o)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.run(page, ${r}, '${i}');`]}function ec(e,t,i,a){let n=" ".repeat(t),o=e.description,r=e.uid,l=a.actionEntityStore?.entries[e.uid]?.action_entity??e.action_entity;if(!l){if(!o)return[`${n}// ${i}: Skipping - no description`];if(a.noAgent)return[`${n}// ${i}: ${B(o)}`,`${n}// DRAFT: ${B(o)} (requires agent - skipped in hook)`];let S=JSON.stringify(o),E=!!e.use_pure_vision;return[`${n}// ${i}: ${B(o)}`,`${n}// \u26A0 DRAFT: AI-resolved at runtime (~5-10s). Add a locator to make this <1s.`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.execute(page, ${S}, '${i}', ${E});`]}let c=e.locator?{...l,locator:e.locator}:l;o&&o!==c.action_description&&(c={...c,action_description:o});let d=c.action_data?.action_name||"",h=c.action_description||"",m=ql(d);if(!m)return[`${n}// ${i}: Unknown action: ${d}`,`${n}throw new Error(${JSON.stringify(`Unknown action: ${d}`)});`];let g={imports:a.imports},f=m(c,i,g);if(a.noAgent){if(no(c))return[`${n}// ${i}: ${B(h)}`,`${n}// AI action: ${B(h)} (requires agent - skipped in hook)`];let S=ac(c,d,n,i);return S||[`${n}// ${i}: ${B(h)}`,...f.map(E=>`${n}${E}`)]}if(no(c))return[`${n}// ${i}: ${B(h)}`,`${n}page = agent.agentServices.validatePage(page);`,...f.map(S=>`${n}${S}`)];let y=JSON.stringify(h),b=f.map(S=>`${n} ${S}`),p=Jl(c),x=r?`'${r}'`:"undefined";return[`${n}// ${i}: ${B(h)}`,`${n}page = agent.agentServices.validatePage(page);`,`${n}await agent.step(page, async () => {`,...b,`${n}}, ${y}, '${i}', ${x}, ${p});`]}function tc(e,t,i,a){let n=" ".repeat(t),o=[];e.description&&e.description.trim()&&o.push(`${n}// Step: ${B(e.description)}`);let r=he(e.statements,t,a,i);return o.push(...r),o}function ic(e,t,i,a){let n=" ".repeat(t),o=[];if(o.push(`${n}// ${i}: Conditional check`),e.condition.type==="JS_CODE")o.push(`${n}if (${e.condition.expression}) {`);else{o.push(`${n}// AI Condition: ${B(e.condition.expression)}`);let s=JSON.stringify(e.condition.expression);o.push(`${n}if (await agent.evaluate(page, ${s}, "${i}")) {`)}let r=he(e.then,t+1,a,`${i}.then`);if(o.push(...r),e.else&&e.else.length>0){o.push(`${n}} else {`);let s=he(e.else,t+1,a,`${i}.else`);o.push(...s)}return o.push(`${n}}`),o}function nc(e,t,i,a){let n=" ".repeat(t),o=[];o.push(`${n}// ${i}: Loop`);let r=e.timeout_ms??Pn,s=r/1e3,l=e.timeout_ms?`While loop exceeded timeout of ${s}s`:`While loop exceeded default timeout of ${s}s`,c=`loop_${i.replace(/\./g,"_")}`;if(o.push(`${n}const ${c}_start = Date.now();`),o.push(`${n}const ${c}_timeout = ${r};`),o.push(`${n}const ${c}_check = () => {`),o.push(`${n} if (Date.now() - ${c}_start > ${c}_timeout) {`),o.push(`${n} throw new Error('${l}');`),o.push(`${n} }`),o.push(`${n} return true;`),o.push(`${n}};`),e.condition.type==="JS_CODE")o.push(`${n}while (${c}_check() && (${e.condition.expression})) {`);else{o.push(`${n}// AI Loop Condition: ${B(e.condition.expression)}`);let h=JSON.stringify(e.condition.expression);o.push(`${n}while (${c}_check() && await agent.evaluate(page, ${h}, "${i}")) {`)}let d=he(e.body,t+1,a,`${i}.body`);return o.push(...d),o.push(`${n}}`),o}function ac(e,t,i,a){let n=e.action_description||"",o=e.action_data?.kwargs||{},r=o.timeout_ms??Ln;switch(t){case"go_to_url":case"open_tab":{let s=o.url||"";return[`${i}// ${a}: ${B(n)}`,`${i}await page.goto(${JSON.stringify(s)}, { waitUntil: 'domcontentloaded' });`]}case"go_back":return[`${i}// ${a}: ${B(n)}`,`${i}await page.goBack();`];case"go_forward":return[`${i}// ${a}: ${B(n)}`,`${i}await page.goForward();`];case"input_text":{let s=o.text||"",l=wi(e);return l?[`${i}// ${a}: ${B(n)}`,`${i}await ${l}.fill(${JSON.stringify(s)}, { timeout: ${r} });`]:null}case"select_dropdown_option":{let s=o.text||o.label||"",l=wi(e);return l?[`${i}// ${a}: ${B(n)}`,`${i}await ${l}.selectOption({ label: ${JSON.stringify(s)} }, { timeout: ${r} });`]:null}default:return null}}function oc(e,t){let i=[],a=t?.version||"unknown";i.push(`// @generated by shiplightai v${a}`),i.push(...co()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let n=new Set,o={imports:n,actionEntityStore:t?.actionEntityStore};t?.beforeEach&&t.beforeEach.length>0&&(i.push(...oo("beforeEach",t.beforeEach,o)),i.push(""));let r=t?.timeout||t?.skip!==void 0||t?.fail!==void 0||t?.only||t?.slow?{timeout:t.timeout,skip:t.skip,fail:t.fail,only:t.only,slow:t.slow}:void 0;if(t?.parameters&&t.parameters.length>0){let s=t?.testName||e.goal||"Generated test",l=Cn(t?.tags);for(let c of t.parameters)i.push(...yi(e,`${l}${ue(s)} [${ue(c.name)}]`,o,0,r,c.name,c.values)),i.push("")}else{let s=t?.testName||e.goal||"Generated test",l=Cn(t?.tags);i.push(...yi(e,`${l}${ue(s)}`,o,0,r))}return t?.afterEach&&t.afterEach.length>0&&(i.push(""),i.push(...oo("afterEach",t.afterEach,o))),uo(i,n),i.join(`
4365
+ `)}function rc(e,t){let i=[],a=t?.version||"unknown";i.push(`// @generated by shiplightai v${a}`),i.push(...co()),i.push(""),t?.use&&Object.keys(t.use).length>0&&(i.push(`test.use(${JSON.stringify(t.use,null,2)});`),i.push(""));let n=new Set,o={imports:n,actionEntityStore:t?.actionEntityStore},r=t?.testName||"Test Suite",s=Cn(t?.tags);i.push(`test.describe.serial('${s}${ue(r)}', () => {`),e.beforeAll&&e.beforeAll.length>0&&(i.push(...fi("beforeAll",e.beforeAll,o,1)),i.push("")),e.beforeEach&&e.beforeEach.length>0&&(i.push(...fi("beforeEach",e.beforeEach,o,1)),i.push(""));for(let c=0;c<e.tests.length;c++){let d=e.tests[c],h=d.timeout||d.skip!==void 0||d.fail!==void 0||d.only||d.slow?{timeout:d.timeout,skip:d.skip,fail:d.fail,only:d.only,slow:d.slow}:void 0;if(d.parameters&&d.parameters.length>0)for(let m of d.parameters)i.push(...yi(d.testFlow,`${ue(d.name)} [${ue(m.name)}]`,o,1,h,m.name,m.values)),i.push("");else i.push(...yi(d.testFlow,ue(d.name),o,1,h)),(c<e.tests.length-1||e.afterEach||e.afterAll)&&i.push("")}return e.afterEach&&e.afterEach.length>0&&(i.push(...fi("afterEach",e.afterEach,o,1)),i.push("")),e.afterAll&&e.afterAll.length>0&&i.push(...fi("afterAll",e.afterAll,o,1)),i.push("});"),uo(i,n),i.join(`
4366
+ `)}function Cn(e){return e&&e.length>0?e.map(t=>`@${t}`).join(" ")+" ":""}var sc=["testContext","request"];function bi(e){let t=new Set;function i(a){for(let n of a)switch(n.type){case ce.ACTION:{let r=n.action_entity?.action_data?.kwargs;if(r?.args&&Array.isArray(r.args))for(let s of r.args)typeof s=="string"&&sc.includes(s)&&t.add(s);break}case ce.STEP:i(n.statements);break;case ce.IF_ELSE:{let o=n;i(o.then),o.else&&i(o.else);break}case ce.WHILE_LOOP:i(n.body);break}}return i(e),t}function lc(e){let t=bi(e.statements??[]);if(e.teardown)for(let i of bi(e.teardown))t.add(i);return t}function Dn(e){return`{ ${["page","agent",...Array.from(e).sort()].join(", ")} }`}function yi(e,t,i,a=0,n,o,r){let s=" ".repeat(a),l=[],c=lc(e),d=Dn(c),h=n?.only?"test.only":"test",m=o?`, { tag: '@${ue(o)}' }`:"";if(l.push(`${s}${h}('${t}'${m}, async (${d}) => {`),n?.skip===!0?l.push(`${s} test.skip();`):typeof n?.skip=="string"&&l.push(`${s} test.skip(true, '${ue(n.skip)}');`),n?.fail===!0?l.push(`${s} test.fail();`):typeof n?.fail=="string"&&l.push(`${s} test.fail(true, '${ue(n.fail)}');`),n?.slow&&l.push(`${s} test.slow();`),n?.timeout&&l.push(`${s} test.setTimeout(${n.timeout});`),r){for(let[y,b]of Object.entries(r))l.push(`${s} agent.agentServices.saveVariable(${JSON.stringify(y)}, ${JSON.stringify(b)});`);l.push("")}let g=e.teardown&&e.teardown.length>0,f=a+1;if(g){if(l.push(`${s} try {`),e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let b=he(e.statements,f+1,i);l.push(...b)}l.push(`${s} } finally {`),l.push(`${s} // Teardown`);let y=he(e.teardown,f+1,i,"teardown");l.push(...y),l.push(`${s} }`)}else if(e.statements&&e.statements.length>0){l.push(`${s} // Test steps`);let y=he(e.statements,f,i);l.push(...y)}return l.push(`${s}});`),l}function oo(e,t,i){let a=[],n=lo(t),o=bi(n),r=Dn(o);return a.push(`test.${e}(async (${r}) => {`),a.push(...he(n,1,i,e)),a.push("});"),a}function fi(e,t,i,a){let n=" ".repeat(a),o=[],r=lo(t);if(e==="beforeAll"||e==="afterAll"){let l={...i,noAgent:!0};o.push(`${n}test.${e}(async ({ browser }, workerInfo) => {`),o.push(`${n} const page = await browser.newPage({ baseURL: workerInfo.project.use.baseURL });`),o.push(...he(r,a+1,l,e)),o.push(`${n} await page.close();`),o.push(`${n}});`)}else{let l=bi(r),c=Dn(l);o.push(`${n}test.${e}(async (${c}) => {`),o.push(...he(r,a+1,i,e)),o.push(`${n}});`)}return o}function lo(e){let i=Kl({goal:"_hook",statements:e});return xe(i).statements??[]}function co(){return["import { test, expect } from 'shiplightai/fixture';"]}function uo(e,t){if(t.size>0){let i=0;for(let n=0;n<e.length;n++)e[n].startsWith("import ")&&(i=n+1);let a=Array.from(t);e.splice(i,0,...a)}}var so=5;function po(e,t,i){let a={expandingPaths:new Set([On(t)]),depth:0,referencedPaths:new Set,basePath:i},n={...e};Array.isArray(n.statements)&&(n.statements=Oe(n.statements,t,a)),Array.isArray(n.teardown)&&(n.teardown=Oe(n.teardown,t,a));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[o])&&(n[o]=Oe(n[o],t,a));return{doc:n,referencedTemplatePaths:Array.from(a.referencedPaths)}}function Oe(e,t,i){let a=[];for(let n of e)if(gc(n)){let o=fc(n,t,i);a.push(o)}else a.push(wc(n,t,i));return a}function gc(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function fc(e,t,i){if(i.depth>=so)throw new Error(`Template expansion exceeded maximum depth of ${so}. Check for deeply nested or circular template references.`);let a=On(pc(t),e.template),n=!hc(a)&&i.basePath?On(i.basePath,e.template):a;if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let o;try{o=uc(n,"utf-8")}catch(f){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${f.message}`)}let r=ro(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let s=r.params||[],l=e.params||{};for(let f of s)if(!(f in l))throw new Error(`Template ${e.template} requires param "${f}" but it was not provided. Required params: [${s.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(l).length>0){let y=mc(c);for(let[b,p]of Object.entries(l))y=y.split(`<<${b}>>`).join(String(p));c=ro(y)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths},h=Oe(c,n,d),g={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:h};return Object.keys(l).length>0&&(g.template_params=l),g}function wc(e,t,i){if(typeof e!="object"||e===null)return e;let a={...e};return Array.isArray(a.statements)&&(a.statements=Oe(a.statements,t,i)),Array.isArray(a.THEN)&&(a.THEN=Oe(a.THEN,t,i)),Array.isArray(a.ELSE)&&(a.ELSE=Oe(a.ELSE,t,i)),Array.isArray(a.DO)&&(a.DO=Oe(a.DO,t,i)),a}var Rn=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}};function Fn(e,t,i){let a=dc(e),n=a?.name,o=a?.tags,r=a?.use;if(a&&(a.name!==void 0||a.tags!==void 0||a.use!==void 0)&&(delete a.name,delete a.tags,delete a.use),a?.suite){if(a.goal||a.statements)throw new Rn('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return yc(a,n,o,r,t,i)}return bc(a,n,o,r,t,i)}function bc(e,t,i,a,n,o){let r=e?.beforeEach,s=e?.afterEach,l=mo(e?.parameters),c=e?.timeout,d=e?.skip,h=e?.fail,m=e?.only,g=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new Rn(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let f=[];if(n&&e&&typeof e=="object"){let p=po(e,n,o);e=p.doc,f=p.referencedTemplatePaths}let y=ho(e),b=xe(y);return n&&(ze(b.statements??[],n,"main"),b.teardown&&ze(b.teardown,n,"teardown")),{testFlow:b,name:t,tags:i,use:a,beforeEach:r,afterEach:s,parameters:l,timeout:c,skip:d,fail:h,only:m,slow:g,referencedTemplatePaths:f}}function yc(e,t,i,a,n,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let s=r.beforeAll,l=r.afterAll,c=r.beforeEach,d=r.afterEach,h=[],m=r.tests.map(y=>{if(!y.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(y.statements)||y.statements.length===0)throw new Error(`Suite test "${y.name}" must have a non-empty "statements" array.`);let b={goal:y.name,statements:y.statements};y.teardown&&(b.teardown=y.teardown);let p=[],x=b;if(n&&typeof b=="object"){let M=po(b,n,o);x=M.doc,p=M.referencedTemplatePaths,h.push(...p)}let S=ho(x),E=xe(S),A=mo(y.parameters);return{testFlow:E,name:y.name,tags:Array.isArray(y.tags)?y.tags:void 0,parameters:A,timeout:y.timeout,skip:y.skip,fail:y.fail,only:y.only,slow:y.slow}}),g=r.base_url,f=g?{...a,baseURL:g}:a;return{suite:{beforeAll:s,afterAll:l,beforeEach:c,afterEach:d,tests:m},name:t,tags:i,use:f,referencedTemplatePaths:h}}function mo(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function ze(e,t,i){for(let a=0;a<e.length;a++){let n=e[a],o=`${i}.${a}`,r=n.description||"";if(n.uid=xc(t,o,r),n.type===ce.STEP)ze(n.statements,t,o);else if(n.type===ce.IF_ELSE){let s=n;ze(s.then,t,`${o}.then`),s.else&&ze(s.else,t,`${o}.else`)}else n.type===ce.WHILE_LOOP&&ze(n.body,t,`${o}.body`)}}function xc(e,t,i){let a=cc("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${a.slice(0,8)}-${a.slice(8,12)}-${a.slice(12,16)}-${a.slice(16,20)}-${a.slice(20,32)}`}function go(e,t,i){let a=/\btemplate:\s/.test(e),n=/^suite:/m.test(e),o=a||n?null:Mn(e);if(o&&!o.valid)return{valid:!1,errors:o.errors,warnings:[],stats:o.stats};let r,s,l=[];try{let c=i?.parsed??Fn(e,t,i?.basePath);l=c.referencedTemplatePaths;let d={version:i?.version,actionEntityStore:i?.actionEntityStore},h=c.testFlow?.baseURL?{...c.use,baseURL:c.testFlow.baseURL}:c.use;c.suite?r=rc(c.suite,{...d,testName:c.name,tags:c.tags,use:c.use}):r=oc(c.testFlow,{...d,testName:c.name,tags:c.tags,use:h,beforeEach:c.beforeEach,afterEach:c.afterEach,parameters:c.parameters,timeout:c.timeout,skip:c.skip,fail:c.fail,only:c.only,slow:c.slow});let m=r.split(`
4367
4367
  `).filter(g=>!g.startsWith("import ")).join(`
4368
- `);new Function(p),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),vc(_c(s),{recursive:!0}),xc(s,r)}catch(c){let d=c instanceof Dn?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var Fn="0.1.73";function go(e){try{return kc(e).mtimeMs}catch{return 0}}var Tc=`// @generated by shiplightai v${Fn}`;function Ac(e,t){if(!wo(e)||fo(e,"utf-8").split(`
4369
- `,1)[0]!==Tc)return!1;let a=go(e);for(let n of t)if(go(n)>a)return!1;return!0}function $c(e){let t=process.argv.slice(2),i=[],a=Hn(e);for(let n of t){if(n.startsWith("-"))continue;let o=n.endsWith(".yaml.spec.ts")?n.replace(/\.yaml\.spec\.ts$/,".test.yaml"):n;if(!o.endsWith(".test.yaml"))continue;let r=Hn(e,o);wo(r)&&i.push(r.startsWith(a)?r.slice(a.length+1):o)}return i.length>0?i:null}function bo(e){let t=$c(e.cwd),i=t??Ec("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),a=[];for(let n of i){let o=Hn(e.cwd,n),r=o.replace(/\.test\.yaml$/,".yaml.spec.ts"),s=fo(o,"utf-8");try{let l=Rn(s,o,e.projectRoot??e.cwd),c=Sc(e.cwd,o),d=e.actionEntityStores?.get(c)??e.actionEntityStores?.get("*");if(!(d&&Object.keys(d.entries).length>0)&&Ac(r,[o,...l.referencedTemplatePaths]))continue;let p=po(s,o,{version:Fn,actionEntityStore:d,parsed:l});if(!p.valid)throw new Error(p.errors.join("; "))}catch(l){console.error(`[shiplight] Failed to transpile ${n}:`,l),a.push({file:n,error:l})}}if(a.length>0){let n=`[shiplight] Transpilation failed for ${a.length} file(s):
4368
+ `);new Function(m),s=t.replace(/\.test\.yaml$/,".yaml.spec.ts"),_c(kc(s),{recursive:!0}),vc(s,r)}catch(c){let d=c instanceof Rn?"":c.message.includes("Unexpected token")?" This usually means a YAML escaping issue \u2014 in double-quoted strings, use \\\\/ instead of \\/ for regex patterns, or use single quotes / block scalars.":" This may indicate a transpiler bug \u2014 please report it.";return{valid:!1,errors:[`Transpilation failed: ${c.message}.${d}`],warnings:[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},referencedTemplatePaths:l}}return{valid:!0,errors:[],warnings:o?.warnings??[],stats:o?.stats??{total:0,action:0,draft:0,coverage:0},specFile:s,referencedTemplatePaths:l}}var Hn="0.1.74";function fo(e){try{return Sc(e).mtimeMs}catch{return 0}}var Ac=`// @generated by shiplightai v${Hn}`;function $c(e,t){if(!bo(e)||wo(e,"utf-8").split(`
4369
+ `,1)[0]!==Ac)return!1;let a=fo(e);for(let n of t)if(fo(n)>a)return!1;return!0}function Mc(e){let t=process.argv.slice(2),i=[],a=Wn(e);for(let n of t){if(n.startsWith("-"))continue;let o=n.endsWith(".yaml.spec.ts")?n.replace(/\.yaml\.spec\.ts$/,".test.yaml"):n;if(!o.endsWith(".test.yaml"))continue;let r=Wn(e,o);bo(r)&&i.push(r.startsWith(a)?r.slice(a.length+1):o)}return i.length>0?i:null}function yo(e){let t=Mc(e.cwd),i=t??Tc("**/*.test.yaml",{cwd:e.cwd,ignore:["**/node_modules/**"]}),a=[];for(let n of i){let o=Wn(e.cwd,n),r=o.replace(/\.test\.yaml$/,".yaml.spec.ts"),s=wo(o,"utf-8");try{let l=Fn(s,o,e.projectRoot??e.cwd),c=Ec(e.cwd,o),d=e.actionEntityStores?.get(c)??e.actionEntityStores?.get("*");if(!(d&&Object.keys(d.entries).length>0)&&$c(r,[o,...l.referencedTemplatePaths]))continue;let m=go(s,o,{version:Hn,actionEntityStore:d,parsed:l});if(!m.valid)throw new Error(m.errors.join("; "))}catch(l){console.error(`[shiplight] Failed to transpile ${n}:`,l),a.push({file:n,error:l})}}if(a.length>0){let n=`[shiplight] Transpilation failed for ${a.length} file(s):
4370
4370
  `+a.map(o=>` - ${o.file}`).join(`
4371
- `);if(t)throw new Error(n);console.warn(n+" (skipped)")}}import*as ae from"fs";import*as mt from"path";import{globSync as Hc}from"glob";_i();function Eo(e){let t=vi().SHIPLIGHT_API_TOKEN;return process.env.CI&&t?new jn:new Gn(e)}var Wc=".shiplight/action-cache";function So(e){return e.replace(/\//g,"__")+".json"}function Uc(e){return e.replace(/\.json$/,"").replace(/__/g,"/")}var Gn=class{constructor(t){this.cwd=t;this.cacheDir=mt.join(t,Wc)}isCloud=!1;cacheDir;async lookup(t){let i=new Map;if(t.length===0||!ae.existsSync(this.cacheDir))return i;for(let a of t){let n=mt.join(this.cacheDir,So(a));try{if(ae.existsSync(n)){let o=ae.readFileSync(n,"utf-8");i.set(a,JSON.parse(o))}}catch{}}return i}async update(t){if(t.size===0)return 0;ae.mkdirSync(this.cacheDir,{recursive:!0});let i=0;for(let[a,n]of t)try{let o=mt.join(this.cacheDir,So(a)),r=In();if(ae.existsSync(o))try{r=JSON.parse(ae.readFileSync(o,"utf-8"))}catch{}let s={...r,entries:{...r.entries,...n.entries}};ae.writeFileSync(o,JSON.stringify(s,null,2)),i++}catch{}return i}loadAll(){if(!ae.existsSync(this.cacheDir))return;let t=Hc("*.json",{cwd:this.cacheDir});if(t.length===0)return;let i=new Map,a=0;for(let n of t)try{let o=ae.readFileSync(mt.join(this.cacheDir,n),"utf-8"),r=JSON.parse(o),s=Uc(n);i.set(s,r),a+=Object.keys(r.entries??{}).length}catch{}if(i.size!==0)return console.log(`[shiplight] Cache: loaded ${a} cached action entit${a===1?"y":"ies"} for ${i.size} test file${i.size!==1?"s":""}`),i}},jn=class{isCloud=!0;async lookup(t){let{lookupActionStores:i}=await Promise.resolve().then(()=>(Bn(),Un));return i(t)}async update(t){let{updateActionStores:i}=await Promise.resolve().then(()=>(Bn(),Un));return i(t)}loadAll(){}};_i();function jc(e={}){e.dotenv!==!1&&zc(e.scanDir||process.cwd());let t=e.scanDir||process.cwd(),a=Eo(t).loadAll();return bo({cwd:t,projectRoot:process.cwd(),actionEntityStores:a}),{reporter:[["list"],["shiplightai/reporter",{outputFolder:process.env.SHIPLIGHT_REPORT_DIR??"shiplight-report",open:"never"}]]}}function Kc(e,...t){return Gc(e,...t)}function zc(e){xo(e);for(let t of Wn(e))Bc.config({path:t})}R();R();Pt();qe();import{z as Vs}from"zod";var uh=Vs.object({instruction:Vs.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function Xs(e){e.register({name:"perform_accurate_operation",description:"Perform an operation that requires accurate interaction like dragging or interacting with a specific area of an element. Only use this action when neccecary.",schema:uh,usesElementIndex:!1,async execute(t,i){let{instruction:a}=t,n={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Je(a,n,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:a,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:a}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await Mt(r,n);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}Se();R();import{generateText as hh}from"ai";import{convert as mh}from"html-to-text";async function ph(e,t,i){let{apiKey:a,domain:n}=e;if(!a||!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${n}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let d=new Date(Date.now()-6e5);s.begin=Math.floor(d.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!l.ok){let d=await l.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await l.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let h=(d.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let f=(d.message||{}).headers||{},y=f.subject||"",b=f.from||"",m=f.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!y.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:y,from:b,to:m,date:new Date(d.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let p=h.split("/"),g=p[p.length-1];if(u.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${n}/messages/${g}`;try{let y=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`,Accept:"application/json"}});if(y.ok){let b=await y.json(),m=b.Subject||"",x=b.From||"",S=b.To||"",E=b.Date||"",A=b["Message-Id"]||"";u.info(`subject: ${m}`),u.info(`from_addr: ${x}`),u.info(`to_addr: ${S}`),u.info(`date: ${E}`),u.info(`message_id: ${A}`);let $=b["body-html"]||b["body-plain"]||"";if($&&$.includes("<")&&($=mh($)),u.info(`Body: ${$.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!$.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:m,from:x,to:S,date:E,body:$,message_id:A});continue}else u.warn(`Messages API returned ${y.status}`)}catch(y){u.warn(`Failed to parse JSON response: ${y}`)}}try{let f=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!f.ok){u.warn(`Could not fetch stored message: ${f.status}`);continue}let y=await f.text();u.info(`Fallback: Raw email length: ${y.length}`);let b=y.split(`
4372
- `),m=!0,x={},S="";for(let C=0;C<b.length;C++){let V=b[C];if(V.trim()===""&&m){m=!1;continue}if(m){let ee=V.match(/^([^:]+):\s*(.+)$/);ee&&(x[ee[1].toLowerCase()]=ee[2])}else S+=V+`
4373
- `}let E=x.subject||"",A=x.from||"",$=x.to||"",L=x.date||"",D=x["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:A,to:$,date:L,body:S.trim(),message_id:D})}catch(f){u.warn(`Error fetching raw message: ${f}`)}}if(o.length>0){try{o.sort((h,p)=>{let g=new Date(h.date).getTime();return new Date(p.date).getTime()-g})}catch{}let d=o[0];return u.info(`Returning most recent email: ${d.subject}`),[d]}return o}catch(r){throw u.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function gh(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4371
+ `);if(t)throw new Error(n);console.warn(n+" (skipped)")}}import*as ae from"fs";import*as pt from"path";import{globSync as Wc}from"glob";_i();function To(e){let t=vi().SHIPLIGHT_API_TOKEN;return process.env.CI&&t?new Kn:new jn(e)}var Uc=".shiplight/action-cache";function Eo(e){return e.replace(/\//g,"__")+".json"}function Bc(e){return e.replace(/\.json$/,"").replace(/__/g,"/")}var jn=class{constructor(t){this.cwd=t;this.cacheDir=pt.join(t,Uc)}isCloud=!1;cacheDir;async lookup(t){let i=new Map;if(t.length===0||!ae.existsSync(this.cacheDir))return i;for(let a of t){let n=pt.join(this.cacheDir,Eo(a));try{if(ae.existsSync(n)){let o=ae.readFileSync(n,"utf-8");i.set(a,JSON.parse(o))}}catch{}}return i}async update(t){if(t.size===0)return 0;ae.mkdirSync(this.cacheDir,{recursive:!0});let i=0;for(let[a,n]of t)try{let o=pt.join(this.cacheDir,Eo(a)),r=In();if(ae.existsSync(o))try{r=JSON.parse(ae.readFileSync(o,"utf-8"))}catch{}let s={...r,entries:{...r.entries,...n.entries}};ae.writeFileSync(o,JSON.stringify(s,null,2)),i++}catch{}return i}loadAll(){if(!ae.existsSync(this.cacheDir))return;let t=Wc("*.json",{cwd:this.cacheDir});if(t.length===0)return;let i=new Map,a=0;for(let n of t)try{let o=ae.readFileSync(pt.join(this.cacheDir,n),"utf-8"),r=JSON.parse(o),s=Bc(n);i.set(s,r),a+=Object.keys(r.entries??{}).length}catch{}if(i.size!==0)return console.log(`[shiplight] Cache: loaded ${a} cached action entit${a===1?"y":"ies"} for ${i.size} test file${i.size!==1?"s":""}`),i}},Kn=class{isCloud=!0;async lookup(t){let{lookupActionStores:i}=await Promise.resolve().then(()=>(Gn(),Bn));return i(t)}async update(t){let{updateActionStores:i}=await Promise.resolve().then(()=>(Gn(),Bn));return i(t)}loadAll(){}};_i();function Kc(e={}){e.dotenv!==!1&&Xc(e.scanDir||process.cwd());let t=e.scanDir||process.cwd(),a=To(t).loadAll();yo({cwd:t,projectRoot:process.cwd(),actionEntityStores:a});let n=process.env.SHIPLIGHT_REPORT_DIR,o=process.env.SHIPLIGHT_RUN_ID??zc();return process.env.SHIPLIGHT_RUN_ID=o,n?{outputDir:`test-results/${o}`,reporter:[["list"],["shiplightai/reporter",{outputFolder:n,open:"never"}]]}:{outputDir:`test-results/${o}`,reporter:[["list"],["shiplightai/reporter",{outputFolder:`shiplight-report/${o}`,latestSymlinkDir:"shiplight-report",open:"never"}]]}}function zc(){let e=new Date,t=(i,a=2)=>String(i).padStart(a,"0");return`${e.getFullYear()}-${t(e.getMonth()+1)}-${t(e.getDate())}T${t(e.getHours())}-${t(e.getMinutes())}-${t(e.getSeconds())}-${t(e.getMilliseconds(),3)}`}function Vc(e,...t){return jc(e,...t)}function Xc(e){vo(e);for(let t of Un(e))Gc.config({path:t})}R();R();Pt();qe();import{z as Xs}from"zod";var ph=Xs.object({instruction:Xs.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function Ys(e){e.register({name:"perform_accurate_operation",description:"Perform an operation that requires accurate interaction like dragging or interacting with a specific area of an element. Only use this action when neccecary.",schema:ph,usesElementIndex:!1,async execute(t,i){let{instruction:a}=t,n={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Je(a,n,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:a,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:a}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await Mt(r,n);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}Se();R();import{generateText as mh}from"ai";import{convert as gh}from"html-to-text";async function fh(e,t,i){let{apiKey:a,domain:n}=e;if(!a||!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${n}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let d=new Date(Date.now()-6e5);s.begin=Math.floor(d.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!l.ok){let d=await l.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await l.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let h=(d.storage||{}).url;if(u.info(`message_url: ${h}`),!h){let f=(d.message||{}).headers||{},y=f.subject||"",b=f.from||"",p=f.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!y.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:y,from:b,to:p,date:new Date(d.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let m=h.split("/"),g=m[m.length-1];if(u.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${n}/messages/${g}`;try{let y=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`,Accept:"application/json"}});if(y.ok){let b=await y.json(),p=b.Subject||"",x=b.From||"",S=b.To||"",E=b.Date||"",A=b["Message-Id"]||"";u.info(`subject: ${p}`),u.info(`from_addr: ${x}`),u.info(`to_addr: ${S}`),u.info(`date: ${E}`),u.info(`message_id: ${A}`);let M=b["body-html"]||b["body-plain"]||"";if(M&&M.includes("<")&&(M=gh(M)),u.info(`Body: ${M.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:p,from:x,to:S,date:E,body:M,message_id:A});continue}else u.warn(`Messages API returned ${y.status}`)}catch(y){u.warn(`Failed to parse JSON response: ${y}`)}}try{let f=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${a}`).toString("base64")}`}});if(!f.ok){u.warn(`Could not fetch stored message: ${f.status}`);continue}let y=await f.text();u.info(`Fallback: Raw email length: ${y.length}`);let b=y.split(`
4372
+ `),p=!0,x={},S="";for(let C=0;C<b.length;C++){let V=b[C];if(V.trim()===""&&p){p=!1;continue}if(p){let ee=V.match(/^([^:]+):\s*(.+)$/);ee&&(x[ee[1].toLowerCase()]=ee[2])}else S+=V+`
4373
+ `}let E=x.subject||"",A=x.from||"",M=x.to||"",L=x.date||"",D=x["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:A,to:M,date:L,body:S.trim(),message_id:D})}catch(f){u.warn(`Error fetching raw message: ${f}`)}}if(o.length>0){try{o.sort((h,m)=>{let g=new Date(h.date).getTime();return new Date(m.date).getTime()-g})}catch{}let d=o[0];return u.info(`Returning most recent email: ${d.subject}`),[d]}return o}catch(r){throw u.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function wh(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4374
4374
 
4375
4375
  Please carefully examine the email content and look for:
4376
4376
  1. Numeric codes (usually 4-8 digits)
@@ -4427,27 +4427,27 @@ Examples of what to extract:
4427
4427
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4428
4428
 
4429
4429
  Return ONLY the complete extracted URL or "NOT_FOUND".`;if(e==="custom"){if(!t)throw new Error("Custom prompt is required when extraction_type is custom");return t+`
4430
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function fh(e,t,i){try{let a=`${t}
4430
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function bh(e,t,i){try{let a=`${t}
4431
4431
  ---
4432
4432
  Email Content:
4433
4433
  ---
4434
4434
  ${e}
4435
4435
  ---
4436
- `,n=_e(i);return(await hh({model:n,messages:[{role:"user",content:a}],temperature:0,providerOptions:ke(i,0)})).text.trim()||"NOT_FOUND"}catch(a){throw u.error(`Error in LLM extraction: ${a.message}`),new Error(`Error in LLM extraction: ${a.message}`)}}async function Ys(e,t){u.info(`extract_email_content:
4436
+ `,n=_e(i);return(await mh({model:n,messages:[{role:"user",content:a}],temperature:0,providerOptions:ke(i,0)})).text.trim()||"NOT_FOUND"}catch(a){throw u.error(`Error in LLM extraction: ${a.message}`),new Error(`Error in LLM extraction: ${a.message}`)}}async function Js(e,t){u.info(`extract_email_content:
4437
4437
  forward_email: ${t.forward_email}
4438
4438
  extraction_type: ${t.extraction_type}
4439
4439
  filters: ${JSON.stringify(t.filters||{})}
4440
4440
  timeout: ${t.timeout||60}
4441
- polling_interval: 10`);let i=t.timeout||60,a=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let n=gh(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(u.info(`Starting email polling for ${i} seconds with ${a}s intervals`);new Date<r;){s++,u.info(`Polling attempt ${s}`);try{let c=t.filters||{},d=await ph(e,t.forward_email,c);if(d.length>0){u.info(`Found ${d.length} emails matching criteria`);let h=[];for(let p of d){let g=`Subject: ${p.subject}
4442
- From: ${p.from}
4443
- To: ${p.to}
4444
- Date: ${p.date}
4441
+ polling_interval: 10`);let i=t.timeout||60,a=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let n=wh(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(u.info(`Starting email polling for ${i} seconds with ${a}s intervals`);new Date<r;){s++,u.info(`Polling attempt ${s}`);try{let c=t.filters||{},d=await fh(e,t.forward_email,c);if(d.length>0){u.info(`Found ${d.length} emails matching criteria`);let h=[];for(let m of d){let g=`Subject: ${m.subject}
4442
+ From: ${m.from}
4443
+ To: ${m.to}
4444
+ Date: ${m.date}
4445
4445
 
4446
4446
  Body:
4447
- ${p.body}`,f=await fh(g,n,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(h.length>0){let p=h[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${s})`}}else u.info(`Found emails but no extractable content in attempt ${s}`)}else u.info(`No emails found in attempt ${s}`)}catch(c){u.warn(`Error in polling attempt ${s}: ${c.message}`)}if(new Date(Date.now()+a*1e3)>=r){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${a} seconds before next attempt...`),await new Promise(c=>setTimeout(c,a*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(n){return u.error(`Error extracting email content: ${n.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${n.message}`}}}R();te();import{z as Me}from"zod";function Js(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var qs=class{getMailgunConfig(){let e=G().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.getMailgunConfig();if(!n)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=a.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Ys(n,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Js(o.extraction_type);i.variableStore.set(l,s.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},wh=Me.object({forward_email:Me.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Me.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:Me.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Me.string().optional().describe("Filter emails by sender address"),filter_to_email:Me.string().optional().describe("Filter emails by recipient address"),filter_subject:Me.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Me.string().optional().describe("Filter emails by body content (partial match)"),timeout:Me.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Zs(e,t){e.register({name:"extract_email_content",description:"Extract verification codes, magic links, or custom content from emails received via Mailgun. Polls the Mailgun inbox for matching emails and uses AI to extract the requested content.",schema:wh,async execute(i,a){let{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:p,agentServices:g}=a;u.info(`[extract_email_content] Extracting ${o} from ${n}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(p,f,g);let y=Js(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${y}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();si();var xn=null;async function we(){if(xn)return xn;let e=(await Promise.resolve().then(()=>(st(),rt))).default;return xn=new e,xn}async function Qs(e){let t=await we(),i=t.getAction("click"),a=t.getAction("hover"),n=t.getAction("right_click"),o=t.getAction("double_click");return As(e,i),xs(e,a),os(e,n),Ls(e,o),"Click, hover, double-click, right-click, or drag elements"}async function el(e){let t=await we(),i=t.getAction("go_to_url"),a=t.getAction("go_back"),n=t.getAction("reload_page");return bs(e,i),ws(e,a),ns(e,n),"Navigate to URLs, go back, or reload the page"}async function tl(e){let t=await we(),i=t.getAction("clear_input"),a=t.getAction("input_text"),n=t.getAction("press");return Es(e,i),_s(e,a),ts(e,n),"Type text into inputs, clear input values, or press keyboard keys"}async function il(e){let t=await we(),i=t.getAction("scroll_on_element"),a=t.getAction("scroll_to_text"),n=t.getAction("scroll");return Nr(e,i),Fr(e,a),ls(e,n),"Scroll the page or scroll to specific text/elements"}async function nl(e){let t=await we(),i=t.getAction("close_tab"),a=t.getAction("switch_tab");return Is(e,i),zr(e,a),"Switch between browser tabs or close tabs"}async function al(e){let t=await we(),i=t.getAction("upload_file"),a=t.getAction("wait_for_download_complete");return Jr(e,i),Ir(e,a),"Upload files or wait for downloads to complete"}async function ol(e){let t=await we(),i=t.getAction("get_dropdown_options"),a=t.getAction("select_dropdown_option"),n=t.getAction("set_date_for_native_date_picker");return gs(e,i),Ur(e,a),Gr(e,n),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function rl(e){let t=await we(),i=t.getAction("wait"),a=t.getAction("save_variable"),n=t.getAction("done");return Qr(e,i),ss(e,a),Cs(e,n),Xs(e),"Wait for conditions, save variables, or complete tasks"}async function sl(e){let t=(await we()).getAction("generate_2fa_code");us(e,t);let i=new qs;return(await Promise.resolve().then(()=>(st(),rt))).default.registerAction("extract_email_content",i),Zs(e,i),"Generate 2FA codes or extract email/activation codes"}async function ll(e){let t=await we(),i=t.getAction("verify"),a=t.getAction("ai_extract"),n=t.getAction("ai_wait_until");return Rs(e,i),Hs(e,a),Cr(e,n),"Perform AI-powered assertions, extractions, or wait conditions"}Ee();var bh=[Qs(H),el(H),tl(H),il(H),nl(H),al(H),ol(H),rl(H),ll(H),sl(H)],OS=Promise.all(bh);gt();ct();$e();lt();R();import{chromium as vE,firefox as _E,webkit as kE}from"playwright";ct();var Ch=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Ch||{});Pt();Ue();Sn();ie();var fl=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(a=>!a.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}};ct();$e();R();async function wl(e,t=3e3,i=1e3){try{await Ae(e,t,i)}catch{}}async function bl(e,t,i){let a=i*1e3,n=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>a){let r;throw t.downloadStatus?r=`Timed out after ${a}ms waiting for download to complete`:r="No download in progress or completed",u.error(r),new Error(r)}await e.waitForTimeout(n)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function yl(e,t,i,a=60,n){let o=Math.min(a,300),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,n))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}$e();R();import*as xl from"fs";import*as hi from"path";import{generateSync as Nh,createGuardrails as Dh}from"otplib";var Rh=Dh({MIN_SECRET_BYTES:1});function vl(e){return e.url()===":"}var La=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new fl(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return u.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(a=>!a.isClosed());if(i.length>0){let a=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${a.url()}`),a}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return Ia(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return hi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(a=>{let n=hi.basename(a),o=hi.join(t,n),r=xl.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${n}`),!r});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return bl(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4448
- ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=Nh({secret:e,guardrails:Rh});return u.info(`Generated 2FA code: ${t}`),t}catch(t){throw u.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ae(e,t)}setPage(e){this.context.setPage?(u.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):u.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,a){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let n=await this.knowledgeRetriever(e,t,i,a);return u.debug(`[AgentServices] Retrieved ${n.length} knowledges for statement`),n}catch(n){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${n.message}`),[]}}};var _l=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(_l||{}),Na=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}};Wt();R();import*as K from"fs";import*as Q from"path";var Fh=1;function Hh(e){try{let t=e.toString(),i,a=t.indexOf("=>");if(a!==-1){let s=t.slice(a+2).trim();if(s.startsWith("{")){let l=s.lastIndexOf("}");i=s.slice(1,l)}else return s.trim()}else{let s=t.indexOf("{"),l=t.lastIndexOf("}");s!==-1&&l>s&&(i=t.slice(s+1,l))}if(!i)return;let n=i.split(`
4447
+ ${m.body}`,f=await bh(g,n,t.model);u.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&h.push({content:f,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(h.length>0){let m=h[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let f=(new Date().getTime()-o.getTime())/1e3;return u.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:m.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else u.info(`Found emails but no extractable content in attempt ${s}`)}else u.info(`No emails found in attempt ${s}`)}catch(c){u.warn(`Error in polling attempt ${s}: ${c.message}`)}if(new Date(Date.now()+a*1e3)>=r){u.info("Not enough time for another polling attempt");break}u.info(`Waiting ${a} seconds before next attempt...`),await new Promise(c=>setTimeout(c,a*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(n){return u.error(`Error extracting email content: ${n.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${n.message}`}}}R();te();import{z as Me}from"zod";function qs(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var Zs=class{getMailgunConfig(){let e=G().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let a=t.action_data;if(!a)throw new Error("Action data not found");let n=this.getMailgunConfig();if(!n)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=a.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await Js(n,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||qs(o.extraction_type);i.variableStore.set(l,s.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},yh=Me.object({forward_email:Me.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Me.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:Me.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Me.string().optional().describe("Filter emails by sender address"),filter_to_email:Me.string().optional().describe("Filter emails by recipient address"),filter_subject:Me.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Me.string().optional().describe("Filter emails by body content (partial match)"),timeout:Me.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Qs(e,t){e.register({name:"extract_email_content",description:"Extract verification codes, magic links, or custom content from emails received via Mailgun. Polls the Mailgun inbox for matching emails and uses AI to extract the requested content.",schema:yh,async execute(i,a){let{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}=i,{page:m,agentServices:g}=a;u.info(`[extract_email_content] Extracting ${o} from ${n}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}}};await t.execute(m,f,g);let y=qs(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${y}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:n,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:c,filter_body_contains:d,timeout:h}},feedback:f.message}}}}})}Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();si();var xn=null;async function we(){if(xn)return xn;let e=(await Promise.resolve().then(()=>(st(),rt))).default;return xn=new e,xn}async function el(e){let t=await we(),i=t.getAction("click"),a=t.getAction("hover"),n=t.getAction("right_click"),o=t.getAction("double_click");return $s(e,i),vs(e,a),rs(e,n),Ns(e,o),"Click, hover, double-click, right-click, or drag elements"}async function tl(e){let t=await we(),i=t.getAction("go_to_url"),a=t.getAction("go_back"),n=t.getAction("reload_page");return ys(e,i),bs(e,a),as(e,n),"Navigate to URLs, go back, or reload the page"}async function il(e){let t=await we(),i=t.getAction("clear_input"),a=t.getAction("input_text"),n=t.getAction("press");return Ts(e,i),ks(e,a),is(e,n),"Type text into inputs, clear input values, or press keyboard keys"}async function nl(e){let t=await we(),i=t.getAction("scroll_on_element"),a=t.getAction("scroll_to_text"),n=t.getAction("scroll");return Dr(e,i),Hr(e,a),cs(e,n),"Scroll the page or scroll to specific text/elements"}async function al(e){let t=await we(),i=t.getAction("close_tab"),a=t.getAction("switch_tab");return Ps(e,i),Vr(e,a),"Switch between browser tabs or close tabs"}async function ol(e){let t=await we(),i=t.getAction("upload_file"),a=t.getAction("wait_for_download_complete");return qr(e,i),Pr(e,a),"Upload files or wait for downloads to complete"}async function rl(e){let t=await we(),i=t.getAction("get_dropdown_options"),a=t.getAction("select_dropdown_option"),n=t.getAction("set_date_for_native_date_picker");return fs(e,i),Br(e,a),jr(e,n),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function sl(e){let t=await we(),i=t.getAction("wait"),a=t.getAction("save_variable"),n=t.getAction("done");return es(e,i),ls(e,a),Os(e,n),Ys(e),"Wait for conditions, save variables, or complete tasks"}async function ll(e){let t=(await we()).getAction("generate_2fa_code");hs(e,t);let i=new Zs;return(await Promise.resolve().then(()=>(st(),rt))).default.registerAction("extract_email_content",i),Qs(e,i),"Generate 2FA codes or extract email/activation codes"}async function cl(e){let t=await we(),i=t.getAction("verify"),a=t.getAction("ai_extract"),n=t.getAction("ai_wait_until");return Fs(e,i),Ws(e,a),Or(e,n),"Perform AI-powered assertions, extractions, or wait conditions"}Ee();var xh=[el(H),tl(H),il(H),nl(H),al(H),ol(H),rl(H),sl(H),cl(H),ll(H)],NS=Promise.all(xh);gt();ct();$e();lt();R();import{chromium as kE,firefox as SE,webkit as EE}from"playwright";ct();var Lh=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Lh||{});Pt();Ue();Sn();ie();var wl=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(a=>!a.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}};ct();$e();R();async function bl(e,t=3e3,i=1e3){try{await Ae(e,t,i)}catch{}}async function yl(e,t,i){let a=i*1e3,n=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>a){let r;throw t.downloadStatus?r=`Timed out after ${a}ms waiting for download to complete`:r="No download in progress or completed",u.error(r),new Error(r)}await e.waitForTimeout(n)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function xl(e,t,i,a=60,n){let o=Math.min(a,300),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,n))return u.info(`Condition met: "${t}"`),!0}catch(d){u.warn(`Error evaluating condition: ${d.message}`)}if(Date.now()>s)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let c=r-(Date.now()-l);c>0&&await e.waitForTimeout(c)}}$e();R();import*as vl from"fs";import*as hi from"path";import{generateSync as Rh,createGuardrails as Fh}from"otplib";var Hh=Fh({MIN_SECRET_BYTES:1});function _l(e){return e.url()===":"}var Na=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new wl(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return u.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(a=>!a.isClosed());if(i.length>0){let a=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${a.url()}`),a}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return Pa(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return hi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(a=>{let n=hi.basename(a),o=hi.join(t,n),r=vl.existsSync(o);return r&&u.debug(`[AgentServices] File already exists locally: ${n}`),!r});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return yl(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4448
+ ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=Rh({secret:e,guardrails:Hh});return u.info(`Generated 2FA code: ${t}`),t}catch(t){throw u.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ae(e,t)}setPage(e){this.context.setPage?(u.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):u.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,a){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let n=await this.knowledgeRetriever(e,t,i,a);return u.debug(`[AgentServices] Retrieved ${n.length} knowledges for statement`),n}catch(n){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${n.message}`),[]}}};var kl=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(kl||{}),Da=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}};Wt();R();import*as K from"fs";import*as Q from"path";var Wh=1;function Uh(e){try{let t=e.toString(),i,a=t.indexOf("=>");if(a!==-1){let s=t.slice(a+2).trim();if(s.startsWith("{")){let l=s.lastIndexOf("}");i=s.slice(1,l)}else return s.trim()}else{let s=t.indexOf("{"),l=t.lastIndexOf("}");s!==-1&&l>s&&(i=t.slice(s+1,l))}if(!i)return;let n=i.split(`
4449
4449
  `),o=n.filter(s=>s.trim().length>0);if(o.length===0)return;let r=Math.min(...o.map(s=>s.match(/^(\s*)/)?.[1].length??0));return n.map(s=>s.slice(r)).join(`
4450
- `).trim()}catch{return}}var Wh=3,Uh=40;function dt(e,t){let i={};for(let[a,n]of Object.entries(e))i[a]=t.has(a)?"*****":n;return i}var El=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new La(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(st(),rt));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let a=(await this.getActionHandler()).getAction(e);if(!a)throw new Error(`Unknown action: ${e}`);await a.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
4450
+ `).trim()}catch{return}}var Bh=3,Gh=40;function dt(e,t){let i={};for(let[a,n]of Object.entries(e))i[a]=t.has(a)?"*****":n;return i}var Tl=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new Na(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(st(),rt));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let a=(await this.getActionHandler()).getAction(e);if(!a)throw new Error(`Unknown action: ${e}`);await a.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
4451
4451
 
4452
4452
  ONLY dismiss intrusive popups such as:
4453
4453
  - Cookie/GDPR consent banners
@@ -4469,7 +4469,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
4469
4469
  IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
4470
4470
  It's better to miss a popup than to accidentally interact with normal page elements.
4471
4471
 
4472
- If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Wh),a=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:a,details:i.details||(a?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),vl(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let a=this.context.downloadDir||Q.join(process.cwd(),"downloads");K.existsSync(a)||K.mkdirSync(a,{recursive:!0});let n=Q.join(a,i);u.info(`[Download Tracking] Downloading file to: ${n}`),await t.saveAs(n),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:n,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${n}`),u.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(a){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:a.message,timestamp:Date.now()},u.error(`[Download Tracking] Download failed for ${i}: ${a.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),a=t.message();u.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${a}"`);let n=i==="beforeunload";try{n?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:a,response:n?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${n?"dismissed":"accepted"} - type: ${i}, message: "${a}"`)}catch(o){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,a=1,n,o){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=a,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:a,tokenUsages:[...r],statement:n,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${a}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let a=this.getCompletedExecutionHistory(),n=await at(t,e,this.agentServices,{executionHistory:a,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let o=n.explanation||n.error||"No explanation";if(i&&this.trackAIAction(i,"assert",n.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,n.success?"success":"failure",o,void 0,n.debugInfo),!n.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!0}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async evaluate(e,t,i){u.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let a=this.getCompletedExecutionHistory(),n=await at(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let o=n.explanation||n.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",n.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,n.debugInfo),n.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(u.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!1)}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async performAction(e,t){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),a=await nt(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0)return{success:!1,details:a.explanation||a.error||"Action failed"};let n=a.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,n),{success:!0,details:a.explanation}}async execute(e,t,i,a,n){if(n!==void 0&&n<=0)throw new Error(`maxSteps must be >= 1, got ${n}`);let o=n!==void 0&&n>1;u.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${n}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"execute"),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(o){let d=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let p=`${i}-step${h.step}`;this.saveDebugInfoToFiles(p,h.debugInfo,this.context.model)}}:void 0;if(s=await ot(t,e,this.agentServices,d,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:n??Uh}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let h={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",h,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await nt(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:a}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let d=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,d)}if(s.status!=="success"||s.actionEntities.length===0||!l){let d=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",d,void 0,s.debugInfo),new Error(`Action failed: ${d}`)}let c=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,c),{success:!0,details:c,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,a){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let n=this.getCompletedExecutionHistory(),o=await It(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:a});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async run(e,t,i,a){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let n=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=a?.onAction||o?d=>{if(d.type==="action"&&d.action_entity&&(a?.onAction?.(d.action_entity),o&&d.debugInfo)){let h=`${i}-step${d.step}`;this.saveDebugInfoToFiles(h,d.debugInfo,this.context.model)}}:void 0,s=await ot(t,e,this.agentServices,r,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:a?.abortSignal,maxSteps:a?.maxSteps});w.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,c=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let d={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",d,s.actionEntities?.length||1,t,c)}if(!l)throw new Na(c);if(a?.stmtUid&&s.actionEntities?.length){let d=s.actionEntities.at(-1);d&&(this._newActionEntities.set(a.stmtUid,d),w.log(`Stored resolved action entity for DRAFT stmtUid: ${a.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,c),w.log(`Run result: success=${l}, details=${c}`),{success:l,details:c,actions:s.actionEntities}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${n.message}`),n}}async step(e,t,i,a,n,o=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,a,i,"step");let p=Hh(t);p&&this.context.stepTracking.results[a]&&(this.context.stepTracking.results[a].code=p)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=a),e=this.agentServices.validatePage(e);let l=e.url(),c=await this.captureDOMSnapshot(e),d=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[a]?.screenshot;try{u.info(`Executing step ${a}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),f=await this.captureDOMSnapshot(e),y=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(a,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,x=this.context.stepTracking.results[a]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:f||void 0,variables:y,screenshotPath:x,timestamp:S})}let b=this.context.agentNote;return(!b||b.trim()==="")&&(b="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=o&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(a,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(u.info(`Failed to heal at step ${a}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),x=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:E,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:x||void 0,variables:S,timestamp:A})}throw this.context.stepTracking&&(await this.updateStepResult(a,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,u.info(`Action failed at step ${a}. ${i}`),u.info(`with error: ${p.message}`);let f,y;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){f=`[Auto-dismissed modal: ${m.details}]`,y=m.actions,u.info(`Modal dismissed, retrying original action for step ${a}`);try{let x=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(a,"success",f),this.context.stepTracking.results[a].dismissedModalActions=y,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,x}catch(x){u.info(`Retry after modal dismissal failed: ${x.message}, falling back to self-healing`)}}}let b=r??Fh;u.info(`Calling execute() to self-heal (maxSteps: ${b})`);try{let m=await this.execute(e,i,a,!1,b);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let x=m.actions?.at(-1);n&&x&&(this._newActionEntities.set(n,x),u.info(`Stored new action entity for stmtUid: ${n} (last of ${m.actions?.length} actions)`));let S=e.url(),E=await this.captureDOMSnapshot(e),A=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[a].autoHealed=!0,this.context.stepTracking.results[a].healedAction=x,y&&(this.context.stepTracking.results[a].dismissedModalActions=y);let $=f||"";await this.updateStepResult(a,"success",$)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let $=Date.now()-s,L=this.context.stepTracking.results[a]?.screenshot,D=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{actionEntity:x,playwrightCode:m.actions?.map(C=>C.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(a),durationMs:$,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:E||void 0,variables:A,screenshotPath:L,timestamp:D})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let x=e.url(),S=await this.captureDOMSnapshot(e),E=this.context.stepTracking.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},A=Date.now()-s,$=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:A,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:S||void 0,variables:E,timestamp:$})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(e,t,i,a){a&&this.context.stepTracking&&await this.createStepResult(e,a,`Extract ${t} into ${i}`,"extract");try{let n=`Extract ${t} and save to ${i}`,o=await this.execute(e,n,a);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);a&&this.context.stepTracking&&await this.updateStepResult(a,"success",`Extracted ${t} to ${i}`)}catch(n){throw a&&this.context.stepTracking&&await this.updateStepResult(a,"failure",n.message),n}}async getDOMText(e){let t=new fe(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),a=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new fe(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),a=this.agentServices.getIframeFallbackDomains(),n=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a,highlightElements:!1,viewportExpansion:0});return{elementTreeText:n.elementTree.clickableElementsToString(),elementCount:n.selectorMap.size,timestamp:Date.now()}}catch(t){return u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return wl(e,t,i)}async waitUntilCondition(e,t,i=60,a){return yl(e,t,(n,o,r)=>this.evaluate(n,o,r),i,a)}async uploadFile(e,t,i={},a){return Vr(e,t,i,this.context,(n,o,r)=>this.execute(n,o,r),a)}async loginPage(e,t,i){let{LoginType:a}=await Promise.resolve().then(()=>(Sl(),kl));if(u.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return u.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===a.PASSWORD||t.account.type===a.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),u.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let n=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=n?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(n){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return w.log("Level 1 SUCCESS: Already logged in via AI verification"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!n&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await ui(e,i.validation_exprs))return w.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(n||r)){w.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:o})).success){w.log("Level 2 SUCCESS: Cached login succeeded"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4472
+ If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Bh),a=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:a,details:i.details||(a?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),_l(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let a=this.context.downloadDir||Q.join(process.cwd(),"downloads");K.existsSync(a)||K.mkdirSync(a,{recursive:!0});let n=Q.join(a,i);u.info(`[Download Tracking] Downloading file to: ${n}`),await t.saveAs(n),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:n,timestamp:Date.now()},u.info(`[Download Tracking] Download completed: ${n}`),u.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(a){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:a.message,timestamp:Date.now()},u.error(`[Download Tracking] Download failed for ${i}: ${a.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),a=t.message();u.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${a}"`);let n=i==="beforeunload";try{n?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:a,response:n?"dismiss":"accept",timestamp:Date.now()},u.info(`[Dialog Handling] Dialog ${n?"dismissed":"accepted"} - type: ${i}, message: "${a}"`)}catch(o){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,a=1,n,o){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=a,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:a,tokenUsages:[...r],statement:n,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${a}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let a=this.getCompletedExecutionHistory(),n=await at(t,e,this.agentServices,{executionHistory:a,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let o=n.explanation||n.error||"No explanation";if(i&&this.trackAIAction(i,"assert",n.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,n.success?"success":"failure",o,void 0,n.debugInfo),!n.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!0}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async evaluate(e,t,i){u.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let a=this.getCompletedExecutionHistory(),n=await at(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(n.debugInfo),this.context.lastActionDebugInfo=n.debugInfo;let o=n.explanation||n.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",n.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,n.debugInfo),n.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(u.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!1)}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async performAction(e,t){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),a=await nt(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0)return{success:!1,details:a.explanation||a.error||"Action failed"};let n=a.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,n),{success:!0,details:a.explanation}}async execute(e,t,i,a,n){if(n!==void 0&&n<=0)throw new Error(`maxSteps must be >= 1, got ${n}`);let o=n!==void 0&&n>1;u.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${n}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"execute"),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(o){let d=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let m=`${i}-step${h.step}`;this.saveDebugInfoToFiles(m,h.debugInfo,this.context.model)}}:void 0;if(s=await ot(t,e,this.agentServices,d,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:n??Gh}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let h={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",h,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await nt(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:a}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let d=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,d)}if(s.status!=="success"||s.actionEntities.length===0||!l){let d=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",d,void 0,s.debugInfo),new Error(`Action failed: ${d}`)}let c=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,c),{success:!0,details:c,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,a){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let n=this.getCompletedExecutionHistory(),o=await It(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:a});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),u.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async run(e,t,i,a){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let n=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=a?.onAction||o?d=>{if(d.type==="action"&&d.action_entity&&(a?.onAction?.(d.action_entity),o&&d.debugInfo)){let h=`${i}-step${d.step}`;this.saveDebugInfoToFiles(h,d.debugInfo,this.context.model)}}:void 0,s=await ot(t,e,this.agentServices,r,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:a?.abortSignal,maxSteps:a?.maxSteps});w.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,c=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let d={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",d,s.actionEntities?.length||1,t,c)}if(!l)throw new Da(c);if(a?.stmtUid&&s.actionEntities?.length){let d=s.actionEntities.at(-1);d&&(this._newActionEntities.set(a.stmtUid,d),w.log(`Stored resolved action entity for DRAFT stmtUid: ${a.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",c,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,c),w.log(`Run result: success=${l}, details=${c}`),{success:l,details:c,actions:s.actionEntities}}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${n.message}`),n}}async step(e,t,i,a,n,o=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,a,i,"step");let m=Uh(t);m&&this.context.stepTracking.results[a]&&(this.context.stepTracking.results[a].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=a),e=this.agentServices.validatePage(e);let l=e.url(),c=await this.captureDOMSnapshot(e),d=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[a]?.screenshot;try{u.info(`Executing step ${a}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let m=await t();e=this.agentServices.validatePage(e);let g=e.url(),f=await this.captureDOMSnapshot(e),y=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(a,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=Date.now()-s,x=this.context.stepTracking.results[a]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:f||void 0,variables:y,screenshotPath:x,timestamp:S})}let b=this.context.agentNote;return(!b||b.trim()==="")&&(b="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=b),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=o&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(a,"failure",m.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=m.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!g){if(u.info(`Failed to heal at step ${a}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=e.url(),x=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:E,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:x||void 0,variables:S,timestamp:A})}throw this.context.stepTracking&&(await this.updateStepResult(a,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,u.info(`Action failed at step ${a}. ${i}`),u.info(`with error: ${m.message}`);let f,y;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){f=`[Auto-dismissed modal: ${p.details}]`,y=p.actions,u.info(`Modal dismissed, retrying original action for step ${a}`);try{let x=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(a,"success",f),this.context.stepTracking.results[a].dismissedModalActions=y,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,x}catch(x){u.info(`Retry after modal dismissal failed: ${x.message}, falling back to self-healing`)}}}let b=r??Wh;u.info(`Calling execute() to self-heal (maxSteps: ${b})`);try{let p=await this.execute(e,i,a,!1,b);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let x=p.actions?.at(-1);n&&x&&(this._newActionEntities.set(n,x),u.info(`Stored new action entity for stmtUid: ${n} (last of ${p.actions?.length} actions)`));let S=e.url(),E=await this.captureDOMSnapshot(e),A=this.context.stepTracking?.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[a].autoHealed=!0,this.context.stepTracking.results[a].healedAction=x,y&&(this.context.stepTracking.results[a].dismissedModalActions=y);let M=f||"";await this.updateStepResult(a,"success",M)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let M=Date.now()-s,L=this.context.stepTracking.results[a]?.screenshot,D=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{actionEntity:x,playwrightCode:p.actions?.map(C=>C.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(a),durationMs:M,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:E||void 0,variables:A,screenshotPath:L,timestamp:D})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let x=e.url(),S=await this.captureDOMSnapshot(e),E=this.context.stepTracking.captureVariables?dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},A=Date.now()-s,M=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:c||void 0,variables:d,screenshotPath:h,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:a,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(a),durationMs:A,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:S||void 0,variables:E,timestamp:M})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,a){a&&this.context.stepTracking&&await this.createStepResult(e,a,`Extract ${t} into ${i}`,"extract");try{let n=`Extract ${t} and save to ${i}`,o=await this.execute(e,n,a);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);a&&this.context.stepTracking&&await this.updateStepResult(a,"success",`Extracted ${t} to ${i}`)}catch(n){throw a&&this.context.stepTracking&&await this.updateStepResult(a,"failure",n.message),n}}async getDOMText(e){let t=new fe(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),a=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new fe(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),a=this.agentServices.getIframeFallbackDomains(),n=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:a,highlightElements:!1,viewportExpansion:0});return{elementTreeText:n.elementTree.clickableElementsToString(),elementCount:n.selectorMap.size,timestamp:Date.now()}}catch(t){return u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return bl(e,t,i)}async waitUntilCondition(e,t,i=60,a){return xl(e,t,(n,o,r)=>this.evaluate(n,o,r),i,a)}async uploadFile(e,t,i={},a){return Xr(e,t,i,this.context,(n,o,r)=>this.execute(n,o,r),a)}async loginPage(e,t,i){let{LoginType:a}=await Promise.resolve().then(()=>(El(),Sl));if(u.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return u.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===a.PASSWORD||t.account.type===a.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),u.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let n=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=n?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(n){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return w.log("Level 1 SUCCESS: Already logged in via AI verification"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!n&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await ui(e,i.validation_exprs))return w.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(n||r)){w.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:o})).success){w.log("Level 2 SUCCESS: Cached login succeeded"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4473
4473
  Use your best judgement to determine if the page is signed in.
4474
4474
  `;if(t.verification_hint&&(s+=`
4475
4475
  Signed in verification hint: ${t.verification_hint}
@@ -4481,4 +4481,4 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
4481
4481
  `}t.additional_prompt&&(s+=`
4482
4482
  Additional instructions: ${t.additional_prompt}
4483
4483
  `);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
4484
- ${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(y,b,m,x)=>await l(y,b,m,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;if(n)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let y=await kn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,m)=>this.run(b,m),async b=>this.getDOMText(b));y?(p=y,w.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(y){w.log(`Error generating validation locators: ${y.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs:p}}catch(l){return w.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let a=(await Promise.resolve().then(()=>(st(),rt))).default,n=new a;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await n.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await ui(e,i.validationExprs)?{success:!0}:{success:!1}:(w.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i,a){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[],type:a,code:i};if(this.context.stepTracking.artifactsDir){let o=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(o,{recursive:!0});let r=Q.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),n.screenshot=r}n.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,a=0){let n={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),n;let o=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=Q.join(o,`system_prompt_${a}.txt`);K.writeFileSync(r,t.systemPrompt),n.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(o,`user_prompt_${a}.txt`);K.writeFileSync(r,t.userPrompt),n.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=Q.join(o,`messages_${a}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),n.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(o,`${r}_response_${a}.txt`);K.writeFileSync(s,t.rawLlmResponse),n.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(o,`screenshot_${a}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),n.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(o,`reasoning_${a}.txt`);K.writeFileSync(r,t.reasoningContent),n.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(n).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return n}async updateStepResult(e,t,i,a,n){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,o.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),a&&o.artifacts.push(a),n){let r=n.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,n,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=Q.join(e,"test-results.json");await K.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=Q.join(e,"token-usages.json");await K.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=Q.join(e,"ai-actions.json");await K.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}};Pt();ji();Bi();Ei();qe();Oi();Ni();Ve();Li();Fi();vt();_t();Ee();gt();xt();tn();Ue();kt();St();Ze();Et();Tt();Sn();ie();ct();$e();lt();Se();bt();Xe();yt();Ne();$a();zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();$t();si();un();Wt();j();We();R();te();et();pn();F();function Bh(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(m=>m.type==="year").value,a=t.find(m=>m.type==="month").value,n=t.find(m=>m.type==="day").value,o=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),c=`${i}-${a}-${n}T${o}:${r}:${s}.${l}`,d=e.toISOString().slice(0,-1),h=Date.parse(c+"Z"),p=Date.parse(d+"Z"),g=Math.round((p-h)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),y=String(Math.abs(g)%60).padStart(2,"0"),b=g<=0?"+":"-";return`${i}-${a}-${n}T${o}:${r}:${s}.${l}${b}${f}:${y}`}function Tl(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Bh()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}me();export{ml as VariableStore,El as WebAgent,To as configureSdk,Tl as createAgentContext,Kc as defineConfig,jc as shiplightConfig};
4484
+ ${s}`);let l=this.agentServices.knowledgeRetriever,c=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(y,b,p,x)=>await l(y,b,p,"login")),c=!0,w.log("Login knowledge retriever configured"));let d;try{if(d=await this.run(e,s,"login"),!d.success)return w.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{c&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),m;if(n)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let y=await kn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(b,p)=>this.run(b,p),async b=>this.getDOMText(b));y?(m=y,w.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(y){w.log(`Error generating validation locators: ${y.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=d.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:f,validation_exprs:m}}catch(l){return w.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let a=(await Promise.resolve().then(()=>(st(),rt))).default,n=new a;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await n.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await ui(e,i.validationExprs)?{success:!0}:{success:!1}:(w.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i,a){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[],type:a,code:i};if(this.context.stepTracking.artifactsDir){let o=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(o,{recursive:!0});let r=Q.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),n.screenshot=r}n.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=n}catch(n){u.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,a=0){let n={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),n;let o=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=Q.join(o,`system_prompt_${a}.txt`);K.writeFileSync(r,t.systemPrompt),n.system_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(o,`user_prompt_${a}.txt`);K.writeFileSync(r,t.userPrompt),n.user_prompt_path=r,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(c=>Array.isArray(c.content)?{...c,content:c.content.map(d=>d.type==="image"&&d.file?.startsWith("data:")?{...d,file:"[base64 image data stripped]"}:d)}:c),s=Q.join(o,`messages_${a}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),n.messages_path=s,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(o,`${r}_response_${a}.txt`);K.writeFileSync(s,t.rawLlmResponse),n.response_path=s,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(o,`screenshot_${a}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),n.screenshot_path=r,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(o,`reasoning_${a}.txt`);K.writeFileSync(r,t.reasoningContent),n.reasoning_path=r,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(n).length} artifacts for step ${e}`)}catch(r){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return n}async updateStepResult(e,t,i,a,n){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,o.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),a&&o.artifacts.push(a),n){let r=n.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,n,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=Q.join(e,"test-results.json");await K.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=Q.join(e,"token-usages.json");await K.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=Q.join(e,"ai-actions.json");await K.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}};Pt();ji();Bi();Ei();qe();Oi();Ni();Ve();Li();Fi();vt();_t();Ee();gt();xt();tn();Ue();kt();St();Ze();Et();Tt();Sn();ie();ct();$e();lt();Se();bt();Xe();yt();Ne();Ma();zi();Vi();Xi();Yi();Ji();qi();Zi();Qi();en();nn();an();Ct();Ot();Nt();Dt();Rt();Ft();Ht();Ut();Bt();Gt();jt();Kt();zt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();oi();ri();$t();si();un();Wt();j();We();R();te();et();mn();F();function jh(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(p=>p.type==="year").value,a=t.find(p=>p.type==="month").value,n=t.find(p=>p.type==="day").value,o=t.find(p=>p.type==="hour").value,r=t.find(p=>p.type==="minute").value,s=t.find(p=>p.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),c=`${i}-${a}-${n}T${o}:${r}:${s}.${l}`,d=e.toISOString().slice(0,-1),h=Date.parse(c+"Z"),m=Date.parse(d+"Z"),g=Math.round((m-h)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),y=String(Math.abs(g)%60).padStart(2,"0"),b=g<=0?"+":"-";return`${i}-${a}-${n}T${o}:${r}:${s}.${l}${b}${f}:${y}`}function Al(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",jh()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}pe();export{ml as VariableStore,Tl as WebAgent,Ao as configureSdk,Al as createAgentContext,Vc as defineConfig,Kc as shiplightConfig};