shiplightai 0.1.49 → 0.1.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/fixture.js CHANGED
@@ -1,11 +1,11 @@
1
1
  import { createRequire as __createRequire } from "module";
2
2
  const require = __createRequire(import.meta.url);
3
- var cu=Object.defineProperty;var y=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ze=(e,t)=>{for(var i in t)cu(e,i,{get:t[i],enumerable:!0})};function pr(e){ga.updateConfig(e)}function W(){return ga.getConfig()}function gr(){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 du,ga,Li,Q=y(()=>{"use strict";du=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}},ga=new du,Li=ga});var uu,hu,h,N=y(()=>{"use strict";Q();uu=class{getLevel(){return Li.get("logLevel")}isStderrOnly(){return Li.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){Li.set("logLevel",e)}},hu=new uu,h=hu});import*as fr from"fs/promises";import*as et from"vm";async function mu(e,t){let i=await import(e),n=Object.keys(i),a=new et.SyntheticModule(n,function(){for(let o of n)this.setExport(o,i[o])},{context:t});return await a.link(()=>{throw new Error("Nested imports not supported in VM context")}),await a.evaluate(),a}function fa(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let a;if(et.isContext(e)?a=new et.Script(i,{importModuleDynamically:async o=>mu(o,e)}).runInContext(e):a=(0,eval)(i),typeof a!="function")throw new Error("The injected code must be a function");e[t]=a}catch(a){h.error(`Error injecting user function ${t}: ${a.message}`)}}async function wr(e,t,i=!1){try{let n=await fr.readFile(t,"utf8"),a=JSON.parse(n);h.info(`Loading ${Object.keys(a).length} user functions...`);for(let[o,r]of Object.entries(a))fa(e,o,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var br=y(()=>{"use strict";N()});import*as wa from"fs/promises";async function yr(e){try{let t=await wa.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function xr(e){try{let t=await wa.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var vr=y(()=>{"use strict";N()});async function kr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,a="";try{for(;;){let{done:o,value:r}=await i.read();if(o)break;a+=n.decode(r,{stream:!0});let s=a.split(`
4
- `);a=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var _r=y(()=>{"use strict"});import{appendFileSync as Sr}from"fs";var pu,w,ee=y(()=>{"use strict";Q();pu=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=W().agentLogPath;if(e)try{Sr(e,`
3
+ var lu=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ze=(e,t)=>{for(var i in t)lu(e,i,{get:t[i],enumerable:!0})};function mr(e){ga.updateConfig(e)}function W(){return ga.getConfig()}function pr(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var cu,ga,Li,Q=b(()=>{"use strict";cu=class{constructor(){this.config=this.getDefaultConfig()}getDefaultConfig(){return{logLevel:1,debugAgent:!1,testResultsJsonPath:void 0,consoleLogsPath:void 0}}getConfig(){return{...this.config}}updateConfig(e){this.config={...this.config,...e}}resetConfig(){this.config=this.getDefaultConfig()}get(e){return this.config[e]}set(e,t){this.config[e]=t}},ga=new cu,Li=ga});var du,uu,h,N=b(()=>{"use strict";Q();du=class{getLevel(){return Li.get("logLevel")}isStderrOnly(){return Li.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){Li.set("logLevel",e)}},uu=new du,h=uu});import*as gr from"fs/promises";import*as et from"vm";async function hu(e,t){let i=await import(e),n=Object.keys(i),a=new et.SyntheticModule(n,function(){for(let o of n)this.setExport(o,i[o])},{context:t});return await a.link(()=>{throw new Error("Nested imports not supported in VM context")}),await a.evaluate(),a}function fa(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let a;if(et.isContext(e)?a=new et.Script(i,{importModuleDynamically:async o=>hu(o,e)}).runInContext(e):a=(0,eval)(i),typeof a!="function")throw new Error("The injected code must be a function");e[t]=a}catch(a){h.error(`Error injecting user function ${t}: ${a.message}`)}}async function fr(e,t,i=!1){try{let n=await gr.readFile(t,"utf8"),a=JSON.parse(n);h.info(`Loading ${Object.keys(a).length} user functions...`);for(let[o,r]of Object.entries(a))fa(e,o,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var wr=b(()=>{"use strict";N()});import*as wa from"fs/promises";async function br(e){try{let t=await wa.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function yr(e){try{let t=await wa.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var xr=b(()=>{"use strict";N()});async function vr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,a="";try{for(;;){let{done:o,value:r}=await i.read();if(o)break;a+=n.decode(r,{stream:!0});let s=a.split(`
4
+ `);a=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var kr=b(()=>{"use strict"});import{appendFileSync as _r}from"fs";var mu,f,ee=b(()=>{"use strict";Q();mu=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=W().agentLogPath;if(e)try{_r(e,`
5
5
  === Agent Execution Log ===
6
6
  Started: ${new Date().toISOString()}
7
7
 
8
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=W().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();Sr(t,`[${i}] ${e}
8
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=W().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();_r(t,`[${i}] ${e}
9
9
  `)}catch{}}}section(e){this.log(`
10
10
  ${"=".repeat(60)}
11
11
  ${e}
@@ -14,9 +14,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
14
14
  ${e}`),this.log(`
15
15
  User Prompt:
16
16
  ${t}`)}response(e){this.log(`LLM Response:
17
- ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!W().agentLogPath}},w=new pu});var Oi,gu,fu,wu,bu,Er,Ni,ba,Tr,ya,xa,me=y(()=>{"use strict";Oi=Object.defineProperty,gu=Object.getOwnPropertyDescriptor,fu=Object.getOwnPropertyNames,wu=Object.prototype.hasOwnProperty,bu=(e,t,i)=>t in e?Oi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Er=(e,t)=>()=>(e&&(t=e(e=0)),t),Ni=(e,t)=>{for(var i in t)Oi(e,i,{get:t[i],enumerable:!0})},ba=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of fu(t))!wu.call(e,a)&&a!==i&&Oi(e,a,{get:()=>t[a],enumerable:!(n=gu(t,a))||n.enumerable});return e},Tr=(e,t,i)=>(ba(e,t,"default"),i&&ba(i,t,"default")),ya=e=>ba(Oi({},"__esModule",{value:!0}),e),xa=(e,t,i)=>bu(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??ka}function yu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function L(e,t){let i=$e(t);return i?new Function("page",`return ${i}`)(e):null}async function va(e,t=[]){let i=e;for(let n of t){let a=await i.locator(n).elementHandle();if(!a)return null;let o=await a.contentFrame();if(await a.dispose(),!o)return null;i=o}return i}function xu(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 vu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function ku(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 $e(e){let t=vu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=ku(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var Ri,St,ka,pe,P,R=y(()=>{"use strict";me();Ri={};Ni(Ri,{ACTION_TIMEOUT:()=>ka,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>St,getActionTimeoutMs:()=>D,getFrameContext:()=>va,getLocator:()=>L,getMinimalActionEntity:()=>xu,getPageLocatorExpression:()=>$e,sanitizeForComment:()=>yu});P=Er(()=>{St=5e3,ka=1e4,pe=2e4})});async function Et(e,t,i=[],n=[]){try{let a=await va(e,i);if(!a)return h.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${Ar(s)}`),d=_u(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Ar(t)}`)).elementHandle({timeout:St}),!o)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:St}),!o)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return h.error(`Error in pickBestLocator: ${a}`),null}}async function Fi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Mr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let a=await Et(e,n);i.set(n,a)})),i}function Ar(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function _u(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Be=y(()=>{"use strict";N();R();P()});async function Tt(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:a}=await import("sharp"),o=a(n),{width:r=0,height:s=0}=await o.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ke(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function Hi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Fi(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Wi(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 tt=y(()=>{"use strict";ee();Be()});import{createGoogleGenerativeAI as Su}from"@ai-sdk/google";import{createVertex as Eu}from"@ai-sdk/google-vertex";function Bi(){let e=(W().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Cr(e){let t=W().env||{};if(Bi()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Eu({project:n,location:a})(e)}let i=t.GOOGLE_API_KEY;if(!i)throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.");return h.debug(`Using Google AI provider (API key): model=${e}`),Su({apiKey:i})(e)}function Pr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ir.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Ir.MEDIA_RESOLUTION_HIGH)}return Bi()?{vertex:a}:{google:a}}var Ir,it=y(()=>{"use strict";N();Q();Ir={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Tu,Environment as Au}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function Iu(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=ge(i.x,n),l=ge(i.y,a),d=ge(i.destination_x,n),c=ge(i.destination_y,a),u=await ke(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Hi(e,r)}}async function Dr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||Cu,l=W(),d;if(Bi()){let b=l.env?.GOOGLE_CLOUD_PROJECT;if(!b)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let _=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:b,location:_}}else{let b=l.env?.GOOGLE_API_KEY;if(!b)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};d={apiKey:b}}let c=new Tu(d);w.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Au.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Mu}],temperature:.1}});w.log("Received response from Gemini CUA");let p=u.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(b=>b.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(b=>b.text).map(b=>b.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:k}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(k)}`),h.debug(`Generated function call: ${f} with args ${JSON.stringify(k)}`);let{action_data:x,locatorInfo:m}=await Iu(i,f,k,a,o);return x?{status:"success",actionEntity:Wi(t,x,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var $r,Mu,Cu,Ui=y(()=>{"use strict";tt();ee();it();N();Q();$r={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"]},Mu=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:$r},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:$r}];Cu="gemini-3-flash-preview"});function Or(e){return e!=null&&typeof e=="object"}function nt(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Lr(e){return typeof e=="string"?e:void 0}function Pu(e){let t,i;return Array.isArray(e)?(t=nt(e[0]),i=nt(e[1])):Or(e)&&(t=nt(e.x),i=nt(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Nr(e){if(!Or(e))return{};let t=Array.isArray(e.path)?e.path.map(Pu).filter(i=>i!==null):void 0;return{type:Lr(e.type),x:nt(e.x),y:nt(e.y),button:Lr(e.button),path:t}}var Gi=y(()=>{"use strict"});import $u from"openai";async function Du(e,t){let i=Nr(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ke(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ke(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ke(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=s.element;break}}return{action_data:n,locatorInfo:await Hi(e,a)}}async function Fr(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||Lu,s=await Tt(i,n,a),l=W().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=new $u({apiKey:l}),c=d.responses.create.bind(d.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let u=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function p(m,b){let _={model:r,tools:[Ou],input:m,temperature:.1};return b&&(_.previous_response_id=b),c(_)}let g=await p(u,void 0),f;for(let m=0;m<Rr;m++){w.log(`Received response from OpenAI CUA (turn ${m+1})`);let b=g.output.find(S=>S.type==="computer_call");if(!b)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let _=b.actions??[];if(_.length>1&&w.log(`[openai CUA] dropping ${_.length-1} batched action(s); only the first is executed`),f=_[0],!f)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(f.type!=="screenshot")break;s=await Tt(i,n,a);let v=[{type:"computer_call_output",call_id:b.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];g=await p(v,g.id)}if(!f)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(f.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Rr} turns`};w.log(`Generated action: ${JSON.stringify(f)}`);let{action_data:k,locatorInfo:x}=await Du(i,f);return k?{status:"success",actionEntity:Wi(t,k,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(f)}`}}var Lu,Ou,Rr,Ki=y(()=>{"use strict";Gi();tt();ee();Q();Lu="gpt-5.4",Ou={type:"computer"},Rr=4});import{createOpenAI as Nu}from"@ai-sdk/openai";function Hr(e){let t=W(),i=t.env?.OPENAI_API_KEY;if(!i)throw new Error("OPENAI_API_KEY not configured in SDK config");let n=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),Nu({apiKey:i,baseURL:n})(e)}function Wr(e){return{}}var At=y(()=>{"use strict";N();Q()});import{createAnthropic as Ru}from"@ai-sdk/anthropic";import{createVertexAnthropic as Fu}from"@ai-sdk/google-vertex/anthropic";function Hu(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function _a(e){return W().env?.[e]??process.env[e]}function Wu(){return Hu(_a("ANTHROPIC_MODELS_USE_VERTEXAI"))}function Br(e){if(Wu()){let i=_a("GOOGLE_CLOUD_PROJECT"),n=_a("GOOGLE_CLOUD_LOCATION");if(!i)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!n)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${i}, location=${n}`),Fu({project:i,location:n})(e)}let t=W().env?.ANTHROPIC_API_KEY;if(!t)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return h.debug(`Using Anthropic provider: model=${e}`),Ru({apiKey:t})(e)}function Sa(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Mt=y(()=>{"use strict";N();Q()});function Gr(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Bu.test(e))return"openai"}function ji(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Uu.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=ji(e),n=t??Gr(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 a=Ur[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Ur).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function we(e,t){let{provider:i,modelId:n}=ji(e),a=i??Gr(n);return a==="anthropic"||a==="vertex"?Sa(n):a==="openai"||a==="azure"?Wr(n):a==="bedrock"?n.startsWith("anthropic.")?Sa(n):{}:Pr(t,n)}var Bu,Uu,Ur,_e=y(()=>{"use strict";At();Mt();it();Bu=/^(gpt-|o\d|chatgpt-)/;Uu=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Ur={anthropic:Br,google:Cr,openai:Hr}});function Ku(e){return e.startsWith("gemini-")?"google":"openai"}async function at(e,t,i={}){let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=a;w.log(`Viewport: ${o}x${r}`);let s=await Tt(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=ji(l),c=Ku(d),u=Gu[c];w.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:d};try{return await u(p)}catch(g){return w.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Gu,ot=y(()=>{"use strict";Ui();Ki();tt();ee();_e();Gu={google:Dr,openai:Fr}});import{zodToJsonSchema as Kr}from"zod-to-json-schema";function zi(e){let t=Kr(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return It(t),t}function Vi(e){return Kr(e,{$refStrategy:"none"})}function It(e){if(!(typeof e!="object"||e===null)){if(e.type==="object"&&(e.additionalProperties=!1,e.properties)){let t=Object.keys(e.properties);e.required=t;for(let i of Object.values(e.properties))It(i)}e.type==="array"&&e.items&&It(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(It);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&It(i)}}var Ct=y(()=>{"use strict"});var Xi,Yi=y(()=>{"use strict";Ct();Xi=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:zi(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:zi(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:zi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function ju(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,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(o,r.index);l&&a.push({type:"text",text:l});let d=r[2];i.has(d)?a.push({type:"image",image:new URL(i.get(d))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&a.push({type:"text",text:s}),a.length===0&&a.push({type:"text",text:e}),a}function zu(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=ju(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
17
+ ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!W().agentLogPath}},f=new mu});var Oi,pu,gu,fu,wu,Sr,Ni,ba,Er,ya,xa,me=b(()=>{"use strict";Oi=Object.defineProperty,pu=Object.getOwnPropertyDescriptor,gu=Object.getOwnPropertyNames,fu=Object.prototype.hasOwnProperty,wu=(e,t,i)=>t in e?Oi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Sr=(e,t)=>()=>(e&&(t=e(e=0)),t),Ni=(e,t)=>{for(var i in t)Oi(e,i,{get:t[i],enumerable:!0})},ba=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of gu(t))!fu.call(e,a)&&a!==i&&Oi(e,a,{get:()=>t[a],enumerable:!(n=pu(t,a))||n.enumerable});return e},Er=(e,t,i)=>(ba(e,t,"default"),i&&ba(i,t,"default")),ya=e=>ba(Oi({},"__esModule",{value:!0}),e),xa=(e,t,i)=>wu(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??ka}function bu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function L(e,t){let i=$e(t);return i?new Function("page",`return ${i}`)(e):null}async function va(e,t=[]){let i=e;for(let n of t){let a=await i.locator(n).elementHandle();if(!a)return null;let o=await a.contentFrame();if(await a.dispose(),!o)return null;i=o}return i}function yu(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 xu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function vu(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 $e(e){let t=xu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=vu(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var Ri,St,ka,pe,P,R=b(()=>{"use strict";me();Ri={};Ni(Ri,{ACTION_TIMEOUT:()=>ka,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>St,getActionTimeoutMs:()=>D,getFrameContext:()=>va,getLocator:()=>L,getMinimalActionEntity:()=>yu,getPageLocatorExpression:()=>$e,sanitizeForComment:()=>bu});P=Sr(()=>{St=5e3,ka=1e4,pe=2e4})});async function Et(e,t,i=[],n=[]){try{let a=await va(e,i);if(!a)return h.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${Tr(s)}`),d=ku(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Tr(t)}`)).elementHandle({timeout:St}),!o)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:St}),!o)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return h.error(`Error in pickBestLocator: ${a}`),null}}async function Fi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Ar(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let a=await Et(e,n);i.set(n,a)})),i}function Tr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function ku(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Be=b(()=>{"use strict";N();R();P()});async function Tt(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:a}=await import("sharp"),o=a(n),{width:r=0,height:s=0}=await o.metadata();return f.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ke(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function Hi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Fi(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Wi(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 tt=b(()=>{"use strict";ee();Be()});import{createGoogleGenerativeAI as _u}from"@ai-sdk/google";import{createVertex as Su}from"@ai-sdk/google-vertex";function Bi(){let e=(W().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ir(e){let t=W().env||{};if(Bi()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Su({project:n,location:a})(e)}let i=t.GOOGLE_API_KEY;if(!i)throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.");return h.debug(`Using Google AI provider (API key): model=${e}`),_u({apiKey:i})(e)}function Cr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Mr.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Mr.MEDIA_RESOLUTION_HIGH)}return Bi()?{vertex:a}:{google:a}}var Mr,it=b(()=>{"use strict";N();Q();Mr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Eu,Environment as Tu}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function Mu(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=ge(i.x,n),l=ge(i.y,a),d=await ke(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=ge(i.x,n),l=ge(i.y,a),d=ge(i.destination_x,n),c=ge(i.destination_y,a),u=await ke(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:f.log(`Unsupported Gemini function: ${t}`)}}catch(s){f.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await Hi(e,r)}}async function $r(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||Iu,l=W(),d;if(Bi()){let x=l.env?.GOOGLE_CLOUD_PROJECT;if(!x)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let _=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:x,location:_}}else{let x=l.env?.GOOGLE_API_KEY;if(!x)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};d={apiKey:x}}let c=new Eu(d);f.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Tu.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Au}],temperature:.1}});f.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let g=m.content?.parts?.find(x=>x.functionCall);if(!g)return{status:"error",reasoning:m.content?.parts?.filter(x=>x.text).map(x=>x.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:w,args:k}=g.functionCall;f.log(`Generated function call: ${w} with args ${JSON.stringify(k)}`),h.debug(`Generated function call: ${w} with args ${JSON.stringify(k)}`);let{action_data:y,locatorInfo:p}=await Mu(i,w,k,a,o);return y?{status:"success",actionEntity:Wi(t,y,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${w}`}}var Pr,Au,Iu,Ui=b(()=>{"use strict";tt();ee();it();N();Q();Pr={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"]},Au=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Pr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Pr}];Iu="gemini-3-flash-preview"});function Lr(e){return e!=null&&typeof e=="object"}function nt(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Dr(e){return typeof e=="string"?e:void 0}function Cu(e){let t,i;return Array.isArray(e)?(t=nt(e[0]),i=nt(e[1])):Lr(e)&&(t=nt(e.x),i=nt(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Or(e){if(!Lr(e))return{};let t=Array.isArray(e.path)?e.path.map(Cu).filter(i=>i!==null):void 0;return{type:Dr(e.type),x:nt(e.x),y:nt(e.y),button:Dr(e.button),path:t}}var Gi=b(()=>{"use strict"});import Pu from"openai";async function $u(e,t){let i=Or(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ke(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ke(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],s=await ke(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=s.element;break}}return{action_data:n,locatorInfo:await Hi(e,a)}}async function Rr(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||Du,s=await Tt(i,n,a),l=W(),d=l.env?.OPENAI_API_KEY;if(!d)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let c=l.env?.OPENAI_BASE_URL,u=new Pu({apiKey:d,...c&&{baseURL:c}}),m=u.responses.create.bind(u.responses);f.log(`Sending request to OpenAI CUA (model=${r})...`);let g=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function w(_,v){let S={model:r,tools:[Lu],input:_,temperature:.1};return v&&(S.previous_response_id=v),m(S)}let k=await w(g,void 0),y;for(let _=0;_<Nr;_++){f.log(`Received response from OpenAI CUA (turn ${_+1})`);let v=k.output.find(C=>C.type==="computer_call");if(!v)return{status:"error",reasoning:k.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let S=v.actions??[];if(S.length>1&&f.log(`[openai CUA] dropping ${S.length-1} batched action(s); only the first is executed`),y=S[0],!y)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(y.type!=="screenshot")break;s=await Tt(i,n,a);let A=[{type:"computer_call_output",call_id:v.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];k=await w(A,k.id)}if(!y)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(y.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Nr} turns`};f.log(`Generated action: ${JSON.stringify(y)}`);let{action_data:p,locatorInfo:x}=await $u(i,y);return p?{status:"success",actionEntity:Wi(t,p,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(y)}`}}var Du,Lu,Nr,Ki=b(()=>{"use strict";Gi();tt();ee();Q();Du="gpt-5.4",Lu={type:"computer"},Nr=4});import{createAnthropic as Ou}from"@ai-sdk/anthropic";import{createVertexAnthropic as Nu}from"@ai-sdk/google-vertex/anthropic";function Ru(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Fu(){return Ru(W().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Fr(e){let t=W();if(Fu()){let n=t.env?.GOOGLE_CLOUD_PROJECT,a=t.env?.GOOGLE_CLOUD_LOCATION;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${n}, location=${a}`),Nu({project:n,location:a})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(!i)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return h.debug(`Using Anthropic provider: model=${e}`),Ou({apiKey:i})(e)}function _a(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var At=b(()=>{"use strict";N();Q()});import{createOpenAI as Hu}from"@ai-sdk/openai";function Hr(e){let t=W(),i=t.env?.OPENAI_API_KEY;if(!i)throw new Error("OPENAI_API_KEY not configured in SDK config");let n=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),Hu({apiKey:i,baseURL:n})(e)}function Wr(e){return{}}var Mt=b(()=>{"use strict";N();Q()});function Ur(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Wu.test(e))return"openai"}function ji(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Bu.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=ji(e),n=t??Ur(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 a=Br[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Br).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function we(e,t){let{provider:i,modelId:n}=ji(e),a=i??Ur(n);return a==="anthropic"||a==="vertex"?_a(n):a==="openai"||a==="azure"?Wr(n):a==="bedrock"?n.startsWith("anthropic.")?_a(n):{}:Cr(t,n)}var Wu,Bu,Br,_e=b(()=>{"use strict";At();it();Mt();Wu=/^(gpt-|o\d|chatgpt-)/;Bu=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Br={anthropic:Fr,google:Ir,openai:Hr}});function Gu(e){return e.startsWith("gemini-")?"google":"openai"}async function at(e,t,i={}){let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=a;f.log(`Viewport: ${o}x${r}`);let s=await Tt(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=ji(l),c=Gu(d),u=Uu[c];f.log(`Using CUA provider: ${c} (model: ${d})`);let m={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:d};try{return await u(m)}catch(g){return f.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Uu,ot=b(()=>{"use strict";Ui();Ki();tt();ee();_e();Uu={google:$r,openai:Rr}});import{zodToJsonSchema as Gr}from"zod-to-json-schema";function zi(e){let t=Gr(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return It(t),t}function Vi(e){return Gr(e,{$refStrategy:"none"})}function It(e){if(!(typeof e!="object"||e===null)){if(e.type==="object"&&(e.additionalProperties=!1,e.properties)){let t=Object.keys(e.properties);e.required=t;for(let i of Object.values(e.properties))It(i)}e.type==="array"&&e.items&&It(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(It);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&It(i)}}var Ct=b(()=>{"use strict"});var Xi,Yi=b(()=>{"use strict";Ct();Xi=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:zi(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:zi(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:zi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function Ku(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,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(o,r.index);l&&a.push({type:"text",text:l});let d=r[2];i.has(d)?a.push({type:"image",image:new URL(i.get(d))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&a.push({type:"text",text:s}),a.length===0&&a.push({type:"text",text:e}),a}function ju(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=Ku(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
18
18
 
19
- `}),t.push(...o)}return t}function Ji(e,t=jr){if(t){let i=zu(e);if(i.length===0)return[];let n={type:"text",text:`
19
+ `}),t.push(...o)}return t}function Ji(e,t=Kr){if(t){let i=ju(e);if(i.length===0)return[];let n={type:"text",text:`
20
20
 
21
21
  <retrieved_knowledge>
22
22
 
@@ -36,7 +36,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
36
36
 
37
37
  </retrieved_knowledge>
38
38
 
39
- `}]:[]}}function zr(e,t=jr){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var jr,Pt=y(()=>{"use strict";jr=!1});function Vu(){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,a=t.find(c=>c.type==="day").value,o=t.find(c=>c.type==="hour").value,r=t.find(c=>c.type==="minute").value,s=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}-${a} ${o}:${r}:${s}.${d} ${l}`}function Vr(e){return`# Your Role
39
+ `}]:[]}}function jr(e,t=Kr){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Kr,Pt=b(()=>{"use strict";Kr=!1});function zu(){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,a=t.find(c=>c.type==="day").value,o=t.find(c=>c.type==="hour").value,r=t.find(c=>c.type==="minute").value,s=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}-${a} ${o}:${r}:${s}.${d} ${l}`}function zr(e){return`# Your Role
40
40
  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.
41
41
 
42
42
  # Rules
@@ -96,11 +96,11 @@ Example of empty action when the target element is not on the page, or the instr
96
96
  "action": {}, // empty action object to indicate the instruction cannot be completed
97
97
  "completes_instruction": false
98
98
  }
99
- `}function Xu(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
99
+ `}function Vu(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
100
100
  Feedback: ${n}
101
101
  `}),`## Additional context
102
102
  You just executed following steps in order:
103
- ${t}`}function Xr(e,t,i,n,a,o,r=!1,s=Vu(),l=!1,d){let c=[],u=`
103
+ ${t}`}function Vr(e,t,i,n,a,o,r=!1,s=zu(),l=!1,d){let c=[],u=`
104
104
  # Instruction
105
105
  "${t}"
106
106
 
@@ -120,9 +120,9 @@ ${e.tabsText}
120
120
 
121
121
  ## Interactive elements from current page:
122
122
  ${e.elementsText}
123
- `;if(c.push({type:"text",text:u}),r&&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 o&&(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:o}));if(a&&a.length>0){let g=Ji(a,l);c.push(...g)}let p="";if(p+=`
123
+ `;if(c.push({type:"text",text:u}),r&&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 o&&(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:o}));if(a&&a.length>0){let g=Ji(a,l);c.push(...g)}let m="";if(m+=`
124
124
  Current local time is ${s}.
125
- `,i&&Object.keys(i).length>0){let g=[];for(let f of Object.keys(i))if(d?.has(f))g.push(` - ${f}: [SENSITIVE - value hidden]`);else{let k=i[f],x=typeof k=="string"?k:JSON.stringify(k);g.push(` - ${f}: "${x}"`)}p+=`
125
+ `,i&&Object.keys(i).length>0){let g=[];for(let w of Object.keys(i))if(d?.has(w))g.push(` - ${w}: [SENSITIVE - value hidden]`);else{let k=i[w],y=typeof k=="string"?k:JSON.stringify(k);g.push(` - ${w}: "${y}"`)}m+=`
126
126
  ## Available Data Placeholders
127
127
  The following placeholders are available for use in your actions:
128
128
  ${g.join(`
@@ -133,32 +133,32 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
133
133
  - Do NOT use the actual value directly
134
134
  - The values shown are for context only to help you understand what data is available
135
135
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
136
- `}if(n&&n.length>0){let g=Xu(n);p+=`
137
- `+g}return p+=`
136
+ `}if(n&&n.length>0){let g=Vu(n);m+=`
137
+ `+g}return m+=`
138
138
  Based on the above information, please determine the right action to accomplish the task.
139
- `,c.push({type:"text",text:p}),c}var qi=y(()=>{"use strict";Pt()});function Zi(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var $t=y(()=>{"use strict"});async function Yu(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let a=n.length>0?n.join(`
139
+ `,c.push({type:"text",text:m}),c}var qi=b(()=>{"use strict";Pt()});function Zi(e,t){return e?{prompt_tokens:e.promptTokens||e.inputTokens||0,completion_tokens:e.completionTokens||e.outputTokens||0,total_tokens:e.totalTokens||0,model:t}:null}var $t=b(()=>{"use strict"});async function Xu(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let a=n.length>0?n.join(`
140
140
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
141
- `:"",tabsText:a}}async function Ju(e,t){let{currentTabText:i,tabsText:n}=await Yu(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Qi(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),s=a.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=l.elementTree.clickableElementsToString(),p=await Ju(i,u);return c&&(p.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var Dt=y(()=>{"use strict"});import{z as se}from"zod";var rt,F,Se=y(()=>{"use strict";rt=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 a=t?.description,o={...t};delete o.description;let r=n.schema.parse(o),s={...i,actionDescription:a};return await n.execute(r,s)}catch(a){if(a instanceof se.ZodError){let o=a.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw a}}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(a=>i.has(a.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return se.object({done:se.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof se.ZodObject){let l=s._def.shape();s=se.object({...l,description:se.string().describe("Semantic, human-readable description of the action")})}if(s instanceof se.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=se.object({_empty:se.boolean().optional()}))}return se.object({[r.name]:s})});if(i.length===1)return i[0];let[n,a,...o]=i;return se.union([n,a,...o])}},F=new rt});async function H(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function qu(e){let t=e.split("/").filter(a=>a);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,a,o]=n;return o?`${a}:nth-of-type(${o})`:a}return i}function Zu(e,t=!0){try{let i=qu(e.xpath);if(e.attributes.class&&t){let a=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&a.test(r)&&(i+=`.${r}`)}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(a=>n.add(a));for(let[a,o]of Object.entries(e.attributes)){if(a==="class"||!a.trim()||!n.has(a))continue;let r=a.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
141
+ `:"",tabsText:a}}async function Yu(e,t){let{currentTabText:i,tabsText:n}=await Xu(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Qi(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),s=a.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=l.elementTree.clickableElementsToString(),m=await Yu(i,u);return c&&(m.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:m}}var Dt=b(()=>{"use strict"});import{z as se}from"zod";var rt,F,Se=b(()=>{"use strict";rt=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 a=t?.description,o={...t};delete o.description;let r=n.schema.parse(o),s={...i,actionDescription:a};return await n.execute(r,s)}catch(a){if(a instanceof se.ZodError){let o=a.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw a}}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(a=>i.has(a.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return se.object({done:se.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof se.ZodObject){let l=s._def.shape();s=se.object({...l,description:se.string().describe("Semantic, human-readable description of the action")})}if(s instanceof se.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=se.object({_empty:se.boolean().optional()}))}return se.object({[r.name]:s})});if(i.length===1)return i[0];let[n,a,...o]=i;return se.union([n,a,...o])}},F=new rt});async function H(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function Ju(e){let t=e.split("/").filter(a=>a);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,a,o]=n;return o?`${a}:nth-of-type(${o})`:a}return i}function qu(e,t=!0){try{let i=Ju(e.xpath);if(e.attributes.class&&t){let a=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&a.test(r)&&(i+=`.${r}`)}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(a=>n.add(a));for(let[a,o]of Object.entries(e.attributes)){if(a==="class"||!a.trim()||!n.has(a))continue;let r=a.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
142
142
  `)&&(s=o.split(`
143
- `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Qu(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 Zu(e,!1)}function Ea(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let n=[],a=t.filter(o=>o.tagName==="iframe");for(let o of a){let r=Qu(o);h.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function O(e,t){let i=null,n=Ea(t);return t.xpath&&(i=await Et(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var G=y(()=>{"use strict";Be();N()});import{generateText as eh,Output as th}from"ai";import{z as en}from"zod";function ih(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 nh(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 ah(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,a=nh(n);if(a)return{type:"image",file:a};let 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 Yr(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(z=>(w.log(`Failed to retrieve knowledges: ${z.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),g=p?ih(e):"all";p&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:k,pageContext:x}=await Qi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:g});t.domState=k;let m=new Xi(F).getToolDefinitions().map(z=>{let qe=z.function;return`${qe.name}: ${qe.description}
143
+ `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function Zu(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 qu(e,!1)}function Sa(e){let t=[],i=e;for(;i&&i.parent!==null;){let o=i.parent;t.push(o),i=o}t.reverse();let n=[],a=t.filter(o=>o.tagName==="iframe");for(let o of a){let r=Zu(o);h.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function O(e,t){let i=null,n=Sa(t);return t.xpath&&(i=await Et(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var G=b(()=>{"use strict";Be();N()});import{generateText as Qu,Output as eh}from"ai";import{z as en}from"zod";function th(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 ih(e){if(!e)return null;if(e instanceof URL)return e.href;if(typeof e=="object"&&e.href)return String(e.href);if(typeof e=="object"&&typeof e.toString=="function"){let t=e.toString();if(t.startsWith("http://")||t.startsWith("https://"))return t}return typeof e=="string"&&(e.startsWith("http://")||e.startsWith("https://"))?e:null}function nh(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,a=ih(n);if(a)return{type:"image",file:a};let 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 Xr(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(z=>(f.log(`Failed to retrieve knowledges: ${z.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),m=a.isActionIntentFilteringEnabled(),g=m?th(e):"all";m&&g!=="all"&&f.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:w,domState:k,pageContext:y}=await Qi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:g});t.domState=k;let p=new Xi(F).getToolDefinitions().map(z=>{let qe=z.function;return`${qe.name}: ${qe.description}
144
144
  Parameters: ${JSON.stringify(qe.parameters,null,2)}`}).join(`
145
145
 
146
- `),b=Vr(m),_=await s,v=Xr(x,e,t.variables,t.executionHistory,_.length>0?_:void 0,f,l,void 0,c,t.sensitiveKeys),S=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(z=>{z.role==="user"?S.push({role:"user",content:z.content}):z.role==="assistant"&&S.push({role:"assistant",content:z.content})}),S.push({role:"user",content:v});let A=ah(S),C=F.buildActionUnionSchema(),I=en.object({thought:en.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:en.string().describe("Detailed description of the action to be performed").optional().default(""),action:C,completes_instruction:en.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),$=Array.isArray(v)?v.filter(z=>z.type==="image").length:0,U=we(o,$),q=await eh({model:fe(o),system:b,messages:S,temperature:r,output:th.object({schema:I}),providerOptions:U}),xe=q.reasoningText;h.info(`Action Generation Reasoning: ${xe}`);let j=q.output,V=JSON.stringify(j,null,2);h.info(`Generate Action Raw Output: ${V}`);let ve=[],We=Zi(q.usage,o);We&&ve.push(We);let Ie={systemPrompt:b,userPrompt:A,rawLlmResponse:V,tokenUsages:ve},Ce=j.thought||"",Pe=j.description||"",B=j.action||{},X=j.completes_instruction||!1;if(!B||Object.keys(B).length===0)return{status:"error",reasoning:Ce||Pe||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Ie};let Y=Object.keys(B)[0];if(Y==="done")return{status:"error",reasoning:Ce||Pe||"Task marked as done",goalAccomplished:X,error:"Agent indicated task is done without generating an action",debugInfo:Ie};if(Y==="perform_accurate_operation")return await at(e,t,i);if(!X){let z="Can't complete the instruction in one action";return{status:"error",reasoning:Ce||Pe||z,goalAccomplished:!1,error:z,debugInfo:Ie}}let re=B[Y]||{},sr={};if(typeof re.element_index=="number"){let z=re.element_index;if(z<0)return{status:"error",reasoning:Ce||Pe||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Ie};let qe=k.selectorMap.get(z);qe&&(sr=await O(n,qe))}let lr=Pe;return Y==="verify"&&(lr=e,re.statement=e),{status:"success",actionEntity:{...sr,action_description:lr||Ce||`${Y}(${JSON.stringify(re)})`,action_data:{action_name:Y,kwargs:re}},reasoning:Ce||Pe,goalAccomplished:X,debugInfo:Ie}}var tn=y(()=>{"use strict";ot();Yi();qi();$t();Dt();Se();ee();_e();G();N()});import{generateText as oh,Output as rh}from"ai";import{z as nn}from"zod";function sh(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 Ta(e,t,i={}){return i.usePureVision?at(e,t,i):Yr(e,t,i)}function ch(){let e=new Date,t=e.toLocaleDateString("en-US",{weekday:"long",year:"numeric",month:"long",day:"numeric",timeZone:"America/Los_Angeles"}),i=e.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",second:"2-digit",fractionalSecondDigits:3,timeZoneName:"short",timeZone:"America/Los_Angeles"});return{dateString:t,timeString:i}}function dh(){return`# Role
146
+ `),x=zr(p),_=await s,v=Vr(y,e,t.variables,t.executionHistory,_.length>0?_:void 0,w,l,void 0,c,t.sensitiveKeys),S=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(z=>{z.role==="user"?S.push({role:"user",content:z.content}):z.role==="assistant"&&S.push({role:"assistant",content:z.content})}),S.push({role:"user",content:v});let A=nh(S),C=F.buildActionUnionSchema(),I=en.object({thought:en.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:en.string().describe("Detailed description of the action to be performed").optional().default(""),action:C,completes_instruction:en.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),$=Array.isArray(v)?v.filter(z=>z.type==="image").length:0,U=we(o,$),q=await Qu({model:fe(o),system:x,messages:S,temperature:r,output:eh.object({schema:I}),providerOptions:U}),xe=q.reasoningText;h.info(`Action Generation Reasoning: ${xe}`);let j=q.output,V=JSON.stringify(j,null,2);h.info(`Generate Action Raw Output: ${V}`);let ve=[],We=Zi(q.usage,o);We&&ve.push(We);let Ie={systemPrompt:x,userPrompt:A,rawLlmResponse:V,tokenUsages:ve},Ce=j.thought||"",Pe=j.description||"",B=j.action||{},X=j.completes_instruction||!1;if(!B||Object.keys(B).length===0)return{status:"error",reasoning:Ce||Pe||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Ie};let Y=Object.keys(B)[0];if(Y==="done")return{status:"error",reasoning:Ce||Pe||"Task marked as done",goalAccomplished:X,error:"Agent indicated task is done without generating an action",debugInfo:Ie};if(Y==="perform_accurate_operation")return await at(e,t,i);if(!X){let z="Can't complete the instruction in one action";return{status:"error",reasoning:Ce||Pe||z,goalAccomplished:!1,error:z,debugInfo:Ie}}let re=B[Y]||{},rr={};if(typeof re.element_index=="number"){let z=re.element_index;if(z<0)return{status:"error",reasoning:Ce||Pe||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Ie};let qe=k.selectorMap.get(z);qe&&(rr=await O(n,qe))}let sr=Pe;return Y==="verify"&&(sr=e,re.statement=e),{status:"success",actionEntity:{...rr,action_description:sr||Ce||`${Y}(${JSON.stringify(re)})`,action_data:{action_name:Y,kwargs:re}},reasoning:Ce||Pe,goalAccomplished:X,debugInfo:Ie}}var tn=b(()=>{"use strict";ot();Yi();qi();$t();Dt();Se();ee();_e();G();N()});import{generateText as ah,Output as oh}from"ai";import{z as nn}from"zod";function rh(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 Ea(e,t,i={}){return i.usePureVision?at(e,t,i):Xr(e,t,i)}function lh(){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 ch(){return`# Role
147
147
  You are an experienced QA person for web applications.
148
148
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
149
- `}async function Jr(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:p,domState:g,pageContext:f}=await Qi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let k="";a&&a.length>0&&(k=`
149
+ `}async function Yr(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:m,domState:g,pageContext:w}=await Qi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let k="";a&&a.length>0&&(k=`
150
150
  # Previous actions in this session:
151
151
  ${a.map(([B,X],Y)=>`${Y+1}. Action: ${B}
152
152
  Result: ${X}`).join(`
153
153
  `)}
154
- `);let{dateString:x,timeString:m}=ch(),b=`
154
+ `);let{dateString:y,timeString:p}=lh(),x=`
155
155
  # User statement
156
156
  "${e}"
157
157
 
158
158
  # Current webpage state
159
159
  ## Tab information:
160
- ${f.currentTabText}Available tabs:
161
- ${f.tabsText}
160
+ ${w.currentTabText}Available tabs:
161
+ ${w.tabsText}
162
162
 
163
163
  ## Element interaction guidelines:
164
164
  - Each element has a unique index number (e.g., "[33]<button>")
@@ -169,7 +169,7 @@ ${f.tabsText}
169
169
  ${c}
170
170
 
171
171
  ## Screenshot
172
- ${r&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
172
+ ${r&&m?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
173
173
  `,_="";if(t.variables&&Object.keys(t.variables).length>0){let B=[];for(let X of Object.keys(t.variables))if(!t.sensitiveKeys?.has(X)){let Y=t.variables[X],re=typeof Y=="string"?Y:JSON.stringify(Y);B.push(` - ${X}: "${re}"`)}B.length>0&&(_=`
174
174
  ## Available Variables
175
175
  The following non-sensitive variables are available:
@@ -178,14 +178,14 @@ ${B.join(`
178
178
  ${_}
179
179
  ${k}
180
180
 
181
- Today is ${x}. Current local time is ${m}.
181
+ Today is ${y}. Current local time is ${p}.
182
182
  Based on the above information, please determine if the statement is true.
183
- `,S=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:b}],C=0;if(r&&p&&p.length>0)for(let B of p)A.push({type:"image",image:B}),C++;else A.push({type:"image",image:u}),C=1;if(S&&S.length>0){let B=Ji(S,l);A.push(...B)}A.push({type:"text",text:v});let I=S?zr(S,l):0,$=C+I,U=we(o,$),q=dh(),xe=await oh({model:fe(o),system:q,messages:[{role:"user",content:A}],output:rh.object({schema:lh}),temperature:0,providerOptions:U}),{conclusion:j,explanation:V}=xe.output,ve=JSON.stringify(xe.output,null,2),We=[],Ie=Zi(xe.usage,o);Ie&&We.push(Ie);let Ce=[{role:"user",content:A.map(B=>{if(B.type==="text")return{type:"text",text:B.text};if(B.type==="image"){let X=B.image,Y=sh(X);if(Y)return{type:"image",file:Y};let re=typeof X=="string"?X:"";return{type:"image",file:re.startsWith("data:")?re:`data:image/png;base64,${re}`}}return{type:"text",text:"[unknown content type]"}})}],Pe={systemPrompt:q,userPrompt:Ce,rawLlmResponse:ve,screenshotWithSom:u,tokenUsages:We,retrievedKnowledges:S&&S.length>0?S:void 0,elementTree:c};return{success:j==="true",explanation:V,debugInfo:Pe}}catch(r){return{success:!1,error:r.message}}}var lh,an=y(()=>{"use strict";tn();ot();$t();Dt();Pt();_e();lh=nn.object({screenshotDescription:nn.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
183
+ `,S=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:x}],C=0;if(r&&m&&m.length>0)for(let B of m)A.push({type:"image",image:B}),C++;else A.push({type:"image",image:u}),C=1;if(S&&S.length>0){let B=Ji(S,l);A.push(...B)}A.push({type:"text",text:v});let I=S?jr(S,l):0,$=C+I,U=we(o,$),q=ch(),xe=await ah({model:fe(o),system:q,messages:[{role:"user",content:A}],output:oh.object({schema:sh}),temperature:0,providerOptions:U}),{conclusion:j,explanation:V}=xe.output,ve=JSON.stringify(xe.output,null,2),We=[],Ie=Zi(xe.usage,o);Ie&&We.push(Ie);let Ce=[{role:"user",content:A.map(B=>{if(B.type==="text")return{type:"text",text:B.text};if(B.type==="image"){let X=B.image,Y=rh(X);if(Y)return{type:"image",file:Y};let re=typeof X=="string"?X:"";return{type:"image",file:re.startsWith("data:")?re:`data:image/png;base64,${re}`}}return{type:"text",text:"[unknown content type]"}})}],Pe={systemPrompt:q,userPrompt:Ce,rawLlmResponse:ve,screenshotWithSom:u,tokenUsages:We,retrievedKnowledges:S&&S.length>0?S:void 0,elementTree:c};return{success:j==="true",explanation:V,debugInfo:Pe}}catch(r){return{success:!1,error:r.message}}}var sh,an=b(()=>{"use strict";tn();ot();$t();Dt();Pt();_e();sh=nn.object({screenshotDescription:nn.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
184
184
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
185
185
  [45] A modal dialog titled "Confirmation",
186
- in the center of the screen`),explanation:nn.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:nn.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Zr(){let{default:e}=await import("sharp");return e}async function Aa(e,t){let i=await Zr(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((a-r)/2),d=Math.max(0,a-r),c=(f,k)=>{let x=i(e).extract({left:f,top:0,width:k,height:r});return t?.resize&&(x=x.resize(qr,qr)),x.png().toBuffer()},[u,p,g]=await Promise.all([c(s,Math.min(r,a)),c(l,Math.min(r,a-l)),c(d,Math.min(r,a-d))]);return[u,p,g]}async function Qr(e){let t=(await Zr())(e),i=await t.metadata(),n=i.width||0,a=i.height||0;if(n===0||a===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<a;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=o[s*n+l]}return{pixels:r,width:n,height:a}}var qr,Lt=y(()=>{"use strict";qr=768});function es(e){return e?Ot.has(e):!1}function ts(e){return st.has(e)}function is(e){return e.filter(t=>st.has(t.type))}var Ot,st,on,rn,Nt=y(()=>{"use strict";Ot=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),st=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),on=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],rn=500});function ns(e,t){return e.length>t?e.slice(0,t)+"...":e}var Rt=y(()=>{"use strict"});var as,os,Ft=y(()=>{"use strict";as=["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"],os={"react-flow__(\\S+)":"$1"}});var rs,Ht,be,lt=y(()=>{"use strict";Rt();Ft();rs=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},Ht=class extends rs{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},be=class sn extends rs{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,p=null,g=null,f=null,k=null,x=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=f,this.viewportInfo=k,this.isNew=null,this.shadowHostXPaths=x}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof sn&&a!==this&&a.highlightIndex!==null)){if(a instanceof Ht)i.push(a.text);else if(a instanceof sn)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
187
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??as,n=t?.includeClassesWithRename??os,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof sn){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let v of Object.keys(r.attributes))if(i.includes(v)){let S=r.attributes[v].trim();S!==""&&(m[v]=S)}let b=i.filter(v=>v in m);if(b.length>1){let v=new Set,S={};for(let A of b){let C=m[A];C.length>5&&(C in S?v.add(A):S[C]=A)}for(let A of v)delete m[A]}r.tagName===m.role&&delete m.role;let _=["aria-label","placeholder","title"];for(let v of _)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(u=Object.entries(m).map(([v,S])=>`${v}=${ns(S,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let b of m)for(let[_,v]of Object.entries(n))try{let S=new RegExp(`^${_}$`);if(b.match(S)){let A=b.replace(S,v);A&&g.push(A);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",k=r.markAsClickable?" (CLICKABLE)":"",x=`${d}${p}${f}${k}<${r.tagName}`;if(g.length>0&&(x+=` ${g.join(" ")}`),u&&(x+=` ${u}`),c){let m=c.trim();u||(x+=" "),x+=`>${m}`}else u||(x+=" ");x+=" />",a.push(x)}else{let c=["data-testid","data-test-id"].filter(u=>r.attributes[u]);c.length>0&&(l+=1,a.push(`${d}<${r.tagName} ${c.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let c of r.children)o(c,l)}else if(r instanceof Ht){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${d}${r.text}`)}};return o(this,0),a.join(`
188
- `)}}});function mh(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var uh,hh,le,Ue=y(()=>{"use strict";Lt();Nt();lt();N();uh=`(
186
+ in the center of the screen`),explanation:nn.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:nn.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function qr(){let{default:e}=await import("sharp");return e}async function Ta(e,t){let i=await qr(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((a-r)/2),d=Math.max(0,a-r),c=(w,k)=>{let y=i(e).extract({left:w,top:0,width:k,height:r});return t?.resize&&(y=y.resize(Jr,Jr)),y.png().toBuffer()},[u,m,g]=await Promise.all([c(s,Math.min(r,a)),c(l,Math.min(r,a-l)),c(d,Math.min(r,a-d))]);return[u,m,g]}async function Zr(e){let t=(await qr())(e),i=await t.metadata(),n=i.width||0,a=i.height||0;if(n===0||a===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<a;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=o[s*n+l]}return{pixels:r,width:n,height:a}}var Jr,Lt=b(()=>{"use strict";Jr=768});function Qr(e){return e?Ot.has(e):!1}function es(e){return st.has(e)}function ts(e){return e.filter(t=>st.has(t.type))}var Ot,st,on,rn,Nt=b(()=>{"use strict";Ot=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),st=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),on=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],rn=500});function is(e,t){return e.length>t?e.slice(0,t)+"...":e}var Rt=b(()=>{"use strict"});var ns,as,Ft=b(()=>{"use strict";ns=["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"],as={"react-flow__(\\S+)":"$1"}});var os,Ht,be,lt=b(()=>{"use strict";Rt();Ft();os=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},Ht=class extends os{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},be=class sn extends os{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,m=null,g=null,w=null,k=null,y=[],p=null){super(o,p),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=m,this.viewportCoordinates=g,this.pageCoordinates=w,this.viewportInfo=k,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof sn&&a!==this&&a.highlightIndex!==null)){if(a instanceof Ht)i.push(a.text);else if(a instanceof sn)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
187
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??ns,n=t?.includeClassesWithRename??as,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof sn){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let p={};for(let v of Object.keys(r.attributes))if(i.includes(v)){let S=r.attributes[v].trim();S!==""&&(p[v]=S)}let x=i.filter(v=>v in p);if(x.length>1){let v=new Set,S={};for(let A of x){let C=p[A];C.length>5&&(C in S?v.add(A):S[C]=A)}for(let A of v)delete p[A]}r.tagName===p.role&&delete p.role;let _=["aria-label","placeholder","title"];for(let v of _)p[v]&&p[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete p[v];Object.keys(p).length>0&&(u=Object.entries(p).map(([v,S])=>`${v}=${is(S,200)}`).join(" "))}let m=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&r.attributes.class){let p=r.attributes.class.split(/\s+/);for(let x of p)for(let[_,v]of Object.entries(n))try{let S=new RegExp(`^${_}$`);if(x.match(S)){let A=x.replace(S,v);A&&g.push(A);break}}catch{continue}}let w=r.isScrollable?" (SCROLLABLE)":"",k=r.markAsClickable?" (CLICKABLE)":"",y=`${d}${m}${w}${k}<${r.tagName}`;if(g.length>0&&(y+=` ${g.join(" ")}`),u&&(y+=` ${u}`),c){let p=c.trim();u||(y+=" "),y+=`>${p}`}else u||(y+=" ");y+=" />",a.push(y)}else{let c=["data-testid","data-test-id"].filter(u=>r.attributes[u]);c.length>0&&(l+=1,a.push(`${d}<${r.tagName} ${c.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let c of r.children)o(c,l)}else if(r instanceof Ht){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${d}${r.text}`)}};return o(this,0),a.join(`
188
+ `)}}});function hh(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var dh,uh,le,Ue=b(()=>{"use strict";Lt();Nt();lt();N();dh=`(
189
189
  args = {
190
190
  doHighlightElements: true,
191
191
  focusHighlightIndex: -1,
@@ -1953,7 +1953,7 @@ Based on the above information, please determine if the statement is true.
1953
1953
 
1954
1954
  return { rootId, map: DOM_HASH_MAP };
1955
1955
  }
1956
- `,hh=`((args = {
1956
+ `,uh=`((args = {
1957
1957
  doHighlightElements: true,
1958
1958
  focusHighlightIndex: -1,
1959
1959
  viewportExpansion: 0,
@@ -4001,7 +4001,7 @@ Based on the above information, please determine if the statement is true.
4001
4001
  // Return element data from boxes phase for use in labels phase
4002
4002
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4003
4003
  };
4004
- })`;le=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 a=this.normalizeDomain(n);if(a&&(i===a||i.endsWith(`.${a}`)))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={}){h.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?hh:uh}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,u]=await this.buildDomTree(e,i,n,a,o,r,s,l,d);return{elementTree:c,selectorMap:u}}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 a=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await Aa(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){h.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){h.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:a}=await n.send("Accessibility.getFullAXTree",{depth:-1});h.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(m=>{if(m.ignored)return!1;let b=m.role?.value;return!(!b||!Ot.has(b)||m.properties?.find(_=>_.name==="disabled")?.value?.value||!m.backendDOMNodeId)});h.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(m=>m.role?.value==="button");h.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let b=[];m.ignored&&b.push("ignored"),m.backendDOMNodeId||b.push("no-backendDOMNodeId"),m.properties?.find(_=>_.name==="disabled")?.value?.value&&b.push("disabled"),h.debug(` - "${m.name?.value||"(no name)"}" ${b.length>0?`[SKIPPED: ${b.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)s.has(m.backendNodeId)||(o.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),d++);h.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${o.length})`);let c=await this.resolveAXNodesToDOM(n,o),u=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){h.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let b=[];m.isVisible||b.push("not-visible"),m.isInViewport||b.push("not-in-viewport"),m.isTopElement||b.push("not-top-element"),m.boundingRect||b.push("no-bounding-rect"),h.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${b.join(", ")}]`)}}h.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:g,highlightIndex:f}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let k=i.toString("base64"),x;if(t.useSlicedScreenshots)try{x=(await Aa(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){h.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:k,screenshot:i,slicedScreenshotsBase64:x}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],s=a[o];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4004
+ })`;le=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 a=this.normalizeDomain(n);if(a&&(i===a||i.endsWith(`.${a}`)))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={}){h.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?uh:dh}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,u]=await this.buildDomTree(e,i,n,a,o,r,s,l,d);return{elementTree:c,selectorMap:u}}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 a=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await Ta(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){h.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){h.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:a}=await n.send("Accessibility.getFullAXTree",{depth:-1});h.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(p=>{if(p.ignored)return!1;let x=p.role?.value;return!(!x||!Ot.has(x)||p.properties?.find(_=>_.name==="disabled")?.value?.value||!p.backendDOMNodeId)});h.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(p=>p.role?.value==="button");h.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let p of r){let x=[];p.ignored&&x.push("ignored"),p.backendDOMNodeId||x.push("no-backendDOMNodeId"),p.properties?.find(_=>_.name==="disabled")?.value?.value&&x.push("disabled"),h.debug(` - "${p.name?.value||"(no name)"}" ${x.length>0?`[SKIPPED: ${x.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(p=>p.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let p of l)s.has(p.backendNodeId)||(o.push({nodeId:`synthetic-${p.backendNodeId}`,ignored:!1,backendDOMNodeId:p.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:p.eventTypes.join(",")}}]}),s.add(p.backendNodeId),d++);h.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${o.length})`);let c=await this.resolveAXNodesToDOM(n,o),u=c.filter(p=>p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect),m=c.filter(p=>!(p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect));if(m.length>0){h.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let p of m){let x=[];p.isVisible||x.push("not-visible"),p.isInViewport||x.push("not-in-viewport"),p.isTopElement||x.push("not-top-element"),p.boundingRect||x.push("no-bounding-rect"),h.debug(` - <${p.tagName}> "${p.axNode.name?.value||""}" [${x.join(", ")}]`)}}h.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:g,highlightIndex:w}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&w>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,w)),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 k=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await Ta(i,{resize:t.resizeSlicedScreenshots})).map(p=>p.toString("base64"))}catch(p){h.warn("Failed to slice screenshot:",p)}return{domState:g,screenshotBase64:k,screenshot:i,slicedScreenshotsBase64:y}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],s=a[o];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4005
4005
  const el = this;
4006
4006
  const rect = el.getBoundingClientRect();
4007
4007
  const rects = el.getClientRects();
@@ -4085,36 +4085,36 @@ Based on the above information, please determine if the statement is true.
4085
4085
  } : null,
4086
4086
  clientRects: clientRectsArray
4087
4087
  };
4088
- }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=rn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=on.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});h.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>st.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new be("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new be(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",s,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let d=new Ht(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=a[l%a.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let 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),f=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${f}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let d=new URL(l).hostname;d&&d!==a&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(mh(e.url()))return[new be("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:x});h.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let b=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let _=performance.now(),v=await Qr(b);u=v.pixels;let S=Math.round(performance.now()-_);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${S}ms`);let A={...d,phase:"labels",grayscaleImage:u,elementData:m.elementData};c=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:A}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){h.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),u=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:b,argsObj:_})=>new Function("return "+b)()(_),{code:this.jsCode,argsObj:m}),h.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}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw h.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:b})=>new Function("return "+m)()(b),{code:this.jsCode,argsObj:x})}let p=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[x,m]of p){let b=m;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${b.attributes?.src} inaccessibleFrame=${b.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let f=[];for(let[x,m]of Object.entries(c.map)){let b=m;this.shouldProcessWithPlaywrightFrameFallback(b,o)&&f.push({nodeId:x,src:b.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){h.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let m of Object.values(c.map)){let b=m;b.highlightIndex!=null&&(x=Math.max(x,b.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let m=0;m<f.length;m++){let{nodeId:b,src:_}=f[m];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${_}`);let v=I=>{try{let $=new URL(I);if($.protocol==="chrome-extension:"&&$.hostname)return`chrome-extension://${$.hostname}`;let U=$.origin;return U==="null"?null:U}catch{return null}},S=v(_);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${S??"null"}`);let A=null,C=e.frames().find(I=>{let $=I.url();if($===_)return A="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${$}`),!0;let U=v($);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${$} origin=${U??"null"} vs srcOrigin=${S??"null"}`),S&&U===S?(A="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${$}`),!0):!1});if(!C){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${_}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(I=>I.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${_} (frame url: ${C.url()})`);try{let I={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${I.initialHighlightIndex}`);let $=await C.evaluate(({code:j,argsObj:V})=>new Function("return "+j)()(V),{code:this.jsCode,argsObj:I});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys($?.map??{}).length} rootId=${$?.rootId}`),!$?.map||!$.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let U=Object.values($.map).filter(j=>j.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${U.length}`);for(let j of U){let V=j;h.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let j of Object.values($.map)){let V=j;V.highlightIndex!=null&&(x=Math.max(x,V.highlightIndex))}let q=`ext_${m}_`;for(let[j,V]of Object.entries($.map)){let ve={...V};ve.children&&(ve.children=ve.children.map(We=>`${q}${We}`)),c.map[`${q}${j}`]=ve}let xe=c.map[b];xe?(xe.children=[...xe.children||[],`${q}${$.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${b}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${b} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${_}`)}catch(I){h.warn(`Failed to process fallback iframe ${_}:`,I)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let _ of Object.values(c.map))typeof _=="object"&&_!==null&&_.isInteractive&&m++;let b=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${b} interactive=${m}/${x}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(a.set(s,d),o.set(s,c),d instanceof be&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof be)for(let c of l){let u=a.get(c);u&&(u.parent=d,d.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof be))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Ht(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new be(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),a=e.children||[];return[n,a]}}});var ss,ln=y(()=>{"use strict";R();P();ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=L(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=$e(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as ph}from"zod";var ls,sw,cn=y(()=>{"use strict";ls=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},sw=ph.object({})});var cs,dn=y(()=>{"use strict";R();P();cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof 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 ds,un=y(()=>{"use strict";ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4088
+ }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=rn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=on.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});h.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>st.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new be("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new be(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",s,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let d=new Ht(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=a[l%a.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let m=document.createElement("div");m.style.position="fixed",m.style.background=d,m.style.color="white",m.style.padding="1px 4px",m.style.borderRadius="4px",m.style.fontSize=l>=100?"8px":"12px",m.textContent=String(l);let g=Math.max(0,c.y-16),w=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${g}px`,m.style.left=`${w}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let d=new URL(l).hostname;d&&d!==a&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(hh(e.url()))return[new be("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let y={...d,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:y});h.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let _=performance.now(),v=await Zr(x);u=v.pixels;let S=Math.round(performance.now()-_);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${S}ms`);let A={...d,phase:"labels",grayscaleImage:u,elementData:p.elementData};c=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:A}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){h.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),u=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:x,argsObj:_})=>new Function("return "+x)()(_),{code:this.jsCode,argsObj:p}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:y,argsObj:p})=>new Function("return "+y)()(p),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw h.error("Error evaluating JavaScript:",y.message),y}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let y={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:x})=>new Function("return "+p)()(x),{code:this.jsCode,argsObj:y})}let m=Object.entries(c.map).filter(([,y])=>y.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[y,p]of m){let x=p;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let y of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let w=[];for(let[y,p]of Object.entries(c.map)){let x=p;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&w.push({nodeId:y,src:x.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${w.length}`),w.length>0){h.debug(`\u{1F50C} Found ${w.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let p of Object.values(c.map)){let x=p;x.highlightIndex!=null&&(y=Math.max(y,x.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let p=0;p<w.length;p++){let{nodeId:x,src:_}=w[p];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${_}`);let v=I=>{try{let $=new URL(I);if($.protocol==="chrome-extension:"&&$.hostname)return`chrome-extension://${$.hostname}`;let U=$.origin;return U==="null"?null:U}catch{return null}},S=v(_);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${S??"null"}`);let A=null,C=e.frames().find(I=>{let $=I.url();if($===_)return A="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${$}`),!0;let U=v($);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${$} origin=${U??"null"} vs srcOrigin=${S??"null"}`),S&&U===S?(A="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${$}`),!0):!1});if(!C){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${_}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(I=>I.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${_} (frame url: ${C.url()})`);try{let I={...d,initialHighlightIndex:y+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${I.initialHighlightIndex}`);let $=await C.evaluate(({code:j,argsObj:V})=>new Function("return "+j)()(V),{code:this.jsCode,argsObj:I});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys($?.map??{}).length} rootId=${$?.rootId}`),!$?.map||!$.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let U=Object.values($.map).filter(j=>j.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${U.length}`);for(let j of U){let V=j;h.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let j of Object.values($.map)){let V=j;V.highlightIndex!=null&&(y=Math.max(y,V.highlightIndex))}let q=`ext_${p}_`;for(let[j,V]of Object.entries($.map)){let ve={...V};ve.children&&(ve.children=ve.children.map(We=>`${q}${We}`)),c.map[`${q}${j}`]=ve}let xe=c.map[x];xe?(xe.children=[...xe.children||[],`${q}${$.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${_}`)}catch(I){h.warn(`Failed to process fallback iframe ${_}:`,I)}}}if(c&&c.perfMetrics){let y=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let _ of Object.values(c.map))typeof _=="object"&&_!==null&&_.isInteractive&&p++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${p}/${y}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(a.set(s,d),o.set(s,c),d instanceof be&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof be)for(let c of l){let u=a.get(c);u&&(u.parent=d,d.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof be))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new Ht(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new be(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),a=e.children||[];return[n,a]}}});var rs,ln=b(()=>{"use strict";R();P();rs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=L(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=$e(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as mh}from"zod";var ss,cw,cn=b(()=>{"use strict";ss=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},cw=mh.object({})});var ls,dn=b(()=>{"use strict";R();P();ls=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 a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof 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 cs,un=b(()=>{"use strict";cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4089
4089
  return (async () => {
4090
4090
  ${a}
4091
4091
  })();
4092
4092
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4093
- `):["// Skipping js_action: missing code"]}}});import{z as us}from"zod";var hs,fw,hn=y(()=>{"use strict";hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
4093
+ `):["// Skipping js_action: missing code"]}}});import{z as ds}from"zod";var us,bw,hn=b(()=>{"use strict";us=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
4094
4094
  return (async () => {
4095
4095
  ${a}
4096
4096
  })();
4097
4097
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4098
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},fw=us.object({code:us.string().describe("JavaScript code to execute in the browser context")})});var ms,mn=y(()=>{"use strict";R();P();ms=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 a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var ps,pn=y(()=>{"use strict";R();P();ps=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof 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 gs,gn=y(()=>{"use strict";R();P();gs=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=L(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+o.relative_x+d.width/2,u=d.y+o.relative_y+d.height/2,p=c+o.delta_x,g=u+o.delta_y;await e.mouse.move(c,u),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(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(a=>` ${a},`),"});"]}}});var fs,fn=y(()=>{"use strict";fs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.generateFunctionCallCode(n.kwargs);if(!a)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4098
+ `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},bw=ds.object({code:ds.string().describe("JavaScript code to execute in the browser context")})});var hs,mn=b(()=>{"use strict";R();P();hs=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 a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof 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 ms,pn=b(()=>{"use strict";R();P();ms=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 a=L(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var ps,gn=b(()=>{"use strict";R();P();ps=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=L(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+o.relative_x+d.width/2,u=d.y+o.relative_y+d.height/2,m=c+o.delta_x,g=u+o.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,g,{steps:n}):await e.mouse.move(m,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(a=>` ${a},`),"});"]}}});var gs,fn=b(()=>{"use strict";gs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.generateFunctionCallCode(n.kwargs);if(!a)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4099
4099
  return (async () => {
4100
4100
  ${a}
4101
4101
  })();
4102
- `)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});import{createHash as Ma}from"crypto";var ws,wn=y(()=>{"use strict";lt();ws=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=a=>{if(a.highlightIndex!==null){let o=this.hashDomElement(a);if(this.compareHashes(o,i))return a}for(let o of a.children)if(o instanceof be){let r=n(o);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),a=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:a}}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 Ma("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return Ma("sha256").update(t).digest("hex")}static xpathHash(e){return Ma("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(a=>a.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Ia,ct=y(()=>{"use strict";Ia=(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))(Ia||{})});var dt={};Ze(dt,{evaluateStatement:()=>Ke,executeAction:()=>Wt,executeStep:()=>Ge,generateActionStep:()=>ht,runTask:()=>je});var ut=y(()=>{"use strict";Bt();an();tn();ot();Ui();Ki();Gi();tt();Yi();qi();$t();Dt();Se();Ct();Pt();wn();Ue();Lt();Nt();lt();Rt();Ft();ee();_e();At();Mt();it();G();Be();N();Q();ct();R();me()});import{z as bs}from"zod";var ys,fb,bn=y(()=>{"use strict";ys=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(ut(),dt)),s=await r(a,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},fb=bs.object({statement:bs.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as xs}from"zod";var vs,xb,yn=y(()=>{"use strict";vs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(ut(),dt)),r=await o(a,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},xb=xs.object({statement:xs.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Ca}from"zod";function _s(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:gh,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:l.message}}}}})}var ks,gh,Ut=y(()=>{"use strict";ks=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(ut(),dt));for(;Date.now()-s<o;){if((await l(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}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"]}},gh=Ca.object({condition:Ca.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Ca.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as xn}from"zod";async function fh(e,t,i,n){return{...await O(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Ss(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 Ts(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:wh,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Ss(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await fh(d,r,o,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${o}" in dropdown ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ss(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Es,wh,Gt=y(()=>{"use strict";G();R();P();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=L(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};wh=xn.object({element_index:xn.number().int().describe("Index of the dropdown/select element"),option:xn.string().describe("Option value, label, or index to select"),timeout_ms:xn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as vn}from"zod";async function bh(e,t,i,n){return{...await O(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Pa(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 Ms(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">).
4102
+ `)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});import{createHash as Aa}from"crypto";var fs,wn=b(()=>{"use strict";lt();fs=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=a=>{if(a.highlightIndex!==null){let o=this.hashDomElement(a);if(this.compareHashes(o,i))return a}for(let o of a.children)if(o instanceof be){let r=n(o);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),a=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:a}}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 Aa("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return Aa("sha256").update(t).digest("hex")}static xpathHash(e){return Aa("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(a=>a.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Ma,ct=b(()=>{"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 dt={};Ze(dt,{evaluateStatement:()=>Ke,executeAction:()=>Wt,executeStep:()=>Ge,generateActionStep:()=>ht,runTask:()=>je});var ut=b(()=>{"use strict";Bt();an();tn();ot();Ui();Ki();Gi();tt();Yi();qi();$t();Dt();Se();Ct();Pt();wn();Ue();Lt();Nt();lt();Rt();Ft();ee();_e();At();it();Mt();G();Be();N();Q();ct();R();me()});import{z as ws}from"zod";var bs,bb,bn=b(()=>{"use strict";bs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(ut(),dt)),s=await r(a,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},bb=ws.object({statement:ws.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as ys}from"zod";var xs,kb,yn=b(()=>{"use strict";xs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(ut(),dt)),r=await o(a,e,i);if(r.status!=="success")throw new Error(r.error||"Task execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]}},kb=ys.object({statement:ys.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Ia}from"zod";function ks(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:ph,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:l.message}}}}})}var vs,ph,Ut=b(()=>{"use strict";vs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(ut(),dt));for(;Date.now()-s<o;){if((await l(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}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"]}},ph=Ia.object({condition:Ia.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Ia.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as xn}from"zod";async function gh(e,t,i,n){return{...await O(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function _s(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 Es(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:fh,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:_s(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await gh(d,r,o,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${o}" in dropdown ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:_s(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Ss,fh,Gt=b(()=>{"use strict";G();R();P();Ss=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=L(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};fh=xn.object({element_index:xn.number().int().describe("Index of the dropdown/select element"),option:xn.string().describe("Option value, label, or index to select"),timeout_ms:xn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as vn}from"zod";async function wh(e,t,i,n){return{...await O(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Ca(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"set_date_for_native_date_picker",kwargs:t},feedback:"Element not found in DOM"}}function As(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">).
4103
4103
 
4104
4104
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4105
4105
  Do NOT use it for custom/non-native date pickers
4106
4106
 
4107
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:yh,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:Pa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Pa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await bh(`Set date to ${o} on element ${a}`,l,r,o);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${o} on element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Pa(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var As,yh,Kt=y(()=>{"use strict";G();R();P();As=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.date;if(!a)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(a))throw new Error(`Invalid date format: ${a}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(a)),r=L(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout: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},`),"});"]}};yh=vn.object({element_index:vn.number().int().describe("Index of the native date picker input element"),date:vn.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:vn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Is}from"zod";function Ps(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:xh,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:l.message}}}}})}var Cs,xh,jt=y(()=>{"use strict";Cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},xh=Is.object({tab_index:Is.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import vh from"fs";import kh from"path";async function $s(e,t,i,n,a,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return kh.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await kn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await kn(e,u,s,d);return}if(a){let c=r.map(p=>`"${p}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await a(e,u,o)}else throw new Error("No selector provided and AI action execution is not available")}async function kn(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(vh.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var zt=y(()=>{"use strict";N()});import{z as De}from"zod";async function _h(e,t,i={},n){return{...await O(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Ds(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 Os(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:Sh,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:Ds(l||`Upload file to element ${a}`,{index:a,paths:o})};let c=await _h(d,r,{paths:o},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ds(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Ls,Sh,Vb,Vt=y(()=>{"use strict";zt();G();R();P();Ls=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(d=>i.getTestDataFilePath(d)),r=L(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await kn(e,r,o,{useFileInput:s,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(a=>` ${a},`),"});"]}};Sh=De.object({element_index:De.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:De.string().describe("Paths to the files to upload"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Vb=De.object({element_index:De.number().int().describe("Index of the file input element"),paths:De.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Ns}from"zod";function Fs(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Eh,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${a} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:l.message}}}}})}var Rs,Eh,Xt=y(()=>{"use strict";Rs=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});`]}},Eh=Ns.object({seconds:Ns.number().positive().describe("Number of seconds to wait")})});import{z as Hs}from"zod";function Bs(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Th,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:s.message}}}}})}var Ws,Th,Yt=y(()=>{"use strict";Ws=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Th=Hs.object({timeout_seconds:Hs.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Us}from"zod";function Gs(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:Ah,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:l.message}}}}})}var $a,Ah,Jt=y(()=>{"use strict";$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)});`]}},Ah=Us.object({keys:Us.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as Mh}from"zod";function js(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:Ih,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:`Reloaded ${a.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var Ks,Ih,qt=y(()=>{"use strict";R();P();Ks=class{async execute(e,t){await e.reload({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Ih=Mh.object({})});import{z as Da}from"zod";async function Ch(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function zs(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Vs(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Ph,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:zs(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await Ch("right_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:zs(`Right-click element ${a}`,"right_click",{index:a})}}}})}var La,Ph,Zt=y(()=>{"use strict";G();R();P();La=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});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},`),"});"]}};Ph=Da.object({element_index:Da.number().int().describe("Index of the element to right-click"),timeout_ms:Da.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Oa}from"zod";function Ys(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:$h,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:l.message}}}}})}var Xs,$h,Qt=y(()=>{"use strict";Xs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},$h=Oa.object({name:Oa.string().describe("Variable name to save"),value:Oa.string().describe("Value to save in the variable")})});import{z as Na}from"zod";async function Dh(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Lh(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Js(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:Oh,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${a?"down":"up"} ${o} page(s)`,c=await Dh("scroll",d,{down:a,num_pages:o});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Lh(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var ei,Oh,ti=y(()=>{"use strict";ei=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,a=i.kwargs.num_pages??1,o=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${a} * ${o})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Oh=Na.object({down:Na.boolean().describe("True to scroll down, False to scroll up"),num_pages:Na.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as ii}from"zod";async function Nh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function qs(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Qs(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Rh,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:qs(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await Nh("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,d,s,{delta_x:o,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:qs(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Zs,Rh,ni=y(()=>{"use strict";G();R();P();Zs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.delta_x||0,o=n.kwargs.delta_y||0,r=L(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=$e(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}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});`]}};Rh=ii.object({element_index:ii.number().int().describe("Index of the scrollable element"),delta_x:ii.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:ii.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:ii.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as el}from"zod";function il(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Fh,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:l.message}}}}})}var tl,Fh,ai=y(()=>{"use strict";tl=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();`]}},Fh=el.object({text:el.string().describe("Text to scroll to on the page")})});import{z as nl}from"zod";async function Hh(e,t,i){return{...await O(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function al(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 rl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Wh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:al(s||`Get options from dropdown ${a}`,{index:a})};let d=await Hh(l,o,s);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:al(s||`Get options from dropdown ${a}`,{index:a})}}}})}var ol,Wh,oi=y(()=>{"use strict";G();ol=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
4107
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:bh,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:Ca(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Ca(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await wh(`Set date to ${o} on element ${a}`,l,r,o);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${o} on element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ca(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Ts,bh,Kt=b(()=>{"use strict";G();R();P();Ts=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.date;if(!a)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(a))throw new Error(`Invalid date format: ${a}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let o=i.replaceVariables(String(a)),r=L(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout: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},`),"});"]}};bh=vn.object({element_index:vn.number().int().describe("Index of the native date picker input element"),date:vn.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:vn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Ms}from"zod";function Cs(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:yh,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:l.message}}}}})}var Is,yh,jt=b(()=>{"use strict";Is=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},yh=Ms.object({tab_index:Ms.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import xh from"fs";import vh from"path";async function Ps(e,t,i,n,a,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return vh.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await kn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await kn(e,u,s,d);return}if(a){let c=r.map(m=>`"${m}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await a(e,u,o)}else throw new Error("No selector provided and AI action execution is not available")}async function kn(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(xh.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var zt=b(()=>{"use strict";N()});import{z as De}from"zod";async function kh(e,t,i={},n){return{...await O(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function $s(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 Ls(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:_h,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:$s(l||`Upload file to element ${a}`,{index:a,paths:o})};let c=await kh(d,r,{paths:o},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:$s(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Ds,_h,Yb,Vt=b(()=>{"use strict";zt();G();R();P();Ds=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(d=>i.getTestDataFilePath(d)),r=L(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await kn(e,r,o,{useFileInput:s,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(a=>` ${a},`),"});"]}};_h=De.object({element_index:De.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:De.string().describe("Paths to the files to upload"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Yb=De.object({element_index:De.number().int().describe("Index of the file input element"),paths:De.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:De.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Os}from"zod";function Rs(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Sh,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${a} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:l.message}}}}})}var Ns,Sh,Xt=b(()=>{"use strict";Ns=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});`]}},Sh=Os.object({seconds:Os.number().positive().describe("Number of seconds to wait")})});import{z as Fs}from"zod";function Ws(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Eh,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:s.message}}}}})}var Hs,Eh,Yt=b(()=>{"use strict";Hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Eh=Fs.object({timeout_seconds:Fs.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as Bs}from"zod";function Us(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:Th,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:l.message}}}}})}var Pa,Th,Jt=b(()=>{"use strict";Pa=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)});`]}},Th=Bs.object({keys:Bs.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as Ah}from"zod";function Ks(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:Mh,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:`Reloaded ${a.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var Gs,Mh,qt=b(()=>{"use strict";R();P();Gs=class{async execute(e,t){await e.reload({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Mh=Ah.object({})});import{z as $a}from"zod";async function Ih(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function js(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 zs(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Ch,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:js(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await Ih("right_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:js(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Da,Ch,Zt=b(()=>{"use strict";G();R();P();Da=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});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},`),"});"]}};Ch=$a.object({element_index:$a.number().int().describe("Index of the element to right-click"),timeout_ms:$a.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as La}from"zod";function Xs(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Ph,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:l.message}}}}})}var Vs,Ph,Qt=b(()=>{"use strict";Vs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Ph=La.object({name:La.string().describe("Variable name to save"),value:La.string().describe("Value to save in the variable")})});import{z as Oa}from"zod";async function $h(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Dh(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Ys(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:Lh,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${a?"down":"up"} ${o} page(s)`,c=await $h("scroll",d,{down:a,num_pages:o});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Dh(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var ei,Lh,ti=b(()=>{"use strict";ei=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,a=i.kwargs.num_pages??1,o=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${a} * ${o})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Lh=Oa.object({down:Oa.boolean().describe("True to scroll down, False to scroll up"),num_pages:Oa.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as ii}from"zod";async function Oh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Js(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Zs(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Nh,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Js(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await Oh("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,d,s,{delta_x:o,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:Js(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var qs,Nh,ni=b(()=>{"use strict";G();R();P();qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.delta_x||0,o=n.kwargs.delta_y||0,r=L(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=$e(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}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});`]}};Nh=ii.object({element_index:ii.number().int().describe("Index of the scrollable element"),delta_x:ii.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:ii.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:ii.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qs}from"zod";function tl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Rh,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:l.message}}}}})}var el,Rh,ai=b(()=>{"use strict";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();`]}},Rh=Qs.object({text:Qs.string().describe("Text to scroll to on the page")})});import{z as il}from"zod";async function Fh(e,t,i){return{...await O(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function nl(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 ol(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Hh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:nl(s||`Get options from dropdown ${a}`,{index:a})};let d=await Fh(l,o,s);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:nl(s||`Get options from dropdown ${a}`,{index:a})}}}})}var al,Hh,oi=b(()=>{"use strict";G();al=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
4108
4108
  `);a+=`
4109
- Use the exact text string in select_dropdown_option`,i.addNote(a)}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},`),"});"]}};Wh=nl.object({element_index:nl.number().int().describe("Index of the dropdown/select element")})});import{z as Bh}from"zod";function ll(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Uh,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,s,o),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var sl,Uh,ri=y(()=>{"use strict";R();P();sl=class{async execute(e,t){await e.goBack({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Uh=Bh.object({})});import{z as _n}from"zod";function cl(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:Gh,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:a,new_tab:o??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(p){let g=o?`Open ${a} in new tab`:`Navigate to ${a}`;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 Ra,Gh,si=y(()=>{"use strict";R();P();Ra=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},Gh=_n.object({url:_n.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:_n.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:_n.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as Fa}from"zod";async function Kh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function dl(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 ul(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:jh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:dl(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await Kh("hover",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:dl(`Hover element ${a}`,"hover",{index:a})}}}})}var Ha,jh,li=y(()=>{"use strict";G();R();P();Ha=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};jh=Fa.object({element_index:Fa.number().int().describe("Index of the element to hover over"),timeout_ms:Fa.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Sn}from"zod";async function zh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function hl(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 ml(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Vh,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:hl(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await zh("input_text",c,d,r,{text:o});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:hl(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Wa,Vh,ci=y(()=>{"use strict";G();R();P();Wa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text??n.kwargs.value??"",o=i.replaceVariables(String(a)),r=L(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(o,{delay:l}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Vh=Sn.object({element_index:Sn.number().int().describe("Index of the input element"),text:Sn.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:Sn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as pl}from"zod";function fl(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Xh,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var gl,Xh,di=y(()=>{"use strict";gl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.index;if(a===void 0&&(a=e.context().pages().indexOf(e)),typeof a=="number"){if(a===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(a)}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} } },`,"});"]}},Xh=pl.object({index:pl.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as Ba}from"zod";function bl(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Yh,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var wl,Yh,ui=y(()=>{"use strict";wl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Yh=Ba.object({success:Ba.boolean().describe("Whether the task was completed successfully"),summary:Ba.string().describe("Summary of what was accomplished or why it failed")})});import{z as Ua}from"zod";async function Jh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function yl(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 xl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:qh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:yl(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await Jh("double_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:yl(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Ga,qh,hi=y(()=>{"use strict";G();R();P();Ga=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});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},`),"});"]}};qh=Ua.object({element_index:Ua.number().int().describe("Index of the element to double-click"),timeout_ms:Ua.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as vl}from"zod";function _l(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:Zh,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:s.message}}}}})}var kl,Zh,mi=y(()=>{"use strict";kl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.otp_secret_key;if(!a)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(a)),r=await i.generate2faCode(o);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Zh=vl.object({otp_secret_key:vl.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Qh}from"@babel/parser";function Sl(e){if(!e.trim())return!1;try{return Qh(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var En=y(()=>{"use strict"});import{z as El}from"zod";import*as em from"playwright/test";import{default as tm}from"playwright/test";function Tl(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:im,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Ka,Tn,im,pi=y(()=>{"use strict";En();N();me();Ka={};Ni(Ka,{default:()=>tm});Tr(Ka,em);Tn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let p=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(ut(),dt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}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",`
4109
+ Use the exact text string in select_dropdown_option`,i.addNote(a)}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},`),"});"]}};Hh=il.object({element_index:il.number().int().describe("Index of the dropdown/select element")})});import{z as Wh}from"zod";function sl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Bh,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,s,o),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var rl,Bh,ri=b(()=>{"use strict";R();P();rl=class{async execute(e,t){await e.goBack({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Bh=Wh.object({})});import{z as _n}from"zod";function ll(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:Uh,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:a,new_tab:o??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let m=o?`Open ${a} in new tab`:`Navigate to ${a}`,g={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(m){let g=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var Na,Uh,si=b(()=>{"use strict";R();P();Na=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},Uh=_n.object({url:_n.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:_n.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:_n.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as Ra}from"zod";async function Gh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function cl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function dl(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:Kh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:cl(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await Gh("hover",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:cl(`Hover element ${a}`,"hover",{index:a})}}}})}var Fa,Kh,li=b(()=>{"use strict";G();R();P();Fa=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};Kh=Ra.object({element_index:Ra.number().int().describe("Index of the element to hover over"),timeout_ms:Ra.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Sn}from"zod";async function jh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function ul(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 hl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:zh,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await H(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:ul(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await jh("input_text",c,d,r,{text:o});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:ul(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Ha,zh,ci=b(()=>{"use strict";G();R();P();Ha=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text??n.kwargs.value??"",o=i.replaceVariables(String(a)),r=L(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(o,{delay:l}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};zh=Sn.object({element_index:Sn.number().int().describe("Index of the input element"),text:Sn.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:Sn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ml}from"zod";function gl(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Vh,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var pl,Vh,di=b(()=>{"use strict";pl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.index;if(a===void 0&&(a=e.context().pages().indexOf(e)),typeof a=="number"){if(a===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(a)}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} } },`,"});"]}},Vh=ml.object({index:ml.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as Wa}from"zod";function wl(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Xh,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var fl,Xh,ui=b(()=>{"use strict";fl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Xh=Wa.object({success:Wa.boolean().describe("Whether the task was completed successfully"),summary:Wa.string().describe("Summary of what was accomplished or why it failed")})});import{z as Ba}from"zod";async function Yh(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function bl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function yl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Jh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:bl(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await Yh("double_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:bl(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Ua,Jh,hi=b(()=>{"use strict";G();R();P();Ua=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});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},`),"});"]}};Jh=Ba.object({element_index:Ba.number().int().describe("Index of the element to double-click"),timeout_ms:Ba.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as xl}from"zod";function kl(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:qh,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:s.message}}}}})}var vl,qh,mi=b(()=>{"use strict";vl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.otp_secret_key;if(!a)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(a)),r=await i.generate2faCode(o);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},qh=xl.object({otp_secret_key:xl.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Zh}from"@babel/parser";function _l(e){if(!e.trim())return!1;try{return Zh(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var En=b(()=>{"use strict"});import{z as Sl}from"zod";import*as Qh from"playwright/test";import{default as em}from"playwright/test";function El(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:tm,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var Ga,Tn,tm,pi=b(()=>{"use strict";En();N();me();Ga={};Ni(Ga,{default:()=>em});Er(Ga,Qh);Tn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let m=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(ut(),dt)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}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",`
4110
4110
  return (async () => {
4111
4111
  ${t}
4112
4112
  })();
4113
- `)(e,Ka.expect,n)}catch(a){throw new Error(`Assertion failed: ${a instanceof Error?a.message:String(a)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(n){let r=i.code;if(!Sl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
4113
+ `)(e,Ga.expect,n)}catch(a){throw new Error(`Assertion failed: ${a instanceof Error?a.message:String(a)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(n){let r=i.code;if(!_l(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
4114
4114
  `),l=JSON.stringify(a);return["{ const _t = Date.now(); try {",...s.map(d=>` ${d}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${o});`,"} }"]}return r.split(`
4115
- `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},im=El.object({statement:El.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as ja}from"zod";function Ml(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:nm,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${a} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Al,nm,gi=y(()=>{"use strict";Al=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(ut(),dt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},nm=ja.object({element_description:ja.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:ja.string().describe("Name of the variable to store the extracted value")})});import{z as za}from"zod";async function am(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Il(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Pl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:om,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Il(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await am("clear_input",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Cleared element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Il(`Clear element ${a}`,"clear_input",{index:a})}}}})}var Cl,om,fi=y(()=>{"use strict";G();R();P();Cl=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),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},`),"});"]}};om=za.object({element_index:za.number().int().describe("Index of the input element to clear"),timeout_ms:za.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Va}from"zod";async function rm(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function $l(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Dl(e,t){e.register({name:"click",description:"Click an interactive element.",schema:sm,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:$l(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await rm("click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:$l(`Click element ${a}`,"click",{index:a})}}}})}var An,sm,wi=y(()=>{"use strict";G();R();P();An=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=$e(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};sm=Va.object({element_index:Va.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Va.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var lm,cm,bi,Mn=y(()=>{"use strict";lm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],cm=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],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:lm.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,a=i.variable_name;return n&&a?`Extract ${n} and save to ${a}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!cm.includes(t)}}});var Xa,Ya,In,Ja=y(()=>{"use strict";ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();Mn();R();me();Xa=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 Ra),M.registerAction("go_back",new sl),M.registerAction("reload_page",new Ks),M.registerAction("close_tab",new gl),M.registerAction("switch_tab",new Cs),M.registerAction("click",new An),M.registerAction("hover",new Ha),M.registerAction("right_click",new La),M.registerAction("double_click",new Ga),M.registerAction("click_by_coordinates",new ms),M.registerAction("right_click_by_coordinates",new cs),M.registerAction("double_click_by_coordinates",new ps),M.registerAction("drag_drop",new gs),M.registerAction("input_text",new Wa),M.registerAction("clear_input",new Cl),M.registerAction("press",new $a),M.registerAction("send_keys_on_element",new ss),M.registerAction("scroll_on_element",new Zs),M.registerAction("scroll_to_text",new tl),M.registerAction("scroll",new ei),M.registerAction("upload_file",new Ls),M.registerAction("wait_for_download_complete",new Ws),M.registerAction("get_dropdown_options",new ol),M.registerAction("select_dropdown_option",new Es),M.registerAction("set_date_for_native_date_picker",new As),M.registerAction("verify",new Tn),M.registerAction("ai_action",new ys),M.registerAction("ai_extract",new Al),M.registerAction("ai_step",new vs),M.registerAction("ai_wait_until",new ks),M.registerAction("generate_2fa_code",new kl),M.registerAction("wait",new Rs),M.registerAction("wait_for_page_ready",new ls),M.registerAction("save_variable",new Xs),M.registerAction("js_code",new hs),M.registerAction("js_action",new ds),M.registerAction("function",new fs),M.registerAction("done",new wl),M.registerAction("click_element",new An),M.registerAction("click_element_by_index",new An),M.registerAction("hover_element_by_index",new Ha),M.registerAction("right_click_on_element",new La),M.registerAction("double_click_on_element",new Ga),M.registerAction("scroll_down",new ei),M.registerAction("scroll_up",new ei),M.registerAction("scroll_element",new ei),M.registerAction("send_keys",new $a),M.registerAction("open_tab",new Ra),M.registerAction("fill",new Wa),M.registerAction("ai_assert",new Tn),M.registerAction("assert",new Tn)}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 a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(P(),ya(Ri)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(bi.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(g=>` ${g}`),u=bi.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(P(),ya(Ri));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(a){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};Xa.actions=new Map,Xa.initialized=!1;Ya=Xa,In=Ya});var mt={};Ze(mt,{ActionHandler:()=>Ya,default:()=>In});var pt=y(()=>{"use strict";Ja();ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();En();zt();G();Be();N();Q();ct();Mn();R();me()});import{z as yi}from"zod";function Cn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4116
- ${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,u)=>{let p=c.action_description||"Unknown action";d+=`
4117
- \u2192 Action ${u+1}: ${p}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
4115
+ `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},tm=Sl.object({statement:Sl.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as Ka}from"zod";function Al(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:im,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${a} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Tl,im,gi=b(()=>{"use strict";Tl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(ut(),dt)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},im=Ka.object({element_description:Ka.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Ka.string().describe("Name of the variable to store the extracted value")})});import{z as ja}from"zod";async function nm(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ml(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Cl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:am,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Ml(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await nm("clear_input",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Cleared element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Ml(`Clear element ${a}`,"clear_input",{index:a})}}}})}var Il,am,fi=b(()=>{"use strict";G();R();P();Il=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),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},`),"});"]}};am=ja.object({element_index:ja.number().int().describe("Index of the input element to clear"),timeout_ms:ja.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as za}from"zod";async function om(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Pl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function $l(e,t){e.register({name:"click",description:"Click an interactive element.",schema:rm,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await H(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Pl(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await om("click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Pl(`Click element ${a}`,"click",{index:a})}}}})}var An,rm,wi=b(()=>{"use strict";G();R();P();An=class{async execute(e,t,i){let n=L(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=$e(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};rm=za.object({element_index:za.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:za.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var sm,lm,bi,Mn=b(()=>{"use strict";sm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],lm=["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:sm.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,a=i.variable_name;return n&&a?`Extract ${n} and save to ${a}`: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:!lm.includes(t)}}});var Va,Xa,In,Ya=b(()=>{"use strict";ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();Mn();R();me();Va=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 Na),M.registerAction("go_back",new rl),M.registerAction("reload_page",new Gs),M.registerAction("close_tab",new pl),M.registerAction("switch_tab",new Is),M.registerAction("click",new An),M.registerAction("hover",new Fa),M.registerAction("right_click",new Da),M.registerAction("double_click",new Ua),M.registerAction("click_by_coordinates",new hs),M.registerAction("right_click_by_coordinates",new ls),M.registerAction("double_click_by_coordinates",new ms),M.registerAction("drag_drop",new ps),M.registerAction("input_text",new Ha),M.registerAction("clear_input",new Il),M.registerAction("press",new Pa),M.registerAction("send_keys_on_element",new rs),M.registerAction("scroll_on_element",new qs),M.registerAction("scroll_to_text",new el),M.registerAction("scroll",new ei),M.registerAction("upload_file",new Ds),M.registerAction("wait_for_download_complete",new Hs),M.registerAction("get_dropdown_options",new al),M.registerAction("select_dropdown_option",new Ss),M.registerAction("set_date_for_native_date_picker",new Ts),M.registerAction("verify",new Tn),M.registerAction("ai_action",new bs),M.registerAction("ai_extract",new Tl),M.registerAction("ai_step",new xs),M.registerAction("ai_wait_until",new vs),M.registerAction("generate_2fa_code",new vl),M.registerAction("wait",new Ns),M.registerAction("wait_for_page_ready",new ss),M.registerAction("save_variable",new Vs),M.registerAction("js_code",new us),M.registerAction("js_action",new cs),M.registerAction("function",new gs),M.registerAction("done",new fl),M.registerAction("click_element",new An),M.registerAction("click_element_by_index",new An),M.registerAction("hover_element_by_index",new Fa),M.registerAction("right_click_on_element",new Da),M.registerAction("double_click_on_element",new Ua),M.registerAction("scroll_down",new ei),M.registerAction("scroll_up",new ei),M.registerAction("scroll_element",new ei),M.registerAction("send_keys",new Pa),M.registerAction("open_tab",new Na),M.registerAction("fill",new Ha),M.registerAction("ai_assert",new Tn),M.registerAction("assert",new Tn)}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 a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(P(),ya(Ri)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(bi.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(g=>` ${g}`),u=bi.canSelfHeal(t),m=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${m}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(P(),ya(Ri));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(a){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};Va.actions=new Map,Va.initialized=!1;Xa=Va,In=Xa});var mt={};Ze(mt,{ActionHandler:()=>Xa,default:()=>In});var pt=b(()=>{"use strict";Ya();ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();En();zt();G();Be();N();Q();ct();Mn();R();me()});import{z as yi}from"zod";function Cn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4116
+ ${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,u)=>{let m=c.action_description||"Unknown action";d+=`
4117
+ \u2192 Action ${u+1}: ${m}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
4118
4118
  \u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
4119
4119
  Error: ${c}${l.outcome.error.length>100?"...":""}`}return l.evaluation&&(d+=`
4120
4120
  Eval: ${l.evaluation}`),d}).join(`
@@ -4132,7 +4132,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
4132
4132
  **Current URL**: ${i}
4133
4133
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4134
4134
 
4135
- ${o()}${r()}${a()}${n()}${s()}`.trim()}function Ll(){return`
4135
+ ${o()}${r()}${a()}${n()}${s()}`.trim()}function Dl(){return`
4136
4136
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4137
4137
 
4138
4138
  This is your last step. You MUST use the "done" action now.
@@ -4141,7 +4141,7 @@ This is your last step. You MUST use the "done" action now.
4141
4141
  - If the task is incomplete or partially complete, set success=false
4142
4142
  - Include everything you've accomplished in the done action's text field
4143
4143
  - No other actions are allowed on this step
4144
- `.trim()}function dm(){let e=F.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 yi.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof yi.ZodNumber?l="number":s instanceof yi.ZodString?l="string":s instanceof yi.ZodBoolean?l="boolean":s instanceof yi.ZodEnum&&(l=s._def.values.map(d=>`"${d}"`).join(" | ")),o.push(`${r}: ${l}`)}),n=`{${o.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(`
4144
+ `.trim()}function cm(){let e=F.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 yi.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof yi.ZodNumber?l="number":s instanceof yi.ZodString?l="string":s instanceof yi.ZodBoolean?l="boolean":s instanceof yi.ZodEnum&&(l=s._def.values.map(d=>`"${d}"`).join(" | ")),o.push(`${r}: ${l}`)}),n=`{${o.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(`
4145
4145
  `)}function Pn(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
4146
4146
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4147
4147
  - "success: <reason>" if the goal was fully achieved
@@ -4164,7 +4164,7 @@ This is your last step. You MUST use the "done" action now.
4164
4164
  `:"",d=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
4165
4165
  `:"",c=a?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
4166
4166
  `:"",u=n?` "memory": "<important facts to remember>", // Update only when learning something new
4167
- `:"",p=o?` "actions": [ // Can be single action or multiple actions in sequence
4167
+ `:"",m=o?` "actions": [ // Can be single action or multiple actions in sequence
4168
4168
  {
4169
4169
  "description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
4170
4170
  "action_name": "<name of action to execute>",
@@ -4249,7 +4249,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4249
4249
 
4250
4250
  When stuck, call \`done\` with success=false and explain what happened.
4251
4251
 
4252
- ${dm()}
4252
+ ${cm()}
4253
4253
  ## Reasoning Rules
4254
4254
 
4255
4255
  Use the \`thinking\` field to reason about each step:
@@ -4267,7 +4267,7 @@ You must ALWAYS respond with a valid JSON in this exact format:
4267
4267
  \`\`\`json
4268
4268
  {
4269
4269
  ${d}${c}${u} "current_goal": "State the current goal. Include only what to achieve, not how to achieve it.",
4270
- ${p}
4270
+ ${m}
4271
4271
  "completes_instruction": true | false // Is the entire task complete?
4272
4272
  }
4273
4273
  \`\`\`
@@ -4285,13 +4285,13 @@ ${p}
4285
4285
  **Current Goal Examples:**
4286
4286
  - "Add the product to the cart"
4287
4287
  - "Find more product listings and extract details from the next 5 items on the page"
4288
- ${g}`.trim()}var $n=y(()=>{"use strict";Se()});var Dn,qa=y(()=>{"use strict";$n();ee();Dn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,a,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=o,u=[],p=Cn(a,e,t);if(u.push({type:"text",text:p}),u.push({type:"text",text:`## CURRENT PAGE STATE
4288
+ ${g}`.trim()}var $n=b(()=>{"use strict";Se()});var Dn,Ja=b(()=>{"use strict";$n();ee();Dn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,a,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=o,u=[],m=Cn(a,e,t);if(u.push({type:"text",text:m}),u.push({type:"text",text:`## CURRENT PAGE STATE
4289
4289
 
4290
4290
  **Interactive Elements**:
4291
- ${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([f,k],x)=>`${x+1}. ${f} \u2192 ${k}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4291
+ ${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([w,k],y)=>`${y+1}. ${w} \u2192 ${k}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4292
4292
 
4293
4293
  ${g.join(`
4294
- `)}`})}if(s&&Object.keys(s).length>0){w.log("Adding placeholder data description");let g=this.getPlaceholderDataDescription(s,l);w.log(`Placeholder data description: ${g}`),g&&u.push({type:"text",text:g})}d&&c&&u.push({type:"text",text:c}),u.push({type:"image",image:n}),w.log(`Adding state message: ${u.length} parts`),this.messages.push({role:"user",content:u})}addAssistantMessage(e){this.messages.push({role:"assistant",content:e})}addTextMessage(e,t){this.messages.push({role:e,content:t})}getMessageCount(){return this.messages.length}clear(){this.messages=[]}getRecentMessages(e){return this.messages.slice(-e)}updateSystemPrompt(e){this.systemPrompt=e}addAssistantMessageWithToolCalls(e){this.messages.push({role:"assistant",content:e.map(t=>({type:"tool-call",toolCallId:t.toolCallId,toolName:t.toolName,input:t.input}))})}addToolResponseMessage(e,t,i){this.messages.push({role:"tool",content:[{type:"tool-result",toolCallId:t,toolName:i,output:typeof e=="string"?{type:"text",value:e}:{type:"json",value:e}}]})}getPlaceholderDataDescription(e,t){let i=[];for(let a of Object.keys(e))if(e[a])if(t?.has(a))i.push(` - ${a}: [SENSITIVE - value hidden]`);else{let o=e[a],r=typeof o=="string"?o:JSON.stringify(o);i.push(` - ${a}: "${r}"`)}if(i.length===0)return"";let n=`## DATA PLACEHOLDERS
4294
+ `)}`})}if(s&&Object.keys(s).length>0){f.log("Adding placeholder data description");let g=this.getPlaceholderDataDescription(s,l);f.log(`Placeholder data description: ${g}`),g&&u.push({type:"text",text:g})}d&&c&&u.push({type:"text",text:c}),u.push({type:"image",image:n}),f.log(`Adding state message: ${u.length} parts`),this.messages.push({role:"user",content:u})}addAssistantMessage(e){this.messages.push({role:"assistant",content:e})}addTextMessage(e,t){this.messages.push({role:e,content:t})}getMessageCount(){return this.messages.length}clear(){this.messages=[]}getRecentMessages(e){return this.messages.slice(-e)}updateSystemPrompt(e){this.systemPrompt=e}addAssistantMessageWithToolCalls(e){this.messages.push({role:"assistant",content:e.map(t=>({type:"tool-call",toolCallId:t.toolCallId,toolName:t.toolName,input:t.input}))})}addToolResponseMessage(e,t,i){this.messages.push({role:"tool",content:[{type:"tool-result",toolCallId:t,toolName:i,output:typeof e=="string"?{type:"text",value:e}:{type:"json",value:e}}]})}getPlaceholderDataDescription(e,t){let i=[];for(let a of Object.keys(e))if(e[a])if(t?.has(a))i.push(` - ${a}: [SENSITIVE - value hidden]`);else{let o=e[a],r=typeof o=="string"?o:JSON.stringify(o);i.push(` - ${a}: "${r}"`)}if(i.length===0)return"";let n=`## DATA PLACEHOLDERS
4295
4295
 
4296
4296
  `;return n+=`The following placeholders are available for use in your actions:
4297
4297
  `,n+=`${i.join(`
@@ -4301,7 +4301,7 @@ ${g.join(`
4301
4301
  `,n+=`- Use the EXACT placeholder name as shown above
4302
4302
  `,n+=`- Do NOT use the actual value directly in the action
4303
4303
  `,n+=`- The values shown are for context only to help you understand what data is available
4304
- `,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 gt,ft=y(()=>{"use strict";gt=`
4304
+ `,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 gt,ft=b(()=>{"use strict";gt=`
4305
4305
  // check to make sure we're not inside the PDF viewer
4306
4306
  window.isPdfViewer = !!document?.body?.querySelector('body > embed[type="application/pdf"][width="100%"]')
4307
4307
  if (!window.isPdfViewer) {
@@ -4356,9 +4356,9 @@ if (!window.isPdfViewer) {
4356
4356
  };
4357
4357
  })();
4358
4358
  }
4359
- `});function Ol(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 Nl(e,t){let i=await e.newContext(t);return i.addInitScript(gt),i}async function Ln(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Rl(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 Fl(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function gm(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=u=>{let p=u.resourceType(),g=u.url();if(!a.has(p)||s(g))return;let f=u.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let p=u.request();if(!i.has(p))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(p);return}if(![...o].some(k=>g.startsWith(k))){i.delete(p);return}let f=u.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-pm;for(let u of await e.requests()){let p=u.resourceType(),g=u.url(),f=u.timing();a.has(p)&&!s(g)&&f.responseEnd===-1&&f.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),p=mm;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-n>=p){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ee(e,t=hm,i=um){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),gm(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let a=Date.now()-n,o=Math.max(i-a,0);o>0&&await new Promise(r=>setTimeout(r,o))}var On,um,hm,mm,pm,Te=y(()=>{"use strict";ft();N();On=async(e,t,i)=>{let n=await e.context().newCDPSession(e),a=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:a.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((o,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},um=.5*1e3,hm=30*1e3,mm=1*1e3,pm=3*1e3});import{generateText as fm}from"ai";function wm(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 Wl(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 a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new le(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${a}`),w.log(`Model: ${r}`);let d={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Pn(i.customPrompt),p=new Dn(u);w.log(`System prompt length: ${u.length} chars`);let g=!1,f="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});d.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();w.section(`Step ${d.currentStep}/${a}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{w.log("Waiting for page to stabilize..."),await Ee(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let m;try{w.log("Preparing context (DOM + screenshot)...");let C=l.agentServices.getInteractiveClassNames(),I=l.agentServices.getIframeFallbackDomains();m=await Hl(l.page,l.domService,C,I),w.log("Context prepared")}catch(C){if(C.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Ee(l.page);let I=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();m=await Hl(l.page,l.domService,I,$)}else throw w.error("Error preparing context",C),C}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let b=await ym(p,r,i,m.screenshotBase64);if(b.tokenUsages&&b.tokenUsages.length>0&&c.push(...b.tokenUsages),!b.stepOutput){if(w.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let _=b.stepOutput;_m(d.currentStep,a,_);let v=await vm(_,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,b.debugInfo);k.push(...v.actionEntities);let S=km(d.currentStep,_,v,d,x,b.debugInfo,b.tokenUsages),A=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=o){w.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,f=v.doneResult.summary;break}if(v.completesInstruction){g=!0,f="Instruction completed";break}}return d.currentStep>=a&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${k.length}, tokens=${c.length}`),Sm(d,k,g,f,n,c,r)}catch(x){let m=x.message;return w.error(`Task execution failed: ${m}`,x),i.onEvent?.({type:"error",error:m,recoverable:!1}),Em(d,m,n,c,r)}}async function Hl(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function bm(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,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 ym(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(p=>p.type==="image").length);let l=we(t,s),d={model:fe(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let p=Date.now();w.log(`Calling LLM (${t})...`);let g=await fm(d),f=Date.now()-p,k=g,x=k.usage;w.llmCall(t,f,x);let m=k.reasoningText;m&&(w.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let b={systemPrompt:o,userPrompt:bm(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},_=[],v=wm(x,t);v&&_.push(v);let S=xm(g.text);if(!S)if(u<c-1){w.log(`Attempt ${u+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(A=>setTimeout(A,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:b,tokenUsages:_};return{stepOutput:S,debugInfo:b,tokenUsages:_}}catch(p){if(u<c-1){w.log(`Attempt ${u+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function xm(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return w.error("Action missing required field: action_name"),null;if(!n.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function vm(e,t,i,n,a,o,r){let s=[],l=!0,d=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},p=o;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 f={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let m=i.selectorMap.get(k);m&&(f=await O(t.page,m))}let x={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await F.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(x=m.actionEntity);let b=await u.agentServices.getCurrentPage();if(b&&(u.page=b,t.page=u.page),m?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(x),a?.({type:"action",action_entity:x,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,w.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function km(e,t,i,n,a,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function _m(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];w.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{w.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Sm(e,t,i,n,a,o,r){let s=o.reduce((c,u)=>c+u.prompt_tokens,0),l=o.reduce((c,u)=>c+u.completion_tokens,0),d=o.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-a,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:o}}}function Em(e,t,i,n,a){let o=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:a,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Bl=y(()=>{"use strict";qa();$n();Se();Ue();ee();Te();_e();G()});var Ul={};Ze(Ul,{TaskMessageManager:()=>Dn,formatFinalStepWarning:()=>Ll,formatTaskContext:()=>Cn,getBrowserTaskJSONPrompt:()=>Pn,runTaskLoop:()=>Wl});var Gl=y(()=>{"use strict";Bl();qa();$n();Se();wn();Ue();Lt();Nt();lt();Rt();Ft();ee();Te();ft();_e();At();Mt();it();G();Be();N();Q();ct();R();me()});async function Wt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(F.has(i)){let a=await F.execute(i,n,t),o=a?.success!==!1,r=a?.error||a?.message;return{success:o,error:o?void 0:r}}else{let{page:a,agentServices:o}=t;return await(await Tm()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Tm(){if(Nn)return Nn;let e=await Promise.resolve().then(()=>(pt(),mt));return Nn=new e.default,Nn}async function ht(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ta(r,o,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function Ge(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ta(r,o,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,p=await Wt(l,o);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:u}}async function Ke(e,t,i,n={}){let a={page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Jr(o,a,n)}async function je(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Gl(),Ul)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Nn,Bt=y(()=>{"use strict";an();Se();Ue();Nn=null});import{z as Kl}from"zod";function jl(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:Am,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await at(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await Wt(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var Am,Za=y(()=>{"use strict";Bt();ot();Am=Kl.object({instruction:Kl.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});import{generateText as Mm}from"ai";import{convert as Im}from"html-to-text";async function Cm(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let f=(c.message||{}).headers||{},k=f.subject||"",x=f.from||"",m=f.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:k,from:x,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let p=u.split("/"),g=p[p.length-1];if(h.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${a}/messages/${g}`;try{let k=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let x=await k.json(),m=x.Subject||"",b=x.From||"",_=x.To||"",v=x.Date||"",S=x["Message-Id"]||"";h.info(`subject: ${m}`),h.info(`from_addr: ${b}`),h.info(`to_addr: ${_}`),h.info(`date: ${v}`),h.info(`message_id: ${S}`);let A=x["body-html"]||x["body-plain"]||"";if(A&&A.includes("<")&&(A=Im(A)),h.info(`Body: ${A.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:m,from:b,to:_,date:v,body:A,message_id:S});continue}else h.warn(`Messages API returned ${k.status}`)}catch(k){h.warn(`Failed to parse JSON response: ${k}`)}}try{let f=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!f.ok){h.warn(`Could not fetch stored message: ${f.status}`);continue}let k=await f.text();h.info(`Fallback: Raw email length: ${k.length}`);let x=k.split(`
4360
- `),m=!0,b={},_="";for(let $=0;$<x.length;$++){let U=x[$];if(U.trim()===""&&m){m=!1;continue}if(m){let q=U.match(/^([^:]+):\s*(.+)$/);q&&(b[q[1].toLowerCase()]=q[2])}else _+=U+`
4361
- `}let v=b.subject||"",S=b.from||"",A=b.to||"",C=b.date||"",I=b["message-id"]||"";if(i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!_.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:v,from:S,to:A,date:C,body:_.trim(),message_id:I})}catch(f){h.warn(`Error fetching raw message: ${f}`)}}if(o.length>0){try{o.sort((u,p)=>{let g=new Date(u.date).getTime();return new Date(p.date).getTime()-g})}catch{}let c=o[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return o}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Pm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4359
+ `});function Ll(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 Ol(e,t){let i=await e.newContext(t);return i.addInitScript(gt),i}async function Ln(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Nl(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 Rl(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function pm(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let m=u.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(g=>m.includes(g))},l=u=>{let m=u.resourceType(),g=u.url();if(!a.has(m)||s(g))return;let w=u.headers();w.purpose==="prefetch"||["video","audio"].includes(w["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(m);return}if(![...o].some(k=>g.startsWith(k))){i.delete(m);return}let w=u.headers()["content-length"];if(w)try{if(parseInt(w,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-mm;for(let u of await e.requests()){let m=u.resourceType(),g=u.url(),w=u.timing();a.has(m)&&!s(g)&&w.responseEnd===-1&&w.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=hm;for(;;){await new Promise(w=>setTimeout(w,100));let g=Date.now();if(i.size===0&&g-n>=m){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ee(e,t=um,i=dm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),pm(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let a=Date.now()-n,o=Math.max(i-a,0);o>0&&await new Promise(r=>setTimeout(r,o))}var On,dm,um,hm,mm,Te=b(()=>{"use strict";ft();N();On=async(e,t,i)=>{let n=await e.context().newCDPSession(e),a=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:a.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((o,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},dm=.5*1e3,um=30*1e3,hm=1*1e3,mm=3*1e3});import{generateText as gm}from"ai";function fm(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 Hl(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 a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new le(t.agentServices.getDomServiceOptions()),l={...t,domService:s};f.init(),f.section("Task Execution Started"),f.log(`Task: ${e}`),f.log(`Max steps: ${a}`),f.log(`Model: ${r}`);let d={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Pn(i.customPrompt),m=new Dn(u);f.log(`System prompt length: ${u.length} chars`);let g=!1,w="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});d.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let y=Date.now();f.section(`Step ${d.currentStep}/${a}`),f.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{f.log("Waiting for page to stabilize..."),await Ee(l.page),f.log("Page stabilized")}catch{f.log("Page stabilization timed out, continuing anyway")}let p;try{f.log("Preparing context (DOM + screenshot)...");let C=l.agentServices.getInteractiveClassNames(),I=l.agentServices.getIframeFallbackDomains();p=await Fl(l.page,l.domService,C,I),f.log("Context prepared")}catch(C){if(C.message.includes("Execution context was destroyed")){f.log("Page navigating, waiting for load..."),await Ee(l.page);let I=l.agentServices.getInteractiveClassNames(),$=l.agentServices.getIframeFallbackDomains();p=await Fl(l.page,l.domService,I,$)}else throw f.error("Error preparing context",C),C}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await bm(m,r,i,p.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&c.push(...x.tokenUsages),!x.stepOutput){if(f.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=o){w="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let _=x.stepOutput;km(d.currentStep,a,_);let v=await xm(_,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,x.debugInfo);k.push(...v.actionEntities);let S=vm(d.currentStep,_,v,d,y,x.debugInfo,x.tokenUsages),A=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=o){f.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),w=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,w=v.doneResult.summary;break}if(v.completesInstruction){g=!0,w="Instruction completed";break}}return d.currentStep>=a&&!g&&(w="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),f.log(`Build success result: summary=${w}, completed=${g}, actions=${k.length}, tokens=${c.length}`),_m(d,k,g,w,n,c,r)}catch(y){let p=y.message;return f.error(`Task execution failed: ${p}`,y),i.onEvent?.({type:"error",error:p,recoverable:!1}),Sm(d,p,n,c,r)}}async function Fl(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function wm(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,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 bm(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(m=>m.type==="image").length);let l=we(t,s),d={model:fe(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();f.log(`Calling LLM (${t})...`);let g=await gm(d),w=Date.now()-m,k=g,y=k.usage;f.llmCall(t,w,y);let p=k.reasoningText;p&&(f.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:wm(r),rawLlmResponse:g.text,reasoningContent:p,screenshotWithSom:n},_=[],v=fm(y,t);v&&_.push(v);let S=ym(g.text);if(!S)if(u<c-1){f.log(`Attempt ${u+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(A=>setTimeout(A,i.retryDelay||1e3));continue}else return f.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:_};return{stepOutput:S,debugInfo:x,tokenUsages:_}}catch(m){if(u<c-1){f.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw f.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function ym(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 f.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return f.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return f.error("Action missing required field: action_name"),null;if(!n.description)return f.error("Action missing required field: description"),null}return i}catch(i){return f.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),f.error(`Parse error: ${i.message}`),null}}async function xm(e,t,i,n,a,o,r){let s=[],l=!0,d=null;f.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},m=o;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let w={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let p=i.selectorMap.get(k);p&&(w=await O(t.page,p))}let y={...w,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let p=await F.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(y=p.actionEntity);let x=await u.agentServices.getCurrentPage();if(x&&(u.page=x,t.page=u.page),p?.success===!1){l=!1,f.log("Action failed, stopping execution of remaining actions in this step"),d=p.error||"Action execution failed";break}s.push(y),a?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(p){l=!1,d=p.message,f.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function vm(e,t,i,n,a,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function km(e,t,i){if(f.log(`Step ${e}/${t}`),i.thinking&&f.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&f.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&f.log(`Memory: ${i.memory}`),f.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];f.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else f.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{f.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function _m(e,t,i,n,a,o,r){let s=o.reduce((c,u)=>c+u.prompt_tokens,0),l=o.reduce((c,u)=>c+u.completion_tokens,0),d=o.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-a,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:o}}}function Sm(e,t,i,n,a){let o=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:a,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Wl=b(()=>{"use strict";Ja();$n();Se();Ue();ee();Te();_e();G()});var Bl={};Ze(Bl,{TaskMessageManager:()=>Dn,formatFinalStepWarning:()=>Dl,formatTaskContext:()=>Cn,getBrowserTaskJSONPrompt:()=>Pn,runTaskLoop:()=>Hl});var Ul=b(()=>{"use strict";Wl();Ja();$n();Se();wn();Ue();Lt();Nt();lt();Rt();Ft();ee();Te();ft();_e();At();it();Mt();G();Be();N();Q();ct();R();me()});async function Wt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(F.has(i)){let a=await F.execute(i,n,t),o=a?.success!==!1,r=a?.error||a?.message;return{success:o,error:o?void 0:r}}else{let{page:a,agentServices:o}=t;return await(await Em()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Em(){if(Nn)return Nn;let e=await Promise.resolve().then(()=>(pt(),mt));return Nn=new e.default,Nn}async function ht(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ea(r,o,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function Ge(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ea(r,o,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,m=await Wt(l,o);return m.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:m.error||"Action execution failed",debugInfo:u}}async function Ke(e,t,i,n={}){let a={page:t,agentServices:i,domService:new le(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Yr(o,a,n)}async function je(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Ul(),Bl)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Nn,Bt=b(()=>{"use strict";an();Se();Ue();Nn=null});import{z as Gl}from"zod";function Kl(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:Tm,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await at(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await Wt(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var Tm,qa=b(()=>{"use strict";Bt();ot();Tm=Gl.object({instruction:Gl.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});import{generateText as Am}from"ai";import{convert as Mm}from"html-to-text";async function Im(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let w=(c.message||{}).headers||{},k=w.subject||"",y=w.from||"",p=w.to||"";if(i.from_email&&!y.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:k,from:y,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:w["message-id"]||""});continue}let m=u.split("/"),g=m[m.length-1];if(h.info(`Storage key: ${g}`),g){let w=`https://api.mailgun.net/v3/domains/${a}/messages/${g}`;try{let k=await fetch(w,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let y=await k.json(),p=y.Subject||"",x=y.From||"",_=y.To||"",v=y.Date||"",S=y["Message-Id"]||"";h.info(`subject: ${p}`),h.info(`from_addr: ${x}`),h.info(`to_addr: ${_}`),h.info(`date: ${v}`),h.info(`message_id: ${S}`);let A=y["body-html"]||y["body-plain"]||"";if(A&&A.includes("<")&&(A=Mm(A)),h.info(`Body: ${A.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:p,from:x,to:_,date:v,body:A,message_id:S});continue}else h.warn(`Messages API returned ${k.status}`)}catch(k){h.warn(`Failed to parse JSON response: ${k}`)}}try{let w=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!w.ok){h.warn(`Could not fetch stored message: ${w.status}`);continue}let k=await w.text();h.info(`Fallback: Raw email length: ${k.length}`);let y=k.split(`
4360
+ `),p=!0,x={},_="";for(let $=0;$<y.length;$++){let U=y[$];if(U.trim()===""&&p){p=!1;continue}if(p){let q=U.match(/^([^:]+):\s*(.+)$/);q&&(x[q[1].toLowerCase()]=q[2])}else _+=U+`
4361
+ `}let v=x.subject||"",S=x.from||"",A=x.to||"",C=x.date||"",I=x["message-id"]||"";if(i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!_.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:v,from:S,to:A,date:C,body:_.trim(),message_id:I})}catch(w){h.warn(`Error fetching raw message: ${w}`)}}if(o.length>0){try{o.sort((u,m)=>{let g=new Date(u.date).getTime();return new Date(m.date).getTime()-g})}catch{}let c=o[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return o}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Cm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4362
4362
 
4363
4363
  Please carefully examine the email content and look for:
4364
4364
  1. Numeric codes (usually 4-8 digits)
@@ -4415,28 +4415,28 @@ Examples of what to extract:
4415
4415
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4416
4416
 
4417
4417
  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+`
4418
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function $m(e,t,i){try{let n=`${t}
4418
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Pm(e,t,i){try{let n=`${t}
4419
4419
  ---
4420
4420
  Email Content:
4421
4421
  ---
4422
4422
  ${e}
4423
4423
  ---
4424
- `,a=fe(i);return(await Mm({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:we(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw h.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function zl(e,t){h.info(`extract_email_content:
4424
+ `,a=fe(i);return(await Am({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:we(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw h.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function jl(e,t){h.info(`extract_email_content:
4425
4425
  forward_email: ${t.forward_email}
4426
4426
  extraction_type: ${t.extraction_type}
4427
4427
  filters: ${JSON.stringify(t.filters||{})}
4428
4428
  timeout: ${t.timeout||60}
4429
- 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 a=Pm(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(h.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,h.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await Cm(e,t.forward_email,d);if(c.length>0){h.info(`Found ${c.length} emails matching criteria`);let u=[];for(let p of c){let g=`Subject: ${p.subject}
4430
- From: ${p.from}
4431
- To: ${p.to}
4432
- Date: ${p.date}
4429
+ 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 a=Cm(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(h.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,h.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await Im(e,t.forward_email,d);if(c.length>0){h.info(`Found ${c.length} emails matching criteria`);let u=[];for(let m of c){let g=`Subject: ${m.subject}
4430
+ From: ${m.from}
4431
+ To: ${m.to}
4432
+ Date: ${m.date}
4433
4433
 
4434
4434
  Body:
4435
- ${p.body}`,f=await $m(g,a,t.model);h.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&u.push({content:f,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=u[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let f=(new Date().getTime()-o.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${s})`}}else h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(a){return h.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}var Qa=y(()=>{"use strict";_e();N()});import{z as Ae}from"zod";function Vl(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 Yl(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:Dm,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:p,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(p,f,g);let k=Vl(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${k}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:f.message}}}}})}var Xl,Dm,eo=y(()=>{"use strict";Qa();N();Q();Xl=class{getMailgunConfig(){let e=W().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await zl(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||Vl(o.extraction_type);i.variableStore.set(l,s.data),h.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},Dm=Ae.object({forward_email:Ae.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ae.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:Ae.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ae.string().optional().describe("Filter emails by sender address"),filter_to_email:Ae.string().optional().describe("Filter emails by recipient address"),filter_subject:Ae.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ae.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ae.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ye(){if(Rn)return Rn;let e=(await Promise.resolve().then(()=>(pt(),mt))).default;return Rn=new e,Rn}async function Fn(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Dl(e,i),ul(e,n),Vs(e,a),xl(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Hn(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return cl(e,i),ll(e,n),js(e,a),"Navigate to URLs, go back, or reload the page"}async function Wn(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Pl(e,i),ml(e,n),Gs(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Bn(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Qs(e,i),il(e,n),Js(e,a),"Scroll the page or scroll to specific text/elements"}async function Un(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return fl(e,i),Ps(e,n),"Switch between browser tabs or close tabs"}async function Gn(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Os(e,i),Bs(e,n),"Upload files or wait for downloads to complete"}async function Kn(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return rl(e,i),Ts(e,n),Ms(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function jn(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Fs(e,i),Ys(e,n),bl(e,a),jl(e),"Wait for conditions, save variables, or complete tasks"}async function zn(e){let t=(await ye()).getAction("generate_2fa_code");_l(e,t);let i=new Xl;return(await Promise.resolve().then(()=>(pt(),mt))).default.registerAction("extract_email_content",i),Yl(e,i),"Generate 2FA codes or extract email/activation codes"}async function Vn(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return Tl(e,i),Ml(e,n),_s(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}async function Jl(e){let[t,i,n,a,o,r,s,l,d,c]=await Promise.all([Fn(e),Hn(e),Wn(e),Bn(e),Un(e),Gn(e),Kn(e),jn(e),zn(e),Vn(e)]);return{mouse:t,navigation:i,input:n,scroll:a,tabs:o,files:r,forms:s,utility:l,auth:d,ai:c}}function ql(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(`
4436
- `)}var Rn,to=y(()=>{"use strict";Za();eo();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();Rn=null});async function Zl(){await Om}function Ql(){return F}function ec(e=!0){let t=new rt;return e&&(Fn(t),Hn(t),Wn(t),Bn(t),Un(t),Gn(t),Kn(t),zn(t),jn(t),Vn(t)),t}async function tc(){let e=new rt,t=await Jl(e),i=ql(t);return{registry:e,capabilities:t,summary:i}}function ic(){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(`
4437
- `)}var Lm,Om,nc=y(()=>{"use strict";to();Se();Lm=[Fn(F),Hn(F),Wn(F),Bn(F),Un(F),Gn(F),Kn(F),jn(F),Vn(F),zn(F)],Om=Promise.all(Lm)});function oc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Vi(t.schema)}))}var ac,rc=y(()=>{"use strict";Ct();ac=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:Vi(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:Vi(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 sc=y(()=>{"use strict"});import"uuid";import{z as E}from"zod";import"yaml";import"uuid";import"yaml";function Yn(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var Nm,Jn,Rm,Fm,Hm,Wm,Bm,Um,Gm,Km,ze,wt,cc,jm,Xn,vi,h_,m_,qn,dc,uc,hc,mc,ki,io,no,zm,lc,Vm,xi,Xm,Ym,Jm,ne,qm,Zm,w_,M_,bt=y(()=>{"use strict";me();Nm="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Jn=112,Rm=1920,Fm=1080,Hm=1920,Wm=1080-Jn,Bm=1280,Um=720,Gm=500,Km=500,ze="Desktop Chrome",wt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(wt||{}),cc={"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"}},jm={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"]},Xn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),jm[e].map(n=>cc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},vi=e=>cc[e],h_={desktop:{label:"Desktop",type:"desktop",devices:Xn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Xn("mobile")}},m_={desktop:{label:"Desktop",type:"desktop",devices:Xn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Xn("mobile",!0)}},qn=(e,t=!1)=>{let i={userAgent:Nm,viewport:{width:Hm,height:Wm},isMobile:!1,hasTouch:!1};if(!e||e===ze)return i;let n=vi(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(Gm/a,1),s=Math.max(Km/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},dc=e=>{let t={width:Rm,height:Fm};if(!e||e===ze)return t;let i=qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Jn}:t},uc=e=>{let t={width:Bm,height:Um};if(!e||e===ze)return t;let i=qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},hc=e=>!e||e===ze?void 0:vi(e)?.channel,mc=e=>!e||e===ze?"chromium":vi(e)?.defaultBrowserType??"chromium",ki=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ki||{}),io=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(io||{}),no=class pc{constructor(){xa(this,"data",{}),xa(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new pc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}},zm=E.enum(["JS_CODE","AI_MODE"]),lc=E.object({type:zm,expression:E.string()}),Vm=E.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),xi=E.object({uid:E.string(),type:Vm,comment:E.string().optional()}),Xm=E.object({action_data:E.object({action_name:E.string(),kwargs:E.record(E.any()).optional(),args:E.array(E.any()).optional()}),action_description:E.string().optional(),url:E.string().optional(),xpath:E.string().nullable().optional(),locator:E.string().nullable().optional(),css_selector:E.string().nullable().optional(),unique_selector:E.string().nullable().optional(),element_index:E.number().nullable().optional(),frame_path:E.array(E.any()).optional(),artifacts:E.record(E.any()).optional(),feedback:E.string().optional(),original_browser_use_action:E.any().optional()}).passthrough(),Ym=xi.extend({type:E.literal("DRAFT"),description:E.string()}),Jm=xi.extend({type:E.literal("ACTION"),description:E.string(),action_entity:Xm.optional(),locator:E.string().optional(),use_pure_vision:E.boolean().optional()}),ne=E.lazy(()=>E.union([Ym,Jm,xi.extend({type:E.literal("STEP"),description:E.string().optional().default(""),statements:E.array(ne),reference_id:E.number().optional()}),xi.extend({type:E.literal("IF_ELSE"),description:E.string().optional(),condition:lc,then:E.array(ne),else:E.array(ne).optional()}),xi.extend({type:E.literal("WHILE_LOOP"),description:E.string().optional(),condition:lc,body:E.array(ne),timeout_ms:E.number().optional()})])),qm=E.object({name:E.string(),statements:E.array(ne),teardown:E.array(ne).optional(),skip:E.union([E.boolean(),E.string()]).optional(),timeout:E.number().optional(),fail:E.union([E.boolean(),E.string()]).optional(),only:E.boolean().optional(),slow:E.boolean().optional()}),Zm=E.object({tests:E.array(qm).min(1),beforeAll:E.array(ne).optional(),afterAll:E.array(ne).optional(),beforeEach:E.array(ne).optional(),afterEach:E.array(ne).optional()}),w_=E.object({comment:E.string().optional(),version:E.string().optional(),goal:E.string().optional(),url:E.string().optional(),baseURL:E.string().optional(),final_feedback:E.string().optional(),completed:E.boolean().optional(),success:E.boolean().optional(),statements:E.array(ne).optional(),teardown:E.array(ne).optional(),last_modified_at:E.string().optional(),testGroup:Zm.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"}),M_=1024*1024});import Ve from"fs";import Qm from"os";import _i from"path";import{chromium as gc,firefox as ep,webkit as tp}from"playwright";async function ip(e,t){let i=JSON.parse(Ve.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var fc,wc=y(()=>{"use strict";bt();Te();ft();N();fc=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=_i.join(e.testDir,"videos"),this.statesBasePath=_i.join(e.testDir,"states"),this.downloadsBasePath=_i.join(e.testDir,"downloads"),Ve.mkdirSync(this.videoBasePath,{recursive:!0}),Ve.mkdirSync(this.statesBasePath,{recursive:!0}),Ve.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=mc(e.deviceName),a=hc(e.deviceName),o=n===wt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(o){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let v=[];(e.enableCamera||e.enableMicrophone)&&(v.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(v.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let S=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Ol(t,e.disableSecurity??!0,i),...v,...S,...this.additionalArgs],a&&(s.channel=a,h.debug(`[BrowserManager] Launching browser with channel: ${a}`))}let l=qn(e.deviceName),d=uc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&o?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let p,g,f,k=!1;if(o&&(r||e.userDataDir)){if(e.userDataDir)f=e.userDataDir;else{let S=this.testDir||Ve.mkdtempSync(_i.join(Qm.tmpdir(),"shiplight-"));f=_i.join(S,`ext-profile-${Date.now()}`),Ve.mkdirSync(f,{recursive:!0}),k=!0}let v={...s,...c};g=await gc.launchPersistentContext(f,v),u&&(await ip(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),p=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${f}`}`)}else{switch(n){case wt.Firefox:p=await ep.launch(s);break;case wt.Webkit:p=await tp.launch(s);break;case wt.Chromium:default:p=await gc.launch(s);break}g=await p.newContext(c)}if(g.addInitScript(gt),o){let v=["clipboard-read","clipboard-write"];e.enableCamera&&v.push("camera"),e.enableMicrophone&&v.push("microphone");try{await g.grantPermissions(v),h.info(`[BrowserManager] Granted permissions: ${v.join(", ")}`)}catch(S){h.warn("[BrowserManager] Failed to grant permissions:",S)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let v=(Date.now()+31536e6)/1e3,S=e.cookies.map(A=>({...A,expires:v}));await g.addCookies(S),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${v}`)}let x=e.viewport,m=x?{width:x.width,height:x.height+Jn}:dc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),o){let v=async S=>{try{await On(S,m.width,m.height),x&&await S.setViewportSize(x)}catch(A){h.warn("[BrowserManager] Failed to set window bounds via CDP:",A)}};for(let S of g.pages())await v(S);g.on("page",v)}let b="";if(o&&t!==void 0)try{b=await Ln(t)}catch(v){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",v)}let _={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:b,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:f,isTempUserDataDir:k};if(this.terminationTimeout!==null){let v=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(S=>h.error("[BrowserManager] Error terminating browser:",S))},this.terminationTimeout);_.timeout=v}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ve.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var bc,yc=y(()=>{"use strict";bt();bc=e=>{if(!e||e===ze)return"desktop";let t=vi(e);return t&&t.isMobile?"mobile":"desktop"}});var np,xc=y(()=>{"use strict";np=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(np||{})});async function vc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4435
+ ${m.body}`,w=await Pm(g,a,t.model);h.info(`Extracted content: ${w}`),w&&w!=="NOT_FOUND"&&u.push({content:w,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let w=(new Date().getTime()-o.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${w.toFixed(1)} seconds`),{data:m.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(a){return h.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}var Za=b(()=>{"use strict";_e();N()});import{z as Ae}from"zod";function zl(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 Xl(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:$m,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:m,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let w={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(m,w,g);let k=zl(o);return{success:!0,actionEntity:w,message:`Extracted ${o} and saved to $${k}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:w.message}}}}})}var Vl,$m,Qa=b(()=>{"use strict";Za();N();Q();Vl=class{getMailgunConfig(){let e=W().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await jl(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||zl(o.extraction_type);i.variableStore.set(l,s.data),h.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},$m=Ae.object({forward_email:Ae.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ae.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:Ae.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ae.string().optional().describe("Filter emails by sender address"),filter_to_email:Ae.string().optional().describe("Filter emails by recipient address"),filter_subject:Ae.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ae.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ae.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ye(){if(Rn)return Rn;let e=(await Promise.resolve().then(()=>(pt(),mt))).default;return Rn=new e,Rn}async function Fn(e){let t=await ye(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return $l(e,i),dl(e,n),zs(e,a),yl(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Hn(e){let t=await ye(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return ll(e,i),sl(e,n),Ks(e,a),"Navigate to URLs, go back, or reload the page"}async function Wn(e){let t=await ye(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Cl(e,i),hl(e,n),Us(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Bn(e){let t=await ye(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Zs(e,i),tl(e,n),Ys(e,a),"Scroll the page or scroll to specific text/elements"}async function Un(e){let t=await ye(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return gl(e,i),Cs(e,n),"Switch between browser tabs or close tabs"}async function Gn(e){let t=await ye(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Ls(e,i),Ws(e,n),"Upload files or wait for downloads to complete"}async function Kn(e){let t=await ye(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return ol(e,i),Es(e,n),As(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function jn(e){let t=await ye(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Rs(e,i),Xs(e,n),wl(e,a),Kl(e),"Wait for conditions, save variables, or complete tasks"}async function zn(e){let t=(await ye()).getAction("generate_2fa_code");kl(e,t);let i=new Vl;return(await Promise.resolve().then(()=>(pt(),mt))).default.registerAction("extract_email_content",i),Xl(e,i),"Generate 2FA codes or extract email/activation codes"}async function Vn(e){let t=await ye(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return El(e,i),Al(e,n),ks(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}async function Yl(e){let[t,i,n,a,o,r,s,l,d,c]=await Promise.all([Fn(e),Hn(e),Wn(e),Bn(e),Un(e),Gn(e),Kn(e),jn(e),zn(e),Vn(e)]);return{mouse:t,navigation:i,input:n,scroll:a,tabs:o,files:r,forms:s,utility:l,auth:d,ai:c}}function Jl(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(`
4436
+ `)}var Rn,eo=b(()=>{"use strict";qa();Qa();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();Rn=null});async function ql(){await Lm}function Zl(){return F}function Ql(e=!0){let t=new rt;return e&&(Fn(t),Hn(t),Wn(t),Bn(t),Un(t),Gn(t),Kn(t),zn(t),jn(t),Vn(t)),t}async function ec(){let e=new rt,t=await Yl(e),i=Jl(t);return{registry:e,capabilities:t,summary:i}}function tc(){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(`
4437
+ `)}var Dm,Lm,ic=b(()=>{"use strict";eo();Se();Dm=[Fn(F),Hn(F),Wn(F),Bn(F),Un(F),Gn(F),Kn(F),jn(F),Vn(F),zn(F)],Lm=Promise.all(Dm)});function ac(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Vi(t.schema)}))}var nc,oc=b(()=>{"use strict";Ct();nc=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:Vi(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:Vi(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 rc=b(()=>{"use strict"});import"uuid";import{z as E}from"zod";import"yaml";import"uuid";import"yaml";function Yn(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var Om,Jn,Nm,Rm,Fm,Hm,Wm,Bm,Um,Gm,ze,wt,lc,Km,Xn,vi,p_,g_,qn,cc,dc,uc,hc,ki,to,io,jm,sc,zm,xi,Vm,Xm,Ym,ne,Jm,qm,y_,C_,bt=b(()=>{"use strict";me();Om="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Jn=112,Nm=1920,Rm=1080,Fm=1920,Hm=1080-Jn,Wm=1280,Bm=720,Um=500,Gm=500,ze="Desktop Chrome",wt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(wt||{}),lc={"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"}},Km={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"]},Xn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Km[e].map(n=>lc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},vi=e=>lc[e],p_={desktop:{label:"Desktop",type:"desktop",devices:Xn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Xn("mobile")}},g_={desktop:{label:"Desktop",type:"desktop",devices:Xn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Xn("mobile",!0)}},qn=(e,t=!1)=>{let i={userAgent:Om,viewport:{width:Fm,height:Hm},isMobile:!1,hasTouch:!1};if(!e||e===ze)return i;let n=vi(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(Um/a,1),s=Math.max(Gm/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},cc=e=>{let t={width:Nm,height:Rm};if(!e||e===ze)return t;let i=qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Jn}:t},dc=e=>{let t={width:Wm,height:Bm};if(!e||e===ze)return t;let i=qn(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},uc=e=>!e||e===ze?void 0:vi(e)?.channel,hc=e=>!e||e===ze?"chromium":vi(e)?.defaultBrowserType??"chromium",ki=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ki||{}),to=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(to||{}),io=class mc{constructor(){xa(this,"data",{}),xa(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 mc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}},jm=E.enum(["JS_CODE","AI_MODE"]),sc=E.object({type:jm,expression:E.string()}),zm=E.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),xi=E.object({uid:E.string(),type:zm,comment:E.string().optional()}),Vm=E.object({action_data:E.object({action_name:E.string(),kwargs:E.record(E.any()).optional(),args:E.array(E.any()).optional()}),action_description:E.string().optional(),url:E.string().optional(),xpath:E.string().nullable().optional(),locator:E.string().nullable().optional(),css_selector:E.string().nullable().optional(),unique_selector:E.string().nullable().optional(),element_index:E.number().nullable().optional(),frame_path:E.array(E.any()).optional(),artifacts:E.record(E.any()).optional(),feedback:E.string().optional(),original_browser_use_action:E.any().optional()}).passthrough(),Xm=xi.extend({type:E.literal("DRAFT"),description:E.string()}),Ym=xi.extend({type:E.literal("ACTION"),description:E.string(),action_entity:Vm.optional(),locator:E.string().optional(),use_pure_vision:E.boolean().optional()}),ne=E.lazy(()=>E.union([Xm,Ym,xi.extend({type:E.literal("STEP"),description:E.string().optional().default(""),statements:E.array(ne),reference_id:E.number().optional()}),xi.extend({type:E.literal("IF_ELSE"),description:E.string().optional(),condition:sc,then:E.array(ne),else:E.array(ne).optional()}),xi.extend({type:E.literal("WHILE_LOOP"),description:E.string().optional(),condition:sc,body:E.array(ne),timeout_ms:E.number().optional()})])),Jm=E.object({name:E.string(),statements:E.array(ne),teardown:E.array(ne).optional(),skip:E.union([E.boolean(),E.string()]).optional(),timeout:E.number().optional(),fail:E.union([E.boolean(),E.string()]).optional(),only:E.boolean().optional(),slow:E.boolean().optional()}),qm=E.object({tests:E.array(Jm).min(1),beforeAll:E.array(ne).optional(),afterAll:E.array(ne).optional(),beforeEach:E.array(ne).optional(),afterEach:E.array(ne).optional()}),y_=E.object({comment:E.string().optional(),version:E.string().optional(),goal:E.string().optional(),url:E.string().optional(),baseURL:E.string().optional(),final_feedback:E.string().optional(),completed:E.boolean().optional(),success:E.boolean().optional(),statements:E.array(ne).optional(),teardown:E.array(ne).optional(),last_modified_at:E.string().optional(),testGroup:qm.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"}),C_=1024*1024});import Ve from"fs";import Zm from"os";import _i from"path";import{chromium as pc,firefox as Qm,webkit as ep}from"playwright";async function tp(e,t){let i=JSON.parse(Ve.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var gc,fc=b(()=>{"use strict";bt();Te();ft();N();gc=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=_i.join(e.testDir,"videos"),this.statesBasePath=_i.join(e.testDir,"states"),this.downloadsBasePath=_i.join(e.testDir,"downloads"),Ve.mkdirSync(this.videoBasePath,{recursive:!0}),Ve.mkdirSync(this.statesBasePath,{recursive:!0}),Ve.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=hc(e.deviceName),a=uc(e.deviceName),o=n===wt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(o){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let v=[];(e.enableCamera||e.enableMicrophone)&&(v.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(v.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let S=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Ll(t,e.disableSecurity??!0,i),...v,...S,...this.additionalArgs],a&&(s.channel=a,h.debug(`[BrowserManager] Launching browser with channel: ${a}`))}let l=qn(e.deviceName),d=dc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&o?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let m,g,w,k=!1;if(o&&(r||e.userDataDir)){if(e.userDataDir)w=e.userDataDir;else{let S=this.testDir||Ve.mkdtempSync(_i.join(Zm.tmpdir(),"shiplight-"));w=_i.join(S,`ext-profile-${Date.now()}`),Ve.mkdirSync(w,{recursive:!0}),k=!0}let v={...s,...c};g=await pc.launchPersistentContext(w,v),u&&(await tp(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),m=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${w}`}`)}else{switch(n){case wt.Firefox:m=await Qm.launch(s);break;case wt.Webkit:m=await ep.launch(s);break;case wt.Chromium:default:m=await pc.launch(s);break}g=await m.newContext(c)}if(g.addInitScript(gt),o){let v=["clipboard-read","clipboard-write"];e.enableCamera&&v.push("camera"),e.enableMicrophone&&v.push("microphone");try{await g.grantPermissions(v),h.info(`[BrowserManager] Granted permissions: ${v.join(", ")}`)}catch(S){h.warn("[BrowserManager] Failed to grant permissions:",S)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let v=(Date.now()+31536e6)/1e3,S=e.cookies.map(A=>({...A,expires:v}));await g.addCookies(S),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${v}`)}let y=e.viewport,p=y?{width:y.width,height:y.height+Jn}:cc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(p)}`),o){let v=async S=>{try{await On(S,p.width,p.height),y&&await S.setViewportSize(y)}catch(A){h.warn("[BrowserManager] Failed to set window bounds via CDP:",A)}};for(let S of g.pages())await v(S);g.on("page",v)}let x="";if(o&&t!==void 0)try{x=await Ln(t)}catch(v){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",v)}let _={debugPort:t,browser:m,context:g,startTime:new Date,timeout:null,browserWsUrl:x,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:w,isTempUserDataDir:k};if(this.terminationTimeout!==null){let v=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(S=>h.error("[BrowserManager] Error terminating browser:",S))},this.terminationTimeout);_.timeout=v}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Ve.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var wc,bc=b(()=>{"use strict";bt();wc=e=>{if(!e||e===ze)return"desktop";let t=vi(e);return t&&t.isMobile?"mobile":"desktop"}});var ip,yc=b(()=>{"use strict";ip=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(ip||{})});async function xc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4438
4438
  return await (${t});
4439
- `;return await new i("page",n)(e)}async function Si(e,t,i){let n=[],a=[];for(let o of t){let r=!1;try{let s=`page.${o}`;w.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await vc(e,`${s}.waitFor({ state: 'attached', timeout: ${ap} })`),w.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await vc(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(a.push(r),!r&&i)break}return{successResults:a,logs:n}}async function ao(e,t,i=!0){let{successResults:n,logs:a}=await Si(e,t,i);return{success:n.length===t.length&&n.every(o=>o),logs:a}}async function Ei(e,t){if(!t||t.length===0)return w.log("No validation expressions provided, cannot validate login"),!1;w.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await ao(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${n.join(", ")}`),i}async function oo(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(),a=await n.newPage();return await a.goto(t),await Ee(a,op),{context:n,page:a,close:async()=>{await a.close(),await n.close()}}}async function ro(e,t,i,n,a,o){let r=`
4439
+ `;return await new i("page",n)(e)}async function Si(e,t,i){let n=[],a=[];for(let o of t){let r=!1;try{let s=`page.${o}`;f.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await xc(e,`${s}.waitFor({ state: 'attached', timeout: ${np} })`),f.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await xc(e,`${s}.count()`)>0?(f.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(f.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){f.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(a.push(r),!r&&i)break}return{successResults:a,logs:n}}async function no(e,t,i=!0){let{successResults:n,logs:a}=await Si(e,t,i);return{success:n.length===t.length&&n.every(o=>o),logs:a}}async function Ei(e,t){if(!t||t.length===0)return f.log("No validation expressions provided, cannot validate login"),!1;f.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await no(e,t,!0);return i?f.log("All validation expressions passed"):f.log(`Validation failed: ${n.join(", ")}`),i}async function ao(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(),a=await n.newPage();return await a.goto(t),await Ee(a,ap),{context:n,page:a,close:async()=>{await a.close(),await n.close()}}}async function oo(e,t,i,n,a,o){let r=`
4440
4440
  Based on the current page status, generate ${a} 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.
@@ -4478,22 +4478,24 @@ Avoid regenerating these failed ones, but can reuse the successful ones.`),n&&(r
4478
4478
  ${n}
4479
4479
  `),r+=`
4480
4480
  Remember, you must have the javascript code block in your final response.
4481
- `,w.log("Agent generating validation locators"),w.log(`Prompt:
4481
+ `,f.log("Agent generating validation locators"),f.log(`Prompt:
4482
4482
  ${r}`);let s=await o(e,r);if(!s.success)throw new Error(s.details||"Agent failed to generate verification code");let l=(s.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
4483
- `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function Zn(e,t,i,n,a){let o=null;try{o=await oo(e,t);let r=await a(o.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await ro(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);w.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:p}=await Si(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4484
- ${p.join(`
4483
+ `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function Zn(e,t,i,n,a){let o=null;try{o=await ao(e,t);let r=await a(o.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await oo(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);f.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:m}=await Si(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4484
+ ${m.join(`
4485
4485
  `)}
4486
4486
 
4487
- `,!u.every(g=>g)){w.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(u)}`),w.log(`Validation logs:
4488
- ${p.join(`
4489
- `)}`);continue}}{w.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:p}=await Si(o.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4490
- ${p.join(`
4487
+ `,!u.every(g=>g)){f.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(u)}`),f.log(`Validation logs:
4488
+ ${m.join(`
4489
+ `)}`);continue}}{f.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:m}=await Si(o.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4490
+ ${m.join(`
4491
4491
  `)}
4492
4492
 
4493
- `,u.some(g=>g)){w.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(u)}`),w.log(`Validation logs:
4494
- ${p.join(`
4495
- `)}`);continue}}return w.log("Generated validation locators passed dual validation"),c}catch(c){w.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var ap,op,Qn=y(()=>{"use strict";ee();Te();ap=5e3,op=1e4});var kc,so=y(()=>{"use strict";kc=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 _c(e,t=3e3,i=1e3){try{await Ee(e,t,i)}catch{}}async function Sc(e,t,i){let n=i*1e3,a=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(a)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Ec(e,t,i,n=60,a){let o=Math.min(n,280),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,a))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var ea=y(()=>{"use strict";Te();N()});import*as Tc from"fs";import*as Ti from"path";import{generateSync as rp,createGuardrails as sp}from"otplib";function Ac(e){return e.url()===":"}var lp,ta,lo=y(()=>{"use strict";so();bt();ea();Te();N();lp=sp({MIN_SECRET_BYTES:1});ta=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 kc(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return Yn(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Ti.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let a=Ti.basename(n),o=Ti.join(t,a),r=Tc.existsSync(o);return r&&h.debug(`[AgentServices] File already exists locally: ${a}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Sc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),h.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4496
- ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=rp({secret:e,guardrails:lp});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ee(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let a=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}}});var co,ia,uo=y(()=>{"use strict";co=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(co||{}),ia=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Mc={};Ze(Mc,{LoginType:()=>ki,checkLocators:()=>Si,createUnsignedInContext:()=>oo,generateAndValidateLoginLocators:()=>Zn,generateValidationLocators:()=>ro,validateLogin:()=>Ei,validateLoginLocators:()=>ao});var Ic=y(()=>{"use strict";Qn();ee();bt();Te();ft();N();Q();ct();me()});import*as K from"fs";import*as J from"path";function Ai(e,t){let i={};for(let[n,a]of Object.entries(e))i[n]=t.has(n)?"*****":a;return i}var cp,dp,up,ho,Cc=y(()=>{"use strict";Bt();Ue();Qn();ee();lo();ea();uo();zt();N();cp=1,dp=3,up=40;ho=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new ta(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(()=>(pt(),mt));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.
4493
+ `,u.some(g=>g)){f.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(u)}`),f.log(`Validation logs:
4494
+ ${m.join(`
4495
+ `)}`);continue}}return f.log("Generated validation locators passed dual validation"),c}catch(c){f.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return f.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var np,ap,Qn=b(()=>{"use strict";ee();Te();np=5e3,ap=1e4});var vc,ro=b(()=>{"use strict";vc=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 kc(e,t=3e3,i=1e3){try{await Ee(e,t,i)}catch{}}async function _c(e,t,i){let n=i*1e3,a=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(a)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Sc(e,t,i,n=60,a){let o=Math.min(n,280),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,a))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var ea=b(()=>{"use strict";Te();N()});import*as Ec from"fs";import*as Ti from"path";import{generateSync as op,createGuardrails as rp}from"otplib";function Tc(e){return e.url()===":"}var sp,ta,so=b(()=>{"use strict";ro();bt();ea();Te();N();sp=rp({MIN_SECRET_BYTES:1});ta=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 vc(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return Yn(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Ti.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let a=Ti.basename(n),o=Ti.join(t,a),r=Ec.existsSync(o);return r&&h.debug(`[AgentServices] File already exists locally: ${a}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return _c(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),h.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4496
+ ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=op({secret:e,guardrails:sp});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Ee(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let a=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}}});var lo,ia,co=b(()=>{"use strict";lo=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(lo||{}),ia=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Ac={};Ze(Ac,{LoginType:()=>ki,checkLocators:()=>Si,createUnsignedInContext:()=>ao,generateAndValidateLoginLocators:()=>Zn,generateValidationLocators:()=>oo,validateLogin:()=>Ei,validateLoginLocators:()=>no});var Mc=b(()=>{"use strict";Qn();ee();bt();Te();ft();N();Q();ct();me()});import*as K from"fs";import*as J from"path";function cp(e){try{let t=e.toString(),i,n=t.indexOf("=>");if(n!==-1){let s=t.slice(n+2).trim();if(s.startsWith("{")){let l=s.lastIndexOf("}");i=s.slice(1,l)}else return s.trim()}else{let s=t.indexOf("{"),l=t.lastIndexOf("}");s!==-1&&l>s&&(i=t.slice(s+1,l))}if(!i)return;let a=i.split(`
4497
+ `),o=a.filter(s=>s.trim().length>0);if(o.length===0)return;let r=Math.min(...o.map(s=>s.match(/^(\s*)/)?.[1].length??0));return a.map(s=>s.slice(r)).join(`
4498
+ `).trim()}catch{return}}function Ai(e,t){let i={};for(let[n,a]of Object.entries(e))i[n]=t.has(n)?"*****":a;return i}var lp,dp,up,uo,Ic=b(()=>{"use strict";Bt();Ue();Qn();ee();so();ea();co();zt();N();lp=1;dp=3,up=40;uo=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new ta(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(()=>(pt(),mt));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.
4497
4499
 
4498
4500
  ONLY dismiss intrusive popups such as:
4499
4501
  - Cookie/GDPR consent banners
@@ -4515,7 +4517,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
4515
4517
  IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
4516
4518
  It's better to miss a popup than to accidentally interact with normal page elements.
4517
4519
 
4518
- If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,dp),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Ac(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||J.join(process.cwd(),"downloads");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let a=J.join(n,i);h.info(`[Download Tracking] Downloading file to: ${a}`),await t.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${a}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let a=i==="beforeunload";try{a?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:a?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${a?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(o){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,a,o){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ke(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",o,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ke(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(h.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Ge(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 a=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,a),{success:!0,details:n.explanation}}async execute(e,t,i,n,a){if(a!==void 0&&a<=0)throw new Error(`maxSteps must be >= 1, got ${a}`);let o=a!==void 0&&a>1;h.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${a}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(o){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let p=`${i}-step${u.step}`;this.saveDebugInfoToFiles(p,u.debugInfo,this.context.model)}}:void 0;if(s=await je(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a??up}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await Ge(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory(),o=await ht(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||o?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),o&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await je(t,e,this.agentServices,r,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});w.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new ia(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),w.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),w.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${a.message}`),a}}async step(e,t,i,n,a,o=!0,r){let s=Date.now();this.context.stepTracking&&await this.createStepResult(e,n,i),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?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),f=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Ai(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()-s,b=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:u,timestamp:s}),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:f||void 0,variables:k,screenshotPath:b,timestamp:_})}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=o&&!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 h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),b=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-s,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:b||void 0,variables:_,timestamp:S})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${p.message}`);let f,k;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){f=`[Auto-dismissed modal: ${m.details}]`,k=m.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let b=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",f),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,b}catch(b){h.info(`Retry after modal dismissal failed: ${b.message}, falling back to self-healing`)}}}let x=r??cp;h.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 b=m.actions?.at(-1);a&&b&&(this._newActionEntities.set(a,b),h.info(`Stored new action entity for stmtUid: ${a} (last of ${m.actions?.length} actions)`));let _=e.url(),v=await this.captureDOMSnapshot(e),S=this.context.stepTracking?.captureVariables?Ai(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=b,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let A=f||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-s,C=this.context.stepTracking.results[n]?.screenshot,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:b,playwrightCode:m.actions?.map($=>$.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:_,domSnapshot:v||void 0,variables:S,screenshotPath:C,timestamp:I})}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 b=e.url(),_=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},S=Date.now()-s,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:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:S,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:b,domSnapshot:_||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}`);try{let a=`Extract ${t} and save to ${i}`,o=await this.execute(e,a,n);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(a){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",a.message),a}}async getDOMText(e){let t=new le(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 le(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),a=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:a.elementTree.clickableElementsToString(),elementCount:a.selectorMap.size,timestamp:Date.now()}}catch(t){return h.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return _c(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Ec(e,t,(a,o,r)=>this.evaluate(a,o,r),i,n)}async uploadFile(e,t,i={},n){return $s(e,t,i,this.context,(a,o,r)=>this.execute(a,o,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Ic(),Mc));if(h.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let a=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=a?`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(a){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return w.log("Level 1 SUCCESS: Already logged in via AI verification"),h.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!a&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Ei(e,i.validation_exprs))return w.log("Level 1 SUCCESS: Already logged in via storage state"),h.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(a||r)){w.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:o})).success){w.log("Level 2 SUCCESS: Cached login succeeded"),h.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4520
+ If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,dp),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Tc(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||J.join(process.cwd(),"downloads");K.existsSync(n)||K.mkdirSync(n,{recursive:!0});let a=J.join(n,i);h.info(`[Download Tracking] Downloading file to: ${a}`),await t.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${a}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let a=i==="beforeunload";try{a?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:a?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${a?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(o){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,a,o){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"assert"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ke(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",o,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"evaluate"),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ke(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(h.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await Ge(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 a=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,a),{success:!0,details:n.explanation}}async execute(e,t,i,n,a){if(a!==void 0&&a<=0)throw new Error(`maxSteps must be >= 1, got ${a}`);let o=a!==void 0&&a>1;h.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${a}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"execute"),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(o){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let m=`${i}-step${u.step}`;this.saveDebugInfoToFiles(m,u.debugInfo,this.context.model)}}:void 0;if(s=await je(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a??up}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await Ge(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"generate");try{let a=this.getCompletedExecutionHistory(),o=await ht(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t,"run");try{let a=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||o?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),o&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await je(t,e,this.agentServices,r,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});f.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new ia(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),f.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),f.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${a.message}`),a}}async step(e,t,i,n,a,o=!0,r){let s=Date.now();if(this.context.stepTracking){await this.createStepResult(e,n,i,"step");let m=cp(t);m&&this.context.stepTracking.results[n]&&(this.context.stepTracking.results[n].code=m)}e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let m=await t();e=this.agentServices.validatePage(e);let g=e.url(),w=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=Date.now()-s,x=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:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:p,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:w||void 0,variables:k,screenshotPath:x,timestamp:_})}let y=this.context.agentNote;return(!y||y.trim()==="")&&(y="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=y),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){e=this.agentServices.validatePage(e);let g=o&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",m.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=m.message)),!i||i.trim()==="")throw h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let p=e.url(),x=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-s,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:p,domSnapshot:x||void 0,variables:_,timestamp:S})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),m}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${m.message}`);let w,k;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let p=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${p.details}`),p.modalDismissed){w=`[Auto-dismissed modal: ${p.details}]`,k=p.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let x=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=w+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",w),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=w,x}catch(x){h.info(`Retry after modal dismissal failed: ${x.message}, falling back to self-healing`)}}}let y=r??lp;h.info(`Calling execute() to self-heal (maxSteps: ${y})`);try{let p=await this.execute(e,i,n,!1,y);if(this.context.isSelfHealing=!1,!p.success)throw new Error(`Self-healing failed: ${p.details}`);let x=p.actions?.at(-1);a&&x&&(this._newActionEntities.set(a,x),h.info(`Stored new action entity for stmtUid: ${a} (last of ${p.actions?.length} actions)`));let _=e.url(),v=await this.captureDOMSnapshot(e),S=this.context.stepTracking?.captureVariables?Ai(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=x,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let A=w||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-s,C=this.context.stepTracking.results[n]?.screenshot,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:x,playwrightCode:p.actions?.map($=>$.locator||""),llmPrompt:p.debugInfo?.userPrompt,llmResponse:p.debugInfo?.rawLlmResponse,llmReasoning:p.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:_,domSnapshot:v||void 0,variables:S,screenshotPath:C,timestamp:I})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let x=e.url(),_=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Ai(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},S=Date.now()-s,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:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:S,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:_||void 0,variables:v,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`,"extract");try{let a=`Extract ${t} and save to ${i}`,o=await this.execute(e,a,n);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(a){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",a.message),a}}async getDOMText(e){let t=new le(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 le(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),a=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:a.elementTree.clickableElementsToString(),elementCount:a.selectorMap.size,timestamp:Date.now()}}catch(t){return h.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return kc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Sc(e,t,(a,o,r)=>this.evaluate(a,o,r),i,n)}async uploadFile(e,t,i={},n){return Ps(e,t,i,this.context,(a,o,r)=>this.execute(a,o,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Mc(),Ac));if(h.info("Start login"),f.section("Login Flow"),f.log(`Site URL: ${t.site_url}`),f.log(`Account type: ${t.account.type}`),f.log(`Has cached actions: ${!!i?.cached_actions?.length}`),f.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let a=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=a?`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(a){f.log("Level 1: Checking if already logged in via AI verification hint..."),f.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return f.log("Level 1 SUCCESS: Already logged in via AI verification"),h.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){f.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&f.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!a&&i?.validation_exprs&&i.validation_exprs.length>0){if(f.log("Level 1: Checking if already logged in via storage state..."),f.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Ei(e,i.validation_exprs))return f.log("Level 1 SUCCESS: Already logged in via storage state"),h.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(a||r)){f.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:o})).success){f.log("Level 2 SUCCESS: Cached login succeeded"),h.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}f.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){f.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&f.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4519
4521
  Use your best judgement to determine if the page is signed in.
4520
4522
  `;if(t.verification_hint&&(s+=`
4521
4523
  Signed in verification hint: ${t.verification_hint}
@@ -4526,8 +4528,8 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
4526
4528
  ($username, $password), and use $otp_secret_key to generate $otp_code for two-factor authentication. If you can't login with the provided credentials, just stop and report the failure.
4527
4529
  `}t.additional_prompt&&(s+=`
4528
4530
  Additional instructions: ${t.additional_prompt}
4529
- `);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
4530
- ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,x,m,b)=>await l(k,x,m,"login")),d=!0,w.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return w.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),p;if(a)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let k=await Zn(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));k?(p=k,w.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(k){w.log(`Error generating validation locators: ${k.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:f,validation_exprs:p}}catch(l){return w.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(pt(),mt))).default,a=new n;for(let o=0;o<t.length;o++){let r=t[o];w.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${o+1} missing action_data, skipping`);continue}await a.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Ei(e,i.validationExprs)?{success:!0}:{success:!1}:(w.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let a=J.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(a,{recursive:!0});let o=J.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:o}),n.screenshot=o}this.context.stepTracking.results[t]=n}catch(n){h.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let a={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),a;let o=J.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=J.join(o,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),a.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=J.join(o,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),a.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=J.join(o,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),a.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=J.join(o,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),a.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=J.join(o,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),a.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=J.join(o,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),a.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(a).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return a}async updateStepResult(e,t,i,n,a){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),n&&o.artifacts.push(n),a){let r=a.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,a,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=J.join(e,"test-results.json");await K.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),h.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=J.join(e,"token-usages.json");await K.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),h.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=J.join(e,"ai-actions.json");await K.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function hp(){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,a=t.find(m=>m.type==="day").value,o=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${a}T${o}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-u)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${a}T${o}:${r}:${s}.${l}${x}${f}:${k}`}function mo(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",hp()),{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 Pc=y(()=>{"use strict"});var $c={};Ze($c,{ActionHandler:()=>In,ActionHelper:()=>bi,Agent:()=>ho,AgentServices:()=>ta,AgentStepEventTypes:()=>co,AgentTaskFailedError:()=>ia,BrowserManager:()=>fc,DEFAULT_EVENT_LISTENER_LIMIT:()=>rn,DomService:()=>le,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>on,HistoryTreeProcessor:()=>ws,INIT_SCRIPT:()=>gt,INTERACTION_EVENT_TYPES:()=>st,INTERACTIVE_ROLES:()=>Ot,LogLevel:()=>Ia,LoginType:()=>ki,MCPToolProvider:()=>ac,OpenAIToolProvider:()=>Xi,SDK_VERSION:()=>pp,ToolRegistry:()=>rt,TwoFactorAuthType:()=>io,VariableStore:()=>no,WebAgent:()=>ho,configureSdk:()=>pr,createAgent:()=>mp,createAgentContext:()=>mo,createToolRegistry:()=>ec,createToolRegistryWithCapabilities:()=>tc,ensureToolsRegistered:()=>Zl,evaluateStatement:()=>Ke,executeStep:()=>Ge,exportMCPTools:()=>oc,filterInteractionListeners:()=>is,generateActionStep:()=>ht,getActionEntityLocatorInfo:()=>O,getBrowserCdpUrl:()=>Ln,getCapabilitySummary:()=>ic,getFramePath:()=>Ea,getModel:()=>fe,getPageInfo:()=>Fl,getPageWsUrl:()=>Rl,getPlatformFromDeviceName:()=>bc,getProviderOptions:()=>we,getSdkConfig:()=>W,getToolRegistry:()=>Ql,injectUserFunction:()=>fa,isInteractionEventType:()=>ts,isInteractiveRole:()=>es,loadKnowledgeMappings:()=>xr,loadKnowledges:()=>yr,loadUserFunctions:()=>wr,logger:()=>h,newBrowserContext:()=>Nl,parseSSEStream:()=>kr,parseSdkLogLevelFromEnv:()=>gr,pickBestLocator:()=>Et,pickBestLocatorForElement:()=>Fi,pickBestLocators:()=>Mr,replaceVariables:()=>Yn,runTask:()=>je,setWindowBounds:()=>On,toolRegistry:()=>F});function mp(e){let t=new no,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[a,o]of Object.entries(e.variables))t.set(a,o,i.has(a));let n=mo({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new ho(n)}var pp,Dc=y(()=>{"use strict";br();vr();_r();nc();to();rc();sc();Za();eo();Qa();wc();yc();xc();Cc();Bt();an();tn();ot();Ui();Ki();Gi();tt();Yi();qi();$t();Dt();Se();Ct();Pt();wn();Ue();Lt();Nt();lt();Rt();Ft();Qn();ee();lo();so();bt();ea();Te();ft();_e();At();Mt();it();uo();Ja();ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();En();zt();G();Be();N();Q();ct();Mn();R();Pc();me();pp="1.0.0"});var Lc,Oc=y(()=>{"use strict";Lc=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4531
+ `);try{f.log("Level 3: Attempting agent-based login"),f.log(`Login prompt:
4532
+ ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(f.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,y,p,x)=>await l(k,y,p,"login")),d=!0,f.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return f.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),f.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),m;if(a)f.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{f.log("Generating validation locators for future login verification...");let k=await Zn(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(y,p)=>this.run(y,p),async y=>this.getDOMText(y));k?(m=k,f.log(`Generated ${m.length} validation locator(s): ${JSON.stringify(m)}`)):f.log("Failed to generate validation locators, login will still succeed")}catch(k){f.log(`Error generating validation locators: ${k.message}`)}else f.log("Skipping validation locator generation (num_verification_exprs=0)");f.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:w,validation_exprs:m}}catch(l){return f.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(pt(),mt))).default,a=new n;for(let o=0;o<t.length;o++){let r=t[o];f.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){f.log(`Action ${o+1} missing action_data, skipping`);continue}await a.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return f.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(f.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 Ei(e,i.validationExprs)?{success:!0}:{success:!1}:(f.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 a={description:i,startTime:Date.now(),artifacts:[],type:n,code:i};if(this.context.stepTracking.artifactsDir){let o=J.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));K.mkdirSync(o,{recursive:!0});let r=J.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:r}),a.screenshot=r}this.context.stepTracking.results[t]=a}catch(a){h.warn(`createStepResult failed for step ${t}: ${a}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let a={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),a;let o=J.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(K.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=J.join(o,`system_prompt_${n}.txt`);K.writeFileSync(r,t.systemPrompt),a.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=J.join(o,`user_prompt_${n}.txt`);K.writeFileSync(r,t.userPrompt),a.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=J.join(o,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};K.writeFileSync(s,JSON.stringify(l,null,2)),a.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=J.join(o,`${r}_response_${n}.txt`);K.writeFileSync(s,t.rawLlmResponse),a.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=J.join(o,`screenshot_${n}.png`);K.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),a.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=J.join(o,`reasoning_${n}.txt`);K.writeFileSync(r,t.reasoningContent),a.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(a).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return a}async updateStepResult(e,t,i,n,a){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),n&&o.artifacts.push(n),a){let r=a.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,a,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await K.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=J.join(e,"test-results.json");await K.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),h.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=J.join(e,"token-usages.json");await K.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),h.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=J.join(e,"ai-actions.json");await K.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function hp(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(p=>p.type==="year").value,n=t.find(p=>p.type==="month").value,a=t.find(p=>p.type==="day").value,o=t.find(p=>p.type==="hour").value,r=t.find(p=>p.type==="minute").value,s=t.find(p=>p.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${a}T${o}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),m=Date.parse(c+"Z"),g=Math.round((m-u)/(1e3*60)),w=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),y=g<=0?"+":"-";return`${i}-${n}-${a}T${o}:${r}:${s}.${l}${y}${w}:${k}`}function ho(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",hp()),{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 Cc=b(()=>{"use strict"});var Pc={};Ze(Pc,{ActionHandler:()=>In,ActionHelper:()=>bi,Agent:()=>uo,AgentServices:()=>ta,AgentStepEventTypes:()=>lo,AgentTaskFailedError:()=>ia,BrowserManager:()=>gc,DEFAULT_EVENT_LISTENER_LIMIT:()=>rn,DomService:()=>le,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>on,HistoryTreeProcessor:()=>fs,INIT_SCRIPT:()=>gt,INTERACTION_EVENT_TYPES:()=>st,INTERACTIVE_ROLES:()=>Ot,LogLevel:()=>Ma,LoginType:()=>ki,MCPToolProvider:()=>nc,OpenAIToolProvider:()=>Xi,SDK_VERSION:()=>pp,ToolRegistry:()=>rt,TwoFactorAuthType:()=>to,VariableStore:()=>io,WebAgent:()=>uo,configureSdk:()=>mr,createAgent:()=>mp,createAgentContext:()=>ho,createToolRegistry:()=>Ql,createToolRegistryWithCapabilities:()=>ec,ensureToolsRegistered:()=>ql,evaluateStatement:()=>Ke,executeStep:()=>Ge,exportMCPTools:()=>ac,filterInteractionListeners:()=>ts,generateActionStep:()=>ht,getActionEntityLocatorInfo:()=>O,getBrowserCdpUrl:()=>Ln,getCapabilitySummary:()=>tc,getFramePath:()=>Sa,getModel:()=>fe,getPageInfo:()=>Rl,getPageWsUrl:()=>Nl,getPlatformFromDeviceName:()=>wc,getProviderOptions:()=>we,getSdkConfig:()=>W,getToolRegistry:()=>Zl,injectUserFunction:()=>fa,isInteractionEventType:()=>es,isInteractiveRole:()=>Qr,loadKnowledgeMappings:()=>yr,loadKnowledges:()=>br,loadUserFunctions:()=>fr,logger:()=>h,newBrowserContext:()=>Ol,parseSSEStream:()=>vr,parseSdkLogLevelFromEnv:()=>pr,pickBestLocator:()=>Et,pickBestLocatorForElement:()=>Fi,pickBestLocators:()=>Ar,replaceVariables:()=>Yn,runTask:()=>je,setWindowBounds:()=>On,toolRegistry:()=>F});function mp(e){let t=new io,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[a,o]of Object.entries(e.variables))t.set(a,o,i.has(a));let n=ho({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new uo(n)}var pp,$c=b(()=>{"use strict";wr();xr();kr();ic();eo();oc();rc();qa();Qa();Za();fc();bc();yc();Ic();Bt();an();tn();ot();Ui();Ki();Gi();tt();Yi();qi();$t();Dt();Se();Ct();Pt();wn();Ue();Lt();Nt();lt();Rt();Ft();Qn();ee();so();ro();bt();ea();Te();ft();_e();At();it();Mt();co();Ya();ln();cn();dn();un();hn();mn();pn();gn();fn();bn();yn();Ut();Gt();Kt();jt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ni();ai();oi();ri();si();li();ci();di();ui();hi();mi();pi();gi();fi();wi();En();zt();G();Be();N();Q();ct();Mn();R();Cc();me();pp="1.0.0"});var Dc,Lc=b(()=>{"use strict";Dc=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4531
4533
  `,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
4532
4534
  const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
4533
4535
  if (targetUrl !== null) {
@@ -4541,6 +4543,6 @@ await page.waitForTimeout(2000);
4541
4543
  `,e+=` // Goal:
4542
4544
  `;let n=t.trim().split(`
4543
4545
  `);for(let a of n)e+=` // ${a}
4544
- `;return e}generatePostlude(){return""}}});function Nc(e){if(!e)return"desktop";for(let t of gp)if(t.test(e))return"mobile";return"desktop"}var gp,Rc=y(()=>{"use strict";gp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function Fc(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var Hc=y(()=>{"use strict"});import{v4 as fp}from"uuid";function go(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let m=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(m&&m[1]){let _=m[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${_}"`}let b=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(b&&b[1]){let _=b[1].replace(/^\/|\/$/g,""),v=_.length>30?`${_.substring(0,27)}...`:_;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=yt(e),b=i[1].replace(/\\(.)/g,"$1");return`${m} with text "${b}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${yt(e)} with text matching ${n[1]}`;let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let m=yt(e),b=a[1].replace(/\\(.)/g,"$1");return`${m} containing "${b}"`}let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let m=yt(e),b=o[1].replace(/\\(.)/g,"$1");return`${m} containing "${b}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let m=yt(e),b=r[1].replace(/\\(.)/g,"$1");return`${m} not containing "${b}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let m=yt(e),b=s[1].replace(/\\(.)/g,"$1");return`${m} not containing "${b}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let 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 f=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(f&&f[1])return`"${f[1].replace(/\\(.)/g,"$1")}"`;let k=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(k&&k[1])return`"${k[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 fo(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4545
- `);for(let a of n){if(!a.includes(`[ref=${i}]`))continue;let s=a.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function wo(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 a=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return a&&a[1]?`frameLocator(${a[1]})`:t}function yt(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let a=t[1],o=a.match(/^([a-zA-Z][\w-]*)/);return o?o[1]:a.length>20?`${a.substring(0,17)}...`:a}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 po(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 wp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function bp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Bc(e,t){let i=e.name||"unknown",n=wo(t,e.selector||""),a=e.ariaSnapshot??e.arIAaSnapshot??"",o=e.ref,r=/getByTestId\s*\(/.test(n),l=(o&&a&&r?fo(a,o):null)??go(n),d,c,u={};switch(i){case"click":{let p=wp(t),g=bp(t);p==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},p&&p!=="left"&&(u.button=p),g&&(u.modifiers=g);break}case"fill":{let p=e.text||e.value||po(t)||"";d="fill",c=p?`Fill ${l} with '${p}'`:`Fill ${l}`,u={value:p,index:0};break}case"press":{let p=e.key||po(t)||"";d="press",c=`Press '${p}' on ${l}`,u={keyComb:p,index:0};break}case"selectOption":{let p=e.options?.[0]||po(t)||"";d="select_dropdown_option",c=`Select '${p}' from ${l}`,u={text:p,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let p=e.files||[];d="upload_file",c=p.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:p,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var Wc,Uc=y(()=>{"use strict";Wc=()=>fp()});import{z as T}from"zod";var bo,na,yo,Xe,xo,vo,ko,te,_o,Mi,aa,So=y(()=>{"use strict";bo=T.enum(["JS_CODE","AI_MODE"]),na=T.object({type:bo,expression:T.string()}),yo=T.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Xe=T.object({uid:T.string(),type:yo,comment:T.string().optional()}),xo=T.object({action_data:T.object({action_name:T.string(),kwargs:T.record(T.any()).optional(),args:T.array(T.any()).optional()}),action_description:T.string().optional(),url:T.string().optional(),xpath:T.string().nullable().optional(),locator:T.string().nullable().optional(),css_selector:T.string().nullable().optional(),unique_selector:T.string().nullable().optional(),element_index:T.number().nullable().optional(),frame_path:T.array(T.any()).optional(),artifacts:T.record(T.any()).optional(),feedback:T.string().optional(),original_browser_use_action:T.any().optional()}).passthrough(),vo=Xe.extend({type:T.literal("DRAFT"),description:T.string()}),ko=Xe.extend({type:T.literal("ACTION"),description:T.string(),action_entity:xo.optional(),locator:T.string().optional(),use_pure_vision:T.boolean().optional()}),te=T.lazy(()=>T.union([vo,ko,Xe.extend({type:T.literal("STEP"),description:T.string().optional().default(""),statements:T.array(te),reference_id:T.number().optional()}),Xe.extend({type:T.literal("IF_ELSE"),description:T.string().optional(),condition:na,then:T.array(te),else:T.array(te).optional()}),Xe.extend({type:T.literal("WHILE_LOOP"),description:T.string().optional(),condition:na,body:T.array(te),timeout_ms:T.number().optional()})])),_o=T.object({name:T.string(),statements:T.array(te),teardown:T.array(te).optional(),skip:T.union([T.boolean(),T.string()]).optional(),timeout:T.number().optional(),fail:T.union([T.boolean(),T.string()]).optional(),only:T.boolean().optional(),slow:T.boolean().optional()}),Mi=T.object({tests:T.array(_o).min(1),beforeAll:T.array(te).optional(),afterAll:T.array(te).optional(),beforeEach:T.array(te).optional(),afterEach:T.array(te).optional()}),aa=T.object({comment:T.string().optional(),version:T.string().optional(),goal:T.string().optional(),url:T.string().optional(),baseURL:T.string().optional(),final_feedback:T.string().optional(),completed:T.boolean().optional(),success:T.boolean().optional(),statements:T.array(te).optional(),teardown:T.array(te).optional(),last_modified_at:T.string().optional(),testGroup:Mi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});import{stringify as Ci,parse as oa,parseAllDocuments as yp,parseDocument as xp,Document as vp,isMap as vt,isSeq as de}from"yaml";import{v4 as ce}from"uuid";function To(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(ae)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ae)),i}function zc(e,t){if(e.testGroup)return Ao(e,t);let i=To(e,t),n=new vp(i);return e.comment&&(n.commentBefore=e.comment),Gc(n,e.statements??[]),e.teardown&&Gc(n,e.teardown,"teardown"),n.toString(kt)}function Gc(e,t,i="statements"){let n=e.contents;if(!n||!vt(n))return;let a=n.get(i,!0);de(a)&&Ii(a,t)}function Ii(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),vt(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);de(r)&&Ii(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);de(r)&&Ii(r,n.then);let s=o.get("ELSE",!0);de(s)&&n.else&&Ii(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);de(r)&&Ii(r,n.body)}}}}function Ao(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);let a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(ae)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ae)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ae)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ae)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(ae),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(ae)),r}),n.suite=a,Ci(n,kt)}function Vc(e){return e.map(t=>Ci(t,kt)).join(`---
4546
- `)}function ae(e){switch(e.type){case"DRAFT":return kp(e);case"ACTION":return Xc(e);case"STEP":return Sp(e);case"IF_ELSE":return Ep(e);case"WHILE_LOOP":return Tp(e)}}function kp(e){return{intent:e.description}}function Xc(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))a[s]=l;return n.args&&n.args.length>0&&(a.args=n.args),a}function Yc(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},a=Xc(n);if(typeof a=="object"&&a!==null){let o={...a};return delete o.intent,delete o.VERIFY,delete o.WAIT_UNTIL,delete o.WAIT,delete o.statement,Object.keys(o).length>0?Ci(o,kt).trim():""}return Ci(a,kt).trim()}function Jc(e){let t=oa(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,a=typeof t.locator=="string"?t.locator:void 0,o=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))_p.has(c)||(l[c]=u);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...a?{locator:a}:{},...o?{xpath:o}:{},...r?{frame_path:r}:{}},description:i,locator:a}:{description:i,actionEntity:{action_description:i||""}}}function Sp(e){let t={STEP:e.description,statements:e.statements.map(ae)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Ep(e){let t={IF:qc(e.condition),THEN:e.then.map(ae)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ae)),t}function Tp(e){let t={WHILE:qc(e.condition),DO:e.body.map(ae)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function qc(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Zc(e){let t=yp(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,a)=>n.errors.length>0?{__parseError:`Document ${a+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=oa(e)}catch(a){throw new Error(`Invalid YAML: ${a instanceof Error?a.message:String(a)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,a)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${a+1}: expected an object`};let o=n,r=typeof o.name=="string"&&o.name.trim()||void 0,s=typeof o.goal=="string"?o.goal.trim():"";if(!s)return{error:`Item ${a+1}: missing "goal" field`};if(Array.isArray(o.statements))try{let l=Ci(o,kt),d=Ye(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(o){return{error:`Item ${a+1}: ${o instanceof Error?o.message:String(o)}`}}})}function Qc(e){try{let t=oa(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()),i}catch{return{}}}function Eo(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Eo);let t=e,i=Object.keys(t);if(i.length===1){let a=i[0];if(a.startsWith("{ ")&&a.endsWith(" }")&&t[a]===null)return`{{${a.slice(2,-2)}}}`}let n={};for(let[a,o]of Object.entries(t))n[a]=Eo(o);return n}function Ye(e){if(e.length>Kc)throw new Error(`YAML input too large (${e.length} bytes, max ${Kc})`);let t=Eo(oa(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Ap(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:oe(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=oe(t.teardown));let n=aa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return Mo(e,a),a}function Ap(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 a={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:oe(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=oe(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=oe(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=oe(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=oe(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=oe(t.afterEach));let o=Mi.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function oe(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Mp)}function Mp(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 Ip(t);if("WHILE"in t)return Cp(t);if("STEP"in t)return Pp(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:ce(),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,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:ce(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:ce(),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:ce(),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.');return{uid:ce(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:ce(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return jc({...n,action:"function",functionName:i})}if("action"in t)return jc(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:ce(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function ed(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 Ip(e){let t=ed(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:ce(),type:"IF_ELSE",condition:t,then:oe(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=oe(e.ELSE)),n}function Cp(e){let t=ed(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:ce(),type:"WHILE_LOOP",condition:t,body:oe(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Pp(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:ce(),type:"STEP",description:t,statements:oe(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function jc(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,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))$p.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),a&&(s.xpath=a);let l={uid:ce(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Mo(e,t){let i;try{i=xp(e)}catch{return}let n=i.contents;if(!n||!vt(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 a=n,o=a.get("statements",!0);de(o)&&t.statements&&xt(o,t.statements);let r=a.get("teardown",!0);de(r)&&t.teardown&&xt(r,t.teardown)}function xt(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 a=t[i];if(a.type==="STEP"&&vt(n)){let o=n.get("statements",!0);de(o)&&xt(o,a.statements)}else if(a.type==="IF_ELSE"&&vt(n)){let o=n.get("THEN",!0);de(o)&&xt(o,a.then);let r=n.get("ELSE",!0);de(r)&&a.else&&xt(r,a.else)}else if(a.type==="WHILE_LOOP"&&vt(n)){let o=n.get("DO",!0);de(o)&&xt(o,a.body)}}}var kt,_p,Kc,$p,ra=y(()=>{"use strict";So();kt={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};_p=new Set(["intent","action","locator","xpath","frame_path","args"]);Kc=1024*1024;$p=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as Dp,stringify as Lp}from"yaml";function Io(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 a=t.operations[n],o=`operations[${n}]`;switch(a.reason||i.push(`${o}: missing reason`),a.op){case"remove":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}case"insert":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),a.position!=="before"&&a.position!=="after"&&i.push(`${o}: position must be 'before' or 'after'`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}default:i.push(`${o}: unknown operation type "${a.op}"`)}}return{valid:i.length===0,errors:i}}function Co(e,t){let i=Io(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],a=t.operations.map((s,l)=>({...s,originalOrder:l})),o={remove:0,modify:1,insert:2},r=[...a].sort((s,l)=>s.index!==l.index?l.index-s.index:o[s.op]-o[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function td(e,t){let i=Dp(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 a=Co(n,t);i.statements=a;let o=Lp(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Ye(o),{modifiedYaml:o,modifiedStatements:a}}var id=y(()=>{"use strict";ra()});function Po(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Me(t);for(let n of i)if(Po(n.statements))return!0}return!1}function od(e){let t=new Set;function i(n){for(let a of n){a.type==="STEP"&&a.reference_id&&t.add(a.reference_id);let o=Me(a);for(let r of o)i(r.statements)}}return i(e),Array.from(t)}function ld(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Fe(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Fe(e.teardown,"teardown",t),t}function Le(e,t,i){let n=e+".",a=t.filter(([c])=>c===e||c.startsWith(n));if(a.length===0)return[];let o=[],r=new Set;for(let[c]of a){let u=c===e?"":c.slice(n.length);if(!u)continue;let p=u.split(".")[0];r.has(p)||r.add(p)}let s=Array.from(r);s.sort((c,u)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return p>=0&&g>=0?p-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,p=l(u),g=p?.description??"",f=u;if(c==="then"){let v=`${e}.then`,S=`${e}.else`,A=Le(v,t,i),C=Le(S,t,i),I=l(e),$=I?d(I.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"IF_ELSE",condition:$,then:A,...C.length>0?{else:C}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,S=Le(v,t,i),A=l(e),C=A?d(A.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"WHILE_LOOP",condition:C,body:S});continue}let k=`${e}.${c}`,x=t.some(([v])=>v.startsWith(k+".then.")||v===k+".then"),m=t.some(([v])=>v.startsWith(k+".else.")||v===k+".else"),b=t.some(([v])=>v.startsWith(k+".body.")||v===k+".body"),_=t.filter(([v])=>{if(!v.startsWith(k+"."))return!1;let A=v.slice(k.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(x||m){let v=k+".then",S=k+".else",A=Le(v,t,i),C=Le(S,t,i),I=p?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"IF_ELSE",condition:I,then:A,...C.length>0?{else:C}:{}})}else if(b){let v=k+".body",S=Le(v,t,i),A=p?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"WHILE_LOOP",condition:A,body:S})}else if(_.length>0){let v=Le(k,t,i);o.push({uid:u,type:"STEP",description:g||"Group",statements:v})}else o.push({uid:u,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return o}function cd(e){let t=Object.entries(e),i=n=>{let a=n+".";return t.some(([r])=>r===n||r.startsWith(a))?Le(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Me,ie,Oe,Ne,Re,Pi,nd,ad,Op,Np,rd,sd,Fe,sa=y(()=>{"use strict";Me=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},ie=(e,t,i=void 0,n="root")=>{for(let a=0;a<e.length;a++){let o=e[a],r=o.uid;if(r===t)return{stableId:r,path:[a],statement:o,parent:i,containerKey:n,index:a};let s=Me(o);for(let l of s){let d=ie(l.statements,t,o,l.key);if(d)return{...d,path:[a,l.key,...d.path]}}}return null},Oe=(e,t,i)=>{let n=ie(e,t);if(!n)return null;let{statement:a,parent:o,containerKey:r,index:s}=n,l=null;switch(a.type){case"DRAFT":case"ACTION":l=Ne(e,n)||Re(e,n);break;case"STEP":if(a.statements&&a.statements.length>0)return a.statements[0];l=Ne(e,n)||Re(e,n);break;case"IF_ELSE":if(i===!0&&a.then&&a.then.length>0)return a.then[0];if(i===!1&&a.else&&a.else.length>0)return a.else[0];l=Ne(e,n)||Re(e,n);break;case"WHILE_LOOP":if(i===!0&&a.body&&a.body.length>0)return a.body[0];l=Ne(e,n)||Re(e,n);break;default:l=Ne(e,n)||Re(e,n);break}if(o&&o.type==="WHILE_LOOP"&&r==="body"){if(!l)return o;let d=ie(e,l.uid);if(!d||d.parent!==o)return o}return l},Ne=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Me(t.parent).find(a=>a.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Re=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=ie(e,i);return n?Ne(e,n)||Re(e,n):null},Pi=e=>{let t=[],i=n=>{for(let a of n){t.push(a);let o=Me(a);for(let r of o)i(r.statements)}};return i(e),t},nd=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}},ad=(e,t,i)=>{if(!ie(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&ie(e,l);)if(s.push(l),l=Oe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!ie(e,i))return null;if(t===i)return[];let o=[],r=t;for(;r&&r!==i;){let s=ie(e,r);if(!s)break;if(o.push(r),s.statement.type==="IF_ELSE"){let l=Op(s.statement,i);l?r=Oe(e,r,l==="then")?.uid||null:r=Oe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?Np(s.statement,i)?r=Oe(e,r,!0)?.uid||null:r=Oe(e,r,!1)?.uid||null:r=Oe(e,r)?.uid||null;if(o.length>1e3)return null}return r===i?o:null},Op=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&ie(i.then,t)?"then":i.else&&ie(i.else,t)?"else":null},Np=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&ie(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),sd=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),Fe=(e,t,i)=>{e.forEach((n,a)=>{let o=`${t}.${a}`;n.type==="DRAFT"?i[o]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[o]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Fe(n.statements,o,i):n.type==="IF_ELSE"?(i[o]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Fe(n.then,`${o}.then`,i),n.else&&Fe(n.else,`${o}.else`,i)):n.type==="WHILE_LOOP"&&(i[o]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Fe(n.body,`${o}.body`,i))})}});function Do(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let a=n.action_entity?.action_data?.action_name??"";$o.has(a)||t++}return{action:t,draft:i}}function Fp(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function dd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function ud(e,t){let i=t?.coverageThreshold??Rp,n=[],a=[],o;try{o=Ye(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||n.push('Missing required field: "goal"'),o.statements?.length||n.push('Missing required field: "statements"');let r=[...Pi(o.statements??[]),...o.teardown?Pi(o.teardown):[]],{action:s,draft:l}=Do(r),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 r){if(p.type==="ACTION"){let g=p,f=g.action_entity?.action_data?.action_name??"";if(f==="js_code"||f==="js_action"||f==="verify"||f==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let x=Fp(k);if(x){let m=g.description||f;n.push(`Invalid JS in "${m}": ${x}. ${d}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let f=dd(g.condition.expression);f&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${f}. ${d}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let f=dd(g.condition.expression);f&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${f}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&a.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:a,stats:{total:c,action:s,draft:l,coverage:u}}}var Rp,$o,hd=y(()=>{"use strict";ra();sa();Rp=.5,$o=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function md(e){return e?e.startsWith(ue)?"android":e.startsWith(he)?"ios":"web":"web"}function pd(e){return e?e.startsWith(ue)||e.startsWith(he):!1}function gd(e){return!!e&&e.startsWith(ue)}function fd(e){return!!e&&e.startsWith(he)}function wd(e){return e.startsWith(ue)?e.slice(ue.length):e.startsWith(he)?e.slice(he.length):e}function bd(e){return`${ue}${e}`}function yd(e){return`${he}${e}`}function la(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function xd(e){return e?!la(e):!1}function Lo(e){return e?la(e)?["web"]:["android","ios"]:["web","android","ios"]}function vd(e,t){if(!t)return!0;let i=Lo(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var ue,he,ca=y(()=>{"use strict";ue="android:",he="ios:"});function kd(e){return e.startsWith(he)?e:`${he}${e}`}function _d(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Sd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Ed=y(()=>{"use strict";ca()});var Oo,da,No,Ro,Fo,Ho,Wo,Bo,Uo,Go,Je,Ko,$i,jo,zo,_t,Td,Di,Ad,Md,ua,Id,Cd,Pd,$d,Dd=y(()=>{"use strict";Oo="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",da=112,No=1920,Ro=1080,Fo=1920,Ho=1080-da,Wo=1280,Bo=720,Uo=500,Go=500,Je="Desktop Chrome",Ko=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Ko||{}),$i={"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"}},jo=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(jo||{}),zo={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"]},_t=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),zo[e].map(n=>$i[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Td=()=>Object.keys($i),Di=e=>$i[e],Ad={desktop:{label:"Desktop",type:"desktop",devices:_t("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:_t("mobile")}},Md={desktop:{label:"Desktop",type:"desktop",devices:_t("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:_t("mobile",!0)}},ua=(e,t=!1)=>{let i={userAgent:Oo,viewport:{width:Fo,height:Ho},isMobile:!1,hasTouch:!1};if(!e||e===Je)return i;let n=Di(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(Uo/a,1),s=Math.max(Go/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Id=e=>{let t={width:No,height:Ro};if(!e||e===Je)return t;let i=ua(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+da}:t},Cd=e=>{let t={width:Wo,height:Bo};if(!e||e===Je)return t;let i=ua(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Pd=e=>!e||e===Je?void 0:Di(e)?.channel,$d=e=>!e||e===Je?"chromium":Di(e)?.defaultBrowserType??"chromium"});var Vo,Xo,Ld=y(()=>{"use strict";Vo=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Vo||{}),Xo=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Xo||{})});function Od(){return{version:"1.0",entries:{}}}function Nd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Rd(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 Fd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Hd(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,a]of t)i.entries[n]=a;return i}function Wd(e){return e?Object.keys(e.entries).length===0:!0}function Bd(e){return e?Object.keys(e.entries).length:0}function Ud(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Yo(e.statements??[],t),n=e.teardown?Yo(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Yo(e,t){return e.map(i=>Hp(i,t))}function Hp(e,t){if(e.type==="ACTION"){let a=e,o=t.entries[a.uid];return o?{...a,action_entity:o.action_entity}:a}let i=Me(e);if(i.length===0)return e;let n={};for(let a of i)n[a.key]=Yo(a.statements,t);return{...e,...n}}var Gd=y(()=>{"use strict";sa()});var Jo,qo,Kd,jd=y(()=>{"use strict";Jo=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Jo||{}),qo=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(qo||{}),Kd=18e4});var zd,Xd=y(()=>{"use strict";zd=class Vd{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 Vd;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}}});function Yd(e,t=Wp()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||tr,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||ir,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||nr}}function Jd(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return ha;if(e.ANTHROPIC_API_KEY)return Zo;if(e.OPENAI_API_KEY)return Qo}}function qd(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return ma;if(e.OPENAI_API_KEY)return er}}var Zo,ha,Qo,ma,er,tr,ir,nr,Wp,Zd=y(()=>{"use strict";Zo="claude-haiku-4-5",ha="gemini-3.1-flash-lite-preview",Qo="gpt-5.4-mini",ma="gemini-3-flash-preview",er="gpt-5.4",tr="claude-sonnet-4-6",ir=ha,nr=ma,Wp=()=>typeof process<"u"?process.env:{}});var ar,Qd=y(()=>{"use strict";ar=(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))(ar||{})});function eu(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],a=i[1],o="usb";return n.startsWith("emulator-")?o="emulator":n.includes(":")&&(o="wifi"),{id:n,state:a,connectionType:o}}function tu(e){return e.startsWith(ue)?e:`${ue}${e}`}function iu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var nu=y(()=>{"use strict";ca()});var or={};Ze(or,{ADDRESS_BAR_HEIGHT:()=>da,ANDROID_DEVICE_PREFIX:()=>ue,ActionEntitySchema:()=>xo,ActionSchema:()=>ko,AgentStatus:()=>ar,BaseStatementSchema:()=>Xe,BrowserType:()=>Ko,ConditionSchema:()=>na,ConditionType:()=>qo,ConditionTypeSchema:()=>bo,DEFAULT_ANTHROPIC_MODEL:()=>Zo,DEFAULT_COMPUTER_USE_MODEL:()=>nr,DEFAULT_COPILOT_MODEL:()=>tr,DEFAULT_DEVICE_NAME:()=>Je,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>ma,DEFAULT_GOOGLE_MODEL:()=>ha,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>er,DEFAULT_OPENAI_MODEL:()=>Qo,DEFAULT_WEBAGENT_MODEL:()=>ir,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Kd,DEVICE_CATEGORIES:()=>zo,DeviceType:()=>jo,DraftSchema:()=>vo,IOS_DEVICE_PREFIX:()=>he,LoginType:()=>Vo,MIN_WINDOW_HEIGHT:()=>Go,MIN_WINDOW_WIDTH:()=>Uo,NON_INTENT_ACTIONS:()=>$o,NodeJSCodeCommon:()=>Lc,PLAYWRIGHT_DEVICES:()=>$i,RECORD_VIDEO_HEIGHT:()=>Bo,RECORD_VIDEO_WIDTH:()=>Wo,StatementSchema:()=>te,StatementType:()=>Jo,StatementTypeSchema:()=>yo,TestFlowSchema:()=>aa,TestGroupEntrySchema:()=>_o,TestGroupSchema:()=>Mi,TwoFactorAuthType:()=>Xo,UI_DEVICE_CATEGORIES:()=>Ad,UI_DEVICE_CATEGORIES_ELECTRON:()=>Md,USER_AGENT:()=>Oo,VIEWPORT_HEIGHT:()=>Ho,VIEWPORT_WIDTH:()=>Fo,VariableStore:()=>zd,WINDOW_HEIGHT:()=>Ro,WINDOW_WIDTH:()=>No,actionEntityToYaml:()=>Yc,actionStepsMapToTestFlowSections:()=>cd,allowPureVisionAction:()=>sd,applyPatchToYaml:()=>Co,applyPatchToYamlString:()=>td,collectActionSteps:()=>Fe,convertPlaywrightActionToEntity:()=>Bc,countIntentStatements:()=>Do,createAndroidDeviceName:()=>bd,createEmptyStore:()=>Od,createIOSDeviceName:()=>yd,createRunnerStoreEntry:()=>Nd,extractActionStepsFromTestFlow:()=>ld,extractAndAttachComments:()=>Mo,extractDeviceIdentifier:()=>wd,extractElementDescription:()=>go,extractElementDescriptionFromAriaSnapshot:()=>fo,extractLocatorFromCode:()=>wo,extractYamlMetadata:()=>Qc,findNextAfterContainer:()=>Re,findNextSibling:()=>Ne,findNextStatement:()=>Oe,findPathBetweenStatements:()=>ad,findStatementPathById:()=>ie,generateUid:()=>Wc,getAllDeviceNames:()=>Td,getAllReferenceIds:()=>od,getAllStatementsInOrder:()=>Pi,getAndroidDeviceDisplayName:()=>iu,getBrowserWindowSize:()=>Id,getCompatiblePlatforms:()=>Lo,getDeviceBrowserType:()=>$d,getDeviceByName:()=>Di,getDeviceChannel:()=>Pd,getDeviceOptions:()=>ua,getDevicesByCategory:()=>_t,getIOSDeviceDisplayName:()=>_d,getLoginConfigPlatform:()=>Nc,getRecordVideoSize:()=>Cd,getStatementContainers:()=>Me,getStoreSize:()=>Bd,getTestPlatformFromDeviceName:()=>md,hasReferenceIds:()=>Po,isAndroidDevice:()=>gd,isAppPackage:()=>xd,isDynamicAction:()=>rd,isExecutableStatement:()=>nd,isIOSDevice:()=>fd,isNativeDevice:()=>pd,isPhysicalDeviceUDID:()=>Sd,isPlatformCompatibleWithUrl:()=>vd,isStoreEmpty:()=>Wd,isWebUrl:()=>la,mergeActionEntitiesIntoTestFlow:()=>Ud,mergeStoreUpdates:()=>Hd,parseAdbDeviceLine:()=>eu,parseYamlArrayItems:()=>Zc,replaceVariables:()=>Fc,resolveActionEntity:()=>Rd,resolveComputerUseModelFromEnv:()=>qd,resolveModels:()=>Yd,resolveWebAgentModelFromEnv:()=>Jd,suiteToYaml:()=>Ao,testFlowToYaml:()=>zc,testFlowToYamlObject:()=>To,toAndroidDeviceName:()=>tu,toIOSDeviceName:()=>kd,updateStoreEntry:()=>Fd,validatePatch:()=>Io,validateTestYaml:()=>ud,yamlObjectsToString:()=>Vc,yamlToActionEntity:()=>Jc,yamlToTestFlow:()=>Ye});var rr=y(()=>{"use strict";Oc();Rc();Hc();Uc();id();hd();ra();So();Ed();Dd();Ld();Gd();sa();jd();Xd();Zd();Qd();nu();ca()});import*as He from"path";import*as su from"fs";import{test as Bp,expect as x1,chromium as Up}from"@playwright/test";import*as Z from"fs";import*as Qe from"path";import{randomUUID as cr}from"crypto";import{tmpdir as dr}from"os";function ur(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function hr(e){if(!Z.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(Z.readFileSync(e,"utf-8"))}catch(o){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${o}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,a=i.cookies.filter(o=>o&&typeof o=="object"&&typeof o.name=="string"&&typeof o.domain=="string");return a.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-a.length} malformed cookies (missing name or domain)`),a.map(o=>({...o,expires:n}))}function mr(e){if(e){let i=Qe.resolve(process.cwd(),e),n=Qe.join(dr(),`ext-profile-${cr()}`);if(Z.existsSync(i)){try{Z.cpSync(i,n,{recursive:!0})}catch(o){try{Z.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${o}`)}let a=Qe.join(n,"SingletonLock");Z.existsSync(a)&&Z.rmSync(a,{force:!0})}else Z.mkdirSync(n,{recursive:!0});return n}let t=Qe.join(dr(),`ext-profile-${cr()}`);return Z.mkdirSync(t,{recursive:!0}),t}async function Gp(e){let i=await import(He.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let a=await n(e.args||{});if(typeof a!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof a})`);return a}function au(e){return!(!e||e==="off")}function lu(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?lu(e.mode,t):!0}async function ou(e,t,i){let n=lu(t,i);for(let a of e)try{if(n){let o=await a.path();await i.attach("video",{path:o,contentType:"video/webm"})}else await a.delete()}catch(o){console.warn("[fixture] Failed to process video:",o)}}var pa;async function ru(){return pa||(pa=await Promise.resolve().then(()=>(Dc(),$c)),pa)}var Kp=new Set(["get","set","getAll","has","__variableStore"]);function jp(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,a=!1){e.set(i,n,a)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,a){if(n in i)return Reflect.get(i,n,a);if(typeof n=="string")return i.get(n)},set(i,n,a){return typeof n!="string"||Kp.has(n)?Reflect.set(i,n,a):(i.set(n,a),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var k1=Bp.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:a},o,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=mr(n),u=i?ur(He.resolve(process.cwd(),i)):[],p={...r.project.use},{storageState:g,account:f,extensionDir:k,userDataDir:x,extensionStorageState:m,autoDismissModal:b,video:_,...v}=p,S=au(_)?{dir:r.outputDir}:void 0,A;try{if(A=await Up.launchPersistentContext(c,{...v,headless:d,args:u,viewport:v.viewport??{width:1280,height:720},...S?{recordVideo:S}:{}}),a){let C=He.resolve(process.cwd(),a),I=hr(C);I&&await A.addCookies(I)}await o(A)}finally{let C=A?.pages().map(I=>I.video()).filter(I=>I!==null)??[];if(await A?.close().catch(I=>{console.warn("[fixture] Failed to close persistent context:",I)}),await ou(C,_,r),!n)try{su.rmSync(c,{recursive:!0,force:!0})}catch(I){console.warn("[fixture] Failed to clean up temp profile dir:",c,I)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await Gp(c)}let u=l.video;au(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let p=await e.newContext(l);try{await o(p)}finally{let g=p.pages().map(f=>f.video()).filter(f=>f!==null);await p.close(),await ou(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await ru(),n=new i,a=t.project.use.variables;if(a)for(let[r,s]of Object.entries(a))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let o=jp(n);global.testContext=o,global.$=o,global.ctx=o,await e(o),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,a)=>{let{WebAgent:o,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await ru(),d=l();s({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??"",OPENAI_API_KEY:process.env.OPENAI_API_KEY??""},...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(rr(),or)),p=c(process.env);if(!p)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, or OPENAI_API_KEY.");let g=u(process.env),f=t.__variableStore,k=r({model:p,computer_use_model:g,variableStore:f,autoDismissModal:i}),x=He.join(a.outputDir,"artifacts");k.stepTracking={results:{},artifactsDir:x};let m=new o(k),b=e.context();m.agentServices.setupPageTracking(b),global.agent=m,await n(m),delete global.agent;try{let _=a.outputDir;await m.writeExecutionResults(_);let v=He.join(_,"test-results.json");await(await import("fs/promises")).stat(v).catch(()=>null)&&await a.attach("shiplight-results",{path:v,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=m.getNewActionEntities();if(_.size>0&&a.status==="passed"){let{createEmptyStore:v,createRunnerStoreEntry:S}=await Promise.resolve().then(()=>(rr(),or)),A=await import("fs/promises"),C=v();for(let[$,U]of _)C.entries[$]=S(U,0);let I=He.join(a.outputDir,"new-action-entities.json");await A.writeFile(I,JSON.stringify(C,null,2)),await a.attach("shiplight-new-action-entities",{path:I,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});export{jp as createTestContext,x1 as expect,Gp as resolveAuthState,k1 as test};
4546
+ `;return e}generatePostlude(){return""}}});function Oc(e){if(!e)return"desktop";for(let t of gp)if(t.test(e))return"mobile";return"desktop"}var gp,Nc=b(()=>{"use strict";gp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function Rc(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var Fc=b(()=>{"use strict"});import{v4 as fp}from"uuid";function po(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let p=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(p&&p[1]){let _=p[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${_}"`}let x=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(x&&x[1]){let _=x[1].replace(/^\/|\/$/g,""),v=_.length>30?`${_.substring(0,27)}...`:_;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 p=yt(e),x=i[1].replace(/\\(.)/g,"$1");return`${p} with text "${x}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${yt(e)} with text matching ${n[1]}`;let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let p=yt(e),x=a[1].replace(/\\(.)/g,"$1");return`${p} containing "${x}"`}let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let p=yt(e),x=o[1].replace(/\\(.)/g,"$1");return`${p} containing "${x}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let p=yt(e),x=r[1].replace(/\\(.)/g,"$1");return`${p} not containing "${x}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let p=yt(e),x=s[1].replace(/\\(.)/g,"$1");return`${p} not containing "${x}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let m=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(m&&m[1])return`input with placeholder "${m[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let w=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(w&&w[1])return`"${w[1].replace(/\\(.)/g,"$1")}"`;let k=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(k&&k[1])return`"${k[1].replace(/\\(.)/g,"$1")}"`;let y=e.match(/getByRole\(['"]([^'"]+)['"]/);return y&&y[1]?`${y[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function go(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4547
+ `);for(let a of n){if(!a.includes(`[ref=${i}]`))continue;let s=a.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function fo(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 a=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return a&&a[1]?`frameLocator(${a[1]})`:t}function yt(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let a=t[1],o=a.match(/^([a-zA-Z][\w-]*)/);return o?o[1]:a.length>20?`${a.substring(0,17)}...`:a}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 mo(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 wp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function bp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Wc(e,t){let i=e.name||"unknown",n=fo(t,e.selector||""),a=e.ariaSnapshot??e.arIAaSnapshot??"",o=e.ref,r=/getByTestId\s*\(/.test(n),l=(o&&a&&r?go(a,o):null)??po(n),d,c,u={};switch(i){case"click":{let m=wp(t),g=bp(t);m==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},m&&m!=="left"&&(u.button=m),g&&(u.modifiers=g);break}case"fill":{let m=e.text||e.value||mo(t)||"";d="fill",c=m?`Fill ${l} with '${m}'`:`Fill ${l}`,u={value:m,index:0};break}case"press":{let m=e.key||mo(t)||"";d="press",c=`Press '${m}' on ${l}`,u={keyComb:m,index:0};break}case"selectOption":{let m=e.options?.[0]||mo(t)||"";d="select_dropdown_option",c=`Select '${m}' from ${l}`,u={text:m,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let m=e.files||[];d="upload_file",c=m.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:m,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var Hc,Bc=b(()=>{"use strict";Hc=()=>fp()});import{z as T}from"zod";var wo,na,bo,Xe,yo,xo,vo,te,ko,Mi,aa,_o=b(()=>{"use strict";wo=T.enum(["JS_CODE","AI_MODE"]),na=T.object({type:wo,expression:T.string()}),bo=T.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Xe=T.object({uid:T.string(),type:bo,comment:T.string().optional()}),yo=T.object({action_data:T.object({action_name:T.string(),kwargs:T.record(T.any()).optional(),args:T.array(T.any()).optional()}),action_description:T.string().optional(),url:T.string().optional(),xpath:T.string().nullable().optional(),locator:T.string().nullable().optional(),css_selector:T.string().nullable().optional(),unique_selector:T.string().nullable().optional(),element_index:T.number().nullable().optional(),frame_path:T.array(T.any()).optional(),artifacts:T.record(T.any()).optional(),feedback:T.string().optional(),original_browser_use_action:T.any().optional()}).passthrough(),xo=Xe.extend({type:T.literal("DRAFT"),description:T.string()}),vo=Xe.extend({type:T.literal("ACTION"),description:T.string(),action_entity:yo.optional(),locator:T.string().optional(),use_pure_vision:T.boolean().optional()}),te=T.lazy(()=>T.union([xo,vo,Xe.extend({type:T.literal("STEP"),description:T.string().optional().default(""),statements:T.array(te),reference_id:T.number().optional()}),Xe.extend({type:T.literal("IF_ELSE"),description:T.string().optional(),condition:na,then:T.array(te),else:T.array(te).optional()}),Xe.extend({type:T.literal("WHILE_LOOP"),description:T.string().optional(),condition:na,body:T.array(te),timeout_ms:T.number().optional()})])),ko=T.object({name:T.string(),statements:T.array(te),teardown:T.array(te).optional(),skip:T.union([T.boolean(),T.string()]).optional(),timeout:T.number().optional(),fail:T.union([T.boolean(),T.string()]).optional(),only:T.boolean().optional(),slow:T.boolean().optional()}),Mi=T.object({tests:T.array(ko).min(1),beforeAll:T.array(te).optional(),afterAll:T.array(te).optional(),beforeEach:T.array(te).optional(),afterEach:T.array(te).optional()}),aa=T.object({comment:T.string().optional(),version:T.string().optional(),goal:T.string().optional(),url:T.string().optional(),baseURL:T.string().optional(),final_feedback:T.string().optional(),completed:T.boolean().optional(),success:T.boolean().optional(),statements:T.array(te).optional(),teardown:T.array(te).optional(),last_modified_at:T.string().optional(),testGroup:Mi.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});import{stringify as Ci,parse as oa,parseAllDocuments as yp,parseDocument as xp,Document as vp,isMap as vt,isSeq as de}from"yaml";import{v4 as ce}from"uuid";function Eo(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(ae)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ae)),i}function jc(e,t){if(e.testGroup)return To(e,t);let i=Eo(e,t),n=new vp(i);return e.comment&&(n.commentBefore=e.comment),Uc(n,e.statements??[]),e.teardown&&Uc(n,e.teardown,"teardown"),n.toString(kt)}function Uc(e,t,i="statements"){let n=e.contents;if(!n||!vt(n))return;let a=n.get(i,!0);de(a)&&Ii(a,t)}function Ii(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),vt(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);de(r)&&Ii(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);de(r)&&Ii(r,n.then);let s=o.get("ELSE",!0);de(s)&&n.else&&Ii(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);de(r)&&Ii(r,n.body)}}}}function To(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);let a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(ae)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ae)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ae)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ae)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(ae),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(ae)),r}),n.suite=a,Ci(n,kt)}function zc(e){return e.map(t=>Ci(t,kt)).join(`---
4548
+ `)}function ae(e){switch(e.type){case"DRAFT":return kp(e);case"ACTION":return Vc(e);case"STEP":return Sp(e);case"IF_ELSE":return Ep(e);case"WHILE_LOOP":return Tp(e)}}function kp(e){return{intent:e.description}}function Vc(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))a[s]=l;return n.args&&n.args.length>0&&(a.args=n.args),a}function Xc(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},a=Vc(n);if(typeof a=="object"&&a!==null){let o={...a};return delete o.intent,delete o.VERIFY,delete o.WAIT_UNTIL,delete o.WAIT,delete o.statement,Object.keys(o).length>0?Ci(o,kt).trim():""}return Ci(a,kt).trim()}function Yc(e){let t=oa(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,a=typeof t.locator=="string"?t.locator:void 0,o=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))_p.has(c)||(l[c]=u);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...a?{locator:a}:{},...o?{xpath:o}:{},...r?{frame_path:r}:{}},description:i,locator:a}:{description:i,actionEntity:{action_description:i||""}}}function Sp(e){let t={STEP:e.description,statements:e.statements.map(ae)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Ep(e){let t={IF:Jc(e.condition),THEN:e.then.map(ae)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ae)),t}function Tp(e){let t={WHILE:Jc(e.condition),DO:e.body.map(ae)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Jc(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function qc(e){let t=yp(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,a)=>n.errors.length>0?{__parseError:`Document ${a+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=oa(e)}catch(a){throw new Error(`Invalid YAML: ${a instanceof Error?a.message:String(a)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,a)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${a+1}: expected an object`};let o=n,r=typeof o.name=="string"&&o.name.trim()||void 0,s=typeof o.goal=="string"?o.goal.trim():"";if(!s)return{error:`Item ${a+1}: missing "goal" field`};if(Array.isArray(o.statements))try{let l=Ci(o,kt),d=Ye(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(o){return{error:`Item ${a+1}: ${o instanceof Error?o.message:String(o)}`}}})}function Zc(e){try{let t=oa(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()),i}catch{return{}}}function So(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(So);let t=e,i=Object.keys(t);if(i.length===1){let a=i[0];if(a.startsWith("{ ")&&a.endsWith(" }")&&t[a]===null)return`{{${a.slice(2,-2)}}}`}let n={};for(let[a,o]of Object.entries(t))n[a]=So(o);return n}function Ye(e){if(e.length>Gc)throw new Error(`YAML input too large (${e.length} bytes, max ${Gc})`);let t=So(oa(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Ap(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:oe(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=oe(t.teardown));let n=aa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return Ao(e,a),a}function Ap(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 a={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:oe(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=oe(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=oe(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=oe(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=oe(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=oe(t.afterEach));let o=Mi.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function oe(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Mp)}function Mp(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 Ip(t);if("WHILE"in t)return Cp(t);if("STEP"in t)return Pp(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:ce(),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,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:ce(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:ce(),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:ce(),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.');return{uid:ce(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:ce(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Kc({...n,action:"function",functionName:i})}if("action"in t)return Kc(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:ce(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Qc(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 Ip(e){let t=Qc(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:ce(),type:"IF_ELSE",condition:t,then:oe(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=oe(e.ELSE)),n}function Cp(e){let t=Qc(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:ce(),type:"WHILE_LOOP",condition:t,body:oe(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Pp(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:ce(),type:"STEP",description:t,statements:oe(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function Kc(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,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))$p.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),a&&(s.xpath=a);let l={uid:ce(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function Ao(e,t){let i;try{i=xp(e)}catch{return}let n=i.contents;if(!n||!vt(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 a=n,o=a.get("statements",!0);de(o)&&t.statements&&xt(o,t.statements);let r=a.get("teardown",!0);de(r)&&t.teardown&&xt(r,t.teardown)}function xt(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 a=t[i];if(a.type==="STEP"&&vt(n)){let o=n.get("statements",!0);de(o)&&xt(o,a.statements)}else if(a.type==="IF_ELSE"&&vt(n)){let o=n.get("THEN",!0);de(o)&&xt(o,a.then);let r=n.get("ELSE",!0);de(r)&&a.else&&xt(r,a.else)}else if(a.type==="WHILE_LOOP"&&vt(n)){let o=n.get("DO",!0);de(o)&&xt(o,a.body)}}}var kt,_p,Gc,$p,ra=b(()=>{"use strict";_o();kt={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};_p=new Set(["intent","action","locator","xpath","frame_path","args"]);Gc=1024*1024;$p=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as Dp,stringify as Lp}from"yaml";function Mo(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 a=t.operations[n],o=`operations[${n}]`;switch(a.reason||i.push(`${o}: missing reason`),a.op){case"remove":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}case"insert":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),a.position!=="before"&&a.position!=="after"&&i.push(`${o}: position must be 'before' or 'after'`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}default:i.push(`${o}: unknown operation type "${a.op}"`)}}return{valid:i.length===0,errors:i}}function Io(e,t){let i=Mo(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],a=t.operations.map((s,l)=>({...s,originalOrder:l})),o={remove:0,modify:1,insert:2},r=[...a].sort((s,l)=>s.index!==l.index?l.index-s.index:o[s.op]-o[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function ed(e,t){let i=Dp(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 a=Io(n,t);i.statements=a;let o=Lp(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Ye(o),{modifiedYaml:o,modifiedStatements:a}}var td=b(()=>{"use strict";ra()});function Co(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Me(t);for(let n of i)if(Co(n.statements))return!0}return!1}function ad(e){let t=new Set;function i(n){for(let a of n){a.type==="STEP"&&a.reference_id&&t.add(a.reference_id);let o=Me(a);for(let r of o)i(r.statements)}}return i(e),Array.from(t)}function sd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return Fe(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&Fe(e.teardown,"teardown",t),t}function Le(e,t,i){let n=e+".",a=t.filter(([c])=>c===e||c.startsWith(n));if(a.length===0)return[];let o=[],r=new Set;for(let[c]of a){let u=c===e?"":c.slice(n.length);if(!u)continue;let m=u.split(".")[0];r.has(m)||r.add(m)}let s=Array.from(r);s.sort((c,u)=>{let m=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return m>=0&&g>=0?m-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,m=l(u),g=m?.description??"",w=u;if(c==="then"){let v=`${e}.then`,S=`${e}.else`,A=Le(v,t,i),C=Le(S,t,i),I=l(e),$=I?d(I.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"IF_ELSE",condition:$,then:A,...C.length>0?{else:C}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,S=Le(v,t,i),A=l(e),C=A?d(A.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"WHILE_LOOP",condition:C,body:S});continue}let k=`${e}.${c}`,y=t.some(([v])=>v.startsWith(k+".then.")||v===k+".then"),p=t.some(([v])=>v.startsWith(k+".else.")||v===k+".else"),x=t.some(([v])=>v.startsWith(k+".body.")||v===k+".body"),_=t.filter(([v])=>{if(!v.startsWith(k+"."))return!1;let A=v.slice(k.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(y||p){let v=k+".then",S=k+".else",A=Le(v,t,i),C=Le(S,t,i),I=m?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"IF_ELSE",condition:I,then:A,...C.length>0?{else:C}:{}})}else if(x){let v=k+".body",S=Le(v,t,i),A=m?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"WHILE_LOOP",condition:A,body:S})}else if(_.length>0){let v=Le(k,t,i);o.push({uid:u,type:"STEP",description:g||"Group",statements:v})}else o.push({uid:u,type:"ACTION",description:g||"Action",action_entity:m?.action_entity})}return o}function ld(e){let t=Object.entries(e),i=n=>{let a=n+".";return t.some(([r])=>r===n||r.startsWith(a))?Le(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Me,ie,Oe,Ne,Re,Pi,id,nd,Op,Np,od,rd,Fe,sa=b(()=>{"use strict";Me=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},ie=(e,t,i=void 0,n="root")=>{for(let a=0;a<e.length;a++){let o=e[a],r=o.uid;if(r===t)return{stableId:r,path:[a],statement:o,parent:i,containerKey:n,index:a};let s=Me(o);for(let l of s){let d=ie(l.statements,t,o,l.key);if(d)return{...d,path:[a,l.key,...d.path]}}}return null},Oe=(e,t,i)=>{let n=ie(e,t);if(!n)return null;let{statement:a,parent:o,containerKey:r,index:s}=n,l=null;switch(a.type){case"DRAFT":case"ACTION":l=Ne(e,n)||Re(e,n);break;case"STEP":if(a.statements&&a.statements.length>0)return a.statements[0];l=Ne(e,n)||Re(e,n);break;case"IF_ELSE":if(i===!0&&a.then&&a.then.length>0)return a.then[0];if(i===!1&&a.else&&a.else.length>0)return a.else[0];l=Ne(e,n)||Re(e,n);break;case"WHILE_LOOP":if(i===!0&&a.body&&a.body.length>0)return a.body[0];l=Ne(e,n)||Re(e,n);break;default:l=Ne(e,n)||Re(e,n);break}if(o&&o.type==="WHILE_LOOP"&&r==="body"){if(!l)return o;let d=ie(e,l.uid);if(!d||d.parent!==o)return o}return l},Ne=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Me(t.parent).find(a=>a.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},Re=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=ie(e,i);return n?Ne(e,n)||Re(e,n):null},Pi=e=>{let t=[],i=n=>{for(let a of n){t.push(a);let o=Me(a);for(let r of o)i(r.statements)}};return i(e),t},id=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}},nd=(e,t,i)=>{if(!ie(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&ie(e,l);)if(s.push(l),l=Oe(e,l)?.uid||null,s.length>1e3)return null;return s}if(!ie(e,i))return null;if(t===i)return[];let o=[],r=t;for(;r&&r!==i;){let s=ie(e,r);if(!s)break;if(o.push(r),s.statement.type==="IF_ELSE"){let l=Op(s.statement,i);l?r=Oe(e,r,l==="then")?.uid||null:r=Oe(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?Np(s.statement,i)?r=Oe(e,r,!0)?.uid||null:r=Oe(e,r,!1)?.uid||null:r=Oe(e,r)?.uid||null;if(o.length>1e3)return null}return r===i?o:null},Op=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&ie(i.then,t)?"then":i.else&&ie(i.else,t)?"else":null},Np=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&ie(i.body,t))};od=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),rd=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),Fe=(e,t,i)=>{e.forEach((n,a)=>{let o=`${t}.${a}`;n.type==="DRAFT"?i[o]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[o]={description:n.description||"Action",action_entity:n.action_entity,locator:n.locator}:n.type==="STEP"&&n.statements?Fe(n.statements,o,i):n.type==="IF_ELSE"?(i[o]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&Fe(n.then,`${o}.then`,i),n.else&&Fe(n.else,`${o}.else`,i)):n.type==="WHILE_LOOP"&&(i[o]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&Fe(n.body,`${o}.body`,i))})}});function $o(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let a=n.action_entity?.action_data?.action_name??"";Po.has(a)||t++}return{action:t,draft:i}}function Fp(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function cd(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function dd(e,t){let i=t?.coverageThreshold??Rp,n=[],a=[],o;try{o=Ye(e)}catch(m){return{valid:!1,errors:[`Invalid YAML: ${m.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||n.push('Missing required field: "goal"'),o.statements?.length||n.push('Missing required field: "statements"');let r=[...Pi(o.statements??[]),...o.teardown?Pi(o.teardown):[]],{action:s,draft:l}=$o(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let m of r){if(m.type==="ACTION"){let g=m,w=g.action_entity?.action_data?.action_name??"";if(w==="js_code"||w==="js_action"||w==="verify"||w==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let y=Fp(k);if(y){let p=g.description||w;n.push(`Invalid JS in "${p}": ${y}. ${d}`)}}}}if(m.type==="IF_ELSE"){let g=m;if(g.condition.type==="JS_CODE"){let w=cd(g.condition.expression);w&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${w}. ${d}`)}}if(m.type==="WHILE_LOOP"){let g=m;if(g.condition.type==="JS_CODE"){let w=cd(g.condition.expression);w&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${w}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&a.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:a,stats:{total:c,action:s,draft:l,coverage:u}}}var Rp,Po,ud=b(()=>{"use strict";ra();sa();Rp=.5,Po=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function hd(e){return e?e.startsWith(ue)?"android":e.startsWith(he)?"ios":"web":"web"}function md(e){return e?e.startsWith(ue)||e.startsWith(he):!1}function pd(e){return!!e&&e.startsWith(ue)}function gd(e){return!!e&&e.startsWith(he)}function fd(e){return e.startsWith(ue)?e.slice(ue.length):e.startsWith(he)?e.slice(he.length):e}function wd(e){return`${ue}${e}`}function bd(e){return`${he}${e}`}function la(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function yd(e){return e?!la(e):!1}function Do(e){return e?la(e)?["web"]:["android","ios"]:["web","android","ios"]}function xd(e,t){if(!t)return!0;let i=Do(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var ue,he,ca=b(()=>{"use strict";ue="android:",he="ios:"});function vd(e){return e.startsWith(he)?e:`${he}${e}`}function kd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function _d(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Sd=b(()=>{"use strict";ca()});var Lo,da,Oo,No,Ro,Fo,Ho,Wo,Bo,Uo,Je,Go,$i,Ko,jo,_t,Ed,Di,Td,Ad,ua,Md,Id,Cd,Pd,$d=b(()=>{"use strict";Lo="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",da=112,Oo=1920,No=1080,Ro=1920,Fo=1080-da,Ho=1280,Wo=720,Bo=500,Uo=500,Je="Desktop Chrome",Go=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Go||{}),$i={"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"}},Ko=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Ko||{}),jo={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"]},_t=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),jo[e].map(n=>$i[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ed=()=>Object.keys($i),Di=e=>$i[e],Td={desktop:{label:"Desktop",type:"desktop",devices:_t("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:_t("mobile")}},Ad={desktop:{label:"Desktop",type:"desktop",devices:_t("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:_t("mobile",!0)}},ua=(e,t=!1)=>{let i={userAgent:Lo,viewport:{width:Ro,height:Fo},isMobile:!1,hasTouch:!1};if(!e||e===Je)return i;let n=Di(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(Bo/a,1),s=Math.max(Uo/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Md=e=>{let t={width:Oo,height:No};if(!e||e===Je)return t;let i=ua(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+da}:t},Id=e=>{let t={width:Ho,height:Wo};if(!e||e===Je)return t;let i=ua(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Cd=e=>!e||e===Je?void 0:Di(e)?.channel,Pd=e=>!e||e===Je?"chromium":Di(e)?.defaultBrowserType??"chromium"});var zo,Vo,Dd=b(()=>{"use strict";zo=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(zo||{}),Vo=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Vo||{})});function Ld(){return{version:"1.0",entries:{}}}function Od(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Nd(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 Rd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function Fd(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,a]of t)i.entries[n]=a;return i}function Hd(e){return e?Object.keys(e.entries).length===0:!0}function Wd(e){return e?Object.keys(e.entries).length:0}function Bd(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Xo(e.statements??[],t),n=e.teardown?Xo(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Xo(e,t){return e.map(i=>Hp(i,t))}function Hp(e,t){if(e.type==="ACTION"){let a=e,o=t.entries[a.uid];return o?{...a,action_entity:o.action_entity}:a}let i=Me(e);if(i.length===0)return e;let n={};for(let a of i)n[a.key]=Xo(a.statements,t);return{...e,...n}}var Ud=b(()=>{"use strict";sa()});var Yo,Jo,Gd,Kd=b(()=>{"use strict";Yo=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Yo||{}),Jo=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(Jo||{}),Gd=18e4});var jd,Vd=b(()=>{"use strict";jd=class zd{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 zd;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}}});function Xd(e,t=Wp()){return{copilot:e?.models?.copilot||t.COPILOT_MODEL||er,webagent:e?.models?.webagent||t.WEB_AGENT_MODEL||tr,computer_use:e?.models?.computer_use||t.COMPUTER_USE_MODEL||ir}}function Yd(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.GOOGLE_API_KEY)return ha;if(e.ANTHROPIC_API_KEY)return qo;if(e.OPENAI_API_KEY)return Zo}}function Jd(e){if(e){if(e.COMPUTER_USE_MODEL)return e.COMPUTER_USE_MODEL;if(e.GOOGLE_API_KEY)return ma;if(e.OPENAI_API_KEY)return Qo}}var qo,ha,Zo,ma,Qo,er,tr,ir,Wp,qd=b(()=>{"use strict";qo="claude-haiku-4-5",ha="gemini-3.1-flash-lite-preview",Zo="gpt-5.4-mini",ma="gemini-3-flash-preview",Qo="gpt-5.4",er="claude-sonnet-4-6",tr=ha,ir=ma,Wp=()=>typeof process<"u"?process.env:{}});var nr,Zd=b(()=>{"use strict";nr=(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))(nr||{})});function Qd(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],a=i[1],o="usb";return n.startsWith("emulator-")?o="emulator":n.includes(":")&&(o="wifi"),{id:n,state:a,connectionType:o}}function eu(e){return e.startsWith(ue)?e:`${ue}${e}`}function tu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var iu=b(()=>{"use strict";ca()});var ar={};Ze(ar,{ADDRESS_BAR_HEIGHT:()=>da,ANDROID_DEVICE_PREFIX:()=>ue,ActionEntitySchema:()=>yo,ActionSchema:()=>vo,AgentStatus:()=>nr,BaseStatementSchema:()=>Xe,BrowserType:()=>Go,ConditionSchema:()=>na,ConditionType:()=>Jo,ConditionTypeSchema:()=>wo,DEFAULT_ANTHROPIC_MODEL:()=>qo,DEFAULT_COMPUTER_USE_MODEL:()=>ir,DEFAULT_COPILOT_MODEL:()=>er,DEFAULT_DEVICE_NAME:()=>Je,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>ma,DEFAULT_GOOGLE_MODEL:()=>ha,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Qo,DEFAULT_OPENAI_MODEL:()=>Zo,DEFAULT_WEBAGENT_MODEL:()=>tr,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Gd,DEVICE_CATEGORIES:()=>jo,DeviceType:()=>Ko,DraftSchema:()=>xo,IOS_DEVICE_PREFIX:()=>he,LoginType:()=>zo,MIN_WINDOW_HEIGHT:()=>Uo,MIN_WINDOW_WIDTH:()=>Bo,NON_INTENT_ACTIONS:()=>Po,NodeJSCodeCommon:()=>Dc,PLAYWRIGHT_DEVICES:()=>$i,RECORD_VIDEO_HEIGHT:()=>Wo,RECORD_VIDEO_WIDTH:()=>Ho,StatementSchema:()=>te,StatementType:()=>Yo,StatementTypeSchema:()=>bo,TestFlowSchema:()=>aa,TestGroupEntrySchema:()=>ko,TestGroupSchema:()=>Mi,TwoFactorAuthType:()=>Vo,UI_DEVICE_CATEGORIES:()=>Td,UI_DEVICE_CATEGORIES_ELECTRON:()=>Ad,USER_AGENT:()=>Lo,VIEWPORT_HEIGHT:()=>Fo,VIEWPORT_WIDTH:()=>Ro,VariableStore:()=>jd,WINDOW_HEIGHT:()=>No,WINDOW_WIDTH:()=>Oo,actionEntityToYaml:()=>Xc,actionStepsMapToTestFlowSections:()=>ld,allowPureVisionAction:()=>rd,applyPatchToYaml:()=>Io,applyPatchToYamlString:()=>ed,collectActionSteps:()=>Fe,convertPlaywrightActionToEntity:()=>Wc,countIntentStatements:()=>$o,createAndroidDeviceName:()=>wd,createEmptyStore:()=>Ld,createIOSDeviceName:()=>bd,createRunnerStoreEntry:()=>Od,extractActionStepsFromTestFlow:()=>sd,extractAndAttachComments:()=>Ao,extractDeviceIdentifier:()=>fd,extractElementDescription:()=>po,extractElementDescriptionFromAriaSnapshot:()=>go,extractLocatorFromCode:()=>fo,extractYamlMetadata:()=>Zc,findNextAfterContainer:()=>Re,findNextSibling:()=>Ne,findNextStatement:()=>Oe,findPathBetweenStatements:()=>nd,findStatementPathById:()=>ie,generateUid:()=>Hc,getAllDeviceNames:()=>Ed,getAllReferenceIds:()=>ad,getAllStatementsInOrder:()=>Pi,getAndroidDeviceDisplayName:()=>tu,getBrowserWindowSize:()=>Md,getCompatiblePlatforms:()=>Do,getDeviceBrowserType:()=>Pd,getDeviceByName:()=>Di,getDeviceChannel:()=>Cd,getDeviceOptions:()=>ua,getDevicesByCategory:()=>_t,getIOSDeviceDisplayName:()=>kd,getLoginConfigPlatform:()=>Oc,getRecordVideoSize:()=>Id,getStatementContainers:()=>Me,getStoreSize:()=>Wd,getTestPlatformFromDeviceName:()=>hd,hasReferenceIds:()=>Co,isAndroidDevice:()=>pd,isAppPackage:()=>yd,isDynamicAction:()=>od,isExecutableStatement:()=>id,isIOSDevice:()=>gd,isNativeDevice:()=>md,isPhysicalDeviceUDID:()=>_d,isPlatformCompatibleWithUrl:()=>xd,isStoreEmpty:()=>Hd,isWebUrl:()=>la,mergeActionEntitiesIntoTestFlow:()=>Bd,mergeStoreUpdates:()=>Fd,parseAdbDeviceLine:()=>Qd,parseYamlArrayItems:()=>qc,replaceVariables:()=>Rc,resolveActionEntity:()=>Nd,resolveComputerUseModelFromEnv:()=>Jd,resolveModels:()=>Xd,resolveWebAgentModelFromEnv:()=>Yd,suiteToYaml:()=>To,testFlowToYaml:()=>jc,testFlowToYamlObject:()=>Eo,toAndroidDeviceName:()=>eu,toIOSDeviceName:()=>vd,updateStoreEntry:()=>Rd,validatePatch:()=>Mo,validateTestYaml:()=>dd,yamlObjectsToString:()=>zc,yamlToActionEntity:()=>Yc,yamlToTestFlow:()=>Ye});var or=b(()=>{"use strict";Lc();Nc();Fc();Bc();td();ud();ra();_o();Sd();$d();Dd();Ud();sa();Kd();Vd();qd();Zd();iu();ca()});import*as He from"path";import*as ru from"fs";import{test as Bp,expect as k1,chromium as Up}from"@playwright/test";import*as Z from"fs";import*as Qe from"path";import{randomUUID as lr}from"crypto";import{tmpdir as cr}from"os";function dr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function ur(e){if(!Z.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(Z.readFileSync(e,"utf-8"))}catch(o){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${o}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,a=i.cookies.filter(o=>o&&typeof o=="object"&&typeof o.name=="string"&&typeof o.domain=="string");return a.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-a.length} malformed cookies (missing name or domain)`),a.map(o=>({...o,expires:n}))}function hr(e){if(e){let i=Qe.resolve(process.cwd(),e),n=Qe.join(cr(),`ext-profile-${lr()}`);if(Z.existsSync(i)){try{Z.cpSync(i,n,{recursive:!0})}catch(o){try{Z.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${o}`)}let a=Qe.join(n,"SingletonLock");Z.existsSync(a)&&Z.rmSync(a,{force:!0})}else Z.mkdirSync(n,{recursive:!0});return n}let t=Qe.join(cr(),`ext-profile-${lr()}`);return Z.mkdirSync(t,{recursive:!0}),t}async function Gp(e){let i=await import(He.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let a=await n(e.args||{});if(typeof a!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof a})`);return a}function nu(e){return!(!e||e==="off")}function su(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?su(e.mode,t):!0}async function au(e,t,i){let n=su(t,i);for(let a of e)try{if(n){let o=await a.path();await i.attach("video",{path:o,contentType:"video/webm"})}else await a.delete()}catch(o){console.warn("[fixture] Failed to process video:",o)}}var pa;async function ou(){return pa||(pa=await Promise.resolve().then(()=>($c(),Pc)),pa)}var Kp=new Set(["get","set","getAll","has","__variableStore"]);function jp(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,a=!1){e.set(i,n,a)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,a){if(n in i)return Reflect.get(i,n,a);if(typeof n=="string")return i.get(n)},set(i,n,a){return typeof n!="string"||Kp.has(n)?Reflect.set(i,n,a):(i.set(n,a),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var zp=["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"];function Vp(e=process.env){let t={};for(let i of zp)t[i]=e[i]??"";return t}var S1=Bp.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:a},o,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=hr(n),u=i?dr(He.resolve(process.cwd(),i)):[],m={...r.project.use},{storageState:g,account:w,extensionDir:k,userDataDir:y,extensionStorageState:p,autoDismissModal:x,video:_,...v}=m,S=nu(_)?{dir:r.outputDir}:void 0,A;try{if(A=await Up.launchPersistentContext(c,{...v,headless:d,args:u,viewport:v.viewport??{width:1280,height:720},...S?{recordVideo:S}:{}}),a){let C=He.resolve(process.cwd(),a),I=ur(C);I&&await A.addCookies(I)}await o(A)}finally{let C=A?.pages().map(I=>I.video()).filter(I=>I!==null)??[];if(await A?.close().catch(I=>{console.warn("[fixture] Failed to close persistent context:",I)}),await au(C,_,r),!n)try{ru.rmSync(c,{recursive:!0,force:!0})}catch(I){console.warn("[fixture] Failed to clean up temp profile dir:",c,I)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await Gp(c)}let u=l.video;nu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let m=await e.newContext(l);try{await o(m)}finally{let g=m.pages().map(w=>w.video()).filter(w=>w!==null);await m.close(),await au(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await ou(),n=new i,a=t.project.use.variables;if(a)for(let[r,s]of Object.entries(a))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let o=jp(n);global.testContext=o,global.$=o,global.ctx=o,await e(o),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,a)=>{let{WebAgent:o,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await ou(),d=l();s({env:Vp(),...d!==void 0&&{logLevel:d}});let{resolveWebAgentModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(or(),ar)),m=c(process.env);if(!m)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, GOOGLE_API_KEY, ANTHROPIC_API_KEY, or OPENAI_API_KEY.");let g=u(process.env),w=t.__variableStore,k=r({model:m,computer_use_model:g,variableStore:w,autoDismissModal:i}),y=He.join(a.outputDir,"artifacts");k.stepTracking={results:{},artifactsDir:y};let p=new o(k),x=e.context();p.agentServices.setupPageTracking(x),global.agent=p,await n(p),delete global.agent;try{let _=a.outputDir;await p.writeExecutionResults(_);let v=He.join(_,"test-results.json");await(await import("fs/promises")).stat(v).catch(()=>null)&&await a.attach("shiplight-results",{path:v,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=p.getNewActionEntities();if(_.size>0&&a.status==="passed"){let{createEmptyStore:v,createRunnerStoreEntry:S}=await Promise.resolve().then(()=>(or(),ar)),A=await import("fs/promises"),C=v();for(let[$,U]of _)C.entries[$]=S(U,0);let I=He.join(a.outputDir,"new-action-entities.json");await A.writeFile(I,JSON.stringify(C,null,2)),await a.attach("shiplight-new-action-entities",{path:I,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});export{zp as SDK_ENV_ALLOWLIST,Vp as buildSdkEnv,jp as createTestContext,k1 as expect,Gp as resolveAuthState,S1 as test};