shiplightai 0.1.82 → 0.1.84

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.
@@ -1,9 +1,9 @@
1
- "use strict";var bh=Object.create;var tn=Object.defineProperty;var yh=Object.getOwnPropertyDescriptor;var xh=Object.getOwnPropertyNames;var vh=Object.getPrototypeOf,_h=Object.prototype.hasOwnProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ye=(e,t)=>{for(var i in t)tn(e,i,{get:t[i],enumerable:!0})},Qr=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of xh(t))!_h.call(e,o)&&o!==i&&tn(e,o,{get:()=>t[o],enumerable:!(n=yh(t,o))||n.enumerable});return e};var W=(e,t,i)=>(i=e!=null?bh(vh(e)):{},Qr(t||!e||!e.__esModule?tn(i,"default",{value:e,enumerable:!0}):i,e)),kh=e=>Qr(tn({},"__esModule",{value:!0}),e);async function ns(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:s}=await i.read();if(a)break;o+=n.decode(s,{stream:!0});let r=o.split(`
2
- `);o=r.pop()||"";for(let l of r){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 os=w(()=>{"use strict"});function as(e){Yo.updateConfig(e)}function Y(){return Yo.getConfig()}function rs(){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 Sh,Yo,nn,se=w(()=>{"use strict";Sh=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}},Yo=new Sh,nn=Yo});var Eh,Th,u,G=w(()=>{"use strict";se();Eh=class{getLevel(){return nn.get("logLevel")}isStderrOnly(){return nn.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){nn.set("logLevel",e)}},Th=new Eh,u=Th});async function Ah(e,t){let i=await import(e),n=Object.keys(i),o=new lt.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 Jo(e,t,i,n=!1){if(e[t])if(n)u.info(`Overriding existing function: ${t}`),delete e[t];else{u.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(lt.isContext(e)?o=new lt.Script(i,{importModuleDynamically:async a=>Ah(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){u.error(`Error injecting user function ${t}: ${o.message}`)}}async function ls(e,t,i=!1){try{let n=await ss.readFile(t,"utf8"),o=JSON.parse(n);u.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,s]of Object.entries(o))Jo(e,a,s,i)}catch(n){throw u.error("Failed to load user functions:",n),n}}var ss,lt,cs=w(()=>{"use strict";G();ss=W(require("fs/promises"),1),lt=W(require("vm"),1)});async function ds(e){try{let t=await qo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledges file found"),[];throw u.error("Failed to load knowledges:",t),t}}async function us(e){try{let t=await qo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledge mappings file found"),[];throw u.error("Failed to load knowledge mappings:",t),t}}var qo,hs=w(()=>{"use strict";G();qo=W(require("fs/promises"),1)});function on(e){let t=(0,Zo.zodToJsonSchema)(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 Gt(t),t}function an(e){return(0,Zo.zodToJsonSchema)(e,{$refStrategy:"none"})}function Gt(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))Gt(i)}e.type==="array"&&e.items&&Gt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Gt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Gt(i)}}var Zo,Bt=w(()=>{"use strict";Zo=require("zod-to-json-schema")});var rn,sn=w(()=>{"use strict";Bt();rn=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:on(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:on(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:on(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var Qo,Mh,b,le=w(()=>{"use strict";se();Qo=require("fs"),Mh=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=Y().agentLogPath;if(e)try{(0,Qo.appendFileSync)(e,`
1
+ "use strict";var Ah=Object.create;var nn=Object.defineProperty;var Mh=Object.getOwnPropertyDescriptor;var Ih=Object.getOwnPropertyNames;var Ph=Object.getPrototypeOf,Ch=Object.prototype.hasOwnProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var Je=(e,t)=>{for(var i in t)nn(e,i,{get:t[i],enumerable:!0})},is=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ih(t))!Ch.call(e,o)&&o!==i&&nn(e,o,{get:()=>t[o],enumerable:!(n=Mh(t,o))||n.enumerable});return e};var F=(e,t,i)=>(i=e!=null?Ah(Ph(e)):{},is(t||!e||!e.__esModule?nn(i,"default",{value:e,enumerable:!0}):i,e)),$h=e=>is(nn({},"__esModule",{value:!0}),e);async function rs(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:s}=await i.read();if(a)break;o+=n.decode(s,{stream:!0});let r=o.split(`
2
+ `);o=r.pop()||"";for(let l of r){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 ss=w(()=>{"use strict"});function ls(e){qo.updateConfig(e)}function Y(){return qo.getConfig()}function cs(){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 Oh,qo,on,se=w(()=>{"use strict";Oh=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}},qo=new Oh,on=qo});var Lh,Dh,u,B=w(()=>{"use strict";se();Lh=class{getLevel(){return on.get("logLevel")}isStderrOnly(){return on.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){on.set("logLevel",e)}},Dh=new Lh,u=Dh});async function Nh(e,t){let i=await import(e),n=Object.keys(i),o=new ct.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 Zo(e,t,i,n=!1){if(e[t])if(n)u.info(`Overriding existing function: ${t}`),delete e[t];else{u.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(ct.isContext(e)?o=new ct.Script(i,{importModuleDynamically:async a=>Nh(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){u.error(`Error injecting user function ${t}: ${o.message}`)}}async function us(e,t,i=!1){try{let n=await ds.readFile(t,"utf8"),o=JSON.parse(n);u.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,s]of Object.entries(o))Zo(e,a,s,i)}catch(n){throw u.error("Failed to load user functions:",n),n}}var ds,ct,hs=w(()=>{"use strict";B();ds=F(require("fs/promises"),1),ct=F(require("vm"),1)});async function ms(e){try{let t=await Qo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledges file found"),[];throw u.error("Failed to load knowledges:",t),t}}async function ps(e){try{let t=await Qo.readFile(e,"utf8"),i=JSON.parse(t);return u.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return u.debug("No knowledge mappings file found"),[];throw u.error("Failed to load knowledge mappings:",t),t}}var Qo,gs=w(()=>{"use strict";B();Qo=F(require("fs/promises"),1)});function an(e){let t=(0,ea.zodToJsonSchema)(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 Gt(t),t}function rn(e){return(0,ea.zodToJsonSchema)(e,{$refStrategy:"none"})}function Gt(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))Gt(i)}e.type==="array"&&e.items&&Gt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Gt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Gt(i)}}var ea,jt=w(()=>{"use strict";ea=require("zod-to-json-schema")});var sn,ln=w(()=>{"use strict";jt();sn=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:an(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:an(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:an(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function ws(e){return e!=null&&typeof e=="object"}function dt(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function fs(e){return typeof e=="string"?e:void 0}function Rh(e){let t,i;return Array.isArray(e)?(t=dt(e[0]),i=dt(e[1])):ws(e)&&(t=dt(e.x),i=dt(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function bs(e){if(!ws(e))return{};let t=Array.isArray(e.path)?e.path.map(Rh).filter(i=>i!==null):void 0;return{type:fs(e.type),x:dt(e.x),y:dt(e.y),button:fs(e.button),path:t}}var cn=w(()=>{"use strict"});var ta,Fh,b,le=w(()=>{"use strict";se();ta=require("fs"),Fh=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=Y().agentLogPath;if(e)try{(0,ta.appendFileSync)(e,`
3
3
  === Agent Execution Log ===
4
4
  Started: ${new Date().toISOString()}
5
5
 
6
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=Y().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,Qo.appendFileSync)(t,`[${i}] ${e}
6
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=Y().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,ta.appendFileSync)(t,`[${i}] ${e}
7
7
  `)}catch{}}}section(e){this.log(`
8
8
  ${"=".repeat(60)}
9
9
  ${e}
@@ -12,9 +12,9 @@ ${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!!Y().agentLogPath}},b=new Mh});var ln,Ih,Ph,Ch,$h,ms,cn,ea,ps,ta,ia,Ee=w(()=>{"use strict";ln=Object.defineProperty,Ih=Object.getOwnPropertyDescriptor,Ph=Object.getOwnPropertyNames,Ch=Object.prototype.hasOwnProperty,$h=(e,t,i)=>t in e?ln(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,ms=(e,t)=>()=>(e&&(t=e(e=0)),t),cn=(e,t)=>{for(var i in t)ln(e,i,{get:t[i],enumerable:!0})},ea=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ph(t))!Ch.call(e,o)&&o!==i&&ln(e,o,{get:()=>t[o],enumerable:!(n=Ih(t,o))||n.enumerable});return e},ps=(e,t,i)=>(ea(e,t,"default"),i&&ea(i,t,"default")),ta=e=>ea(ln({},"__esModule",{value:!0}),e),ia=(e,t,i)=>$h(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??oa}function Lh(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function R(e,t){let i=We(t);return i?new Function("page",`return ${i}`)(e):null}async function na(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 Oh(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 Dh(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Nh(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 We(e){let t=Dh(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Nh(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var dn,Kt,oa,Te,C,B=w(()=>{"use strict";Ee();dn={};cn(dn,{ACTION_TIMEOUT:()=>oa,GOTO_TIMEOUT:()=>Te,LOCATOR_TIMEOUT:()=>Kt,getActionTimeoutMs:()=>D,getFrameContext:()=>na,getLocator:()=>R,getMinimalActionEntity:()=>Oh,getPageLocatorExpression:()=>We,sanitizeForComment:()=>Lh});C=ms(()=>{Kt=5e3,oa=1e4,Te=2e4})});async function jt(e,t,i=[],n=[]){try{let o=await na(e,i);if(!o)return u.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let r=n[0];if(!r)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${gs(r)}`),d=Rh(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${gs(t)}`)).elementHandle({timeout:Kt}),!a)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Kt}),!a)return u.warn(`Could not find element with xpath: ${t}`),null;let s=await o.evaluate(r=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(r):null,a);return await a.dispose(),s?(u.debug(`Generated locator for ${t}: ${s}`),s):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return u.error(`Error in pickBestLocator: ${o}`),null}}async function un(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?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}async function fs(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await jt(e,n);i.set(n,o)})),i}function gs(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Rh(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 s=a[1].toLowerCase(),r=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${s}${r}`)}return n.join(" > ")}var Je=w(()=>{"use strict";G();B();C()});async function zt(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:s=0,height:r=0}=await a.metadata();return b.log(`Screenshot actual: ${s}x${r}, viewport: ${t}x${i}`),(s!==t||r!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function Le(e,t,i){let n=await e.evaluateHandle(s=>document.elementFromPoint(s.x,s.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 hn(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],s=o;for(;s&&s.nodeType===Node.ELEMENT_NODE;){let r=1,l=s.previousElementSibling;for(;l;)l.tagName===s.tagName&&r++,l=l.previousElementSibling;a.unshift(`${s.tagName.toLowerCase()}[${r}]`),s=s.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await un(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function mn(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 ct=w(()=>{"use strict";le();Je()});function Uh(e){return e.startsWith(Fh)}function qe(e,t){let i=t?.trim();return i?Gh(i):Uh(e)?Hh:Wh}function Gh(e){return e.endsWith("/")?e.slice(0,-1):e}var Fh,Hh,Wh,dt=w(()=>{"use strict";Fh="shp_",Hh="https://nova-api.shiplight.ai",Wh="https://api.shiplight.ai"});function ws(e,t){return`${qe(e,t)}/llm/v1`}function bs(e,t){return`${qe(e,t)}/llm/v1`}function ys(e,t){return`${qe(e,t)}/llm/v1beta`}function xs(e,t){return`${qe(e,t)}/llm`}var Ue=w(()=>{"use strict";dt()});function pn(){let e=(Y().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function ks(e){let t=Y().env||{};if(pn()){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 u.debug(`Using Vertex AI provider: model=${e}, location=${a}`),(0,_s.createVertex)({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),(0,aa.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=ys(n,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),(0,aa.createGoogleGenerativeAI)({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Ss(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:vs.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=vs.MEDIA_RESOLUTION_HIGH)}return pn()?{vertex:o}:{google:o}}var aa,_s,vs,ut=w(()=>{"use strict";Ue();G();se();aa=require("@ai-sdk/google"),_s=require("@ai-sdk/google-vertex"),vs={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function Ae(e,t){return Math.round(e/1e3*t)}async function Kh(e,t,i,n,o){let a=null,s=null;try{switch(t){case"click_at":{let r=Ae(i.x,n),l=Ae(i.y,o),d=await Le(e,r,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"right_click_at":{let r=Ae(i.x,n),l=Ae(i.y,o),d=await Le(e,r,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"double_click_at":{let r=Ae(i.x,n),l=Ae(i.y,o),d=await Le(e,r,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"drag_and_drop":{let r=Ae(i.x,n),l=Ae(i.y,o),d=Ae(i.destination_x,n),c=Ae(i.destination_y,o),h=await Le(e,r,l);a={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:d-r,delta_y:c-l}},s=h.element;break}default:b.log(`Unsupported Gemini function: ${t}`)}}catch(r){b.error(`Error mapping Gemini action "${t}"`,r)}return{action_data:a,locatorInfo:await hn(e,s)}}async function Ts(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:s}=e,r=s||jh,l=Y(),d;if(pn()){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)u.debug(`Using Google AI provider (API key): model=${r}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let v=xs(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${r}, baseUrl=${v}`),d={apiKey:S,httpOptions:{baseUrl:v}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new gn.GoogleGenAI(d);b.log(`Sending request to Gemini CUA (model=${r})...`);let h=await c.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:gn.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Bh}],temperature:.1}});b.log("Received response from Gemini CUA");let p=h.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:y,args:_}=g.functionCall;b.log(`Generated function call: ${y} with args ${JSON.stringify(_)}`),u.debug(`Generated function call: ${y} with args ${JSON.stringify(_)}`);let{action_data:x,locatorInfo:m}=await Kh(i,y,_,o,a);return x?{status:"success",actionEntity:mn(t,x,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${y}`}}var gn,Es,Bh,jh,fn=w(()=>{"use strict";ct();le();ut();Ue();G();se();gn=require("@google/genai");Es={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"]},Bh=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Es},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Es}];jh="gemini-3-flash-preview"});function Ms(e){return e!=null&&typeof e=="object"}function ht(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function As(e){return typeof e=="string"?e:void 0}function zh(e){let t,i;return Array.isArray(e)?(t=ht(e[0]),i=ht(e[1])):Ms(e)&&(t=ht(e.x),i=ht(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Is(e){if(!Ms(e))return{};let t=Array.isArray(e.path)?e.path.map(zh).filter(i=>i!==null):void 0;return{type:As(e.type),x:ht(e.x),y:ht(e.y),button:As(e.button),path:t}}var wn=w(()=>{"use strict"});async function Vh(e,t){let i=Is(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",s=await Le(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:s.relative_x,relative_y:s.relative_y}},o=s.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await Le(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],s=i.path[i.path.length-1],r=await Le(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:s.x-a.x,delta_y:s.y-a.y}},o=r.element;break}}return{action_data:n,locatorInfo:await hn(e,o)}}async function $s(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,s=a||Xh,r=await zt(i,n,o),l=Y(),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,h=new Cs.default({apiKey:d,...c&&{baseURL:c}}),p=h.responses.create.bind(h.responses);b.log(`Sending request to OpenAI CUA (model=${s})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${r}`}]}];async function y(S,v){let k={model:s,tools:[Yh],input:S,temperature:.1};return v&&(k.previous_response_id=v),p(k)}let _=await y(g,void 0),x;for(let S=0;S<Ps;S++){b.log(`Received response from OpenAI CUA (turn ${S+1})`);let v=_.output.find(I=>I.type==="computer_call");if(!v)return{status:"error",reasoning:_.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=v.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;r=await zt(i,n,o);let A=[{type:"computer_call_output",call_id:v.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${r}`,detail:"original"}}];_=await y(A,_.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 ${Ps} turns`};b.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:m,locatorInfo:f}=await Vh(i,x);return m?{status:"success",actionEntity:mn(t,m,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var Cs,Xh,Yh,Ps,bn=w(()=>{"use strict";wn();ct();le();se();Cs=W(require("openai"),1);Xh="gpt-5.4",Yh={type:"computer"},Ps=4});function Jh(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function qh(){return Jh(Y().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Os(e){let t=Y();if(qh()){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 u.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${o}, location=${a}`),(0,Ls.createVertexAnthropic)({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),(0,ra.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=bs(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),(0,ra.createAnthropic)({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function sa(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var ra,Ls,Vt=w(()=>{"use strict";Ue();G();se();ra=require("@ai-sdk/anthropic"),Ls=require("@ai-sdk/google-vertex/anthropic")});function Ds(e){let t=Y(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),(0,la.createOpenAI)({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=ws(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),(0,la.createOpenAI)({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Ns(e){return{}}var la,Xt=w(()=>{"use strict";Ue();G();se();la=require("@ai-sdk/openai")});function Fs(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Zh.test(e))return"openai"}function yn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Qh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function Me(e){let{provider:t,modelId:i}=yn(e),n=t??Fs(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=Rs[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Rs).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function Ie(e,t){let{provider:i,modelId:n}=yn(e),o=i??Fs(n);return o==="anthropic"||o==="vertex"?sa(n):o==="openai"||o==="azure"?Ns(n):o==="bedrock"?n.startsWith("anthropic.")?sa(n):{}:Ss(t,n)}var Zh,Qh,Rs,Oe=w(()=>{"use strict";Vt();ut();Xt();Zh=/^(gpt-|o\d|chatgpt-)/;Qh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Rs={anthropic:Os,google:ks,openai:Ds}});function tm(e){return e.startsWith("gemini-")?"google":"openai"}async function mt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:s}=o;b.log(`Viewport: ${a}x${s}`);let r=await zt(n,a,s),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=yn(l),c=tm(d),h=em[c];b.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:r,viewportWidth:a,viewportHeight:s,modelId:d};try{return await h(p)}catch(g){return b.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var em,pt=w(()=>{"use strict";fn();bn();ct();le();Oe();em={google:Ts,openai:$s}});function im(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,s;for(;(s=n.exec(e))!==null;){let l=e.slice(a,s.index);l&&o.push({type:"text",text:l});let d=s[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:s[0]}),a=s.index+s[0].length}let r=e.slice(a);return r&&o.push({type:"text",text:r}),o.length===0&&o.push({type:"text",text:e}),o}function nm(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=im(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!!Y().agentLogPath}},b=new Fh});var dn,Hh,Wh,Uh,Bh,ys,un,ia,xs,na,oa,Ae=w(()=>{"use strict";dn=Object.defineProperty,Hh=Object.getOwnPropertyDescriptor,Wh=Object.getOwnPropertyNames,Uh=Object.prototype.hasOwnProperty,Bh=(e,t,i)=>t in e?dn(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,ys=(e,t)=>()=>(e&&(t=e(e=0)),t),un=(e,t)=>{for(var i in t)dn(e,i,{get:t[i],enumerable:!0})},ia=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Wh(t))!Uh.call(e,o)&&o!==i&&dn(e,o,{get:()=>t[o],enumerable:!(n=Hh(t,o))||n.enumerable});return e},xs=(e,t,i)=>(ia(e,t,"default"),i&&ia(i,t,"default")),na=e=>ia(dn({},"__esModule",{value:!0}),e),oa=(e,t,i)=>Bh(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??ra}function Gh(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function R(e,t){let i=We(t);return i?new Function("page",`return ${i}`)(e):null}async function aa(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 jh(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 Kh(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function zh(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 We(e){let t=Kh(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=zh(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var hn,Kt,ra,Me,C,G=w(()=>{"use strict";Ae();hn={};un(hn,{ACTION_TIMEOUT:()=>ra,GOTO_TIMEOUT:()=>Me,LOCATOR_TIMEOUT:()=>Kt,getActionTimeoutMs:()=>D,getFrameContext:()=>aa,getLocator:()=>R,getMinimalActionEntity:()=>jh,getPageLocatorExpression:()=>We,sanitizeForComment:()=>Gh});C=ys(()=>{Kt=5e3,ra=1e4,Me=2e4})});async function zt(e,t,i=[],n=[]){try{let o=await aa(e,i);if(!o)return u.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let r=n[0];if(!r)return u.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${vs(r)}`),d=Vh(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${vs(t)}`)).elementHandle({timeout:Kt}),!a)return u.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Kt}),!a)return u.warn(`Could not find element with xpath: ${t}`),null;let s=await o.evaluate(r=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(r):null,a);return await a.dispose(),s?(u.debug(`Generated locator for ${t}: ${s}`),s):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return u.error(`Error in pickBestLocator: ${o}`),null}}async function mn(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?(u.debug(`Generated locator: ${i}`),i):(u.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return u.error(`Error in pickBestLocator: ${i}`),null}}async function _s(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await zt(e,n);i.set(n,o)})),i}function vs(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Vh(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 s=a[1].toLowerCase(),r=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${s}${r}`)}return n.join(" > ")}var qe=w(()=>{"use strict";B();G();C()});async function Vt(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:s=0,height:r=0}=await a.metadata();return b.log(`Screenshot actual: ${s}x${r}, viewport: ${t}x${i}`),(s!==t||r!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function Le(e,t,i){let n=await e.evaluateHandle(s=>document.elementFromPoint(s.x,s.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 pn(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],s=o;for(;s&&s.nodeType===Node.ELEMENT_NODE;){let r=1,l=s.previousElementSibling;for(;l;)l.tagName===s.tagName&&r++,l=l.previousElementSibling;a.unshift(`${s.tagName.toLowerCase()}[${r}]`),s=s.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await mn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function gn(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 ut=w(()=>{"use strict";le();qe()});async function Xh(e,t){let i=bs(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",s=await Le(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:s.relative_x,relative_y:s.relative_y}},o=s.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await Le(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],s=i.path[i.path.length-1],r=await Le(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:s.x-a.x,delta_y:s.y-a.y}},o=r.element;break}}return{action_data:n,locatorInfo:await pn(e,o)}}async function Es(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,s=a||Yh,r=await Vt(i,n,o),l=Y(),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,h=new Ss.default({apiKey:d,...c&&{baseURL:c}}),p=h.responses.create.bind(h.responses);b.log(`Sending request to OpenAI CUA (model=${s})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${r}`}]}];async function y(S,v){let k={model:s,tools:[Jh],input:S,temperature:.1};return v&&(k.previous_response_id=v),p(k)}let _=await y(g,void 0),x;for(let S=0;S<ks;S++){b.log(`Received response from OpenAI CUA (turn ${S+1})`);let v=_.output.find(I=>I.type==="computer_call");if(!v)return{status:"error",reasoning:_.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let k=v.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;r=await Vt(i,n,o);let A=[{type:"computer_call_output",call_id:v.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${r}`,detail:"original"}}];_=await y(A,_.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 ${ks} turns`};b.log(`Generated action: ${JSON.stringify(x)}`);let{action_data:m,locatorInfo:f}=await Xh(i,x);return m?{status:"success",actionEntity:gn(t,m,f),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(x)}`}}var Ss,Yh,Jh,ks,fn=w(()=>{"use strict";cn();ut();le();se();Ss=F(require("openai"),1);Yh="gpt-5.4",Jh={type:"computer"},ks=4});function em(e){return e.startsWith(qh)}function Ze(e,t){let i=t?.trim();return i?tm(i):em(e)?Zh:Qh}function tm(e){return e.endsWith("/")?e.slice(0,-1):e}var qh,Zh,Qh,ht=w(()=>{"use strict";qh="shp_",Zh="https://nova-api.shiplight.ai",Qh="https://api.shiplight.ai"});function Ts(e,t){return`${Ze(e,t)}/llm/v1`}function As(e,t){return`${Ze(e,t)}/llm/v1`}function Ms(e,t){return`${Ze(e,t)}/llm/v1beta`}function Is(e,t){return`${Ze(e,t)}/llm`}var Ue=w(()=>{"use strict";ht()});function wn(){let e=(Y().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function $s(e){let t=Y().env||{};if(wn()){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 u.debug(`Using Vertex AI provider: model=${e}, location=${a}`),(0,Cs.createVertex)({project:o,location:a})(e)}let i=t.GOOGLE_API_KEY;if(i)return u.debug(`Using Google AI provider (API key): model=${e}`),(0,sa.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let o=Ms(n,t.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${o}`),(0,sa.createGoogleGenerativeAI)({apiKey:n,baseURL:o})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Os(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ps.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=Ps.MEDIA_RESOLUTION_HIGH)}return wn()?{vertex:o}:{google:o}}var sa,Cs,Ps,mt=w(()=>{"use strict";Ue();B();se();sa=require("@ai-sdk/google"),Cs=require("@ai-sdk/google-vertex"),Ps={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function Ie(e,t){return Math.round(e/1e3*t)}async function nm(e,t,i,n,o){let a=null,s=null;try{switch(t){case"click_at":{let r=Ie(i.x,n),l=Ie(i.y,o),d=await Le(e,r,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"right_click_at":{let r=Ie(i.x,n),l=Ie(i.y,o),d=await Le(e,r,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"double_click_at":{let r=Ie(i.x,n),l=Ie(i.y,o),d=await Le(e,r,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},s=d.element;break}case"drag_and_drop":{let r=Ie(i.x,n),l=Ie(i.y,o),d=Ie(i.destination_x,n),c=Ie(i.destination_y,o),h=await Le(e,r,l);a={action_name:"drag_drop",kwargs:{relative_x:h.relative_x,relative_y:h.relative_y,delta_x:d-r,delta_y:c-l}},s=h.element;break}default:b.log(`Unsupported Gemini function: ${t}`)}}catch(r){b.error(`Error mapping Gemini action "${t}"`,r)}return{action_data:a,locatorInfo:await pn(e,s)}}async function Ds(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:s}=e,r=s||om,l=Y(),d;if(wn()){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)u.debug(`Using Google AI provider (API key): model=${r}`),d={apiKey:f};else{let S=l.env?.SHIPLIGHT_API_TOKEN;if(S){let v=Is(S,l.env?.SHIPLIGHT_API_URL);u.debug(`Using Shiplight LLM proxy (Google CUA): model=${r}, baseUrl=${v}`),d={apiKey:S,httpOptions:{baseUrl:v}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let c=new bn.GoogleGenAI(d);b.log(`Sending request to Gemini CUA (model=${r})...`);let h=await c.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:bn.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:im}],temperature:.1}});b.log("Received response from Gemini CUA");let p=h.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(f=>f.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(f=>f.text).map(f=>f.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:y,args:_}=g.functionCall;b.log(`Generated function call: ${y} with args ${JSON.stringify(_)}`),u.debug(`Generated function call: ${y} with args ${JSON.stringify(_)}`);let{action_data:x,locatorInfo:m}=await nm(i,y,_,o,a);return x?{status:"success",actionEntity:gn(t,x,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${y}`}}var bn,Ls,im,om,yn=w(()=>{"use strict";ut();le();mt();Ue();B();se();bn=require("@google/genai");Ls={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"]},im=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Ls},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Ls}];om="gemini-3-flash-preview"});function am(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function rm(){return am(Y().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Rs(e){let t=Y();if(rm()){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 u.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${o}, location=${a}`),(0,Ns.createVertexAnthropic)({project:o,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return u.debug(`Using Anthropic provider: model=${e}`),(0,la.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=As(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${o}`),(0,la.createAnthropic)({apiKey:n,baseURL:o})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function ca(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var la,Ns,Xt=w(()=>{"use strict";Ue();B();se();la=require("@ai-sdk/anthropic"),Ns=require("@ai-sdk/google-vertex/anthropic")});function Fs(e){let t=Y(),i=t.env?.OPENAI_API_KEY;if(i){let o=t.env?.OPENAI_BASE_URL;return u.debug(`Using OpenAI provider: model=${e}${o?`, baseURL=${o}`:""}`),(0,da.createOpenAI)({apiKey:i,baseURL:o})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let o=Ts(n,t.env?.SHIPLIGHT_API_URL);return u.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${o}`),(0,da.createOpenAI)({apiKey:n,baseURL:o})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Hs(e){return{}}var da,Yt=w(()=>{"use strict";Ue();B();se();da=require("@ai-sdk/openai")});function Us(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(sm.test(e))return"openai"}function xn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(lm.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=xn(e),n=t??Us(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=Ws[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Ws).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}=xn(e),o=i??Us(n);return o==="anthropic"||o==="vertex"?ca(n):o==="openai"||o==="azure"?Hs(n):o==="bedrock"?n.startsWith("anthropic.")?ca(n):{}:Os(t,n)}var sm,lm,Ws,Pe=w(()=>{"use strict";Xt();mt();Yt();sm=/^(gpt-|o\d|chatgpt-)/;lm=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Ws={anthropic:Rs,google:$s,openai:Fs}});function dm(e){return e.startsWith("gemini-")?"google":"openai"}async function pt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:s}=o;b.log(`Viewport: ${a}x${s}`);let r=await Vt(n,a,s),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=xn(l),c=dm(d),h=cm[c];b.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:r,viewportWidth:a,viewportHeight:s,modelId:d};try{return await h(p)}catch(g){return b.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var cm,gt=w(()=>{"use strict";fn();yn();ut();le();Pe();cm={google:Ds,openai:Es}});function um(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,s;for(;(s=n.exec(e))!==null;){let l=e.slice(a,s.index);l&&o.push({type:"text",text:l});let d=s[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:s[0]}),a=s.index+s[0].length}let r=e.slice(a);return r&&o.push({type:"text",text:r}),o.length===0&&o.push({type:"text",text:e}),o}function hm(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=um(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
16
16
 
17
- `}),t.push(...a)}return t}function xn(e,t=Hs){if(t){let i=nm(e);if(i.length===0)return[];let n={type:"text",text:`
17
+ `}),t.push(...a)}return t}function vn(e,t=Bs){if(t){let i=hm(e);if(i.length===0)return[];let n={type:"text",text:`
18
18
 
19
19
  <retrieved_knowledge>
20
20
 
@@ -34,7 +34,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
34
34
 
35
35
  </retrieved_knowledge>
36
36
 
37
- `}]:[]}}function Ws(e,t=Hs){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Hs,Yt=w(()=>{"use strict";Hs=!1});function om(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,o=t.find(c=>c.type==="day").value,a=t.find(c=>c.type==="hour").value,s=t.find(c=>c.type==="minute").value,r=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${o} ${a}:${s}:${r}.${d} ${l}`}function Us(e){return`# Your Role
37
+ `}]:[]}}function Gs(e,t=Bs){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Bs,Jt=w(()=>{"use strict";Bs=!1});function mm(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,o=t.find(c=>c.type==="day").value,a=t.find(c=>c.type==="hour").value,s=t.find(c=>c.type==="minute").value,r=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${o} ${a}:${s}:${r}.${d} ${l}`}function js(e){return`# Your Role
38
38
  You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
39
39
 
40
40
  # Rules
@@ -94,11 +94,11 @@ Example of empty action when the target element is not on the page, or the instr
94
94
  "action": {}, // empty action object to indicate the instruction cannot be completed
95
95
  "completes_instruction": false
96
96
  }
97
- `}function am(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],o)=>{t+=`(${o+1}) Description: ${i}
97
+ `}function pm(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],o)=>{t+=`(${o+1}) Description: ${i}
98
98
  Feedback: ${n}
99
99
  `}),`## Additional context
100
100
  You just executed following steps in order:
101
- ${t}`}function Gs(e,t,i,n,o,a,s=!1,r=om(),l=!1,d){let c=[],h=`
101
+ ${t}`}function Ks(e,t,i,n,o,a,s=!1,r=mm(),l=!1,d){let c=[],h=`
102
102
  # Instruction
103
103
  "${t}"
104
104
 
@@ -118,7 +118,7 @@ ${e.tabsText}
118
118
 
119
119
  ## Interactive elements from current page:
120
120
  ${e.elementsText}
121
- `;if(c.push({type:"text",text:h}),s&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=xn(o,l);c.push(...g)}let p="";if(p+=`
121
+ `;if(c.push({type:"text",text:h}),s&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=vn(o,l);c.push(...g)}let p="";if(p+=`
122
122
  Current local time is ${r}.
123
123
  `,i&&Object.keys(i).length>0){let g=[];for(let y of Object.keys(i))if(d?.has(y))g.push(` - ${y}: [SENSITIVE - value hidden]`);else{let _=i[y],x=typeof _=="string"?_:JSON.stringify(_);g.push(` - ${y}: "${x}"`)}p+=`
124
124
  ## Available Data Placeholders
@@ -131,25 +131,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
131
131
  - Do NOT use the actual value directly
132
132
  - The values shown are for context only to help you understand what data is available
133
133
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
134
- `}if(n&&n.length>0){let g=am(n);p+=`
134
+ `}if(n&&n.length>0){let g=pm(n);p+=`
135
135
  `+g}return p+=`
136
136
  Based on the above information, please determine the right action to accomplish the task.
137
- `,c.push({type:"text",text:p}),c}var vn=w(()=>{"use strict";Yt()});async function rm(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let s=t[a];s===e&&(i=a);let r="(title unavailable)";try{r=await Promise.race([s.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${s.url()}`;r&&(l+=` - ${r.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
137
+ `,c.push({type:"text",text:p}),c}var _n=w(()=>{"use strict";Jt()});async function gm(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let s=t[a];s===e&&(i=a);let r="(title unavailable)";try{r=await Promise.race([s.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${s.url()}`;r&&(l+=` - ${r.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
138
138
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
139
- `:"",tabsText:o}}async function sm(e,t){let{currentTabText:i,tabsText:n}=await rm(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function _n(e,t){let{page:i,domService:n,agentServices:o}=e,a=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},s=o.getInteractiveClassNames(),r=o.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:s,playwrightFrameFallbackDomains:r,useCleanScreenshot:a.useCleanScreenshot,useSlicedScreenshots:a.useSlicedScreenshots,resizeSlicedScreenshots:a.resizeSlicedScreenshots,useAccessibilityTree:a.useAccessibilityTree,actionIntent:a.actionIntent}),h=l.elementTree.clickableElementsToString(),p=await sm(i,h);return c&&(p.slicedScreenshotsBase64=c),{domTree:h,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var Jt=w(()=>{"use strict"});function gt(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var qt=w(()=>{"use strict"});var fe,ft,j,De=w(()=>{"use strict";fe=require("zod"),ft=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let o=t?.description,a={...t};delete a.description;let s=n.schema.parse(a),r={...i,actionDescription:o};return await n.execute(s,r)}catch(o){if(o instanceof fe.z.ZodError){let a=o.issues.map(s=>`${s.path.join(".")}: ${s.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${a}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${a}`}}}throw o}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(o=>i.has(o.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return fe.z.object({done:fe.z.any()});let i=e.map(s=>{let r=s.schema;if(t&&r instanceof fe.z.ZodObject){let l=r._def.shape();r=fe.z.object({...l,description:fe.z.string().describe("Semantic, human-readable description of the action")})}if(r instanceof fe.z.ZodObject){let l=r._def.shape();Object.keys(l).length===0&&(r=fe.z.object({_empty:fe.z.boolean().optional()}))}return fe.z.object({[s.name]:r})});if(i.length===1)return i[0];let[n,o,...a]=i;return fe.z.union([n,o,...a])}},j=new ft});async function z(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function lm(e){let t=e.split("/").filter(o=>o);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,o,a]=n;return a?`${o}:nth-of-type(${a})`:o}return i}function cm(e,t=!0){try{let i=lm(e.xpath);if(e.attributes.class&&t){let o=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,a=e.attributes.class.split(/\s+/);for(let s of a)s.trim()&&o.test(s)&&(i+=`.${s}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(o=>n.add(o));for(let[o,a]of Object.entries(e.attributes)){if(o==="class"||!o.trim()||!n.has(o))continue;let s=o.replace(/:/g,"\\:");if(a==="")i+=`[${s}]`;else if(/["'<>`\n\r\t]/.test(a)){let r=a;a.includes(`
139
+ `:"",tabsText:o}}async function fm(e,t){let{currentTabText:i,tabsText:n}=await gm(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function kn(e,t){let{page:i,domService:n,agentServices:o}=e,a=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},s=o.getInteractiveClassNames(),r=o.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:s,playwrightFrameFallbackDomains:r,useCleanScreenshot:a.useCleanScreenshot,useSlicedScreenshots:a.useSlicedScreenshots,resizeSlicedScreenshots:a.resizeSlicedScreenshots,useAccessibilityTree:a.useAccessibilityTree,actionIntent:a.actionIntent}),h=l.elementTree.clickableElementsToString(),p=await fm(i,h);return c&&(p.slicedScreenshotsBase64=c),{domTree:h,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var qt=w(()=>{"use strict"});var be,ft,K,De=w(()=>{"use strict";be=require("zod"),ft=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let o=t?.description,a={...t};delete a.description;let s=n.schema.parse(a),r={...i,actionDescription:o};return await n.execute(s,r)}catch(o){if(o instanceof be.z.ZodError){let a=o.issues.map(s=>`${s.path.join(".")}: ${s.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${a}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${a}`}}}throw o}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(o=>i.has(o.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return be.z.object({done:be.z.any()});let i=e.map(s=>{let r=s.schema;if(t&&r instanceof be.z.ZodObject){let l=r._def.shape();r=be.z.object({...l,description:be.z.string().describe("Semantic, human-readable description of the action")})}if(r instanceof be.z.ZodObject){let l=r._def.shape();Object.keys(l).length===0&&(r=be.z.object({_empty:be.z.boolean().optional()}))}return be.z.object({[s.name]:r})});if(i.length===1)return i[0];let[n,o,...a]=i;return be.z.union([n,o,...a])}},K=new ft});function Be(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var wt=w(()=>{"use strict"});async function z(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function wm(e){let t=e.split("/").filter(o=>o);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,o,a]=n;return a?`${o}:nth-of-type(${a})`:o}return i}function bm(e,t=!0){try{let i=wm(e.xpath);if(e.attributes.class&&t){let o=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,a=e.attributes.class.split(/\s+/);for(let s of a)s.trim()&&o.test(s)&&(i+=`.${s}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(o=>n.add(o));for(let[o,a]of Object.entries(e.attributes)){if(o==="class"||!o.trim()||!n.has(o))continue;let s=o.replace(/:/g,"\\:");if(a==="")i+=`[${s}]`;else if(/["'<>`\n\r\t]/.test(a)){let r=a;a.includes(`
140
140
  `)&&(r=a.split(`
141
- `)[0]),r=r.replace(/\s+/g," ").trim();let l=r.replace(/"/g,'\\"');i+=`[${s}*="${l}"]`}else i+=`[${s}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function dm(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 cm(e,!1)}function ca(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 s=dm(a);u.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",s),n.push(s)}return n}async function F(e,t){let i=null,n=ca(t);return t.xpath&&(i=await jt(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var J=w(()=>{"use strict";Je();G()});function um(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 hm(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 mm(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=hm(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 Bs(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),s=i.temperature??0,r=o.retrieveKnowledges(e).catch(N=>(b.log(`Failed to retrieve knowledges: ${N.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),h=o.isAccessibilityTreeEnabled(),p=o.isActionIntentFilteringEnabled(),g=p?um(e):"all";p&&g!=="all"&&b.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:y,domState:_,pageContext:x}=await _n(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:h,actionIntent:g});t.domState=_;let m=new rn(j).getToolDefinitions().map(N=>{let X=N.function;return`${X.name}: ${X.description}
141
+ `)[0]),r=r.replace(/\s+/g," ").trim();let l=r.replace(/"/g,'\\"');i+=`[${s}*="${l}"]`}else i+=`[${s}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function ym(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 bm(e,!1)}function ua(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 s=ym(a);u.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",s),n.push(s)}return n}async function H(e,t){let i=null,n=ua(t);return t.xpath&&(i=await zt(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var J=w(()=>{"use strict";qe();B()});function xm(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 vm(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 _m(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=vm(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 zs(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),s=i.temperature??0,r=o.retrieveKnowledges(e).catch(N=>(b.log(`Failed to retrieve knowledges: ${N.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),h=o.isAccessibilityTreeEnabled(),p=o.isActionIntentFilteringEnabled(),g=p?xm(e):"all";p&&g!=="all"&&b.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:y,domState:_,pageContext:x}=await kn(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:h,actionIntent:g});t.domState=_;let m=new sn(K).getToolDefinitions().map(N=>{let X=N.function;return`${X.name}: ${X.description}
142
142
  Parameters: ${JSON.stringify(X.parameters,null,2)}`}).join(`
143
143
 
144
- `),f=Us(m),S=await r,v=Gs(x,e,t.variables,t.executionHistory,S.length>0?S:void 0,y,l,void 0,c,t.sensitiveKeys),k=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(N=>{N.role==="user"?k.push({role:"user",content:N.content}):N.role==="assistant"&&k.push({role:"assistant",content:N.content})}),k.push({role:"user",content:v});let A=mm(k),I=j.buildActionUnionSchema(),$=Zt.z.object({thought:Zt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Zt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:Zt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),P=Array.isArray(v)?v.filter(N=>N.type==="image").length:0,H=Ie(a,P),V;try{V=await(0,wt.generateText)({model:Me(a),system:f,messages:k,temperature:s,output:wt.Output.object({schema:$}),providerOptions:H})}catch(N){if(wt.NoObjectGeneratedError.isInstance(N)){let X={},pe=!1;if(N.text!=null)try{X=JSON.parse(N.text),pe=!0}catch{}let ge=X.thought||X.description||"",ue=ge.length>300?`${ge.slice(0,300)}\u2026`:ge,wh=!X.action||typeof X.action=="object"&&Object.keys(X.action).length===0,Yr=[],Jr=gt(N.usage,a);Jr&&Yr.push(Jr);let qr={systemPrompt:f,userPrompt:A,rawLlmResponse:N.text??"",tokenUsages:Yr};if(pe&&wh)return{status:"error",reasoning:ge||"No matching element/action found",goalAccomplished:X.completes_instruction??!1,error:ue?`No matching element/action: ${ue}`:"Agent did not generate any action (no matching element found)",debugInfo:qr};let Zr=pe?"Action generation failed: the model returned an action that did not match any known action schema.":"Action generation failed: the model returned a response that could not be parsed as a valid action.";return{status:"error",reasoning:ge||Zr,goalAccomplished:X.completes_instruction??!1,error:Zr,debugInfo:qr}}throw N}if(V.output==null){let N=V.finishReason,X=N==="length"?"Action generation failed: the model response was truncated before a complete action could be produced (token limit reached).":N==="content-filter"?"Action generation failed: the model response was blocked by a content filter.":`Action generation failed: the model stopped before producing an action (finishReason=${N??"unknown"}).`,pe=[],ge=gt(V.usage,a);return ge&&pe.push(ge),{status:"error",reasoning:"",goalAccomplished:!1,error:X,debugInfo:{systemPrompt:f,userPrompt:A,rawLlmResponse:V.text??"",tokenUsages:pe}}}let Z=V.reasoningText;u.info(`Action Generation Reasoning: ${Z}`);let U=V.output,O=JSON.stringify(U,null,2);u.info(`Generate Action Raw Output: ${O}`);let Q=[],ie=gt(V.usage,a);ie&&Q.push(ie);let de={systemPrompt:f,userPrompt:A,rawLlmResponse:O,tokenUsages:Q},ne=U.thought||"",ve=U.description||"",K=U.action||{},ee=U.completes_instruction||!1;if(!K||Object.keys(K).length===0)return{status:"error",reasoning:ne||ve||"No action generated",goalAccomplished:ee,error:"Agent did not generate any action",debugInfo:de};let te=Object.keys(K)[0];if(te==="done")return{status:"error",reasoning:ne||ve||"Task marked as done",goalAccomplished:ee,error:"Agent indicated task is done without generating an action",debugInfo:de};if(te==="perform_accurate_operation")return await mt(e,t,i);if(!ee){let N="Can't complete the instruction in one action";return{status:"error",reasoning:ne||ve||N,goalAccomplished:!1,error:N,debugInfo:de}}let me=K[te]||{},zo={};if(typeof me.element_index=="number"){let N=me.element_index;if(N<0)return{status:"error",reasoning:ne||ve||"No action generated",goalAccomplished:ee,error:"Agent did not generate any action",debugInfo:de};let X=_.selectorMap.get(N);X&&(zo=await F(n,X))}let Ut=ve;return te==="verify"&&(Ut=e,me.statement=e),{status:"success",actionEntity:{...zo,action_description:Ut||ne||`${te}(${JSON.stringify(me)})`,action_data:{action_name:te,kwargs:me}},reasoning:ne||ve,goalAccomplished:ee,debugInfo:de}}var wt,Zt,kn=w(()=>{"use strict";sn();pt();vn();Jt();qt();De();le();Oe();J();G();wt=require("ai"),Zt=require("zod")});function pm(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 da(e,t,i={}){return i.usePureVision?mt(e,t,i):Bs(e,t,i)}function fm(){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 wm(){return`# Role
144
+ `),f=js(m),S=await r,v=Ks(x,e,t.variables,t.executionHistory,S.length>0?S:void 0,y,l,void 0,c,t.sensitiveKeys),k=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(N=>{N.role==="user"?k.push({role:"user",content:N.content}):N.role==="assistant"&&k.push({role:"assistant",content:N.content})}),k.push({role:"user",content:v});let A=_m(k),I=K.buildActionUnionSchema(),$=Zt.z.object({thought:Zt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Zt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:Zt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),P=Array.isArray(v)?v.filter(N=>N.type==="image").length:0,W=we(a,P),V;try{V=await(0,bt.generateText)({model:fe(a),system:f,messages:k,temperature:s,output:bt.Output.object({schema:$}),providerOptions:W})}catch(N){if(bt.NoObjectGeneratedError.isInstance(N)){let X={},pe=!1;if(N.text!=null)try{X=JSON.parse(N.text),pe=!0}catch{}let ge=X.thought||X.description||"",ue=ge.length>300?`${ge.slice(0,300)}\u2026`:ge,Th=!X.action||typeof X.action=="object"&&Object.keys(X.action).length===0,Zr=[],Qr=Be(N.usage,a);Qr&&Zr.push(Qr);let es={systemPrompt:f,userPrompt:A,rawLlmResponse:N.text??"",tokenUsages:Zr};if(pe&&Th)return{status:"error",reasoning:ge||"No matching element/action found",goalAccomplished:X.completes_instruction??!1,error:ue?`No matching element/action: ${ue}`:"Agent did not generate any action (no matching element found)",debugInfo:es};let ts=pe?"Action generation failed: the model returned an action that did not match any known action schema.":"Action generation failed: the model returned a response that could not be parsed as a valid action.";return{status:"error",reasoning:ge||ts,goalAccomplished:X.completes_instruction??!1,error:ts,debugInfo:es}}throw N}if(V.output==null){let N=V.finishReason,X=N==="length"?"Action generation failed: the model response was truncated before a complete action could be produced (token limit reached).":N==="content-filter"?"Action generation failed: the model response was blocked by a content filter.":`Action generation failed: the model stopped before producing an action (finishReason=${N??"unknown"}).`,pe=[],ge=Be(V.usage,a);return ge&&pe.push(ge),{status:"error",reasoning:"",goalAccomplished:!1,error:X,debugInfo:{systemPrompt:f,userPrompt:A,rawLlmResponse:V.text??"",tokenUsages:pe}}}let Z=V.reasoningText;u.info(`Action Generation Reasoning: ${Z}`);let U=V.output,L=JSON.stringify(U,null,2);u.info(`Generate Action Raw Output: ${L}`);let Q=[],ie=Be(V.usage,a);ie&&Q.push(ie);let de={systemPrompt:f,userPrompt:A,rawLlmResponse:L,tokenUsages:Q},ne=U.thought||"",ke=U.description||"",j=U.action||{},ee=U.completes_instruction||!1;if(!j||Object.keys(j).length===0)return{status:"error",reasoning:ne||ke||"No action generated",goalAccomplished:ee,error:"Agent did not generate any action",debugInfo:de};let te=Object.keys(j)[0];if(te==="done")return{status:"error",reasoning:ne||ke||"Task marked as done",goalAccomplished:ee,error:"Agent indicated task is done without generating an action",debugInfo:de};if(te==="perform_accurate_operation")return await pt(e,t,i);if(!ee){let N="Can't complete the instruction in one action";return{status:"error",reasoning:ne||ke||N,goalAccomplished:!1,error:N,debugInfo:de}}let me=j[te]||{},Xo={};if(typeof me.element_index=="number"){let N=me.element_index;if(N<0)return{status:"error",reasoning:ne||ke||"No action generated",goalAccomplished:ee,error:"Agent did not generate any action",debugInfo:de};let X=_.selectorMap.get(N);X&&(Xo=await H(n,X))}let Bt=ke;return te==="verify"&&(Bt=e,me.statement=e),{status:"success",actionEntity:{...Xo,action_description:Bt||ne||`${te}(${JSON.stringify(me)})`,action_data:{action_name:te,kwargs:me}},reasoning:ne||ke,goalAccomplished:ee,debugInfo:de}}var bt,Zt,Sn=w(()=>{"use strict";ln();gt();_n();qt();De();le();wt();Pe();J();B();bt=require("ai"),Zt=require("zod")});function km(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 ha(e,t,i={}){return i.usePureVision?pt(e,t,i):zs(e,t,i)}function Em(){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 Tm(){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
- `}async function Ks(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let s=t.agentServices.isSlicedScreenshotsEnabled(),r=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:y}=await _n(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:s,resizeSlicedScreenshots:r,useAccessibilityTree:d});t.domState=g;let _="";o&&o.length>0&&(_=`
147
+ `}async function Vs(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let s=t.agentServices.isSlicedScreenshotsEnabled(),r=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:h,slicedScreenshotsBase64:p,domState:g,pageContext:y}=await kn(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:s,resizeSlicedScreenshots:r,useAccessibilityTree:d});t.domState=g;let _="";o&&o.length>0&&(_=`
148
148
  # Previous actions in this session:
149
- ${o.map(([K,ee],te)=>`${te+1}. Action: ${K}
149
+ ${o.map(([j,ee],te)=>`${te+1}. Action: ${j}
150
150
  Result: ${ee}`).join(`
151
151
  `)}
152
- `);let{dateString:x,timeString:m}=fm(),f=`
152
+ `);let{dateString:x,timeString:m}=Em(),f=`
153
153
  # User statement
154
154
  "${e}"
155
155
 
@@ -168,22 +168,22 @@ ${c}
168
168
 
169
169
  ## Screenshot
170
170
  ${s&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
171
- `,S="";if(t.variables&&Object.keys(t.variables).length>0){let K=[];for(let ee of Object.keys(t.variables))if(!t.sensitiveKeys?.has(ee)){let te=t.variables[ee],me=typeof te=="string"?te:JSON.stringify(te);K.push(` - ${ee}: "${me}"`)}K.length>0&&(S=`
171
+ `,S="";if(t.variables&&Object.keys(t.variables).length>0){let j=[];for(let ee of Object.keys(t.variables))if(!t.sensitiveKeys?.has(ee)){let te=t.variables[ee],me=typeof te=="string"?te:JSON.stringify(te);j.push(` - ${ee}: "${me}"`)}j.length>0&&(S=`
172
172
  ## Available Variables
173
173
  The following non-sensitive variables are available:
174
- ${K.join(`
174
+ ${j.join(`
175
175
  `)}`)}let v=`
176
176
  ${S}
177
177
  ${_}
178
178
 
179
179
  Today is ${x}. Current local time is ${m}.
180
180
  Based on the above information, please determine if the statement is true.
181
- `,k=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:f}],I=0;if(s&&p&&p.length>0)for(let K of p)A.push({type:"image",image:K}),I++;else A.push({type:"image",image:h}),I=1;if(k&&k.length>0){let K=xn(k,l);A.push(...K)}A.push({type:"text",text:v});let $=k?Ws(k,l):0,P=I+$,H=Ie(a,P),V=wm(),Z=await(0,Sn.generateText)({model:Me(a),system:V,messages:[{role:"user",content:A}],output:Sn.Output.object({schema:gm}),temperature:0,providerOptions:H}),{conclusion:U,explanation:O}=Z.output,Q=JSON.stringify(Z.output,null,2),ie=[],de=gt(Z.usage,a);de&&ie.push(de);let ne=[{role:"user",content:A.map(K=>{if(K.type==="text")return{type:"text",text:K.text};if(K.type==="image"){let ee=K.image,te=pm(ee);if(te)return{type:"image",file:te};let me=typeof ee=="string"?ee:"";return{type:"image",file:me.startsWith("data:")?me:`data:image/png;base64,${me}`}}return{type:"text",text:"[unknown content type]"}})}],ve={systemPrompt:V,userPrompt:ne,rawLlmResponse:Q,screenshotWithSom:h,tokenUsages:ie,retrievedKnowledges:k&&k.length>0?k:void 0,elementTree:c};return{success:U==="true",explanation:O,debugInfo:ve}}catch(s){return{success:!1,error:s.message}}}var Sn,Qt,gm,En=w(()=>{"use strict";kn();pt();Jt();qt();Yt();Oe();Sn=require("ai"),Qt=require("zod");gm=Qt.z.object({screenshotDescription:Qt.z.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),A=[{type:"text",text:f}],I=0;if(s&&p&&p.length>0)for(let j of p)A.push({type:"image",image:j}),I++;else A.push({type:"image",image:h}),I=1;if(k&&k.length>0){let j=vn(k,l);A.push(...j)}A.push({type:"text",text:v});let $=k?Gs(k,l):0,P=I+$,W=we(a,P),V=Tm(),Z=await(0,En.generateText)({model:fe(a),system:V,messages:[{role:"user",content:A}],output:En.Output.object({schema:Sm}),temperature:0,providerOptions:W}),{conclusion:U,explanation:L}=Z.output,Q=JSON.stringify(Z.output,null,2),ie=[],de=Be(Z.usage,a);de&&ie.push(de);let ne=[{role:"user",content:A.map(j=>{if(j.type==="text")return{type:"text",text:j.text};if(j.type==="image"){let ee=j.image,te=km(ee);if(te)return{type:"image",file:te};let me=typeof ee=="string"?ee:"";return{type:"image",file:me.startsWith("data:")?me:`data:image/png;base64,${me}`}}return{type:"text",text:"[unknown content type]"}})}],ke={systemPrompt:V,userPrompt:ne,rawLlmResponse:Q,screenshotWithSom:h,tokenUsages:ie,retrievedKnowledges:k&&k.length>0?k:void 0,elementTree:c};return{success:U==="true",explanation:L,debugInfo:ke}}catch(s){return{success:!1,error:s.message}}}var En,Qt,Sm,Tn=w(()=>{"use strict";Sn();gt();qt();Jt();wt();Pe();En=require("ai"),Qt=require("zod");Sm=Qt.z.object({screenshotDescription:Qt.z.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
- in the center of the screen`),explanation:Qt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Qt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function zs(){let{default:e}=await import("sharp");return e}async function ua(e,t){let i=await zs(),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 s=a,r=0,l=Math.floor((o-s)/2),d=Math.max(0,o-s),c=(y,_)=>{let x=i(e).extract({left:y,top:0,width:_,height:s});return t?.resize&&(x=x.resize(js,js)),x.png().toBuffer()},[h,p,g]=await Promise.all([c(r,Math.min(s,o)),c(l,Math.min(s,o-l)),c(d,Math.min(s,o-d))]);return[h,p,g]}async function Vs(e){let t=(await zs())(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}),s=[];for(let r=0;r<o;r++){s[r]=[];for(let l=0;l<n;l++)s[r][l]=a[r*n+l]}return{pixels:s,width:n,height:o}}var js,ei=w(()=>{"use strict";js=768});function Xs(e){return e?ti.has(e):!1}function Ys(e){return bt.has(e)}function Js(e){return e.filter(t=>bt.has(t.type))}var ti,bt,Tn,An,ii=w(()=>{"use strict";ti=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),bt=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Tn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],An=500});function qs(e,t){return e.length>t?e.slice(0,t)+"...":e}var ni=w(()=>{"use strict"});var Zs,Qs,oi=w(()=>{"use strict";Zs=["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"],Qs={"react-flow__(\\S+)":"$1"}});var el,ai,Pe,yt=w(()=>{"use strict";ni();oi();el=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},ai=class extends el{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}},Pe=class Mn extends el{constructor(t,i,n,o,a,s=!1,r=!1,l=!1,d=!1,c=!1,h=!1,p=null,g=null,y=null,_=null,x=[],m=null){super(a,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=s,this.isScrollable=r,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=h,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=y,this.viewportInfo=_,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 ai)i.push(o.text);else if(o instanceof Mn)for(let s of o.children)n(s,a+1)}};return n(this,0),i.join(`
185
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??Zs,n=t?.includeClassesWithRename??Qs,o=[],a=(s,r)=>{let l=r,d=" ".repeat(r);if(s instanceof Mn){if(s.highlightIndex!==null){l+=1;let c=s.isScrollable?"":s.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let v of Object.keys(s.attributes))if(i.includes(v)){let k=s.attributes[v].trim();k!==""&&(m[v]=k)}let f=i.filter(v=>v in m);if(f.length>1){let v=new Set,k={};for(let A of f){let I=m[A];I.length>5&&(I in k?v.add(A):k[I]=A)}for(let A of v)delete m[A]}s.tagName===m.role&&delete m.role;let S=["aria-label","placeholder","title"];for(let v of S)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(h=Object.entries(m).map(([v,k])=>`${v}=${qs(k,200)}`).join(" "))}let p=s.isNew?`*[${s.highlightIndex}]`:`[${s.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&s.attributes.class){let m=s.attributes.class.split(/\s+/);for(let f of m)for(let[S,v]of Object.entries(n))try{let k=new RegExp(`^${S}$`);if(f.match(k)){let A=f.replace(k,v);A&&g.push(A);break}}catch{continue}}let y=s.isScrollable?" (SCROLLABLE)":"",_=s.markAsClickable?" (CLICKABLE)":"",x=`${d}${p}${y}${_}<${s.tagName}`;if(g.length>0&&(x+=` ${g.join(" ")}`),h&&(x+=` ${h}`),c){let m=c.trim();h||(x+=" "),x+=`>${m}`}else h||(x+=" ");x+=" />",o.push(x)}else{let c=["data-testid","data-test-id"].filter(h=>s.attributes[h]);c.length>0&&(l+=1,o.push(`${d}<${s.tagName} ${c.map(h=>`${h}="${s.attributes[h]}"`).join(" ")} />`))}for(let c of s.children)a(c,l)}else if(s instanceof ai){if(s.hasParentWithHighlightIndex())return;s.parent&&s.parent.isVisible&&s.parent.isTopElement&&o.push(`${d}${s.text}`)}};return a(this,0),o.join(`
186
- `)}}});function xm(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var bm,ym,_e,Ze=w(()=>{"use strict";ei();ii();yt();G();bm=`(
184
+ in the center of the screen`),explanation:Qt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Qt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Ys(){let{default:e}=await import("sharp");return e}async function ma(e,t){let i=await Ys(),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 s=a,r=0,l=Math.floor((o-s)/2),d=Math.max(0,o-s),c=(y,_)=>{let x=i(e).extract({left:y,top:0,width:_,height:s});return t?.resize&&(x=x.resize(Xs,Xs)),x.png().toBuffer()},[h,p,g]=await Promise.all([c(r,Math.min(s,o)),c(l,Math.min(s,o-l)),c(d,Math.min(s,o-d))]);return[h,p,g]}async function Js(e){let t=(await Ys())(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}),s=[];for(let r=0;r<o;r++){s[r]=[];for(let l=0;l<n;l++)s[r][l]=a[r*n+l]}return{pixels:s,width:n,height:o}}var Xs,ei=w(()=>{"use strict";Xs=768});function qs(e){return e?ti.has(e):!1}function Zs(e){return yt.has(e)}function Qs(e){return e.filter(t=>yt.has(t.type))}var ti,yt,An,Mn,ii=w(()=>{"use strict";ti=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),yt=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),An=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],Mn=500});function el(e,t){return e.length>t?e.slice(0,t)+"...":e}var ni=w(()=>{"use strict"});var tl,il,oi=w(()=>{"use strict";tl=["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"],il={"react-flow__(\\S+)":"$1"}});var nl,ai,Ce,xt=w(()=>{"use strict";ni();oi();nl=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},ai=class extends nl{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}},Ce=class In extends nl{constructor(t,i,n,o,a,s=!1,r=!1,l=!1,d=!1,c=!1,h=!1,p=null,g=null,y=null,_=null,x=[],m=null){super(a,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=s,this.isScrollable=r,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=h,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=y,this.viewportInfo=_,this.isNew=null,this.shadowHostXPaths=x}getAllTextTillNextClickableElement(t=-1){let i=[],n=(o,a)=>{if(!(t!==-1&&a>t)&&!(o instanceof In&&o!==this&&o.highlightIndex!==null)){if(o instanceof ai)i.push(o.text);else if(o instanceof In)for(let s of o.children)n(s,a+1)}};return n(this,0),i.join(`
185
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??tl,n=t?.includeClassesWithRename??il,o=[],a=(s,r)=>{let l=r,d=" ".repeat(r);if(s instanceof In){if(s.highlightIndex!==null){l+=1;let c=s.isScrollable?"":s.getAllTextTillNextClickableElement(),h=null;if(i.length>0){let m={};for(let v of Object.keys(s.attributes))if(i.includes(v)){let k=s.attributes[v].trim();k!==""&&(m[v]=k)}let f=i.filter(v=>v in m);if(f.length>1){let v=new Set,k={};for(let A of f){let I=m[A];I.length>5&&(I in k?v.add(A):k[I]=A)}for(let A of v)delete m[A]}s.tagName===m.role&&delete m.role;let S=["aria-label","placeholder","title"];for(let v of S)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(h=Object.entries(m).map(([v,k])=>`${v}=${el(k,200)}`).join(" "))}let p=s.isNew?`*[${s.highlightIndex}]`:`[${s.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&s.attributes.class){let m=s.attributes.class.split(/\s+/);for(let f of m)for(let[S,v]of Object.entries(n))try{let k=new RegExp(`^${S}$`);if(f.match(k)){let A=f.replace(k,v);A&&g.push(A);break}}catch{continue}}let y=s.isScrollable?" (SCROLLABLE)":"",_=s.markAsClickable?" (CLICKABLE)":"",x=`${d}${p}${y}${_}<${s.tagName}`;if(g.length>0&&(x+=` ${g.join(" ")}`),h&&(x+=` ${h}`),c){let m=c.trim();h||(x+=" "),x+=`>${m}`}else h||(x+=" ");x+=" />",o.push(x)}else{let c=["data-testid","data-test-id"].filter(h=>s.attributes[h]);c.length>0&&(l+=1,o.push(`${d}<${s.tagName} ${c.map(h=>`${h}="${s.attributes[h]}"`).join(" ")} />`))}for(let c of s.children)a(c,l)}else if(s instanceof ai){if(s.hasParentWithHighlightIndex())return;s.parent&&s.parent.isVisible&&s.parent.isTopElement&&o.push(`${d}${s.text}`)}};return a(this,0),o.join(`
186
+ `)}}});function Im(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Am,Mm,Se,Qe=w(()=>{"use strict";ei();ii();xt();B();Am=`(
187
187
  args = {
188
188
  doHighlightElements: true,
189
189
  focusHighlightIndex: -1,
@@ -1951,7 +1951,7 @@ Based on the above information, please determine if the statement is true.
1951
1951
 
1952
1952
  return { rootId, map: DOM_HASH_MAP };
1953
1953
  }
1954
- `,ym=`((args = {
1954
+ `,Mm=`((args = {
1955
1955
  doHighlightElements: true,
1956
1956
  focusHighlightIndex: -1,
1957
1957
  viewportExpansion: 0,
@@ -3999,7 +3999,7 @@ Based on the above information, please determine if the statement is true.
3999
3999
  // Return element data from boxes phase for use in labels phase
4000
4000
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4001
4001
  };
4002
- })`;_e=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let o=this.normalizeDomain(n);if(o&&(i===o||i.endsWith(`.${o}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?ym:bm}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:o=0,interactiveClassNames:a=[],playwrightFrameFallbackDomains:s=[],alwaysHighlightFileInput:r=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,h]=await this.buildDomTree(e,i,n,o,a,s,r,l,d);return{elementTree:c,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let o=i.toString("base64"),a;if(t.useSlicedScreenshots)try{a=(await ua(i,{resize:t.resizeSlicedScreenshots})).map(s=>s.toString("base64"))}catch(s){u.warn("Failed to slice screenshot:",s)}return{domState:n,screenshotBase64:o,screenshot:i,slicedScreenshotsBase64:a}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:o}=await n.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${o.length} AXNodes from accessibility tree`);let a=o.filter(m=>{if(m.ignored)return!1;let f=m.role?.value;return!(!f||!ti.has(f)||m.properties?.find(S=>S.name==="disabled")?.value?.value||!m.backendDOMNodeId)});u.debug(`\u2705 Found ${a.length} interactive elements from AXTree`);let s=o.filter(m=>m.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${s.length}`);for(let m of s){let f=[];m.ignored&&f.push("ignored"),m.backendDOMNodeId||f.push("no-backendDOMNodeId"),m.properties?.find(S=>S.name==="disabled")?.value?.value&&f.push("disabled"),u.debug(` - "${m.name?.value||"(no name)"}" ${f.length>0?`[SKIPPED: ${f.join(", ")}]`:"[INCLUDED]"}`)}let r=new Set(a.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)r.has(m.backendNodeId)||(a.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),r.add(m.backendNodeId),d++);u.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${a.length})`);let c=await this.resolveAXNodesToDOM(n,a),h=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){u.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let f=[];m.isVisible||f.push("not-visible"),m.isInViewport||f.push("not-in-viewport"),m.isTopElement||f.push("not-top-element"),m.boundingRect||f.push("no-bounding-rect"),u.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${f.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:y}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&y>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,y)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let _=i.toString("base64"),x;if(t.useSlicedScreenshots)try{x=(await ua(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){u.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:_,screenshot:i,slicedScreenshotsBase64:x}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(a=>a.backendDOMNodeId).filter(a=>a!==void 0);if(n.length===0)return i;let o=[];for(let a of n)try{let{object:s}=await e.send("DOM.resolveNode",{backendNodeId:a});o.push(s.objectId||null)}catch{o.push(null)}for(let a=0;a<t.length;a++){let s=t[a],r=o[a];if(r)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:r,functionDeclaration:`function() {
4002
+ })`;Se=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let o=this.normalizeDomain(n);if(o&&(i===o||i.endsWith(`.${o}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){u.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Mm:Am}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:o=0,interactiveClassNames:a=[],playwrightFrameFallbackDomains:s=[],alwaysHighlightFileInput:r=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,h]=await this.buildDomTree(e,i,n,o,a,s,r,l,d);return{elementTree:c,selectorMap:h}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let o=i.toString("base64"),a;if(t.useSlicedScreenshots)try{a=(await ma(i,{resize:t.resizeSlicedScreenshots})).map(s=>s.toString("base64"))}catch(s){u.warn("Failed to slice screenshot:",s)}return{domState:n,screenshotBase64:o,screenshot:i,slicedScreenshotsBase64:a}}async getClickableElementsWithAXTree(e,t={}){u.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:o}=await n.send("Accessibility.getFullAXTree",{depth:-1});u.debug(`\u{1F4CA} Got ${o.length} AXNodes from accessibility tree`);let a=o.filter(m=>{if(m.ignored)return!1;let f=m.role?.value;return!(!f||!ti.has(f)||m.properties?.find(S=>S.name==="disabled")?.value?.value||!m.backendDOMNodeId)});u.debug(`\u2705 Found ${a.length} interactive elements from AXTree`);let s=o.filter(m=>m.role?.value==="button");u.debug(`\u{1F518} Total buttons in AXTree: ${s.length}`);for(let m of s){let f=[];m.ignored&&f.push("ignored"),m.backendDOMNodeId||f.push("no-backendDOMNodeId"),m.properties?.find(S=>S.name==="disabled")?.value?.value&&f.push("disabled"),u.debug(` - "${m.name?.value||"(no name)"}" ${f.length>0?`[SKIPPED: ${f.join(", ")}]`:"[INCLUDED]"}`)}let r=new Set(a.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)r.has(m.backendNodeId)||(a.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),r.add(m.backendNodeId),d++);u.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${a.length})`);let c=await this.resolveAXNodesToDOM(n,a),h=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){u.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let f=[];m.isVisible||f.push("not-visible"),m.isInViewport||f.push("not-in-viewport"),m.isTopElement||f.push("not-top-element"),m.boundingRect||f.push("no-bounding-rect"),u.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${f.join(", ")}]`)}}u.debug(`\u{1F441}\uFE0F ${h.length} elements are visible and in viewport`);let{domState:g,highlightIndex:y}=await this.buildDomStateFromAXTree(h);t.highlightElements!==!1&&y>0&&(await this.renderHighlightsForAXElements(e,h.slice(0,y)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let _=i.toString("base64"),x;if(t.useSlicedScreenshots)try{x=(await ma(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){u.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:_,screenshot:i,slicedScreenshotsBase64:x}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(a=>a.backendDOMNodeId).filter(a=>a!==void 0);if(n.length===0)return i;let o=[];for(let a of n)try{let{object:s}=await e.send("DOM.resolveNode",{backendNodeId:a});o.push(s.objectId||null)}catch{o.push(null)}for(let a=0;a<t.length;a++){let s=t[a],r=o[a];if(r)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:r,functionDeclaration:`function() {
4003
4003
  const el = this;
4004
4004
  const rect = el.getBoundingClientRect();
4005
4005
  const rects = el.getClientRects();
@@ -4083,34 +4083,34 @@ 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:s,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=An){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=Tn.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});u.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let s of a.slice(0,t))try{let{object:r}=await e.send("DOM.resolveNode",{nodeId:s});if(!r.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:r.objectId}),d=l.filter(c=>bt.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:s});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:r.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){u.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Pe("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",s=o.axNode.name?.value||"",r=["button","link","menuitem","tab","switch"].includes(a),l=new Pe(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",r,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(s){let d=new ai(s,!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",s=document.getElementById(a);s||(s=document.createElement("div"),s.id=a,s.style.position="fixed",s.style.pointerEvents="none",s.style.top="0",s.style.left="0",s.style.width="100%",s.style.height="100%",s.style.zIndex="2147483647",s.style.backgroundColor="transparent",document.body.appendChild(s)),n.forEach((r,l)=>{if(!r.boundingRect)return;let d=o[l%o.length],c=r.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${d}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${c.y}px`,h.style.left=`${c.x}px`,h.style.width=`${c.width}px`,h.style.height=`${c.height}px`,s.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),y=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${y}px`,s.appendChild(p)})},{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),u.debug("\u2705 Highlights removed from page")}catch(n){u.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(r=>r.map(l=>l.src)),i=r=>{try{let l=new URL(r);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(),s=[];for(let r of a){let l=r.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&s.push(l)}catch{continue}}return s}async buildDomTree(e,t,i,n,o,a,s,r,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(xm(e.url()))return[new Pe("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:s,sameRectIoUThreshold:r,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,h=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:I,argsObj:$})=>new Function("return "+I)()($),{code:this.jsCode,argsObj:x});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),v=await Vs(f);h=v.pixels;let k=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${k}ms`);let A={...d,phase:"labels",grayscaleImage:h,elementData:m.elementData};c=await e.evaluate(({code:I,argsObj:$})=>new Function("return "+I)()($),{code:this.jsCode,argsObj:A}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){u.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),h=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:m})=>new Function("return "+x)()(m),{code:this.jsCode,argsObj:d}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw u.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw u.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw u.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){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:f})=>new Function("return "+m)()(f),{code:this.jsCode,argsObj:x})}let p=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[x,m]of p){let f=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let y=[];for(let[x,m]of Object.entries(c.map)){let f=m;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&y.push({nodeId:x,src:f.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${y.length}`),y.length>0){u.debug(`\u{1F50C} Found ${y.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let m of Object.values(c.map)){let f=m;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let m=0;m<y.length;m++){let{nodeId:f,src:S}=y[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${S}`);let v=$=>{try{let P=new URL($);if(P.protocol==="chrome-extension:"&&P.hostname)return`chrome-extension://${P.hostname}`;let H=P.origin;return H==="null"?null:H}catch{return null}},k=v(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let A=null,I=e.frames().find($=>{let P=$.url();if(P===S)return A="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${P}`),!0;let H=v(P);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${P} origin=${H??"null"} vs srcOrigin=${k??"null"}`),k&&H===k?(A="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${P}`),!0):!1});if(!I){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map($=>$.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let $={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${$.initialHighlightIndex}`);let P=await I.evaluate(({code:U,argsObj:O})=>new Function("return "+U)()(O),{code:this.jsCode,argsObj:$});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(P?.map??{}).length} rootId=${P?.rootId}`),!P?.map||!P.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let H=Object.values(P.map).filter(U=>U.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${H.length}`);for(let U of H){let O=U;u.debug(`\u{1F50D} [ext-iframe] - <${O.tagName}> highlightIndex=${O.highlightIndex} text="${O.children?.length?"...":""}"`)}for(let U of Object.values(P.map)){let O=U;O.highlightIndex!=null&&(x=Math.max(x,O.highlightIndex))}let V=`ext_${m}_`;for(let[U,O]of Object.entries(P.map)){let Q={...O};Q.children&&(Q.children=Q.children.map(ie=>`${V}${ie}`)),c.map[`${V}${U}`]=Q}let Z=c.map[f];Z?(Z.children=[...Z.children||[],`${V}${P.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch($){u.warn(`Failed to process fallback iframe ${S}:`,$)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&m++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${m}/${x}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let _=await this.constructDomTree(c);return u.debug("\u2705 TypeScript DOM tree construction completed"),_}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[r,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(r,d),a.set(r,c),d instanceof Pe&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[r,l]of a){let d=o.get(r);if(d instanceof Pe)for(let c of l){let h=o.get(c);h&&(h.parent=d,d.children.push(h))}}let s=o.get(i);if(!s||!(s instanceof Pe))throw new Error("Failed to parse HTML to dictionary");return[s,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new ai(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 Pe(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]}}});var tl,il,Uw,In=w(()=>{"use strict";tl=require("zod"),il=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Uw=tl.z.object({})});var nl,Pn=w(()=>{"use strict";B();C();nl=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=R(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:s}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=We(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=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var ol,Cn=w(()=>{"use strict";ol=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_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4086
+ }`,returnByValue:!0});l.value&&i.push({axNode:s,...l.value})}catch(l){u.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=Mn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=An.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});u.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let s of a.slice(0,t))try{let{object:r}=await e.send("DOM.resolveNode",{nodeId:s});if(!r.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:r.objectId}),d=l.filter(c=>yt.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:s});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(h=>h.type)})}await e.send("Runtime.releaseObject",{objectId:r.objectId})}catch{}u.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){u.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Ce("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",s=o.axNode.name?.value||"",r=["button","link","menuitem","tab","switch"].includes(a),l=new Ce(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",r,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(s){let d=new ai(s,!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",s=document.getElementById(a);s||(s=document.createElement("div"),s.id=a,s.style.position="fixed",s.style.pointerEvents="none",s.style.top="0",s.style.left="0",s.style.width="100%",s.style.height="100%",s.style.zIndex="2147483647",s.style.backgroundColor="transparent",document.body.appendChild(s)),n.forEach((r,l)=>{if(!r.boundingRect)return;let d=o[l%o.length],c=r.boundingRect,h=document.createElement("div");h.style.position="fixed",h.style.border=`1px solid ${d}`,h.style.backgroundColor="transparent",h.style.pointerEvents="none",h.style.boxSizing="border-box",h.style.top=`${c.y}px`,h.style.left=`${c.x}px`,h.style.width=`${c.width}px`,h.style.height=`${c.height}px`,s.appendChild(h);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),y=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${y}px`,s.appendChild(p)})},{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),u.debug("\u2705 Highlights removed from page")}catch(n){u.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(r=>r.map(l=>l.src)),i=r=>{try{let l=new URL(r);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(),s=[];for(let r of a){let l=r.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&s.push(l)}catch{continue}}return s}async buildDomTree(e,t,i,n,o,a,s,r,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Im(e.url()))return[new Ce("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:s,sameRectIoUThreshold:r,actionIntent:l,domTreeRoot:this.domTreeRoot};u.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,h=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:I,argsObj:$})=>new Function("return "+I)()($),{code:this.jsCode,argsObj:x});u.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let f=await e.screenshot({type:"png",fullPage:!1});u.debug("\u{1F4F8} Captured screenshot with bounding boxes");let S=performance.now(),v=await Js(f);h=v.pixels;let k=Math.round(performance.now()-S);u.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${k}ms`);let A={...d,phase:"labels",grayscaleImage:h,elementData:m.elementData};c=await e.evaluate(({code:I,argsObj:$})=>new Function("return "+I)()($),{code:this.jsCode,argsObj:A}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,u.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){u.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),h=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:f,argsObj:S})=>new Function("return "+f)()(S),{code:this.jsCode,argsObj:m}),u.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:m})=>new Function("return "+x)()(m),{code:this.jsCode,argsObj:d}),u.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw u.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw u.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw u.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){u.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:f})=>new Function("return "+m)()(f),{code:this.jsCode,argsObj:x})}let p=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");u.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[x,m]of p){let f=m;u.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${f.attributes?.src} inaccessibleFrame=${f.inaccessibleFrame}`)}let g=e.frames();u.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)u.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let y=[];for(let[x,m]of Object.entries(c.map)){let f=m;this.shouldProcessWithPlaywrightFrameFallback(f,a)&&y.push({nodeId:x,src:f.attributes.src})}if(u.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${y.length}`),y.length>0){u.debug(`\u{1F50C} Found ${y.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let m of Object.values(c.map)){let f=m;f.highlightIndex!=null&&(x=Math.max(x,f.highlightIndex))}u.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let m=0;m<y.length;m++){let{nodeId:f,src:S}=y[m];u.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${S}`);let v=$=>{try{let P=new URL($);if(P.protocol==="chrome-extension:"&&P.hostname)return`chrome-extension://${P.hostname}`;let W=P.origin;return W==="null"?null:W}catch{return null}},k=v(S);u.debug(`\u{1F50D} [ext-iframe] iframe src origin=${k??"null"}`);let A=null,I=e.frames().find($=>{let P=$.url();if(P===S)return A="exact",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${P}`),!0;let W=v(P);return u.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${P} origin=${W??"null"} vs srcOrigin=${k??"null"}`),k&&W===k?(A="origin",u.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${P}`),!0):!1});if(!I){u.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${S}`),u.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map($=>$.url()).join(", ")}`);continue}u.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${S} (frame url: ${I.url()})`);try{let $={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};u.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${$.initialHighlightIndex}`);let P=await I.evaluate(({code:U,argsObj:L})=>new Function("return "+U)()(L),{code:this.jsCode,argsObj:$});if(u.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(P?.map??{}).length} rootId=${P?.rootId}`),!P?.map||!P.rootId){u.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let W=Object.values(P.map).filter(U=>U.highlightIndex!=null);u.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${W.length}`);for(let U of W){let L=U;u.debug(`\u{1F50D} [ext-iframe] - <${L.tagName}> highlightIndex=${L.highlightIndex} text="${L.children?.length?"...":""}"`)}for(let U of Object.values(P.map)){let L=U;L.highlightIndex!=null&&(x=Math.max(x,L.highlightIndex))}let V=`ext_${m}_`;for(let[U,L]of Object.entries(P.map)){let Q={...L};Q.children&&(Q.children=Q.children.map(ie=>`${V}${ie}`)),c.map[`${V}${U}`]=Q}let Z=c.map[f];Z?(Z.children=[...Z.children||[],`${V}${P.rootId}`],u.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${f}`)):u.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${f} not found in map`),u.debug(`\u2705 Merged fallback iframe content from: ${S}`)}catch($){u.warn(`Failed to process fallback iframe ${S}:`,$)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let S of Object.values(c.map))typeof S=="object"&&S!==null&&S.isInteractive&&m++;let f=e.url().length>50?e.url().slice(0,50)+"...":e.url();u.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${f} interactive=${m}/${x}`)}u.debug("\u{1F504} Starting TypeScript DOM tree construction...");let _=await this.constructDomTree(c);return u.debug("\u2705 TypeScript DOM tree construction completed"),_}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[r,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(r,d),a.set(r,c),d instanceof Ce&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[r,l]of a){let d=o.get(r);if(d instanceof Ce)for(let c of l){let h=o.get(c);h&&(h.parent=d,d.children.push(h))}}let s=o.get(i);if(!s||!(s instanceof Ce))throw new Error("Failed to parse HTML to dictionary");return[s,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new ai(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 Ce(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]}}});var ol,al,qw,Pn=w(()=>{"use strict";ol=require("zod"),al=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},qw=ol.z.object({})});var rl,Cn=w(()=>{"use strict";G();C();rl=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=R(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:s}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=We(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=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var sl,$n=w(()=>{"use strict";sl=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_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4087
4087
  return (async () => {
4088
4088
  ${o}
4089
4089
  })();
4090
4090
  `)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4091
- `):["// Skipping js_action: missing code"]}}});var vm,al,xt,ri=w(()=>{"use strict";Ee();vm=W(require("playwright/test"),1),al=W(require("playwright/test"),1),xt={};cn(xt,{default:()=>al.default});ps(xt,vm)});var ha,rl,Zw,$n=w(()=>{"use strict";ri();ha=require("zod"),rl=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",`
4091
+ `):["// Skipping js_action: missing code"]}}});var Pm,ll,vt,ri=w(()=>{"use strict";Ae();Pm=F(require("playwright/test"),1),ll=F(require("playwright/test"),1),vt={};un(vt,{default:()=>ll.default});xs(vt,Pm)});var pa,cl,lb,On=w(()=>{"use strict";ri();pa=require("zod"),cl=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",`
4092
4092
  return (async () => {
4093
4093
  ${o}
4094
4094
  })();
4095
- `)(e,xt.expect,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4096
- `);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},Zw=ha.z.object({code:ha.z.string().describe("JavaScript code to execute in the browser context")})});var sl,Ln=w(()=>{"use strict";B();C();sl=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r,{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 ll,On=w(()=>{"use strict";B();C();ll=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,s=[a.coord_source_x,a.coord_source_y],r=[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=R(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:D(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,h=d.y+a.relative_y+d.height/2,p=c+a.delta_x,g=h+a.delta_y;await e.mouse.move(c,h),await e.mouse.down(),n>0?await e.mouse.move(p,g,{steps:n}):await e.mouse.move(p,g),await e.mouse.up()}else if(s.every(l=>typeof l=="number")&&r.every(l=>typeof l=="number")){let[l,d]=s,[c,h]=r;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,h,{steps:n}):await e.mouse.move(c,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],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},`),"});"]}}});var cl,Dn=w(()=>{"use strict";cl=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",`
4095
+ `)(e,vt.expect,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4096
+ `);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},lb=pa.z.object({code:pa.z.string().describe("JavaScript code to execute in the browser context")})});var dl,Ln=w(()=>{"use strict";G();C();dl=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r,{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 ul,Dn=w(()=>{"use strict";G();C();ul=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(s,r,{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 hl,Nn=w(()=>{"use strict";G();C();hl=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,s=[a.coord_source_x,a.coord_source_y],r=[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=R(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:D(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,h=d.y+a.relative_y+d.height/2,p=c+a.delta_x,g=h+a.delta_y;await e.mouse.move(c,h),await e.mouse.down(),n>0?await e.mouse.move(p,g,{steps:n}):await e.mouse.move(p,g),await e.mouse.up()}else if(s.every(l=>typeof l=="number")&&r.every(l=>typeof l=="number")){let[l,d]=s,[c,h]=r;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,h,{steps:n}):await e.mouse.move(c,h),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],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},`),"});"]}}});var ml,Rn=w(()=>{"use strict";ml=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",`
4097
4097
  return (async () => {
4098
4098
  ${o}
4099
4099
  })();
4100
- `)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let s=e.parameterValues||[];i=e.parameterNames.map((r,l)=>l<s.length?String(s[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(s=>n.includes(s)||o.includes(s)||/^-?\d+(\.\d+)?$/.test(s)?s:s.startsWith("$")?`agent.agentServices.readVariable('${s.substring(1)}')`:`"${s}"`);return`await ${t}(${a.join(", ")})`}}});var Nn,dl,Rn=w(()=>{"use strict";yt();Nn=require("crypto"),dl=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 Pe){let s=n(a);if(s!==null)return s}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(0,Nn.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,Nn.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,Nn.createHash)("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 ma,vt=w(()=>{"use strict";ma=(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))(ma||{})});var _t={};Ye(_t,{evaluateStatement:()=>et,executeAction:()=>si,executeStep:()=>Qe,generateActionStep:()=>St,runTask:()=>tt});var kt=w(()=>{"use strict";li();En();kn();sn();pt();fn();bn();wn();ct();vn();Jt();qt();De();Bt();Yt();Rn();Ze();ei();ii();yt();ni();oi();le();Oe();Vt();ut();Xt();Ue();dt();J();Je();G();se();vt();B();Ee()});var pa,ul,Yb,Fn=w(()=>{"use strict";pa=require("zod"),ul=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(()=>(kt(),_t)),s=await a(o,e,i);if(s.status!=="success")throw new Error(s.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"]}},Yb=pa.z.object({statement:pa.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});var hl,Hn=w(()=>{"use strict";B();C();hl=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r),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 ml,Wn=w(()=>{"use strict";B();C();ml=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(s,r,{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 ga,pl,oy,Un=w(()=>{"use strict";ga=require("zod"),pl=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:s}=await Promise.resolve().then(()=>(kt(),_t)),r=await s(o,e,i,{usePureVision:a});if(r.status!=="success")throw new Error(r.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});`]}},oy=ga.z.object({statement:ga.z.string().describe('The action to perform (e.g., "click the submit button")')})});function fl(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:_m,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var fa,gl,_m,ci=w(()=>{"use strict";fa=require("zod"),gl=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});`]}},_m=fa.z.object({seconds:fa.z.number().positive().describe("Number of seconds to wait")})});function bl(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:km,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:s}=n;try{let r={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,r,s),{success:!0,actionEntity:r,message:"Download completed"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:r.message}}}}})}var wa,wl,km,di=w(()=>{"use strict";wa=require("zod"),wl=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} } },`,"});"]}},km=wa.z.object({timeout_seconds:wa.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function xl(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:Sm,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:s,agentServices:r}=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(s,l,r),{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 Gn,yl,Sm,ui=w(()=>{"use strict";Gn=require("zod"),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.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,s=5e3,r=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(kt(),_t));for(;Date.now()-r<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(s)}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"]}},Sm=Gn.z.object({condition:Gn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Gn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function Em(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Tm(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function vl(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:Am,async execute(i,n){let{down:o,num_pages:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await Em("scroll",d,{down:o,num_pages:a});return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Tm(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var Bn,hi,Am,mi=w(()=>{"use strict";Bn=require("zod"),hi=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)})');`]}};Am=Bn.z.object({down:Bn.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Bn.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Mm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function _l(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Sl(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Im,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:s}=i,{page:r,agentServices:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:_l(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})};let c=await Mm("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,d,r,{delta_x:a,delta_y:s});return await t.execute(r,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${s}px`}}catch(d){return{success:!1,error:d.message,actionEntity:_l(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})}}}})}var Et,kl,Im,pi=w(()=>{"use strict";J();B();Et=require("zod");C();kl=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,s=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(s)await s.hover({timeout:r}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=We(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: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Im=Et.z.object({element_index:Et.z.number().int().describe("Index of the scrollable element"),delta_x:Et.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Et.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Et.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Tl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Pm,async execute(i,n){let{text:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var ba,El,Pm,gi=w(()=>{"use strict";ba=require("zod"),El=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();`]}},Pm=ba.z.object({text:ba.z.string().describe("Text to scroll to on the page")})});async function Cm(e,t,i,n){return{...await F(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Al(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 Il(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:$m,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Al(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await Cm(d,s,a,l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Al(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var fi,Ml,$m,wi=w(()=>{"use strict";J();B();fi=require("zod");C();Ml=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=R(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{timeout:s});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},`),"});"]}};$m=fi.z.object({element_index:fi.z.number().int().describe("Index of the dropdown/select element"),option:fi.z.string().describe("Option value, label, or index to select"),timeout_ms:fi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Lm(e,t,i,n){return{...await F(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function ya(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 Cl(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
+ `)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let s=e.parameterValues||[];i=e.parameterNames.map((r,l)=>l<s.length?String(s[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(s=>n.includes(s)||o.includes(s)||/^-?\d+(\.\d+)?$/.test(s)?s:s.startsWith("$")?`agent.agentServices.readVariable('${s.substring(1)}')`:`"${s}"`);return`await ${t}(${a.join(", ")})`}}});var Fn,pl,Hn=w(()=>{"use strict";xt();Fn=require("crypto"),pl=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 Ce){let s=n(a);if(s!==null)return s}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(0,Fn.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,Fn.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,Fn.createHash)("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 ga,_t=w(()=>{"use strict";ga=(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))(ga||{})});var kt={};Je(kt,{evaluateStatement:()=>tt,executeAction:()=>si,executeStep:()=>et,generateActionStep:()=>Et,runTask:()=>it});var St=w(()=>{"use strict";li();Tn();Sn();ln();gt();fn();cn();yn();ut();_n();qt();Jt();De();jt();Hn();Qe();ei();ii();xt();ni();oi();le();wt();Pe();Xt();mt();Yt();Ue();ht();J();qe();B();se();_t();G();Ae()});var fa,gl,ly,Wn=w(()=>{"use strict";fa=require("zod"),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.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(St(),kt)),s=await a(o,e,i);if(s.status!=="success")throw new Error(s.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"]}},ly=fa.z.object({statement:fa.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});var fl,Un=w(()=>{"use strict";G();C();fl=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=R(e,t);if(o){await o.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let s=a.x+n.kwargs.relative_x+a.width/2,r=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(s,r),await e.waitForTimeout(200),await e.mouse.click(s,r),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 wa,wl,py,Bn=w(()=>{"use strict";wa=require("zod"),wl=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:s}=await Promise.resolve().then(()=>(St(),kt)),r=await s(o,e,i,{usePureVision:a});if(r.status!=="success")throw new Error(r.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});`]}},py=wa.z.object({statement:wa.z.string().describe('The action to perform (e.g., "click the submit button")')})});async function xl(e,t,i,n,o,a){let s=Array.isArray(t)?t:[t];if(s.length===0)throw new Error("No file paths provided for upload");let r=s.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let h=n.testDataDir||process.cwd();return yl.default.join(h,c)});u.info(`Uploading files: ${r.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 Gn(e,c,r,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,h=(c.startsWith("xpath="),e.locator(c));await Gn(e,h,r,d);return}if(o){let c=s.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${c} to ${i.targetDescription}`:h=`Upload ${c}`,u.info(`Using AI to handle file upload: ${h}`),await o(e,h,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Gn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:s}=n;if(s){u.info("Using mockShowOpenFilePicker approach");let r=i.map(l=>({path:l,buffer:new Uint8Array(bl.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},r),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let r=e.waitForEvent("filechooser",{timeout:a});r.catch(()=>{}),await t.click({timeout:a}),await(await r).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var bl,yl,ci=w(()=>{"use strict";B();bl=F(require("fs"),1),yl=F(require("path"),1)});async function Cm(e,t,i={},n){return{...await H(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function vl(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 kl(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:$m,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:vl(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await Cm(d,s,{paths:a},l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:vl(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var oe,_l,$m,_y,di=w(()=>{"use strict";ci();J();G();oe=require("zod");C();_l=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)),s=R(e,t);if(!s)throw new Error("Missing locator for upload_file action");let r=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Gn(e,s,a,{useFileInput:r,timeout:D(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},`),"});"]}};$m=oe.z.object({element_index:oe.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:oe.z.union([oe.z.string(),oe.z.array(oe.z.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});_y=oe.z.object({element_index:oe.z.number().int().describe("Index of the file input element"),paths:oe.z.union([oe.z.string(),oe.z.array(oe.z.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function El(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Om,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var ba,Sl,Om,ui=w(()=>{"use strict";ba=require("zod"),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});`]}},Om=ba.z.object({seconds:ba.z.number().positive().describe("Number of seconds to wait")})});function Al(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Lm,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:s}=n;try{let r={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,r,s),{success:!0,actionEntity:r,message:"Download completed"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:r.message}}}}})}var ya,Tl,Lm,hi=w(()=>{"use strict";ya=require("zod"),Tl=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} } },`,"});"]}},Lm=ya.z.object({timeout_seconds:ya.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function Il(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:Dm,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:s,agentServices:r}=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(s,l,r),{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 jn,Ml,Dm,mi=w(()=>{"use strict";jn=require("zod"),Ml=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,s=5e3,r=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(St(),kt));for(;Date.now()-r<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(s)}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"]}},Dm=jn.z.object({condition:jn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:jn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});function Cl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Nm,async execute(i,n){let{name:o,value:a}=i,{page:s,agentServices:r}=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(s,l,r),{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 Kn,Pl,Nm,pi=w(()=>{"use strict";Kn=require("zod"),Pl=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)} } },`,"});"]}},Nm=Kn.z.object({name:Kn.z.string().describe("Variable name to save"),value:Kn.z.string().describe("Value to save in the variable")})});async function Rm(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Fm(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function $l(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:Hm,async execute(i,n){let{down:o,num_pages:a}=i,{page:s,agentServices:r,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(s,c,r),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Fm(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var zn,gi,Hm,fi=w(()=>{"use strict";zn=require("zod"),gi=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)})');`]}};Hm=zn.z.object({down:zn.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:zn.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Wm(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ol(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Dl(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Um,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:s}=i,{page:r,agentServices:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:Ol(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})};let c=await Wm("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,d,r,{delta_x:a,delta_y:s});return await t.execute(r,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${s}px`}}catch(d){return{success:!1,error:d.message,actionEntity:Ol(`Scroll on element ${o} horizontally: ${a}px, vertically: ${s}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:s})}}}})}var Tt,Ll,Um,wi=w(()=>{"use strict";J();G();Tt=require("zod");C();Ll=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,s=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(s)await s.hover({timeout:r}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=We(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: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Um=Tt.z.object({element_index:Tt.z.number().int().describe("Index of the scrollable element"),delta_x:Tt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Tt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Tt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Rl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Bm,async execute(i,n){let{text:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var xa,Nl,Bm,bi=w(()=>{"use strict";xa=require("zod"),Nl=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();`]}},Bm=xa.z.object({text:xa.z.string().describe("Text to scroll to on the page")})});async function Gm(e,t,i,n){return{...await H(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Fl(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 Wl(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:jm,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Fl(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await Gm(d,s,a,l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Fl(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var yi,Hl,jm,xi=w(()=>{"use strict";J();G();yi=require("zod");C();Hl=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=R(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{timeout:s});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},`),"});"]}};jm=yi.z.object({element_index:yi.z.number().int().describe("Index of the dropdown/select element"),option:yi.z.string().describe("Option value, label, or index to select"),timeout_ms:yi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Km(e,t,i,n){return{...await H(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function va(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 Bl(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:Om,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:s,agentServices:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:ya(`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:ya(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await Lm(`Set date to ${a} on element ${o}`,l,s,a);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ya(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var bi,Pl,Om,yi=w(()=>{"use strict";J();B();bi=require("zod");C();Pl=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)),s=R(e,t);if(s){let r=await s.getAttribute("type").catch(()=>null);if(r&&r!=="date")throw new Error(`Element is not a native date picker (type="${r}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await s.fill(a,{timeout:D(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},`),"});"]}};Om=bi.z.object({element_index:bi.z.number().int().describe("Index of the native date picker input element"),date:bi.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:bi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ll(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Dm,async execute(i,n){let o=i.tab_index,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var xa,$l,Dm,xi=w(()=>{"use strict";xa=require("zod"),$l=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(),s=o===-1?a.length-1:o;if(i){let r=await i.switchTab(s);await r.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await r.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} } },`,"});"]}},Dm=xa.z.object({tab_index:xa.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Nl(e,t,i,n,o,a){let s=Array.isArray(t)?t:[t];if(s.length===0)throw new Error("No file paths provided for upload");let r=s.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let h=n.testDataDir||process.cwd();return Dl.default.join(h,c)});u.info(`Uploading files: ${r.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 Kn(e,c,r,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,h=(c.startsWith("xpath="),e.locator(c));await Kn(e,h,r,d);return}if(o){let c=s.map(p=>`"${p}"`).join(", "),h="";i.targetDescription?h=`Upload ${c} to ${i.targetDescription}`:h=`Upload ${c}`,u.info(`Using AI to handle file upload: ${h}`),await o(e,h,a)}else throw new Error("No selector provided and AI action execution is not available")}async function Kn(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:s}=n;if(s){u.info("Using mockShowOpenFilePicker approach");let r=i.map(l=>({path:l,buffer:new Uint8Array(Ol.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},r),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)u.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{u.info("Using file chooser approach");let r=e.waitForEvent("filechooser",{timeout:a});r.catch(()=>{}),await t.click({timeout:a}),await(await r).setFiles(i),await e.waitForTimeout(3e3)}u.info(`Successfully uploaded ${i.length} file(s)`)}var Ol,Dl,vi=w(()=>{"use strict";G();Ol=W(require("fs"),1),Dl=W(require("path"),1)});async function Nm(e,t,i={},n){return{...await F(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Rl(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 Hl(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:Rm,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:Rl(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await Nm(d,s,{paths:a},l);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Rl(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var oe,Fl,Rm,Ny,_i=w(()=>{"use strict";vi();J();B();oe=require("zod");C();Fl=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)),s=R(e,t);if(!s)throw new Error("Missing locator for upload_file action");let r=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Kn(e,s,a,{useFileInput:r,timeout:D(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},`),"});"]}};Rm=oe.z.object({element_index:oe.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:oe.z.union([oe.z.string(),oe.z.array(oe.z.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Ny=oe.z.object({element_index:oe.z.number().int().describe("Index of the file input element"),paths:oe.z.union([oe.z.string(),oe.z.array(oe.z.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:oe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Wl(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:Fm,async execute(i,n){let{keys:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var va,_a,Fm,ki=w(()=>{"use strict";va=require("zod"),_a=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)});`]}},Fm=va.z.object({keys:va.z.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.")})});function Bl(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:Hm,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:`Reloaded ${o.url()}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:s.message}}}}})}var Ul,Gl,Hm,Si=w(()=>{"use strict";B();Ul=require("zod");C();Gl=class{async execute(e,t){await e.reload({timeout:Te}),await e.waitForLoadState("load",{timeout:Te}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Hm=Ul.z.object({})});async function Wm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Kl(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 jl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Um,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Kl(`Right-click element ${o}`,"right_click",{index:o})};let d=r||`Right-click element ${o}`,c=await Wm("right_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Kl(`Right-click element ${o}`,"right_click",{index:o})}}}})}var jn,ka,Um,Ei=w(()=>{"use strict";J();B();jn=require("zod");C();ka=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};Um=jn.z.object({element_index:jn.z.number().int().describe("Index of the element to right-click"),timeout_ms:jn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Vl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Gm,async execute(i,n){let{name:o,value:a}=i,{page:s,agentServices:r}=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(s,l,r),{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 zn,zl,Gm,Ti=w(()=>{"use strict";zn=require("zod"),zl=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)} } },`,"});"]}},Gm=zn.z.object({name:zn.z.string().describe("Variable name to save"),value:zn.z.string().describe("Value to save in the variable")})});function Yl(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:Bm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:r.message}}}}})}var Sa,Xl,Bm,Ai=w(()=>{"use strict";Sa=require("zod"),Xl=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)),s=await i.generate2faCode(a);i.saveVariable("otp_code",s)}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)} } },`,"});"]}},Bm=Sa.z.object({otp_secret_key:Sa.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function Km(e,t,i){return{...await F(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Jl(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 Zl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:jm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Jl(r||`Get options from dropdown ${o}`,{index:o})};let d=await Km(l,a,r);return await t.execute(a,d,s),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:Jl(r||`Get options from dropdown ${o}`,{index:o})}}}})}var Ea,ql,jm,Mi=w(()=>{"use strict";J();Ea=require("zod"),ql=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(s=>{let r=document.evaluate(s,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return r?{options:Array.from(r.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:r.id,name:r.name}:null},t.xpath);if(a){let s=[];for(let r of a.options){let l=JSON.stringify(r.text);s.push(`${r.index}: text=${l}`)}n.push(...s)}}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:zm,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:s,agentServices:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:va(`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:va(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await Km(`Set date to ${a} on element ${o}`,l,s,a);return await t.execute(s,c,r),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:va(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var vi,Ul,zm,_i=w(()=>{"use strict";J();G();vi=require("zod");C();Ul=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)),s=R(e,t);if(s){let r=await s.getAttribute("type").catch(()=>null);if(r&&r!=="date")throw new Error(`Element is not a native date picker (type="${r}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await s.fill(a,{timeout:D(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},`),"});"]}};zm=vi.z.object({element_index:vi.z.number().int().describe("Index of the native date picker input element"),date:vi.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:vi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function jl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Vm,async execute(i,n){let o=i.tab_index,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var _a,Gl,Vm,ki=w(()=>{"use strict";_a=require("zod"),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.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),s=o===-1?a.length-1:o;if(i){let r=await i.switchTab(s);await r.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await r.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} } },`,"});"]}},Vm=_a.z.object({tab_index:_a.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Xm(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Kl(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 zl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Ym,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Kl(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,h=await Xm("input_text",c,d,s,{text:a});return await t.execute(s,h,r),{success:!0,actionEntity:h,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Kl(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Si,ka,Ym,Ei=w(()=>{"use strict";J();G();Si=require("zod");C();ka=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)),s=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(s){await s.evaluate(d=>{d.value&&(d.value="")},null,{timeout:r}),await s.click({timeout:r}),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},`),"});"]}};Ym=Si.z.object({element_index:Si.z.number().int().describe("Index of the input element"),text:Si.z.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:Si.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Vl(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:Jm,async execute(i,n){let{keys:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var Sa,Ea,Jm,Ti=w(()=>{"use strict";Sa=require("zod"),Ea=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)});`]}},Jm=Sa.z.object({keys:Sa.z.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.")})});function Jl(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:qm,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:`Reloaded ${o.url()}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:s.message}}}}})}var Xl,Yl,qm,Ai=w(()=>{"use strict";G();Xl=require("zod");C();Yl=class{async execute(e,t){await e.reload({timeout:Me}),await e.waitForLoadState("load",{timeout:Me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},qm=Xl.z.object({})});async function Zm(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ql(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 Zl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Qm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ql(`Right-click element ${o}`,"right_click",{index:o})};let d=r||`Right-click element ${o}`,c=await Zm("right_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ql(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Vn,Ta,Qm,Mi=w(()=>{"use strict";J();G();Vn=require("zod");C();Ta=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};Qm=Vn.z.object({element_index:Vn.z.number().int().describe("Index of the element to right-click"),timeout_ms:Vn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ec(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:ep,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:r.message}}}}})}var Aa,Ql,ep,Ii=w(()=>{"use strict";Aa=require("zod"),Ql=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)),s=await i.generate2faCode(a);i.saveVariable("otp_code",s)}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)} } },`,"});"]}},ep=Aa.z.object({otp_secret_key:Aa.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function tp(e,t,i){return{...await H(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function tc(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 nc(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:ip,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:tc(r||`Get options from dropdown ${o}`,{index:o})};let d=await tp(l,a,r);return await t.execute(a,d,s),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:tc(r||`Get options from dropdown ${o}`,{index:o})}}}})}var Ma,ic,ip,Pi=w(()=>{"use strict";J();Ma=require("zod"),ic=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(s=>{let r=document.evaluate(s,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return r?{options:Array.from(r.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:r.id,name:r.name}:null},t.xpath);if(a){let s=[];for(let r of a.options){let l=JSON.stringify(r.text);s.push(`${r.index}: text=${l}`)}n.push(...s)}}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},`),"});"]}};jm=Ea.z.object({element_index:Ea.z.number().int().describe("Index of the dropdown/select element")})});function tc(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:zm,async execute(i,n){let{page:o,agentServices:a,actionDescription:s}=n;try{let r={action_description:s||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Navigated back"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:(s||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:r.message}}}}})}var Ql,ec,zm,Ii=w(()=>{"use strict";B();Ql=require("zod");C();ec=class{async execute(e,t){await e.goBack({timeout:Te}),await e.waitForLoadState("load",{timeout:Te}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},zm=Ql.z.object({})});function ic(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:Vm,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:s}=i,{page:r,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};s!==void 0&&(c.timeout_seconds=s);let h=s?` (timeout: ${s}s)`:"";try{let p=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(r,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+h}}catch(p){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var Pi,Ta,Vm,Ci=w(()=>{"use strict";B();Pi=require("zod");C();Ta=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,s=i.replaceVariables(String(o));if(s.startsWith("/")){let d=e.url(),c=null;try{let h=new URL(d);h.origin&&h.origin!=="null"&&(c=h.origin)}catch{}c&&(s=c+s)}let r=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:Te,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(s,{timeout:r})}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(", ")} } },`,"});"]}},Vm=Pi.z.object({url:Pi.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Pi.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Pi.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function Xm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function nc(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 oc(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Ym,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:nc(`Hover element ${o}`,"hover",{index:o})};let d=r||`Hover over element ${o}`,c=await Xm("hover",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:nc(`Hover element ${o}`,"hover",{index:o})}}}})}var Vn,Aa,Ym,$i=w(()=>{"use strict";J();B();Vn=require("zod");C();Aa=class{async execute(e,t,i){let n=R(e,t),o=D(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 s=await a.boundingBox();if(!s)throw new Error("Unable to determine bounding box for hover action");let r=s.x+s.width/2,l=s.y+s.height/2;await e.mouse.move(r,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},`),"});"]}};Ym=Vn.z.object({element_index:Vn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Vn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Jm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ac(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 rc(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:qm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:s,agentServices:r,actionDescription:l}=n;try{let d=await z(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:ac(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,h=await Jm("input_text",c,d,s,{text:a});return await t.execute(s,h,r),{success:!0,actionEntity:h,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:ac(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var Li,Ma,qm,Oi=w(()=>{"use strict";J();B();Li=require("zod");C();Ma=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)),s=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(s){await s.evaluate(d=>{d.value&&(d.value="")},null,{timeout:r}),await s.click({timeout:r}),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},`),"});"]}};qm=Li.z.object({element_index:Li.z.number().int().describe("Index of the input element"),text:Li.z.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:Li.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Zm(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function sc(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 cc(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Qm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:sc(r||`Clear element ${o}`,"clear_input",{index:o})};let d=r||`Clear element ${o}`,c=await Zm("clear_input",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:sc(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Xn,lc,Qm,Di=w(()=>{"use strict";J();B();Xn=require("zod");C();lc=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};Qm=Xn.z.object({element_index:Xn.z.number().int().describe("Index of the input element to clear"),timeout_ms:Xn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function ep(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function dc(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 uc(e,t){e.register({name:"click",description:"Click an interactive element.",schema:tp,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:dc(`Click element ${o}`,"click",{index:o})};let d=r||`Click element ${o}`,c=await ep("click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:dc(`Click element ${o}`,"click",{index:o})}}}})}var Yn,Jn,tp,Ni=w(()=>{"use strict";J();B();Yn=require("zod");C();Jn=class{async execute(e,t,i){let n=R(e,t),o=D(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=We(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};tp=Yn.z.object({element_index:Yn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Yn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function mc(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:ip,async execute(i,n){let{index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Ia,hc,ip,Ri=w(()=>{"use strict";Ia=require("zod"),hc=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} } },`,"});"]}},ip=Ia.z.object({index:Ia.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function gc(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:np,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Task marked as complete"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:s.message}}}}})}var qn,pc,np,Fi=w(()=>{"use strict";qn=require("zod"),pc=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},np=qn.z.object({success:qn.z.boolean().describe("Whether the task was completed successfully"),summary:qn.z.string().describe("Summary of what was accomplished or why it failed")})});async function op(e,t,i,n,o={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function fc(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 wc(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:ap,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:fc(`Double-click element ${o}`,"double_click",{index:o})};let d=r||`Double-click element ${o}`,c=await op("double_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:fc(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Zn,Pa,ap,Hi=w(()=>{"use strict";J();B();Zn=require("zod");C();Pa=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};ap=Zn.z.object({element_index:Zn.z.number().int().describe("Index of the element to double-click"),timeout_ms:Zn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function yc(e){if(!e.trim())return!1;try{return(0,bc.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var bc,Qn=w(()=>{"use strict";bc=require("@babel/parser")});function xc(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:rp,async execute(i,n){let{statement:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:`Assertion verified: ${o}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:r.message}}}},availability:{openai:!0,mcp:!0}})}var Ca,eo,rp,Wi=w(()=>{"use strict";ri();Qn();G();Ca=require("zod"),eo=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),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(h){let p=((Date.now()-c)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),u.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 s=Date.now();u.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:r}=await Promise.resolve().then(()=>(kt(),_t)),l=await r(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-s)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-s)/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},`),"});"]}};ip=Ma.z.object({element_index:Ma.z.number().int().describe("Index of the dropdown/select element")})});function rc(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:np,async execute(i,n){let{page:o,agentServices:a,actionDescription:s}=n;try{let r={action_description:s||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:"Navigated back"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:(s||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:r.message}}}}})}var oc,ac,np,Ci=w(()=>{"use strict";G();oc=require("zod");C();ac=class{async execute(e,t){await e.goBack({timeout:Me}),await e.waitForLoadState("load",{timeout:Me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},np=oc.z.object({})});function sc(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:op,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:s}=i,{page:r,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};s!==void 0&&(c.timeout_seconds=s);let h=s?` (timeout: ${s}s)`:"";try{let p=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(r,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+h}}catch(p){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var $i,Ia,op,Oi=w(()=>{"use strict";G();$i=require("zod");C();Ia=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,s=i.replaceVariables(String(o));if(s.startsWith("/")){let d=e.url(),c=null;try{let h=new URL(d);h.origin&&h.origin!=="null"&&(c=h.origin)}catch{}c&&(s=c+s)}let r=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:Me,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(s,{timeout:r})}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(", ")} } },`,"});"]}},op=$i.z.object({url:$i.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:$i.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:$i.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function ap(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function lc(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 cc(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:rp,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:lc(`Hover element ${o}`,"hover",{index:o})};let d=r||`Hover over element ${o}`,c=await ap("hover",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:lc(`Hover element ${o}`,"hover",{index:o})}}}})}var Xn,Pa,rp,Li=w(()=>{"use strict";J();G();Xn=require("zod");C();Pa=class{async execute(e,t,i){let n=R(e,t),o=D(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 s=await a.boundingBox();if(!s)throw new Error("Unable to determine bounding box for hover action");let r=s.x+s.width/2,l=s.y+s.height/2;await e.mouse.move(r,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},`),"});"]}};rp=Xn.z.object({element_index:Xn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Xn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function uc(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:sp,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:s,agentServices:r}=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(s,l,r),{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 Yn,dc,sp,Di=w(()=>{"use strict";Yn=require("zod"),dc=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 s=`Extract ${o} and save to ${a}`,{executeStep:r}=await Promise.resolve().then(()=>(St(),kt)),l=await r(s,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||""}');`]}},sp=Yn.z.object({element_description:Yn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Yn.z.string().describe("Name of the variable to store the extracted value")})});async function lp(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function hc(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 pc(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:cp,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:hc(r||`Clear element ${o}`,"clear_input",{index:o})};let d=r||`Clear element ${o}`,c=await lp("clear_input",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:hc(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Jn,mc,cp,Ni=w(()=>{"use strict";J();G();Jn=require("zod");C();mc=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};cp=Jn.z.object({element_index:Jn.z.number().int().describe("Index of the input element to clear"),timeout_ms:Jn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function dp(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function gc(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 fc(e,t){e.register({name:"click",description:"Click an interactive element.",schema:up,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:gc(`Click element ${o}`,"click",{index:o})};let d=r||`Click element ${o}`,c=await dp("click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:gc(`Click element ${o}`,"click",{index:o})}}}})}var qn,Zn,up,Ri=w(()=>{"use strict";J();G();qn=require("zod");C();Zn=class{async execute(e,t,i){let n=R(e,t),o=D(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=We(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};up=qn.z.object({element_index:qn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:qn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function bc(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:hp,async execute(i,n){let{index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l={action_description:r||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,s),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var Ca,wc,hp,Fi=w(()=>{"use strict";Ca=require("zod"),wc=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} } },`,"});"]}},hp=Ca.z.object({index:Ca.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function xc(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:mp,async execute(i,n){let{page:o,agentServices:a}=n;try{let s={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Task marked as complete"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:s.message}}}}})}var Qn,yc,mp,Hi=w(()=>{"use strict";Qn=require("zod"),yc=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},mp=Qn.z.object({success:Qn.z.boolean().describe("Whether the task was completed successfully"),summary:Qn.z.string().describe("Summary of what was accomplished or why it failed")})});async function pp(e,t,i,n,o={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function vc(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 _c(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:gp,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:s,actionDescription:r}=n;try{let l=await z(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:vc(`Double-click element ${o}`,"double_click",{index:o})};let d=r||`Double-click element ${o}`,c=await pp("double_click",d,l,a);return await t.execute(a,c,s),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:vc(`Double-click element ${o}`,"double_click",{index:o})}}}})}var eo,$a,gp,Wi=w(()=>{"use strict";J();G();eo=require("zod");C();$a=class{async execute(e,t,i){let n=R(e,t),o=D(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},`),"});"]}};gp=eo.z.object({element_index:eo.z.number().int().describe("Index of the element to double-click"),timeout_ms:eo.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Sc(e){if(!e.trim())return!1;try{return(0,kc.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var kc,to=w(()=>{"use strict";kc=require("@babel/parser")});function Ec(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:fp,async execute(i,n){let{statement:o}=i,{page:a,agentServices:s}=n;try{let r={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,r,s),{success:!0,actionEntity:r,message:`Assertion verified: ${o}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:r.message}}}},availability:{openai:!0,mcp:!0}})}var Oa,io,fp,Ui=w(()=>{"use strict";ri();to();B();Oa=require("zod"),io=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),u.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(h){let p=((Date.now()-c)/1e3).toFixed(1);u.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${h instanceof Error?h.message:String(h)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),u.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 s=Date.now();u.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:r}=await Promise.resolve().then(()=>(St(),kt)),l=await r(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw u.info(`[VERIFY:AI] \u2717 ${((Date.now()-s)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");u.info(`[VERIFY:AI] \u2713 ${((Date.now()-s)/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
- `)(e,xt.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 s=i.code;if(!yc(s))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(s)});`];if(o){let r=s.split(`
4111
+ `)(e,vt.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 s=i.code;if(!Sc(s))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(s)});`];if(o){let r=s.split(`
4112
4112
  `),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...r.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 s.split(`
4113
- `)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},rp=Ca.z.object({statement:Ca.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function _c(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:sp,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:s,agentServices:r}=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(s,l,r),{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 to,vc,sp,Ui=w(()=>{"use strict";to=require("zod"),vc=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 s=`Extract ${o} and save to ${a}`,{executeStep:r}=await Promise.resolve().then(()=>(kt(),_t)),l=await r(s,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||""}');`]}},sp=to.z.object({element_description:to.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:to.z.string().describe("Name of the variable to store the extracted value")})});var lp,cp,Gi,io=w(()=>{"use strict";lp=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],cp=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Gi=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:lp.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:!cp.includes(t)}}});var $a,La,no,Oa=w(()=>{"use strict";In();Pn();Cn();$n();Ln();On();Dn();Fn();Hn();Wn();Un();ci();di();ui();mi();pi();gi();wi();yi();xi();_i();ki();Si();Ei();Ti();Ai();Mi();Ii();Ci();$i();Oi();Di();Ni();Ri();Fi();Hi();Wi();Ui();io();B();Ee();$a=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 Ta),M.registerAction("go_back",new ec),M.registerAction("reload_page",new Gl),M.registerAction("close_tab",new hc),M.registerAction("switch_tab",new $l),M.registerAction("click",new Jn),M.registerAction("hover",new Aa),M.registerAction("right_click",new ka),M.registerAction("double_click",new Pa),M.registerAction("click_by_coordinates",new hl),M.registerAction("right_click_by_coordinates",new sl),M.registerAction("double_click_by_coordinates",new ml),M.registerAction("drag_drop",new ll),M.registerAction("input_text",new Ma),M.registerAction("clear_input",new lc),M.registerAction("press",new _a),M.registerAction("send_keys_on_element",new nl),M.registerAction("scroll_on_element",new kl),M.registerAction("scroll_to_text",new El),M.registerAction("scroll",new hi),M.registerAction("upload_file",new Fl),M.registerAction("wait_for_download_complete",new wl),M.registerAction("get_dropdown_options",new ql),M.registerAction("select_dropdown_option",new Ml),M.registerAction("set_date_for_native_date_picker",new Pl),M.registerAction("verify",new eo),M.registerAction("ai_action",new pl),M.registerAction("ai_extract",new vc),M.registerAction("ai_step",new ul),M.registerAction("ai_wait_until",new yl),M.registerAction("generate_2fa_code",new Xl),M.registerAction("wait",new gl),M.registerAction("wait_for_page_ready",new il),M.registerAction("save_variable",new zl),M.registerAction("js_code",new rl),M.registerAction("js_action",new ol),M.registerAction("function",new cl),M.registerAction("done",new pc),M.registerAction("click_element",new Jn),M.registerAction("click_element_by_index",new Jn),M.registerAction("hover_element_by_index",new Aa),M.registerAction("right_click_on_element",new ka),M.registerAction("double_click_on_element",new Pa),M.registerAction("scroll_down",new hi),M.registerAction("scroll_up",new hi),M.registerAction("scroll_element",new hi),M.registerAction("send_keys",new _a),M.registerAction("open_tab",new Ta),M.registerAction("fill",new Ma),M.registerAction("ai_assert",new eo),M.registerAction("assert",new eo)}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(),ta(dn)),a=t.action_description||"",s=t.action_data?.action_name||"",r=this.getAction(s);if(!r)return[`// ${i}: Unknown action: ${s}`];let l=r.transpile(t,i);if(Gi.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),h=Gi.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:s}=(C(),ta(dn));if(!t)return[`// ${i}: Skipping - no description`];let r=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${r}, '${i}'${l});`]}return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${r}, '${i}', ${n});`]}};$a.actions=new Map,$a.initialized=!1;La=$a,no=La});var Tt={};Ye(Tt,{ActionHandler:()=>La,default:()=>no});var At=w(()=>{"use strict";Oa();In();Pn();Cn();$n();Ln();On();Dn();Fn();Hn();Wn();Un();ci();di();ui();mi();pi();gi();wi();yi();xi();_i();ki();Si();Ei();Ti();Ai();Mi();Ii();Ci();$i();Oi();Di();Ni();Ri();Fi();Hi();Wi();ri();Ui();Qn();vi();J();Je();G();se();vt();io();B();Ee()});function oo(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"]}},fp=Oa.z.object({statement:Oa.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});var wp,bp,Bi,no=w(()=>{"use strict";wp=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],bp=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Bi=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:wp.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:!bp.includes(t)}}});var La,Da,oo,Na=w(()=>{"use strict";Pn();Cn();$n();On();Ln();Dn();Nn();Rn();Wn();Un();Bn();di();ui();hi();mi();pi();fi();wi();bi();xi();_i();ki();Ei();Ti();Ai();Mi();Ii();Pi();Ci();Oi();Li();Di();Ni();Ri();Fi();Hi();Wi();Ui();no();G();Ae();La=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 Ia),M.registerAction("go_back",new ac),M.registerAction("reload_page",new Yl),M.registerAction("close_tab",new wc),M.registerAction("switch_tab",new Gl),M.registerAction("click",new Zn),M.registerAction("hover",new Pa),M.registerAction("right_click",new Ta),M.registerAction("double_click",new $a),M.registerAction("click_by_coordinates",new fl),M.registerAction("right_click_by_coordinates",new dl),M.registerAction("double_click_by_coordinates",new ul),M.registerAction("drag_drop",new hl),M.registerAction("input_text",new ka),M.registerAction("clear_input",new mc),M.registerAction("press",new Ea),M.registerAction("send_keys_on_element",new rl),M.registerAction("scroll_on_element",new Ll),M.registerAction("scroll_to_text",new Nl),M.registerAction("scroll",new gi),M.registerAction("upload_file",new _l),M.registerAction("wait_for_download_complete",new Tl),M.registerAction("get_dropdown_options",new ic),M.registerAction("select_dropdown_option",new Hl),M.registerAction("set_date_for_native_date_picker",new Ul),M.registerAction("verify",new io),M.registerAction("ai_action",new wl),M.registerAction("ai_extract",new dc),M.registerAction("ai_step",new gl),M.registerAction("ai_wait_until",new Ml),M.registerAction("generate_2fa_code",new Ql),M.registerAction("wait",new Sl),M.registerAction("wait_for_page_ready",new al),M.registerAction("save_variable",new Pl),M.registerAction("js_code",new cl),M.registerAction("js_action",new sl),M.registerAction("function",new ml),M.registerAction("done",new yc),M.registerAction("click_element",new Zn),M.registerAction("click_element_by_index",new Zn),M.registerAction("hover_element_by_index",new Pa),M.registerAction("right_click_on_element",new Ta),M.registerAction("double_click_on_element",new $a),M.registerAction("scroll_down",new gi),M.registerAction("scroll_up",new gi),M.registerAction("scroll_element",new gi),M.registerAction("send_keys",new Ea),M.registerAction("open_tab",new Ia),M.registerAction("fill",new ka),M.registerAction("ai_assert",new io),M.registerAction("assert",new io)}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(),na(hn)),a=t.action_description||"",s=t.action_data?.action_name||"",r=this.getAction(s);if(!r)return[`// ${i}: Unknown action: ${s}`];let l=r.transpile(t,i);if(Bi.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),h=Bi.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${h});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:s}=(C(),na(hn));if(!t)return[`// ${i}: Skipping - no description`];let r=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${r}, '${i}'${l});`]}return[`// ${i}: ${s(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${r}, '${i}', ${n});`]}};La.actions=new Map,La.initialized=!1;Da=La,oo=Da});var At={};Je(At,{ActionHandler:()=>Da,default:()=>oo});var Mt=w(()=>{"use strict";Na();Pn();Cn();$n();On();Ln();Dn();Nn();Rn();Wn();Un();Bn();di();ui();hi();mi();pi();fi();wi();bi();xi();_i();ki();Ei();Ti();Ai();Mi();Ii();Pi();Ci();Oi();Li();Di();Ni();Ri();Fi();Hi();Wi();Ui();ri();to();ci();J();qe();B();se();_t();no();G();Ae()});function ao(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,h)=>{let p=c.action_description||"Unknown action";d+=`
4115
4115
  \u2192 Action ${h+1}: ${p}`});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+=`
@@ -4130,7 +4130,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
4130
4130
  **Current URL**: ${i}
4131
4131
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4132
4132
 
4133
- ${a()}${s()}${o()}${n()}${r()}`.trim()}function kc(){return`
4133
+ ${a()}${s()}${o()}${n()}${r()}`.trim()}function Tc(){return`
4134
4134
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4135
4135
 
4136
4136
  This is your last step. You MUST use the "done" action now.
@@ -4139,8 +4139,8 @@ This is your last step. You MUST use the "done" action now.
4139
4139
  - If the task is incomplete or partially complete, set success=false
4140
4140
  - Include everything you've accomplished in the done action's text field
4141
4141
  - No other actions are allowed on this step
4142
- `.trim()}function dp(){let e=j.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof Mt.z.ZodObject){let o=i.schema.shape,a=[];Object.keys(o).forEach(s=>{let r=o[s],l="any";r instanceof Mt.z.ZodNumber?l="number":r instanceof Mt.z.ZodString?l="string":r instanceof Mt.z.ZodBoolean?l="boolean":r instanceof Mt.z.ZodEnum&&(l=r._def.values.map(d=>`"${d}"`).join(" | ")),a.push(`${s}: ${l}`)}),n=`{${a.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4143
- `)}function ao(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:o=!0,useMultiAction:a=!0}=t,s=o?`
4142
+ `.trim()}function yp(){let e=K.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof It.z.ZodObject){let o=i.schema.shape,a=[];Object.keys(o).forEach(s=>{let r=o[s],l="any";r instanceof It.z.ZodNumber?l="number":r instanceof It.z.ZodString?l="string":r instanceof It.z.ZodBoolean?l="boolean":r instanceof It.z.ZodEnum&&(l=r._def.values.map(d=>`"${d}"`).join(" | ")),a.push(`${s}: ${l}`)}),n=`{${a.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4143
+ `)}function ro(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:o=!0,useMultiAction:a=!0}=t,s=o?`
4144
4144
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4145
4145
  - "success: <reason>" if the goal was fully achieved
4146
4146
  - "partial: <reason>" if the goal was partially achieved but needs more work
@@ -4247,7 +4247,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4247
4247
 
4248
4248
  When stuck, call \`done\` with success=false and explain what happened.
4249
4249
 
4250
- ${dp()}
4250
+ ${yp()}
4251
4251
  ## Reasoning Rules
4252
4252
 
4253
4253
  Use the \`thinking\` field to reason about each step:
@@ -4283,7 +4283,7 @@ ${p}
4283
4283
  **Current Goal Examples:**
4284
4284
  - "Add the product to the cart"
4285
4285
  - "Find more product listings and extract details from the next 5 items on the page"
4286
- ${g}`.trim()}var Mt,ro=w(()=>{"use strict";De();Mt=require("zod")});var so,Da=w(()=>{"use strict";ro();le();so=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,o,a={}){let{executionHistory:s,placeholderData:r,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=a,h=[],p=oo(o,e,t);if(h.push({type:"text",text:p}),h.push({type:"text",text:`## CURRENT PAGE STATE
4286
+ ${g}`.trim()}var It,so=w(()=>{"use strict";De();It=require("zod")});var lo,Ra=w(()=>{"use strict";so();le();lo=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,o,a={}){let{executionHistory:s,placeholderData:r,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=a,h=[],p=ao(o,e,t);if(h.push({type:"text",text:p}),h.push({type:"text",text:`## CURRENT PAGE STATE
4287
4287
 
4288
4288
  **Interactive Elements**:
4289
4289
  ${i}`}),s&&Array.isArray(s)&&s.length>0){let g=s.map(([y,_],x)=>`${x+1}. ${y} \u2192 ${_}`);h.push({type:"text",text:`## EXECUTION HISTORY (from test)
@@ -4299,7 +4299,7 @@ ${g.join(`
4299
4299
  `,n+=`- Use the EXACT placeholder name as shown above
4300
4300
  `,n+=`- Do NOT use the actual value directly in the action
4301
4301
  `,n+=`- The values shown are for context only to help you understand what data is available
4302
- `,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var Ge,It=w(()=>{"use strict";Ge=`
4302
+ `,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var Ge,Pt=w(()=>{"use strict";Ge=`
4303
4303
  // check to make sure we're not inside the PDF viewer
4304
4304
  window.isPdfViewer = !!document?.body?.querySelector('body > embed[type="application/pdf"][width="100%"]')
4305
4305
  if (!window.isPdfViewer) {
@@ -4354,9 +4354,9 @@ if (!window.isPdfViewer) {
4354
4354
  };
4355
4355
  })();
4356
4356
  }
4357
- `});function Sc(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 Ec(e,t){let i=await e.newContext(t);return i.addInitScript(Ge),i}async function lo(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Tc(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 Ac(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function gp(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"]),s=["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"],r=h=>{let p=h.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:s.some(g=>p.includes(g))},l=h=>{let p=h.resourceType(),g=h.url();if(!o.has(p)||r(g))return;let y=h.headers();y.purpose==="prefetch"||["video","audio"].includes(y["sec-fetch-dest"])||(i.add(h),n=Date.now())},d=async h=>{let p=h.request();if(!i.has(p))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(_=>g.includes(_))){i.delete(p);return}if(![...a].some(_=>g.startsWith(_))){i.delete(p);return}let y=h.headers()["content-length"];if(y)try{if(parseInt(y,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-pp;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),y=h.timing();o.has(p)&&!r(g)&&y.responseEnd===-1&&y.startTime>=c&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let h=Date.now(),p=mp;for(;;){await new Promise(y=>setTimeout(y,100));let g=Date.now();if(i.size===0&&g-n>=p){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ne(e,t=hp,i=up){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),gp(e,t)])}catch(s){throw s instanceof Error?new Error(`Failed during network stabilization: ${s.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(s=>setTimeout(s,a))}var co,up,hp,mp,pp,Re=w(()=>{"use strict";It();G();co=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,s)=>setTimeout(()=>s(new Error("CDP detach timeout")),1e3))])}catch{}},up=.5*1e3,hp=30*1e3,mp=1*1e3,pp=3*1e3});function fp(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 Pc(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,s=t.agentServices.getModel(),r=t.domService||new _e(t.agentServices.getDomServiceOptions()),l={...t,domService:r};b.init(),b.section("Task Execution Started"),b.log(`Task: ${e}`),b.log(`Max steps: ${o}`),b.log(`Model: ${s}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],h=ao(i.customPrompt),p=new so(h);b.log(`System prompt length: ${h.length} chars`);let g=!1,y="",_=[];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 Ne(l.page),b.log("Page stabilized")}catch{b.log("Page stabilization timed out, continuing anyway")}let m;try{b.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();m=await Mc(l.page,l.domService,I,$),b.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){b.log("Page navigating, waiting for load..."),await Ne(l.page);let $=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();m=await Mc(l.page,l.domService,$,P)}else throw b.error("Error preparing context",I),I}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await bp(p,s,i,m.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){y="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;_p(d.currentStep,o,S);let v=await xp(S,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,f.debugInfo);_.push(...v.actionEntities);let k=vp(d.currentStep,S,v,d,x,f.debugInfo,f.tokenUsages),A=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=a){b.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),y=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,y=v.doneResult.summary;break}if(v.completesInstruction){g=!0,y="Instruction completed";break}}return d.currentStep>=o&&!g&&(y="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),b.log(`Build success result: summary=${y}, completed=${g}, actions=${_.length}, tokens=${c.length}`),kp(d,_,g,y,n,c,s)}catch(x){let m=x.message;return b.error(`Task execution failed: ${m}`,x),i.onEvent?.({type:"error",error:m,recoverable:!1}),Sp(d,m,n,c,s)}}async function Mc(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),s=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:s,screenshotBase64:a,domState:o}}function wp(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 bp(e,t,i,n){let o=i.temperature??0,{system:a,messages:s}=e.getMessages(),r=0;for(let h of s)Array.isArray(h.content)&&(r+=h.content.filter(p=>p.type==="image").length);let l=Ie(t,r),d={model:Me(t),system:a,messages:s,temperature:o,providerOptions:l},c=3;for(let h=0;h<c;h++)try{let p=Date.now();b.log(`Calling LLM (${t})...`);let g=await(0,Ic.generateText)(d),y=Date.now()-p,_=g,x=_.usage;b.llmCall(t,y,x);let m=_.reasoningText;m&&(b.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:wp(s),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},S=[],v=fp(x,t);v&&S.push(v);let k=yp(g.text);if(!k)if(h<c-1){b.log(`Attempt ${h+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(A=>setTimeout(A,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(p){if(h<c-1){b.log(`Attempt ${h+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw b.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function yp(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 xp(e,t,i,n,o,a,s){let r=[],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,h={...t,domState:i},p=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 y={},_=g.kwargs?.element_index??g.kwargs?.index;if(typeof _=="number"){let m=i.selectorMap.get(_);m&&(y=await F(t.page,m))}let x={...y,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await j.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(x=m.actionEntity);let f=await h.agentServices.getCurrentPage();if(f&&(h.page=f,t.page=h.page),m?.success===!1){l=!1,b.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}r.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:s})}catch(m){l=!1,d=m.message,b.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:r,doneResult:c,completesInstruction:e.completes_instruction??!1}}function vp(e,t,i,n,o,a,s){let r={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:s};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(r),r}function _p(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 kp(e,t,i,n,o,a,s){let r=a.reduce((c,h)=>c+h.prompt_tokens,0),l=a.reduce((c,h)=>c+h.completion_tokens,0),d=a.reduce((c,h)=>c+h.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:s,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:r,completionTokens:l,totalTokens:d,tokenUsages:a}}}function Sp(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),s=n.reduce((l,d)=>l+d.completion_tokens,0),r=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:s,totalTokens:r,tokenUsages:n}}}var Ic,Cc=w(()=>{"use strict";Da();ro();De();Ze();le();Re();Oe();J();Ic=require("ai")});var $c={};Ye($c,{TaskMessageManager:()=>so,formatFinalStepWarning:()=>kc,formatTaskContext:()=>oo,getBrowserTaskJSONPrompt:()=>ao,runTaskLoop:()=>Pc});var Lc=w(()=>{"use strict";Cc();Da();ro();De();Rn();Ze();ei();ii();yt();ni();oi();le();Re();It();Oe();Vt();ut();Xt();Ue();dt();J();Je();G();se();vt();B();Ee()});async function si(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(j.has(i)){let o=await j.execute(i,n,t),a=o?.success!==!1,s=o?.error||o?.message;return{success:a,error:a?void 0:s}}else{let{page:o,agentServices:a}=t;return await(await Ep()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Ep(){if(uo)return uo;let e=await Promise.resolve().then(()=>(At(),Tt));return uo=new e.default,uo}async function St(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new _e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await da(s,a,n);return r.status==="error"?{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error,debugInfo:r.debugInfo}:{status:"success",completed:r.goalAccomplished||!1,actionEntities:r.actionEntity?[r.actionEntity]:[],explanation:r.reasoning,debugInfo:r.debugInfo}}async function Qe(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new _e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await da(s,a,n);if(r.status==="error"||!r.actionEntity)return{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error||"No action generated",debugInfo:r.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:h}=r,p=await si(l,a);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function et(e,t,i,n={}){let o={page:t,agentServices:i,domService:new _e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Ks(a,o,n)}async function tt(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(Lc(),$c)),s=n?l=>{n(l)}:void 0,r=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:s,abortSignal:o.abortSignal});return{status:r.success?"success":"error",completed:r.completed,actionEntities:r.trajectory.actions,explanation:r.summary,error:r.error,tokenUsages:r.metadata.tokenUsages}}var uo,li=w(()=>{"use strict";En();De();Ze();uo=null});function Oc(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:Tp,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await mt(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:s}=a,r=await si(s,o);return{success:r.success,actionEntity:s,message:r.success?`Successfully executed action: ${s.action_data?.action_name}`:void 0,error:r.error}}})}var Na,Tp,Ra=w(()=>{"use strict";li();pt();Na=require("zod"),Tp=Na.z.object({instruction:Na.z.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!""')})});async function Ap(e,t,i){let{apiKey:n,domain:o}=e;if(!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=!!e.baseURL,s=e.baseURL||"https://api.mailgun.net",r=e.authHeader||`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,l=[];try{let d=a?`${s}/events`:`${s}/v3/${o}/events`,c={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(c.from=i.from_email),i.since)c.begin=Math.floor(i.since/1e3).toString();else{let g=new Date(Date.now()-6e5);c.begin=Math.floor(g.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(c)}`);let h=await fetch(d+"?"+new URLSearchParams(c),{method:"GET",headers:{Authorization:r}});if(!h.ok){let g=await h.text();throw new Error(`Mailgun events API error: ${g}`)}let p=(await h.json()).items||[];for(let g of p.slice(0,10)){if(g.event!=="accepted")continue;let y=(g.storage||{}).url;if(u.info(`message_url: ${y}`),!y){let m=(g.message||{}).headers||{},f=m.subject||"",S=m.from||"",v=m.to||"";if(i.from_email&&!S.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!v.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!f.toLowerCase().includes(i.subject.toLowerCase()))continue;l.push({subject:f,from:S,to:v,date:new Date(g.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:m["message-id"]||""});continue}let _=y.split("/"),x=_[_.length-1];if(u.info(`Storage key: ${x}`),x){let m=a?`${s}/messages/${x}`:`${s}/v3/domains/${o}/messages/${x}`;try{let f=await fetch(m,{method:"GET",headers:{Authorization:r,Accept:"application/json"}});if(f.ok){let S=await f.json(),v=S.Subject||"",k=S.From||"",A=S.To||"",I=S.Date||"",$=S["Message-Id"]||"";u.info(`subject: ${v}`),u.info(`from_addr: ${k}`),u.info(`to_addr: ${A}`),u.info(`date: ${I}`),u.info(`message_id: ${$}`);let P=S["body-html"]||S["body-plain"]||"";if(P&&P.includes("<")&&(P=(0,Nc.convert)(P)),u.info(`Body: ${P.substring(0,200)}...`),i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!P.toLowerCase().includes(i.body_contains.toLowerCase()))continue;l.push({subject:v,from:k,to:A,date:I,body:P,message_id:$});continue}else u.warn(`Messages API returned ${f.status}`)}catch(f){u.warn(`Failed to parse JSON response: ${f}`)}}try{let m=await fetch(y,{method:"GET",headers:{Authorization:r}});if(!m.ok){u.warn(`Could not fetch stored message: ${m.status}`);continue}let f=await m.text();u.info(`Fallback: Raw email length: ${f.length}`);let S=f.split(`
4358
- `),v=!0,k={},A="";for(let Z=0;Z<S.length;Z++){let U=S[Z];if(U.trim()===""&&v){v=!1;continue}if(v){let O=U.match(/^([^:]+):\s*(.+)$/);O&&(k[O[1].toLowerCase()]=O[2])}else A+=U+`
4359
- `}let I=k.subject||"",$=k.from||"",P=k.to||"",H=k.date||"",V=k["message-id"]||"";if(i.subject&&!I.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;l.push({subject:I,from:$,to:P,date:H,body:A.trim(),message_id:V})}catch(m){u.warn(`Error fetching raw message: ${m}`)}}if(l.length>0){try{l.sort((y,_)=>{let x=new Date(y.date).getTime();return new Date(_.date).getTime()-x})}catch{}let g=l[0];return u.info(`Returning most recent email: ${g.subject}`),[g]}return l}catch(d){throw u.error(`Error fetching emails from Mailgun: ${d.message}`),new Error(`Error fetching emails from Mailgun: ${d.message}`)}}function Mp(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4357
+ `});function Ac(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 Mc(e,t){let i=await e.newContext(t);return i.addInitScript(Ge),i}async function co(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Ic(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 Pc(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function Sp(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"]),s=["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"],r=h=>{let p=h.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:s.some(g=>p.includes(g))},l=h=>{let p=h.resourceType(),g=h.url();if(!o.has(p)||r(g))return;let y=h.headers();y.purpose==="prefetch"||["video","audio"].includes(y["sec-fetch-dest"])||(i.add(h),n=Date.now())},d=async h=>{let p=h.request();if(!i.has(p))return;let g=(h.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(_=>g.includes(_))){i.delete(p);return}if(![...a].some(_=>g.startsWith(_))){i.delete(p);return}let y=h.headers()["content-length"];if(y)try{if(parseInt(y,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-kp;for(let h of await e.requests()){let p=h.resourceType(),g=h.url(),y=h.timing();o.has(p)&&!r(g)&&y.responseEnd===-1&&y.startTime>=c&&(i.add(h),n=Date.now())}u.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let h=Date.now(),p=_p;for(;;){await new Promise(y=>setTimeout(y,100));let g=Date.now();if(i.size===0&&g-n>=p){u.debug(`[waitForStableNetwork] Network idle after ${g-h}ms`);break}if(g-h>t){u.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ne(e,t=vp,i=xp){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Sp(e,t)])}catch(s){throw s instanceof Error?new Error(`Failed during network stabilization: ${s.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(s=>setTimeout(s,a))}var uo,xp,vp,_p,kp,Re=w(()=>{"use strict";Pt();B();uo=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,s)=>setTimeout(()=>s(new Error("CDP detach timeout")),1e3))])}catch{}},xp=.5*1e3,vp=30*1e3,_p=1*1e3,kp=3*1e3});function Ep(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 Oc(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,s=t.agentServices.getModel(),r=t.domService||new Se(t.agentServices.getDomServiceOptions()),l={...t,domService:r};b.init(),b.section("Task Execution Started"),b.log(`Task: ${e}`),b.log(`Max steps: ${o}`),b.log(`Model: ${s}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],h=ro(i.customPrompt),p=new lo(h);b.log(`System prompt length: ${h.length} chars`);let g=!1,y="",_=[];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 Ne(l.page),b.log("Page stabilized")}catch{b.log("Page stabilization timed out, continuing anyway")}let m;try{b.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();m=await Cc(l.page,l.domService,I,$),b.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){b.log("Page navigating, waiting for load..."),await Ne(l.page);let $=l.agentServices.getInteractiveClassNames(),P=l.agentServices.getIframeFallbackDomains();m=await Cc(l.page,l.domService,$,P)}else throw b.error("Error preparing context",I),I}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let f=await Ap(p,s,i,m.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){y="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;Cp(d.currentStep,o,S);let v=await Ip(S,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,f.debugInfo);_.push(...v.actionEntities);let k=Pp(d.currentStep,S,v,d,x,f.debugInfo,f.tokenUsages),A=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=a){b.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),y=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,y=v.doneResult.summary;break}if(v.completesInstruction){g=!0,y="Instruction completed";break}}return d.currentStep>=o&&!g&&(y="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),b.log(`Build success result: summary=${y}, completed=${g}, actions=${_.length}, tokens=${c.length}`),$p(d,_,g,y,n,c,s)}catch(x){let m=x.message;return b.error(`Task execution failed: ${m}`,x),i.onEvent?.({type:"error",error:m,recoverable:!1}),Op(d,m,n,c,s)}}async function Cc(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),s=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:s,screenshotBase64:a,domState:o}}function Tp(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 Ap(e,t,i,n){let o=i.temperature??0,{system:a,messages:s}=e.getMessages(),r=0;for(let h of s)Array.isArray(h.content)&&(r+=h.content.filter(p=>p.type==="image").length);let l=we(t,r),d={model:fe(t),system:a,messages:s,temperature:o,providerOptions:l},c=3;for(let h=0;h<c;h++)try{let p=Date.now();b.log(`Calling LLM (${t})...`);let g=await(0,$c.generateText)(d),y=Date.now()-p,_=g,x=_.usage;b.llmCall(t,y,x);let m=_.reasoningText;m&&(b.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let f={systemPrompt:a,userPrompt:Tp(s),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},S=[],v=Ep(x,t);v&&S.push(v);let k=Mp(g.text);if(!k)if(h<c-1){b.log(`Attempt ${h+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(A=>setTimeout(A,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(p){if(h<c-1){b.log(`Attempt ${h+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw b.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Mp(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 Ip(e,t,i,n,o,a,s){let r=[],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,h={...t,domState:i},p=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 y={},_=g.kwargs?.element_index??g.kwargs?.index;if(typeof _=="number"){let m=i.selectorMap.get(_);m&&(y=await H(t.page,m))}let x={...y,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await K.execute(g.action_name,g.kwargs,h);g.action_name==="perform_accurate_operation"&&(x=m.actionEntity);let f=await h.agentServices.getCurrentPage();if(f&&(h.page=f,t.page=h.page),m?.success===!1){l=!1,b.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}r.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:s})}catch(m){l=!1,d=m.message,b.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:r,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Pp(e,t,i,n,o,a,s){let r={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:s};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(r),r}function Cp(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 $p(e,t,i,n,o,a,s){let r=a.reduce((c,h)=>c+h.prompt_tokens,0),l=a.reduce((c,h)=>c+h.completion_tokens,0),d=a.reduce((c,h)=>c+h.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:s,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:r,completionTokens:l,totalTokens:d,tokenUsages:a}}}function Op(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),s=n.reduce((l,d)=>l+d.completion_tokens,0),r=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:s,totalTokens:r,tokenUsages:n}}}var $c,Lc=w(()=>{"use strict";Ra();so();De();Qe();le();Re();Pe();J();$c=require("ai")});var Dc={};Je(Dc,{TaskMessageManager:()=>lo,formatFinalStepWarning:()=>Tc,formatTaskContext:()=>ao,getBrowserTaskJSONPrompt:()=>ro,runTaskLoop:()=>Oc});var Nc=w(()=>{"use strict";Lc();Ra();so();De();Hn();Qe();ei();ii();xt();ni();oi();le();Re();Pt();Pe();Xt();mt();Yt();Ue();ht();J();qe();B();se();_t();G();Ae()});async function si(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(K.has(i)){let o=await K.execute(i,n,t),a=o?.success!==!1,s=o?.error||o?.message;return{success:a,error:a?void 0:s}}else{let{page:o,agentServices:a}=t;return await(await Lp()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Lp(){if(ho)return ho;let e=await Promise.resolve().then(()=>(Mt(),At));return ho=new e.default,ho}async function Et(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new Se(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await ha(s,a,n);return r.status==="error"?{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error,debugInfo:r.debugInfo}:{status:"success",completed:r.goalAccomplished||!1,actionEntities:r.actionEntity?[r.actionEntity]:[],explanation:r.reasoning,debugInfo:r.debugInfo}}async function et(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new Se(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},s=i.replaceVariables(e),r=await ha(s,a,n);if(r.status==="error"||!r.actionEntity)return{status:"error",completed:r.goalAccomplished||!1,actionEntities:[],explanation:r.reasoning,error:r.error||"No action generated",debugInfo:r.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:h}=r,p=await si(l,a);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:h}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:h}}async function tt(e,t,i,n={}){let o={page:t,agentServices:i,domService:new Se(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Vs(a,o,n)}async function it(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(Nc(),Dc)),s=n?l=>{n(l)}:void 0,r=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:s,abortSignal:o.abortSignal});return{status:r.success?"success":"error",completed:r.completed,actionEntities:r.trajectory.actions,explanation:r.summary,error:r.error,tokenUsages:r.metadata.tokenUsages}}var ho,li=w(()=>{"use strict";Tn();De();Qe();ho=null});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:Dp,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await pt(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:s}=a,r=await si(s,o);return{success:r.success,actionEntity:s,message:r.success?`Successfully executed action: ${s.action_data?.action_name}`:void 0,error:r.error}}})}var Fa,Dp,Ha=w(()=>{"use strict";li();gt();Fa=require("zod"),Dp=Fa.z.object({instruction:Fa.z.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!""')})});async function Np(e,t,i){let{apiKey:n,domain:o}=e;if(!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=!!e.baseURL,s=e.baseURL||"https://api.mailgun.net",r=e.authHeader||`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,l=[];try{let d=a?`${s}/events`:`${s}/v3/${o}/events`,c={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(c.from=i.from_email),i.since)c.begin=Math.floor(i.since/1e3).toString();else{let g=new Date(Date.now()-6e5);c.begin=Math.floor(g.getTime()/1e3).toString()}u.info(`Mailgun params: ${JSON.stringify(c)}`);let h=await fetch(d+"?"+new URLSearchParams(c),{method:"GET",headers:{Authorization:r}});if(!h.ok){let g=await h.text();throw new Error(`Mailgun events API error: ${g}`)}let p=(await h.json()).items||[];for(let g of p.slice(0,10)){if(g.event!=="accepted")continue;let y=(g.storage||{}).url;if(u.info(`message_url: ${y}`),!y){let m=(g.message||{}).headers||{},f=m.subject||"",S=m.from||"",v=m.to||"";if(i.from_email&&!S.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!v.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!f.toLowerCase().includes(i.subject.toLowerCase()))continue;l.push({subject:f,from:S,to:v,date:new Date(g.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:m["message-id"]||""});continue}let _=y.split("/"),x=_[_.length-1];if(u.info(`Storage key: ${x}`),x){let m=a?`${s}/messages/${x}`:`${s}/v3/domains/${o}/messages/${x}`;try{let f=await fetch(m,{method:"GET",headers:{Authorization:r,Accept:"application/json"}});if(f.ok){let S=await f.json(),v=S.Subject||"",k=S.From||"",A=S.To||"",I=S.Date||"",$=S["Message-Id"]||"";u.info(`subject: ${v}`),u.info(`from_addr: ${k}`),u.info(`to_addr: ${A}`),u.info(`date: ${I}`),u.info(`message_id: ${$}`);let P=S["body-html"]||S["body-plain"]||"";if(P&&P.includes("<")&&(P=(0,Hc.convert)(P)),u.info(`Body: ${P.substring(0,200)}...`),i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!P.toLowerCase().includes(i.body_contains.toLowerCase()))continue;l.push({subject:v,from:k,to:A,date:I,body:P,message_id:$});continue}else u.warn(`Messages API returned ${f.status}`)}catch(f){u.warn(`Failed to parse JSON response: ${f}`)}}try{let m=await fetch(y,{method:"GET",headers:{Authorization:r}});if(!m.ok){u.warn(`Could not fetch stored message: ${m.status}`);continue}let f=await m.text();u.info(`Fallback: Raw email length: ${f.length}`);let S=f.split(`
4358
+ `),v=!0,k={},A="";for(let Z=0;Z<S.length;Z++){let U=S[Z];if(U.trim()===""&&v){v=!1;continue}if(v){let L=U.match(/^([^:]+):\s*(.+)$/);L&&(k[L[1].toLowerCase()]=L[2])}else A+=U+`
4359
+ `}let I=k.subject||"",$=k.from||"",P=k.to||"",W=k.date||"",V=k["message-id"]||"";if(i.subject&&!I.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;l.push({subject:I,from:$,to:P,date:W,body:A.trim(),message_id:V})}catch(m){u.warn(`Error fetching raw message: ${m}`)}}if(l.length>0){try{l.sort((y,_)=>{let x=new Date(y.date).getTime();return new Date(_.date).getTime()-x})}catch{}let g=l[0];return u.info(`Returning most recent email: ${g.subject}`),[g]}return l}catch(d){throw u.error(`Error fetching emails from Mailgun: ${d.message}`),new Error(`Error fetching emails from Mailgun: ${d.message}`)}}function Rp(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)
@@ -4413,30 +4413,30 @@ Examples of what to extract:
4413
4413
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4414
4414
 
4415
4415
  Return ONLY the complete extracted URL or "NOT_FOUND".`;if(e==="custom"){if(!t)throw new Error("Custom prompt is required when extraction_type is custom");return t+`
4416
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Ip(e,t,i){try{let n=`${t}
4416
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Fp(e,t,i){try{let n=`${t}
4417
4417
  ---
4418
4418
  Email Content:
4419
4419
  ---
4420
4420
  ${e}
4421
4421
  ---
4422
- `,o=Me(i);return(await(0,Dc.generateText)({model:o,messages:[{role:"user",content:n}],temperature:0,providerOptions:Ie(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw u.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function Rc(e,t){u.info(`extract_email_content:
4422
+ `,o=fe(i);return(await(0,Fc.generateText)({model:o,messages:[{role:"user",content:n}],temperature:0,providerOptions:we(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw u.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function Wc(e,t){u.info(`extract_email_content:
4423
4423
  forward_email: ${t.forward_email}
4424
4424
  extraction_type: ${t.extraction_type}
4425
4425
  filters: ${JSON.stringify(t.filters||{})}
4426
4426
  timeout: ${t.timeout||60}
4427
- polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=Mp(t.extraction_type,t.prompt),a=new Date,s=new Date(a.getTime()+i*1e3),r=0;for(u.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<s;){r++,u.info(`Polling attempt ${r}`);try{let d=t.filters||{},c=await Ap(e,t.forward_email,d);if(c.length>0){u.info(`Found ${c.length} emails matching criteria`);let h=[];for(let p of c){let g=`Subject: ${p.subject}
4427
+ polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=Rp(t.extraction_type,t.prompt),a=new Date,s=new Date(a.getTime()+i*1e3),r=0;for(u.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<s;){r++,u.info(`Polling attempt ${r}`);try{let d=t.filters||{},c=await Np(e,t.forward_email,d);if(c.length>0){u.info(`Found ${c.length} emails matching criteria`);let h=[];for(let p of c){let g=`Subject: ${p.subject}
4428
4428
  From: ${p.from}
4429
4429
  To: ${p.to}
4430
4430
  Date: ${p.date}
4431
4431
 
4432
4432
  Body:
4433
- ${p.body}`,y=await Ip(g,o,t.model);u.info(`Extracted content: ${y}`),y&&y!=="NOT_FOUND"&&h.push({content:y,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(h.length>0){let p=h[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let y=(new Date().getTime()-a.getTime())/1e3;return u.info(`Successfully extracted content after ${r} attempts in ${y.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${r})`}}else u.info(`Found emails but no extractable content in attempt ${r}`)}else u.info(`No emails found in attempt ${r}`)}catch(d){u.warn(`Error in polling attempt ${r}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=s){u.info("Not enough time for another polling attempt");break}u.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 ${r} attempts over ${l.toFixed(1)} seconds`}}catch(o){return u.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var Dc,Nc,Fa=w(()=>{"use strict";Oe();G();Dc=require("ai"),Nc=require("html-to-text")});function Fc(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 Wc(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:Pp,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}=i,{page:p,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let y={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}}};await t.execute(p,y,g);let _=Fc(a);return{success:!0,actionEntity:y,message:`Extracted ${a} and saved to $${_}`}}catch(y){return{success:!1,error:y.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}},feedback:y.message}}}}})}var Ce,Hc,Pp,Ha=w(()=>{"use strict";Fa();dt();G();se();Ce=require("zod");Hc=class{getMailgunConfig(){let e=Y().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""};let t=e.SHIPLIGHT_API_TOKEN;if(t){let i=`${qe(t,e.SHIPLIGHT_API_URL)}/mailgun`;return u.debug(`[extract_email_content] Using Shiplight proxy for Mailgun: ${i}`),{apiKey:t,domain:e.MAILGUN_DOMAIN||"",baseURL:i,authHeader:`Bearer ${t}`}}}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, or set SHIPLIGHT_API_TOKEN to route through the Shiplight proxy.");let a=n.kwargs,s=i.getModel?.()||"gemini-2.5-pro",r=await Rc(o,{model:s,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(r.status==="success"&&r.data){let l=r.result_variable?.replace(/^\$/,"")||Fc(a.extraction_type);i.variableStore.set(l,r.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(r.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)} },`,"});"]}},Pp=Ce.z.object({forward_email:Ce.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ce.z.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:Ce.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ce.z.string().optional().describe("Filter emails by sender address"),filter_to_email:Ce.z.string().optional().describe("Filter emails by recipient address"),filter_subject:Ce.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ce.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ce.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function $e(){if(ho)return ho;let e=(await Promise.resolve().then(()=>(At(),Tt))).default;return ho=new e,ho}async function mo(e){let t=await $e(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return uc(e,i),oc(e,n),jl(e,o),wc(e,a),"Click, hover, double-click, right-click, or drag elements"}async function po(e){let t=await $e(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return ic(e,i),tc(e,n),Bl(e,o),"Navigate to URLs, go back, or reload the page"}async function go(e){let t=await $e(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return cc(e,i),rc(e,n),Wl(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function fo(e){let t=await $e(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return Sl(e,i),Tl(e,n),vl(e,o),"Scroll the page or scroll to specific text/elements"}async function wo(e){let t=await $e(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return mc(e,i),Ll(e,n),"Switch between browser tabs or close tabs"}async function bo(e){let t=await $e(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Hl(e,i),bl(e,n),"Upload files or wait for downloads to complete"}async function yo(e){let t=await $e(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return Zl(e,i),Il(e,n),Cl(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function xo(e){let t=await $e(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return fl(e,i),Vl(e,n),gc(e,o),Oc(e),"Wait for conditions, save variables, or complete tasks"}async function vo(e){let t=(await $e()).getAction("generate_2fa_code");Yl(e,t);let i=new Hc;return(await Promise.resolve().then(()=>(At(),Tt))).default.registerAction("extract_email_content",i),Wc(e,i),"Generate 2FA codes or extract email/activation codes"}async function _o(e){let t=await $e(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return xc(e,i),_c(e,n),xl(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function Uc(e){let[t,i,n,o,a,s,r,l,d,c]=await Promise.all([mo(e),po(e),go(e),fo(e),wo(e),bo(e),yo(e),xo(e),vo(e),_o(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:s,forms:r,utility:l,auth:d,ai:c}}function Gc(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
- `)}var ho,Wa=w(()=>{"use strict";Ra();Ha();ci();di();ui();mi();pi();gi();wi();yi();xi();_i();ki();Si();Ei();Ti();Ai();Mi();Ii();Ci();$i();Oi();Di();Ni();Ri();Fi();Hi();Wi();Ui();ho=null});async function Bc(){await $p}function Kc(){return j}function jc(e=!0){let t=new ft;return e&&(mo(t),po(t),go(t),fo(t),wo(t),bo(t),yo(t),vo(t),xo(t),_o(t)),t}async function zc(){let e=new ft,t=await Uc(e),i=Gc(t);return{registry:e,capabilities:t,summary:i}}function Vc(){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 Cp,$p,Xc=w(()=>{"use strict";Wa();De();Cp=[mo(j),po(j),go(j),fo(j),wo(j),bo(j),yo(j),xo(j),_o(j),vo(j)],$p=Promise.all(Cp)});function Jc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:an(t.schema)}))}var Yc,qc=w(()=>{"use strict";Bt();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:an(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:an(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 Zc=w(()=>{"use strict"});function Qc(){let e=process.env.SHIPLIGHT_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function Pt(e){let t=Qc();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 Ct(e){if(!e)return;let t=Qc();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var Ua=w(()=>{"use strict"});function So(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var xk,E,kk,Ck,Ok,Lp,Eo,Op,Dp,Np,Rp,Fp,Hp,Wp,Up,it,$t,td,Gp,ko,Ki,bk,yk,To,id,nd,od,ad,ji,Ga,Ba,Bp,ed,Kp,Bi,jp,zp,Vp,we,Xp,Yp,_k,Lk,Lt=w(()=>{"use strict";Ee();xk=require("uuid"),E=require("zod"),kk=require("yaml"),Ck=require("uuid"),Ok=require("yaml");Lp="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Eo=112,Op=1920,Dp=1080,Np=1920,Rp=1080-Eo,Fp=1280,Hp=720,Wp=500,Up=500,it="Desktop Chrome",$t=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))($t||{}),td={"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"}},Gp={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"]},ko=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Gp[e].map(n=>td[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ki=e=>td[e],bk={desktop:{label:"Desktop",type:"desktop",devices:ko("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ko("mobile")}},yk={desktop:{label:"Desktop",type:"desktop",devices:ko("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ko("mobile",!0)}},To=(e,t=!1)=>{let i={userAgent:Lp,viewport:{width:Np,height:Rp},isMobile:!1,hasTouch:!1};if(!e||e===it)return i;let n=Ki(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max(Wp/o,1),r=Math.max(Up/a,1),l=Math.max(s,r),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}},id=e=>{let t={width:Op,height:Dp};if(!e||e===it)return t;let i=To(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Eo}:t},nd=e=>{let t={width:Fp,height:Hp};if(!e||e===it)return t;let i=To(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},od=e=>!e||e===it?void 0:Ki(e)?.channel,ad=e=>!e||e===it?"chromium":Ki(e)?.defaultBrowserType??"chromium",ji=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ji||{}),Ga=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ga||{}),Ba=class rd{constructor(){ia(this,"data",{}),ia(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 rd;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}},Bp=E.z.enum(["JS_CODE","AI_MODE"]),ed=E.z.object({type:Bp,expression:E.z.string()}),Kp=E.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Bi=E.z.object({uid:E.z.string(),type:Kp,comment:E.z.string().optional()}),jp=E.z.object({action_data:E.z.object({action_name:E.z.string(),kwargs:E.z.record(E.z.any()).optional(),args:E.z.array(E.z.any()).optional()}),action_description:E.z.string().optional(),url:E.z.string().optional(),xpath:E.z.string().nullable().optional(),locator:E.z.string().nullable().optional(),css_selector:E.z.string().nullable().optional(),unique_selector:E.z.string().nullable().optional(),element_index:E.z.number().nullable().optional(),frame_path:E.z.array(E.z.any()).optional(),artifacts:E.z.record(E.z.any()).optional(),feedback:E.z.string().optional(),original_browser_use_action:E.z.any().optional()}).passthrough(),zp=Bi.extend({type:E.z.literal("DRAFT"),description:E.z.string()}),Vp=Bi.extend({type:E.z.literal("ACTION"),description:E.z.string(),action_entity:jp.optional(),locator:E.z.string().optional(),use_pure_vision:E.z.boolean().optional()}),we=E.z.lazy(()=>E.z.union([zp,Vp,Bi.extend({type:E.z.literal("STEP"),description:E.z.string().optional().default(""),statements:E.z.array(we),reference_id:E.z.number().optional(),template_path:E.z.string().optional(),template_params:E.z.record(E.z.string()).optional()}),Bi.extend({type:E.z.literal("IF_ELSE"),description:E.z.string().optional(),condition:ed,then:E.z.array(we),else:E.z.array(we).optional()}),Bi.extend({type:E.z.literal("WHILE_LOOP"),description:E.z.string().optional(),condition:ed,body:E.z.array(we),timeout_ms:E.z.number().optional()})])),Xp=E.z.object({name:E.z.string(),statements:E.z.array(we),teardown:E.z.array(we).optional(),skip:E.z.union([E.z.boolean(),E.z.string()]).optional(),timeout:E.z.number().optional(),fail:E.z.union([E.z.boolean(),E.z.string()]).optional(),only:E.z.boolean().optional(),slow:E.z.boolean().optional()}),Yp=E.z.object({tests:E.z.array(Xp).min(1),beforeAll:E.z.array(we).optional(),afterAll:E.z.array(we).optional(),beforeEach:E.z.array(we).optional(),afterEach:E.z.array(we).optional()}),_k=E.z.object({comment:E.z.string().optional(),version:E.z.string().optional(),goal:E.z.string().optional(),url:E.z.string().optional(),baseURL:E.z.string().optional(),final_feedback:E.z.string().optional(),completed:E.z.boolean().optional(),success:E.z.boolean().optional(),statements:E.z.array(we).optional(),teardown:E.z.array(we).optional(),last_modified_at:E.z.string().optional(),testGroup:Yp.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"}),Lk=1024*1024});async function Jp(e,t){let i=JSON.parse(Be.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Be,sd,Ot,nt,ld,cd=w(()=>{"use strict";Ua();Lt();Re();It();G();Be=W(require("fs"),1),sd=W(require("os"),1),Ot=W(require("path"),1),nt=require("playwright");ld=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=Ot.default.join(e.testDir,"videos"),this.statesBasePath=Ot.default.join(e.testDir,"states"),this.downloadsBasePath=Ot.default.join(e.testDir,"downloads"),Be.default.mkdirSync(this.videoBasePath,{recursive:!0}),Be.default.mkdirSync(this.statesBasePath,{recursive:!0}),Be.default.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=ad(e.deviceName),o=od(e.deviceName),a=n===$t.Chromium,s=!!e.extensionPath;u.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let r={headless:i};if(a){s&&i&&(u.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,r.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}`),u.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let A=s&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];r.args=[...Sc(t,e.disableSecurity??!0,i),...k,...A,...this.additionalArgs],o&&(r.channel=o,u.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=To(e.deviceName),d=nd(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 h=s&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!h&&(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 p,g,y,_=!1;if(a&&(s||e.userDataDir)){if(e.userDataDir)y=e.userDataDir;else{let A=this.testDir||Be.default.mkdtempSync(Ot.default.join(sd.default.tmpdir(),"shiplight-"));y=Ot.default.join(A,`ext-profile-${Date.now()}`),Be.default.mkdirSync(y,{recursive:!0}),_=!0}let k={...r,...c};g=await nt.chromium.launchPersistentContext(y,k),h&&(await Jp(g,h),u.info(`[BrowserManager] Loaded storage state into persistent context from ${h}`)),p=g.browser(),u.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${y}`}`)}else{switch(n){case $t.Firefox:p=await nt.firefox.launch(r);break;case $t.Webkit:p=await nt.webkit.launch(r);break;case $t.Chromium:default:p=await nt.chromium.launch(r);break}g=await p.newContext(c)}if(g.addInitScript(Ge),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),u.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(A){u.warn("[BrowserManager] Failed to grant permissions:",A)}}else(e.enableCamera||e.enableMicrophone)&&u.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,A=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(A),u.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,m=x?{width:x.width,height:x.height+Eo}:id(e.deviceName);if(u.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),a){let k=async A=>{try{await co(A,m.width,m.height),x&&await A.setViewportSize(x)}catch(I){u.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let A of g.pages())await k(A);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await lo(t)}catch(k){u.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await Pt({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&u.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let v={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:y,isTempUserDataDir:_,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{u.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(v).catch(A=>u.error("[BrowserManager] Error terminating browser:",A))},this.terminationTimeout);v.timeout=k}return v}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await Ct(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Be.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){u.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}}});function qp(){if(process.platform==="win32"){let i=(0,Ka.execFileSync)("powershell.exe",["-NoProfile","-NonInteractive","-Command","Get-CimInstance Win32_Process | Select-Object ProcessId,ParentProcessId,CommandLine | ConvertTo-Json -Compress"],{encoding:"utf-8",timeout:1e4}),n=JSON.parse(i.trim());return(Array.isArray(n)?n:[n]).filter(o=>o!==null&&typeof o=="object").filter(o=>typeof o.ProcessId=="number").map(o=>({pid:o.ProcessId,ppid:typeof o.ParentProcessId=="number"?o.ParentProcessId:0,args:typeof o.CommandLine=="string"?o.CommandLine:""}))}let e=(0,Ka.execFileSync)("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),t=[];for(let i of e.split(`
4436
- `)){let n=i.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);n&&t.push({pid:parseInt(n[1],10),ppid:parseInt(n[2],10),args:n[3]})}return t}function Zp(e){let t=qp(),i=new Set([e]),n=!0;for(;n;){n=!1;for(let o of t)!i.has(o.pid)&&i.has(o.ppid)&&(i.add(o.pid),n=!0)}for(let o of t){if(o.pid===e||!i.has(o.pid)||!/chrome|chromium/i.test(o.args))continue;let a=o.args.match(/--user-data-dir=(?:"([^"]+)"|(\S+))/);if(a)return a[1]??a[2]}return null}async function Qp(e,t){let i=ud.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let o=dd.readFileSync(i,"utf-8").trim(),[a,s]=o.split(`
4437
- `),r=parseInt(a,10);if(Number.isFinite(r)&&r>0&&typeof s=="string"&&s.startsWith("/"))return{port:r,wsPath:s}}catch{}await new Promise(o=>setTimeout(o,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function Ao(e,t=3e4){let i=Zp(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 Qp(i,t);return`ws://127.0.0.1:${n}${o}`}var Ka,dd,ud,hd=w(()=>{"use strict";Ka=require("child_process"),dd=W(require("fs"),1),ud=W(require("path"),1)});var md,pd=w(()=>{"use strict";Lt();md=e=>{if(!e||e===it)return"desktop";let t=Ki(e);return t&&t.isMobile?"mobile":"desktop"}});var eg,gd=w(()=>{"use strict";eg=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(eg||{})});async function fd(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4433
+ ${p.body}`,y=await Fp(g,o,t.model);u.info(`Extracted content: ${y}`),y&&y!=="NOT_FOUND"&&h.push({content:y,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(h.length>0){let p=h[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let y=(new Date().getTime()-a.getTime())/1e3;return u.info(`Successfully extracted content after ${r} attempts in ${y.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${r})`}}else u.info(`Found emails but no extractable content in attempt ${r}`)}else u.info(`No emails found in attempt ${r}`)}catch(d){u.warn(`Error in polling attempt ${r}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=s){u.info("Not enough time for another polling attempt");break}u.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 ${r} attempts over ${l.toFixed(1)} seconds`}}catch(o){return u.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var Fc,Hc,Wa=w(()=>{"use strict";Pe();B();Fc=require("ai"),Hc=require("html-to-text")});function Uc(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 Gc(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:Hp,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}=i,{page:p,agentServices:g}=n;u.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let y={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}}};await t.execute(p,y,g);let _=Uc(a);return{success:!0,actionEntity:y,message:`Extracted ${a} and saved to $${_}`}}catch(y){return{success:!1,error:y.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:s,filter_from_email:r,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:h}},feedback:y.message}}}}})}var $e,Bc,Hp,Ua=w(()=>{"use strict";Wa();ht();B();se();$e=require("zod");Bc=class{getMailgunConfig(){let e=Y().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""};let t=e.SHIPLIGHT_API_TOKEN;if(t){let i=`${Ze(t,e.SHIPLIGHT_API_URL)}/mailgun`;return u.debug(`[extract_email_content] Using Shiplight proxy for Mailgun: ${i}`),{apiKey:t,domain:e.MAILGUN_DOMAIN||"",baseURL:i,authHeader:`Bearer ${t}`}}}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, or set SHIPLIGHT_API_TOKEN to route through the Shiplight proxy.");let a=n.kwargs,s=i.getModel?.()||"gemini-2.5-pro",r=await Wc(o,{model:s,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(r.status==="success"&&r.data){let l=r.result_variable?.replace(/^\$/,"")||Uc(a.extraction_type);i.variableStore.set(l,r.data),u.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(r.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)} },`,"});"]}},Hp=$e.z.object({forward_email:$e.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:$e.z.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:$e.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:$e.z.string().optional().describe("Filter emails by sender address"),filter_to_email:$e.z.string().optional().describe("Filter emails by recipient address"),filter_subject:$e.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:$e.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:$e.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function Oe(){if(mo)return mo;let e=(await Promise.resolve().then(()=>(Mt(),At))).default;return mo=new e,mo}async function po(e){let t=await Oe(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return fc(e,i),cc(e,n),Zl(e,o),_c(e,a),"Click, hover, double-click, right-click, or drag elements"}async function go(e){let t=await Oe(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return sc(e,i),rc(e,n),Jl(e,o),"Navigate to URLs, go back, or reload the page"}async function fo(e){let t=await Oe(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return pc(e,i),zl(e,n),Vl(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function wo(e){let t=await Oe(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return Dl(e,i),Rl(e,n),$l(e,o),"Scroll the page or scroll to specific text/elements"}async function bo(e){let t=await Oe(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return bc(e,i),jl(e,n),"Switch between browser tabs or close tabs"}async function yo(e){let t=await Oe(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return kl(e,i),Al(e,n),"Upload files or wait for downloads to complete"}async function xo(e){let t=await Oe(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return nc(e,i),Wl(e,n),Bl(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function vo(e){let t=await Oe(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return El(e,i),Cl(e,n),xc(e,o),Rc(e),"Wait for conditions, save variables, or complete tasks"}async function _o(e){let t=(await Oe()).getAction("generate_2fa_code");ec(e,t);let i=new Bc;return(await Promise.resolve().then(()=>(Mt(),At))).default.registerAction("extract_email_content",i),Gc(e,i),"Generate 2FA codes or extract email/activation codes"}async function ko(e){let t=await Oe(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return Ec(e,i),uc(e,n),Il(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function jc(e){let[t,i,n,o,a,s,r,l,d,c]=await Promise.all([po(e),go(e),fo(e),wo(e),bo(e),yo(e),xo(e),vo(e),_o(e),ko(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:s,forms:r,utility:l,auth:d,ai:c}}function Kc(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
+ `)}var mo,Ba=w(()=>{"use strict";Ha();Ua();di();ui();hi();mi();pi();fi();wi();bi();xi();_i();ki();Ei();Ti();Ai();Mi();Ii();Pi();Ci();Oi();Li();Di();Ni();Ri();Fi();Hi();Wi();Ui();mo=null});async function zc(){await Up}function Vc(){return K}function Xc(e=!0){let t=new ft;return e&&(po(t),go(t),fo(t),wo(t),bo(t),yo(t),xo(t),_o(t),vo(t),ko(t)),t}async function Yc(){let e=new ft,t=await jc(e),i=Kc(t);return{registry:e,capabilities:t,summary:i}}function Jc(){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 Wp,Up,qc=w(()=>{"use strict";Ba();De();Wp=[po(K),go(K),fo(K),wo(K),bo(K),yo(K),xo(K),vo(K),ko(K),_o(K)],Up=Promise.all(Wp)});function Qc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:rn(t.schema)}))}var Zc,ed=w(()=>{"use strict";jt();Zc=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:rn(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:rn(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 td=w(()=>{"use strict"});function id(){let e=process.env.OMNITERM_BROWSER_REGISTRY_URL;return e?e.replace(/\/$/,""):null}async function Ct(e){let t=id();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 $t(e){if(!e)return;let t=id();if(t)try{await fetch(`${t}/browsers/${encodeURIComponent(e)}`,{method:"DELETE"})}catch{}}var Ga=w(()=>{"use strict"});function Ao(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var E,Ck,Hk,Bk,Kk,Bp,Eo,Gp,jp,Kp,zp,Vp,Xp,Yp,Jp,nt,Ot,od,qp,So,ji,Mk,Ik,To,ad,rd,sd,ld,ja,Ki,Ka,Zp,nd,Qp,Gi,eg,tg,ig,ye,ng,og,Pk,Uk,Lt=w(()=>{"use strict";Ae();E=require("zod"),Ck=require("yaml"),Hk=require("uuid"),Bk=require("yaml"),Kk=require("uuid"),Bp="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Eo=112,Gp=1920,jp=1080,Kp=1920,zp=1080-Eo,Vp=1280,Xp=720,Yp=500,Jp=500,nt="Desktop Chrome",Ot=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Ot||{}),od={"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"}},qp={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"]},So=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),qp[e].map(n=>od[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},ji=e=>od[e],Mk={desktop:{label:"Desktop",type:"desktop",devices:So("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:So("mobile")}},Ik={desktop:{label:"Desktop",type:"desktop",devices:So("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:So("mobile",!0)}},To=(e,t=!1)=>{let i={userAgent:Bp,viewport:{width:Kp,height:zp},isMobile:!1,hasTouch:!1};if(!e||e===nt)return i;let n=ji(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max(Yp/o,1),r=Math.max(Jp/a,1),l=Math.max(s,r),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}},ad=e=>{let t={width:Gp,height:jp};if(!e||e===nt)return t;let i=To(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Eo}:t},rd=e=>{let t={width:Vp,height:Xp};if(!e||e===nt)return t;let i=To(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},sd=e=>!e||e===nt?void 0:ji(e)?.channel,ld=e=>!e||e===nt?"chromium":ji(e)?.defaultBrowserType??"chromium";ja=class cd{constructor(){oa(this,"data",{}),oa(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 cd;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}},Ki=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ki||{}),Ka=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ka||{}),Zp=E.z.enum(["JS_CODE","AI_MODE"]),nd=E.z.object({type:Zp,expression:E.z.string()}),Qp=E.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Gi=E.z.object({uid:E.z.string(),type:Qp,comment:E.z.string().optional()}),eg=E.z.object({action_data:E.z.object({action_name:E.z.string(),kwargs:E.z.record(E.z.any()).optional(),args:E.z.array(E.z.any()).optional()}),action_description:E.z.string().optional(),url:E.z.string().optional(),xpath:E.z.string().nullable().optional(),locator:E.z.string().nullable().optional(),css_selector:E.z.string().nullable().optional(),unique_selector:E.z.string().nullable().optional(),element_index:E.z.number().nullable().optional(),frame_path:E.z.array(E.z.any()).optional(),artifacts:E.z.record(E.z.any()).optional(),feedback:E.z.string().optional(),original_browser_use_action:E.z.any().optional()}).passthrough(),tg=Gi.extend({type:E.z.literal("DRAFT"),description:E.z.string()}),ig=Gi.extend({type:E.z.literal("ACTION"),description:E.z.string(),action_entity:eg.optional(),locator:E.z.string().optional(),use_pure_vision:E.z.boolean().optional()}),ye=E.z.lazy(()=>E.z.union([tg,ig,Gi.extend({type:E.z.literal("STEP"),description:E.z.string().optional().default(""),statements:E.z.array(ye),reference_id:E.z.number().optional(),template_path:E.z.string().optional(),template_params:E.z.record(E.z.string()).optional()}),Gi.extend({type:E.z.literal("IF_ELSE"),description:E.z.string().optional(),condition:nd,then:E.z.array(ye),else:E.z.array(ye).optional()}),Gi.extend({type:E.z.literal("WHILE_LOOP"),description:E.z.string().optional(),condition:nd,body:E.z.array(ye),timeout_ms:E.z.number().optional()})])),ng=E.z.object({name:E.z.string(),statements:E.z.array(ye),teardown:E.z.array(ye).optional(),skip:E.z.union([E.z.boolean(),E.z.string()]).optional(),timeout:E.z.number().optional(),fail:E.z.union([E.z.boolean(),E.z.string()]).optional(),only:E.z.boolean().optional(),slow:E.z.boolean().optional()}),og=E.z.object({tests:E.z.array(ng).min(1),beforeAll:E.z.array(ye).optional(),afterAll:E.z.array(ye).optional(),beforeEach:E.z.array(ye).optional(),afterEach:E.z.array(ye).optional()}),Pk=E.z.object({comment:E.z.string().optional(),version:E.z.string().optional(),goal:E.z.string().optional(),url:E.z.string().optional(),baseURL:E.z.string().optional(),final_feedback:E.z.string().optional(),completed:E.z.boolean().optional(),success:E.z.boolean().optional(),statements:E.z.array(ye).optional(),teardown:E.z.array(ye).optional(),last_modified_at:E.z.string().optional(),testGroup:og.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"}),Uk=1024*1024});async function ag(e,t){let i=JSON.parse(je.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var je,dd,Dt,ot,ud,hd=w(()=>{"use strict";Ga();Lt();Re();Pt();B();je=F(require("fs"),1),dd=F(require("os"),1),Dt=F(require("path"),1),ot=require("playwright");ud=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=Dt.default.join(e.testDir,"videos"),this.statesBasePath=Dt.default.join(e.testDir,"states"),this.downloadsBasePath=Dt.default.join(e.testDir,"downloads"),je.default.mkdirSync(this.videoBasePath,{recursive:!0}),je.default.mkdirSync(this.statesBasePath,{recursive:!0}),je.default.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=ld(e.deviceName),o=sd(e.deviceName),a=n===Ot.Chromium,s=!!e.extensionPath;u.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let r={headless:i};if(a){s&&i&&(u.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,r.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}`),u.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let A=s&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];r.args=[...Ac(t,e.disableSecurity??!0,i),...k,...A,...this.additionalArgs],o&&(r.channel=o,u.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=To(e.deviceName),d=rd(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 h=s&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!h&&(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 p,g,y,_=!1;if(a&&(s||e.userDataDir)){if(e.userDataDir)y=e.userDataDir;else{let A=this.testDir||je.default.mkdtempSync(Dt.default.join(dd.default.tmpdir(),"shiplight-"));y=Dt.default.join(A,`ext-profile-${Date.now()}`),je.default.mkdirSync(y,{recursive:!0}),_=!0}let k={...r,...c};g=await ot.chromium.launchPersistentContext(y,k),h&&(await ag(g,h),u.info(`[BrowserManager] Loaded storage state into persistent context from ${h}`)),p=g.browser(),u.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${y}`}`)}else{switch(n){case Ot.Firefox:p=await ot.firefox.launch(r);break;case Ot.Webkit:p=await ot.webkit.launch(r);break;case Ot.Chromium:default:p=await ot.chromium.launch(r);break}g=await p.newContext(c)}if(g.addInitScript(Ge),a){let k=["clipboard-read","clipboard-write"];e.enableCamera&&k.push("camera"),e.enableMicrophone&&k.push("microphone");try{await g.grantPermissions(k),u.info(`[BrowserManager] Granted permissions: ${k.join(", ")}`)}catch(A){u.warn("[BrowserManager] Failed to grant permissions:",A)}}else(e.enableCamera||e.enableMicrophone)&&u.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let k=(Date.now()+31536e6)/1e3,A=e.cookies.map(I=>({...I,expires:k}));await g.addCookies(A),u.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${k}`)}let x=e.viewport,m=x?{width:x.width,height:x.height+Eo}:ad(e.deviceName);if(u.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),a){let k=async A=>{try{await uo(A,m.width,m.height),x&&await A.setViewportSize(x)}catch(I){u.warn("[BrowserManager] Failed to set window bounds via CDP:",I)}};for(let A of g.pages())await k(A);g.on("page",k)}let f="";if(a&&t!==void 0)try{f=await co(t)}catch(k){u.warn("[BrowserManager] Failed to get CDP WebSocket URL:",k)}let S=null;f&&(S=await Ct({cdpUrl:f,label:`agent ${e.deviceName??n}`,pid:process.pid}),S&&u.info(`[BrowserManager] Registered browser with dev-box registry id=${S}`));let v={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:f,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:y,isTempUserDataDir:_,registryId:S};if(this.terminationTimeout!==null){let k=setTimeout(()=>{u.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(v).catch(A=>u.error("[BrowserManager] Error terminating browser:",A))},this.terminationTimeout);v.timeout=k}return v}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await $t(e.registryId??null),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{je.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){u.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}}});function rg(){if(process.platform==="win32"){let i=(0,za.execFileSync)("powershell.exe",["-NoProfile","-NonInteractive","-Command","Get-CimInstance Win32_Process | Select-Object ProcessId,ParentProcessId,CommandLine | ConvertTo-Json -Compress"],{encoding:"utf-8",timeout:1e4}),n=JSON.parse(i.trim());return(Array.isArray(n)?n:[n]).filter(o=>o!==null&&typeof o=="object").filter(o=>typeof o.ProcessId=="number").map(o=>({pid:o.ProcessId,ppid:typeof o.ParentProcessId=="number"?o.ParentProcessId:0,args:typeof o.CommandLine=="string"?o.CommandLine:""}))}let e=(0,za.execFileSync)("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),t=[];for(let i of e.split(`
4436
+ `)){let n=i.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);n&&t.push({pid:parseInt(n[1],10),ppid:parseInt(n[2],10),args:n[3]})}return t}function sg(e){let t=rg(),i=new Set([e]),n=!0;for(;n;){n=!1;for(let o of t)!i.has(o.pid)&&i.has(o.ppid)&&(i.add(o.pid),n=!0)}for(let o of t){if(o.pid===e||!i.has(o.pid)||!/chrome|chromium/i.test(o.args))continue;let a=o.args.match(/--user-data-dir=(?:"([^"]+)"|(\S+))/);if(a)return a[1]??a[2]}return null}async function lg(e,t){let i=pd.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let o=md.readFileSync(i,"utf-8").trim(),[a,s]=o.split(`
4437
+ `),r=parseInt(a,10);if(Number.isFinite(r)&&r>0&&typeof s=="string"&&s.startsWith("/"))return{port:r,wsPath:s}}catch{}await new Promise(o=>setTimeout(o,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function Mo(e,t=3e4){let i=sg(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 lg(i,t);return`ws://127.0.0.1:${n}${o}`}var za,md,pd,gd=w(()=>{"use strict";za=require("child_process"),md=F(require("fs"),1),pd=F(require("path"),1)});var fd,wd=w(()=>{"use strict";Lt();fd=e=>{if(!e||e===nt)return"desktop";let t=ji(e);return t&&t.isMobile?"mobile":"desktop"}});var cg,bd=w(()=>{"use strict";cg=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(cg||{})});var Va,Io,Xa=w(()=>{"use strict";Va=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Va||{}),Io=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});async function yd(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4438
4438
  return await (${t});
4439
- `;return await new i("page",n)(e)}async function zi(e,t,i){let n=[],o=[];for(let a of t){let s=!1;try{let r=`page.${a}`;b.log(`Checking element existence: ${r}`),n.push(`Checking element existence: ${r}`);try{await fd(e,`${r}.waitFor({ state: 'attached', timeout: ${tg} })`),b.log(`Element is attached: ${r}`),n.push(`Element is attached: ${r}`),s=!0}catch{await fd(e,`${r}.count()`)>0?(b.log(`Element found (snapshot): ${r}`),n.push(`Element found (snapshot): ${r}`),s=!0):(b.log(`Element not found: ${r}`),n.push(`Element not found: ${r}`),s=!1)}}catch(r){b.log(`Error checking element: ${r.message}`),n.push(`Error checking element: ${r.message}`),s=!1}if(o.push(s),!s&&i)break}return{successResults:o,logs:n}}async function ja(e,t,i=!0){let{successResults:n,logs:o}=await zi(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Vi(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 ja(e,t,!0);return i?b.log("All validation expressions passed"):b.log(`Validation failed: ${n.join(", ")}`),i}async function za(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 Ne(o,ig),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function Va(e,t,i,n,o,a){let s=`
4439
+ `;return await new i("page",n)(e)}async function zi(e,t,i){let n=[],o=[];for(let a of t){let s=!1;try{let r=`page.${a}`;b.log(`Checking element existence: ${r}`),n.push(`Checking element existence: ${r}`);try{await yd(e,`${r}.waitFor({ state: 'attached', timeout: ${dg} })`),b.log(`Element is attached: ${r}`),n.push(`Element is attached: ${r}`),s=!0}catch{await yd(e,`${r}.count()`)>0?(b.log(`Element found (snapshot): ${r}`),n.push(`Element found (snapshot): ${r}`),s=!0):(b.log(`Element not found: ${r}`),n.push(`Element not found: ${r}`),s=!1)}}catch(r){b.log(`Error checking element: ${r.message}`),n.push(`Error checking element: ${r.message}`),s=!1}if(o.push(s),!s&&i)break}return{successResults:o,logs:n}}async function Ya(e,t,i=!0){let{successResults:n,logs:o}=await zi(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Vi(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 Ya(e,t,!0);return i?b.log("All validation expressions passed"):b.log(`Validation failed: ${n.join(", ")}`),i}async function Ja(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 Ne(o,ug),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function qa(e,t,i,n,o,a){let s=`
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,7 +4480,7 @@ ${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
  ${s}`);let r=await a(e,s);if(!r.success)throw new Error(r.details||"Agent failed to generate verification code");let l=(r.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 Mo(e,t,i,n,o){let a=null;try{a=await za(e,t);let s=await o(a.page),r=3,l="";for(let d=0;d<r;d++)try{let c=await Va(e,s,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);b.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:h,logs:p}=await zi(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 Po(e,t,i,n,o){let a=null;try{a=await Ja(e,t);let s=await o(a.page),r=3,l="";for(let d=0;d<r;d++)try{let c=await qa(e,s,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);b.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:h,logs:p}=await zi(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4484
4484
  ${p.join(`
4485
4485
  `)}
4486
4486
 
@@ -4492,10 +4492,13 @@ ${p.join(`
4492
4492
 
4493
4493
  `,h.some(g=>g)){b.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(h)}`),b.log(`Validation logs:
4494
4494
  ${p.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}/${r}): ${c.message}`)}return b.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var tg,ig,Io=w(()=>{"use strict";le();Re();tg=5e3,ig=1e4});var wd,Xa=w(()=>{"use strict";wd=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 bd(e,t=3e3,i=1e3){try{await Ne(e,t,i)}catch{}}async function yd(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 s;throw t.downloadStatus?s=`Timed out after ${n}ms waiting for download to complete`:s="No download in progress or completed",u.error(s),new Error(s)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let s=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(s),new Error(s)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function xd(e,t,i,n=60,o){let a=Math.min(n,300),s=Math.max(10,a/10)*1e3,r=Date.now()+a*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return u.info(`Condition met: "${t}"`),!0}catch(c){u.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>r)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let d=s-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var Po=w(()=>{"use strict";Re();G()});function _d(e){return e.url()===":"}var vd,Xi,Co,ng,$o,Ya=w(()=>{"use strict";Xa();Lt();Po();Re();G();vd=W(require("fs"),1),Xi=W(require("path"),1),Co=require("otplib"),ng=(0,Co.createGuardrails)({MIN_SECRET_BYTES:1});$o=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 wd(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return u.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${n.url()}`),n}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return So(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Xi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=Xi.basename(n),a=Xi.join(t,o),s=vd.existsSync(a);return s&&u.debug(`[AgentServices] File already exists locally: ${o}`),!s});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return yd(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
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 u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,Co.generateSync)({secret:e,guardrails:ng});return u.info(`Generated 2FA code: ${t}`),t}catch(t){throw u.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ne(e,t)}setPage(e){this.context.setPage?(u.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):u.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var Ja,Lo,qa=w(()=>{"use strict";Ja=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Ja||{}),Lo=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var kd={};Ye(kd,{LoginType:()=>ji,checkLocators:()=>zi,createUnsignedInContext:()=>za,generateAndValidateLoginLocators:()=>Mo,generateValidationLocators:()=>Va,validateLogin:()=>Vi,validateLoginLocators:()=>ja});var Sd=w(()=>{"use strict";Io();le();Lt();Re();It();G();se();vt();Ee()});function ag(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let r=t.slice(n+2).trim();if(r.startsWith("{")){let l=r.lastIndexOf("}");i=r.slice(1,l)}else return r.trim()}else{let r=t.indexOf("{"),l=t.lastIndexOf("}");r!==-1&&l>r&&(i=t.slice(r+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}/${r}): ${c.message}`)}return b.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var dg,ug,Co=w(()=>{"use strict";le();Re();dg=5e3,ug=1e4});var xd,Za=w(()=>{"use strict";xd=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 vd(e,t=3e3,i=1e3){try{await Ne(e,t,i)}catch{}}async function _d(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 s;throw t.downloadStatus?s=`Timed out after ${n}ms waiting for download to complete`:s="No download in progress or completed",u.error(s),new Error(s)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let s=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw u.error(s),new Error(s)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function kd(e,t,i,n=60,o){let a=Math.min(n,300),s=Math.max(10,a/10)*1e3,r=Date.now()+a*1e3;for(u.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return u.info(`Condition met: "${t}"`),!0}catch(c){u.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>r)return u.warn(`Timeout waiting for condition: "${t}"`),!1;let d=s-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var $o=w(()=>{"use strict";Re();B()});function Ed(e){return e.url()===":"}var Sd,Xi,Oo,hg,Lo,Qa=w(()=>{"use strict";Za();Lt();$o();Re();B();Sd=F(require("fs"),1),Xi=F(require("path"),1),Oo=require("otplib"),hg=(0,Oo.createGuardrails)({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 xd(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return u.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return u.info(`[validatePage] Page closed, switching to ${n.url()}`),n}u.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return Ao(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Xi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){u.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=Xi.basename(n),a=Xi.join(t,o),s=Sd.existsSync(a);return s&&u.debug(`[AgentServices] File already exists locally: ${o}`),!s});if(i.length===0){u.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){u.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}u.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return _d(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(u.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(u.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(u.warn("Download completed but file path is missing"),null):(u.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),u.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
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 u.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,Oo.generateSync)({secret:e,guardrails:hg});return u.info(`Generated 2FA code: ${t}`),t}catch(t){throw u.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ne(e,t)}setPage(e){this.context.setPage?(u.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):u.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return u.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return u.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return u.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});async function mg(e){let t;try{t=await Yi.promises.stat(e)}catch{throw new Error(`agent.ai: file not found or unreadable: ${e}`)}if(!t.isFile())throw new Error(`agent.ai: not a file: ${e}`);if(t.size>Td)throw new Error(`agent.ai: file exceeds the ${Math.floor(Td/(1024*1024))}MB attachment limit (${t.size} bytes): ${e}`);let i=Do.extname(e).toLowerCase(),n=Do.basename(e);if(Ad[i])return{parts:[{type:"image",image:await Yi.promises.readFile(e)}],imageCount:1};if(Md[i])return{parts:[{type:"file",data:await Yi.promises.readFile(e),mediaType:Md[i],filename:n}],imageCount:0};if(Id.has(i)){let o=await Yi.promises.readFile(e,"utf-8");return{parts:[{type:"text",text:`File: ${n}
4497
+ ---
4498
+ ${o}
4499
+ ---`}],imageCount:0}}throw new Error(`agent.ai: ${i?`unsupported attachment type "${i}"`:"file has no extension, cannot determine attachment type"} (${e}). Supported: PDF, images (${Object.keys(Ad).join(", ")}), and text files (${[...Id].join(", ")}). For other formats, parse the file in code and pass the extracted text in the prompt.`)}async function Cd(e,t,i){let n=[],o=0;for(let s of t){let{parts:r,imageCount:l}=await mg(s);n.push(...r),o+=l}n.push({type:"text",text:e});let a=await(0,Pd.generateText)({model:fe(i),messages:[{role:"user",content:n}],temperature:0,providerOptions:we(i,o)});return{text:a.text,tokenUsage:Be(a.usage,i)}}var Yi,Do,Pd,Td,Ad,Md,Id,er=w(()=>{"use strict";wt();Pe();Yi=F(require("fs"),1),Do=F(require("path"),1),Pd=require("ai"),Td=20*1024*1024,Ad={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".webp":"image/webp",".gif":"image/gif"},Md={".pdf":"application/pdf"},Id=new Set([".txt",".csv",".tsv",".json",".md",".markdown",".html",".htm",".xml",".yaml",".yml",".log"])});var $d={};Je($d,{LoginType:()=>Ki,checkLocators:()=>zi,createUnsignedInContext:()=>Ja,generateAndValidateLoginLocators:()=>Po,generateValidationLocators:()=>qa,validateLogin:()=>Vi,validateLoginLocators:()=>Ya});var Od=w(()=>{"use strict";Co();le();Lt();Re();Pt();B();se();_t();Ae()});function gg(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let r=t.slice(n+2).trim();if(r.startsWith("{")){let l=r.lastIndexOf("}");i=r.slice(1,l)}else return r.trim()}else{let r=t.indexOf("{"),l=t.lastIndexOf("}");r!==-1&&l>r&&(i=t.slice(r+1,l))}if(!i)return;let o=i.split(`
4497
4500
  `),a=o.filter(r=>r.trim().length>0);if(a.length===0)return;let s=Math.min(...a.map(r=>r.match(/^(\s*)/)?.[1].length??0));return o.map(r=>r.slice(s)).join(`
4498
- `).trim()}catch{return}}function Dt(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var q,ae,og,rg,sg,Za,Ed=w(()=>{"use strict";li();Ze();Io();le();Ya();Po();qa();vi();G();q=W(require("fs"),1),ae=W(require("path"),1),og=1;rg=3,sg=40;Za=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new $o(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(()=>(At(),Tt));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.
4501
+ `).trim()}catch{return}}function Nt(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var q,ae,pg,fg,wg,tr,Ld=w(()=>{"use strict";Xa();li();Qe();Co();le();Qa();$o();er();ci();B();q=F(require("fs"),1),ae=F(require("path"),1),pg=1;fg=3,wg=40;tr=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(()=>(Mt(),At));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
4502
 
4500
4503
  ONLY dismiss intrusive popups such as:
4501
4504
  - Cookie/GDPR consent banners
@@ -4517,7 +4520,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
4517
4520
  IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
4518
4521
  It's better to miss a popup than to accidentally interact with normal page elements.
4519
4522
 
4520
- If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,rg),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(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),_d(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||ae.join(process.cwd(),"downloads");q.existsSync(n)||q.mkdirSync(n,{recursive:!0});let o=ae.join(n,i);u.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()},u.info(`[Download Tracking] Download completed: ${o}`),u.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()},u.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();u.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()},u.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){u.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),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let s=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let r=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);r?(r.count+=n,s.length>0&&r.tokenUsages.push(...s),i?.userPrompt&&(r.userPrompt=i.userPrompt),i?.rawLlmResponse&&(r.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(r.reasoningContent=i.reasoningContent),i?.elementTree&&(r.elementTree=i.elementTree),i?.screenshotWithSom&&(r.screenshotWithSom=i.screenshotWithSom),a&&(r.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...s],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await et(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){u.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 et(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):(u.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){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Qe(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;u.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 s=this.getCompletedExecutionHistory();this.context.agentNote="";let r,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let p=`${i}-step${h.step}`;this.saveDebugInfoToFiles(p,h.debugInfo,this.context.model)}}:void 0;if(r=await tt(t,e,this.agentServices,c,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??sg}),l=r.completed,this.collectTokenUsages(r.tokenUsages),i&&r.tokenUsages){let h={tokenUsages:r.tokenUsages};this.trackAIAction(i,"execute",h,r.actionEntities?.length||1,t,r.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),r=await Qe(t,e,this.agentServices,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=r.completed,this.collectTokenUsages(r.debugInfo),this.context.lastActionDebugInfo=r.debugInfo,i){let c=r.explanation||r.error||"No explanation";this.trackAIAction(i,"execute",r.debugInfo,1,t,c)}if(r.status!=="success"||r.actionEntities.length===0||!l){let c=r.explanation||r.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,r.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||r.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,r.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:r.actionEntities,debugInfo:r.debugInfo}}catch(s){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",s.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${s.message}`),s}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await St(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 s=a.completed,r=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,r),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",r,void 0,a.debugInfo),u.info(`[generate] Generated action for "${t}": ${r}, goalAccomplished: ${a.completed}`),{success:s,details:r,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,s=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let h=`${i}-step${c.step}`;this.saveDebugInfoToFiles(h,c.debugInfo,this.context.model)}}:void 0,r=await tt(t,e,this.agentServices,s,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});b.log(`Run task result: status=${r.status}, completed=${r.completed}, actions=${r.actionEntities?.length||0}`),this.collectTokenUsages(r.tokenUsages);let l=r.status==="success"&&r.completed,d=this.context.agentNote?.trim()||r.explanation||r.error||(l?"Step completed":"Step failed");if(i&&r.tokenUsages){let c={tokenUsages:r.tokenUsages};this.trackAIAction(i,"run",c,r.actionEntities?.length||1,t,d)}if(!l)throw new Lo(d);if(n?.stmtUid&&r.actionEntities?.length){let c=r.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:r.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,s){let r=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let p=ag(t);p&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=p)}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?Dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[n]?.screenshot;try{u.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),y=await this.captureDOMSnapshot(e),_=this.context.stepTracking?.captureVariables?Dt(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 m=Date.now()-r,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:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:y||void 0,variables:_,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),p}catch(p){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(u.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?Dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-r,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:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,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),p}this.context.isSelfHealing=!0,u.info(`Action failed at step ${n}. ${i}`),u.info(`with error: ${p.message}`);let y,_;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){y=`[Auto-dismissed modal: ${m.details}]`,_=m.actions,u.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]=y+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",y),this.context.stepTracking.results[n].dismissedModalActions=_,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=y,f}catch(f){u.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=s??og;u.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let m=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let f=m.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),u.info(`Stored new action entity for stmtUid: ${o} (last of ${m.actions?.length} actions)`));let S=e.url(),v=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Dt(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,_&&(this.context.stepTracking.results[n].dismissedModalActions=_);let A=y||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-r,I=this.context.stepTracking.results[n]?.screenshot,$=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:m.actions?.map(P=>P.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:v||void 0,variables:k,screenshotPath:I,timestamp:$})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let f=e.url(),S=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-r,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:v,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}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 _e(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 _e(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 u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return bd(e,t,i)}async waitUntilCondition(e,t,i=60,n){return xd(e,t,(o,a,s)=>this.evaluate(o,a,s),i,n)}async uploadFile(e,t,i={},n){return Nl(e,t,i,this.context,(o,a,s)=>this.execute(o,a,s),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Sd(),kd));if(u.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 u.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),u.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"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};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 Vi(e,i.validation_exprs))return b.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};b.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let s=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||s)){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"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}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 r=`First check if the page is already signed in. If it is, do nothing.
4523
+ If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,fg),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(u.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Ed(e)){u.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();u.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},u.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||ae.join(process.cwd(),"downloads");q.existsSync(n)||q.mkdirSync(n,{recursive:!0});let o=ae.join(n,i);u.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()},u.info(`[Download Tracking] Download completed: ${o}`),u.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()},u.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(u.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){u.debug("[Dialog Handling] Skipping - page is closed");return}u.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();u.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()},u.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){u.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}async waitForDownloadComplete(e,t=10){return this.agentServices.waitForDownloadComplete(e,t)}async ai(e,t){let i=this.agentServices.getModel(),n=t?.files??[];u.info(`[agent.ai] "${e}" (${n.length} attachment(s), model ${i})`);let{text:o,tokenUsage:a}=await Cd(e,n,i);return a&&this.collectTokenUsages([a]),this.addToExecutionHistory(`AI: "${e}"`,o.length>500?`${o.slice(0,500)}\u2026`:o),o}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),u.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):u.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let s=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let r=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);r?(r.count+=n,s.length>0&&r.tokenUsages.push(...s),i?.userPrompt&&(r.userPrompt=i.userPrompt),i?.rawLlmResponse&&(r.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(r.reasoningContent=i.reasoningContent),i?.elementTree&&(r.elementTree=i.elementTree),i?.screenshotWithSom&&(r.screenshotWithSom=i.screenshotWithSom),a&&(r.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...s],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),u.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){u.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await tt(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){u.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 tt(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):(u.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){u.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await et(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;u.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 s=this.getCompletedExecutionHistory();this.context.agentNote="";let r,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?h=>{if(h.type==="action"&&h.debugInfo){let p=`${i}-step${h.step}`;this.saveDebugInfoToFiles(p,h.debugInfo,this.context.model)}}:void 0;if(r=await it(t,e,this.agentServices,c,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??wg}),l=r.completed,this.collectTokenUsages(r.tokenUsages),i&&r.tokenUsages){let h={tokenUsages:r.tokenUsages};this.trackAIAction(i,"execute",h,r.actionEntities?.length||1,t,r.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),r=await et(t,e,this.agentServices,{executionHistory:s,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=r.completed,this.collectTokenUsages(r.debugInfo),this.context.lastActionDebugInfo=r.debugInfo,i){let c=r.explanation||r.error||"No explanation";this.trackAIAction(i,"execute",r.debugInfo,1,t,c)}if(r.status!=="success"||r.actionEntities.length===0||!l){let c=r.explanation||r.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,r.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||r.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,r.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:r.actionEntities,debugInfo:r.debugInfo}}catch(s){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",s.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${s.message}`),s}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let o=this.getCompletedExecutionHistory(),a=await Et(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 s=a.completed,r=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,r),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",r,void 0,a.debugInfo),u.info(`[generate] Generated action for "${t}": ${r}, goalAccomplished: ${a.completed}`),{success:s,details:r,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,s=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let h=`${i}-step${c.step}`;this.saveDebugInfoToFiles(h,c.debugInfo,this.context.model)}}:void 0,r=await it(t,e,this.agentServices,s,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});b.log(`Run task result: status=${r.status}, completed=${r.completed}, actions=${r.actionEntities?.length||0}`),this.collectTokenUsages(r.tokenUsages);let l=r.status==="success"&&r.completed,d=this.context.agentNote?.trim()||r.explanation||r.error||(l?"Step completed":"Step failed");if(i&&r.tokenUsages){let c={tokenUsages:r.tokenUsages};this.trackAIAction(i,"run",c,r.actionEntities?.length||1,t,d)}if(!l)throw new Io(d);if(n?.stmtUid&&r.actionEntities?.length){let c=r.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:r.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,s){let r=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let p=gg(t);p&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=p)}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?Nt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},h=this.context.stepTracking?.results[n]?.screenshot;try{u.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),y=await this.captureDOMSnapshot(e),_=this.context.stepTracking?.captureVariables?Nt(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 m=Date.now()-r,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:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:y||void 0,variables:_,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),p}catch(p){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw u.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(u.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),f=await this.captureDOMSnapshot(e),S=this.context.stepTracking.captureVariables?Nt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-r,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:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,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),p}this.context.isSelfHealing=!0,u.info(`Action failed at step ${n}. ${i}`),u.info(`with error: ${p.message}`);let y,_;if(this.context.autoDismissModal){u.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(u.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){y=`[Auto-dismissed modal: ${m.details}]`,_=m.actions,u.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]=y+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",y),this.context.stepTracking.results[n].dismissedModalActions=_,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=y,f}catch(f){u.info(`Retry after modal dismissal failed: ${f.message}, falling back to self-healing`)}}}let x=s??pg;u.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let m=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let f=m.actions?.at(-1);o&&f&&(this._newActionEntities.set(o,f),u.info(`Stored new action entity for stmtUid: ${o} (last of ${m.actions?.length} actions)`));let S=e.url(),v=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Nt(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,_&&(this.context.stepTracking.results[n].dismissedModalActions=_);let A=y||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-r,I=this.context.stepTracking.results[n]?.screenshot,$=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:f,playwrightCode:m.actions?.map(P=>P.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:S,domSnapshot:v||void 0,variables:k,screenshotPath:I,timestamp:$})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let f=e.url(),S=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Nt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},k=Date.now()-r,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:h,timestamp:r}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:k,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:f,domSnapshot:S||void 0,variables:v,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}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 Se(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 Se(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 u.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return vd(e,t,i)}async waitUntilCondition(e,t,i=60,n){return kd(e,t,(o,a,s)=>this.evaluate(o,a,s),i,n)}async uploadFile(e,t,i={},n){return xl(e,t,i,this.context,(o,a,s)=>this.execute(o,a,s),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Od(),$d));if(u.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 u.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),u.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"),u.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};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 Vi(e,i.validation_exprs))return b.log("Level 1 SUCCESS: Already logged in via storage state"),u.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};b.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let s=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||s)){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"),u.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}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 r=`First check if the page is already signed in. If it is, do nothing.
4521
4524
  Use your best judgement to determine if the page is signed in.
4522
4525
  `;if(t.verification_hint&&(r+=`
4523
4526
  Signed in verification hint: ${t.verification_hint}
@@ -4529,7 +4532,7 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
4529
4532
  `}t.additional_prompt&&(r+=`
4530
4533
  Additional instructions: ${t.additional_prompt}
4531
4534
  `);try{b.log("Level 3: Attempting agent-based login"),b.log(`Login prompt:
4532
- ${r}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(b.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(_,x,m,f)=>await l(_,x,m,"login")),d=!0,b.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,r,"login"),!c.success)return b.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),b.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;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 _=await Mo(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,m)=>this.run(x,m),async x=>this.getDOMText(x));_?(p=_,b.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):b.log("Failed to generate validation locators, login will still succeed")}catch(_){b.log(`Error generating validation locators: ${_.message}`)}else b.log("Skipping validation locator generation (num_verification_exprs=0)");b.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=c.actions||[],y=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:y,validation_exprs:p}}catch(l){return b.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(At(),Tt))).default,o=new n;for(let a=0;a<t.length;a++){let s=t[a];b.log(`Executing cached action ${a+1}/${t.length}: ${s.action_description||s.action_data?.action_name}`);try{if(!s.action_data){b.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,s,this.agentServices),await this.waitUntilStable(e,5e3)}catch(r){return b.error(`Cached action ${a+1} failed: ${r.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 Vi(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=ae.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));q.mkdirSync(a,{recursive:!0});let s=ae.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:s}),o.screenshot=s}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){u.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return Dt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=ae.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(q.mkdirSync(a,{recursive:!0}),t.systemPrompt){let s=ae.join(a,`system_prompt_${n}.txt`);q.writeFileSync(s,t.systemPrompt),o.system_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${s}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let s=ae.join(a,`user_prompt_${n}.txt`);q.writeFileSync(s,t.userPrompt),o.user_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${s}`)}else{let s=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),r=ae.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:s};q.writeFileSync(r,JSON.stringify(l,null,2)),o.messages_path=r,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${r}`)}if(t.rawLlmResponse){let s=i?i.replace(/[\/\\:]/g,"-"):"llm",r=ae.join(a,`${s}_response_${n}.txt`);q.writeFileSync(r,t.rawLlmResponse),o.response_path=r,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${r}`)}if(t.screenshotWithSom){let s=ae.join(a,`screenshot_${n}.png`);q.writeFileSync(s,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=s,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${s}`)}if(t.reasoningContent){let s=ae.join(a,`reasoning_${n}.txt`);q.writeFileSync(s,t.reasoningContent),o.reasoning_path=s,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${s}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(s){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,s)}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 s=o.tokenUsages?.[0]?.model,r=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,s,r);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 q.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=ae.join(e,"test-results.json");await q.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=ae.join(e,"token-usages.json");await q.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=ae.join(e,"ai-actions.json");await q.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}}});function lg(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,o=t.find(m=>m.type==="day").value,a=t.find(m=>m.type==="hour").value,s=t.find(m=>m.type==="minute").value,r=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${s}:${r}.${l}`,c=e.toISOString().slice(0,-1),h=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-h)/(1e3*60)),y=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),_=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${s}:${r}.${l}${x}${y}:${_}`}function Qa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",lg()),{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 Td=w(()=>{"use strict"});var Ad={};Ye(Ad,{ActionHandler:()=>no,ActionHelper:()=>Gi,Agent:()=>Za,AgentServices:()=>$o,AgentStepEventTypes:()=>Ja,AgentTaskFailedError:()=>Lo,BrowserManager:()=>ld,DEFAULT_EVENT_LISTENER_LIMIT:()=>An,DomService:()=>_e,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>Tn,HistoryTreeProcessor:()=>dl,INIT_SCRIPT:()=>Ge,INTERACTION_EVENT_TYPES:()=>bt,INTERACTIVE_ROLES:()=>ti,LogLevel:()=>ma,LoginType:()=>ji,MCPToolProvider:()=>Yc,OpenAIToolProvider:()=>rn,SDK_VERSION:()=>dg,ToolRegistry:()=>ft,TwoFactorAuthType:()=>Ga,VariableStore:()=>Ba,WebAgent:()=>Za,configureSdk:()=>as,createAgent:()=>cg,createAgentContext:()=>Qa,createToolRegistry:()=>jc,createToolRegistryWithCapabilities:()=>zc,discoverChromiumCdpUrl:()=>Ao,ensureToolsRegistered:()=>Bc,evaluateStatement:()=>et,executeStep:()=>Qe,exportMCPTools:()=>Jc,filterInteractionListeners:()=>Js,generateActionStep:()=>St,getActionEntityLocatorInfo:()=>F,getBrowserCdpUrl:()=>lo,getCapabilitySummary:()=>Vc,getFramePath:()=>ca,getModel:()=>Me,getPageInfo:()=>Ac,getPageWsUrl:()=>Tc,getPlatformFromDeviceName:()=>md,getProviderOptions:()=>Ie,getSdkConfig:()=>Y,getToolRegistry:()=>Kc,injectUserFunction:()=>Jo,isInteractionEventType:()=>Ys,isInteractiveRole:()=>Xs,loadKnowledgeMappings:()=>us,loadKnowledges:()=>ds,loadUserFunctions:()=>ls,logger:()=>u,newBrowserContext:()=>Ec,parseSSEStream:()=>ns,parseSdkLogLevelFromEnv:()=>rs,pickBestLocator:()=>jt,pickBestLocatorForElement:()=>un,pickBestLocators:()=>fs,registerBrowser:()=>Pt,replaceVariables:()=>So,runTask:()=>tt,setWindowBounds:()=>co,toolRegistry:()=>j,unregisterBrowser:()=>Ct});function cg(e){let t=new Ba,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=Qa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new Za(n)}var dg,er=w(()=>{"use strict";os();cs();hs();Xc();qc();Zc();Wa();Ra();Ha();Fa();cd();hd();pd();gd();Ua();Ed();li();En();kn();sn();pt();fn();bn();wn();ct();vn();Jt();qt();De();Bt();Yt();Rn();Ze();ei();ii();yt();ni();oi();Io();le();Ya();Xa();Lt();Po();Re();It();Oe();Vt();ut();Xt();Ue();dt();qa();Oa();In();Pn();Cn();$n();Ln();On();Dn();Fn();Hn();Wn();Un();ci();di();ui();mi();pi();gi();wi();yi();xi();_i();ki();Si();Ei();Ti();Ai();Mi();Ii();Ci();$i();Oi();Di();Ni();Ri();Fi();Hi();Wi();ri();Ui();Qn();vi();J();Je();G();se();vt();io();B();Td();Ee();dg="1.0.0"});var Md,Id=w(()=>{"use strict";Md=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4535
+ ${r}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(b.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(_,x,m,f)=>await l(_,x,m,"login")),d=!0,b.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,r,"login"),!c.success)return b.log("Level 3 FAILED: Agent login failed"),u.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),b.log("Restored original knowledge retriever"))}let h=await e.context().storageState(),p;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 _=await Po(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,m)=>this.run(x,m),async x=>this.getDOMText(x));_?(p=_,b.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):b.log("Failed to generate validation locators, login will still succeed")}catch(_){b.log(`Error generating validation locators: ${_.message}`)}else b.log("Skipping validation locator generation (num_verification_exprs=0)");b.log("Level 3 SUCCESS: Agent login succeeded"),u.info("Login: Agent login succeeded");let g=c.actions||[],y=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:h,cached_actions:y,validation_exprs:p}}catch(l){return b.error(`Agent login failed: ${l.message}`),u.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(Mt(),At))).default,o=new n;for(let a=0;a<t.length;a++){let s=t[a];b.log(`Executing cached action ${a+1}/${t.length}: ${s.action_description||s.action_data?.action_name}`);try{if(!s.action_data){b.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,s,this.agentServices),await this.waitUntilStable(e,5e3)}catch(r){return b.error(`Cached action ${a+1} failed: ${r.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 Vi(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=ae.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));q.mkdirSync(a,{recursive:!0});let s=ae.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:s}),o.screenshot=s}o.contextBefore=this.snapshotVariables(),this.context.stepTracking.results[t]=o}catch(o){u.warn(`createStepResult failed for step ${t}: ${o}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[],contextBefore:this.snapshotVariables()}}}}snapshotVariables(){return Nt(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys())}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return u.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=ae.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(q.mkdirSync(a,{recursive:!0}),t.systemPrompt){let s=ae.join(a,`system_prompt_${n}.txt`);q.writeFileSync(s,t.systemPrompt),o.system_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${s}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let s=ae.join(a,`user_prompt_${n}.txt`);q.writeFileSync(s,t.userPrompt),o.user_prompt_path=s,u.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${s}`)}else{let s=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),r=ae.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:s};q.writeFileSync(r,JSON.stringify(l,null,2)),o.messages_path=r,u.debug(`[saveDebugInfoToFiles] Saved messages to: ${r}`)}if(t.rawLlmResponse){let s=i?i.replace(/[\/\\:]/g,"-"):"llm",r=ae.join(a,`${s}_response_${n}.txt`);q.writeFileSync(r,t.rawLlmResponse),o.response_path=r,u.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${r}`)}if(t.screenshotWithSom){let s=ae.join(a,`screenshot_${n}.png`);q.writeFileSync(s,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=s,u.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${s}`)}if(t.reasoningContent){let s=ae.join(a,`reasoning_${n}.txt`);q.writeFileSync(s,t.reasoningContent),o.reasoning_path=s,u.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${s}`)}u.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(s){u.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,s)}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 s=o.tokenUsages?.[0]?.model,r=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,s,r);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 q.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=ae.join(e,"test-results.json");await q.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),u.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=ae.join(e,"token-usages.json");await q.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),u.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=ae.join(e,"ai-actions.json");await q.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),u.debug(`AI action details written to: ${i}`)}}catch(i){throw u.error("Failed to write execution results:",i),i}}}});function bg(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,o=t.find(m=>m.type==="day").value,a=t.find(m=>m.type==="hour").value,s=t.find(m=>m.type==="minute").value,r=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${s}:${r}.${l}`,c=e.toISOString().slice(0,-1),h=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-h)/(1e3*60)),y=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),_=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${s}:${r}.${l}${x}${y}:${_}`}function ir(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",bg()),{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 Dd=w(()=>{"use strict"});var Nd={};Je(Nd,{ActionHandler:()=>oo,ActionHelper:()=>Bi,Agent:()=>tr,AgentServices:()=>Lo,AgentStepEventTypes:()=>Va,AgentTaskFailedError:()=>Io,BrowserManager:()=>ud,DEFAULT_EVENT_LISTENER_LIMIT:()=>Mn,DomService:()=>Se,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>An,HistoryTreeProcessor:()=>pl,INIT_SCRIPT:()=>Ge,INTERACTION_EVENT_TYPES:()=>yt,INTERACTIVE_ROLES:()=>ti,LogLevel:()=>ga,LoginType:()=>Ki,MCPToolProvider:()=>Zc,OpenAIToolProvider:()=>sn,SDK_VERSION:()=>xg,ToolRegistry:()=>ft,TwoFactorAuthType:()=>Ka,VariableStore:()=>ja,WebAgent:()=>tr,configureSdk:()=>ls,createAgent:()=>yg,createAgentContext:()=>ir,createToolRegistry:()=>Xc,createToolRegistryWithCapabilities:()=>Yc,discoverChromiumCdpUrl:()=>Mo,ensureToolsRegistered:()=>zc,evaluateStatement:()=>tt,executeStep:()=>et,exportMCPTools:()=>Qc,filterInteractionListeners:()=>Qs,generateActionStep:()=>Et,getActionEntityLocatorInfo:()=>H,getBrowserCdpUrl:()=>co,getCapabilitySummary:()=>Jc,getFramePath:()=>ua,getModel:()=>fe,getPageInfo:()=>Pc,getPageWsUrl:()=>Ic,getPlatformFromDeviceName:()=>fd,getProviderOptions:()=>we,getSdkConfig:()=>Y,getToolRegistry:()=>Vc,injectUserFunction:()=>Zo,isInteractionEventType:()=>Zs,isInteractiveRole:()=>qs,loadKnowledgeMappings:()=>ps,loadKnowledges:()=>ms,loadUserFunctions:()=>us,logger:()=>u,newBrowserContext:()=>Mc,parseSSEStream:()=>rs,parseSdkLogLevelFromEnv:()=>cs,pickBestLocator:()=>zt,pickBestLocatorForElement:()=>mn,pickBestLocators:()=>_s,registerBrowser:()=>Ct,replaceVariables:()=>Ao,runTask:()=>it,setWindowBounds:()=>uo,toolRegistry:()=>K,unregisterBrowser:()=>$t});function yg(e){let t=new ja,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=ir({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new tr(n)}var xg,nr=w(()=>{"use strict";ss();hs();gs();qc();ed();td();Ba();Ha();Ua();Wa();hd();gd();wd();bd();Ga();Ld();Xa();li();Tn();Sn();ln();gt();fn();cn();yn();ut();_n();qt();Jt();De();jt();Hn();Qe();ei();ii();xt();ni();oi();Co();le();Qa();Za();Lt();$o();Re();Pt();er();wt();Pe();Xt();mt();Yt();Ue();ht();Na();Pn();Cn();$n();On();Ln();Dn();Nn();Rn();Wn();Un();Bn();di();ui();hi();mi();pi();fi();wi();bi();xi();_i();ki();Ei();Ti();Ai();Mi();Ii();Pi();Ci();Oi();Li();Di();Ni();Ri();Fi();Hi();Wi();Ui();ri();to();ci();J();qe();B();se();_t();no();G();Dd();Ae();xg="1.0.0"});var Rd,Fd=w(()=>{"use strict";Rd=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
4536
  `,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
4534
4537
  const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
4535
4538
  if (targetUrl !== null) {
@@ -4543,7 +4546,7 @@ await page.waitForTimeout(2000);
4543
4546
  `,e+=` // Goal:
4544
4547
  `;let n=t.trim().split(`
4545
4548
  `);for(let o of n)e+=` // ${o}
4546
- `;return e}generatePostlude(){return""}}});function Pd(e){if(!e)return"desktop";for(let t of pg)if(t.test(e))return"mobile";return"desktop"}var pg,Cd=w(()=>{"use strict";pg=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function $d(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var Ld=w(()=>{"use strict"});function ir(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Fe(t);for(let n of i)if(ir(n.statements))return!0}return!1}function Nd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let s=o;s.reference_id&&t.add(s.reference_id)}let a=Fe(o);for(let s of a)i(s.statements)}}return i(e),Array.from(t)}function Hd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Xe(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Xe(e.teardown,"teardown",t),t}function Ke(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],s=new Set;for(let[c]of o){let h=c===e?"":c.slice(n.length);if(!h)continue;let p=h.split(".")[0];s.has(p)||s.add(p)}let r=Array.from(s);r.sort((c,h)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(h)?parseInt(h,10):-1;return p>=0&&g>=0?p-g:c==="then"&&h==="else"?-1:c==="else"&&h==="then"||c==="body"?1:h==="body"?-1:c.localeCompare(h)});function l(c){return i[c]}function d(c){let h=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(h?h[2].trim():c)||"true"}}for(let c of r){let h=e?`${e}.${c}`:c,p=l(h),g=p?.description??"",y=h;if(c==="then"){let v=`${e}.then`,k=`${e}.else`,A=Ke(v,t,i),I=Ke(k,t,i),$=l(e),P=$?d($.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:P,then:A,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,k=Ke(v,t,i),A=l(e),I=A?d(A.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let _=`${e}.${c}`,x=t.some(([v])=>v.startsWith(_+".then.")||v===_+".then"),m=t.some(([v])=>v.startsWith(_+".else.")||v===_+".else"),f=t.some(([v])=>v.startsWith(_+".body.")||v===_+".body"),S=t.filter(([v])=>{if(!v.startsWith(_+"."))return!1;let A=v.slice(_.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(x||m){let v=_+".then",k=_+".else",A=Ke(v,t,i),I=Ke(k,t,i),$=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"IF_ELSE",condition:$,then:A,...I.length>0?{else:I}:{}})}else if(f){let v=_+".body",k=Ke(v,t,i),A=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"WHILE_LOOP",condition:A,body:k})}else if(S.length>0){let v=Ke(_,t,i);a.push({uid:h,type:"STEP",description:g||"Group",statements:v})}else a.push({uid:h,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return a}function Wd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([s])=>s===n||s.startsWith(o))?Ke(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Fe,he,je,ze,Ve,Yi,Od,Dd,gg,fg,Rd,Fd,Xe,Oo=w(()=>{"use strict";Fe=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},he=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],s=a.uid;if(s===t)return{stableId:s,path:[o],statement:a,parent:i,containerKey:n,index:o};let r=Fe(a);for(let l of r){let d=he(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},je=(e,t,i)=>{let n=he(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:s,index:r}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=ze(e,n)||Ve(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=ze(e,n)||Ve(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=ze(e,n)||Ve(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=ze(e,n)||Ve(e,n);break;default:l=ze(e,n)||Ve(e,n);break}if(a&&a.type==="WHILE_LOOP"&&s==="body"){if(!l)return a;let d=he(e,l.uid);if(!d||d.parent!==a)return a}return l},ze=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Fe(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Ve=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=he(e,i);return n?ze(e,n)||Ve(e,n):null},Yi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Fe(o);for(let s of a)i(s.statements)}};return i(e),t},Od=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}},Dd=(e,t,i)=>{if(!he(e,t))return null;if(i===null){let r=[],l=t;for(;l!==null&&he(e,l);)if(r.push(l),l=je(e,l)?.uid||null,r.length>1e3)return null;return r}if(!he(e,i))return null;if(t===i)return[];let a=[],s=t;for(;s&&s!==i;){let r=he(e,s);if(!r)break;if(a.push(s),r.statement.type==="IF_ELSE"){let l=gg(r.statement,i);l?s=je(e,s,l==="then")?.uid||null:s=je(e,s)?.uid||null}else r.statement.type==="WHILE_LOOP"?fg(r.statement,i)?s=je(e,s,!0)?.uid||null:s=je(e,s,!1)?.uid||null:s=je(e,s)?.uid||null;if(a.length>1e3)return null}return s===i?a:null},gg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&he(i.then,t)?"then":i.else&&he(i.else,t)?"else":null},fg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&he(i.body,t))};Rd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Fd=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),Xe=(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?Xe(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Xe(n.then,`${a}.then`,i),n.else&&Xe(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Xe(n.body,`${a}.body`,i))})}});function Ud(){return{version:"1.0",entries:{}}}function Gd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Bd(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 Kd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function jd(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function zd(e){return e?Object.keys(e.entries).length===0:!0}function Vd(e){return e?Object.keys(e.entries).length:0}function Xd(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=nr(e.statements??[],t),n=e.teardown?nr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function nr(e,t){return e.map(i=>wg(i,t))}function wg(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=Fe(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=nr(o.statements,t);return{...e,...n}}var Yd=w(()=>{"use strict";Oo()});function ar(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let m=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(m&&m[1]){let S=m[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,""),v=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${v}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let m=Nt(e),f=i[1].replace(/\\(.)/g,"$1");return`${m} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${Nt(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let m=Nt(e),f=o[1].replace(/\\(.)/g,"$1");return`${m} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let m=Nt(e),f=a[1].replace(/\\(.)/g,"$1");return`${m} containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let m=Nt(e),f=s[1].replace(/\\(.)/g,"$1");return`${m} not containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let m=Nt(e),f=r[1].replace(/\\(.)/g,"$1");return`${m} 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 h=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(h&&h[1])return`"${h[1].replace(/\\(.)/g,"$1")}"`;let p=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(p&&p[1])return`input with placeholder "${p[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let y=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(y&&y[1])return`"${y[1].replace(/\\(.)/g,"$1")}"`;let _=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(_&&_[1])return`"${_[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 rr(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 r=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return r.length>0?r:null}return null}function sr(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 Nt(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 or(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 bg(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function yg(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Zd(e,t){let i=e.name||"unknown",n=sr(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,s=/getByTestId\s*\(/.test(n),l=(a&&o&&s?rr(o,a):null)??ar(n),d,c,h={};switch(i){case"click":{let p=bg(t),g=yg(t);p==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),h={index:0},p&&p!=="left"&&(h.button=p),g&&(h.modifiers=g);break}case"fill":{let p=e.text||e.value||or(t)||"";d="fill",c=p?`Fill ${l} with '${p}'`:`Fill ${l}`,h={value:p,index:0};break}case"press":{let p=e.key||or(t)||"";d="press",c=`Press '${p}' on ${l}`,h={keyComb:p,index:0};break}case"selectOption":{let p=e.options?.[0]||or(t)||"";d="select_dropdown_option",c=`Select '${p}' from ${l}`,h={text:p,index:0};break}case"check":d="click_element",c=`Check ${l}`,h={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,h={index:0};break;case"setInputFiles":{let p=e.files||[];d="upload_file",c=p.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,h={paths:p,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,h={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,h={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,h={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,h={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,h={index:0};break;case"screenshot":d="wait",c="Take screenshot",h={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,h={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,h={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:h},action_description:c,url:"",feedback:""}}var Jd,qd,Qd=w(()=>{"use strict";Jd=require("uuid"),qd=()=>(0,Jd.v4)()});var T,lr,Do,cr,ot,dr,ur,hr,ce,mr,Ji,No,pr=w(()=>{"use strict";T=require("zod"),lr=T.z.enum(["JS_CODE","AI_MODE"]),Do=T.z.object({type:lr,expression:T.z.string()}),cr=T.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ot=T.z.object({uid:T.z.string(),type:cr,comment:T.z.string().optional()}),dr=T.z.object({action_data:T.z.object({action_name:T.z.string(),kwargs:T.z.record(T.z.any()).optional(),args:T.z.array(T.z.any()).optional()}),action_description:T.z.string().optional(),url:T.z.string().optional(),xpath:T.z.string().nullable().optional(),locator:T.z.string().nullable().optional(),css_selector:T.z.string().nullable().optional(),unique_selector:T.z.string().nullable().optional(),element_index:T.z.number().nullable().optional(),frame_path:T.z.array(T.z.any()).optional(),artifacts:T.z.record(T.z.any()).optional(),feedback:T.z.string().optional(),original_browser_use_action:T.z.any().optional()}).passthrough(),ur=ot.extend({type:T.z.literal("DRAFT"),description:T.z.string()}),hr=ot.extend({type:T.z.literal("ACTION"),description:T.z.string(),action_entity:dr.optional(),locator:T.z.string().optional(),use_pure_vision:T.z.boolean().optional()}),ce=T.z.lazy(()=>T.z.union([ur,hr,ot.extend({type:T.z.literal("STEP"),description:T.z.string().optional().default(""),statements:T.z.array(ce),reference_id:T.z.number().optional(),template_path:T.z.string().optional(),template_params:T.z.record(T.z.string()).optional()}),ot.extend({type:T.z.literal("IF_ELSE"),description:T.z.string().optional(),condition:Do,then:T.z.array(ce),else:T.z.array(ce).optional()}),ot.extend({type:T.z.literal("WHILE_LOOP"),description:T.z.string().optional(),condition:Do,body:T.z.array(ce),timeout_ms:T.z.number().optional()})])),mr=T.z.object({name:T.z.string(),statements:T.z.array(ce),teardown:T.z.array(ce).optional(),skip:T.z.union([T.z.boolean(),T.z.string()]).optional(),timeout:T.z.number().optional(),fail:T.z.union([T.z.boolean(),T.z.string()]).optional(),only:T.z.boolean().optional(),slow:T.z.boolean().optional()}),Ji=T.z.object({tests:T.z.array(mr).min(1),beforeAll:T.z.array(ce).optional(),afterAll:T.z.array(ce).optional(),beforeEach:T.z.array(ce).optional(),afterEach:T.z.array(ce).optional()}),No=T.z.object({comment:T.z.string().optional(),version:T.z.string().optional(),goal:T.z.string().optional(),url:T.z.string().optional(),baseURL:T.z.string().optional(),final_feedback:T.z.string().optional(),completed:T.z.boolean().optional(),success:T.z.boolean().optional(),statements:T.z.array(ce).optional(),teardown:T.z.array(ce).optional(),last_modified_at:T.z.string().optional(),testGroup:Ji.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"})});function fr(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(ye)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ye)),i}function nu(e,t){if(e.testGroup)return wr(e,t);let i=fr(e,t),n=new L.Document(i),o=n.contents?.get("tags",!0);return(0,L.isSeq)(o)&&(o.flow=!0),e.comment&&(n.commentBefore=e.comment),eu(n,e.statements??[]),e.teardown&&eu(n,e.teardown,"teardown"),n.toString(Ft)}function eu(e,t,i="statements"){let n=e.contents;if(!n||!(0,L.isMap)(n))return;let o=n.get(i,!0);(0,L.isSeq)(o)&&qi(o,t)}function qi(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),(0,L.isMap)(o)){let a=o;if(n.type==="STEP"){let s=a.get("statements",!0);(0,L.isSeq)(s)&&qi(s,n.statements)}else if(n.type==="IF_ELSE"){let s=a.get("THEN",!0);(0,L.isSeq)(s)&&qi(s,n.then);let r=a.get("ELSE",!0);(0,L.isSeq)(r)&&n.else&&qi(r,n.else)}else if(n.type==="WHILE_LOOP"){let s=a.get("DO",!0);(0,L.isSeq)(s)&&qi(s,n.body)}}}}function wr(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(ye)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(ye)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(ye)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(ye)),o.tests=i.tests.map(r=>{let l={name:r.name};return r.skip!==void 0&&(l.skip=r.skip),r.timeout!==void 0&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only!==void 0&&(l.only=r.only),r.slow!==void 0&&(l.slow=r.slow),l.statements=r.statements.map(ye),r.teardown&&r.teardown.length>0&&(l.teardown=r.teardown.map(ye)),l}),n.suite=o;let a=new L.Document(n),s=a.contents?.get("tags",!0);return(0,L.isSeq)(s)&&(s.flow=!0),a.toString(Ft)}function ou(e){return e.map(t=>(0,L.stringify)(t,Ft)).join(`---
4548
- `)}function ye(e){switch(e.type){case"DRAFT":return xg(e);case"ACTION":return au(e);case"STEP":return _g(e);case"IF_ELSE":return kg(e);case"WHILE_LOOP":return Sg(e)}}function xg(e){return{intent:e.description}}function au(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 r=i?.statement;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:r,js:l}:{VERIFY:r}}}if(t==="go_to_url"){let r=i?.url;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:r};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 r=i?.code;if(typeof r=="string"&&r.trim()&&e.description)return{description:e.description,js:r}}if(t==="ai_wait_until"){let r=i?.condition;if(typeof r=="string"){let l={WAIT_UNTIL:r};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let r=i?.seconds,d={WAIT:e.description||`Wait ${r}s`};return typeof r=="number"&&(d.seconds=r),d}if(t==="js_code"){let r=i?.code;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:r}}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 s=e.action_entity.xpath;if(s&&(o.xpath=s),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[r,l]of Object.entries(n.kwargs))r!=="uid"&&(r==="statement"&&(t==="ai_action"||t==="ai_step")||(o[r]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function ru(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=au(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?(0,L.stringify)(a,Ft).trim():""}return(0,L.stringify)(o,Ft).trim()}function su(e){let t=(0,L.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),h=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...h?{code:h}:{}}}}}}if("URL"in t){let c=String(t.URL),h={url:c};return t.new_tab===!0&&(h.new_tab=!0),typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:h}}}}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),h={condition:c};return typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:h}}}}if("WAIT"in t){let c=String(t.WAIT),h={};return typeof t.seconds=="number"&&(h.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:h}}}}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,s=Array.isArray(t.frame_path)?t.frame_path:void 0,r=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,h]of Object.entries(t))vg.has(c)||(l[c]=h);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...r&&r.length>0?{args:r}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...s?{frame_path:s}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function _g(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(ye)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function kg(e){let t={IF:lu(e.condition),THEN:e.then.map(ye)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ye)),t}function Sg(e){let t={WHILE:lu(e.condition),DO:e.body.map(ye)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function lu(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function cu(e){let t=(0,L.parseAllDocuments)(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=(0,L.parse)(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,s=typeof a.name=="string"&&a.name.trim()||void 0,r=typeof a.goal=="string"?a.goal.trim():"";if(!r)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,L.stringify)(a,Ft),d=at(l);return{name:s,goal:d.goal??r,testFlow:d}}catch{}return{name:s,goal:r}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function du(e){try{let t=(0,L.parse)(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 gr(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(gr);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]=gr(a);return n}function at(e){if(e.length>tu)throw new Error(`YAML input too large (${e.length} bytes, max ${tu})`);let t=gr((0,L.parse)(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:xe(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=xe(t.teardown));let n=No.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return br(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(r=>{if(!r.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(r.statements)||r.statements.length===0)throw new Error(`Suite test "${r.name}" must have a non-empty "statements" array`);let l={name:r.name,statements:xe(r.statements)};return Array.isArray(r.teardown)&&r.teardown.length>0&&(l.teardown=xe(r.teardown)),r.skip!==void 0&&(l.skip=r.skip),typeof r.timeout=="number"&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only===!0&&(l.only=!0),r.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=xe(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=xe(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=xe(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=xe(t.afterEach));let a=Ji.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 xe(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 Ag(t);if("WHILE"in t)return Mg(t);if("STEP"in t)return Ig(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:(0,be.v4)(),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:(0,be.v4)(),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:(0,be.v4)(),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:(0,be.v4)(),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:(0,be.v4)(),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:(0,be.v4)(),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 iu({...n,action:"function",functionName:i})}if("action"in t)return iu(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,be.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function uu(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 Ag(e){let t=uu(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,be.v4)(),type:"IF_ELSE",condition:t,then:xe(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=xe(e.ELSE)),n}function Mg(e){let t=uu(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,be.v4)(),type:"WHILE_LOOP",condition:t,body:xe(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Ig(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:(0,be.v4)(),type:"STEP",description:t,statements:xe(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,s]of Object.entries(n))o[a]=String(s);i.template_params=o}return i}function iu(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,s={};for(let[d,c]of Object.entries(e))Pg.has(d)||(s[d]=c);t==="verify"&&typeof s.js=="string"&&(s.code=s.js,delete s.js),(t==="ai_action"||t==="ai_step")&&s.statement===void 0&&(s.statement=i);let r={action_description:i,action_data:{action_name:t,kwargs:Object.keys(s).length>0?s:{}}};n&&(r.locator=n),o&&(r.xpath=o);let l={uid:(0,be.v4)(),type:"ACTION",description:i,action_entity:r};return a&&(l.use_pure_vision=!0),l}function br(e,t){let i;try{i=(0,L.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,L.isMap)(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);(0,L.isSeq)(a)&&t.statements&&Rt(a,t.statements);let s=o.get("teardown",!0);(0,L.isSeq)(s)&&t.teardown&&Rt(s,t.teardown)}function Rt(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"&&(0,L.isMap)(n)){let a=n.get("statements",!0);(0,L.isSeq)(a)&&Rt(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,L.isMap)(n)){let a=n.get("THEN",!0);(0,L.isSeq)(a)&&Rt(a,o.then);let s=n.get("ELSE",!0);(0,L.isSeq)(s)&&o.else&&Rt(s,o.else)}else if(o.type==="WHILE_LOOP"&&(0,L.isMap)(n)){let a=n.get("DO",!0);(0,L.isSeq)(a)&&Rt(a,o.body)}}}var L,be,Ft,vg,tu,Pg,Ro=w(()=>{"use strict";pr();L=require("yaml"),be=require("uuid");Ft={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};vg=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);tu=1024*1024;Pg=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function yr(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 xr(e,t){let i=yr(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((r,l)=>({...r,originalOrder:l})),a={remove:0,modify:1,insert:2},s=[...o].sort((r,l)=>r.index!==l.index?l.index-r.index:a[r.op]-a[l.op]);for(let r of s)switch(r.op){case"remove":n.splice(r.index,1);break;case"modify":n[r.index]=r.statement;break;case"insert":r.position==="before"?n.splice(r.index,0,r.statement):n.splice(r.index+1,0,r.statement);break}return n}function hu(e,t){let i=(0,Fo.parse)(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=xr(n,t);i.statements=o;let a=(0,Fo.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return at(a),{modifiedYaml:a,modifiedStatements:o}}var Fo,mu=w(()=>{"use strict";Ro();Fo=require("yaml")});function _r(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??"";vr.has(o)||t++}return{action:t,draft:i}}function $g(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function fu(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Lg(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<=pu&&o<=gu?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${pu} lines and ${gu} 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 wu(e,t){let i=t?.coverageThreshold??Cg,n=[],o=[],a;try{a=at(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.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 s=[...Yi(a.statements??[]),...a.teardown?Yi(a.teardown):[]],{action:r,draft:l}=_r(s),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of s){let g=p;if(g.reference_id!==void 0){let y=g.description||p.uid;n.push(`Unresolved cloud template reference on statement "${y}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(p.type==="ACTION"){let y=p,_=y.action_entity?.action_data?.action_name??"";if(_==="js_code"||_==="js_action"||_==="verify"||_==="ai_assert"){let x=y.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let m=$g(x);if(m){let f=y.description||_;n.push(`Invalid JS in "${f}": ${m}. ${d}`)}else if(_==="verify"){let f=Lg(x);if(f){let S=y.description||_;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(p.type==="IF_ELSE"){let y=p;if(y.condition.type==="JS_CODE"){let _=fu(y.condition.expression);_&&n.push(`Invalid JS in IF condition "${y.condition.expression}": ${_}. ${d}`)}}if(p.type==="WHILE_LOOP"){let y=p;if(y.condition.type==="JS_CODE"){let _=fu(y.condition.expression);_&&n.push(`Invalid JS in WHILE condition "${y.condition.expression}": ${_}. ${d}`)}}}let c=r+l,h=c>0?Math.round(r/c*100):0;return c>0&&h/100<i&&o.push(`Low action coverage: ${r}/${c} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:r,draft:l,coverage:h}}}var Cg,pu,gu,vr,bu=w(()=>{"use strict";Oo();Ro();Cg=.5,pu=5,gu=3,vr=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});var kr,Sr,yu,xu=w(()=>{"use strict";kr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(kr||{}),Sr=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Sr||{}),yu=18e4});function vu(e){return e?e.startsWith(ke)?"android":e.startsWith(Se)?"ios":"web":"web"}function _u(e){return e?e.startsWith(ke)||e.startsWith(Se):!1}function ku(e){return!!e&&e.startsWith(ke)}function Su(e){return!!e&&e.startsWith(Se)}function Eu(e){return e.startsWith(ke)?e.slice(ke.length):e.startsWith(Se)?e.slice(Se.length):e}function Tu(e){return`${ke}${e}`}function Au(e){return`${Se}${e}`}function Ho(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Mu(e){return e?!Ho(e):!1}function Er(e){return e?Ho(e)?["web"]:["android","ios"]:["web","android","ios"]}function Iu(e,t){if(!t)return!0;let i=Er(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var ke,Se,Wo=w(()=>{"use strict";ke="android:",Se="ios:"});function Pu(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 Cu(e){return e.startsWith(ke)?e:`${ke}${e}`}function $u(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Lu=w(()=>{"use strict";Wo()});function Ou(e){return e.startsWith(Se)?e:`${Se}${e}`}function Du(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Nu(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Ru=w(()=>{"use strict";Wo()});var Tr,Uo,Ar,Mr,Ir,Pr,Cr,$r,Lr,Or,rt,Dr,Zi,Nr,Rr,Ht,Fu,Qi,Hu,Wu,Go,Uu,Gu,Bu,Ku,ju=w(()=>{"use strict";Tr="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Uo=112,Ar=1920,Mr=1080,Ir=1920,Pr=1080-Uo,Cr=1280,$r=720,Lr=500,Or=500,rt="Desktop Chrome",Dr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Dr||{}),Zi={"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"}},Nr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Nr||{}),Rr={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},Ht=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Rr[e].map(n=>Zi[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Fu=()=>Object.keys(Zi),Qi=e=>Zi[e],Hu={desktop:{label:"Desktop",type:"desktop",devices:Ht("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Ht("mobile")}},Wu={desktop:{label:"Desktop",type:"desktop",devices:Ht("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Ht("mobile",!0)}},Go=(e,t=!1)=>{let i={userAgent:Tr,viewport:{width:Ir,height:Pr},isMobile:!1,hasTouch:!1};if(!e||e===rt)return i;let n=Qi(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max(Lr/o,1),r=Math.max(Or/a,1),l=Math.max(s,r),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}},Uu=e=>{let t={width:Ar,height:Mr};if(!e||e===rt)return t;let i=Go(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Uo}:t},Gu=e=>{let t={width:Cr,height:$r};if(!e||e===rt)return t;let i=Go(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Bu=e=>!e||e===rt?void 0:Qi(e)?.channel,Ku=e=>!e||e===rt?"chromium":Qi(e)?.defaultBrowserType??"chromium"});var Fr,Hr,zu=w(()=>{"use strict";Fr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Fr||{}),Hr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Hr||{})});var Vu,Yu=w(()=>{"use strict";Vu=class Xu{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 Xu;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 Ju(e,t=Og()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||Br,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||Ko,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||Kr}}function qu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return Bo;if(e.ANTHROPIC_API_KEY)return Wr;if(e.OPENAI_API_KEY)return Ur;if(e.SHIPLIGHT_API_TOKEN)return Ko}}function Zu(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return en;if(e.OPENAI_API_KEY)return Gr;if(e.SHIPLIGHT_API_TOKEN)return en}}var Wr,Bo,Ur,en,Gr,Br,Ko,Kr,Og,Qu=w(()=>{"use strict";Wr="claude-haiku-4-5",Bo="gemini-3.1-pro-preview",Ur="gpt-5.4-mini",en="gemini-3-flash-preview",Gr="gpt-5.4",Br="claude-sonnet-4-6",Ko=Bo,Kr=en,Og=()=>typeof process<"u"?process.env:{}});var jr,eh=w(()=>{"use strict";jr=(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))(jr||{})});var zr={};Ye(zr,{ADDRESS_BAR_HEIGHT:()=>Uo,ANDROID_DEVICE_PREFIX:()=>ke,ActionEntitySchema:()=>dr,ActionSchema:()=>hr,AgentStatus:()=>jr,BaseStatementSchema:()=>ot,BrowserType:()=>Dr,ConditionSchema:()=>Do,ConditionType:()=>Sr,ConditionTypeSchema:()=>lr,DEFAULT_ANTHROPIC_MODEL:()=>Wr,DEFAULT_COMPUTER_USE_MODEL:()=>Kr,DEFAULT_COPILOT_MODEL:()=>Br,DEFAULT_DEVICE_NAME:()=>rt,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>en,DEFAULT_GOOGLE_MODEL:()=>Bo,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Gr,DEFAULT_OPENAI_MODEL:()=>Ur,DEFAULT_WEBAGENT_MODEL:()=>Ko,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>yu,DEVICE_CATEGORIES:()=>Rr,DeviceType:()=>Nr,DraftSchema:()=>ur,IOS_DEVICE_PREFIX:()=>Se,LoginType:()=>Fr,MIN_WINDOW_HEIGHT:()=>Or,MIN_WINDOW_WIDTH:()=>Lr,NON_INTENT_ACTIONS:()=>vr,NodeJSCodeCommon:()=>Md,PLAYWRIGHT_DEVICES:()=>Zi,RECORD_VIDEO_HEIGHT:()=>$r,RECORD_VIDEO_WIDTH:()=>Cr,StatementSchema:()=>ce,StatementType:()=>kr,StatementTypeSchema:()=>cr,TestFlowSchema:()=>No,TestGroupEntrySchema:()=>mr,TestGroupSchema:()=>Ji,TwoFactorAuthType:()=>Hr,UI_DEVICE_CATEGORIES:()=>Hu,UI_DEVICE_CATEGORIES_ELECTRON:()=>Wu,USER_AGENT:()=>Tr,VIEWPORT_HEIGHT:()=>Pr,VIEWPORT_WIDTH:()=>Ir,VariableStore:()=>Vu,WINDOW_HEIGHT:()=>Mr,WINDOW_WIDTH:()=>Ar,actionEntityToYaml:()=>ru,actionStepsMapToTestFlowSections:()=>Wd,allowPureVisionAction:()=>Fd,applyPatchToYaml:()=>xr,applyPatchToYamlString:()=>hu,collectActionSteps:()=>Xe,convertPlaywrightActionToEntity:()=>Zd,countIntentStatements:()=>_r,createAndroidDeviceName:()=>Tu,createEmptyStore:()=>Ud,createIOSDeviceName:()=>Au,createRunnerStoreEntry:()=>Gd,extractActionStepsFromTestFlow:()=>Hd,extractAndAttachComments:()=>br,extractDeviceIdentifier:()=>Eu,extractElementDescription:()=>ar,extractElementDescriptionFromAriaSnapshot:()=>rr,extractLocatorFromCode:()=>sr,extractYamlMetadata:()=>du,findNextAfterContainer:()=>Ve,findNextSibling:()=>ze,findNextStatement:()=>je,findPathBetweenStatements:()=>Dd,findStatementPathById:()=>he,generateUid:()=>qd,getAllDeviceNames:()=>Fu,getAllReferenceIds:()=>Nd,getAllStatementsInOrder:()=>Yi,getAndroidDeviceDisplayName:()=>$u,getBrowserWindowSize:()=>Uu,getCompatiblePlatforms:()=>Er,getDeviceBrowserType:()=>Ku,getDeviceByName:()=>Qi,getDeviceChannel:()=>Bu,getDeviceOptions:()=>Go,getDevicesByCategory:()=>Ht,getIOSDeviceDisplayName:()=>Du,getLoginConfigPlatform:()=>Pd,getRecordVideoSize:()=>Gu,getStatementContainers:()=>Fe,getStoreSize:()=>Vd,getTestPlatformFromDeviceName:()=>vu,hasReferenceIds:()=>ir,isAndroidDevice:()=>ku,isAppPackage:()=>Mu,isDynamicAction:()=>Rd,isExecutableStatement:()=>Od,isIOSDevice:()=>Su,isNativeDevice:()=>_u,isPhysicalDeviceUDID:()=>Nu,isPlatformCompatibleWithUrl:()=>Iu,isStoreEmpty:()=>zd,isWebUrl:()=>Ho,mergeActionEntitiesIntoTestFlow:()=>Xd,mergeStoreUpdates:()=>jd,parseAdbDeviceLine:()=>Pu,parseYamlArrayItems:()=>cu,replaceVariables:()=>$d,resolveActionEntity:()=>Bd,resolveComputerUseModelFromEnv:()=>Zu,resolveModels:()=>Ju,resolveWebAgentModelFromEnv:()=>qu,suiteToYaml:()=>wr,testFlowToYaml:()=>nu,testFlowToYamlObject:()=>fr,toAndroidDeviceName:()=>Cu,toIOSDeviceName:()=>Ou,updateStoreEntry:()=>Kd,validatePatch:()=>yr,validateTestYaml:()=>wu,yamlObjectsToString:()=>ou,yamlToActionEntity:()=>su,yamlToTestFlow:()=>at});var Vr=w(()=>{"use strict";Id();Cd();Ld();Yd();Qd();mu();bu();Oo();Ro();xu();pr();Lu();Ru();Wo();ju();zu();Yu();Qu();eh()});var Fg={};Ye(Fg,{EXCLUDED_CONTEXT_OPTION_KEYS:()=>Dg,HANDLED_CONTEXT_OPTION_KEYS:()=>sh,SDK_ENV_ALLOWLIST:()=>gh,VIEWPORT_INCOMPATIBLE_OPTIONS:()=>lh,applyVarsOverride:()=>ph,buildSdkEnv:()=>fh,createTestContext:()=>uh,dropViewportIncompatibleOptions:()=>ch,expect:()=>Wt.expect,isDeclaredSensitive:()=>mh,mergeResolvedContextOptions:()=>Xr,parseVarsOverrideEnv:()=>hh,resolveAuthState:()=>rh,test:()=>Rg});module.exports=kh(Fg);var He=W(require("path"),1),oh=W(require("fs"),1),ah=require("url"),Wt=require("@playwright/test");var re=W(require("fs"),1),st=W(require("path"),1),Vo=require("crypto"),Xo=require("os");function es(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function ts(e){if(!re.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(re.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 is(e){if(e){let i=st.resolve(process.cwd(),e),n=st.join((0,Xo.tmpdir)(),`ext-profile-${(0,Vo.randomUUID)()}`);if(re.existsSync(i)){try{re.cpSync(i,n,{recursive:!0})}catch(a){try{re.rmSync(n,{recursive:!0,force:!0})}catch(s){console.warn("[fixture] Failed to clean up partial profile copy:",n,s)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=st.join(n,"SingletonLock");re.existsSync(o)&&re.rmSync(o,{force:!0})}else re.mkdirSync(n,{recursive:!0});return n}let t=st.join((0,Xo.tmpdir)(),`ext-profile-${(0,Vo.randomUUID)()}`);return re.mkdirSync(t,{recursive:!0}),t}er();var ug=W(require("dotenv"),1),hg="__shiplightDotenvCache__";function mg(){return globalThis[hg]}function tr(){let e=mg();return e===void 0?process.env:e}async function rh(e,t,i){let n=He.resolve(process.cwd(),e.auth),o=await import((0,ah.pathToFileURL)(n).href),a=o.login||o.default;if(typeof a!="function")throw new Error(`auth module "${e.auth}" must export a login(args, browser?) function that returns a storageState file path`);let s={...e.args};i&&!s.baseUrl&&(s.baseUrl=i);let r=await a(s,t);if(typeof r!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof r})`);return r}function th(e){return!(!e||e==="off")}var sh=["acceptDownloads","baseURL","bypassCSP","colorScheme","deviceScaleFactor","extraHTTPHeaders","geolocation","hasTouch","httpCredentials","ignoreHTTPSErrors","isMobile","javaScriptEnabled","locale","offline","permissions","proxy","serviceWorkers","timezoneId","userAgent","viewport"],Dg=["storageState","contextOptions","clientCertificates"],lh=[{key:"deviceScaleFactor",conflicts:e=>e!==void 0},{key:"isMobile",conflicts:e=>!!e}];function ch(e){if(e.viewport!==null)return[];let t=[];for(let{key:i,conflicts:n}of lh)n(e[i])&&(delete e[i],t.push(i));return t}function Xr(e,t){let i={...e};for(let[o,a]of Object.entries(t))a!==void 0&&(i[o]=a);let n=ch(i);return n.length>0&&console.warn(`[fixture] "viewport: null" (no fixed viewport) is incompatible with ${n.join(" and ")}; dropping ${n.length>1?"them":"it"} so the browser context can be created.`),i}function dh(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?dh(e.mode,t):!0}async function ih(e,t,i){let n=dh(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 jo;async function nh(){return jo||(jo=await Promise.resolve().then(()=>(er(),Ad)),jo)}var Ng=new Set(["get","set","getAll","has","__variableStore"]);function uh(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"||Ng.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 hh(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 mh(e,t,i){let n=s=>{if(!s||!(e in s))return null;let r=s[e];return r&&typeof r=="object"&&"value"in r?r.sensitive===!0:!1},o=n(i);if(o!==null)return o;let a=n(t);return a!==null?a:!1}function ph(e,t,i,n=process.env.SHIPLIGHT_VARS_OVERRIDE){let o=hh(n);if(o)for(let[a,s]of Object.entries(o)){let r=mh(a,t,i);e.set(a,s,r)}}var gh=["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 fh(e=tr()){let t={};for(let i of gh)t[i]=e[i]??"";return t}var Rg=Wt.test.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 Ao(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await Pt({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await Ct(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o,acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:p,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:_,javaScriptEnabled:x,locale:m,offline:f,permissions:S,proxy:v,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:$},P,H)=>{let V=i||n,Z={acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:p,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:_,javaScriptEnabled:x,locale:m,offline:f,permissions:S,proxy:v,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:$},U={};for(let O of sh){if(!(O in Z))throw new Error(`[fixture] HANDLED_CONTEXT_OPTION_KEYS lists "${O}" but the context fixture does not resolve it \u2014 add "${O}" to the fixture destructure and fixtureOptionValues so per-test use: overrides apply.`);U[O]=Z[O]}if(V){if(t||H.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 O=H.project.use?.browserName;O&&O!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${O}". Forcing Chromium.`);let Q=process.env.PLAYWRIGHT_HEADLESS==="true";i&&Q&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let ie=is(n),de=i?es(He.resolve(process.cwd(),i)):[],ne=Xr(H.project.use,U),{storageState:ve,account:K,extensionDir:ee,userDataDir:te,extensionStorageState:me,autoDismissModal:zo,video:Ut,...N}=ne,X=th(Ut)?{dir:H.outputDir}:void 0,pe;try{if(pe=await Wt.chromium.launchPersistentContext(ie,{...N,headless:Q,args:de,viewport:"viewport"in N?N.viewport:{width:1280,height:720},...X?{recordVideo:X}:{}}),o){let ge=He.resolve(process.cwd(),o),ue=ts(ge);ue&&await pe.addCookies(ue)}await P(pe)}finally{let ge=pe?.pages().map(ue=>ue.video()).filter(ue=>ue!==null)??[];if(await pe?.close().catch(ue=>{console.warn("[fixture] Failed to close persistent context:",ue)}),await ih(ge,Ut,H),!n)try{oh.rmSync(ie,{recursive:!0,force:!0})}catch(ue){console.warn("[fixture] Failed to clean up temp profile dir:",ie,ue)}}}else{let O=Xr(H.project.use,U),Q=H.project.use,ie=Q.auth?{auth:Q.auth,args:Q.args}:t;if(ie){if(!ie.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");O.storageState=await rh(ie,e,s)}let de=O.video;th(de)&&!O.recordVideo&&(O.recordVideo={dir:H.outputDir});let ne=await e.newContext(O);ne.addInitScript(Ge);try{await P(ne)}finally{let ve=ne.pages().map(K=>K.video()).filter(K=>K!==null);await ne.close(),await ih(ve,de,H)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await nh(),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)},s=i.project.use.variables;a(s),a(e),ph(o,s,e);let r=uh(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:s,configureSdk:r,parseSdkLogLevelFromEnv:l}=await nh(),d=l();r({env:fh(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:h}=await Promise.resolve().then(()=>(Vr(),zr)),p=tr(),g=c(p);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 y=h(p),_=t.__variableStore,x=s({model:g,computer_use_model:y,variableStore:_,autoDismissModal:i,downloadDir:He.join(o.outputDir,"downloads")}),m=He.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:m};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let v of S.pages())f.setupDownloadTracking(v),f.setupDialogHandling(v);S.on("page",v=>{f.setupDownloadTracking(v),f.setupDialogHandling(v)}),global.agent=f,await n(f),delete global.agent;try{let v=o.outputDir;await f.writeExecutionResults(v);let k=He.join(v,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(v){console.error("[Shiplight] Failed to attach step results:",v)}try{let v=f.getNewActionEntities();if(v.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:A}=await Promise.resolve().then(()=>(Vr(),zr)),I=await import("fs/promises"),$=k();for(let[H,V]of v)$.entries[H]=A(V,0);let P=He.join(o.outputDir,"new-action-entities.json");await I.writeFile(P,JSON.stringify($,null,2)),await o.attach("shiplight-new-action-entities",{path:P,contentType:"application/json"}),console.log(`[Shiplight] ${v.size} healed action entit${v.size===1?"y":"ies"} saved`)}}catch(v){console.warn("[Shiplight] Failed to persist new action entities:",v)}}});0&&(module.exports={EXCLUDED_CONTEXT_OPTION_KEYS,HANDLED_CONTEXT_OPTION_KEYS,SDK_ENV_ALLOWLIST,VIEWPORT_INCOMPATIBLE_OPTIONS,applyVarsOverride,buildSdkEnv,createTestContext,dropViewportIncompatibleOptions,expect,isDeclaredSensitive,mergeResolvedContextOptions,parseVarsOverrideEnv,resolveAuthState,test});
4549
+ `;return e}generatePostlude(){return""}}});function Hd(e){if(!e)return"desktop";for(let t of Sg)if(t.test(e))return"mobile";return"desktop"}var Sg,Wd=w(()=>{"use strict";Sg=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function Ud(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let s=a.startsWith("$")?a.slice(1):a,r=i[s]??i[`$${s}`];return r!=null?String(r):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,s)=>{let r=n(s.trim());return r!==void 0?r:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,s)=>{let r=n(s);return r!==void 0?r:a}),o}var Bd=w(()=>{"use strict"});function ar(e){for(let t of e){if(t.type==="STEP"){let n=t;if(n.reference_id||n.template_path)return!0}let i=Fe(t);for(let n of i)if(ar(n.statements))return!0}return!1}function Kd(e){let t=new Set;function i(n){for(let o of n){if(o.type==="STEP"){let s=o;s.reference_id&&t.add(s.reference_id)}let a=Fe(o);for(let s of a)i(s.statements)}}return i(e),Array.from(t)}function Xd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Ye(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Ye(e.teardown,"teardown",t),t}function Ke(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],s=new Set;for(let[c]of o){let h=c===e?"":c.slice(n.length);if(!h)continue;let p=h.split(".")[0];s.has(p)||s.add(p)}let r=Array.from(s);r.sort((c,h)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(h)?parseInt(h,10):-1;return p>=0&&g>=0?p-g:c==="then"&&h==="else"?-1:c==="else"&&h==="then"||c==="body"?1:h==="body"?-1:c.localeCompare(h)});function l(c){return i[c]}function d(c){let h=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(h?h[2].trim():c)||"true"}}for(let c of r){let h=e?`${e}.${c}`:c,p=l(h),g=p?.description??"",y=h;if(c==="then"){let v=`${e}.then`,k=`${e}.else`,A=Ke(v,t,i),I=Ke(k,t,i),$=l(e),P=$?d($.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:P,then:A,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,k=Ke(v,t,i),A=l(e),I=A?d(A.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:k});continue}let _=`${e}.${c}`,x=t.some(([v])=>v.startsWith(_+".then.")||v===_+".then"),m=t.some(([v])=>v.startsWith(_+".else.")||v===_+".else"),f=t.some(([v])=>v.startsWith(_+".body.")||v===_+".body"),S=t.filter(([v])=>{if(!v.startsWith(_+"."))return!1;let A=v.slice(_.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(x||m){let v=_+".then",k=_+".else",A=Ke(v,t,i),I=Ke(k,t,i),$=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"IF_ELSE",condition:$,then:A,...I.length>0?{else:I}:{}})}else if(f){let v=_+".body",k=Ke(v,t,i),A=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:h,type:"WHILE_LOOP",condition:A,body:k})}else if(S.length>0){let v=Ke(_,t,i);a.push({uid:h,type:"STEP",description:g||"Group",statements:v})}else a.push({uid:h,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return a}function Yd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([s])=>s===n||s.startsWith(o))?Ke(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Fe,he,ze,Ve,Xe,Ji,Gd,jd,Eg,Tg,zd,Vd,Ye,No=w(()=>{"use strict";Fe=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},he=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],s=a.uid;if(s===t)return{stableId:s,path:[o],statement:a,parent:i,containerKey:n,index:o};let r=Fe(a);for(let l of r){let d=he(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},ze=(e,t,i)=>{let n=he(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:s,index:r}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=Ve(e,n)||Xe(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=Ve(e,n)||Xe(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=Ve(e,n)||Xe(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=Ve(e,n)||Xe(e,n);break;default:l=Ve(e,n)||Xe(e,n);break}if(a&&a.type==="WHILE_LOOP"&&s==="body"){if(!l)return a;let d=he(e,l.uid);if(!d||d.parent!==a)return a}return l},Ve=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Fe(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Xe=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=he(e,i);return n?Ve(e,n)||Xe(e,n):null},Ji=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Fe(o);for(let s of a)i(s.statements)}};return i(e),t},Gd=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}},jd=(e,t,i)=>{if(!he(e,t))return null;if(i===null){let r=[],l=t;for(;l!==null&&he(e,l);)if(r.push(l),l=ze(e,l)?.uid||null,r.length>1e3)return null;return r}if(!he(e,i))return null;if(t===i)return[];let a=[],s=t;for(;s&&s!==i;){let r=he(e,s);if(!r)break;if(a.push(s),r.statement.type==="IF_ELSE"){let l=Eg(r.statement,i);l?s=ze(e,s,l==="then")?.uid||null:s=ze(e,s)?.uid||null}else r.statement.type==="WHILE_LOOP"?Tg(r.statement,i)?s=ze(e,s,!0)?.uid||null:s=ze(e,s,!1)?.uid||null:s=ze(e,s)?.uid||null;if(a.length>1e3)return null}return s===i?a:null},Eg=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&he(i.then,t)?"then":i.else&&he(i.else,t)?"else":null},Tg=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&he(i.body,t))};zd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),Vd=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),Ye=(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?Ye(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Ye(n.then,`${a}.then`,i),n.else&&Ye(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Ye(n.body,`${a}.body`,i))})}});function Jd(){return{version:"1.0",entries:{}}}function qd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Zd(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 Qd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function eu(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function tu(e){return e?Object.keys(e.entries).length===0:!0}function iu(e){return e?Object.keys(e.entries).length:0}function nu(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=rr(e.statements??[],t),n=e.teardown?rr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function rr(e,t){return e.map(i=>Ag(i,t))}function Ag(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=Fe(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=rr(o.statements,t);return{...e,...n}}var ou=w(()=>{"use strict";No()});function lr(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let m=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(m&&m[1]){let S=m[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,""),v=S.length>30?`${S.substring(0,27)}...`:S;return`${t[1]} element with text matching "${v}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let m=Rt(e),f=i[1].replace(/\\(.)/g,"$1");return`${m} with text "${f}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${Rt(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let m=Rt(e),f=o[1].replace(/\\(.)/g,"$1");return`${m} containing "${f}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let m=Rt(e),f=a[1].replace(/\\(.)/g,"$1");return`${m} containing "${f}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let m=Rt(e),f=s[1].replace(/\\(.)/g,"$1");return`${m} not containing "${f}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let m=Rt(e),f=r[1].replace(/\\(.)/g,"$1");return`${m} 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 h=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(h&&h[1])return`"${h[1].replace(/\\(.)/g,"$1")}"`;let p=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(p&&p[1])return`input with placeholder "${p[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let y=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(y&&y[1])return`"${y[1].replace(/\\(.)/g,"$1")}"`;let _=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(_&&_[1])return`"${_[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 cr(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4550
+ `);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let r=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return r.length>0?r:null}return null}function dr(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 Rt(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 sr(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 Mg(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function Ig(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function su(e,t){let i=e.name||"unknown",n=dr(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,s=/getByTestId\s*\(/.test(n),l=(a&&o&&s?cr(o,a):null)??lr(n),d,c,h={};switch(i){case"click":{let p=Mg(t),g=Ig(t);p==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),h={index:0},p&&p!=="left"&&(h.button=p),g&&(h.modifiers=g);break}case"fill":{let p=e.text||e.value||sr(t)||"";d="fill",c=p?`Fill ${l} with '${p}'`:`Fill ${l}`,h={value:p,index:0};break}case"press":{let p=e.key||sr(t)||"";d="press",c=`Press '${p}' on ${l}`,h={keyComb:p,index:0};break}case"selectOption":{let p=e.options?.[0]||sr(t)||"";d="select_dropdown_option",c=`Select '${p}' from ${l}`,h={text:p,index:0};break}case"check":d="click_element",c=`Check ${l}`,h={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,h={index:0};break;case"setInputFiles":{let p=e.files||[];d="upload_file",c=p.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,h={paths:p,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,h={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,h={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,h={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,h={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,h={index:0};break;case"screenshot":d="wait",c="Take screenshot",h={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,h={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,h={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:h},action_description:c,url:"",feedback:""}}var au,ru,lu=w(()=>{"use strict";au=require("uuid"),ru=()=>(0,au.v4)()});var T,ur,Ro,hr,at,mr,pr,gr,ce,fr,qi,Fo,wr=w(()=>{"use strict";T=require("zod"),ur=T.z.enum(["JS_CODE","AI_MODE"]),Ro=T.z.object({type:ur,expression:T.z.string()}),hr=T.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),at=T.z.object({uid:T.z.string(),type:hr,comment:T.z.string().optional()}),mr=T.z.object({action_data:T.z.object({action_name:T.z.string(),kwargs:T.z.record(T.z.any()).optional(),args:T.z.array(T.z.any()).optional()}),action_description:T.z.string().optional(),url:T.z.string().optional(),xpath:T.z.string().nullable().optional(),locator:T.z.string().nullable().optional(),css_selector:T.z.string().nullable().optional(),unique_selector:T.z.string().nullable().optional(),element_index:T.z.number().nullable().optional(),frame_path:T.z.array(T.z.any()).optional(),artifacts:T.z.record(T.z.any()).optional(),feedback:T.z.string().optional(),original_browser_use_action:T.z.any().optional()}).passthrough(),pr=at.extend({type:T.z.literal("DRAFT"),description:T.z.string()}),gr=at.extend({type:T.z.literal("ACTION"),description:T.z.string(),action_entity:mr.optional(),locator:T.z.string().optional(),use_pure_vision:T.z.boolean().optional()}),ce=T.z.lazy(()=>T.z.union([pr,gr,at.extend({type:T.z.literal("STEP"),description:T.z.string().optional().default(""),statements:T.z.array(ce),reference_id:T.z.number().optional(),template_path:T.z.string().optional(),template_params:T.z.record(T.z.string()).optional()}),at.extend({type:T.z.literal("IF_ELSE"),description:T.z.string().optional(),condition:Ro,then:T.z.array(ce),else:T.z.array(ce).optional()}),at.extend({type:T.z.literal("WHILE_LOOP"),description:T.z.string().optional(),condition:Ro,body:T.z.array(ce),timeout_ms:T.z.number().optional()})])),fr=T.z.object({name:T.z.string(),statements:T.z.array(ce),teardown:T.z.array(ce).optional(),skip:T.z.union([T.z.boolean(),T.z.string()]).optional(),timeout:T.z.number().optional(),fail:T.z.union([T.z.boolean(),T.z.string()]).optional(),only:T.z.boolean().optional(),slow:T.z.boolean().optional()}),qi=T.z.object({tests:T.z.array(fr).min(1),beforeAll:T.z.array(ce).optional(),afterAll:T.z.array(ce).optional(),beforeEach:T.z.array(ce).optional(),afterEach:T.z.array(ce).optional()}),Fo=T.z.object({comment:T.z.string().optional(),version:T.z.string().optional(),goal:T.z.string().optional(),url:T.z.string().optional(),baseURL:T.z.string().optional(),final_feedback:T.z.string().optional(),completed:T.z.boolean().optional(),success:T.z.boolean().optional(),statements:T.z.array(ce).optional(),teardown:T.z.array(ce).optional(),last_modified_at:T.z.string().optional(),testGroup:qi.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"})});function yr(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(ve)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ve)),i}function hu(e,t){if(e.testGroup)return xr(e,t);let i=yr(e,t),n=new O.Document(i),o=n.contents?.get("tags",!0);return(0,O.isSeq)(o)&&(o.flow=!0),e.comment&&(n.commentBefore=e.comment),cu(n,e.statements??[]),e.teardown&&cu(n,e.teardown,"teardown"),n.toString(Ht)}function cu(e,t,i="statements"){let n=e.contents;if(!n||!(0,O.isMap)(n))return;let o=n.get(i,!0);(0,O.isSeq)(o)&&Zi(o,t)}function Zi(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),(0,O.isMap)(o)){let a=o;if(n.type==="STEP"){let s=a.get("statements",!0);(0,O.isSeq)(s)&&Zi(s,n.statements)}else if(n.type==="IF_ELSE"){let s=a.get("THEN",!0);(0,O.isSeq)(s)&&Zi(s,n.then);let r=a.get("ELSE",!0);(0,O.isSeq)(r)&&n.else&&Zi(r,n.else)}else if(n.type==="WHILE_LOOP"){let s=a.get("DO",!0);(0,O.isSeq)(s)&&Zi(s,n.body)}}}}function xr(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(ve)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(ve)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(ve)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(ve)),o.tests=i.tests.map(r=>{let l={name:r.name};return r.skip!==void 0&&(l.skip=r.skip),r.timeout!==void 0&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only!==void 0&&(l.only=r.only),r.slow!==void 0&&(l.slow=r.slow),l.statements=r.statements.map(ve),r.teardown&&r.teardown.length>0&&(l.teardown=r.teardown.map(ve)),l}),n.suite=o;let a=new O.Document(n),s=a.contents?.get("tags",!0);return(0,O.isSeq)(s)&&(s.flow=!0),a.toString(Ht)}function mu(e){return e.map(t=>(0,O.stringify)(t,Ht)).join(`---
4551
+ `)}function ve(e){switch(e.type){case"DRAFT":return Pg(e);case"ACTION":return pu(e);case"STEP":return $g(e);case"IF_ELSE":return Og(e);case"WHILE_LOOP":return Lg(e)}}function Pg(e){return{intent:e.description}}function pu(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 r=i?.statement;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"&&l.trim()?{VERIFY:r,js:l}:{VERIFY:r}}}if(t==="go_to_url"){let r=i?.url;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:r};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 r=i?.code;if(typeof r=="string"&&r.trim()&&e.description)return{description:e.description,js:r}}if(t==="ai_wait_until"){let r=i?.condition;if(typeof r=="string"){let l={WAIT_UNTIL:r};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let r=i?.seconds,d={WAIT:e.description||`Wait ${r}s`};return typeof r=="number"&&(d.seconds=r),d}if(t==="js_code"){let r=i?.code;if(typeof r=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:r}}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 s=e.action_entity.xpath;if(s&&(o.xpath=s),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[r,l]of Object.entries(n.kwargs))r!=="uid"&&(r==="statement"&&(t==="ai_action"||t==="ai_step")||(o[r]=l));return n.args&&n.args.length>0&&(o.args=n.args),o}function gu(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=pu(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?(0,O.stringify)(a,Ht).trim():""}return(0,O.stringify)(o,Ht).trim()}function fu(e){let t=(0,O.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),h=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...h?{code:h}:{}}}}}}if("URL"in t){let c=String(t.URL),h={url:c};return t.new_tab===!0&&(h.new_tab=!0),typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:h}}}}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),h={condition:c};return typeof t.timeout_seconds=="number"&&(h.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:h}}}}if("WAIT"in t){let c=String(t.WAIT),h={};return typeof t.seconds=="number"&&(h.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:h}}}}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,s=Array.isArray(t.frame_path)?t.frame_path:void 0,r=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,h]of Object.entries(t))Cg.has(c)||(l[c]=h);return n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...r&&r.length>0?{args:r}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...s?{frame_path:s}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function $g(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(ve)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Og(e){let t={IF:wu(e.condition),THEN:e.then.map(ve)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ve)),t}function Lg(e){let t={WHILE:wu(e.condition),DO:e.body.map(ve)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function wu(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function bu(e){let t=(0,O.parseAllDocuments)(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=(0,O.parse)(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,s=typeof a.name=="string"&&a.name.trim()||void 0,r=typeof a.goal=="string"?a.goal.trim():"";if(!r)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,O.stringify)(a,Ht),d=rt(l);return{name:s,goal:d.goal??r,testFlow:d}}catch{}return{name:s,goal:r}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function yu(e){try{let t=(0,O.parse)(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 br(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(br);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]=br(a);return n}function rt(e){if(e.length>du)throw new Error(`YAML input too large (${e.length} bytes, max ${du})`);let t=br((0,O.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Dg(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:_e(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=_e(t.teardown));let n=Fo.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return vr(e,o),o}function Dg(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(r=>{if(!r.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(r.statements)||r.statements.length===0)throw new Error(`Suite test "${r.name}" must have a non-empty "statements" array`);let l={name:r.name,statements:_e(r.statements)};return Array.isArray(r.teardown)&&r.teardown.length>0&&(l.teardown=_e(r.teardown)),r.skip!==void 0&&(l.skip=r.skip),typeof r.timeout=="number"&&(l.timeout=r.timeout),r.fail!==void 0&&(l.fail=r.fail),r.only===!0&&(l.only=!0),r.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=_e(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=_e(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=_e(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=_e(t.afterEach));let a=qi.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 _e(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Ng)}function Ng(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 Rg(t);if("WHILE"in t)return Fg(t);if("STEP"in t)return Hg(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:(0,xe.v4)(),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:(0,xe.v4)(),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:(0,xe.v4)(),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:(0,xe.v4)(),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:(0,xe.v4)(),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:(0,xe.v4)(),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 uu({...n,action:"function",functionName:i})}if("action"in t)return uu(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,xe.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function xu(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 Rg(e){let t=xu(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,xe.v4)(),type:"IF_ELSE",condition:t,then:_e(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=_e(e.ELSE)),n}function Fg(e){let t=xu(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,xe.v4)(),type:"WHILE_LOOP",condition:t,body:_e(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Hg(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:(0,xe.v4)(),type:"STEP",description:t,statements:_e(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,s]of Object.entries(n))o[a]=String(s);i.template_params=o}return i}function uu(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,s={};for(let[d,c]of Object.entries(e))Wg.has(d)||(s[d]=c);t==="verify"&&typeof s.js=="string"&&(s.code=s.js,delete s.js),(t==="ai_action"||t==="ai_step")&&s.statement===void 0&&(s.statement=i);let r={action_description:i,action_data:{action_name:t,kwargs:Object.keys(s).length>0?s:{}}};n&&(r.locator=n),o&&(r.xpath=o);let l={uid:(0,xe.v4)(),type:"ACTION",description:i,action_entity:r};return a&&(l.use_pure_vision=!0),l}function vr(e,t){let i;try{i=(0,O.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,O.isMap)(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);(0,O.isSeq)(a)&&t.statements&&Ft(a,t.statements);let s=o.get("teardown",!0);(0,O.isSeq)(s)&&t.teardown&&Ft(s,t.teardown)}function Ft(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"&&(0,O.isMap)(n)){let a=n.get("statements",!0);(0,O.isSeq)(a)&&Ft(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,O.isMap)(n)){let a=n.get("THEN",!0);(0,O.isSeq)(a)&&Ft(a,o.then);let s=n.get("ELSE",!0);(0,O.isSeq)(s)&&o.else&&Ft(s,o.else)}else if(o.type==="WHILE_LOOP"&&(0,O.isMap)(n)){let a=n.get("DO",!0);(0,O.isSeq)(a)&&Ft(a,o.body)}}}var O,xe,Ht,Cg,du,Wg,Ho=w(()=>{"use strict";wr();O=require("yaml"),xe=require("uuid");Ht={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Cg=new Set(["intent","description","action","locator","xpath","frame_path","args","js"]);du=1024*1024;Wg=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function _r(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 kr(e,t){let i=_r(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((r,l)=>({...r,originalOrder:l})),a={remove:0,modify:1,insert:2},s=[...o].sort((r,l)=>r.index!==l.index?l.index-r.index:a[r.op]-a[l.op]);for(let r of s)switch(r.op){case"remove":n.splice(r.index,1);break;case"modify":n[r.index]=r.statement;break;case"insert":r.position==="before"?n.splice(r.index,0,r.statement):n.splice(r.index+1,0,r.statement);break}return n}function vu(e,t){let i=(0,Wo.parse)(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=kr(n,t);i.statements=o;let a=(0,Wo.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return rt(a),{modifiedYaml:a,modifiedStatements:o}}var Wo,_u=w(()=>{"use strict";Ho();Wo=require("yaml")});function Er(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??"";Sr.has(o)||t++}return{action:t,draft:i}}function Bg(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Eu(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Gg(e){let t=e.split(/\r?\n/).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("//")),i=t.length,n=t.join(`
4552
+ `).match(/\bawait\b/g),o=n?n.length:0;return i<=ku&&o<=Su?null:`${i} non-blank line(s), ${o} await(s) \u2014 limits are ${ku} lines and ${Su} 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 Tu(e,t){let i=t?.coverageThreshold??Ug,n=[],o=[],a;try{a=rt(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.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 s=[...Ji(a.statements??[]),...a.teardown?Ji(a.teardown):[]],{action:r,draft:l}=Er(s),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of s){let g=p;if(g.reference_id!==void 0){let y=g.description||p.uid;n.push(`Unresolved cloud template reference on statement "${y}" (reference_id: ${g.reference_id}). Local YAML tests cannot use reference_id \u2014 inline the template statements or use the local "template:" key instead.`)}if(p.type==="ACTION"){let y=p,_=y.action_entity?.action_data?.action_name??"";if(_==="js_code"||_==="js_action"||_==="verify"||_==="ai_assert"){let x=y.action_entity?.action_data?.kwargs?.code;if(typeof x=="string"){let m=Bg(x);if(m){let f=y.description||_;n.push(`Invalid JS in "${f}": ${m}. ${d}`)}else if(_==="verify"){let f=Gg(x);if(f){let S=y.description||_;n.push(`JS cache for "${S}" is too complex: ${f}`)}}}}}if(p.type==="IF_ELSE"){let y=p;if(y.condition.type==="JS_CODE"){let _=Eu(y.condition.expression);_&&n.push(`Invalid JS in IF condition "${y.condition.expression}": ${_}. ${d}`)}}if(p.type==="WHILE_LOOP"){let y=p;if(y.condition.type==="JS_CODE"){let _=Eu(y.condition.expression);_&&n.push(`Invalid JS in WHILE condition "${y.condition.expression}": ${_}. ${d}`)}}}let c=r+l,h=c>0?Math.round(r/c*100):0;return c>0&&h/100<i&&o.push(`Low action coverage: ${r}/${c} statements (${h}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:r,draft:l,coverage:h}}}var Ug,ku,Su,Sr,Au=w(()=>{"use strict";No();Ho();Ug=.5,ku=5,Su=3,Sr=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});var Tr,Ar,Mu,Iu=w(()=>{"use strict";Tr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Tr||{}),Ar=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Ar||{}),Mu=18e4});function Pu(e){return e?e.startsWith(Ee)?"android":e.startsWith(Te)?"ios":"web":"web"}function Cu(e){return e?e.startsWith(Ee)||e.startsWith(Te):!1}function $u(e){return!!e&&e.startsWith(Ee)}function Ou(e){return!!e&&e.startsWith(Te)}function Lu(e){return e.startsWith(Ee)?e.slice(Ee.length):e.startsWith(Te)?e.slice(Te.length):e}function Du(e){return`${Ee}${e}`}function Nu(e){return`${Te}${e}`}function Uo(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Ru(e){return e?!Uo(e):!1}function Mr(e){return e?Uo(e)?["web"]:["android","ios"]:["web","android","ios"]}function Fu(e,t){if(!t)return!0;let i=Mr(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var Ee,Te,Bo=w(()=>{"use strict";Ee="android:",Te="ios:"});function Hu(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 Wu(e){return e.startsWith(Ee)?e:`${Ee}${e}`}function Uu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Bu=w(()=>{"use strict";Bo()});function Gu(e){return e.startsWith(Te)?e:`${Te}${e}`}function ju(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Ku(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var zu=w(()=>{"use strict";Bo()});var Ir,Go,Pr,Cr,$r,Or,Lr,Dr,Nr,Rr,st,Fr,Qi,Hr,Wr,Wt,Vu,en,Xu,Yu,jo,Ju,qu,Zu,Qu,eh=w(()=>{"use strict";Ir="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Go=112,Pr=1920,Cr=1080,$r=1920,Or=1080-Go,Lr=1280,Dr=720,Nr=500,Rr=500,st="Desktop Chrome",Fr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Fr||{}),Qi={"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"}},Hr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Hr||{}),Wr={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"]},Wt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Wr[e].map(n=>Qi[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Vu=()=>Object.keys(Qi),en=e=>Qi[e],Xu={desktop:{label:"Desktop",type:"desktop",devices:Wt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Wt("mobile")}},Yu={desktop:{label:"Desktop",type:"desktop",devices:Wt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Wt("mobile",!0)}},jo=(e,t=!1)=>{let i={userAgent:Ir,viewport:{width:$r,height:Or},isMobile:!1,hasTouch:!1};if(!e||e===st)return i;let n=en(e);if(!n)return i;let{width:o,height:a}=n.viewport,s=Math.max(Nr/o,1),r=Math.max(Rr/a,1),l=Math.max(s,r),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}},Ju=e=>{let t={width:Pr,height:Cr};if(!e||e===st)return t;let i=jo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Go}:t},qu=e=>{let t={width:Lr,height:Dr};if(!e||e===st)return t;let i=jo(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Zu=e=>!e||e===st?void 0:en(e)?.channel,Qu=e=>!e||e===st?"chromium":en(e)?.defaultBrowserType??"chromium"});var Ur,Br,th=w(()=>{"use strict";Ur=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ur||{}),Br=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Br||{})});var ih,oh=w(()=>{"use strict";ih=class nh{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 nh;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 ah(e,t=jg()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||zr,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||zo,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||Vr}}function rh(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return Ko;if(e.ANTHROPIC_API_KEY)return Gr;if(e.OPENAI_API_KEY)return jr;if(e.SHIPLIGHT_API_TOKEN)return zo}}function sh(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return tn;if(e.OPENAI_API_KEY)return Kr;if(e.SHIPLIGHT_API_TOKEN)return tn}}var Gr,Ko,jr,tn,Kr,zr,zo,Vr,jg,lh=w(()=>{"use strict";Gr="claude-haiku-4-5",Ko="gemini-3.1-pro-preview",jr="gpt-5.4-mini",tn="gemini-3-flash-preview",Kr="gpt-5.4",zr="claude-sonnet-4-6",zo=Ko,Vr=tn,jg=()=>typeof process<"u"?process.env:{}});var Xr,ch=w(()=>{"use strict";Xr=(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))(Xr||{})});var Yr={};Je(Yr,{ADDRESS_BAR_HEIGHT:()=>Go,ANDROID_DEVICE_PREFIX:()=>Ee,ActionEntitySchema:()=>mr,ActionSchema:()=>gr,AgentStatus:()=>Xr,BaseStatementSchema:()=>at,BrowserType:()=>Fr,ConditionSchema:()=>Ro,ConditionType:()=>Ar,ConditionTypeSchema:()=>ur,DEFAULT_ANTHROPIC_MODEL:()=>Gr,DEFAULT_COMPUTER_USE_MODEL:()=>Vr,DEFAULT_COPILOT_MODEL:()=>zr,DEFAULT_DEVICE_NAME:()=>st,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>tn,DEFAULT_GOOGLE_MODEL:()=>Ko,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Kr,DEFAULT_OPENAI_MODEL:()=>jr,DEFAULT_WEBAGENT_MODEL:()=>zo,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Mu,DEVICE_CATEGORIES:()=>Wr,DeviceType:()=>Hr,DraftSchema:()=>pr,IOS_DEVICE_PREFIX:()=>Te,LoginType:()=>Ur,MIN_WINDOW_HEIGHT:()=>Rr,MIN_WINDOW_WIDTH:()=>Nr,NON_INTENT_ACTIONS:()=>Sr,NodeJSCodeCommon:()=>Rd,PLAYWRIGHT_DEVICES:()=>Qi,RECORD_VIDEO_HEIGHT:()=>Dr,RECORD_VIDEO_WIDTH:()=>Lr,StatementSchema:()=>ce,StatementType:()=>Tr,StatementTypeSchema:()=>hr,TestFlowSchema:()=>Fo,TestGroupEntrySchema:()=>fr,TestGroupSchema:()=>qi,TwoFactorAuthType:()=>Br,UI_DEVICE_CATEGORIES:()=>Xu,UI_DEVICE_CATEGORIES_ELECTRON:()=>Yu,USER_AGENT:()=>Ir,VIEWPORT_HEIGHT:()=>Or,VIEWPORT_WIDTH:()=>$r,VariableStore:()=>ih,WINDOW_HEIGHT:()=>Cr,WINDOW_WIDTH:()=>Pr,actionEntityToYaml:()=>gu,actionStepsMapToTestFlowSections:()=>Yd,allowPureVisionAction:()=>Vd,applyPatchToYaml:()=>kr,applyPatchToYamlString:()=>vu,collectActionSteps:()=>Ye,convertPlaywrightActionToEntity:()=>su,countIntentStatements:()=>Er,createAndroidDeviceName:()=>Du,createEmptyStore:()=>Jd,createIOSDeviceName:()=>Nu,createRunnerStoreEntry:()=>qd,extractActionStepsFromTestFlow:()=>Xd,extractAndAttachComments:()=>vr,extractDeviceIdentifier:()=>Lu,extractElementDescription:()=>lr,extractElementDescriptionFromAriaSnapshot:()=>cr,extractLocatorFromCode:()=>dr,extractYamlMetadata:()=>yu,findNextAfterContainer:()=>Xe,findNextSibling:()=>Ve,findNextStatement:()=>ze,findPathBetweenStatements:()=>jd,findStatementPathById:()=>he,generateUid:()=>ru,getAllDeviceNames:()=>Vu,getAllReferenceIds:()=>Kd,getAllStatementsInOrder:()=>Ji,getAndroidDeviceDisplayName:()=>Uu,getBrowserWindowSize:()=>Ju,getCompatiblePlatforms:()=>Mr,getDeviceBrowserType:()=>Qu,getDeviceByName:()=>en,getDeviceChannel:()=>Zu,getDeviceOptions:()=>jo,getDevicesByCategory:()=>Wt,getIOSDeviceDisplayName:()=>ju,getLoginConfigPlatform:()=>Hd,getRecordVideoSize:()=>qu,getStatementContainers:()=>Fe,getStoreSize:()=>iu,getTestPlatformFromDeviceName:()=>Pu,hasReferenceIds:()=>ar,isAndroidDevice:()=>$u,isAppPackage:()=>Ru,isDynamicAction:()=>zd,isExecutableStatement:()=>Gd,isIOSDevice:()=>Ou,isNativeDevice:()=>Cu,isPhysicalDeviceUDID:()=>Ku,isPlatformCompatibleWithUrl:()=>Fu,isStoreEmpty:()=>tu,isWebUrl:()=>Uo,mergeActionEntitiesIntoTestFlow:()=>nu,mergeStoreUpdates:()=>eu,parseAdbDeviceLine:()=>Hu,parseYamlArrayItems:()=>bu,replaceVariables:()=>Ud,resolveActionEntity:()=>Zd,resolveComputerUseModelFromEnv:()=>sh,resolveModels:()=>ah,resolveWebAgentModelFromEnv:()=>rh,suiteToYaml:()=>xr,testFlowToYaml:()=>hu,testFlowToYamlObject:()=>yr,toAndroidDeviceName:()=>Wu,toIOSDeviceName:()=>Gu,updateStoreEntry:()=>Qd,validatePatch:()=>_r,validateTestYaml:()=>Tu,yamlObjectsToString:()=>mu,yamlToActionEntity:()=>fu,yamlToTestFlow:()=>rt});var Jr=w(()=>{"use strict";Fd();Wd();Bd();ou();lu();_u();Au();No();Ho();Iu();wr();Bu();zu();Bo();eh();th();oh();lh();ch()});var Xg={};Je(Xg,{EXCLUDED_CONTEXT_OPTION_KEYS:()=>Kg,HANDLED_CONTEXT_OPTION_KEYS:()=>fh,SDK_ENV_ALLOWLIST:()=>Sh,VIEWPORT_INCOMPATIBLE_OPTIONS:()=>wh,applyVarsOverride:()=>kh,buildSdkEnv:()=>Eh,createTestContext:()=>xh,dropViewportIncompatibleOptions:()=>bh,expect:()=>Ut.expect,isDeclaredSensitive:()=>_h,mergeResolvedContextOptions:()=>qr,parseVarsOverrideEnv:()=>vh,resolveAuthState:()=>gh,test:()=>Vg});module.exports=$h(Xg);var He=F(require("path"),1),mh=F(require("fs"),1),ph=require("url"),Ut=require("@playwright/test");var re=F(require("fs"),1),lt=F(require("path"),1),Yo=require("crypto"),Jo=require("os");function ns(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function os(e){if(!re.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(re.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 as(e){if(e){let i=lt.resolve(process.cwd(),e),n=lt.join((0,Jo.tmpdir)(),`ext-profile-${(0,Yo.randomUUID)()}`);if(re.existsSync(i)){try{re.cpSync(i,n,{recursive:!0})}catch(a){try{re.rmSync(n,{recursive:!0,force:!0})}catch(s){console.warn("[fixture] Failed to clean up partial profile copy:",n,s)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=lt.join(n,"SingletonLock");re.existsSync(o)&&re.rmSync(o,{force:!0})}else re.mkdirSync(n,{recursive:!0});return n}let t=lt.join((0,Jo.tmpdir)(),`ext-profile-${(0,Yo.randomUUID)()}`);return re.mkdirSync(t,{recursive:!0}),t}nr();var vg=F(require("dotenv"),1),_g="__shiplightDotenvCache__";function kg(){return globalThis[_g]}function or(){let e=kg();return e===void 0?process.env:e}async function gh(e,t,i){let n=He.resolve(process.cwd(),e.auth),o=await import((0,ph.pathToFileURL)(n).href),a=o.login||o.default;if(typeof a!="function")throw new Error(`auth module "${e.auth}" must export a login(args, browser?) function that returns a storageState file path`);let s={...e.args};i&&!s.baseUrl&&(s.baseUrl=i);let r=await a(s,t);if(typeof r!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof r})`);return r}function dh(e){return!(!e||e==="off")}var fh=["acceptDownloads","baseURL","bypassCSP","colorScheme","deviceScaleFactor","extraHTTPHeaders","geolocation","hasTouch","httpCredentials","ignoreHTTPSErrors","isMobile","javaScriptEnabled","locale","offline","permissions","proxy","serviceWorkers","timezoneId","userAgent","viewport"],Kg=["storageState","contextOptions","clientCertificates"],wh=[{key:"deviceScaleFactor",conflicts:e=>e!==void 0},{key:"isMobile",conflicts:e=>!!e}];function bh(e){if(e.viewport!==null)return[];let t=[];for(let{key:i,conflicts:n}of wh)n(e[i])&&(delete e[i],t.push(i));return t}function qr(e,t){let i={...e};for(let[o,a]of Object.entries(t))a!==void 0&&(i[o]=a);let n=bh(i);return n.length>0&&console.warn(`[fixture] "viewport: null" (no fixed viewport) is incompatible with ${n.join(" and ")}; dropping ${n.length>1?"them":"it"} so the browser context can be created.`),i}function yh(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?yh(e.mode,t):!0}async function uh(e,t,i){let n=yh(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 Vo;async function hh(){return Vo||(Vo=await Promise.resolve().then(()=>(nr(),Nd)),Vo)}var zg=new Set(["get","set","getAll","has","__variableStore"]);function xh(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"||zg.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 vh(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 _h(e,t,i){let n=s=>{if(!s||!(e in s))return null;let r=s[e];return r&&typeof r=="object"&&"value"in r?r.sensitive===!0:!1},o=n(i);if(o!==null)return o;let a=n(t);return a!==null?a:!1}function kh(e,t,i,n=process.env.SHIPLIGHT_VARS_OVERRIDE){let o=vh(n);if(o)for(let[a,s]of Object.entries(o)){let r=_h(a,t,i);e.set(a,s,r)}}var Sh=["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 Eh(e=or()){let t={};for(let i of Sh)t[i]=e[i]??"";return t}var Vg=Ut.test.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.OMNITERM_BROWSER_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.OMNITERM_BROWSER_REGISTRY_URL)try{let n=await Mo(process.pid),o=process.env.TEST_WORKER_INDEX??"?";i=await Ct({cdpUrl:n,label:`shiplight test w${o}`,pid:process.pid})}catch{}await t(e),await $t(i)},context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o,acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:p,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:_,javaScriptEnabled:x,locale:m,offline:f,permissions:S,proxy:v,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:$},P,W)=>{let V=i||n,Z={acceptDownloads:a,baseURL:s,bypassCSP:r,colorScheme:l,deviceScaleFactor:d,extraHTTPHeaders:c,geolocation:h,hasTouch:p,httpCredentials:g,ignoreHTTPSErrors:y,isMobile:_,javaScriptEnabled:x,locale:m,offline:f,permissions:S,proxy:v,serviceWorkers:k,timezoneId:A,userAgent:I,viewport:$},U={};for(let L of fh){if(!(L in Z))throw new Error(`[fixture] HANDLED_CONTEXT_OPTION_KEYS lists "${L}" but the context fixture does not resolve it \u2014 add "${L}" to the fixture destructure and fixtureOptionValues so per-test use: overrides apply.`);U[L]=Z[L]}if(V){if(t||W.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=W.project.use?.browserName;L&&L!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${L}". Forcing Chromium.`);let Q=process.env.PLAYWRIGHT_HEADLESS==="true";i&&Q&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let ie=as(n),de=i?ns(He.resolve(process.cwd(),i)):[],ne=qr(W.project.use,U),{storageState:ke,account:j,extensionDir:ee,userDataDir:te,extensionStorageState:me,autoDismissModal:Xo,video:Bt,...N}=ne,X=dh(Bt)?{dir:W.outputDir}:void 0,pe;try{if(pe=await Ut.chromium.launchPersistentContext(ie,{...N,headless:Q,args:de,viewport:"viewport"in N?N.viewport:{width:1280,height:720},...X?{recordVideo:X}:{}}),o){let ge=He.resolve(process.cwd(),o),ue=os(ge);ue&&await pe.addCookies(ue)}await P(pe)}finally{let ge=pe?.pages().map(ue=>ue.video()).filter(ue=>ue!==null)??[];if(await pe?.close().catch(ue=>{console.warn("[fixture] Failed to close persistent context:",ue)}),await uh(ge,Bt,W),!n)try{mh.rmSync(ie,{recursive:!0,force:!0})}catch(ue){console.warn("[fixture] Failed to clean up temp profile dir:",ie,ue)}}}else{let L=qr(W.project.use,U),Q=W.project.use,ie=Q.auth?{auth:Q.auth,args:Q.args}:t;if(ie){if(!ie.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 gh(ie,e,s)}let de=L.video;dh(de)&&!L.recordVideo&&(L.recordVideo={dir:W.outputDir});let ne=await e.newContext(L);ne.addInitScript(Ge);try{await P(ne)}finally{let ke=ne.pages().map(j=>j.video()).filter(j=>j!==null);await ne.close(),await uh(ke,de,W)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({variables:e},t,i)=>{let{VariableStore:n}=await hh(),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)},s=i.project.use.variables;a(s),a(e),kh(o,s,e);let r=xh(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:s,configureSdk:r,parseSdkLogLevelFromEnv:l}=await hh(),d=l();r({env:Eh(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:h}=await Promise.resolve().then(()=>(Jr(),Yr)),p=or(),g=c(p);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 y=h(p),_=t.__variableStore,x=s({model:g,computer_use_model:y,variableStore:_,autoDismissModal:i,downloadDir:He.join(o.outputDir,"downloads")}),m=He.join(o.outputDir,"artifacts");x.stepTracking={results:{},artifactsDir:m};let f=new a(x),S=e.context();f.agentServices.setupPageTracking(S);for(let v of S.pages())f.setupDownloadTracking(v),f.setupDialogHandling(v);S.on("page",v=>{f.setupDownloadTracking(v),f.setupDialogHandling(v)}),global.agent=f,await n(f),delete global.agent;try{let v=o.outputDir;await f.writeExecutionResults(v);let k=He.join(v,"test-results.json");await(await import("fs/promises")).stat(k).catch(()=>null)&&await o.attach("shiplight-results",{path:k,contentType:"application/json"})}catch(v){console.error("[Shiplight] Failed to attach step results:",v)}try{let v=f.getNewActionEntities();if(v.size>0&&o.status==="passed"){let{createEmptyStore:k,createRunnerStoreEntry:A}=await Promise.resolve().then(()=>(Jr(),Yr)),I=await import("fs/promises"),$=k();for(let[W,V]of v)$.entries[W]=A(V,0);let P=He.join(o.outputDir,"new-action-entities.json");await I.writeFile(P,JSON.stringify($,null,2)),await o.attach("shiplight-new-action-entities",{path:P,contentType:"application/json"}),console.log(`[Shiplight] ${v.size} healed action entit${v.size===1?"y":"ies"} saved`)}}catch(v){console.warn("[Shiplight] Failed to persist new action entities:",v)}}});0&&(module.exports={EXCLUDED_CONTEXT_OPTION_KEYS,HANDLED_CONTEXT_OPTION_KEYS,SDK_ENV_ALLOWLIST,VIEWPORT_INCOMPATIBLE_OPTIONS,applyVarsOverride,buildSdkEnv,createTestContext,dropViewportIncompatibleOptions,expect,isDeclaredSensitive,mergeResolvedContextOptions,parseVarsOverrideEnv,resolveAuthState,test});