shiplightai 0.1.72 → 0.1.73

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/fixture.js CHANGED
@@ -1,5 +1,5 @@
1
- var Cu=Object.defineProperty;var y=(e,t)=>()=>(e&&(t=e(e=0)),t);var et=(e,t)=>{for(var i in t)Cu(e,i,{get:t[i],enumerable:!0})};async function _r(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,o="";try{for(;;){let{done:a,value:r}=await i.read();if(a)break;o+=n.decode(r,{stream:!0});let s=o.split(`
2
- `);o=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var kr=y(()=>{"use strict"});function Sr(e){So.updateConfig(e)}function W(){return So.getConfig()}function Er(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var Pu,So,Hi,Q=y(()=>{"use strict";Pu=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}},So=new Pu,Hi=So});var $u,Lu,h,N=y(()=>{"use strict";Q();$u=class{getLevel(){return Hi.get("logLevel")}isStderrOnly(){return Hi.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){Hi.set("logLevel",e)}},Lu=new $u,h=Lu});import*as Tr from"fs/promises";import*as it from"vm";async function Du(e,t){let i=await import(e),n=Object.keys(i),o=new it.SyntheticModule(n,function(){for(let a of n)this.setExport(a,i[a])},{context:t});return await o.link(()=>{throw new Error("Nested imports not supported in VM context")}),await o.evaluate(),o}function Eo(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(it.isContext(e)?o=new it.Script(i,{importModuleDynamically:async a=>Du(a,e)}).runInContext(e):o=(0,eval)(i),typeof o!="function")throw new Error("The injected code must be a function");e[t]=o}catch(o){h.error(`Error injecting user function ${t}: ${o.message}`)}}async function Ar(e,t,i=!1){try{let n=await Tr.readFile(t,"utf8"),o=JSON.parse(n);h.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,r]of Object.entries(o))Eo(e,a,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var Mr=y(()=>{"use strict";N()});import*as To from"fs/promises";async function Ir(e){try{let t=await To.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function Cr(e){try{let t=await To.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var Pr=y(()=>{"use strict";N()});import{zodToJsonSchema as $r}from"zod-to-json-schema";function Wi(e){let t=$r(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 It(t),t}function Ui(e){return $r(e,{$refStrategy:"none"})}function It(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))It(i)}e.type==="array"&&e.items&&It(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(It);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&It(i)}}var Ct=y(()=>{"use strict"});var Bi,Gi=y(()=>{"use strict";Ct();Bi=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:Wi(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:Wi(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:Wi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});import{appendFileSync as Lr}from"fs";var Ou,b,ee=y(()=>{"use strict";Q();Ou=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=W().agentLogPath;if(e)try{Lr(e,`
1
+ var Pu=Object.defineProperty;var y=(e,t)=>()=>(e&&(t=e(e=0)),t);var et=(e,t)=>{for(var i in t)Pu(e,i,{get:t[i],enumerable:!0})};async function _r(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,o="";try{for(;;){let{done:a,value:r}=await i.read();if(a)break;o+=n.decode(r,{stream:!0});let s=o.split(`
2
+ `);o=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var kr=y(()=>{"use strict"});function Sr(e){So.updateConfig(e)}function W(){return So.getConfig()}function Er(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var Cu,So,Hi,Q=y(()=>{"use strict";Cu=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}},So=new Cu,Hi=So});var $u,Lu,h,N=y(()=>{"use strict";Q();$u=class{getLevel(){return Hi.get("logLevel")}isStderrOnly(){return Hi.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){Hi.set("logLevel",e)}},Lu=new $u,h=Lu});import*as Tr from"fs/promises";import*as it from"vm";async function Du(e,t){let i=await import(e),n=Object.keys(i),o=new it.SyntheticModule(n,function(){for(let a of n)this.setExport(a,i[a])},{context:t});return await o.link(()=>{throw new Error("Nested imports not supported in VM context")}),await o.evaluate(),o}function Eo(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(it.isContext(e)?o=new it.Script(i,{importModuleDynamically:async a=>Du(a,e)}).runInContext(e):o=(0,eval)(i),typeof o!="function")throw new Error("The injected code must be a function");e[t]=o}catch(o){h.error(`Error injecting user function ${t}: ${o.message}`)}}async function Ar(e,t,i=!1){try{let n=await Tr.readFile(t,"utf8"),o=JSON.parse(n);h.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,r]of Object.entries(o))Eo(e,a,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var Mr=y(()=>{"use strict";N()});import*as To from"fs/promises";async function Ir(e){try{let t=await To.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function Pr(e){try{let t=await To.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var Cr=y(()=>{"use strict";N()});import{zodToJsonSchema as $r}from"zod-to-json-schema";function Wi(e){let t=$r(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 It(t),t}function Ui(e){return $r(e,{$refStrategy:"none"})}function It(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))It(i)}e.type==="array"&&e.items&&It(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(It);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&It(i)}}var Pt=y(()=>{"use strict"});var Bi,Gi=y(()=>{"use strict";Pt();Bi=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:Wi(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:Wi(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:Wi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});import{appendFileSync as Lr}from"fs";var Ou,b,ee=y(()=>{"use strict";Q();Ou=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=W().agentLogPath;if(e)try{Lr(e,`
3
3
  === Agent Execution Log ===
4
4
  Started: ${new Date().toISOString()}
5
5
 
@@ -12,7 +12,7 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
12
12
  ${e}`),this.log(`
13
13
  User Prompt:
14
14
  ${t}`)}response(e){this.log(`LLM Response:
15
- ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!W().agentLogPath}},b=new Ou});var Ki,Nu,Ru,Fu,Hu,Dr,ji,Ao,Or,Mo,Io,me=y(()=>{"use strict";Ki=Object.defineProperty,Nu=Object.getOwnPropertyDescriptor,Ru=Object.getOwnPropertyNames,Fu=Object.prototype.hasOwnProperty,Hu=(e,t,i)=>t in e?Ki(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Dr=(e,t)=>()=>(e&&(t=e(e=0)),t),ji=(e,t)=>{for(var i in t)Ki(e,i,{get:t[i],enumerable:!0})},Ao=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ru(t))!Fu.call(e,o)&&o!==i&&Ki(e,o,{get:()=>t[o],enumerable:!(n=Nu(t,o))||n.enumerable});return e},Or=(e,t,i)=>(Ao(e,t,"default"),i&&Ao(i,t,"default")),Mo=e=>Ao(Ki({},"__esModule",{value:!0}),e),Io=(e,t,i)=>Hu(e,typeof t!="symbol"?t+"":t,i)});function L(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Po}function Wu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function D(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function Co(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Uu(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 Bu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Gu(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=Bu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Gu(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var zi,Pt,Po,pe,P,R=y(()=>{"use strict";me();zi={};ji(zi,{ACTION_TIMEOUT:()=>Po,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>Pt,getActionTimeoutMs:()=>L,getFrameContext:()=>Co,getLocator:()=>D,getMinimalActionEntity:()=>Uu,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>Wu});P=Dr(()=>{Pt=5e3,Po=1e4,pe=2e4})});async function $t(e,t,i=[],n=[]){try{let o=await Co(e,i);if(!o)return h.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${Nr(s)}`),d=Ku(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Nr(t)}`)).elementHandle({timeout:Pt}),!a)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Pt}),!a)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return h.error(`Error in pickBestLocator: ${o}`),null}}async function Vi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Rr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await $t(e,n);i.set(n,o)})),i}function Nr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Ku(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ge=y(()=>{"use strict";N();R();P()});async function Lt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:r=0,height:s=0}=await a.metadata();return b.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function _e(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function Xi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],r=o;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;a.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await Vi(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Yi(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 nt=y(()=>{"use strict";ee();Ge()});function Ji(e,t){let i=t?.trim();return i?Xu(i):e.startsWith(ju)?zu:Vu}function Fr(e,t){return`${Ji(e,t)}/llm/v1`}function Hr(e,t){return`${Ji(e,t)}/llm/v1`}function Wr(e,t){return`${Ji(e,t)}/llm/v1beta`}function Ur(e,t){return`${Ji(e,t)}/llm`}function Xu(e){return e.endsWith("/")?e.slice(0,-1):e}var ju,zu,Vu,De=y(()=>{"use strict";ju="shp_",zu="https://nova-api.shiplight.ai",Vu="https://api.shiplight.ai"});import{createGoogleGenerativeAI as Br}from"@ai-sdk/google";import{createVertex as Yu}from"@ai-sdk/google-vertex";function qi(){let e=(W().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Kr(e){let t=W().env||{};if(qi()){let o=t.GOOGLE_CLOUD_PROJECT;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Yu({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return h.debug(`Using Google AI provider (API key): model=${e}`),Br({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=Wr(n,t.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),Br({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function jr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Gr.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=Gr.MEDIA_RESOLUTION_HIGH)}return qi()?{vertex:o}:{google:o}}var Gr,ot=y(()=>{"use strict";De();N();Q();Gr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Ju,Environment as qu}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function Qu(e,t,i,n,o){let a=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=ge(i.x,n),l=ge(i.y,o),d=ge(i.destination_x,n),c=ge(i.destination_y,o),u=await _e(e,s,l);a={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:b.log(`Unsupported Gemini function: ${t}`)}}catch(s){b.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:a,locatorInfo:await Xi(e,r)}}async function Vr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:r}=e,s=r||eh,l=W(),d;if(qi()){let f=l.env?.GOOGLE_CLOUD_PROJECT;if(!f)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:f,location:S}}else{let f=l.env?.GOOGLE_API_KEY;if(f)h.debug(`Using Google AI provider (API key): model=${s}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let _=Ur(S,l.env?.SHIPLIGHT_API_URL);h.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${_}`),d={apiKey:S,httpOptions:{baseUrl:_}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new Ju(d);b.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:qu.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Zu}],temperature:.1}});b.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:w,args:v}=g.functionCall;b.log(`Generated function call: ${w} with args ${JSON.stringify(v)}`),h.debug(`Generated function call: ${w} with args ${JSON.stringify(v)}`);let{action_data:x,locatorInfo:p}=await Qu(i,w,v,o,a);return x?{status:"success",actionEntity:Yi(t,x,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${w}`}}var zr,Zu,eh,Zi=y(()=>{"use strict";nt();ee();ot();De();N();Q();zr={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"]},Zu=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:zr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:zr}];eh="gemini-3-flash-preview"});function Yr(e){return e!=null&&typeof e=="object"}function at(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Xr(e){return typeof e=="string"?e:void 0}function th(e){let t,i;return Array.isArray(e)?(t=at(e[0]),i=at(e[1])):Yr(e)&&(t=at(e.x),i=at(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Jr(e){if(!Yr(e))return{};let t=Array.isArray(e.path)?e.path.map(th).filter(i=>i!==null):void 0;return{type:Xr(e.type),x:at(e.x),y:at(e.y),button:Xr(e.button),path:t}}var Qi=y(()=>{"use strict"});import ih from"openai";async function nh(e,t){let i=Jr(t),n=null,o=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let a=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await _e(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},o=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await _e(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},o=a.element;break}case"drag":{if(!i.path||i.path.length<2)break;let a=i.path[0],r=i.path[i.path.length-1],s=await _e(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-a.x,delta_y:r.y-a.y}},o=s.element;break}}return{action_data:n,locatorInfo:await Xi(e,o)}}async function Zr(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,r=a||oh,s=await Lt(i,n,o),l=W(),d=l.env?.OPENAI_API_KEY;if(!d)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=l.env?.OPENAI_BASE_URL,u=new ih({apiKey:d,...c&&{baseURL:c}}),m=u.responses.create.bind(u.responses);b.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 w(S,_){let k={model:r,tools:[ah],input:S,temperature:.1};return _&&(k.previous_response_id=_),m(k)}let v=await w(g,void 0),x;for(let S=0;S<qr;S++){b.log(`Received response from OpenAI CUA (turn ${S+1})`);let _=v.output.find(I=>I.type==="computer_call");if(!_)return{status:"error",reasoning:v.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=_.actions??[];if(k.length>1&&b.log(`[openai CUA] dropping ${k.length-1} batched action(s); only the first is executed`),x=k[0],!x)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(x.type!=="screenshot")break;s=await Lt(i,n,o);let E=[{type:"computer_call_output",call_id:_.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];v=await w(E,v.id)}if(!x)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(x.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${qr} turns`};b.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:p,locatorInfo:f}=await nh(i,x);return p?{status:"success",actionEntity:Yi(t,p,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var oh,ah,qr,en=y(()=>{"use strict";nt();Qi();ee();Q();oh="gpt-5.4",ah={type:"computer"},qr=4});import{createAnthropic as Qr}from"@ai-sdk/anthropic";import{createVertexAnthropic as rh}from"@ai-sdk/google-vertex/anthropic";function sh(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function lh(){return sh(W().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function es(e){let t=W();if(lh()){let o=t.env?.GOOGLE_CLOUD_PROJECT,a=t.env?.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${o}, location=${a}`),rh({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return h.debug(`Using Anthropic provider: model=${e}`),Qr({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=Hr(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),Qr({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function $o(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Dt=y(()=>{"use strict";De();N();Q()});import{createOpenAI as ts}from"@ai-sdk/openai";function is(e){let t=W(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),ts({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=Fr(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),ts({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function ns(e){return{}}var Ot=y(()=>{"use strict";De();N();Q()});function as(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ch.test(e))return"openai"}function tn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(dh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=tn(e),n=t??as(i);if(!n)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., "${n}:gpt-5.4-mini").`);let o=os[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(os).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function we(e,t){let{provider:i,modelId:n}=tn(e),o=i??as(n);return o==="anthropic"||o==="vertex"?$o(n):o==="openai"||o==="azure"?ns(n):o==="bedrock"?n.startsWith("anthropic.")?$o(n):{}:jr(t,n)}var ch,dh,os,ke=y(()=>{"use strict";Dt();ot();Ot();ch=/^(gpt-|o\d|chatgpt-)/;dh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);os={anthropic:es,google:Kr,openai:is}});function hh(e){return e.startsWith("gemini-")?"google":"openai"}async function rt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:r}=o;b.log(`Viewport: ${a}x${r}`);let s=await Lt(n,a,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=tn(l),c=hh(d),u=uh[c];b.log(`Using CUA provider: ${c} (model: ${d})`);let m={statement:e,page:n,screenshotB64:s,viewportWidth:a,viewportHeight:r,modelId:d};try{return await u(m)}catch(g){return b.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var uh,st=y(()=>{"use strict";Zi();en();nt();ee();ke();uh={google:Vr,openai:Zr}});function mh(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 n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(a,r.index);l&&o.push({type:"text",text:l});let d=r[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:r[0]}),a=r.index+r[0].length}let s=e.slice(a);return s&&o.push({type:"text",text:s}),o.length===0&&o.push({type:"text",text:e}),o}function ph(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=mh(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
15
+ ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!W().agentLogPath}},b=new Ou});var Ki,Nu,Ru,Fu,Hu,Dr,ji,Ao,Or,Mo,Io,me=y(()=>{"use strict";Ki=Object.defineProperty,Nu=Object.getOwnPropertyDescriptor,Ru=Object.getOwnPropertyNames,Fu=Object.prototype.hasOwnProperty,Hu=(e,t,i)=>t in e?Ki(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Dr=(e,t)=>()=>(e&&(t=e(e=0)),t),ji=(e,t)=>{for(var i in t)Ki(e,i,{get:t[i],enumerable:!0})},Ao=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ru(t))!Fu.call(e,o)&&o!==i&&Ki(e,o,{get:()=>t[o],enumerable:!(n=Nu(t,o))||n.enumerable});return e},Or=(e,t,i)=>(Ao(e,t,"default"),i&&Ao(i,t,"default")),Mo=e=>Ao(Ki({},"__esModule",{value:!0}),e),Io=(e,t,i)=>Hu(e,typeof t!="symbol"?t+"":t,i)});function L(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Co}function Wu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function D(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function Po(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Uu(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 Bu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Gu(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=Bu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Gu(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var zi,Ct,Co,pe,C,R=y(()=>{"use strict";me();zi={};ji(zi,{ACTION_TIMEOUT:()=>Co,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>Ct,getActionTimeoutMs:()=>L,getFrameContext:()=>Po,getLocator:()=>D,getMinimalActionEntity:()=>Uu,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>Wu});C=Dr(()=>{Ct=5e3,Co=1e4,pe=2e4})});async function $t(e,t,i=[],n=[]){try{let o=await Po(e,i);if(!o)return h.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${Nr(s)}`),d=Ku(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Nr(t)}`)).elementHandle({timeout:Ct}),!a)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Ct}),!a)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return h.error(`Error in pickBestLocator: ${o}`),null}}async function Vi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Rr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await $t(e,n);i.set(n,o)})),i}function Nr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Ku(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ge=y(()=>{"use strict";N();R();C()});async function Lt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:r=0,height:s=0}=await a.metadata();return b.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function _e(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function Xi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],r=o;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;a.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await Vi(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Yi(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 nt=y(()=>{"use strict";ee();Ge()});function Ji(e,t){let i=t?.trim();return i?Xu(i):e.startsWith(ju)?zu:Vu}function Fr(e,t){return`${Ji(e,t)}/llm/v1`}function Hr(e,t){return`${Ji(e,t)}/llm/v1`}function Wr(e,t){return`${Ji(e,t)}/llm/v1beta`}function Ur(e,t){return`${Ji(e,t)}/llm`}function Xu(e){return e.endsWith("/")?e.slice(0,-1):e}var ju,zu,Vu,De=y(()=>{"use strict";ju="shp_",zu="https://nova-api.shiplight.ai",Vu="https://api.shiplight.ai"});import{createGoogleGenerativeAI as Br}from"@ai-sdk/google";import{createVertex as Yu}from"@ai-sdk/google-vertex";function qi(){let e=(W().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Kr(e){let t=W().env||{};if(qi()){let o=t.GOOGLE_CLOUD_PROJECT;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Yu({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return h.debug(`Using Google AI provider (API key): model=${e}`),Br({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=Wr(n,t.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),Br({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function jr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Gr.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=Gr.MEDIA_RESOLUTION_HIGH)}return qi()?{vertex:o}:{google:o}}var Gr,ot=y(()=>{"use strict";De();N();Q();Gr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Ju,Environment as qu}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function Qu(e,t,i,n,o){let a=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=ge(i.x,n),l=ge(i.y,o),d=await _e(e,s,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=ge(i.x,n),l=ge(i.y,o),d=ge(i.destination_x,n),c=ge(i.destination_y,o),u=await _e(e,s,l);a={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:b.log(`Unsupported Gemini function: ${t}`)}}catch(s){b.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:a,locatorInfo:await Xi(e,r)}}async function Vr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:r}=e,s=r||eh,l=W(),d;if(qi()){let f=l.env?.GOOGLE_CLOUD_PROJECT;if(!f)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let S=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:f,location:S}}else{let f=l.env?.GOOGLE_API_KEY;if(f)h.debug(`Using Google AI provider (API key): model=${s}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let _=Ur(S,l.env?.SHIPLIGHT_API_URL);h.debug(`Using Shiplight LLM proxy (Google CUA): model=${s}, baseUrl=${_}`),d={apiKey:S,httpOptions:{baseUrl:_}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new Ju(d);b.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:qu.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Zu}],temperature:.1}});b.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:w,args:v}=g.functionCall;b.log(`Generated function call: ${w} with args ${JSON.stringify(v)}`),h.debug(`Generated function call: ${w} with args ${JSON.stringify(v)}`);let{action_data:x,locatorInfo:p}=await Qu(i,w,v,o,a);return x?{status:"success",actionEntity:Yi(t,x,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${w}`}}var zr,Zu,eh,Zi=y(()=>{"use strict";nt();ee();ot();De();N();Q();zr={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"]},Zu=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:zr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:zr}];eh="gemini-3-flash-preview"});function Yr(e){return e!=null&&typeof e=="object"}function at(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Xr(e){return typeof e=="string"?e:void 0}function th(e){let t,i;return Array.isArray(e)?(t=at(e[0]),i=at(e[1])):Yr(e)&&(t=at(e.x),i=at(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Jr(e){if(!Yr(e))return{};let t=Array.isArray(e.path)?e.path.map(th).filter(i=>i!==null):void 0;return{type:Xr(e.type),x:at(e.x),y:at(e.y),button:Xr(e.button),path:t}}var Qi=y(()=>{"use strict"});import ih from"openai";async function nh(e,t){let i=Jr(t),n=null,o=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let a=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await _e(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},o=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await _e(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},o=a.element;break}case"drag":{if(!i.path||i.path.length<2)break;let a=i.path[0],r=i.path[i.path.length-1],s=await _e(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-a.x,delta_y:r.y-a.y}},o=s.element;break}}return{action_data:n,locatorInfo:await Xi(e,o)}}async function Zr(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,r=a||oh,s=await Lt(i,n,o),l=W(),d=l.env?.OPENAI_API_KEY;if(!d)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=l.env?.OPENAI_BASE_URL,u=new ih({apiKey:d,...c&&{baseURL:c}}),m=u.responses.create.bind(u.responses);b.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 w(S,_){let k={model:r,tools:[ah],input:S,temperature:.1};return _&&(k.previous_response_id=_),m(k)}let v=await w(g,void 0),x;for(let S=0;S<qr;S++){b.log(`Received response from OpenAI CUA (turn ${S+1})`);let _=v.output.find(I=>I.type==="computer_call");if(!_)return{status:"error",reasoning:v.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=_.actions??[];if(k.length>1&&b.log(`[openai CUA] dropping ${k.length-1} batched action(s); only the first is executed`),x=k[0],!x)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(x.type!=="screenshot")break;s=await Lt(i,n,o);let E=[{type:"computer_call_output",call_id:_.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];v=await w(E,v.id)}if(!x)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(x.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${qr} turns`};b.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:p,locatorInfo:f}=await nh(i,x);return p?{status:"success",actionEntity:Yi(t,p,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var oh,ah,qr,en=y(()=>{"use strict";nt();Qi();ee();Q();oh="gpt-5.4",ah={type:"computer"},qr=4});import{createAnthropic as Qr}from"@ai-sdk/anthropic";import{createVertexAnthropic as rh}from"@ai-sdk/google-vertex/anthropic";function sh(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function lh(){return sh(W().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function es(e){let t=W();if(lh()){let o=t.env?.GOOGLE_CLOUD_PROJECT,a=t.env?.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${o}, location=${a}`),rh({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return h.debug(`Using Anthropic provider: model=${e}`),Qr({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=Hr(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),Qr({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function $o(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Dt=y(()=>{"use strict";De();N();Q()});import{createOpenAI as ts}from"@ai-sdk/openai";function is(e){let t=W(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),ts({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=Fr(n,t.env?.SHIPLIGHT_API_URL);return h.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),ts({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function ns(e){return{}}var Ot=y(()=>{"use strict";De();N();Q()});function as(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ch.test(e))return"openai"}function tn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(dh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=tn(e),n=t??as(i);if(!n)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., "${n}:gpt-5.4-mini").`);let o=os[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(os).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function we(e,t){let{provider:i,modelId:n}=tn(e),o=i??as(n);return o==="anthropic"||o==="vertex"?$o(n):o==="openai"||o==="azure"?ns(n):o==="bedrock"?n.startsWith("anthropic.")?$o(n):{}:jr(t,n)}var ch,dh,os,ke=y(()=>{"use strict";Dt();ot();Ot();ch=/^(gpt-|o\d|chatgpt-)/;dh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);os={anthropic:es,google:Kr,openai:is}});function hh(e){return e.startsWith("gemini-")?"google":"openai"}async function rt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:r}=o;b.log(`Viewport: ${a}x${r}`);let s=await Lt(n,a,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=tn(l),c=hh(d),u=uh[c];b.log(`Using CUA provider: ${c} (model: ${d})`);let m={statement:e,page:n,screenshotB64:s,viewportWidth:a,viewportHeight:r,modelId:d};try{return await u(m)}catch(g){return b.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var uh,st=y(()=>{"use strict";Zi();en();nt();ee();ke();uh={google:Vr,openai:Zr}});function mh(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 n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(a,r.index);l&&o.push({type:"text",text:l});let d=r[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:r[0]}),a=r.index+r[0].length}let s=e.slice(a);return s&&o.push({type:"text",text:s}),o.length===0&&o.push({type:"text",text:e}),o}function ph(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=mh(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
16
16
 
17
17
  `}),t.push(...a)}return t}function nn(e,t=rs){if(t){let i=ph(e);if(i.length===0)return[];let n={type:"text",text:`
18
18
 
@@ -141,7 +141,7 @@ Based on the above information, please determine the right action to accomplish
141
141
  `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function vh(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 xh(e,!1)}function Lo(e){let t=[],i=e;for(;i&&i.parent!==null;){let a=i.parent;t.push(a),i=a}t.reverse();let n=[],o=t.filter(a=>a.tagName==="iframe");for(let a of o){let r=vh(a);h.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",r),n.push(r)}return n}async function O(e,t){let i=null,n=Lo(t);return t.xpath&&(i=await $t(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var G=y(()=>{"use strict";Ge();N()});import{generateText as _h,Output as kh}from"ai";import{z as sn}from"zod";function Sh(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 Eh(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 Th(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=Eh(n);if(o)return{type:"image",file:o};let a=typeof n=="string"?n:"";return{type:"image",file:a.startsWith("data:")?a:`data:image/png;base64,${a}`}}return{type:"text",text:i.text}}):t.content}))}async function ds(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),r=i.temperature??0,s=o.retrieveKnowledges(e).catch(V=>(b.log(`Failed to retrieve knowledges: ${V.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),u=o.isAccessibilityTreeEnabled(),m=o.isActionIntentFilteringEnabled(),g=m?Sh(e):"all";m&&g!=="all"&&b.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:w,domState:v,pageContext:x}=await an(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:g});t.domState=v;let p=new Bi(F).getToolDefinitions().map(V=>{let Qe=V.function;return`${Qe.name}: ${Qe.description}
142
142
  Parameters: ${JSON.stringify(Qe.parameters,null,2)}`}).join(`
143
143
 
144
- `),f=ls(p),S=await s,_=cs(x,e,t.variables,t.executionHistory,S.length>0?S:void 0,w,l,void 0,c,t.sensitiveKeys),k=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(V=>{V.role==="user"?k.push({role:"user",content:V.content}):V.role==="assistant"&&k.push({role:"assistant",content:V.content})}),k.push({role:"user",content:_});let E=Th(k),I=F.buildActionUnionSchema(),C=sn.object({thought:sn.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:sn.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:sn.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),$=Array.isArray(_)?_.filter(V=>V.type==="image").length:0,B=we(a,$),z=await _h({model:fe(a),system:f,messages:k,temperature:r,output:kh.object({schema:C}),providerOptions:B}),xe=z.reasoningText;h.info(`Action Generation Reasoning: ${xe}`);let j=z.output,X=JSON.stringify(j,null,2);h.info(`Generate Action Raw Output: ${X}`);let ve=[],Be=rn(z.usage,a);Be&&ve.push(Be);let Ce={systemPrompt:f,userPrompt:E,rawLlmResponse:X,tokenUsages:ve},Pe=j.thought||"",$e=j.description||"",U=j.action||{},Y=j.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Pe||$e||"No action generated",goalAccomplished:Y,error:"Agent did not generate any action",debugInfo:Ce};let J=Object.keys(U)[0];if(J==="done")return{status:"error",reasoning:Pe||$e||"Task marked as done",goalAccomplished:Y,error:"Agent indicated task is done without generating an action",debugInfo:Ce};if(J==="perform_accurate_operation")return await rt(e,t,i);if(!Y){let V="Can't complete the instruction in one action";return{status:"error",reasoning:Pe||$e||V,goalAccomplished:!1,error:V,debugInfo:Ce}}let se=U[J]||{},gr={};if(typeof se.element_index=="number"){let V=se.element_index;if(V<0)return{status:"error",reasoning:Pe||$e||"No action generated",goalAccomplished:Y,error:"Agent did not generate any action",debugInfo:Ce};let Qe=v.selectorMap.get(V);Qe&&(gr=await O(n,Qe))}let fr=$e;return J==="verify"&&(fr=e,se.statement=e),{status:"success",actionEntity:{...gr,action_description:fr||Pe||`${J}(${JSON.stringify(se)})`,action_data:{action_name:J,kwargs:se}},reasoning:Pe||$e,goalAccomplished:Y,debugInfo:Ce}}var ln=y(()=>{"use strict";Gi();st();on();Rt();Ft();Se();ee();ke();G();N()});import{generateText as Ah,Output as Mh}from"ai";import{z as cn}from"zod";function Ih(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 Do(e,t,i={}){return i.usePureVision?rt(e,t,i):ds(e,t,i)}function Ph(){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 $h(){return`# Role
144
+ `),f=ls(p),S=await s,_=cs(x,e,t.variables,t.executionHistory,S.length>0?S:void 0,w,l,void 0,c,t.sensitiveKeys),k=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(V=>{V.role==="user"?k.push({role:"user",content:V.content}):V.role==="assistant"&&k.push({role:"assistant",content:V.content})}),k.push({role:"user",content:_});let E=Th(k),I=F.buildActionUnionSchema(),P=sn.object({thought:sn.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:sn.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:sn.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),$=Array.isArray(_)?_.filter(V=>V.type==="image").length:0,B=we(a,$),z=await _h({model:fe(a),system:f,messages:k,temperature:r,output:kh.object({schema:P}),providerOptions:B}),xe=z.reasoningText;h.info(`Action Generation Reasoning: ${xe}`);let j=z.output,X=JSON.stringify(j,null,2);h.info(`Generate Action Raw Output: ${X}`);let ve=[],Be=rn(z.usage,a);Be&&ve.push(Be);let Pe={systemPrompt:f,userPrompt:E,rawLlmResponse:X,tokenUsages:ve},Ce=j.thought||"",$e=j.description||"",U=j.action||{},Y=j.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Ce||$e||"No action generated",goalAccomplished:Y,error:"Agent did not generate any action",debugInfo:Pe};let J=Object.keys(U)[0];if(J==="done")return{status:"error",reasoning:Ce||$e||"Task marked as done",goalAccomplished:Y,error:"Agent indicated task is done without generating an action",debugInfo:Pe};if(J==="perform_accurate_operation")return await rt(e,t,i);if(!Y){let V="Can't complete the instruction in one action";return{status:"error",reasoning:Ce||$e||V,goalAccomplished:!1,error:V,debugInfo:Pe}}let se=U[J]||{},gr={};if(typeof se.element_index=="number"){let V=se.element_index;if(V<0)return{status:"error",reasoning:Ce||$e||"No action generated",goalAccomplished:Y,error:"Agent did not generate any action",debugInfo:Pe};let Qe=v.selectorMap.get(V);Qe&&(gr=await O(n,Qe))}let fr=$e;return J==="verify"&&(fr=e,se.statement=e),{status:"success",actionEntity:{...gr,action_description:fr||Ce||`${J}(${JSON.stringify(se)})`,action_data:{action_name:J,kwargs:se}},reasoning:Ce||$e,goalAccomplished:Y,debugInfo:Pe}}var ln=y(()=>{"use strict";Gi();st();on();Rt();Ft();Se();ee();ke();G();N()});import{generateText as Ah,Output as Mh}from"ai";import{z as cn}from"zod";function Ih(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 Do(e,t,i={}){return i.usePureVision?rt(e,t,i):ds(e,t,i)}function Ch(){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 $h(){return`# Role
145
145
  You are an experienced QA person for web applications.
146
146
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
147
147
  `}async function us(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:m,domState:g,pageContext:w}=await an(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let v="";o&&o.length>0&&(v=`
@@ -149,7 +149,7 @@ You are tasked to verify the validity of a given statement based on the screensh
149
149
  ${o.map(([U,Y],J)=>`${J+1}. Action: ${U}
150
150
  Result: ${Y}`).join(`
151
151
  `)}
152
- `);let{dateString:x,timeString:p}=Ph(),f=`
152
+ `);let{dateString:x,timeString:p}=Ch(),f=`
153
153
  # User statement
154
154
  "${e}"
155
155
 
@@ -178,7 +178,7 @@ ${v}
178
178
 
179
179
  Today is ${x}. Current local time is ${p}.
180
180
  Based on the above information, please determine if the statement is true.
181
- `,k=await t.agentServices.retrieveKnowledges(e),E=[{type:"text",text:f}],I=0;if(r&&m&&m.length>0)for(let U of m)E.push({type:"image",image:U}),I++;else E.push({type:"image",image:u}),I=1;if(k&&k.length>0){let U=nn(k,l);E.push(...U)}E.push({type:"text",text:_});let C=k?ss(k,l):0,$=I+C,B=we(a,$),z=$h(),xe=await Ah({model:fe(a),system:z,messages:[{role:"user",content:E}],output:Mh.object({schema:Ch}),temperature:0,providerOptions:B}),{conclusion:j,explanation:X}=xe.output,ve=JSON.stringify(xe.output,null,2),Be=[],Ce=rn(xe.usage,a);Ce&&Be.push(Ce);let Pe=[{role:"user",content:E.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let Y=U.image,J=Ih(Y);if(J)return{type:"image",file:J};let se=typeof Y=="string"?Y:"";return{type:"image",file:se.startsWith("data:")?se:`data:image/png;base64,${se}`}}return{type:"text",text:"[unknown content type]"}})}],$e={systemPrompt:z,userPrompt:Pe,rawLlmResponse:ve,screenshotWithSom:u,tokenUsages:Be,retrievedKnowledges:k&&k.length>0?k:void 0,elementTree:c};return{success:j==="true",explanation:X,debugInfo:$e}}catch(r){return{success:!1,error:r.message}}}var Ch,dn=y(()=>{"use strict";ln();st();Rt();Ft();Nt();ke();Ch=cn.object({screenshotDescription:cn.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
181
+ `,k=await t.agentServices.retrieveKnowledges(e),E=[{type:"text",text:f}],I=0;if(r&&m&&m.length>0)for(let U of m)E.push({type:"image",image:U}),I++;else E.push({type:"image",image:u}),I=1;if(k&&k.length>0){let U=nn(k,l);E.push(...U)}E.push({type:"text",text:_});let P=k?ss(k,l):0,$=I+P,B=we(a,$),z=$h(),xe=await Ah({model:fe(a),system:z,messages:[{role:"user",content:E}],output:Mh.object({schema:Ph}),temperature:0,providerOptions:B}),{conclusion:j,explanation:X}=xe.output,ve=JSON.stringify(xe.output,null,2),Be=[],Pe=rn(xe.usage,a);Pe&&Be.push(Pe);let Ce=[{role:"user",content:E.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let Y=U.image,J=Ih(Y);if(J)return{type:"image",file:J};let se=typeof Y=="string"?Y:"";return{type:"image",file:se.startsWith("data:")?se:`data:image/png;base64,${se}`}}return{type:"text",text:"[unknown content type]"}})}],$e={systemPrompt:z,userPrompt:Ce,rawLlmResponse:ve,screenshotWithSom:u,tokenUsages:Be,retrievedKnowledges:k&&k.length>0?k:void 0,elementTree:c};return{success:j==="true",explanation:X,debugInfo:$e}}catch(r){return{success:!1,error:r.message}}}var Ph,dn=y(()=>{"use strict";ln();st();Rt();Ft();Nt();ke();Ph=cn.object({screenshotDescription:cn.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
182
182
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
183
183
  [45] A modal dialog titled "Confirmation",
184
184
  in the center of the screen`),explanation:cn.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:cn.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function ms(){let{default:e}=await import("sharp");return e}async function Oo(e,t){let i=await ms(),n=await i(e).metadata(),o=n.width||0,a=n.height||0;if(o===0||a===0)throw new Error("Invalid image dimensions");let r=a,s=0,l=Math.floor((o-r)/2),d=Math.max(0,o-r),c=(w,v)=>{let x=i(e).extract({left:w,top:0,width:v,height:r});return t?.resize&&(x=x.resize(hs,hs)),x.png().toBuffer()},[u,m,g]=await Promise.all([c(s,Math.min(r,o)),c(l,Math.min(r,o-l)),c(d,Math.min(r,o-d))]);return[u,m,g]}async function ps(e){let t=(await ms())(e),i=await t.metadata(),n=i.width||0,o=i.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let{data:a}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<o;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=a[s*n+l]}return{pixels:r,width:n,height:o}}var hs,Ht=y(()=>{"use strict";hs=768});function gs(e){return e?Wt.has(e):!1}function fs(e){return ct.has(e)}function ws(e){return e.filter(t=>ct.has(t.type))}var Wt,ct,un,hn,Ut=y(()=>{"use strict";Wt=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),ct=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),un=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],hn=500});function bs(e,t){return e.length>t?e.slice(0,t)+"...":e}var Bt=y(()=>{"use strict"});var ys,xs,Gt=y(()=>{"use strict";ys=["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"],xs={"react-flow__(\\S+)":"$1"}});var vs,Kt,be,dt=y(()=>{"use strict";Bt();Gt();vs=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},Kt=class extends vs{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}},be=class mn extends vs{constructor(t,i,n,o,a,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,m=null,g=null,w=null,v=null,x=[],p=null){super(a,p),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=m,this.viewportCoordinates=g,this.pageCoordinates=w,this.viewportInfo=v,this.isNew=null,this.shadowHostXPaths=x}getAllTextTillNextClickableElement(t=-1){let i=[],n=(o,a)=>{if(!(t!==-1&&a>t)&&!(o instanceof mn&&o!==this&&o.highlightIndex!==null)){if(o instanceof Kt)i.push(o.text);else if(o instanceof mn)for(let r of o.children)n(r,a+1)}};return n(this,0),i.join(`
@@ -4083,12 +4083,12 @@ Based on the above information, please determine if the statement is true.
4083
4083
  } : null,
4084
4084
  clientRects: clientRectsArray
4085
4085
  };
4086
- }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=hn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=un.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});h.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.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}),d=l.filter(c=>ct.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new be("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new be(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new Kt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,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)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let m=document.createElement("div");m.style.position="fixed",m.style.background=d,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,c.y-16),w=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${w}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.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(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Oh(e.url()))return[new be("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:I,argsObj:C})=>new Function("return "+I)()(C),{code:this.jsCode,argsObj:x});h.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),_=await ps(f);u=_.pixels;let k=Math.round(performance.now()-S);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${_.width}x${_.height}) in ${k}ms`);let E={...d,phase:"labels",grayscaleImage:u,elementData:p.elementData};c=await e.evaluate(({code:I,argsObj:C})=>new Function("return "+I)()(C),{code:this.jsCode,argsObj:E}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){h.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),u=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:p}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:p})=>new Function("return "+x)()(p),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw h.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:f})=>new Function("return "+p)()(f),{code:this.jsCode,argsObj:x})}let m=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[x,p]of m){let f=p;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let w=[];for(let[x,p]of Object.entries(c.map)){let f=p;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&w.push({nodeId:x,src:f.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${w.length}`),w.length>0){h.debug(`\u{1F50C} Found ${w.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let p of Object.values(c.map)){let f=p;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let p=0;p<w.length;p++){let{nodeId:f,src:S}=w[p];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let _=C=>{try{let $=new URL(C);if($.protocol==="chrome-extension:"&&$.hostname)return`chrome-extension://${$.hostname}`;let B=$.origin;return B==="null"?null:B}catch{return null}},k=_(S);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let E=null,I=e.frames().find(C=>{let $=C.url();if($===S)return E="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${$}`),!0;let B=_($);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${$} origin=${B??"null"} vs srcOrigin=${k??"null"}`),k&&B===k?(E="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${$}`),!0):!1});if(!I){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(C=>C.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let C={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${C.initialHighlightIndex}`);let $=await I.evaluate(({code:j,argsObj:X})=>new Function("return "+j)()(X),{code:this.jsCode,argsObj:C});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys($?.map??{}).length} rootId=${$?.rootId}`),!$?.map||!$.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let B=Object.values($.map).filter(j=>j.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${B.length}`);for(let j of B){let X=j;h.debug(`\u{1F50D} [ext-iframe] - <${X.tagName}> highlightIndex=${X.highlightIndex} text="${X.children?.length?"...":""}"`)}for(let j of Object.values($.map)){let X=j;X.highlightIndex!=null&&(x=Math.max(x,X.highlightIndex))}let z=`ext_${p}_`;for(let[j,X]of Object.entries($.map)){let ve={...X};ve.children&&(ve.children=ve.children.map(Be=>`${z}${Be}`)),c.map[`${z}${j}`]=ve}let xe=c.map[f];xe?(xe.children=[...xe.children||[],`${z}${$.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(C){h.warn(`Failed to process fallback iframe ${S}:`,C)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${p}/${x}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof be&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof be)for(let c of l){let u=o.get(c);u&&(u.parent=d,d.children.push(u))}}let r=o.get(i);if(!r||!(r instanceof be))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Kt(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??[],n=new be(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),o=e.children||[];return[n,o]}}});import{z as Nh}from"zod";var _s,Hw,pn=y(()=>{"use strict";_s=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Hw=Nh.object({})});var ks,gn=y(()=>{"use strict";R();P();ks=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=D(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{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 o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=L();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import*as Rh from"playwright/test";import{default as Fh}from"playwright/test";var ut,jt=y(()=>{"use strict";me();ut={};ji(ut,{default:()=>Fh});Or(ut,Rh)});import{z as Ss}from"zod";var Es,Jw,fn=y(()=>{"use strict";jt();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
4086
+ }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=hn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=un.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});h.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.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}),d=l.filter(c=>ct.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new be("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new be(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new Kt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,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)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let m=document.createElement("div");m.style.position="fixed",m.style.background=d,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,c.y-16),w=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${w}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.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(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Oh(e.url()))return[new be("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:I,argsObj:P})=>new Function("return "+I)()(P),{code:this.jsCode,argsObj:x});h.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),_=await ps(f);u=_.pixels;let k=Math.round(performance.now()-S);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${_.width}x${_.height}) in ${k}ms`);let E={...d,phase:"labels",grayscaleImage:u,elementData:p.elementData};c=await e.evaluate(({code:I,argsObj:P})=>new Function("return "+I)()(P),{code:this.jsCode,argsObj:E}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){h.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),u=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:p}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:p})=>new Function("return "+x)()(p),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw h.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:f})=>new Function("return "+p)()(f),{code:this.jsCode,argsObj:x})}let m=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[x,p]of m){let f=p;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let w=[];for(let[x,p]of Object.entries(c.map)){let f=p;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&w.push({nodeId:x,src:f.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${w.length}`),w.length>0){h.debug(`\u{1F50C} Found ${w.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let p of Object.values(c.map)){let f=p;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let p=0;p<w.length;p++){let{nodeId:f,src:S}=w[p];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${S}`);let _=P=>{try{let $=new URL(P);if($.protocol==="chrome-extension:"&&$.hostname)return`chrome-extension://${$.hostname}`;let B=$.origin;return B==="null"?null:B}catch{return null}},k=_(S);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let E=null,I=e.frames().find(P=>{let $=P.url();if($===S)return E="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${$}`),!0;let B=_($);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${$} origin=${B??"null"} vs srcOrigin=${k??"null"}`),k&&B===k?(E="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${$}`),!0):!1});if(!I){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(P=>P.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let P={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${P.initialHighlightIndex}`);let $=await I.evaluate(({code:j,argsObj:X})=>new Function("return "+j)()(X),{code:this.jsCode,argsObj:P});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys($?.map??{}).length} rootId=${$?.rootId}`),!$?.map||!$.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let B=Object.values($.map).filter(j=>j.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${B.length}`);for(let j of B){let X=j;h.debug(`\u{1F50D} [ext-iframe] - <${X.tagName}> highlightIndex=${X.highlightIndex} text="${X.children?.length?"...":""}"`)}for(let j of Object.values($.map)){let X=j;X.highlightIndex!=null&&(x=Math.max(x,X.highlightIndex))}let z=`ext_${p}_`;for(let[j,X]of Object.entries($.map)){let ve={...X};ve.children&&(ve.children=ve.children.map(Be=>`${z}${Be}`)),c.map[`${z}${j}`]=ve}let xe=c.map[f];xe?(xe.children=[...xe.children||[],`${z}${$.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch(P){h.warn(`Failed to process fallback iframe ${S}:`,P)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&p++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${p}/${x}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let v=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),v}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof be&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof be)for(let c of l){let u=o.get(c);u&&(u.parent=d,d.children.push(u))}}let r=o.get(i);if(!r||!(r instanceof be))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Kt(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??[],n=new be(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),o=e.children||[];return[n,o]}}});import{z as Nh}from"zod";var _s,Bw,pn=y(()=>{"use strict";_s=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Bw=Nh.object({})});var ks,gn=y(()=>{"use strict";R();C();ks=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=D(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{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 o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=L();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import*as Rh from"playwright/test";import{default as Fh}from"playwright/test";var ut,jt=y(()=>{"use strict";me();ut={};ji(ut,{default:()=>Fh});Or(ut,Rh)});import{z as Ss}from"zod";var Es,Qw,fn=y(()=>{"use strict";jt();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
4087
4087
  return (async () => {
4088
4088
  ${o}
4089
4089
  })();
4090
4090
  `)(e,ut.expect,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4091
- `);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},Jw=Ss.object({code:Ss.string().describe("JavaScript code to execute in the browser context")})});var Ts,wn=y(()=>{"use strict";R();P();Ts=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var As,bn=y(()=>{"use strict";As=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.generateFunctionCallCode(n.kwargs);if(!o)throw new Error("Missing function name for function action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4091
+ `);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},Qw=Ss.object({code:Ss.string().describe("JavaScript code to execute in the browser context")})});var Ts,wn=y(()=>{"use strict";R();C();Ts=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var As,bn=y(()=>{"use strict";As=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.generateFunctionCallCode(n.kwargs);if(!o)throw new Error("Missing function name for function action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4092
4092
  return (async () => {
4093
4093
  ${o}
4094
4094
  })();
@@ -4097,20 +4097,20 @@ Based on the above information, please determine if the statement is true.
4097
4097
  ${o}
4098
4098
  })();
4099
4099
  `)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4100
- `):["// Skipping js_action: missing code"]}}});var Is,xn=y(()=>{"use strict";R();P();Is=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var Cs,vn=y(()=>{"use strict";R();P();Cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var Ps,_n=y(()=>{"use strict";R();P();Ps=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,r=[a.coord_source_x,a.coord_source_y],s=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=D(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,u=d.y+a.relative_y+d.height/2,m=c+a.delta_x,g=u+a.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,g,{steps:n}):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,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),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=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),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(o=>` ${o},`),"});"]}}});import{createHash as No}from"crypto";var $s,kn=y(()=>{"use strict";dt();$s=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof be){let r=n(a);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return No("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return No("sha256").update(t).digest("hex")}static xpathHash(e){return No("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Ro,ht=y(()=>{"use strict";Ro=(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))(Ro||{})});var mt={};et(mt,{evaluateStatement:()=>ze,executeAction:()=>zt,executeStep:()=>je,generateActionStep:()=>gt,runTask:()=>Ve});var pt=y(()=>{"use strict";Vt();dn();ln();Gi();st();Zi();en();nt();Qi();on();Rt();Ft();Se();Ct();Nt();kn();Ke();Ht();Ut();dt();Bt();Gt();ee();ke();Dt();ot();Ot();De();G();Ge();N();Q();ht();R();me()});import{z as Ls}from"zod";var Ds,iy,Sn=y(()=>{"use strict";Ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(pt(),mt)),s=await r(o,e,i,{usePureVision:a});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 n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},iy=Ls.object({statement:Ls.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Os}from"zod";var Ns,ry,En=y(()=>{"use strict";Ns=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(pt(),mt)),r=await a(o,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"]}},ry=Os.object({statement:Os.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Rs}from"zod";function Hs(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Hh,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,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:o}},feedback:s.message}}}}})}var Fs,Hh,Xt=y(()=>{"use strict";Fs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Hh=Rs.object({timeout_seconds:Rs.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Fo}from"zod";function Us(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:Wh,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Ws,Wh,Yt=y(()=>{"use strict";Ws=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(pt(),mt));for(;Date.now()-s<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},Wh=Fo.object({condition:Fo.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Fo.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Jt}from"zod";async function Uh(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Bs(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ks(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Bh,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:Bs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await Uh("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:Bs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var Gs,Bh,qt=y(()=>{"use strict";G();R();P();Gs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=D(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${L()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Bh=Jt.object({element_index:Jt.number().int().describe("Index of the scrollable element"),delta_x:Jt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Jt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Jt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as js}from"zod";function Vs(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Gh,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var zs,Gh,Zt=y(()=>{"use strict";zs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.text;if(n)await e.getByText(n,{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();`]}},Gh=js.object({text:js.string().describe("Text to scroll to on the page")})});import{z as Tn}from"zod";async function Kh(e,t,i,n){return{...await O(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Xs(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 Js(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:jh,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Xs(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await Kh(d,r,a,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Xs(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var Ys,jh,Qt=y(()=>{"use strict";G();R();P();Ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=D(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{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(n=>` ${n},`),"});"]}};jh=Tn.object({element_index:Tn.number().int().describe("Index of the dropdown/select element"),option:Tn.string().describe("Option value, label, or index to select"),timeout_ms:Tn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as An}from"zod";async function zh(e,t,i,n){return{...await O(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Ho(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 Zs(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
+ `):["// Skipping js_action: missing code"]}}});var Is,xn=y(()=>{"use strict";R();C();Is=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var Ps,vn=y(()=>{"use strict";R();C();Ps=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=D(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.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 n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.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(n=>` ${n},`),"});"]}}});var Cs,_n=y(()=>{"use strict";R();C();Cs=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,r=[a.coord_source_x,a.coord_source_y],s=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=D(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,u=d.y+a.relative_y+d.height/2,m=c+a.delta_x,g=u+a.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,g,{steps:n}):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,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),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=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),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(o=>` ${o},`),"});"]}}});import{createHash as No}from"crypto";var $s,kn=y(()=>{"use strict";dt();$s=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof be){let r=n(a);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return No("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return No("sha256").update(t).digest("hex")}static xpathHash(e){return No("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Ro,ht=y(()=>{"use strict";Ro=(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))(Ro||{})});var mt={};et(mt,{evaluateStatement:()=>ze,executeAction:()=>zt,executeStep:()=>je,generateActionStep:()=>gt,runTask:()=>Ve});var pt=y(()=>{"use strict";Vt();dn();ln();Gi();st();Zi();en();nt();Qi();on();Rt();Ft();Se();Pt();Nt();kn();Ke();Ht();Ut();dt();Bt();Gt();ee();ke();Dt();ot();Ot();De();G();Ge();N();Q();ht();R();me()});import{z as Ls}from"zod";var Ds,ay,Sn=y(()=>{"use strict";Ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(pt(),mt)),s=await r(o,e,i,{usePureVision:a});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 n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},ay=Ls.object({statement:Ls.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Os}from"zod";var Ns,cy,En=y(()=>{"use strict";Ns=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(pt(),mt)),r=await a(o,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"]}},cy=Os.object({statement:Os.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Rs}from"zod";function Hs(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Hh,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,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:o}},feedback:s.message}}}}})}var Fs,Hh,Xt=y(()=>{"use strict";Fs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Hh=Rs.object({timeout_seconds:Rs.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Fo}from"zod";function Us(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:Wh,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Ws,Wh,Yt=y(()=>{"use strict";Ws=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(pt(),mt));for(;Date.now()-s<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},Wh=Fo.object({condition:Fo.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Fo.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Jt}from"zod";async function Uh(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Bs(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ks(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Bh,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:Bs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await Uh("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:Bs(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var Gs,Bh,qt=y(()=>{"use strict";G();R();C();Gs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=D(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${L()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Bh=Jt.object({element_index:Jt.number().int().describe("Index of the scrollable element"),delta_x:Jt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Jt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Jt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as js}from"zod";function Vs(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Gh,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var zs,Gh,Zt=y(()=>{"use strict";zs=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.text;if(n)await e.getByText(n,{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();`]}},Gh=js.object({text:js.string().describe("Text to scroll to on the page")})});import{z as Tn}from"zod";async function Kh(e,t,i,n){return{...await O(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Xs(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 Js(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:jh,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Xs(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await Kh(d,r,a,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Xs(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var Ys,jh,Qt=y(()=>{"use strict";G();R();C();Ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=D(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{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(n=>` ${n},`),"});"]}};jh=Tn.object({element_index:Tn.number().int().describe("Index of the dropdown/select element"),option:Tn.string().describe("Option value, label, or index to select"),timeout_ms:Tn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as An}from"zod";async function zh(e,t,i,n){return{...await O(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Ho(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 Zs(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">).
4101
4101
 
4102
4102
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4103
4103
  Do NOT use it for custom/non-native date pickers
4104
4104
 
4105
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Vh,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await zh(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var qs,Vh,ei=y(()=>{"use strict";G();R();P();qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=D(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(a,{timeout:L(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(n=>` ${n},`),"});"]}};Vh=An.object({element_index:An.number().int().describe("Index of the native date picker input element"),date:An.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:An.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qs}from"zod";function tl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Xh,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var el,Xh,ti=y(()=>{"use strict";el=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;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} } },`,"});"]}},Xh=Qs.object({tab_index:Qs.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import Yh from"fs";import Jh from"path";async function il(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return Jh.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await Mn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await Mn(e,u,s,d);return}if(o){let c=r.map(m=>`"${m}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await o(e,u,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Mn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Yh.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var ii=y(()=>{"use strict";N()});import{z as Oe}from"zod";async function qh(e,t,i={},n){return{...await O(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function nl(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 al(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:Zh,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:nl(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await qh(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:nl(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var ol,Zh,Ky,ni=y(()=>{"use strict";ii();G();R();P();ol=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=D(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Mn(e,r,a,{useFileInput:s,timeout:L(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),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(o=>` ${o},`),"});"]}};Zh=Oe.object({element_index:Oe.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Oe.string().describe("Paths to the files to upload"),timeout_ms:Oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Ky=Oe.object({element_index:Oe.number().int().describe("Index of the file input element"),paths:Oe.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as rl}from"zod";function ll(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Qh,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var sl,Qh,oi=y(()=>{"use strict";sl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},Qh=rl.object({seconds:rl.number().positive().describe("Number of seconds to wait")})});import{z as cl}from"zod";function dl(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:em,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var Wo,em,ai=y(()=>{"use strict";Wo=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(n),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},em=cl.object({keys:cl.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 tm}from"zod";function hl(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:im,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.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 ul,im,ri=y(()=>{"use strict";R();P();ul=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, {});']}},im=tm.object({})});import{z as Uo}from"zod";async function nm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ml(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 pl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:om,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ml(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await nm("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ml(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Bo,om,si=y(()=>{"use strict";G();R();P();Bo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});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},`),"});"]}};om=Uo.object({element_index:Uo.number().int().describe("Index of the element to right-click"),timeout_ms:Uo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Go}from"zod";function fl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:am,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var gl,am,li=y(()=>{"use strict";gl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}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)} } },`,"});"]}},am=Go.object({name:Go.string().describe("Variable name to save"),value:Go.string().describe("Value to save in the variable")})});import{z as Ko}from"zod";async function rm(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function sm(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function wl(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:lm,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await rm("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:sm(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var ci,lm,di=y(()=>{"use strict";ci=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}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)})');`]}};lm=Ko.object({down:Ko.boolean().describe("True to scroll down, False to scroll up"),num_pages:Ko.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as bl}from"zod";function xl(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:cm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,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:o}},feedback:s.message}}}}})}var yl,cm,ui=y(()=>{"use strict";yl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);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)} } },`,"});"]}},cm=bl.object({otp_secret_key:bl.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as vl}from"zod";async function dm(e,t,i){return{...await O(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function _l(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 Sl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:um,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:_l(s||`Get options from dropdown ${o}`,{index:o})};let d=await dm(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:_l(s||`Get options from dropdown ${o}`,{index:o})}}}})}var kl,um,hi=y(()=>{"use strict";G();kl=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.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(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
4105
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Vh,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await zh(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ho(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var qs,Vh,ei=y(()=>{"use strict";G();R();C();qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=D(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(a,{timeout:L(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(n=>` ${n},`),"});"]}};Vh=An.object({element_index:An.number().int().describe("Index of the native date picker input element"),date:An.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:An.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qs}from"zod";function tl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Xh,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var el,Xh,ti=y(()=>{"use strict";el=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;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} } },`,"});"]}},Xh=Qs.object({tab_index:Qs.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import Yh from"fs";import Jh from"path";async function il(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return Jh.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await Mn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await Mn(e,u,s,d);return}if(o){let c=r.map(m=>`"${m}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await o(e,u,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Mn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Yh.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var ii=y(()=>{"use strict";N()});import{z as Oe}from"zod";async function qh(e,t,i={},n){return{...await O(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function nl(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 al(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:Zh,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:nl(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await qh(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:nl(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var ol,Zh,Vy,ni=y(()=>{"use strict";ii();G();R();C();ol=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=D(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Mn(e,r,a,{useFileInput:s,timeout:L(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),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(o=>` ${o},`),"});"]}};Zh=Oe.object({element_index:Oe.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Oe.string().describe("Paths to the files to upload"),timeout_ms:Oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Vy=Oe.object({element_index:Oe.number().int().describe("Index of the file input element"),paths:Oe.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as rl}from"zod";function ll(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Qh,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var sl,Qh,oi=y(()=>{"use strict";sl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},Qh=rl.object({seconds:rl.number().positive().describe("Number of seconds to wait")})});import{z as cl}from"zod";function dl(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:em,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var Wo,em,ai=y(()=>{"use strict";Wo=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.keys;if(!n||typeof n!="string")throw new Error("Missing or invalid keys for press action");await e.keyboard.press(n),await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]}},em=cl.object({keys:cl.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 tm}from"zod";function hl(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:im,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.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 ul,im,ri=y(()=>{"use strict";R();C();ul=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, {});']}},im=tm.object({})});import{z as Uo}from"zod";async function nm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ml(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 pl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:om,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ml(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await nm("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ml(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Bo,om,si=y(()=>{"use strict";G();R();C();Bo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});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},`),"});"]}};om=Uo.object({element_index:Uo.number().int().describe("Index of the element to right-click"),timeout_ms:Uo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Go}from"zod";function fl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:am,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var gl,am,li=y(()=>{"use strict";gl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}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)} } },`,"});"]}},am=Go.object({name:Go.string().describe("Variable name to save"),value:Go.string().describe("Value to save in the variable")})});import{z as Ko}from"zod";async function rm(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function sm(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function wl(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:lm,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await rm("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:sm(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var ci,lm,di=y(()=>{"use strict";ci=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}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)})');`]}};lm=Ko.object({down:Ko.boolean().describe("True to scroll down, False to scroll up"),num_pages:Ko.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as bl}from"zod";function xl(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:cm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,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:o}},feedback:s.message}}}}})}var yl,cm,ui=y(()=>{"use strict";yl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);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)} } },`,"});"]}},cm=bl.object({otp_secret_key:bl.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as vl}from"zod";async function dm(e,t,i){return{...await O(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function _l(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 Sl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:um,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:_l(s||`Get options from dropdown ${o}`,{index:o})};let d=await dm(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:_l(s||`Get options from dropdown ${o}`,{index:o})}}}})}var kl,um,hi=y(()=>{"use strict";G();kl=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.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(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
4106
4106
  `);o+=`
4107
- Use the exact text string in select_dropdown_option`,i.addNote(o)}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},`),"});"]}};um=vl.object({element_index:vl.number().int().describe("Index of the dropdown/select element")})});import{z as hm}from"zod";function Tl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:mm,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{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 El,mm,mi=y(()=>{"use strict";R();P();El=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, {});']}},mm=hm.object({})});import{z as In}from"zod";function Al(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:pm,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let m=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+u}}catch(m){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var jo,pm,pi=y(()=>{"use strict";R();P();jo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,l=e;a&&(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,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},pm=In.object({url:In.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:In.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:In.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as zo}from"zod";async function gm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ml(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 Il(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:fm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Ml(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await gm("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ml(`Hover element ${o}`,"hover",{index:o})}}}})}var Vo,fm,gi=y(()=>{"use strict";G();R();P();Vo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.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},`),"});"]}};fm=zo.object({element_index:zo.number().int().describe("Index of the element to hover over"),timeout_ms:zo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Cn}from"zod";async function wm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Cl(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 Pl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:bm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Cl(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,u=await wm("input_text",c,d,r,{text:a});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Cl(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Xo,bm,fi=y(()=>{"use strict";G();R();P();Xo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=D(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.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(a,{delay:l}):await e.keyboard.type(a)}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(n=>` ${n},`),"});"]}};bm=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 Yo}from"zod";async function ym(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function $l(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 Dl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:xm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:$l(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await ym("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:$l(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Ll,xm,wi=y(()=>{"use strict";G();R();P();Ll=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),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},`),"});"]}};xm=Yo.object({element_index:Yo.number().int().describe("Index of the input element to clear"),timeout_ms:Yo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Jo}from"zod";async function vm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ol(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 Nl(e,t){e.register({name:"click",description:"Click an interactive element.",schema:_m,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Ol(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await vm("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ol(`Click element ${o}`,"click",{index:o})}}}})}var Pn,_m,bi=y(()=>{"use strict";G();R();P();Pn=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});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=L();return[`await ${t}.click({ timeout: ${i} });`]}};_m=Jo.object({element_index:Jo.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Jo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Rl}from"zod";function Hl(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:km,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}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 Fl,km,yi=y(()=>{"use strict";Fl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}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} } },`,"});"]}},km=Rl.object({index:Rl.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as qo}from"zod";function Ul(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Sm,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{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 Wl,Sm,xi=y(()=>{"use strict";Wl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Sm=qo.object({success:qo.boolean().describe("Whether the task was completed successfully"),summary:qo.string().describe("Summary of what was accomplished or why it failed")})});import{z as Zo}from"zod";async function Em(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Bl(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 Gl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Tm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await Em("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Qo,Tm,vi=y(()=>{"use strict";G();R();P();Qo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});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},`),"});"]}};Tm=Zo.object({element_index:Zo.number().int().describe("Index of the element to double-click"),timeout_ms:Zo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as Am}from"@babel/parser";function Kl(e){if(!e.trim())return!1;try{return Am(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var $n=y(()=>{"use strict"});import{z as jl}from"zod";function zl(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:Mm,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Ln,Mm,_i=y(()=>{"use strict";jt();$n();N();Ln=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(u){let m=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(pt(),mt)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4107
+ Use the exact text string in select_dropdown_option`,i.addNote(o)}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},`),"});"]}};um=vl.object({element_index:vl.number().int().describe("Index of the dropdown/select element")})});import{z as hm}from"zod";function Tl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:mm,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{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 El,mm,mi=y(()=>{"use strict";R();C();El=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, {});']}},mm=hm.object({})});import{z as In}from"zod";function Al(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:pm,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let m=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+u}}catch(m){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var jo,pm,pi=y(()=>{"use strict";R();C();jo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,l=e;a&&(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,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},pm=In.object({url:In.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:In.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:In.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as zo}from"zod";async function gm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ml(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 Il(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:fm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Ml(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await gm("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ml(`Hover element ${o}`,"hover",{index:o})}}}})}var Vo,fm,gi=y(()=>{"use strict";G();R();C();Vo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.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},`),"});"]}};fm=zo.object({element_index:zo.number().int().describe("Index of the element to hover over"),timeout_ms:zo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Pn}from"zod";async function wm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Pl(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 Cl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:bm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Pl(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,u=await wm("input_text",c,d,r,{text:a});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Pl(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Xo,bm,fi=y(()=>{"use strict";G();R();C();Xo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=D(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.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(a,{delay:l}):await e.keyboard.type(a)}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(n=>` ${n},`),"});"]}};bm=Pn.object({element_index:Pn.number().int().describe("Index of the input element"),text:Pn.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:Pn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Yo}from"zod";async function ym(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function $l(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 Dl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:xm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:$l(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await ym("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:$l(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Ll,xm,wi=y(()=>{"use strict";G();R();C();Ll=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),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},`),"});"]}};xm=Yo.object({element_index:Yo.number().int().describe("Index of the input element to clear"),timeout_ms:Yo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Jo}from"zod";async function vm(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ol(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 Nl(e,t){e.register({name:"click",description:"Click an interactive element.",schema:_m,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Ol(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await vm("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ol(`Click element ${o}`,"click",{index:o})}}}})}var Cn,_m,bi=y(()=>{"use strict";G();R();C();Cn=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});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=L();return[`await ${t}.click({ timeout: ${i} });`]}};_m=Jo.object({element_index:Jo.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Jo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Rl}from"zod";function Hl(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:km,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}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 Fl,km,yi=y(()=>{"use strict";Fl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}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} } },`,"});"]}},km=Rl.object({index:Rl.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as qo}from"zod";function Ul(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Sm,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{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 Wl,Sm,xi=y(()=>{"use strict";Wl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Sm=qo.object({success:qo.boolean().describe("Whether the task was completed successfully"),summary:qo.string().describe("Summary of what was accomplished or why it failed")})});import{z as Zo}from"zod";async function Em(e,t,i,n,o={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Bl(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 Gl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Tm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await H(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await Em("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Qo,Tm,vi=y(()=>{"use strict";G();R();C();Qo=class{async execute(e,t,i){let n=D(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});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},`),"});"]}};Tm=Zo.object({element_index:Zo.number().int().describe("Index of the element to double-click"),timeout_ms:Zo.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as Am}from"@babel/parser";function Kl(e){if(!e.trim())return!1;try{return Am(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var $n=y(()=>{"use strict"});import{z as jl}from"zod";function zl(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:Mm,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Ln,Mm,_i=y(()=>{"use strict";jt();$n();N();Ln=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(u){let m=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(pt(),mt)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4108
4108
  return (async () => {
4109
4109
  ${t}
4110
4110
  })();
4111
4111
  `)(e,ut.expect,n)}catch(o){throw new Error(`Assertion failed: ${o instanceof Error?o.message:String(o)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",o=n?i?.statement||e.action_description:e.action_description||i?.statement,a=JSON.stringify(t||"");if(n){let r=i.code;if(!Kl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(o){let s=r.split(`
4112
4112
  `),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...s.map(d=>` ${d}`),` 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}, ${a});`,"} }"]}return r.split(`
4113
- `)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},Mm=jl.object({statement:jl.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as ea}from"zod";function Xl(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:Im,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Vl,Im,ki=y(()=>{"use strict";Vl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${o} and save to ${a}`,{executeStep:s}=await Promise.resolve().then(()=>(pt(),mt)),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,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},Im=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 Cm,Pm,Si,Dn=y(()=>{"use strict";Cm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Pm=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Si=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:Cm.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 n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`: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:!Pm.includes(t)}}});var ta,ia,On,na=y(()=>{"use strict";pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();ki();Dn();R();me();ta=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new jo),M.registerAction("go_back",new El),M.registerAction("reload_page",new ul),M.registerAction("close_tab",new Fl),M.registerAction("switch_tab",new el),M.registerAction("click",new Pn),M.registerAction("hover",new Vo),M.registerAction("right_click",new Bo),M.registerAction("double_click",new Qo),M.registerAction("click_by_coordinates",new Is),M.registerAction("right_click_by_coordinates",new Ts),M.registerAction("double_click_by_coordinates",new Cs),M.registerAction("drag_drop",new Ps),M.registerAction("input_text",new Xo),M.registerAction("clear_input",new Ll),M.registerAction("press",new Wo),M.registerAction("send_keys_on_element",new ks),M.registerAction("scroll_on_element",new Gs),M.registerAction("scroll_to_text",new zs),M.registerAction("scroll",new ci),M.registerAction("upload_file",new ol),M.registerAction("wait_for_download_complete",new Fs),M.registerAction("get_dropdown_options",new kl),M.registerAction("select_dropdown_option",new Ys),M.registerAction("set_date_for_native_date_picker",new qs),M.registerAction("verify",new Ln),M.registerAction("ai_action",new Ds),M.registerAction("ai_extract",new Vl),M.registerAction("ai_step",new Ns),M.registerAction("ai_wait_until",new Ws),M.registerAction("generate_2fa_code",new yl),M.registerAction("wait",new sl),M.registerAction("wait_for_page_ready",new _s),M.registerAction("save_variable",new gl),M.registerAction("js_code",new Es),M.registerAction("js_action",new Ms),M.registerAction("function",new As),M.registerAction("done",new Wl),M.registerAction("click_element",new Pn),M.registerAction("click_element_by_index",new Pn),M.registerAction("hover_element_by_index",new Vo),M.registerAction("right_click_on_element",new Bo),M.registerAction("double_click_on_element",new Qo),M.registerAction("scroll_down",new ci),M.registerAction("scroll_up",new ci),M.registerAction("scroll_element",new ci),M.registerAction("send_keys",new Wo),M.registerAction("open_tab",new jo),M.registerAction("fill",new Xo),M.registerAction("ai_assert",new Ln),M.registerAction("assert",new Ln)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(P(),Mo(zi)),a=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(Si.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),u=Si.canSelfHeal(t),m=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${m}, ${u});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:r}=(P(),Mo(zi));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";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}', ${n});`]}};ta.actions=new Map,ta.initialized=!1;ia=ta,On=ia});var ft={};et(ft,{ActionHandler:()=>ia,default:()=>On});var wt=y(()=>{"use strict";na();pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();jt();ki();$n();ii();G();Ge();N();Q();ht();Dn();R();me()});import{z as Ei}from"zod";function Nn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4113
+ `)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},Mm=jl.object({statement:jl.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as ea}from"zod";function Xl(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:Im,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Vl,Im,ki=y(()=>{"use strict";Vl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${o} and save to ${a}`,{executeStep:s}=await Promise.resolve().then(()=>(pt(),mt)),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,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},Im=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 Pm,Cm,Si,Dn=y(()=>{"use strict";Pm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Cm=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Si=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:Pm.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 n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`: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:!Cm.includes(t)}}});var ta,ia,On,na=y(()=>{"use strict";pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();ki();Dn();R();me();ta=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new jo),M.registerAction("go_back",new El),M.registerAction("reload_page",new ul),M.registerAction("close_tab",new Fl),M.registerAction("switch_tab",new el),M.registerAction("click",new Cn),M.registerAction("hover",new Vo),M.registerAction("right_click",new Bo),M.registerAction("double_click",new Qo),M.registerAction("click_by_coordinates",new Is),M.registerAction("right_click_by_coordinates",new Ts),M.registerAction("double_click_by_coordinates",new Ps),M.registerAction("drag_drop",new Cs),M.registerAction("input_text",new Xo),M.registerAction("clear_input",new Ll),M.registerAction("press",new Wo),M.registerAction("send_keys_on_element",new ks),M.registerAction("scroll_on_element",new Gs),M.registerAction("scroll_to_text",new zs),M.registerAction("scroll",new ci),M.registerAction("upload_file",new ol),M.registerAction("wait_for_download_complete",new Fs),M.registerAction("get_dropdown_options",new kl),M.registerAction("select_dropdown_option",new Ys),M.registerAction("set_date_for_native_date_picker",new qs),M.registerAction("verify",new Ln),M.registerAction("ai_action",new Ds),M.registerAction("ai_extract",new Vl),M.registerAction("ai_step",new Ns),M.registerAction("ai_wait_until",new Ws),M.registerAction("generate_2fa_code",new yl),M.registerAction("wait",new sl),M.registerAction("wait_for_page_ready",new _s),M.registerAction("save_variable",new gl),M.registerAction("js_code",new Es),M.registerAction("js_action",new Ms),M.registerAction("function",new As),M.registerAction("done",new Wl),M.registerAction("click_element",new Cn),M.registerAction("click_element_by_index",new Cn),M.registerAction("hover_element_by_index",new Vo),M.registerAction("right_click_on_element",new Bo),M.registerAction("double_click_on_element",new Qo),M.registerAction("scroll_down",new ci),M.registerAction("scroll_up",new ci),M.registerAction("scroll_element",new ci),M.registerAction("send_keys",new Wo),M.registerAction("open_tab",new jo),M.registerAction("fill",new Xo),M.registerAction("ai_assert",new Ln),M.registerAction("assert",new Ln)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(C(),Mo(zi)),a=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(Si.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),u=Si.canSelfHeal(t),m=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${m}, ${u});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:r}=(C(),Mo(zi));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";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}', ${n});`]}};ta.actions=new Map,ta.initialized=!1;ia=ta,On=ia});var ft={};et(ft,{ActionHandler:()=>ia,default:()=>On});var wt=y(()=>{"use strict";na();pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();jt();ki();$n();ii();G();Ge();N();Q();ht();Dn();R();me()});import{z as Ei}from"zod";function Nn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4114
4114
  ${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,u)=>{let m=c.action_description||"Unknown action";d+=`
4115
4115
  \u2192 Action ${u+1}: ${m}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
4116
4116
  \u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
@@ -4354,9 +4354,9 @@ if (!window.isPdfViewer) {
4354
4354
  };
4355
4355
  })();
4356
4356
  }
4357
- `});function Jl(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function ql(e,t){let i=await e.newContext(t);return i.addInitScript(Ne),i}async function Wn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Zl(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function Ql(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function Rm(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=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=u=>{let m=u.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=u=>{let m=u.resourceType(),g=u.url();if(!o.has(m)||s(g))return;let w=u.headers();w.purpose==="prefetch"||["video","audio"].includes(w["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(v=>g.includes(v))){i.delete(m);return}if(![...a].some(v=>g.startsWith(v))){i.delete(m);return}let w=u.headers()["content-length"];if(w)try{if(parseInt(w,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-Nm;for(let u of await e.requests()){let m=u.resourceType(),g=u.url(),w=u.timing();o.has(m)&&!s(g)&&w.responseEnd===-1&&w.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=Om;for(;;){await new Promise(w=>setTimeout(w,100));let g=Date.now();if(i.size===0&&g-n>=m){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ee(e,t=Dm,i=Lm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Rm(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 o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var Un,Lm,Dm,Om,Nm,Te=y(()=>{"use strict";bt();N();Un=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},Lm=.5*1e3,Dm=30*1e3,Om=1*1e3,Nm=3*1e3});import{generateText as Fm}from"ai";function Hm(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 tc(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new ce(t.agentServices.getDomServiceOptions()),l={...t,domService:s};b.init(),b.section("Task Execution Started"),b.log(`Task: ${e}`),b.log(`Max steps: ${o}`),b.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Rn(i.customPrompt),m=new Hn(u);b.log(`System prompt length: ${u.length} chars`);let g=!1,w="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();b.section(`Step ${d.currentStep}/${o}`),b.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{b.log("Waiting for page to stabilize..."),await Ee(l.page),b.log("Page stabilized")}catch{b.log("Page stabilization timed out, continuing anyway")}let p;try{b.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();p=await ec(l.page,l.domService,I,C),b.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){b.log("Page navigating, waiting for load..."),await Ee(l.page);let C=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();p=await ec(l.page,l.domService,C,$)}else throw b.error("Error preparing context",I),I}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await Um(m,r,i,p.screenshotBase64);if(f.tokenUsages&&f.tokenUsages.length>0&&c.push(...f.tokenUsages),!f.stepOutput){if(b.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){w="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=f.stepOutput;jm(d.currentStep,o,S);let _=await Gm(S,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,f.debugInfo);v.push(..._.actionEntities);let k=Km(d.currentStep,S,_,d,x,f.debugInfo,f.tokenUsages),E=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:E}),d.consecutiveFailures>=a){b.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),w=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(_.doneResult){g=_.doneResult.success,w=_.doneResult.summary;break}if(_.completesInstruction){g=!0,w="Instruction completed";break}}return d.currentStep>=o&&!g&&(w="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),b.log(`Build success result: summary=${w}, completed=${g}, actions=${v.length}, tokens=${c.length}`),zm(d,v,g,w,n,c,r)}catch(x){let p=x.message;return b.error(`Task execution failed: ${p}`,x),i.onEvent?.({type:"error",error:p,recoverable:!1}),Vm(d,p,n,c,r)}}async function ec(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function Wm(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function Um(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(m=>m.type==="image").length);let l=we(t,s),d={model:fe(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();b.log(`Calling LLM (${t})...`);let g=await Fm(d),w=Date.now()-m,v=g,x=v.usage;b.llmCall(t,w,x);let p=v.reasoningText;p&&(b.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:Wm(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:n},S=[],_=Hm(x,t);_&&S.push(_);let k=Bm(g.text);if(!k)if(u<c-1){b.log(`Attempt ${u+1}/${c}: 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(E=>setTimeout(E,i.retryDelay||1e3));continue}else return b.error("All parsing attempts failed"),{stepOutput:null,debugInfo:f,tokenUsages:S};return{stepOutput:k,debugInfo:f,tokenUsages:S}}catch(m){if(u<c-1){b.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw b.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function Bm(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 b.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return b.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return b.error("Action missing required field: action_name"),null;if(!n.description)return b.error("Action missing required field: description"),null}return i}catch(i){return b.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),b.error(`Parse error: ${i.message}`),null}}async function Gm(e,t,i,n,o,a,r){let s=[],l=!0,d=null;b.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},m=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let w={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let p=i.selectorMap.get(v);p&&(w=await O(t.page,p))}let x={...w,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await F.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(x=p.actionEntity);let f=await u.agentServices.getCurrentPage();if(f&&(u.page=f,t.page=u.page),p?.success===!1){l=!1,b.log("Action failed, stopping execution of remaining actions in this step"),d=p.error||"Action execution failed";break}s.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:r})}catch(p){l=!1,d=p.message,b.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Km(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function jm(e,t,i){if(b.log(`Step ${e}/${t}`),i.thinking&&b.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&b.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&b.log(`Memory: ${i.memory}`),b.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];b.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else b.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{b.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function zm(e,t,i,n,o,a,r){let s=a.reduce((c,u)=>c+u.prompt_tokens,0),l=a.reduce((c,u)=>c+u.completion_tokens,0),d=a.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function Vm(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.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:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var ic=y(()=>{"use strict";oa();Fn();Se();Ke();ee();Te();ke();G()});var nc={};et(nc,{TaskMessageManager:()=>Hn,formatFinalStepWarning:()=>Yl,formatTaskContext:()=>Nn,getBrowserTaskJSONPrompt:()=>Rn,runTaskLoop:()=>tc});var oc=y(()=>{"use strict";ic();oa();Fn();Se();kn();Ke();Ht();Ut();dt();Bt();Gt();ee();Te();bt();ke();Dt();ot();Ot();De();G();Ge();N();Q();ht();R();me()});async function zt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(F.has(i)){let o=await F.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await Xm()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Xm(){if(Bn)return Bn;let e=await Promise.resolve().then(()=>(wt(),ft));return Bn=new e.default,Bn}async function gt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Do(r,a,n);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 je(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Do(r,a,n);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:d,goalAccomplished:c,debugInfo:u}=s,m=await zt(l,a);return m.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:u}}async function ze(e,t,i,n={}){let o={page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),us(a,o,n)}async function Ve(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(oc(),nc)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.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 Bn,Vt=y(()=>{"use strict";dn();Se();Ke();Bn=null});import{z as ac}from"zod";function rc(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:Ym,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await rt(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await zt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var Ym,aa=y(()=>{"use strict";Vt();st();Ym=ac.object({instruction:ac.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!""')})});import{generateText as Jm}from"ai";import{convert as qm}from"html-to-text";async function Zm(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/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 c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let w=(c.message||{}).headers||{},v=w.subject||"",x=w.from||"",p=w.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:v,from:x,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:w["message-id"]||""});continue}let m=u.split("/"),g=m[m.length-1];if(h.info(`Storage key: ${g}`),g){let w=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let v=await fetch(w,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(v.ok){let x=await v.json(),p=x.Subject||"",f=x.From||"",S=x.To||"",_=x.Date||"",k=x["Message-Id"]||"";h.info(`subject: ${p}`),h.info(`from_addr: ${f}`),h.info(`to_addr: ${S}`),h.info(`date: ${_}`),h.info(`message_id: ${k}`);let E=x["body-html"]||x["body-plain"]||"";if(E&&E.includes("<")&&(E=qm(E)),h.info(`Body: ${E.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!E.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:p,from:f,to:S,date:_,body:E,message_id:k});continue}else h.warn(`Messages API returned ${v.status}`)}catch(v){h.warn(`Failed to parse JSON response: ${v}`)}}try{let w=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!w.ok){h.warn(`Could not fetch stored message: ${w.status}`);continue}let v=await w.text();h.info(`Fallback: Raw email length: ${v.length}`);let x=v.split(`
4357
+ `});function Jl(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function ql(e,t){let i=await e.newContext(t);return i.addInitScript(Ne),i}async function Wn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Zl(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function Ql(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function Rm(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=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=u=>{let m=u.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=u=>{let m=u.resourceType(),g=u.url();if(!o.has(m)||s(g))return;let w=u.headers();w.purpose==="prefetch"||["video","audio"].includes(w["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(v=>g.includes(v))){i.delete(m);return}if(![...a].some(v=>g.startsWith(v))){i.delete(m);return}let w=u.headers()["content-length"];if(w)try{if(parseInt(w,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-Nm;for(let u of await e.requests()){let m=u.resourceType(),g=u.url(),w=u.timing();o.has(m)&&!s(g)&&w.responseEnd===-1&&w.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=Om;for(;;){await new Promise(w=>setTimeout(w,100));let g=Date.now();if(i.size===0&&g-n>=m){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ee(e,t=Dm,i=Lm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Rm(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 o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var Un,Lm,Dm,Om,Nm,Te=y(()=>{"use strict";bt();N();Un=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},Lm=.5*1e3,Dm=30*1e3,Om=1*1e3,Nm=3*1e3});import{generateText as Fm}from"ai";function Hm(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 tc(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new ce(t.agentServices.getDomServiceOptions()),l={...t,domService:s};b.init(),b.section("Task Execution Started"),b.log(`Task: ${e}`),b.log(`Max steps: ${o}`),b.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Rn(i.customPrompt),m=new Hn(u);b.log(`System prompt length: ${u.length} chars`);let g=!1,w="",v=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();b.section(`Step ${d.currentStep}/${o}`),b.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{b.log("Waiting for page to stabilize..."),await Ee(l.page),b.log("Page stabilized")}catch{b.log("Page stabilization timed out, continuing anyway")}let p;try{b.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();p=await ec(l.page,l.domService,I,P),b.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){b.log("Page navigating, waiting for load..."),await Ee(l.page);let P=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();p=await ec(l.page,l.domService,P,$)}else throw b.error("Error preparing context",I),I}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await Um(m,r,i,p.screenshotBase64);if(f.tokenUsages&&f.tokenUsages.length>0&&c.push(...f.tokenUsages),!f.stepOutput){if(b.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){w="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let S=f.stepOutput;jm(d.currentStep,o,S);let _=await Gm(S,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,f.debugInfo);v.push(..._.actionEntities);let k=Km(d.currentStep,S,_,d,x,f.debugInfo,f.tokenUsages),E=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:E}),d.consecutiveFailures>=a){b.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),w=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(_.doneResult){g=_.doneResult.success,w=_.doneResult.summary;break}if(_.completesInstruction){g=!0,w="Instruction completed";break}}return d.currentStep>=o&&!g&&(w="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),b.log(`Build success result: summary=${w}, completed=${g}, actions=${v.length}, tokens=${c.length}`),zm(d,v,g,w,n,c,r)}catch(x){let p=x.message;return b.error(`Task execution failed: ${p}`,x),i.onEvent?.({type:"error",error:p,recoverable:!1}),Vm(d,p,n,c,r)}}async function ec(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function Wm(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function Um(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(m=>m.type==="image").length);let l=we(t,s),d={model:fe(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();b.log(`Calling LLM (${t})...`);let g=await Fm(d),w=Date.now()-m,v=g,x=v.usage;b.llmCall(t,w,x);let p=v.reasoningText;p&&(b.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:Wm(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:n},S=[],_=Hm(x,t);_&&S.push(_);let k=Bm(g.text);if(!k)if(u<c-1){b.log(`Attempt ${u+1}/${c}: 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(E=>setTimeout(E,i.retryDelay||1e3));continue}else return b.error("All parsing attempts failed"),{stepOutput:null,debugInfo:f,tokenUsages:S};return{stepOutput:k,debugInfo:f,tokenUsages:S}}catch(m){if(u<c-1){b.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw b.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function Bm(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 b.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return b.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return b.error("Action missing required field: action_name"),null;if(!n.description)return b.error("Action missing required field: description"),null}return i}catch(i){return b.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),b.error(`Parse error: ${i.message}`),null}}async function Gm(e,t,i,n,o,a,r){let s=[],l=!0,d=null;b.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},m=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let w={},v=g.kwargs?.element_index??g.kwargs?.index;if(typeof v=="number"){let p=i.selectorMap.get(v);p&&(w=await O(t.page,p))}let x={...w,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await F.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(x=p.actionEntity);let f=await u.agentServices.getCurrentPage();if(f&&(u.page=f,t.page=u.page),p?.success===!1){l=!1,b.log("Action failed, stopping execution of remaining actions in this step"),d=p.error||"Action execution failed";break}s.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:r})}catch(p){l=!1,d=p.message,b.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Km(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function jm(e,t,i){if(b.log(`Step ${e}/${t}`),i.thinking&&b.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&b.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&b.log(`Memory: ${i.memory}`),b.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];b.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else b.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{b.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function zm(e,t,i,n,o,a,r){let s=a.reduce((c,u)=>c+u.prompt_tokens,0),l=a.reduce((c,u)=>c+u.completion_tokens,0),d=a.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function Vm(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.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:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var ic=y(()=>{"use strict";oa();Fn();Se();Ke();ee();Te();ke();G()});var nc={};et(nc,{TaskMessageManager:()=>Hn,formatFinalStepWarning:()=>Yl,formatTaskContext:()=>Nn,getBrowserTaskJSONPrompt:()=>Rn,runTaskLoop:()=>tc});var oc=y(()=>{"use strict";ic();oa();Fn();Se();kn();Ke();Ht();Ut();dt();Bt();Gt();ee();Te();bt();ke();Dt();ot();Ot();De();G();Ge();N();Q();ht();R();me()});async function zt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(F.has(i)){let o=await F.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await Xm()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Xm(){if(Bn)return Bn;let e=await Promise.resolve().then(()=>(wt(),ft));return Bn=new e.default,Bn}async function gt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Do(r,a,n);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 je(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Do(r,a,n);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:d,goalAccomplished:c,debugInfo:u}=s,m=await zt(l,a);return m.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:u}}async function ze(e,t,i,n={}){let o={page:t,agentServices:i,domService:new ce(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),us(a,o,n)}async function Ve(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(oc(),nc)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.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 Bn,Vt=y(()=>{"use strict";dn();Se();Ke();Bn=null});import{z as ac}from"zod";function rc(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:Ym,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await rt(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await zt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var Ym,aa=y(()=>{"use strict";Vt();st();Ym=ac.object({instruction:ac.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!""')})});import{generateText as Jm}from"ai";import{convert as qm}from"html-to-text";async function Zm(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/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 c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let w=(c.message||{}).headers||{},v=w.subject||"",x=w.from||"",p=w.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:v,from:x,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:w["message-id"]||""});continue}let m=u.split("/"),g=m[m.length-1];if(h.info(`Storage key: ${g}`),g){let w=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let v=await fetch(w,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(v.ok){let x=await v.json(),p=x.Subject||"",f=x.From||"",S=x.To||"",_=x.Date||"",k=x["Message-Id"]||"";h.info(`subject: ${p}`),h.info(`from_addr: ${f}`),h.info(`to_addr: ${S}`),h.info(`date: ${_}`),h.info(`message_id: ${k}`);let E=x["body-html"]||x["body-plain"]||"";if(E&&E.includes("<")&&(E=qm(E)),h.info(`Body: ${E.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!E.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:p,from:f,to:S,date:_,body:E,message_id:k});continue}else h.warn(`Messages API returned ${v.status}`)}catch(v){h.warn(`Failed to parse JSON response: ${v}`)}}try{let w=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!w.ok){h.warn(`Could not fetch stored message: ${w.status}`);continue}let v=await w.text();h.info(`Fallback: Raw email length: ${v.length}`);let x=v.split(`
4358
4358
  `),p=!0,f={},S="";for(let $=0;$<x.length;$++){let B=x[$];if(B.trim()===""&&p){p=!1;continue}if(p){let z=B.match(/^([^:]+):\s*(.+)$/);z&&(f[z[1].toLowerCase()]=z[2])}else S+=B+`
4359
- `}let _=f.subject||"",k=f.from||"",E=f.to||"",I=f.date||"",C=f["message-id"]||"";if(i.subject&&!_.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:_,from:k,to:E,date:I,body:S.trim(),message_id:C})}catch(w){h.warn(`Error fetching raw message: ${w}`)}}if(a.length>0){try{a.sort((u,m)=>{let g=new Date(u.date).getTime();return new Date(m.date).getTime()-g})}catch{}let c=a[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return a}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Qm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4359
+ `}let _=f.subject||"",k=f.from||"",E=f.to||"",I=f.date||"",P=f["message-id"]||"";if(i.subject&&!_.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!S.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:_,from:k,to:E,date:I,body:S.trim(),message_id:P})}catch(w){h.warn(`Error fetching raw message: ${w}`)}}if(a.length>0){try{a.sort((u,m)=>{let g=new Date(u.date).getTime();return new Date(m.date).getTime()-g})}catch{}let c=a[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return a}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Qm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4360
4360
 
4361
4361
  Please carefully examine the email content and look for:
4362
4362
  1. Numeric codes (usually 4-8 digits)
@@ -4430,13 +4430,13 @@ To: ${m.to}
4430
4430
  Date: ${m.date}
4431
4431
 
4432
4432
  Body:
4433
- ${m.body}`,w=await ep(g,o,t.model);h.info(`Extracted content: ${w}`),w&&w!=="NOT_FOUND"&&u.push({content:w,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[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 w=(new Date().getTime()-a.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${w.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 h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-a.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(o){return h.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var ra=y(()=>{"use strict";ke();N()});import{z as Ae}from"zod";function lc(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"}}function dc(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:tp,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:m,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let w={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(m,w,g);let v=lc(a);return{success:!0,actionEntity:w,message:`Extracted ${a} and saved to $${v}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:w.message}}}}})}var cc,tp,sa=y(()=>{"use strict";ra();N();Q();cc=class{getMailgunConfig(){let e=W().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.getMailgunConfig();if(!o)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let a=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await sc(o,{model:r,forward_email:a.forward_email,extraction_type:a.extraction_type,prompt:a.prompt,filters:{from_email:a.filter_from_email,to_email:a.filter_to_email,subject:a.filter_subject,body_contains:a.filter_body_contains},timeout:a.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||lc(a.extraction_type);i.variableStore.set(l,s.data),h.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)} },`,"});"]}},tp=Ae.object({forward_email:Ae.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ae.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:Ae.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ae.string().optional().describe("Filter emails by sender address"),filter_to_email:Ae.string().optional().describe("Filter emails by recipient address"),filter_subject:Ae.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ae.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ae.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ye(){if(Gn)return Gn;let e=(await Promise.resolve().then(()=>(wt(),ft))).default;return Gn=new e,Gn}async function Kn(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return Nl(e,i),Il(e,n),pl(e,o),Gl(e,a),"Click, hover, double-click, right-click, or drag elements"}async function jn(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return Al(e,i),Tl(e,n),hl(e,o),"Navigate to URLs, go back, or reload the page"}async function zn(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return Dl(e,i),Pl(e,n),dl(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function Vn(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return Ks(e,i),Vs(e,n),wl(e,o),"Scroll the page or scroll to specific text/elements"}async function Xn(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Hl(e,i),tl(e,n),"Switch between browser tabs or close tabs"}async function Yn(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return al(e,i),Hs(e,n),"Upload files or wait for downloads to complete"}async function Jn(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return Sl(e,i),Js(e,n),Zs(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function qn(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return ll(e,i),fl(e,n),Ul(e,o),rc(e),"Wait for conditions, save variables, or complete tasks"}async function Zn(e){let t=(await ye()).getAction("generate_2fa_code");xl(e,t);let i=new cc;return(await Promise.resolve().then(()=>(wt(),ft))).default.registerAction("extract_email_content",i),dc(e,i),"Generate 2FA codes or extract email/activation codes"}async function Qn(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return zl(e,i),Xl(e,n),Us(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function uc(e){let[t,i,n,o,a,r,s,l,d,c]=await Promise.all([Kn(e),jn(e),zn(e),Vn(e),Xn(e),Yn(e),Jn(e),qn(e),Zn(e),Qn(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:r,forms:s,utility:l,auth:d,ai:c}}function hc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
4433
+ ${m.body}`,w=await ep(g,o,t.model);h.info(`Extracted content: ${w}`),w&&w!=="NOT_FOUND"&&u.push({content:w,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[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 w=(new Date().getTime()-a.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${w.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 h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-a.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(o){return h.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var ra=y(()=>{"use strict";ke();N()});import{z as Ae}from"zod";function lc(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"}}function dc(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:tp,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:m,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let w={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(m,w,g);let v=lc(a);return{success:!0,actionEntity:w,message:`Extracted ${a} and saved to $${v}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:w.message}}}}})}var cc,tp,sa=y(()=>{"use strict";ra();N();Q();cc=class{getMailgunConfig(){let e=W().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.getMailgunConfig();if(!o)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let a=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await sc(o,{model:r,forward_email:a.forward_email,extraction_type:a.extraction_type,prompt:a.prompt,filters:{from_email:a.filter_from_email,to_email:a.filter_to_email,subject:a.filter_subject,body_contains:a.filter_body_contains},timeout:a.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||lc(a.extraction_type);i.variableStore.set(l,s.data),h.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)} },`,"});"]}},tp=Ae.object({forward_email:Ae.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ae.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:Ae.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ae.string().optional().describe("Filter emails by sender address"),filter_to_email:Ae.string().optional().describe("Filter emails by recipient address"),filter_subject:Ae.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ae.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ae.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ye(){if(Gn)return Gn;let e=(await Promise.resolve().then(()=>(wt(),ft))).default;return Gn=new e,Gn}async function Kn(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return Nl(e,i),Il(e,n),pl(e,o),Gl(e,a),"Click, hover, double-click, right-click, or drag elements"}async function jn(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return Al(e,i),Tl(e,n),hl(e,o),"Navigate to URLs, go back, or reload the page"}async function zn(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return Dl(e,i),Cl(e,n),dl(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function Vn(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return Ks(e,i),Vs(e,n),wl(e,o),"Scroll the page or scroll to specific text/elements"}async function Xn(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Hl(e,i),tl(e,n),"Switch between browser tabs or close tabs"}async function Yn(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return al(e,i),Hs(e,n),"Upload files or wait for downloads to complete"}async function Jn(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return Sl(e,i),Js(e,n),Zs(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function qn(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return ll(e,i),fl(e,n),Ul(e,o),rc(e),"Wait for conditions, save variables, or complete tasks"}async function Zn(e){let t=(await ye()).getAction("generate_2fa_code");xl(e,t);let i=new cc;return(await Promise.resolve().then(()=>(wt(),ft))).default.registerAction("extract_email_content",i),dc(e,i),"Generate 2FA codes or extract email/activation codes"}async function Qn(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return zl(e,i),Xl(e,n),Us(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function uc(e){let[t,i,n,o,a,r,s,l,d,c]=await Promise.all([Kn(e),jn(e),zn(e),Vn(e),Xn(e),Yn(e),Jn(e),qn(e),Zn(e),Qn(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:r,forms:s,utility:l,auth:d,ai:c}}function hc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
4434
4434
  `)}var Gn,la=y(()=>{"use strict";aa();sa();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();ki();Gn=null});async function mc(){await np}function pc(){return F}function gc(e=!0){let t=new lt;return e&&(Kn(t),jn(t),zn(t),Vn(t),Xn(t),Yn(t),Jn(t),Zn(t),qn(t),Qn(t)),t}async function fc(){let e=new lt,t=await uc(e),i=hc(t);return{registry:e,capabilities:t,summary:i}}function wc(){return["- Mouse: Click, hover, double-click, right-click or drag on elements","- Navigation: Navigate to URLs, go back, or reload the page","- Input: Type text into inputs, clear input fields, or press keyboard keys","- Scroll: Scroll the page or scroll to specific text/elements","- Tabs: Switch between browser tabs or close tabs","- Files: Upload files or wait for downloads to complete","- Forms: Get dropdown options or select dropdown values","- Utility: Wait for conditions, save variables, or complete tasks","- Auth: Generate 2FA codes or extract email/activation codes","- AI: Perform AI-powered verifications, extractions, or wait conditions"].join(`
4435
- `)}var ip,np,bc=y(()=>{"use strict";la();Se();ip=[Kn(F),jn(F),zn(F),Vn(F),Xn(F),Yn(F),Jn(F),qn(F),Qn(F),Zn(F)],np=Promise.all(ip)});function xc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Ui(t.schema)}))}var yc,vc=y(()=>{"use strict";Ct();yc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Ui(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Ui(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var _c=y(()=>{"use strict"});function kc(){let e=process.env.SHIPLIGHT_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function yt(e){let t=kc();if(!t)return null;try{let i=await fetch(`${t}/browsers`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(e)});return i.ok?(await i.json()).id??null:null}catch{return null}}async function xt(e){if(!e)return;let t=kc();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var ca=y(()=>{"use strict"});import"uuid";import{z as T}from"zod";import"yaml";import"uuid";import"yaml";function to(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var op,io,ap,rp,sp,lp,cp,dp,up,hp,Xe,vt,Ec,mp,eo,Ai,eS,tS,no,Tc,Ac,Mc,Ic,Mi,da,ua,pp,Sc,gp,Ti,fp,wp,bp,oe,yp,xp,aS,fS,_t=y(()=>{"use strict";me();op="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",io=112,ap=1920,rp=1080,sp=1920,lp=1080-io,cp=1280,dp=720,up=500,hp=500,Xe="Desktop Chrome",vt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(vt||{}),Ec={"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"}},mp={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"]},eo=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),mp[e].map(n=>Ec[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ai=e=>Ec[e],eS={desktop:{label:"Desktop",type:"desktop",devices:eo("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:eo("mobile")}},tS={desktop:{label:"Desktop",type:"desktop",devices:eo("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:eo("mobile",!0)}},no=(e,t=!1)=>{let i={userAgent:op,viewport:{width:sp,height:lp},isMobile:!1,hasTouch:!1};if(!e||e===Xe)return i;let n=Ai(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(up/o,1),s=Math.max(hp/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Tc=e=>{let t={width:ap,height:rp};if(!e||e===Xe)return t;let i=no(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+io}:t},Ac=e=>{let t={width:cp,height:dp};if(!e||e===Xe)return t;let i=no(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Mc=e=>!e||e===Xe?void 0:Ai(e)?.channel,Ic=e=>!e||e===Xe?"chromium":Ai(e)?.defaultBrowserType??"chromium",Mi=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Mi||{}),da=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(da||{}),ua=class Cc{constructor(){Io(this,"data",{}),Io(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?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,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Cc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},pp=T.enum(["JS_CODE","AI_MODE"]),Sc=T.object({type:pp,expression:T.string()}),gp=T.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ti=T.object({uid:T.string(),type:gp,comment:T.string().optional()}),fp=T.object({action_data:T.object({action_name:T.string(),kwargs:T.record(T.any()).optional(),args:T.array(T.any()).optional()}),action_description:T.string().optional(),url:T.string().optional(),xpath:T.string().nullable().optional(),locator:T.string().nullable().optional(),css_selector:T.string().nullable().optional(),unique_selector:T.string().nullable().optional(),element_index:T.number().nullable().optional(),frame_path:T.array(T.any()).optional(),artifacts:T.record(T.any()).optional(),feedback:T.string().optional(),original_browser_use_action:T.any().optional()}).passthrough(),wp=Ti.extend({type:T.literal("DRAFT"),description:T.string()}),bp=Ti.extend({type:T.literal("ACTION"),description:T.string(),action_entity:fp.optional(),locator:T.string().optional(),use_pure_vision:T.boolean().optional()}),oe=T.lazy(()=>T.union([wp,bp,Ti.extend({type:T.literal("STEP"),description:T.string().optional().default(""),statements:T.array(oe),reference_id:T.number().optional(),template_path:T.string().optional(),template_params:T.record(T.string()).optional()}),Ti.extend({type:T.literal("IF_ELSE"),description:T.string().optional(),condition:Sc,then:T.array(oe),else:T.array(oe).optional()}),Ti.extend({type:T.literal("WHILE_LOOP"),description:T.string().optional(),condition:Sc,body:T.array(oe),timeout_ms:T.number().optional()})])),yp=T.object({name:T.string(),statements:T.array(oe),teardown:T.array(oe).optional(),skip:T.union([T.boolean(),T.string()]).optional(),timeout:T.number().optional(),fail:T.union([T.boolean(),T.string()]).optional(),only:T.boolean().optional(),slow:T.boolean().optional()}),xp=T.object({tests:T.array(yp).min(1),beforeAll:T.array(oe).optional(),afterAll:T.array(oe).optional(),beforeEach:T.array(oe).optional(),afterEach:T.array(oe).optional()}),aS=T.object({comment:T.string().optional(),version:T.string().optional(),goal:T.string().optional(),url:T.string().optional(),baseURL:T.string().optional(),final_feedback:T.string().optional(),completed:T.boolean().optional(),success:T.boolean().optional(),statements:T.array(oe).optional(),teardown:T.array(oe).optional(),last_modified_at:T.string().optional(),testGroup:xp.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"}),fS=1024*1024});import Ye from"fs";import vp from"os";import Ii from"path";import{chromium as Pc,firefox as _p,webkit as kp}from"playwright";async function Sp(e,t){let i=JSON.parse(Ye.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var $c,Lc=y(()=>{"use strict";ca();_t();Te();bt();N();$c=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=Ii.join(e.testDir,"videos"),this.statesBasePath=Ii.join(e.testDir,"states"),this.downloadsBasePath=Ii.join(e.testDir,"downloads"),Ye.mkdirSync(this.videoBasePath,{recursive:!0}),Ye.mkdirSync(this.statesBasePath,{recursive:!0}),Ye.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Ic(e.deviceName),o=Mc(e.deviceName),a=n===vt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let k=[];(e.enableCamera||e.enableMicrophone)&&(k.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(k.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Jl(t,e.disableSecurity??!0,i),...k,...E,...this.additionalArgs],o&&(s.channel=o,h.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=no(e.deviceName),d=Ac(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let m,g,w,v=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)w=e.userDataDir;else{let E=this.testDir||Ye.mkdtempSync(Ii.join(vp.tmpdir(),"shiplight-"));w=Ii.join(E,`ext-profile-${Date.now()}`),Ye.mkdirSync(w,{recursive:!0}),v=!0}let k={...s,...c};g=await Pc.launchPersistentContext(w,k),u&&(await Sp(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),m=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${w}`}`)}else{switch(n){case vt.Firefox:m=await _p.launch(s);break;case vt.Webkit:m=await kp.launch(s);break;case vt.Chromium:default:m=await Pc.launch(s);break}g=await m.newContext(c)}if(g.addInitScript(Ne),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),h.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(E){h.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,E=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(E),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,p=x?{width:x.width,height:x.height+io}:Tc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(p)}`),a){let k=async E=>{try{await Un(E,p.width,p.height),x&&await E.setViewportSize(x)}catch(I){h.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let E of g.pages())await k(E);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await Wn(t)}catch(k){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await yt({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&h.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let _={debugPort:t,browser:m,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:w,isTempUserDataDir:v,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(E=>h.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);_.timeout=k}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await xt(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ye.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});import{execFileSync as Ep}from"child_process";import*as Dc from"fs";import*as Oc from"path";function Tp(e){let t=Ep("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),i=[];for(let a of t.split(`
4435
+ `)}var ip,np,bc=y(()=>{"use strict";la();Se();ip=[Kn(F),jn(F),zn(F),Vn(F),Xn(F),Yn(F),Jn(F),qn(F),Qn(F),Zn(F)],np=Promise.all(ip)});function xc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Ui(t.schema)}))}var yc,vc=y(()=>{"use strict";Pt();yc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Ui(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Ui(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var _c=y(()=>{"use strict"});function kc(){let e=process.env.SHIPLIGHT_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function yt(e){let t=kc();if(!t)return null;try{let i=await fetch(`${t}/browsers`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(e)});return i.ok?(await i.json()).id??null:null}catch{return null}}async function xt(e){if(!e)return;let t=kc();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var ca=y(()=>{"use strict"});import"uuid";import{z as T}from"zod";import"yaml";import"uuid";import"yaml";function to(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var op,io,ap,rp,sp,lp,cp,dp,up,hp,Xe,vt,Ec,mp,eo,Ai,nS,oS,no,Tc,Ac,Mc,Ic,Mi,da,ua,pp,Sc,gp,Ti,fp,wp,bp,oe,yp,xp,lS,yS,_t=y(()=>{"use strict";me();op="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",io=112,ap=1920,rp=1080,sp=1920,lp=1080-io,cp=1280,dp=720,up=500,hp=500,Xe="Desktop Chrome",vt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(vt||{}),Ec={"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"}},mp={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"]},eo=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),mp[e].map(n=>Ec[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ai=e=>Ec[e],nS={desktop:{label:"Desktop",type:"desktop",devices:eo("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:eo("mobile")}},oS={desktop:{label:"Desktop",type:"desktop",devices:eo("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:eo("mobile",!0)}},no=(e,t=!1)=>{let i={userAgent:op,viewport:{width:sp,height:lp},isMobile:!1,hasTouch:!1};if(!e||e===Xe)return i;let n=Ai(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(up/o,1),s=Math.max(hp/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Tc=e=>{let t={width:ap,height:rp};if(!e||e===Xe)return t;let i=no(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+io}:t},Ac=e=>{let t={width:cp,height:dp};if(!e||e===Xe)return t;let i=no(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Mc=e=>!e||e===Xe?void 0:Ai(e)?.channel,Ic=e=>!e||e===Xe?"chromium":Ai(e)?.defaultBrowserType??"chromium",Mi=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Mi||{}),da=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(da||{}),ua=class Pc{constructor(){Io(this,"data",{}),Io(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?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,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Pc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},pp=T.enum(["JS_CODE","AI_MODE"]),Sc=T.object({type:pp,expression:T.string()}),gp=T.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ti=T.object({uid:T.string(),type:gp,comment:T.string().optional()}),fp=T.object({action_data:T.object({action_name:T.string(),kwargs:T.record(T.any()).optional(),args:T.array(T.any()).optional()}),action_description:T.string().optional(),url:T.string().optional(),xpath:T.string().nullable().optional(),locator:T.string().nullable().optional(),css_selector:T.string().nullable().optional(),unique_selector:T.string().nullable().optional(),element_index:T.number().nullable().optional(),frame_path:T.array(T.any()).optional(),artifacts:T.record(T.any()).optional(),feedback:T.string().optional(),original_browser_use_action:T.any().optional()}).passthrough(),wp=Ti.extend({type:T.literal("DRAFT"),description:T.string()}),bp=Ti.extend({type:T.literal("ACTION"),description:T.string(),action_entity:fp.optional(),locator:T.string().optional(),use_pure_vision:T.boolean().optional()}),oe=T.lazy(()=>T.union([wp,bp,Ti.extend({type:T.literal("STEP"),description:T.string().optional().default(""),statements:T.array(oe),reference_id:T.number().optional(),template_path:T.string().optional(),template_params:T.record(T.string()).optional()}),Ti.extend({type:T.literal("IF_ELSE"),description:T.string().optional(),condition:Sc,then:T.array(oe),else:T.array(oe).optional()}),Ti.extend({type:T.literal("WHILE_LOOP"),description:T.string().optional(),condition:Sc,body:T.array(oe),timeout_ms:T.number().optional()})])),yp=T.object({name:T.string(),statements:T.array(oe),teardown:T.array(oe).optional(),skip:T.union([T.boolean(),T.string()]).optional(),timeout:T.number().optional(),fail:T.union([T.boolean(),T.string()]).optional(),only:T.boolean().optional(),slow:T.boolean().optional()}),xp=T.object({tests:T.array(yp).min(1),beforeAll:T.array(oe).optional(),afterAll:T.array(oe).optional(),beforeEach:T.array(oe).optional(),afterEach:T.array(oe).optional()}),lS=T.object({comment:T.string().optional(),version:T.string().optional(),goal:T.string().optional(),url:T.string().optional(),baseURL:T.string().optional(),final_feedback:T.string().optional(),completed:T.boolean().optional(),success:T.boolean().optional(),statements:T.array(oe).optional(),teardown:T.array(oe).optional(),last_modified_at:T.string().optional(),testGroup:xp.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"}),yS=1024*1024});import Ye from"fs";import vp from"os";import Ii from"path";import{chromium as Cc,firefox as _p,webkit as kp}from"playwright";async function Sp(e,t){let i=JSON.parse(Ye.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var $c,Lc=y(()=>{"use strict";ca();_t();Te();bt();N();$c=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=Ii.join(e.testDir,"videos"),this.statesBasePath=Ii.join(e.testDir,"states"),this.downloadsBasePath=Ii.join(e.testDir,"downloads"),Ye.mkdirSync(this.videoBasePath,{recursive:!0}),Ye.mkdirSync(this.statesBasePath,{recursive:!0}),Ye.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Ic(e.deviceName),o=Mc(e.deviceName),a=n===vt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let k=[];(e.enableCamera||e.enableMicrophone)&&(k.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(k.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Jl(t,e.disableSecurity??!0,i),...k,...E,...this.additionalArgs],o&&(s.channel=o,h.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=no(e.deviceName),d=Ac(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let m,g,w,v=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)w=e.userDataDir;else{let E=this.testDir||Ye.mkdtempSync(Ii.join(vp.tmpdir(),"shiplight-"));w=Ii.join(E,`ext-profile-${Date.now()}`),Ye.mkdirSync(w,{recursive:!0}),v=!0}let k={...s,...c};g=await Cc.launchPersistentContext(w,k),u&&(await Sp(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),m=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${w}`}`)}else{switch(n){case vt.Firefox:m=await _p.launch(s);break;case vt.Webkit:m=await kp.launch(s);break;case vt.Chromium:default:m=await Cc.launch(s);break}g=await m.newContext(c)}if(g.addInitScript(Ne),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),h.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(E){h.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,E=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(E),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,p=x?{width:x.width,height:x.height+io}:Tc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(p)}`),a){let k=async E=>{try{await Un(E,p.width,p.height),x&&await E.setViewportSize(x)}catch(I){h.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let E of g.pages())await k(E);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await Wn(t)}catch(k){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await yt({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&h.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let _={debugPort:t,browser:m,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:w,isTempUserDataDir:v,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(E=>h.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);_.timeout=k}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await xt(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ye.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});import{execFileSync as Ep}from"child_process";import*as Dc from"fs";import*as Oc from"path";function Tp(e){let t=Ep("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),i=[];for(let a of t.split(`
4436
4436
  `)){let r=a.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);r&&i.push({pid:parseInt(r[1],10),ppid:parseInt(r[2],10),args:r[3]})}let n=new Set([e]),o=!0;for(;o;){o=!1;for(let a of i)!n.has(a.pid)&&n.has(a.ppid)&&(n.add(a.pid),o=!0)}for(let a of i){if(a.pid===e||!n.has(a.pid)||!/chrome|chromium/i.test(a.args))continue;let r=a.args.match(/--user-data-dir=([^\s]+)/);if(r)return r[1]}return null}async function Ap(e,t){let i=Oc.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let o=Dc.readFileSync(i,"utf-8").trim(),[a,r]=o.split(`
4437
4437
  `),s=parseInt(a,10);if(Number.isFinite(s)&&s>0&&typeof r=="string"&&r.startsWith("/"))return{port:s,wsPath:r}}catch{}await new Promise(o=>setTimeout(o,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function oo(e,t=3e4){let i=Tp(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:o}=await Ap(i,t);return`ws://127.0.0.1:${n}${o}`}var Nc=y(()=>{"use strict"});var Rc,Fc=y(()=>{"use strict";_t();Rc=e=>{if(!e||e===Xe)return"desktop";let t=Ai(e);return t&&t.isMobile?"mobile":"desktop"}});var Mp,Hc=y(()=>{"use strict";Mp=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Mp||{})});async function Wc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4438
4438
  return await (${t});
4439
- `;return await new i("page",n)(e)}async function Ci(e,t,i){let n=[],o=[];for(let a of t){let r=!1;try{let s=`page.${a}`;b.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await Wc(e,`${s}.waitFor({ state: 'attached', timeout: ${Ip} })`),b.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await Wc(e,`${s}.count()`)>0?(b.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(b.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){b.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(o.push(r),!r&&i)break}return{successResults:o,logs:n}}async function ha(e,t,i=!0){let{successResults:n,logs:o}=await Ci(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Pi(e,t){if(!t||t.length===0)return b.log("No validation expressions provided, cannot validate login"),!1;b.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await ha(e,t,!0);return i?b.log("All validation expressions passed"):b.log(`Validation failed: ${n.join(", ")}`),i}async function ma(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),o=await n.newPage();return await o.goto(t),await Ee(o,Cp),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function pa(e,t,i,n,o,a){let r=`
4439
+ `;return await new i("page",n)(e)}async function Pi(e,t,i){let n=[],o=[];for(let a of t){let r=!1;try{let s=`page.${a}`;b.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await Wc(e,`${s}.waitFor({ state: 'attached', timeout: ${Ip} })`),b.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await Wc(e,`${s}.count()`)>0?(b.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(b.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){b.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(o.push(r),!r&&i)break}return{successResults:o,logs:n}}async function ha(e,t,i=!0){let{successResults:n,logs:o}=await Pi(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Ci(e,t){if(!t||t.length===0)return b.log("No validation expressions provided, cannot validate login"),!1;b.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await ha(e,t,!0);return i?b.log("All validation expressions passed"):b.log(`Validation failed: ${n.join(", ")}`),i}async function ma(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),o=await n.newPage();return await o.goto(t),await Ee(o,Pp),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function pa(e,t,i,n,o,a){let r=`
4440
4440
  Based on the current page status, generate ${o} Playwright locators in JavaScript code that can
4441
4441
  be used by a program to verify the page is signed in.
4442
4442
  Each expression should yield a locator object that can be used for waiting and checking visibility.
@@ -4480,20 +4480,20 @@ ${n}
4480
4480
  Remember, you must have the javascript code block in your final response.
4481
4481
  `,b.log("Agent generating validation locators"),b.log(`Prompt:
4482
4482
  ${r}`);let s=await a(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(`
4483
- `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function ao(e,t,i,n,o){let a=null;try{a=await ma(e,t);let r=await o(a.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await pa(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);b.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:m}=await Ci(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4483
+ `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function ao(e,t,i,n,o){let a=null;try{a=await ma(e,t);let r=await o(a.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await pa(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);b.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:m}=await Pi(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4484
4484
  ${m.join(`
4485
4485
  `)}
4486
4486
 
4487
4487
  `,!u.every(g=>g)){b.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(u)}`),b.log(`Validation logs:
4488
4488
  ${m.join(`
4489
- `)}`);continue}}{b.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:m}=await Ci(a.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4489
+ `)}`);continue}}{b.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:m}=await Pi(a.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4490
4490
  ${m.join(`
4491
4491
  `)}
4492
4492
 
4493
4493
  `,u.some(g=>g)){b.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(u)}`),b.log(`Validation logs:
4494
4494
  ${m.join(`
4495
- `)}`);continue}}return b.log("Generated validation locators passed dual validation"),c}catch(c){b.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return b.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var Ip,Cp,ro=y(()=>{"use strict";ee();Te();Ip=5e3,Cp=1e4});var Uc,ga=y(()=>{"use strict";Uc=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(n=>!n.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}}});async function Bc(e,t=3e3,i=1e3){try{await Ee(e,t,i)}catch{}}async function Gc(e,t,i){let n=i*1e3,o=100,a=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-a>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Kc(e,t,i,n=60,o){let a=Math.min(n,300),r=Math.max(10,a/10)*1e3,s=Date.now()+a*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var so=y(()=>{"use strict";Te();N()});import*as jc from"fs";import*as $i from"path";import{generateSync as Pp,createGuardrails as $p}from"otplib";function zc(e){return e.url()===":"}var Lp,lo,fa=y(()=>{"use strict";ga();_t();so();Te();N();Lp=$p({MIN_SECRET_BYTES:1});lo=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 Uc(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 h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return to(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return $i.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=$i.basename(n),a=$i.join(t,o),r=jc.existsSync(a);return r&&h.debug(`[AgentServices] File already exists locally: ${o}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Gc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.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),h.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+=`
4496
- ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=Pp({secret:e,guardrails:Lp});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.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 Ee(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.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,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var wa,co,ba=y(()=>{"use strict";wa=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(wa||{}),co=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Vc={};et(Vc,{LoginType:()=>Mi,checkLocators:()=>Ci,createUnsignedInContext:()=>ma,generateAndValidateLoginLocators:()=>ao,generateValidationLocators:()=>pa,validateLogin:()=>Pi,validateLoginLocators:()=>ha});var Xc=y(()=>{"use strict";ro();ee();_t();Te();bt();N();Q();ht();me()});import*as K from"fs";import*as q from"path";function Op(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let s=t.slice(n+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 o=i.split(`
4495
+ `)}`);continue}}return b.log("Generated validation locators passed dual validation"),c}catch(c){b.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return b.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var Ip,Pp,ro=y(()=>{"use strict";ee();Te();Ip=5e3,Pp=1e4});var Uc,ga=y(()=>{"use strict";Uc=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(n=>!n.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}}});async function Bc(e,t=3e3,i=1e3){try{await Ee(e,t,i)}catch{}}async function Gc(e,t,i){let n=i*1e3,o=100,a=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-a>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Kc(e,t,i,n=60,o){let a=Math.min(n,300),r=Math.max(10,a/10)*1e3,s=Date.now()+a*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var so=y(()=>{"use strict";Te();N()});import*as jc from"fs";import*as $i from"path";import{generateSync as Cp,createGuardrails as $p}from"otplib";function zc(e){return e.url()===":"}var Lp,lo,fa=y(()=>{"use strict";ga();_t();so();Te();N();Lp=$p({MIN_SECRET_BYTES:1});lo=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 Uc(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 h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return to(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return $i.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=$i.basename(n),a=$i.join(t,o),r=jc.existsSync(a);return r&&h.debug(`[AgentServices] File already exists locally: ${o}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Gc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.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),h.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+=`
4496
+ ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=Cp({secret:e,guardrails:Lp});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.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 Ee(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.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,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var wa,co,ba=y(()=>{"use strict";wa=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(wa||{}),co=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Vc={};et(Vc,{LoginType:()=>Mi,checkLocators:()=>Pi,createUnsignedInContext:()=>ma,generateAndValidateLoginLocators:()=>ao,generateValidationLocators:()=>pa,validateLogin:()=>Ci,validateLoginLocators:()=>ha});var Xc=y(()=>{"use strict";ro();ee();_t();Te();bt();N();Q();ht();me()});import*as K from"fs";import*as q from"path";function Op(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let s=t.slice(n+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 o=i.split(`
4497
4497
  `),a=o.filter(s=>s.trim().length>0);if(a.length===0)return;let r=Math.min(...a.map(s=>s.match(/^(\s*)/)?.[1].length??0));return o.map(s=>s.slice(r)).join(`
4498
4498
  `).trim()}catch{return}}function kt(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var Dp,Np,Rp,ya,Yc=y(()=>{"use strict";Vt();Ke();ro();ee();fa();so();ba();ii();N();Dp=1;Np=3,Rp=40;ya=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new lo(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(()=>(wt(),ft));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let n=(await this.getActionHandler()).getAction(e);if(!n)throw new Error(`Unknown action: ${e}`);await n.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.
4499
4499
 
@@ -4517,7 +4517,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
4517
4517
  IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
4518
4518
  It's better to miss a popup than to accidentally interact with normal page elements.
4519
4519
 
4520
- If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Np),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"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(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),zc(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||q.join(process.cwd(),"downloads");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let o=q.join(n,i);h.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${o}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}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),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){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+=n,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),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await ze(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await ze(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(h.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await je(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;h.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"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(a){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let m=`${i}-step${u.step}`;this.saveDebugInfoToFiles(m,u.debugInfo,this.context.model)}}:void 0;if(s=await Ve(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??Rp}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await je(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,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,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await gt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await Ve(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});b.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,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new co(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),b.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),b.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let m=Op(t);m&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${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(),w=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=Date.now()-s,f=this.context.stepTracking.results[n]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:w||void 0,variables:v,screenshotPath:f,timestamp:S})}let x=this.context.agentNote;return(!x||x.trim()==="")&&(x="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"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 h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},_=Date.now()-s,k=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:_,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:f||void 0,variables:S,timestamp:k})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${m.message}`);let w,v;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){w=`[Auto-dismissed modal: ${p.details}]`,v=p.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let f=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=w+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",w),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=w,f}catch(f){h.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=r??Dp;h.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let p=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let f=p.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),h.info(`Stored new action entity for stmtUid: ${o} (last of ${p.actions?.length} actions)`));let S=e.url(),_=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=f,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let E=w||"";await this.updateStepResult(n,"success",E)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let E=Date.now()-s,I=this.context.stepTracking.results[n]?.screenshot,C=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:p.actions?.map($=>$.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:_||void 0,variables:k,screenshotPath:I,timestamp:C})}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 f=e.url(),S=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:_,timestamp:E})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`,"extract");try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new ce(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new ce(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return h.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 Bc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Kc(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return il(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Xc(),Vc));if(h.info("Start login"),b.section("Login Flow"),b.log(`Site URL: ${t.site_url}`),b.log(`Account type: ${t.account.type}`),b.log(`Has cached actions: ${!!i?.cached_actions?.length}`),b.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.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),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`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(o){b.log("Level 1: Checking if already logged in via AI verification hint..."),b.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return b.log("Level 1 SUCCESS: Already logged in via AI verification"),h.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};b.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){b.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&b.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(b.log("Level 1: Checking if already logged in via storage state..."),b.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Pi(e,i.validation_exprs))return b.log("Level 1 SUCCESS: Already logged in via storage state"),h.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};b.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&&(o||r)){b.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:a})).success){b.log("Level 2 SUCCESS: Cached login succeeded"),h.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}}b.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){b.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&b.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.
4520
+ If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,Np),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"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(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),zc(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||q.join(process.cwd(),"downloads");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let o=q.join(n,i);h.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${o}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}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),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){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+=n,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),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await ze(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await ze(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(h.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await je(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;h.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"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(a){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let m=`${i}-step${u.step}`;this.saveDebugInfoToFiles(m,u.debugInfo,this.context.model)}}:void 0;if(s=await Ve(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??Rp}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await je(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,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,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await gt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await Ve(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});b.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,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new co(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),b.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),b.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let m=Op(t);m&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${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(),w=await this.captureDOMSnapshot(e),v=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=Date.now()-s,f=this.context.stepTracking.results[n]?.screenshot,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:w||void 0,variables:v,screenshotPath:f,timestamp:S})}let x=this.context.agentNote;return(!x||x.trim()==="")&&(x="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"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 h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},_=Date.now()-s,k=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:_,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:f||void 0,variables:S,timestamp:k})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${m.message}`);let w,v;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){w=`[Auto-dismissed modal: ${p.details}]`,v=p.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let f=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=w+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",w),this.context.stepTracking.results[n].dismissedModalActions=v,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=w,f}catch(f){h.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=r??Dp;h.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let p=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let f=p.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),h.info(`Stored new action entity for stmtUid: ${o} (last of ${p.actions?.length} actions)`));let S=e.url(),_=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=f,v&&(this.context.stepTracking.results[n].dismissedModalActions=v);let E=w||"";await this.updateStepResult(n,"success",E)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let E=Date.now()-s,I=this.context.stepTracking.results[n]?.screenshot,P=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:p.actions?.map($=>$.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:_||void 0,variables:k,screenshotPath:I,timestamp:P})}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 f=e.url(),S=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:_,timestamp:E})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`,"extract");try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new ce(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new ce(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return h.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 Bc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Kc(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return il(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Xc(),Vc));if(h.info("Start login"),b.section("Login Flow"),b.log(`Site URL: ${t.site_url}`),b.log(`Account type: ${t.account.type}`),b.log(`Has cached actions: ${!!i?.cached_actions?.length}`),b.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.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),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`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(o){b.log("Level 1: Checking if already logged in via AI verification hint..."),b.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return b.log("Level 1 SUCCESS: Already logged in via AI verification"),h.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};b.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){b.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&b.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(b.log("Level 1: Checking if already logged in via storage state..."),b.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Ci(e,i.validation_exprs))return b.log("Level 1 SUCCESS: Already logged in via storage state"),h.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};b.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&&(o||r)){b.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:a})).success){b.log("Level 2 SUCCESS: Cached login succeeded"),h.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}}b.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){b.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&b.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.
4521
4521
  Use your best judgement to determine if the page is signed in.
4522
4522
  `;if(t.verification_hint&&(s+=`
4523
4523
  Signed in verification hint: ${t.verification_hint}
@@ -4529,7 +4529,7 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
4529
4529
  `}t.additional_prompt&&(s+=`
4530
4530
  Additional instructions: ${t.additional_prompt}
4531
4531
  `);try{b.log("Level 3: Attempting agent-based login"),b.log(`Login prompt:
4532
- ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(b.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,x,p,f)=>await l(v,x,p,"login")),d=!0,b.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return b.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),b.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),m;if(o)b.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{b.log("Generating validation locators for future login verification...");let v=await ao(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,p)=>this.run(x,p),async x=>this.getDOMText(x));v?(m=v,b.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):b.log("Failed to generate validation locators, login will still succeed")}catch(v){b.log(`Error generating validation locators: ${v.message}`)}else b.log("Skipping validation locator generation (num_verification_exprs=0)");b.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:w,validation_exprs:m}}catch(l){return b.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(wt(),ft))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];b.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){b.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return b.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(b.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 Pi(e,i.validationExprs)?{success:!0}:{success:!1}:(b.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,n){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 o={description:i,startTime:Date.now(),artifacts:[],type:n,code:i};if(this.context.stepTracking.artifactsDir){let a=q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(a,{recursive:!0});let r=q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),o.screenshot=r}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){h.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=q.join(a,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=q.join(a,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=q.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=q.join(a,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),o.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=q.join(a,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=q.join(a,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,a.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}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)),h.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)),h.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)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function Fp(){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,n=t.find(p=>p.type==="month").value,o=t.find(p=>p.type==="day").value,a=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"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),m=Date.parse(c+"Z"),g=Math.round((m-u)/(1e3*60)),w=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),v=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${x}${w}:${v}`}function xa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Fp()),{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:[]}}var Jc=y(()=>{"use strict"});var qc={};et(qc,{ActionHandler:()=>On,ActionHelper:()=>Si,Agent:()=>ya,AgentServices:()=>lo,AgentStepEventTypes:()=>wa,AgentTaskFailedError:()=>co,BrowserManager:()=>$c,DEFAULT_EVENT_LISTENER_LIMIT:()=>hn,DomService:()=>ce,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>un,HistoryTreeProcessor:()=>$s,INIT_SCRIPT:()=>Ne,INTERACTION_EVENT_TYPES:()=>ct,INTERACTIVE_ROLES:()=>Wt,LogLevel:()=>Ro,LoginType:()=>Mi,MCPToolProvider:()=>yc,OpenAIToolProvider:()=>Bi,SDK_VERSION:()=>Wp,ToolRegistry:()=>lt,TwoFactorAuthType:()=>da,VariableStore:()=>ua,WebAgent:()=>ya,configureSdk:()=>Sr,createAgent:()=>Hp,createAgentContext:()=>xa,createToolRegistry:()=>gc,createToolRegistryWithCapabilities:()=>fc,discoverChromiumCdpUrl:()=>oo,ensureToolsRegistered:()=>mc,evaluateStatement:()=>ze,executeStep:()=>je,exportMCPTools:()=>xc,filterInteractionListeners:()=>ws,generateActionStep:()=>gt,getActionEntityLocatorInfo:()=>O,getBrowserCdpUrl:()=>Wn,getCapabilitySummary:()=>wc,getFramePath:()=>Lo,getModel:()=>fe,getPageInfo:()=>Ql,getPageWsUrl:()=>Zl,getPlatformFromDeviceName:()=>Rc,getProviderOptions:()=>we,getSdkConfig:()=>W,getToolRegistry:()=>pc,injectUserFunction:()=>Eo,isInteractionEventType:()=>fs,isInteractiveRole:()=>gs,loadKnowledgeMappings:()=>Cr,loadKnowledges:()=>Ir,loadUserFunctions:()=>Ar,logger:()=>h,newBrowserContext:()=>ql,parseSSEStream:()=>_r,parseSdkLogLevelFromEnv:()=>Er,pickBestLocator:()=>$t,pickBestLocatorForElement:()=>Vi,pickBestLocators:()=>Rr,registerBrowser:()=>yt,replaceVariables:()=>to,runTask:()=>Ve,setWindowBounds:()=>Un,toolRegistry:()=>F,unregisterBrowser:()=>xt});function Hp(e){let t=new ua,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=xa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new ya(n)}var Wp,va=y(()=>{"use strict";kr();Mr();Pr();bc();vc();_c();la();aa();sa();ra();Lc();Nc();Fc();Hc();ca();Yc();Vt();dn();ln();Gi();st();Zi();en();nt();Qi();on();Rt();Ft();Se();Ct();Nt();kn();Ke();Ht();Ut();dt();Bt();Gt();ro();ee();fa();ga();_t();so();Te();bt();ke();Dt();ot();Ot();De();ba();na();pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();jt();ki();$n();ii();G();Ge();N();Q();ht();Dn();R();Jc();me();Wp="1.0.0"});var Zc,Qc=y(()=>{"use strict";Zc=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4532
+ ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(b.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(v,x,p,f)=>await l(v,x,p,"login")),d=!0,b.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return b.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),b.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),m;if(o)b.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{b.log("Generating validation locators for future login verification...");let v=await ao(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,p)=>this.run(x,p),async x=>this.getDOMText(x));v?(m=v,b.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):b.log("Failed to generate validation locators, login will still succeed")}catch(v){b.log(`Error generating validation locators: ${v.message}`)}else b.log("Skipping validation locator generation (num_verification_exprs=0)");b.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:w,validation_exprs:m}}catch(l){return b.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(wt(),ft))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];b.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){b.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return b.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(b.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 Ci(e,i.validationExprs)?{success:!0}:{success:!1}:(b.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,n){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 o={description:i,startTime:Date.now(),artifacts:[],type:n,code:i};if(this.context.stepTracking.artifactsDir){let a=q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(a,{recursive:!0});let r=q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),o.screenshot=r}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){h.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return kt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=q.join(a,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=q.join(a,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=q.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=q.join(a,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),o.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=q.join(a,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=q.join(a,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,a.contextAfter=this.snapshotVariables(),this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}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)),h.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)),h.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)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function Fp(){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,n=t.find(p=>p.type==="month").value,o=t.find(p=>p.type==="day").value,a=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"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),m=Date.parse(c+"Z"),g=Math.round((m-u)/(1e3*60)),w=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),v=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${x}${w}:${v}`}function xa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",Fp()),{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:[]}}var Jc=y(()=>{"use strict"});var qc={};et(qc,{ActionHandler:()=>On,ActionHelper:()=>Si,Agent:()=>ya,AgentServices:()=>lo,AgentStepEventTypes:()=>wa,AgentTaskFailedError:()=>co,BrowserManager:()=>$c,DEFAULT_EVENT_LISTENER_LIMIT:()=>hn,DomService:()=>ce,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>un,HistoryTreeProcessor:()=>$s,INIT_SCRIPT:()=>Ne,INTERACTION_EVENT_TYPES:()=>ct,INTERACTIVE_ROLES:()=>Wt,LogLevel:()=>Ro,LoginType:()=>Mi,MCPToolProvider:()=>yc,OpenAIToolProvider:()=>Bi,SDK_VERSION:()=>Wp,ToolRegistry:()=>lt,TwoFactorAuthType:()=>da,VariableStore:()=>ua,WebAgent:()=>ya,configureSdk:()=>Sr,createAgent:()=>Hp,createAgentContext:()=>xa,createToolRegistry:()=>gc,createToolRegistryWithCapabilities:()=>fc,discoverChromiumCdpUrl:()=>oo,ensureToolsRegistered:()=>mc,evaluateStatement:()=>ze,executeStep:()=>je,exportMCPTools:()=>xc,filterInteractionListeners:()=>ws,generateActionStep:()=>gt,getActionEntityLocatorInfo:()=>O,getBrowserCdpUrl:()=>Wn,getCapabilitySummary:()=>wc,getFramePath:()=>Lo,getModel:()=>fe,getPageInfo:()=>Ql,getPageWsUrl:()=>Zl,getPlatformFromDeviceName:()=>Rc,getProviderOptions:()=>we,getSdkConfig:()=>W,getToolRegistry:()=>pc,injectUserFunction:()=>Eo,isInteractionEventType:()=>fs,isInteractiveRole:()=>gs,loadKnowledgeMappings:()=>Pr,loadKnowledges:()=>Ir,loadUserFunctions:()=>Ar,logger:()=>h,newBrowserContext:()=>ql,parseSSEStream:()=>_r,parseSdkLogLevelFromEnv:()=>Er,pickBestLocator:()=>$t,pickBestLocatorForElement:()=>Vi,pickBestLocators:()=>Rr,registerBrowser:()=>yt,replaceVariables:()=>to,runTask:()=>Ve,setWindowBounds:()=>Un,toolRegistry:()=>F,unregisterBrowser:()=>xt});function Hp(e){let t=new ua,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=xa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new ya(n)}var Wp,va=y(()=>{"use strict";kr();Mr();Cr();bc();vc();_c();la();aa();sa();ra();Lc();Nc();Fc();Hc();ca();Yc();Vt();dn();ln();Gi();st();Zi();en();nt();Qi();on();Rt();Ft();Se();Pt();Nt();kn();Ke();Ht();Ut();dt();Bt();Gt();ro();ee();fa();ga();_t();so();Te();bt();ke();Dt();ot();Ot();De();ba();na();pn();gn();fn();wn();bn();yn();xn();vn();_n();Sn();En();Xt();Yt();qt();Zt();Qt();ei();ti();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();gi();fi();wi();bi();yi();xi();vi();_i();jt();ki();$n();ii();G();Ge();N();Q();ht();Dn();R();Jc();me();Wp="1.0.0"});var Zc,Qc=y(()=>{"use strict";Zc=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4533
4533
  `,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
4534
4534
  const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
4535
4535
  if (targetUrl !== null) {
@@ -4544,6 +4544,6 @@ await page.waitForTimeout(2000);
4544
4544
  `;let n=t.trim().split(`
4545
4545
  `);for(let o of n)e+=` // ${o}
4546
4546
  `;return e}generatePostlude(){return""}}});function ed(e){if(!e)return"desktop";for(let t of Gp)if(t.test(e))return"mobile";return"desktop"}var Gp,td=y(()=>{"use strict";Gp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function id(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var nd=y(()=>{"use strict"});import{v4 as Kp}from"uuid";function Sa(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let p=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(p&&p[1]){let S=p[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${S}"`}let f=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(f&&f[1]){let S=f[1].replace(/^\/|\/$/g,""),_=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${_}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let p=St(e),f=i[1].replace(/\\(.)/g,"$1");return`${p} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${St(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let p=St(e),f=o[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let p=St(e),f=a[1].replace(/\\(.)/g,"$1");return`${p} containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let p=St(e),f=r[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let p=St(e),f=s[1].replace(/\\(.)/g,"$1");return`${p} not containing "${f}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let m=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(m&&m[1])return`input with placeholder "${m[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let w=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(w&&w[1])return`"${w[1].replace(/\\(.)/g,"$1")}"`;let v=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(v&&v[1])return`"${v[1].replace(/\\(.)/g,"$1")}"`;let x=e.match(/getByRole\(['"]([^'"]+)['"]/);return x&&x[1]?`${x[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function Ea(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4547
- `);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let s=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function Ta(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function St(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function ka(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function jp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function zp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function ad(e,t){let i=e.name||"unknown",n=Ta(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,r=/getByTestId\s*\(/.test(n),l=(a&&o&&r?Ea(o,a):null)??Sa(n),d,c,u={};switch(i){case"click":{let m=jp(t),g=zp(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},m&&m!=="left"&&(u.button=m),g&&(u.modifiers=g);break}case"fill":{let m=e.text||e.value||ka(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,u={value:m,index:0};break}case"press":{let m=e.key||ka(t)||"";d="press",c=`Press '${m}' on ${l}`,u={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||ka(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,u={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var od,rd=y(()=>{"use strict";od=()=>Kp()});import{z as A}from"zod";var Aa,uo,Ma,Je,Ia,Ca,Pa,te,$a,Li,ho,La=y(()=>{"use strict";Aa=A.enum(["JS_CODE","AI_MODE"]),uo=A.object({type:Aa,expression:A.string()}),Ma=A.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Je=A.object({uid:A.string(),type:Ma,comment:A.string().optional()}),Ia=A.object({action_data:A.object({action_name:A.string(),kwargs:A.record(A.any()).optional(),args:A.array(A.any()).optional()}),action_description:A.string().optional(),url:A.string().optional(),xpath:A.string().nullable().optional(),locator:A.string().nullable().optional(),css_selector:A.string().nullable().optional(),unique_selector:A.string().nullable().optional(),element_index:A.number().nullable().optional(),frame_path:A.array(A.any()).optional(),artifacts:A.record(A.any()).optional(),feedback:A.string().optional(),original_browser_use_action:A.any().optional()}).passthrough(),Ca=Je.extend({type:A.literal("DRAFT"),description:A.string()}),Pa=Je.extend({type:A.literal("ACTION"),description:A.string(),action_entity:Ia.optional(),locator:A.string().optional(),use_pure_vision:A.boolean().optional()}),te=A.lazy(()=>A.union([Ca,Pa,Je.extend({type:A.literal("STEP"),description:A.string().optional().default(""),statements:A.array(te),reference_id:A.number().optional(),template_path:A.string().optional(),template_params:A.record(A.string()).optional()}),Je.extend({type:A.literal("IF_ELSE"),description:A.string().optional(),condition:uo,then:A.array(te),else:A.array(te).optional()}),Je.extend({type:A.literal("WHILE_LOOP"),description:A.string().optional(),condition:uo,body:A.array(te),timeout_ms:A.number().optional()})])),$a=A.object({name:A.string(),statements:A.array(te),teardown:A.array(te).optional(),skip:A.union([A.boolean(),A.string()]).optional(),timeout:A.number().optional(),fail:A.union([A.boolean(),A.string()]).optional(),only:A.boolean().optional(),slow:A.boolean().optional()}),Li=A.object({tests:A.array($a).min(1),beforeAll:A.array(te).optional(),afterAll:A.array(te).optional(),beforeEach:A.array(te).optional(),afterEach:A.array(te).optional()}),ho=A.object({comment:A.string().optional(),version:A.string().optional(),goal:A.string().optional(),url:A.string().optional(),baseURL:A.string().optional(),final_feedback:A.string().optional(),completed:A.boolean().optional(),success:A.boolean().optional(),statements:A.array(te).optional(),teardown:A.array(te).optional(),last_modified_at:A.string().optional(),testGroup:Li.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 mo,parse as po,parseAllDocuments as Vp,parseDocument as Xp,Document as dd,isMap as Tt,isSeq as ie}from"yaml";import{v4 as de}from"uuid";function Oa(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(ae)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ae)),i}function ud(e,t){if(e.testGroup)return Na(e,t);let i=Oa(e,t),n=new dd(i),o=n.contents?.get("tags",!0);return ie(o)&&(o.flow=!0),e.comment&&(n.commentBefore=e.comment),sd(n,e.statements??[]),e.teardown&&sd(n,e.teardown,"teardown"),n.toString(At)}function sd(e,t,i="statements"){let n=e.contents;if(!n||!Tt(n))return;let o=n.get(i,!0);ie(o)&&Di(o,t)}function Di(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),Tt(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);ie(r)&&Di(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);ie(r)&&Di(r,n.then);let s=a.get("ELSE",!0);ie(s)&&n.else&&Di(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);ie(r)&&Di(r,n.body)}}}}function Na(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let o={};e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(ae)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(ae)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(ae)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(ae)),o.tests=i.tests.map(s=>{let l={name:s.name};return s.skip!==void 0&&(l.skip=s.skip),s.timeout!==void 0&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only!==void 0&&(l.only=s.only),s.slow!==void 0&&(l.slow=s.slow),l.statements=s.statements.map(ae),s.teardown&&s.teardown.length>0&&(l.teardown=s.teardown.map(ae)),l}),n.suite=o;let a=new dd(n),r=a.contents?.get("tags",!0);return ie(r)&&(r.flow=!0),a.toString(At)}function hd(e){return e.map(t=>mo(t,At)).join(`---
4548
- `)}function ae(e){switch(e.type){case"DRAFT":return Yp(e);case"ACTION":return md(e);case"STEP":return qp(e);case"IF_ELSE":return Zp(e);case"WHILE_LOOP":return Qp(e)}}function Yp(e){return{intent:e.description}}function md(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&s.trim()&&e.description)return{description:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))s!=="uid"&&(s==="statement"&&(t==="ai_action"||t==="ai_step")||(o[s]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function pd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=md(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?mo(a,At).trim():""}return mo(o,At).trim()}function gd(e){let t=po(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))Jp.has(c)||(l[c]=u);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function qp(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(ae)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Zp(e){let t={IF:fd(e.condition),THEN:e.then.map(ae)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ae)),t}function Qp(e){let t={WHILE:fd(e.condition),DO:e.body.map(ae)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function fd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function wd(e){let t=Vp(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=po(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=mo(a,At),d=qe(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function bd(e){try{let t=po(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function Da(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Da);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Da(a);return n}function qe(e){if(e.length>ld)throw new Error(`YAML input too large (${e.length} bytes, max ${ld})`);let t=Da(po(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return eg(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:re(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=re(t.teardown));let n=ho.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return Ra(e,o),o}function eg(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 o={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:re(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=re(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&&(o.beforeAll=re(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=re(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=re(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=re(t.afterEach));let a=Li.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function re(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(tg)}function tg(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 ig(t);if("WHILE"in t)return ng(t);if("STEP"in t)return og(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:de(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:de(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:de(),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:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:de(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}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 n=typeof t.description=="string"?t.description:"Code block";return{uid:de(),type:"ACTION",description:n,action_entity:{action_description:n,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",n=t.js;return{uid:de(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return cd({...n,action:"function",functionName:i})}if("action"in t)return cd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:de(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function yd(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 ig(e){let t=yd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:de(),type:"IF_ELSE",condition:t,then:re(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=re(e.ELSE)),n}function ng(e){let t=yd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:de(),type:"WHILE_LOOP",condition:t,body:re(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function og(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:de(),type:"STEP",description:t,statements:re(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 n=e.template_params,o={};for(let[a,r]of Object.entries(n))o[a]=String(r);i.template_params=o}return i}function cd(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:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))ag.has(d)||(r[d]=c);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:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:de(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function Ra(e,t){let i;try{i=Xp(e)}catch{return}let n=i.contents;if(!n||!Tt(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);ie(a)&&t.statements&&Et(a,t.statements);let r=o.get("teardown",!0);ie(r)&&t.teardown&&Et(r,t.teardown)}function Et(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 n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&Tt(n)){let a=n.get("statements",!0);ie(a)&&Et(a,o.statements)}else if(o.type==="IF_ELSE"&&Tt(n)){let a=n.get("THEN",!0);ie(a)&&Et(a,o.then);let r=n.get("ELSE",!0);ie(r)&&o.else&&Et(r,o.else)}else if(o.type==="WHILE_LOOP"&&Tt(n)){let a=n.get("DO",!0);ie(a)&&Et(a,o.body)}}}var At,Jp,ld,ag,go=y(()=>{"use strict";La();At={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Jp=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);ld=1024*1024;ag=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as rg,stringify as sg}from"yaml";function Fa(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function Ha(e,t){let i=Fa(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function xd(e,t){let i=rg(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=Ha(n,t);i.statements=o;let a=sg(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return qe(a),{modifiedYaml:a,modifiedStatements:o}}var vd=y(()=>{"use strict";go()});function Wa(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Me(t);for(let n of i)if(Wa(n.statements))return!0}return!1}function Sd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let r=o;r.reference_id&&t.add(r.reference_id)}let a=Me(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Ad(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Ue(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Ue(e.teardown,"teardown",t),t}function Re(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,E=Re(_,t,i),I=Re(k,t,i),C=l(e),$=C?d(C.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:$,then:E,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=Re(_,t,i),E=l(e),I=E?d(E.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let E=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(E)&&E!=="then"&&E!=="else"&&E!=="body"});if(x||p){let _=v+".then",k=v+".else",E=Re(_,t,i),I=Re(k,t,i),C=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:C,then:E,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=Re(_,t,i),E=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:E,body:k})}else if(S.length>0){let _=Re(v,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function Md(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Re(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Me,ne,Fe,He,We,Oi,_d,kd,lg,cg,Ed,Td,Ue,fo=y(()=>{"use strict";Me=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},ne=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Me(a);for(let l of s){let d=ne(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Fe=(e,t,i)=>{let n=ne(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=He(e,n)||We(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=He(e,n)||We(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=He(e,n)||We(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=He(e,n)||We(e,n);break;default:l=He(e,n)||We(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=ne(e,l.uid);if(!d||d.parent!==a)return a}return l},He=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Me(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},We=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=ne(e,i);return n?He(e,n)||We(e,n):null},Oi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Me(o);for(let r of a)i(r.statements)}};return i(e),t},_d=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},kd=(e,t,i)=>{if(!ne(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&ne(e,l);)if(s.push(l),l=Fe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!ne(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=ne(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=lg(s.statement,i);l?r=Fe(e,r,l==="then")?.uid||null:r=Fe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?cg(s.statement,i)?r=Fe(e,r,!0)?.uid||null:r=Fe(e,r,!1)?.uid||null:r=Fe(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},lg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&ne(i.then,t)?"then":i.else&&ne(i.else,t)?"else":null},cg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&ne(i.body,t))};Ed=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Td=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Ue=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Ue(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Ue(n.then,`${a}.then`,i),n.else&&Ue(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Ue(n.body,`${a}.body`,i))})}});function Ba(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Ua.has(o)||t++}return{action:t,draft:i}}function ug(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Pd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function hg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
4549
- `).match(/\bawait\b/g),o=n?n.length:0;return i<=Id&&o<=Cd?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${Id} lines and ${Cd} 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 $d(e,t){let i=t?.coverageThreshold??dg,n=[],o=[],a;try{a=qe(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Oi(a.statements??[]),...a.teardown?Oi(a.teardown):[]],{action:s,draft:l}=Ba(r),d="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 w=g.description||m.uid;n.push(`Unresolved cloud template reference on statement "${w}" (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 w=m,v=w.action_entity?.action_data?.action_name??"";if(v==="js_code"||v==="js_action"||v==="verify"||v==="ai_assert"){let x=w.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let p=ug(x);if(p){let f=w.description||v;n.push(`Invalid JS in "${f}": ${p}. ${d}`)}else if(v==="verify"){let f=hg(x);if(f){let S=w.description||v;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(m.type==="IF_ELSE"){let w=m;if(w.condition.type==="JS_CODE"){let v=Pd(w.condition.expression);v&&n.push(`Invalid JS in IF condition "${w.condition.expression}": ${v}. ${d}`)}}if(m.type==="WHILE_LOOP"){let w=m;if(w.condition.type==="JS_CODE"){let v=Pd(w.condition.expression);v&&n.push(`Invalid JS in WHILE condition "${w.condition.expression}": ${v}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:u}}}var dg,Id,Cd,Ua,Ld=y(()=>{"use strict";go();fo();dg=.5,Id=5,Cd=3,Ua=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function Dd(e){return e?e.startsWith(ue)?"android":e.startsWith(he)?"ios":"web":"web"}function Od(e){return e?e.startsWith(ue)||e.startsWith(he):!1}function Nd(e){return!!e&&e.startsWith(ue)}function Rd(e){return!!e&&e.startsWith(he)}function Fd(e){return e.startsWith(ue)?e.slice(ue.length):e.startsWith(he)?e.slice(he.length):e}function Hd(e){return`${ue}${e}`}function Wd(e){return`${he}${e}`}function wo(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Ud(e){return e?!wo(e):!1}function Ga(e){return e?wo(e)?["web"]:["android","ios"]:["web","android","ios"]}function Bd(e,t){if(!t)return!0;let i=Ga(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var ue,he,bo=y(()=>{"use strict";ue="android:",he="ios:"});function Gd(e){return e.startsWith(he)?e:`${he}${e}`}function Kd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function jd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var zd=y(()=>{"use strict";bo()});var Ka,yo,ja,za,Va,Xa,Ya,Ja,qa,Za,Ze,Qa,Ni,er,tr,Mt,Vd,Ri,Xd,Yd,xo,Jd,qd,Zd,Qd,eu=y(()=>{"use strict";Ka="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",yo=112,ja=1920,za=1080,Va=1920,Xa=1080-yo,Ya=1280,Ja=720,qa=500,Za=500,Ze="Desktop Chrome",Qa=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Qa||{}),Ni={"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"}},er=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(er||{}),tr={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"]},Mt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),tr[e].map(n=>Ni[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Vd=()=>Object.keys(Ni),Ri=e=>Ni[e],Xd={desktop:{label:"Desktop",type:"desktop",devices:Mt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Mt("mobile")}},Yd={desktop:{label:"Desktop",type:"desktop",devices:Mt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Mt("mobile",!0)}},xo=(e,t=!1)=>{let i={userAgent:Ka,viewport:{width:Va,height:Xa},isMobile:!1,hasTouch:!1};if(!e||e===Ze)return i;let n=Ri(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(qa/o,1),s=Math.max(Za/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Jd=e=>{let t={width:ja,height:za};if(!e||e===Ze)return t;let i=xo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+yo}:t},qd=e=>{let t={width:Ya,height:Ja};if(!e||e===Ze)return t;let i=xo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Zd=e=>!e||e===Ze?void 0:Ri(e)?.channel,Qd=e=>!e||e===Ze?"chromium":Ri(e)?.defaultBrowserType??"chromium"});var ir,nr,tu=y(()=>{"use strict";ir=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ir||{}),nr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(nr||{})});function iu(){return{version:"1.0",entries:{}}}function nu(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function ou(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function au(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function ru(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function su(e){return e?Object.keys(e.entries).length===0:!0}function lu(e){return e?Object.keys(e.entries).length:0}function cu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=or(e.statements??[],t),n=e.teardown?or(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function or(e,t){return e.map(i=>mg(i,t))}function mg(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Me(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=or(o.statements,t);return{...e,...n}}var du=y(()=>{"use strict";fo()});var ar,rr,uu,hu=y(()=>{"use strict";ar=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ar||{}),rr=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(rr||{}),uu=18e4});var mu,gu=y(()=>{"use strict";mu=class pu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?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,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new pu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function fu(e,t=pg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||_o,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||dr,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||ur}}function wu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return vo;if(e.ANTHROPIC_API_KEY)return sr;if(e.OPENAI_API_KEY)return lr;if(e.SHIPLIGHT_API_TOKEN)return _o}}function bu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return Fi;if(e.OPENAI_API_KEY)return cr;if(e.SHIPLIGHT_API_TOKEN)return Fi}}var sr,vo,lr,Fi,cr,_o,dr,ur,pg,yu=y(()=>{"use strict";sr="claude-haiku-4-5",vo="gemini-3.1-flash-lite",lr="gpt-5.4-mini",Fi="gemini-3-flash-preview",cr="gpt-5.4",_o="claude-sonnet-4-6",dr=vo,ur=Fi,pg=()=>typeof process<"u"?process.env:{}});var hr,xu=y(()=>{"use strict";hr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(hr||{})});function vu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function _u(e){return e.startsWith(ue)?e:`${ue}${e}`}function ku(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Su=y(()=>{"use strict";bo()});var mr={};et(mr,{ADDRESS_BAR_HEIGHT:()=>yo,ANDROID_DEVICE_PREFIX:()=>ue,ActionEntitySchema:()=>Ia,ActionSchema:()=>Pa,AgentStatus:()=>hr,BaseStatementSchema:()=>Je,BrowserType:()=>Qa,ConditionSchema:()=>uo,ConditionType:()=>rr,ConditionTypeSchema:()=>Aa,DEFAULT_ANTHROPIC_MODEL:()=>sr,DEFAULT_COMPUTER_USE_MODEL:()=>ur,DEFAULT_COPILOT_MODEL:()=>_o,DEFAULT_DEVICE_NAME:()=>Ze,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>Fi,DEFAULT_GOOGLE_MODEL:()=>vo,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>cr,DEFAULT_OPENAI_MODEL:()=>lr,DEFAULT_WEBAGENT_MODEL:()=>dr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>uu,DEVICE_CATEGORIES:()=>tr,DeviceType:()=>er,DraftSchema:()=>Ca,IOS_DEVICE_PREFIX:()=>he,LoginType:()=>ir,MIN_WINDOW_HEIGHT:()=>Za,MIN_WINDOW_WIDTH:()=>qa,NON_INTENT_ACTIONS:()=>Ua,NodeJSCodeCommon:()=>Zc,PLAYWRIGHT_DEVICES:()=>Ni,RECORD_VIDEO_HEIGHT:()=>Ja,RECORD_VIDEO_WIDTH:()=>Ya,StatementSchema:()=>te,StatementType:()=>ar,StatementTypeSchema:()=>Ma,TestFlowSchema:()=>ho,TestGroupEntrySchema:()=>$a,TestGroupSchema:()=>Li,TwoFactorAuthType:()=>nr,UI_DEVICE_CATEGORIES:()=>Xd,UI_DEVICE_CATEGORIES_ELECTRON:()=>Yd,USER_AGENT:()=>Ka,VIEWPORT_HEIGHT:()=>Xa,VIEWPORT_WIDTH:()=>Va,VariableStore:()=>mu,WINDOW_HEIGHT:()=>za,WINDOW_WIDTH:()=>ja,actionEntityToYaml:()=>pd,actionStepsMapToTestFlowSections:()=>Md,allowPureVisionAction:()=>Td,applyPatchToYaml:()=>Ha,applyPatchToYamlString:()=>xd,collectActionSteps:()=>Ue,convertPlaywrightActionToEntity:()=>ad,countIntentStatements:()=>Ba,createAndroidDeviceName:()=>Hd,createEmptyStore:()=>iu,createIOSDeviceName:()=>Wd,createRunnerStoreEntry:()=>nu,extractActionStepsFromTestFlow:()=>Ad,extractAndAttachComments:()=>Ra,extractDeviceIdentifier:()=>Fd,extractElementDescription:()=>Sa,extractElementDescriptionFromAriaSnapshot:()=>Ea,extractLocatorFromCode:()=>Ta,extractYamlMetadata:()=>bd,findNextAfterContainer:()=>We,findNextSibling:()=>He,findNextStatement:()=>Fe,findPathBetweenStatements:()=>kd,findStatementPathById:()=>ne,generateUid:()=>od,getAllDeviceNames:()=>Vd,getAllReferenceIds:()=>Sd,getAllStatementsInOrder:()=>Oi,getAndroidDeviceDisplayName:()=>ku,getBrowserWindowSize:()=>Jd,getCompatiblePlatforms:()=>Ga,getDeviceBrowserType:()=>Qd,getDeviceByName:()=>Ri,getDeviceChannel:()=>Zd,getDeviceOptions:()=>xo,getDevicesByCategory:()=>Mt,getIOSDeviceDisplayName:()=>Kd,getLoginConfigPlatform:()=>ed,getRecordVideoSize:()=>qd,getStatementContainers:()=>Me,getStoreSize:()=>lu,getTestPlatformFromDeviceName:()=>Dd,hasReferenceIds:()=>Wa,isAndroidDevice:()=>Nd,isAppPackage:()=>Ud,isDynamicAction:()=>Ed,isExecutableStatement:()=>_d,isIOSDevice:()=>Rd,isNativeDevice:()=>Od,isPhysicalDeviceUDID:()=>jd,isPlatformCompatibleWithUrl:()=>Bd,isStoreEmpty:()=>su,isWebUrl:()=>wo,mergeActionEntitiesIntoTestFlow:()=>cu,mergeStoreUpdates:()=>ru,parseAdbDeviceLine:()=>vu,parseYamlArrayItems:()=>wd,replaceVariables:()=>id,resolveActionEntity:()=>ou,resolveComputerUseModelFromEnv:()=>bu,resolveModels:()=>fu,resolveWebAgentModelFromEnv:()=>wu,suiteToYaml:()=>Na,testFlowToYaml:()=>ud,testFlowToYamlObject:()=>Oa,toAndroidDeviceName:()=>_u,toIOSDeviceName:()=>Gd,updateStoreEntry:()=>au,validatePatch:()=>Fa,validateTestYaml:()=>$d,yamlObjectsToString:()=>hd,yamlToActionEntity:()=>gd,yamlToTestFlow:()=>qe});var pr=y(()=>{"use strict";Qc();td();nd();rd();vd();Ld();go();La();zd();eu();tu();du();fo();hu();gu();yu();xu();Su();bo()});import*as Ie from"path";import*as Mu from"fs";import{test as gg,expect as bA,chromium as fg}from"@playwright/test";import*as Z from"fs";import*as tt from"path";import{randomUUID as wr}from"crypto";import{tmpdir as br}from"os";function yr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function xr(e){if(!Z.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(Z.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function vr(e){if(e){let i=tt.resolve(process.cwd(),e),n=tt.join(br(),`ext-profile-${wr()}`);if(Z.existsSync(i)){try{Z.cpSync(i,n,{recursive:!0})}catch(a){try{Z.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=tt.join(n,"SingletonLock");Z.existsSync(o)&&Z.rmSync(o,{force:!0})}else Z.mkdirSync(n,{recursive:!0});return n}let t=tt.join(br(),`ext-profile-${wr()}`);return Z.mkdirSync(t,{recursive:!0}),t}va();import b1 from"dotenv";var Up="__shiplightDotenvCache__";function Bp(){return globalThis[Up]}function _a(){let e=Bp();return e===void 0?process.env:e}async function wg(e){let i=await import(Ie.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function Eu(e){return!(!e||e==="off")}function Iu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?Iu(e.mode,t):!0}async function Tu(e,t,i){let n=Iu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var ko;async function Au(){return ko||(ko=await Promise.resolve().then(()=>(va(),qc)),ko)}var bg=new Set(["get","set","getAll","has","__variableStore"]);function yg(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||bg.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var xg=["GOOGLE_API_KEY","ANTHROPIC_API_KEY","OPENAI_API_KEY","OPENAI_BASE_URL","ANTHROPIC_MODELS_USE_VERTEXAI","GOOGLE_GENAI_USE_VERTEXAI","GOOGLE_CLOUD_PROJECT","GOOGLE_CLOUD_LOCATION","MAILGUN_API_KEY","MAILGUN_DOMAIN","SHIPLIGHT_API_TOKEN","SHIPLIGHT_API_URL"];function vg(e=_a()){let t={};for(let i of xg)t[i]=e[i]??"";return t}var _A=gg.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],variables:[void 0,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],launchOptions:async({launchOptions:e},t)=>{if(!process.env.SHIPLIGHT_REGISTRY_URL){await t(e);return}let i=e?.args??[],n={...e,args:[...i,"--remote-debugging-port=0"]};await t(n)},browser:async({browser:e},t)=>{let i=null;if(process.env.SHIPLIGHT_REGISTRY_URL)try{let n=await oo(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await yt({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await xt(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=vr(n),u=i?yr(Ie.resolve(process.cwd(),i)):[],m={...r.project.use},{storageState:g,account:w,extensionDir:v,userDataDir:x,extensionStorageState:p,autoDismissModal:f,video:S,..._}=m,k=Eu(S)?{dir:r.outputDir}:void 0,E;try{if(E=await fg.launchPersistentContext(c,{..._,headless:d,args:u,viewport:_.viewport??{width:1280,height:720},...k?{recordVideo:k}:{}}),o){let I=Ie.resolve(process.cwd(),o),C=xr(I);C&&await E.addCookies(C)}await a(E)}finally{let I=E?.pages().map(C=>C.video()).filter(C=>C!==null)??[];if(await E?.close().catch(C=>{console.warn("[fixture] Failed to close persistent context:",C)}),await Tu(I,S,r),!n)try{Mu.rmSync(c,{recursive:!0,force:!0})}catch(C){console.warn("[fixture] Failed to clean up temp profile dir:",c,C)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await wg(c)}let u=l.video;Eu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let m=await e.newContext(l);m.addInitScript(Ne);try{await a(m)}finally{let g=m.pages().map(w=>w.video()).filter(w=>w!==null);await m.close(),await Tu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await Au(),o=new n,a=s=>{if(s)for(let[l,d]of Object.entries(s))typeof d=="string"?o.set(l,d,!1):d&&typeof d=="object"&&"value"in d&&o.set(l,d.value,d.sensitive===!0)};a(i.project.use.variables),a(e);let r=yg(o);global.testContext=r,global.$=r,global.ctx=r,await t(r),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await Au(),d=l();s({env:vg(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(pr(),mr)),m=_a(),g=c(m);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, OPENAI_API_KEY, or SHIPLIGHT_API_TOKEN in your .env file (or in the runner environment for CI).");let w=u(m),v=t.__variableStore,x=r({model:g,computer_use_model:w,variableStore:v,autoDismissModal:i,downloadDir:Ie.join(o.outputDir,"downloads")}),p=Ie.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:p};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let _ of S.pages())f.setupDownloadTracking(_),f.setupDialogHandling(_);S.on("page",_=>{f.setupDownloadTracking(_),f.setupDialogHandling(_)}),global.agent=f,await n(f),delete global.agent;try{let _=o.outputDir;await f.writeExecutionResults(_);let k=Ie.join(_,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=f.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:E}=await Promise.resolve().then(()=>(pr(),mr)),I=await import("fs/promises"),C=k();for(let[B,z]of _)C.entries[B]=E(z,0);let $=Ie.join(o.outputDir,"new-action-entities.json");await I.writeFile($,JSON.stringify(C,null,2)),await o.attach("shiplight-new-action-entities",{path:$,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});export{xg as SDK_ENV_ALLOWLIST,vg as buildSdkEnv,yg as createTestContext,bA as expect,wg as resolveAuthState,_A as test};
4547
+ `);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let s=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function Ta(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function St(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function ka(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function jp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function zp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function ad(e,t){let i=e.name||"unknown",n=Ta(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,r=/getByTestId\s*\(/.test(n),l=(a&&o&&r?Ea(o,a):null)??Sa(n),d,c,u={};switch(i){case"click":{let m=jp(t),g=zp(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},m&&m!=="left"&&(u.button=m),g&&(u.modifiers=g);break}case"fill":{let m=e.text||e.value||ka(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,u={value:m,index:0};break}case"press":{let m=e.key||ka(t)||"";d="press",c=`Press '${m}' on ${l}`,u={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||ka(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,u={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var od,rd=y(()=>{"use strict";od=()=>Kp()});import{z as A}from"zod";var Aa,uo,Ma,Je,Ia,Pa,Ca,te,$a,Li,ho,La=y(()=>{"use strict";Aa=A.enum(["JS_CODE","AI_MODE"]),uo=A.object({type:Aa,expression:A.string()}),Ma=A.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Je=A.object({uid:A.string(),type:Ma,comment:A.string().optional()}),Ia=A.object({action_data:A.object({action_name:A.string(),kwargs:A.record(A.any()).optional(),args:A.array(A.any()).optional()}),action_description:A.string().optional(),url:A.string().optional(),xpath:A.string().nullable().optional(),locator:A.string().nullable().optional(),css_selector:A.string().nullable().optional(),unique_selector:A.string().nullable().optional(),element_index:A.number().nullable().optional(),frame_path:A.array(A.any()).optional(),artifacts:A.record(A.any()).optional(),feedback:A.string().optional(),original_browser_use_action:A.any().optional()}).passthrough(),Pa=Je.extend({type:A.literal("DRAFT"),description:A.string()}),Ca=Je.extend({type:A.literal("ACTION"),description:A.string(),action_entity:Ia.optional(),locator:A.string().optional(),use_pure_vision:A.boolean().optional()}),te=A.lazy(()=>A.union([Pa,Ca,Je.extend({type:A.literal("STEP"),description:A.string().optional().default(""),statements:A.array(te),reference_id:A.number().optional(),template_path:A.string().optional(),template_params:A.record(A.string()).optional()}),Je.extend({type:A.literal("IF_ELSE"),description:A.string().optional(),condition:uo,then:A.array(te),else:A.array(te).optional()}),Je.extend({type:A.literal("WHILE_LOOP"),description:A.string().optional(),condition:uo,body:A.array(te),timeout_ms:A.number().optional()})])),$a=A.object({name:A.string(),statements:A.array(te),teardown:A.array(te).optional(),skip:A.union([A.boolean(),A.string()]).optional(),timeout:A.number().optional(),fail:A.union([A.boolean(),A.string()]).optional(),only:A.boolean().optional(),slow:A.boolean().optional()}),Li=A.object({tests:A.array($a).min(1),beforeAll:A.array(te).optional(),afterAll:A.array(te).optional(),beforeEach:A.array(te).optional(),afterEach:A.array(te).optional()}),ho=A.object({comment:A.string().optional(),version:A.string().optional(),goal:A.string().optional(),url:A.string().optional(),baseURL:A.string().optional(),final_feedback:A.string().optional(),completed:A.boolean().optional(),success:A.boolean().optional(),statements:A.array(te).optional(),teardown:A.array(te).optional(),last_modified_at:A.string().optional(),testGroup:Li.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 mo,parse as po,parseAllDocuments as Vp,parseDocument as Xp,Document as dd,isMap as Tt,isSeq as ie}from"yaml";import{v4 as de}from"uuid";function Oa(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(ae)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ae)),i}function ud(e,t){if(e.testGroup)return Na(e,t);let i=Oa(e,t),n=new dd(i),o=n.contents?.get("tags",!0);return ie(o)&&(o.flow=!0),e.comment&&(n.commentBefore=e.comment),sd(n,e.statements??[]),e.teardown&&sd(n,e.teardown,"teardown"),n.toString(At)}function sd(e,t,i="statements"){let n=e.contents;if(!n||!Tt(n))return;let o=n.get(i,!0);ie(o)&&Di(o,t)}function Di(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),Tt(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);ie(r)&&Di(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);ie(r)&&Di(r,n.then);let s=a.get("ELSE",!0);ie(s)&&n.else&&Di(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);ie(r)&&Di(r,n.body)}}}}function Na(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let o={};e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(ae)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(ae)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(ae)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(ae)),o.tests=i.tests.map(s=>{let l={name:s.name};return s.skip!==void 0&&(l.skip=s.skip),s.timeout!==void 0&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only!==void 0&&(l.only=s.only),s.slow!==void 0&&(l.slow=s.slow),l.statements=s.statements.map(ae),s.teardown&&s.teardown.length>0&&(l.teardown=s.teardown.map(ae)),l}),n.suite=o;let a=new dd(n),r=a.contents?.get("tags",!0);return ie(r)&&(r.flow=!0),a.toString(At)}function hd(e){return e.map(t=>mo(t,At)).join(`---
4548
+ `)}function ae(e){switch(e.type){case"DRAFT":return Yp(e);case"ACTION":return md(e);case"STEP":return qp(e);case"IF_ELSE":return Zp(e);case"WHILE_LOOP":return Qp(e)}}function Yp(e){return{intent:e.description}}function md(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&s.trim()&&e.description)return{description:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))s!=="uid"&&(s==="statement"&&(t==="ai_action"||t==="ai_step")||(o[s]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function pd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=md(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.description,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?mo(a,At).trim():""}return mo(o,At).trim()}function gd(e){let t=po(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("js"in t&&typeof t.js=="string"&&!("VERIFY"in t)&&!("action"in t)){let c=typeof t.description=="string"?t.description:typeof t.intent=="string"?t.intent:"";return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:t.js}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))Jp.has(c)||(l[c]=u);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function qp(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(ae)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Zp(e){let t={IF:fd(e.condition),THEN:e.then.map(ae)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ae)),t}function Qp(e){let t={WHILE:fd(e.condition),DO:e.body.map(ae)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function fd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function wd(e){let t=Vp(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=po(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=mo(a,At),d=qe(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function bd(e){try{let t=po(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function Da(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Da);let t=e,i=Object.keys(t);if(i.length===1){let o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Da(a);return n}function qe(e){if(e.length>ld)throw new Error(`YAML input too large (${e.length} bytes, max ${ld})`);let t=Da(po(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return eg(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:re(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=re(t.teardown));let n=ho.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return Ra(e,o),o}function eg(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 o={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:re(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=re(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&&(o.beforeAll=re(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=re(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=re(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=re(t.afterEach));let a=Li.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function re(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(tg)}function tg(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 ig(t);if("WHILE"in t)return ng(t);if("STEP"in t)return og(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:de(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:de(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:de(),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:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:de(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}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 n=typeof t.description=="string"?t.description:"Code block";return{uid:de(),type:"ACTION",description:n,action_entity:{action_description:n,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",n=t.js;return{uid:de(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return cd({...n,action:"function",functionName:i})}if("action"in t)return cd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:de(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function yd(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 ig(e){let t=yd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:de(),type:"IF_ELSE",condition:t,then:re(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=re(e.ELSE)),n}function ng(e){let t=yd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:de(),type:"WHILE_LOOP",condition:t,body:re(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function og(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:de(),type:"STEP",description:t,statements:re(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 n=e.template_params,o={};for(let[a,r]of Object.entries(n))o[a]=String(r);i.template_params=o}return i}function cd(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:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))ag.has(d)||(r[d]=c);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:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:de(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function Ra(e,t){let i;try{i=Xp(e)}catch{return}let n=i.contents;if(!n||!Tt(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);ie(a)&&t.statements&&Et(a,t.statements);let r=o.get("teardown",!0);ie(r)&&t.teardown&&Et(r,t.teardown)}function Et(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 n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&Tt(n)){let a=n.get("statements",!0);ie(a)&&Et(a,o.statements)}else if(o.type==="IF_ELSE"&&Tt(n)){let a=n.get("THEN",!0);ie(a)&&Et(a,o.then);let r=n.get("ELSE",!0);ie(r)&&o.else&&Et(r,o.else)}else if(o.type==="WHILE_LOOP"&&Tt(n)){let a=n.get("DO",!0);ie(a)&&Et(a,o.body)}}}var At,Jp,ld,ag,go=y(()=>{"use strict";La();At={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Jp=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);ld=1024*1024;ag=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as rg,stringify as sg}from"yaml";function Fa(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function Ha(e,t){let i=Fa(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function xd(e,t){let i=rg(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=Ha(n,t);i.statements=o;let a=sg(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return qe(a),{modifiedYaml:a,modifiedStatements:o}}var vd=y(()=>{"use strict";go()});function Wa(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Me(t);for(let n of i)if(Wa(n.statements))return!0}return!1}function Sd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let r=o;r.reference_id&&t.add(r.reference_id)}let a=Me(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function Ad(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Ue(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Ue(e.teardown,"teardown",t),t}function Re(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let _=`${e}.then`,k=`${e}.else`,E=Re(_,t,i),I=Re(k,t,i),P=l(e),$=P?d(P.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:$,then:E,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let _=`${e}.body`,k=Re(_,t,i),E=l(e),I=E?d(E.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let v=`${e}.${c}`,x=t.some(([_])=>_.startsWith(v+".then.")||_===v+".then"),p=t.some(([_])=>_.startsWith(v+".else.")||_===v+".else"),f=t.some(([_])=>_.startsWith(v+".body.")||_===v+".body"),S=t.filter(([_])=>{if(!_.startsWith(v+"."))return!1;let E=_.slice(v.length+1).split(".")[0];return/^\d+$/.test(E)&&E!=="then"&&E!=="else"&&E!=="body"});if(x||p){let _=v+".then",k=v+".else",E=Re(_,t,i),I=Re(k,t,i),P=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:P,then:E,...I.length>0?{else:I}:{}})}else if(f){let _=v+".body",k=Re(_,t,i),E=m?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:E,body:k})}else if(S.length>0){let _=Re(v,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:_})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return a}function Md(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Re(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Me,ne,Fe,He,We,Oi,_d,kd,lg,cg,Ed,Td,Ue,fo=y(()=>{"use strict";Me=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},ne=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Me(a);for(let l of s){let d=ne(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Fe=(e,t,i)=>{let n=ne(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=He(e,n)||We(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=He(e,n)||We(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=He(e,n)||We(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=He(e,n)||We(e,n);break;default:l=He(e,n)||We(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=ne(e,l.uid);if(!d||d.parent!==a)return a}return l},He=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Me(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},We=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=ne(e,i);return n?He(e,n)||We(e,n):null},Oi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Me(o);for(let r of a)i(r.statements)}};return i(e),t},_d=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},kd=(e,t,i)=>{if(!ne(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&ne(e,l);)if(s.push(l),l=Fe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!ne(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=ne(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=lg(s.statement,i);l?r=Fe(e,r,l==="then")?.uid||null:r=Fe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?cg(s.statement,i)?r=Fe(e,r,!0)?.uid||null:r=Fe(e,r,!1)?.uid||null:r=Fe(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},lg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&ne(i.then,t)?"then":i.else&&ne(i.else,t)?"else":null},cg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&ne(i.body,t))};Ed=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Td=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),Ue=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Ue(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Ue(n.then,`${a}.then`,i),n.else&&Ue(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Ue(n.body,`${a}.body`,i))})}});function Ba(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Ua.has(o)||t++}return{action:t,draft:i}}function ug(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Cd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function hg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
4549
+ `).match(/\bawait\b/g),o=n?n.length:0;return i<=Id&&o<=Pd?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${Id} lines and ${Pd} 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 $d(e,t){let i=t?.coverageThreshold??dg,n=[],o=[],a;try{a=qe(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Oi(a.statements??[]),...a.teardown?Oi(a.teardown):[]],{action:s,draft:l}=Ba(r),d="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 w=g.description||m.uid;n.push(`Unresolved cloud template reference on statement "${w}" (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 w=m,v=w.action_entity?.action_data?.action_name??"";if(v==="js_code"||v==="js_action"||v==="verify"||v==="ai_assert"){let x=w.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let p=ug(x);if(p){let f=w.description||v;n.push(`Invalid JS in "${f}": ${p}. ${d}`)}else if(v==="verify"){let f=hg(x);if(f){let S=w.description||v;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(m.type==="IF_ELSE"){let w=m;if(w.condition.type==="JS_CODE"){let v=Cd(w.condition.expression);v&&n.push(`Invalid JS in IF condition "${w.condition.expression}": ${v}. ${d}`)}}if(m.type==="WHILE_LOOP"){let w=m;if(w.condition.type==="JS_CODE"){let v=Cd(w.condition.expression);v&&n.push(`Invalid JS in WHILE condition "${w.condition.expression}": ${v}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:u}}}var dg,Id,Pd,Ua,Ld=y(()=>{"use strict";go();fo();dg=.5,Id=5,Pd=3,Ua=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function Dd(e){return e?e.startsWith(ue)?"android":e.startsWith(he)?"ios":"web":"web"}function Od(e){return e?e.startsWith(ue)||e.startsWith(he):!1}function Nd(e){return!!e&&e.startsWith(ue)}function Rd(e){return!!e&&e.startsWith(he)}function Fd(e){return e.startsWith(ue)?e.slice(ue.length):e.startsWith(he)?e.slice(he.length):e}function Hd(e){return`${ue}${e}`}function Wd(e){return`${he}${e}`}function wo(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Ud(e){return e?!wo(e):!1}function Ga(e){return e?wo(e)?["web"]:["android","ios"]:["web","android","ios"]}function Bd(e,t){if(!t)return!0;let i=Ga(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var ue,he,bo=y(()=>{"use strict";ue="android:",he="ios:"});function Gd(e){return e.startsWith(he)?e:`${he}${e}`}function Kd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function jd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var zd=y(()=>{"use strict";bo()});var Ka,yo,ja,za,Va,Xa,Ya,Ja,qa,Za,Ze,Qa,Ni,er,tr,Mt,Vd,Ri,Xd,Yd,xo,Jd,qd,Zd,Qd,eu=y(()=>{"use strict";Ka="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",yo=112,ja=1920,za=1080,Va=1920,Xa=1080-yo,Ya=1280,Ja=720,qa=500,Za=500,Ze="Desktop Chrome",Qa=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Qa||{}),Ni={"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"}},er=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(er||{}),tr={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"]},Mt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),tr[e].map(n=>Ni[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Vd=()=>Object.keys(Ni),Ri=e=>Ni[e],Xd={desktop:{label:"Desktop",type:"desktop",devices:Mt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Mt("mobile")}},Yd={desktop:{label:"Desktop",type:"desktop",devices:Mt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Mt("mobile",!0)}},xo=(e,t=!1)=>{let i={userAgent:Ka,viewport:{width:Va,height:Xa},isMobile:!1,hasTouch:!1};if(!e||e===Ze)return i;let n=Ri(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(qa/o,1),s=Math.max(Za/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Jd=e=>{let t={width:ja,height:za};if(!e||e===Ze)return t;let i=xo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+yo}:t},qd=e=>{let t={width:Ya,height:Ja};if(!e||e===Ze)return t;let i=xo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Zd=e=>!e||e===Ze?void 0:Ri(e)?.channel,Qd=e=>!e||e===Ze?"chromium":Ri(e)?.defaultBrowserType??"chromium"});var ir,nr,tu=y(()=>{"use strict";ir=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ir||{}),nr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(nr||{})});function iu(){return{version:"1.0",entries:{}}}function nu(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function ou(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function au(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function ru(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function su(e){return e?Object.keys(e.entries).length===0:!0}function lu(e){return e?Object.keys(e.entries).length:0}function cu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=or(e.statements??[],t),n=e.teardown?or(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function or(e,t){return e.map(i=>mg(i,t))}function mg(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Me(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=or(o.statements,t);return{...e,...n}}var du=y(()=>{"use strict";fo()});var ar,rr,uu,hu=y(()=>{"use strict";ar=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(ar||{}),rr=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(rr||{}),uu=18e4});var mu,gu=y(()=>{"use strict";mu=class pu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?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,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new pu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function fu(e,t=pg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||_o,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||dr,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||ur}}function wu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return vo;if(e.ANTHROPIC_API_KEY)return sr;if(e.OPENAI_API_KEY)return lr;if(e.SHIPLIGHT_API_TOKEN)return _o}}function bu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return Fi;if(e.OPENAI_API_KEY)return cr;if(e.SHIPLIGHT_API_TOKEN)return Fi}}var sr,vo,lr,Fi,cr,_o,dr,ur,pg,yu=y(()=>{"use strict";sr="claude-haiku-4-5",vo="gemini-3.1-flash-lite",lr="gpt-5.4-mini",Fi="gemini-3-flash-preview",cr="gpt-5.4",_o="claude-sonnet-4-6",dr=vo,ur=Fi,pg=()=>typeof process<"u"?process.env:{}});var hr,xu=y(()=>{"use strict";hr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(hr||{})});function vu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function _u(e){return e.startsWith(ue)?e:`${ue}${e}`}function ku(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Su=y(()=>{"use strict";bo()});var mr={};et(mr,{ADDRESS_BAR_HEIGHT:()=>yo,ANDROID_DEVICE_PREFIX:()=>ue,ActionEntitySchema:()=>Ia,ActionSchema:()=>Ca,AgentStatus:()=>hr,BaseStatementSchema:()=>Je,BrowserType:()=>Qa,ConditionSchema:()=>uo,ConditionType:()=>rr,ConditionTypeSchema:()=>Aa,DEFAULT_ANTHROPIC_MODEL:()=>sr,DEFAULT_COMPUTER_USE_MODEL:()=>ur,DEFAULT_COPILOT_MODEL:()=>_o,DEFAULT_DEVICE_NAME:()=>Ze,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>Fi,DEFAULT_GOOGLE_MODEL:()=>vo,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>cr,DEFAULT_OPENAI_MODEL:()=>lr,DEFAULT_WEBAGENT_MODEL:()=>dr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>uu,DEVICE_CATEGORIES:()=>tr,DeviceType:()=>er,DraftSchema:()=>Pa,IOS_DEVICE_PREFIX:()=>he,LoginType:()=>ir,MIN_WINDOW_HEIGHT:()=>Za,MIN_WINDOW_WIDTH:()=>qa,NON_INTENT_ACTIONS:()=>Ua,NodeJSCodeCommon:()=>Zc,PLAYWRIGHT_DEVICES:()=>Ni,RECORD_VIDEO_HEIGHT:()=>Ja,RECORD_VIDEO_WIDTH:()=>Ya,StatementSchema:()=>te,StatementType:()=>ar,StatementTypeSchema:()=>Ma,TestFlowSchema:()=>ho,TestGroupEntrySchema:()=>$a,TestGroupSchema:()=>Li,TwoFactorAuthType:()=>nr,UI_DEVICE_CATEGORIES:()=>Xd,UI_DEVICE_CATEGORIES_ELECTRON:()=>Yd,USER_AGENT:()=>Ka,VIEWPORT_HEIGHT:()=>Xa,VIEWPORT_WIDTH:()=>Va,VariableStore:()=>mu,WINDOW_HEIGHT:()=>za,WINDOW_WIDTH:()=>ja,actionEntityToYaml:()=>pd,actionStepsMapToTestFlowSections:()=>Md,allowPureVisionAction:()=>Td,applyPatchToYaml:()=>Ha,applyPatchToYamlString:()=>xd,collectActionSteps:()=>Ue,convertPlaywrightActionToEntity:()=>ad,countIntentStatements:()=>Ba,createAndroidDeviceName:()=>Hd,createEmptyStore:()=>iu,createIOSDeviceName:()=>Wd,createRunnerStoreEntry:()=>nu,extractActionStepsFromTestFlow:()=>Ad,extractAndAttachComments:()=>Ra,extractDeviceIdentifier:()=>Fd,extractElementDescription:()=>Sa,extractElementDescriptionFromAriaSnapshot:()=>Ea,extractLocatorFromCode:()=>Ta,extractYamlMetadata:()=>bd,findNextAfterContainer:()=>We,findNextSibling:()=>He,findNextStatement:()=>Fe,findPathBetweenStatements:()=>kd,findStatementPathById:()=>ne,generateUid:()=>od,getAllDeviceNames:()=>Vd,getAllReferenceIds:()=>Sd,getAllStatementsInOrder:()=>Oi,getAndroidDeviceDisplayName:()=>ku,getBrowserWindowSize:()=>Jd,getCompatiblePlatforms:()=>Ga,getDeviceBrowserType:()=>Qd,getDeviceByName:()=>Ri,getDeviceChannel:()=>Zd,getDeviceOptions:()=>xo,getDevicesByCategory:()=>Mt,getIOSDeviceDisplayName:()=>Kd,getLoginConfigPlatform:()=>ed,getRecordVideoSize:()=>qd,getStatementContainers:()=>Me,getStoreSize:()=>lu,getTestPlatformFromDeviceName:()=>Dd,hasReferenceIds:()=>Wa,isAndroidDevice:()=>Nd,isAppPackage:()=>Ud,isDynamicAction:()=>Ed,isExecutableStatement:()=>_d,isIOSDevice:()=>Rd,isNativeDevice:()=>Od,isPhysicalDeviceUDID:()=>jd,isPlatformCompatibleWithUrl:()=>Bd,isStoreEmpty:()=>su,isWebUrl:()=>wo,mergeActionEntitiesIntoTestFlow:()=>cu,mergeStoreUpdates:()=>ru,parseAdbDeviceLine:()=>vu,parseYamlArrayItems:()=>wd,replaceVariables:()=>id,resolveActionEntity:()=>ou,resolveComputerUseModelFromEnv:()=>bu,resolveModels:()=>fu,resolveWebAgentModelFromEnv:()=>wu,suiteToYaml:()=>Na,testFlowToYaml:()=>ud,testFlowToYamlObject:()=>Oa,toAndroidDeviceName:()=>_u,toIOSDeviceName:()=>Gd,updateStoreEntry:()=>au,validatePatch:()=>Fa,validateTestYaml:()=>$d,yamlObjectsToString:()=>hd,yamlToActionEntity:()=>gd,yamlToTestFlow:()=>qe});var pr=y(()=>{"use strict";Qc();td();nd();rd();vd();Ld();go();La();zd();eu();tu();du();fo();hu();gu();yu();xu();Su();bo()});import*as Ie from"path";import*as Mu from"fs";import{test as gg,expect as vA,chromium as fg}from"@playwright/test";import*as Z from"fs";import*as tt from"path";import{randomUUID as wr}from"crypto";import{tmpdir as br}from"os";function yr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function xr(e){if(!Z.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(Z.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function vr(e){if(e){let i=tt.resolve(process.cwd(),e),n=tt.join(br(),`ext-profile-${wr()}`);if(Z.existsSync(i)){try{Z.cpSync(i,n,{recursive:!0})}catch(a){try{Z.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=tt.join(n,"SingletonLock");Z.existsSync(o)&&Z.rmSync(o,{force:!0})}else Z.mkdirSync(n,{recursive:!0});return n}let t=tt.join(br(),`ext-profile-${wr()}`);return Z.mkdirSync(t,{recursive:!0}),t}va();import v1 from"dotenv";var Up="__shiplightDotenvCache__";function Bp(){return globalThis[Up]}function _a(){let e=Bp();return e===void 0?process.env:e}async function wg(e){let i=await import(Ie.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function Eu(e){return!(!e||e==="off")}function Iu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?Iu(e.mode,t):!0}async function Tu(e,t,i){let n=Iu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var ko;async function Au(){return ko||(ko=await Promise.resolve().then(()=>(va(),qc)),ko)}var bg=new Set(["get","set","getAll","has","__variableStore"]);function yg(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||bg.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}function xg(e){if(!e)return null;let t;try{t=JSON.parse(e)}catch(n){throw new Error(`SHIPLIGHT_VARS_OVERRIDE is not valid JSON: ${n.message}`)}if(t===null||typeof t!="object"||Array.isArray(t))throw new Error("SHIPLIGHT_VARS_OVERRIDE must be a JSON object");let i={};for(let[n,o]of Object.entries(t)){if(typeof o!="string")throw new Error(`SHIPLIGHT_VARS_OVERRIDE key "${n}" must be a string`);i[n]=o}return i}function vg(e,t,i){let n=r=>{if(!r||!(e in r))return null;let s=r[e];return s&&typeof s=="object"&&"value"in s?s.sensitive===!0:!1},o=n(i);if(o!==null)return o;let a=n(t);return a!==null?a:!1}function _g(e,t,i,n=process.env.SHIPLIGHT_VARS_OVERRIDE){let o=xg(n);if(o)for(let[a,r]of Object.entries(o)){let s=vg(a,t,i);e.set(a,r,s)}}var kg=["GOOGLE_API_KEY","ANTHROPIC_API_KEY","OPENAI_API_KEY","OPENAI_BASE_URL","ANTHROPIC_MODELS_USE_VERTEXAI","GOOGLE_GENAI_USE_VERTEXAI","GOOGLE_CLOUD_PROJECT","GOOGLE_CLOUD_LOCATION","MAILGUN_API_KEY","MAILGUN_DOMAIN","SHIPLIGHT_API_TOKEN","SHIPLIGHT_API_URL"];function Sg(e=_a()){let t={};for(let i of kg)t[i]=e[i]??"";return t}var EA=gg.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],variables:[void 0,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],launchOptions:async({launchOptions:e},t)=>{if(!process.env.SHIPLIGHT_REGISTRY_URL){await t(e);return}let i=e?.args??[],n={...e,args:[...i,"--remote-debugging-port=0"]};await t(n)},browser:async({browser:e},t)=>{let i=null;if(process.env.SHIPLIGHT_REGISTRY_URL)try{let n=await oo(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await yt({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await xt(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=vr(n),u=i?yr(Ie.resolve(process.cwd(),i)):[],m={...r.project.use},{storageState:g,account:w,extensionDir:v,userDataDir:x,extensionStorageState:p,autoDismissModal:f,video:S,..._}=m,k=Eu(S)?{dir:r.outputDir}:void 0,E;try{if(E=await fg.launchPersistentContext(c,{..._,headless:d,args:u,viewport:_.viewport??{width:1280,height:720},...k?{recordVideo:k}:{}}),o){let I=Ie.resolve(process.cwd(),o),P=xr(I);P&&await E.addCookies(P)}await a(E)}finally{let I=E?.pages().map(P=>P.video()).filter(P=>P!==null)??[];if(await E?.close().catch(P=>{console.warn("[fixture] Failed to close persistent context:",P)}),await Tu(I,S,r),!n)try{Mu.rmSync(c,{recursive:!0,force:!0})}catch(P){console.warn("[fixture] Failed to clean up temp profile dir:",c,P)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await wg(c)}let u=l.video;Eu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let m=await e.newContext(l);m.addInitScript(Ne);try{await a(m)}finally{let g=m.pages().map(w=>w.video()).filter(w=>w!==null);await m.close(),await Tu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await Au(),o=new n,a=l=>{if(l)for(let[d,c]of Object.entries(l))typeof c=="string"?o.set(d,c,!1):c&&typeof c=="object"&&"value"in c&&o.set(d,c.value,c.sensitive===!0)},r=i.project.use.variables;a(r),a(e),_g(o,r,e);let s=yg(o);global.testContext=s,global.$=s,global.ctx=s,await t(s),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await Au(),d=l();s({env:Sg(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(pr(),mr)),m=_a(),g=c(m);if(!g)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, OPENAI_API_KEY, or SHIPLIGHT_API_TOKEN in your .env file (or in the runner environment for CI).");let w=u(m),v=t.__variableStore,x=r({model:g,computer_use_model:w,variableStore:v,autoDismissModal:i,downloadDir:Ie.join(o.outputDir,"downloads")}),p=Ie.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:p};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let _ of S.pages())f.setupDownloadTracking(_),f.setupDialogHandling(_);S.on("page",_=>{f.setupDownloadTracking(_),f.setupDialogHandling(_)}),global.agent=f,await n(f),delete global.agent;try{let _=o.outputDir;await f.writeExecutionResults(_);let k=Ie.join(_,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=f.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:E}=await Promise.resolve().then(()=>(pr(),mr)),I=await import("fs/promises"),P=k();for(let[B,z]of _)P.entries[B]=E(z,0);let $=Ie.join(o.outputDir,"new-action-entities.json");await I.writeFile($,JSON.stringify(P,null,2)),await o.attach("shiplight-new-action-entities",{path:$,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});export{kg as SDK_ENV_ALLOWLIST,_g as applyVarsOverride,Sg as buildSdkEnv,yg as createTestContext,vA as expect,vg as isDeclaredSensitive,xg as parseVarsOverrideEnv,wg as resolveAuthState,EA as test};