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.
@@ -1,10 +1,10 @@
1
1
  import { createRequire as __createRequire } from "module";
2
2
  const require = __createRequire(import.meta.url);
3
- var Hs=Object.defineProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var et=(e,t)=>{for(var i in t)Hs(e,i,{get:t[i],enumerable:!0})};function B(){return aa.getConfig()}var Ws,aa,ii,Z=w(()=>{"use strict";Ws=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}},aa=new Ws,ii=aa});var Us,Bs,g,F=w(()=>{"use strict";Z();Us=class{getLevel(){return ii.get("logLevel")}isStderrOnly(){return ii.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){ii.set("logLevel",e)}},Bs=new Us,g=Bs});import{appendFileSync as oa}from"fs";var Gs,k,Q=w(()=>{"use strict";Z();Gs=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=B().agentLogPath;if(e)try{oa(e,`
3
+ var Fs=Object.defineProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var et=(e,t)=>{for(var i in t)Fs(e,i,{get:t[i],enumerable:!0})};function B(){return na.getConfig()}var Hs,na,ii,Z=w(()=>{"use strict";Hs=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}},na=new Hs,ii=na});var Ws,Us,p,F=w(()=>{"use strict";Z();Ws=class{getLevel(){return ii.get("logLevel")}isStderrOnly(){return ii.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){ii.set("logLevel",e)}},Us=new Ws,p=Us});import{appendFileSync as aa}from"fs";var Bs,k,Q=w(()=>{"use strict";Z();Bs=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=B().agentLogPath;if(e)try{aa(e,`
4
4
  === Agent Execution Log ===
5
5
  Started: ${new Date().toISOString()}
6
6
 
7
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=B().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();oa(t,`[${i}] ${e}
7
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=B().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();aa(t,`[${i}] ${e}
8
8
  `)}catch{}}}section(e){this.log(`
9
9
  ${"=".repeat(60)}
10
10
  ${e}
@@ -13,9 +13,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
13
13
  ${e}`),this.log(`
14
14
  User Prompt:
15
15
  ${t}`)}response(e){this.log(`LLM Response:
16
- ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!B().agentLogPath}},k=new Gs});var un,js,Ks,zs,ra,ni,dn,sa,hn,ge=w(()=>{"use strict";un=Object.defineProperty,js=Object.getOwnPropertyDescriptor,Ks=Object.getOwnPropertyNames,zs=Object.prototype.hasOwnProperty,ra=(e,t)=>()=>(e&&(t=e(e=0)),t),ni=(e,t)=>{for(var i in t)un(e,i,{get:t[i],enumerable:!0})},dn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Ks(t))!zs.call(e,a)&&a!==i&&un(e,a,{get:()=>t[a],enumerable:!(n=js(t,a))||n.enumerable});return e},sa=(e,t,i)=>(dn(e,t,"default"),i&&dn(i,t,"default")),hn=e=>dn(un({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??pn}function Vs(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function C(e,t){let i=Ae(t);return i?new Function("page",`return ${i}`)(e):null}async function mn(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 Xs(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 Ys(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Js(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 Ae(e){let t=Ys(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Js(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var ai,tt,pn,de,M,L=w(()=>{"use strict";ge();ai={};ni(ai,{ACTION_TIMEOUT:()=>pn,GOTO_TIMEOUT:()=>de,LOCATOR_TIMEOUT:()=>tt,getActionTimeoutMs:()=>P,getFrameContext:()=>mn,getLocator:()=>C,getMinimalActionEntity:()=>Xs,getPageLocatorExpression:()=>Ae,sanitizeForComment:()=>Vs});M=ra(()=>{tt=5e3,pn=1e4,de=2e4})});async function gn(e,t,i=[],n=[]){try{let a=await mn(e,i);if(!a)return g.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return g.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${la(s)}`),d=qs(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${la(t)}`)).elementHandle({timeout:tt}),!o)return g.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:tt}),!o)return g.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?(g.debug(`Generated locator for ${t}: ${r}`),r):(g.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return g.error(`Error in pickBestLocator: ${a}`),null}}async function fn(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?(g.debug(`Generated locator: ${i}`),i):(g.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return g.error(`Error in pickBestLocator: ${i}`),null}}function la(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function qs(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 Oe=w(()=>{"use strict";F();L();M()});async function it(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 k.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 fe(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 oi(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 fn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ri(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 Fe=w(()=>{"use strict";Q();Oe()});import{createGoogleGenerativeAI as Zs}from"@ai-sdk/google";import{createVertex as Qs}from"@ai-sdk/google-vertex";function si(){let e=(B().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function da(e){let t=B().env||{};if(si()){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 g.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Qs({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 g.debug(`Using Google AI provider (API key): model=${e}`),Zs({apiKey:i})(e)}function ua(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:ca.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=ca.MEDIA_RESOLUTION_HIGH)}return si()?{vertex:a}:{google:a}}var ca,He=w(()=>{"use strict";F();Z();ca={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as el,Environment as tl}from"@google/genai";function ue(e,t){return Math.round(e/1e3*t)}async function nl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=ue(i.destination_x,n),c=ue(i.destination_y,a),u=await fe(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:k.log(`Unsupported Gemini function: ${t}`)}}catch(s){k.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await oi(e,r)}}async function ma(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||al,l=B(),d;if(si()){let b=l.env?.GOOGLE_CLOUD_PROJECT;if(!b)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let E=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:b,location:E}}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 el(d);k.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:tl.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:il}],temperature:.1}});k.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let f=m.content?.parts?.find(b=>b.functionCall);if(!f)return{status:"error",reasoning:m.content?.parts?.filter(b=>b.text).map(b=>b.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:h,args:x}=f.functionCall;k.log(`Generated function call: ${h} with args ${JSON.stringify(x)}`),g.debug(`Generated function call: ${h} with args ${JSON.stringify(x)}`);let{action_data:y,locatorInfo:p}=await nl(i,h,x,a,o);return y?{status:"success",actionEntity:ri(t,y,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${h}`}}var ha,il,al,li=w(()=>{"use strict";Fe();Q();He();F();Z();ha={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"]},il=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:ha},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:ha}];al="gemini-3-flash-preview"});function ga(e){return e!=null&&typeof e=="object"}function We(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function pa(e){return typeof e=="string"?e:void 0}function ol(e){let t,i;return Array.isArray(e)?(t=We(e[0]),i=We(e[1])):ga(e)&&(t=We(e.x),i=We(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function fa(e){if(!ga(e))return{};let t=Array.isArray(e.path)?e.path.map(ol).filter(i=>i!==null):void 0;return{type:pa(e.type),x:We(e.x),y:We(e.y),button:pa(e.button),path:t}}var ci=w(()=>{"use strict"});import rl from"openai";async function sl(e,t){let i=fa(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 fe(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 fe(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 fe(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 oi(e,a)}}async function ba(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||ll,s=await it(i,n,a),l=B().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=new rl({apiKey:l}),c=d.responses.create.bind(d.responses);k.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 m(p,b){let E={model:r,tools:[cl],input:p,temperature:.1};return b&&(E.previous_response_id=b),c(E)}let f=await m(u,void 0),h;for(let p=0;p<wa;p++){k.log(`Received response from OpenAI CUA (turn ${p+1})`);let b=f.output.find(A=>A.type==="computer_call");if(!b)return{status:"error",reasoning:f.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let E=b.actions??[];if(E.length>1&&k.log(`[openai CUA] dropping ${E.length-1} batched action(s); only the first is executed`),h=E[0],!h)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(h.type!=="screenshot")break;s=await it(i,n,a);let T=[{type:"computer_call_output",call_id:b.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];f=await m(T,f.id)}if(!h)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(h.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${wa} turns`};k.log(`Generated action: ${JSON.stringify(h)}`);let{action_data:x,locatorInfo:y}=await sl(i,h);return x?{status:"success",actionEntity:ri(t,x,y),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(h)}`}}var ll,cl,wa,di=w(()=>{"use strict";ci();Fe();Q();Z();ll="gpt-5.4",cl={type:"computer"},wa=4});import{createOpenAI as dl}from"@ai-sdk/openai";function ya(e){let t=B(),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 g.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),dl({apiKey:i,baseURL:n})(e)}function xa(e){return{}}var nt=w(()=>{"use strict";F();Z()});import{createAnthropic as ul}from"@ai-sdk/anthropic";import{createVertexAnthropic as hl}from"@ai-sdk/google-vertex/anthropic";function ml(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function wn(e){return B().env?.[e]??process.env[e]}function pl(){return ml(wn("ANTHROPIC_MODELS_USE_VERTEXAI"))}function va(e){if(pl()){let i=wn("GOOGLE_CLOUD_PROJECT"),n=wn("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 g.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${i}, location=${n}`),hl({project:i,location:n})(e)}let t=B().env?.ANTHROPIC_API_KEY;if(!t)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return g.debug(`Using Anthropic provider: model=${e}`),ul({apiKey:t})(e)}function bn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var at=w(()=>{"use strict";F();Z()});function ka(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(gl.test(e))return"openai"}function ui(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(fl.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function we(e){let{provider:t,modelId:i}=ui(e),n=t??ka(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=_a[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(_a).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function be(e,t){let{provider:i,modelId:n}=ui(e),a=i??ka(n);return a==="anthropic"||a==="vertex"?bn(n):a==="openai"||a==="azure"?xa(n):a==="bedrock"?n.startsWith("anthropic.")?bn(n):{}:ua(t,n)}var gl,fl,_a,ye=w(()=>{"use strict";nt();at();He();gl=/^(gpt-|o\d|chatgpt-)/;fl=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);_a={anthropic:va,google:da,openai:ya}});function bl(e){return e.startsWith("gemini-")?"google":"openai"}async function Ue(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;k.log(`Viewport: ${o}x${r}`);let s=await it(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=ui(l),c=bl(d),u=wl[c];k.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(f){return k.error(`CUA provider "${c}" threw an error`,f),{status:"error",error:f.message??"CUA provider failed"}}}var wl,Be=w(()=>{"use strict";li();di();Fe();Q();ye();wl={google:ma,openai:ba}});import{zodToJsonSchema as yl}from"zod-to-json-schema";function hi(e){let t=yl(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 ot(t),t}function ot(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))ot(i)}e.type==="array"&&e.items&&ot(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(ot);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&ot(i)}}var rt=w(()=>{"use strict"});var yn,mi=w(()=>{"use strict";rt();yn=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:hi(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:hi(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:hi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function xl(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 vl(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=xl(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
16
+ ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!B().agentLogPath}},k=new Bs});var un,Gs,js,Ks,oa,ni,dn,ra,hn,ge=w(()=>{"use strict";un=Object.defineProperty,Gs=Object.getOwnPropertyDescriptor,js=Object.getOwnPropertyNames,Ks=Object.prototype.hasOwnProperty,oa=(e,t)=>()=>(e&&(t=e(e=0)),t),ni=(e,t)=>{for(var i in t)un(e,i,{get:t[i],enumerable:!0})},dn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of js(t))!Ks.call(e,a)&&a!==i&&un(e,a,{get:()=>t[a],enumerable:!(n=Gs(t,a))||n.enumerable});return e},ra=(e,t,i)=>(dn(e,t,"default"),i&&dn(i,t,"default")),hn=e=>dn(un({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??pn}function zs(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function C(e,t){let i=Ae(t);return i?new Function("page",`return ${i}`)(e):null}async function mn(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 Vs(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 Xs(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ys(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 Ae(e){let t=Xs(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ys(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var ai,tt,pn,de,M,L=w(()=>{"use strict";ge();ai={};ni(ai,{ACTION_TIMEOUT:()=>pn,GOTO_TIMEOUT:()=>de,LOCATOR_TIMEOUT:()=>tt,getActionTimeoutMs:()=>P,getFrameContext:()=>mn,getLocator:()=>C,getMinimalActionEntity:()=>Vs,getPageLocatorExpression:()=>Ae,sanitizeForComment:()=>zs});M=oa(()=>{tt=5e3,pn=1e4,de=2e4})});async function gn(e,t,i=[],n=[]){try{let a=await mn(e,i);if(!a)return p.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return p.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${sa(s)}`),d=Js(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${sa(t)}`)).elementHandle({timeout:tt}),!o)return p.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:tt}),!o)return p.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?(p.debug(`Generated locator for ${t}: ${r}`),r):(p.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return p.error(`Error in pickBestLocator: ${a}`),null}}async function fn(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?(p.debug(`Generated locator: ${i}`),i):(p.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return p.error(`Error in pickBestLocator: ${i}`),null}}function sa(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Js(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 Oe=w(()=>{"use strict";F();L();M()});async function it(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 k.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 fe(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 oi(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 fn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ri(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 Fe=w(()=>{"use strict";Q();Oe()});import{createGoogleGenerativeAI as qs}from"@ai-sdk/google";import{createVertex as Zs}from"@ai-sdk/google-vertex";function si(){let e=(B().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function ca(e){let t=B().env||{};if(si()){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 p.debug(`Using Vertex AI provider: model=${e}, location=${a}`),Zs({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 p.debug(`Using Google AI provider (API key): model=${e}`),qs({apiKey:i})(e)}function da(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:la.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=la.MEDIA_RESOLUTION_HIGH)}return si()?{vertex:a}:{google:a}}var la,He=w(()=>{"use strict";F();Z();la={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Qs,Environment as el}from"@google/genai";function ue(e,t){return Math.round(e/1e3*t)}async function il(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=await fe(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=ue(i.x,n),l=ue(i.y,a),d=ue(i.destination_x,n),c=ue(i.destination_y,a),u=await fe(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:k.log(`Unsupported Gemini function: ${t}`)}}catch(s){k.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await oi(e,r)}}async function ha(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=r||nl,l=B(),d;if(si()){let y=l.env?.GOOGLE_CLOUD_PROJECT;if(!y)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let E=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:y,location:E}}else{let y=l.env?.GOOGLE_API_KEY;if(!y)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};d={apiKey:y}}let c=new Qs(d);k.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:el.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:tl}],temperature:.1}});k.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let f=m.content?.parts?.find(y=>y.functionCall);if(!f)return{status:"error",reasoning:m.content?.parts?.filter(y=>y.text).map(y=>y.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:h,args:x}=f.functionCall;k.log(`Generated function call: ${h} with args ${JSON.stringify(x)}`),p.debug(`Generated function call: ${h} with args ${JSON.stringify(x)}`);let{action_data:b,locatorInfo:g}=await il(i,h,x,a,o);return b?{status:"success",actionEntity:ri(t,b,g),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${h}`}}var ua,tl,nl,li=w(()=>{"use strict";Fe();Q();He();F();Z();ua={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"]},tl=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:ua},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:ua}];nl="gemini-3-flash-preview"});function pa(e){return e!=null&&typeof e=="object"}function We(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function ma(e){return typeof e=="string"?e:void 0}function al(e){let t,i;return Array.isArray(e)?(t=We(e[0]),i=We(e[1])):pa(e)&&(t=We(e.x),i=We(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function ga(e){if(!pa(e))return{};let t=Array.isArray(e.path)?e.path.map(al).filter(i=>i!==null):void 0;return{type:ma(e.type),x:We(e.x),y:We(e.y),button:ma(e.button),path:t}}var ci=w(()=>{"use strict"});import ol from"openai";async function rl(e,t){let i=ga(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 fe(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 fe(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 fe(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 oi(e,a)}}async function wa(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||sl,s=await it(i,n,a),l=B(),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 ol({apiKey:d,...c&&{baseURL:c}}),m=u.responses.create.bind(u.responses);k.log(`Sending request to OpenAI CUA (model=${r})...`);let f=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function h(E,T){let A={model:r,tools:[ll],input:E,temperature:.1};return T&&(A.previous_response_id=T),m(A)}let x=await h(f,void 0),b;for(let E=0;E<fa;E++){k.log(`Received response from OpenAI CUA (turn ${E+1})`);let T=x.output.find(N=>N.type==="computer_call");if(!T)return{status:"error",reasoning:x.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=T.actions??[];if(A.length>1&&k.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;s=await it(i,n,a);let I=[{type:"computer_call_output",call_id:T.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`,detail:"original"}}];x=await h(I,x.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${fa} turns`};k.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:g,locatorInfo:y}=await rl(i,b);return g?{status:"success",actionEntity:ri(t,g,y),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var sl,ll,fa,di=w(()=>{"use strict";ci();Fe();Q();Z();sl="gpt-5.4",ll={type:"computer"},fa=4});import{createAnthropic as cl}from"@ai-sdk/anthropic";import{createVertexAnthropic as dl}from"@ai-sdk/google-vertex/anthropic";function ul(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function hl(){return ul(B().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function ba(e){let t=B();if(hl()){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 p.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${n}, location=${a}`),dl({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 p.debug(`Using Anthropic provider: model=${e}`),cl({apiKey:i})(e)}function wn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var nt=w(()=>{"use strict";F();Z()});import{createOpenAI as ml}from"@ai-sdk/openai";function ya(e){let t=B(),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 p.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),ml({apiKey:i,baseURL:n})(e)}function xa(e){return{}}var at=w(()=>{"use strict";F();Z()});function _a(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(pl.test(e))return"openai"}function ui(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(gl.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function we(e){let{provider:t,modelId:i}=ui(e),n=t??_a(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=va[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(va).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function be(e,t){let{provider:i,modelId:n}=ui(e),a=i??_a(n);return a==="anthropic"||a==="vertex"?wn(n):a==="openai"||a==="azure"?xa(n):a==="bedrock"?n.startsWith("anthropic.")?wn(n):{}:da(t,n)}var pl,gl,va,ye=w(()=>{"use strict";nt();He();at();pl=/^(gpt-|o\d|chatgpt-)/;gl=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);va={anthropic:ba,google:ca,openai:ya}});function wl(e){return e.startsWith("gemini-")?"google":"openai"}async function Ue(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;k.log(`Viewport: ${o}x${r}`);let s=await it(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=ui(l),c=wl(d),u=fl[c];k.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(f){return k.error(`CUA provider "${c}" threw an error`,f),{status:"error",error:f.message??"CUA provider failed"}}}var fl,Be=w(()=>{"use strict";li();di();Fe();Q();ye();fl={google:ha,openai:wa}});import{zodToJsonSchema as bl}from"zod-to-json-schema";function hi(e){let t=bl(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 ot(t),t}function ot(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))ot(i)}e.type==="array"&&e.items&&ot(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(ot);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&ot(i)}}var rt=w(()=>{"use strict"});var bn,mi=w(()=>{"use strict";rt();bn=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:hi(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:hi(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:hi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function yl(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 xl(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=yl(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
17
17
 
18
- `}),t.push(...o)}return t}function pi(e,t=Sa){if(t){let i=vl(e);if(i.length===0)return[];let n={type:"text",text:`
18
+ `}),t.push(...o)}return t}function pi(e,t=ka){if(t){let i=xl(e);if(i.length===0)return[];let n={type:"text",text:`
19
19
 
20
20
  <retrieved_knowledge>
21
21
 
@@ -35,7 +35,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
35
35
 
36
36
  </retrieved_knowledge>
37
37
 
38
- `}]:[]}}function Ea(e,t=Sa){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Sa,st=w(()=>{"use strict";Sa=!1});function _l(){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 Ta(e){return`# Your Role
38
+ `}]:[]}}function Sa(e,t=ka){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var ka,st=w(()=>{"use strict";ka=!1});function vl(){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 Ea(e){return`# Your Role
39
39
  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.
40
40
 
41
41
  # Rules
@@ -95,11 +95,11 @@ Example of empty action when the target element is not on the page, or the instr
95
95
  "action": {}, // empty action object to indicate the instruction cannot be completed
96
96
  "completes_instruction": false
97
97
  }
98
- `}function kl(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
98
+ `}function _l(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
99
99
  Feedback: ${n}
100
100
  `}),`## Additional context
101
101
  You just executed following steps in order:
102
- ${t}`}function Aa(e,t,i,n,a,o,r=!1,s=_l(),l=!1,d){let c=[],u=`
102
+ ${t}`}function Ta(e,t,i,n,a,o,r=!1,s=vl(),l=!1,d){let c=[],u=`
103
103
  # Instruction
104
104
  "${t}"
105
105
 
@@ -121,7 +121,7 @@ ${e.tabsText}
121
121
  ${e.elementsText}
122
122
  `;if(c.push({type:"text",text:u}),r&&e.slicedScreenshotsBase64)for(let f 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:f});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 f=pi(a,l);c.push(...f)}let m="";if(m+=`
123
123
  Current local time is ${s}.
124
- `,i&&Object.keys(i).length>0){let f=[];for(let h of Object.keys(i))if(d?.has(h))f.push(` - ${h}: [SENSITIVE - value hidden]`);else{let x=i[h],y=typeof x=="string"?x:JSON.stringify(x);f.push(` - ${h}: "${y}"`)}m+=`
124
+ `,i&&Object.keys(i).length>0){let f=[];for(let h of Object.keys(i))if(d?.has(h))f.push(` - ${h}: [SENSITIVE - value hidden]`);else{let x=i[h],b=typeof x=="string"?x:JSON.stringify(x);f.push(` - ${h}: "${b}"`)}m+=`
125
125
  ## Available Data Placeholders
126
126
  The following placeholders are available for use in your actions:
127
127
  ${f.join(`
@@ -132,25 +132,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
132
132
  - Do NOT use the actual value directly
133
133
  - The values shown are for context only to help you understand what data is available
134
134
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
135
- `}if(n&&n.length>0){let f=kl(n);m+=`
135
+ `}if(n&&n.length>0){let f=_l(n);m+=`
136
136
  `+f}return m+=`
137
137
  Based on the above information, please determine the right action to accomplish the task.
138
- `,c.push({type:"text",text:m}),c}var gi=w(()=>{"use strict";st()});function fi(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 lt=w(()=>{"use strict"});async function Sl(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(`
138
+ `,c.push({type:"text",text:m}),c}var gi=w(()=>{"use strict";st()});function fi(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 lt=w(()=>{"use strict"});async function kl(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
139
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
140
- `:"",tabsText:a}}async function El(e,t){let{currentTabText:i,tabsText:n}=await Sl(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function wi(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 El(i,u);return c&&(m.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:m}}var ct=w(()=>{"use strict"});import{z as se}from"zod";var xn,H,xe=w(()=>{"use strict";xn=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])}},H=new xn});async function W(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function Tl(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 Al(e,t=!0){try{let i=Tl(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(`
140
+ `:"",tabsText:a}}async function Sl(e,t){let{currentTabText:i,tabsText:n}=await kl(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function wi(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 Sl(i,u);return c&&(m.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:m}}var ct=w(()=>{"use strict"});import{z as se}from"zod";var yn,H,xe=w(()=>{"use strict";yn=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])}},H=new yn});async function W(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function El(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 Tl(e,t=!0){try{let i=El(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
141
  `)&&(s=o.split(`
142
- `)[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 $l(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 Al(e,!1)}function $a(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=$l(o);g.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function N(e,t){let i=null,n=$a(t);return t.xpath&&(i=await gn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var G=w(()=>{"use strict";Oe();F()});import{generateText as Ml,Output as Il}from"ai";import{z as bi}from"zod";function Pl(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 Cl(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 Ol(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=Cl(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 Ma(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(z=>(k.log(`Failed to retrieve knowledges: ${z.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),m=a.isActionIntentFilteringEnabled(),f=m?Pl(e):"all";m&&f!=="all"&&k.log(`Action intent filtering: detected '${f}' intent from statement`);let{screenshotBase64:h,domState:x,pageContext:y}=await wi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:f});t.domState=x;let p=new yn(H).getToolDefinitions().map(z=>{let Re=z.function;return`${Re.name}: ${Re.description}
142
+ `)[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 Al(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 Tl(e,!1)}function Aa(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=Al(o);p.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function D(e,t){let i=null,n=Aa(t);return t.xpath&&(i=await gn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var G=w(()=>{"use strict";Oe();F()});import{generateText as $l,Output as Ml}from"ai";import{z as bi}from"zod";function Il(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 Pl(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 Cl(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=Pl(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 $a(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(z=>(k.log(`Failed to retrieve knowledges: ${z.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),m=a.isActionIntentFilteringEnabled(),f=m?Il(e):"all";m&&f!=="all"&&k.log(`Action intent filtering: detected '${f}' intent from statement`);let{screenshotBase64:h,domState:x,pageContext:b}=await wi(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:f});t.domState=x;let g=new bn(H).getToolDefinitions().map(z=>{let Re=z.function;return`${Re.name}: ${Re.description}
143
143
  Parameters: ${JSON.stringify(Re.parameters,null,2)}`}).join(`
144
144
 
145
- `),b=Ta(p),E=await s,T=Aa(y,e,t.variables,t.executionHistory,E.length>0?E:void 0,h,l,void 0,c,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(z=>{z.role==="user"?A.push({role:"user",content:z.content}):z.role==="assistant"&&A.push({role:"assistant",content:z.content})}),A.push({role:"user",content:T});let I=Ol(A),D=H.buildActionUnionSchema(),R=bi.object({thought:bi.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:bi.string().describe("Detailed description of the action to be performed").optional().default(""),action:D,completes_instruction:bi.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),O=Array.isArray(T)?T.filter(z=>z.type==="image").length:0,K=be(o,O),J=await Ml({model:we(o),system:b,messages:A,temperature:r,output:Il.object({schema:R}),providerOptions:K}),me=J.reasoningText;g.info(`Action Generation Reasoning: ${me}`);let j=J.output,V=JSON.stringify(j,null,2);g.info(`Generate Action Raw Output: ${V}`);let pe=[],Ce=fi(J.usage,o);Ce&&pe.push(Ce);let Se={systemPrompt:b,userPrompt:I,rawLlmResponse:V,tokenUsages:pe},Ee=j.thought||"",Te=j.description||"",U=j.action||{},X=j.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Ee||Te||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Se};let Y=Object.keys(U)[0];if(Y==="done")return{status:"error",reasoning:Ee||Te||"Task marked as done",goalAccomplished:X,error:"Agent indicated task is done without generating an action",debugInfo:Se};if(Y==="perform_accurate_operation")return await Ue(e,t,i);if(!X){let z="Can't complete the instruction in one action";return{status:"error",reasoning:Ee||Te||z,goalAccomplished:!1,error:z,debugInfo:Se}}let re=U[Y]||{},ia={};if(typeof re.element_index=="number"){let z=re.element_index;if(z<0)return{status:"error",reasoning:Ee||Te||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Se};let Re=x.selectorMap.get(z);Re&&(ia=await N(n,Re))}let na=Te;return Y==="verify"&&(na=e,re.statement=e),{status:"success",actionEntity:{...ia,action_description:na||Ee||`${Y}(${JSON.stringify(re)})`,action_data:{action_name:Y,kwargs:re}},reasoning:Ee||Te,goalAccomplished:X,debugInfo:Se}}var yi=w(()=>{"use strict";Be();mi();gi();lt();ct();xe();Q();ye();G();F()});import{generateText as Nl,Output as Dl}from"ai";import{z as xi}from"zod";function Ll(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 vn(e,t,i={}){return i.usePureVision?Ue(e,t,i):Ma(e,t,i)}function Fl(){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 Hl(){return`# Role
145
+ `),y=Ea(g),E=await s,T=Ta(b,e,t.variables,t.executionHistory,E.length>0?E:void 0,h,l,void 0,c,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(z=>{z.role==="user"?A.push({role:"user",content:z.content}):z.role==="assistant"&&A.push({role:"assistant",content:z.content})}),A.push({role:"user",content:T});let I=Cl(A),N=H.buildActionUnionSchema(),R=bi.object({thought:bi.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:bi.string().describe("Detailed description of the action to be performed").optional().default(""),action:N,completes_instruction:bi.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),O=Array.isArray(T)?T.filter(z=>z.type==="image").length:0,K=be(o,O),J=await $l({model:we(o),system:y,messages:A,temperature:r,output:Ml.object({schema:R}),providerOptions:K}),me=J.reasoningText;p.info(`Action Generation Reasoning: ${me}`);let j=J.output,V=JSON.stringify(j,null,2);p.info(`Generate Action Raw Output: ${V}`);let pe=[],Ce=fi(J.usage,o);Ce&&pe.push(Ce);let Se={systemPrompt:y,userPrompt:I,rawLlmResponse:V,tokenUsages:pe},Ee=j.thought||"",Te=j.description||"",U=j.action||{},X=j.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Ee||Te||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Se};let Y=Object.keys(U)[0];if(Y==="done")return{status:"error",reasoning:Ee||Te||"Task marked as done",goalAccomplished:X,error:"Agent indicated task is done without generating an action",debugInfo:Se};if(Y==="perform_accurate_operation")return await Ue(e,t,i);if(!X){let z="Can't complete the instruction in one action";return{status:"error",reasoning:Ee||Te||z,goalAccomplished:!1,error:z,debugInfo:Se}}let re=U[Y]||{},ta={};if(typeof re.element_index=="number"){let z=re.element_index;if(z<0)return{status:"error",reasoning:Ee||Te||"No action generated",goalAccomplished:X,error:"Agent did not generate any action",debugInfo:Se};let Re=x.selectorMap.get(z);Re&&(ta=await D(n,Re))}let ia=Te;return Y==="verify"&&(ia=e,re.statement=e),{status:"success",actionEntity:{...ta,action_description:ia||Ee||`${Y}(${JSON.stringify(re)})`,action_data:{action_name:Y,kwargs:re}},reasoning:Ee||Te,goalAccomplished:X,debugInfo:Se}}var yi=w(()=>{"use strict";Be();mi();gi();lt();ct();xe();Q();ye();G();F()});import{generateText as Ol,Output as Nl}from"ai";import{z as xi}from"zod";function Dl(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 xn(e,t,i={}){return i.usePureVision?Ue(e,t,i):$a(e,t,i)}function Rl(){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 Fl(){return`# Role
146
146
  You are an experienced QA person for web applications.
147
147
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
148
- `}async function Ia(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:f,pageContext:h}=await wi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=f;let x="";a&&a.length>0&&(x=`
148
+ `}async function Ma(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:f,pageContext:h}=await wi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=f;let x="";a&&a.length>0&&(x=`
149
149
  # Previous actions in this session:
150
150
  ${a.map(([U,X],Y)=>`${Y+1}. Action: ${U}
151
151
  Result: ${X}`).join(`
152
152
  `)}
153
- `);let{dateString:y,timeString:p}=Fl(),b=`
153
+ `);let{dateString:b,timeString:g}=Rl(),y=`
154
154
  # User statement
155
155
  "${e}"
156
156
 
@@ -177,14 +177,14 @@ ${U.join(`
177
177
  ${E}
178
178
  ${x}
179
179
 
180
- Today is ${y}. Current local time is ${p}.
180
+ Today is ${b}. Current local time is ${g}.
181
181
  Based on the above information, please determine if the statement is true.
182
- `,A=await t.agentServices.retrieveKnowledges(e),I=[{type:"text",text:b}],D=0;if(r&&m&&m.length>0)for(let U of m)I.push({type:"image",image:U}),D++;else I.push({type:"image",image:u}),D=1;if(A&&A.length>0){let U=pi(A,l);I.push(...U)}I.push({type:"text",text:T});let R=A?Ea(A,l):0,O=D+R,K=be(o,O),J=Hl(),me=await Nl({model:we(o),system:J,messages:[{role:"user",content:I}],output:Dl.object({schema:Rl}),temperature:0,providerOptions:K}),{conclusion:j,explanation:V}=me.output,pe=JSON.stringify(me.output,null,2),Ce=[],Se=fi(me.usage,o);Se&&Ce.push(Se);let Ee=[{role:"user",content:I.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let X=U.image,Y=Ll(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]"}})}],Te={systemPrompt:J,userPrompt:Ee,rawLlmResponse:pe,screenshotWithSom:u,tokenUsages:Ce,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:c};return{success:j==="true",explanation:V,debugInfo:Te}}catch(r){return{success:!1,error:r.message}}}var Rl,vi=w(()=>{"use strict";yi();Be();lt();ct();st();ye();Rl=xi.object({screenshotDescription:xi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
182
+ `,A=await t.agentServices.retrieveKnowledges(e),I=[{type:"text",text:y}],N=0;if(r&&m&&m.length>0)for(let U of m)I.push({type:"image",image:U}),N++;else I.push({type:"image",image:u}),N=1;if(A&&A.length>0){let U=pi(A,l);I.push(...U)}I.push({type:"text",text:T});let R=A?Sa(A,l):0,O=N+R,K=be(o,O),J=Fl(),me=await Ol({model:we(o),system:J,messages:[{role:"user",content:I}],output:Nl.object({schema:Ll}),temperature:0,providerOptions:K}),{conclusion:j,explanation:V}=me.output,pe=JSON.stringify(me.output,null,2),Ce=[],Se=fi(me.usage,o);Se&&Ce.push(Se);let Ee=[{role:"user",content:I.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let X=U.image,Y=Dl(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]"}})}],Te={systemPrompt:J,userPrompt:Ee,rawLlmResponse:pe,screenshotWithSom:u,tokenUsages:Ce,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:c};return{success:j==="true",explanation:V,debugInfo:Te}}catch(r){return{success:!1,error:r.message}}}var Ll,vi=w(()=>{"use strict";yi();Be();lt();ct();st();ye();Ll=xi.object({screenshotDescription:xi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
183
183
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
184
184
  [45] A modal dialog titled "Confirmation",
185
- in the center of the screen`),explanation:xi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:xi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Ca(){let{default:e}=await import("sharp");return e}async function _n(e,t){let i=await Ca(),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=(h,x)=>{let y=i(e).extract({left:h,top:0,width:x,height:r});return t?.resize&&(y=y.resize(Pa,Pa)),y.png().toBuffer()},[u,m,f]=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,f]}async function Oa(e){let t=(await Ca())(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 Pa,dt=w(()=>{"use strict";Pa=768});var kn,Sn,En,Tn,ut=w(()=>{"use strict";kn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),Sn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),En=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],Tn=500});function Na(e,t){return e.length>t?e.slice(0,t)+"...":e}var ht=w(()=>{"use strict"});var Da,La,mt=w(()=>{"use strict";Da=["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"],La={"react-flow__(\\S+)":"$1"}});var Ra,pt,ve,Ge=w(()=>{"use strict";ht();mt();Ra=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},pt=class extends Ra{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}},ve=class _i extends Ra{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,m=null,f=null,h=null,x=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=f,this.pageCoordinates=h,this.viewportInfo=x,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof _i&&a!==this&&a.highlightIndex!==null)){if(a instanceof pt)i.push(a.text);else if(a instanceof _i)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
186
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??Da,n=t?.includeClassesWithRename??La,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof _i){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let p={};for(let T of Object.keys(r.attributes))if(i.includes(T)){let A=r.attributes[T].trim();A!==""&&(p[T]=A)}let b=i.filter(T=>T in p);if(b.length>1){let T=new Set,A={};for(let I of b){let D=p[I];D.length>5&&(D in A?T.add(I):A[D]=I)}for(let I of T)delete p[I]}r.tagName===p.role&&delete p.role;let E=["aria-label","placeholder","title"];for(let T of E)p[T]&&p[T].trim().toLowerCase()===c.trim().toLowerCase()&&delete p[T];Object.keys(p).length>0&&(u=Object.entries(p).map(([T,A])=>`${T}=${Na(A,200)}`).join(" "))}let m=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,f=[];if(Object.keys(n).length>0&&r.attributes.class){let p=r.attributes.class.split(/\s+/);for(let b of p)for(let[E,T]of Object.entries(n))try{let A=new RegExp(`^${E}$`);if(b.match(A)){let I=b.replace(A,T);I&&f.push(I);break}}catch{continue}}let h=r.isScrollable?" (SCROLLABLE)":"",x=r.markAsClickable?" (CLICKABLE)":"",y=`${d}${m}${h}${x}<${r.tagName}`;if(f.length>0&&(y+=` ${f.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 pt){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${d}${r.text}`)}};return o(this,0),a.join(`
187
- `)}}});function Bl(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Wl,Ul,$e,Ne=w(()=>{"use strict";dt();ut();Ge();F();Wl=`(
185
+ in the center of the screen`),explanation:xi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:xi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Pa(){let{default:e}=await import("sharp");return e}async function vn(e,t){let i=await Pa(),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=(h,x)=>{let b=i(e).extract({left:h,top:0,width:x,height:r});return t?.resize&&(b=b.resize(Ia,Ia)),b.png().toBuffer()},[u,m,f]=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,f]}async function Ca(e){let t=(await Pa())(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 Ia,dt=w(()=>{"use strict";Ia=768});var _n,kn,Sn,En,ut=w(()=>{"use strict";_n=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),kn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Sn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],En=500});function Oa(e,t){return e.length>t?e.slice(0,t)+"...":e}var ht=w(()=>{"use strict"});var Na,Da,mt=w(()=>{"use strict";Na=["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"],Da={"react-flow__(\\S+)":"$1"}});var La,pt,ve,Ge=w(()=>{"use strict";ht();mt();La=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},pt=class extends La{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}},ve=class _i extends La{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,m=null,f=null,h=null,x=null,b=[],g=null){super(o,g),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=f,this.pageCoordinates=h,this.viewportInfo=x,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof _i&&a!==this&&a.highlightIndex!==null)){if(a instanceof pt)i.push(a.text);else if(a instanceof _i)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
186
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??Na,n=t?.includeClassesWithRename??Da,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof _i){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let g={};for(let T of Object.keys(r.attributes))if(i.includes(T)){let A=r.attributes[T].trim();A!==""&&(g[T]=A)}let y=i.filter(T=>T in g);if(y.length>1){let T=new Set,A={};for(let I of y){let N=g[I];N.length>5&&(N in A?T.add(I):A[N]=I)}for(let I of T)delete g[I]}r.tagName===g.role&&delete g.role;let E=["aria-label","placeholder","title"];for(let T of E)g[T]&&g[T].trim().toLowerCase()===c.trim().toLowerCase()&&delete g[T];Object.keys(g).length>0&&(u=Object.entries(g).map(([T,A])=>`${T}=${Oa(A,200)}`).join(" "))}let m=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,f=[];if(Object.keys(n).length>0&&r.attributes.class){let g=r.attributes.class.split(/\s+/);for(let y of g)for(let[E,T]of Object.entries(n))try{let A=new RegExp(`^${E}$`);if(y.match(A)){let I=y.replace(A,T);I&&f.push(I);break}}catch{continue}}let h=r.isScrollable?" (SCROLLABLE)":"",x=r.markAsClickable?" (CLICKABLE)":"",b=`${d}${m}${h}${x}<${r.tagName}`;if(f.length>0&&(b+=` ${f.join(" ")}`),u&&(b+=` ${u}`),c){let g=c.trim();u||(b+=" "),b+=`>${g}`}else u||(b+=" ");b+=" />",a.push(b)}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 pt){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${d}${r.text}`)}};return o(this,0),a.join(`
187
+ `)}}});function Ul(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Hl,Wl,$e,Ne=w(()=>{"use strict";dt();ut();Ge();F();Hl=`(
188
188
  args = {
189
189
  doHighlightElements: true,
190
190
  focusHighlightIndex: -1,
@@ -1952,7 +1952,7 @@ Based on the above information, please determine if the statement is true.
1952
1952
 
1953
1953
  return { rootId, map: DOM_HASH_MAP };
1954
1954
  }
1955
- `,Ul=`((args = {
1955
+ `,Wl=`((args = {
1956
1956
  doHighlightElements: true,
1957
1957
  focusHighlightIndex: -1,
1958
1958
  viewportExpansion: 0,
@@ -4000,7 +4000,7 @@ Based on the above information, please determine if the statement is true.
4000
4000
  // Return element data from boxes phase for use in labels phase
4001
4001
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4002
4002
  };
4003
- })`;$e=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let 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={}){g.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Ul:Wl}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 _n(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){g.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){g.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});g.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(p=>{if(p.ignored)return!1;let b=p.role?.value;return!(!b||!kn.has(b)||p.properties?.find(E=>E.name==="disabled")?.value?.value||!p.backendDOMNodeId)});g.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(p=>p.role?.value==="button");g.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let p of r){let b=[];p.ignored&&b.push("ignored"),p.backendDOMNodeId||b.push("no-backendDOMNodeId"),p.properties?.find(E=>E.name==="disabled")?.value?.value&&b.push("disabled"),g.debug(` - "${p.name?.value||"(no name)"}" ${b.length>0?`[SKIPPED: ${b.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++);g.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){g.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let p of m){let b=[];p.isVisible||b.push("not-visible"),p.isInViewport||b.push("not-in-viewport"),p.isTopElement||b.push("not-top-element"),p.boundingRect||b.push("no-bounding-rect"),g.debug(` - <${p.tagName}> "${p.axNode.name?.value||""}" [${b.join(", ")}]`)}}g.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:f,highlightIndex:h}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&h>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,h)),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 x=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await _n(i,{resize:t.resizeSlicedScreenshots})).map(p=>p.toString("base64"))}catch(p){g.warn("Failed to slice screenshot:",p)}return{domState:f,screenshotBase64:x,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() {
4003
+ })`;$e=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let 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={}){p.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Wl:Hl}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 vn(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){p.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){p.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});p.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(g=>{if(g.ignored)return!1;let y=g.role?.value;return!(!y||!_n.has(y)||g.properties?.find(E=>E.name==="disabled")?.value?.value||!g.backendDOMNodeId)});p.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(g=>g.role?.value==="button");p.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let g of r){let y=[];g.ignored&&y.push("ignored"),g.backendDOMNodeId||y.push("no-backendDOMNodeId"),g.properties?.find(E=>E.name==="disabled")?.value?.value&&y.push("disabled"),p.debug(` - "${g.name?.value||"(no name)"}" ${y.length>0?`[SKIPPED: ${y.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(g=>g.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let g of l)s.has(g.backendNodeId)||(o.push({nodeId:`synthetic-${g.backendNodeId}`,ignored:!1,backendDOMNodeId:g.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:g.eventTypes.join(",")}}]}),s.add(g.backendNodeId),d++);p.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${o.length})`);let c=await this.resolveAXNodesToDOM(n,o),u=c.filter(g=>g.isVisible&&g.isInViewport&&g.isTopElement&&g.boundingRect),m=c.filter(g=>!(g.isVisible&&g.isInViewport&&g.isTopElement&&g.boundingRect));if(m.length>0){p.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let g of m){let y=[];g.isVisible||y.push("not-visible"),g.isInViewport||y.push("not-in-viewport"),g.isTopElement||y.push("not-top-element"),g.boundingRect||y.push("no-bounding-rect"),p.debug(` - <${g.tagName}> "${g.axNode.name?.value||""}" [${y.join(", ")}]`)}}p.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:f,highlightIndex:h}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&h>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,h)),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 x=i.toString("base64"),b;if(t.useSlicedScreenshots)try{b=(await vn(i,{resize:t.resizeSlicedScreenshots})).map(g=>g.toString("base64"))}catch(g){p.warn("Failed to slice screenshot:",g)}return{domState:f,screenshotBase64:x,screenshot:i,slicedScreenshotsBase64:b}}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
4004
  const el = this;
4005
4005
  const rect = el.getBoundingClientRect();
4006
4006
  const rects = el.getClientRects();
@@ -4084,34 +4084,34 @@ Based on the above information, please determine if the statement is true.
4084
4084
  } : null,
4085
4085
  clientRects: clientRectsArray
4086
4086
  };
4087
- }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){g.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=Tn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=En.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});g.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=>Sn.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{}g.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){g.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new ve("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 ve(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 pt(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 f=Math.max(0,c.y-16),h=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${f}px`,m.style.left=`${h}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),g.debug("\u2705 Highlights removed from page")}catch(n){g.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(Bl(e.url()))return[new ve("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};g.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:D,argsObj:R})=>new Function("return "+D)()(R),{code:this.jsCode,argsObj:y});g.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let b=await e.screenshot({type:"png",fullPage:!1});g.debug("\u{1F4F8} Captured screenshot with bounding boxes");let E=performance.now(),T=await Oa(b);u=T.pixels;let A=Math.round(performance.now()-E);g.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${T.width}x${T.height}) in ${A}ms`);let I={...d,phase:"labels",grayscaleImage:u,elementData:p.elementData};c=await e.evaluate(({code:D,argsObj:R})=>new Function("return "+D)()(R),{code:this.jsCode,argsObj:I}),c.map=p.map,c.rootId=p.rootId,c.highlightCount=p.highlightCount,c.perfMetrics=p.perfMetrics,g.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){g.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),u=null;let p={...d,grayscaleImage:null};c=await e.evaluate(({code:b,argsObj:E})=>new Function("return "+b)()(E),{code:this.jsCode,argsObj:p}),g.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}),g.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw g.error("Error evaluating JavaScript:",y.message),y}if(!c||typeof c!="object")throw g.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw g.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){g.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let y={...d,actionIntent:"all"};c=await e.evaluate(({code:p,argsObj:b})=>new Function("return "+p)()(b),{code:this.jsCode,argsObj:y})}let m=Object.entries(c.map).filter(([,y])=>y.tagName==="iframe");g.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[y,p]of m){let b=p;g.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${b.attributes?.src} inaccessibleFrame=${b.inaccessibleFrame}`)}let f=e.frames();g.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${f.length}`);for(let y of f)g.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let h=[];for(let[y,p]of Object.entries(c.map)){let b=p;this.shouldProcessWithPlaywrightFrameFallback(b,o)&&h.push({nodeId:y,src:b.attributes.src})}if(g.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${h.length}`),h.length>0){g.debug(`\u{1F50C} Found ${h.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let p of Object.values(c.map)){let b=p;b.highlightIndex!=null&&(y=Math.max(y,b.highlightIndex))}g.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let p=0;p<h.length;p++){let{nodeId:b,src:E}=h[p];g.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${E}`);let T=R=>{try{let O=new URL(R);if(O.protocol==="chrome-extension:"&&O.hostname)return`chrome-extension://${O.hostname}`;let K=O.origin;return K==="null"?null:K}catch{return null}},A=T(E);g.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let I=null,D=e.frames().find(R=>{let O=R.url();if(O===E)return I="exact",g.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${O}`),!0;let K=T(O);return g.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${O} origin=${K??"null"} vs srcOrigin=${A??"null"}`),A&&K===A?(I="origin",g.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${O}`),!0):!1});if(!D){g.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${E}`),g.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(R=>R.url()).join(", ")}`);continue}g.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${E} (frame url: ${D.url()})`);try{let R={...d,initialHighlightIndex:y+1,domTreeRoot:"body"};g.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${R.initialHighlightIndex}`);let O=await D.evaluate(({code:j,argsObj:V})=>new Function("return "+j)()(V),{code:this.jsCode,argsObj:R});if(g.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(O?.map??{}).length} rootId=${O?.rootId}`),!O?.map||!O.rootId){g.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let K=Object.values(O.map).filter(j=>j.highlightIndex!=null);g.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${K.length}`);for(let j of K){let V=j;g.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let j of Object.values(O.map)){let V=j;V.highlightIndex!=null&&(y=Math.max(y,V.highlightIndex))}let J=`ext_${p}_`;for(let[j,V]of Object.entries(O.map)){let pe={...V};pe.children&&(pe.children=pe.children.map(Ce=>`${J}${Ce}`)),c.map[`${J}${j}`]=pe}let me=c.map[b];me?(me.children=[...me.children||[],`${J}${O.rootId}`],g.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${b}`)):g.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${b} not found in map`),g.debug(`\u2705 Merged fallback iframe content from: ${E}`)}catch(R){g.warn(`Failed to process fallback iframe ${E}:`,R)}}}if(c&&c.perfMetrics){let y=c.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(c.map)for(let E of Object.values(c.map))typeof E=="object"&&E!==null&&E.isInteractive&&p++;let b=e.url().length>50?e.url().slice(0,50)+"...":e.url();g.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${b} interactive=${p}/${y}`)}g.debug("\u{1F504} Starting TypeScript DOM tree construction...");let x=await this.constructDomTree(c);return g.debug("\u2705 TypeScript DOM tree construction completed"),x}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 ve&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof ve)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 ve))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 pt(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 ve(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 Fa,ki=w(()=>{"use strict";L();M();Fa=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=C(e,t),r=P(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=Ae(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=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as Gl}from"zod";var Ha,km,Si=w(()=>{"use strict";Ha=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},km=Gl.object({})});var Wa,Ei=w(()=>{"use strict";L();M();Wa=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 Ua,Ti=w(()=>{"use strict";Ua=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",`
4087
+ }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){p.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=En){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Sn.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});p.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=>kn.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{}p.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){p.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new ve("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 ve(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 pt(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 f=Math.max(0,c.y-16),h=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));m.style.top=`${f}px`,m.style.left=`${h}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),p.debug("\u2705 Highlights removed from page")}catch(n){p.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(Ul(e.url()))return[new ve("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};p.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let b={...d,phase:"boxes",grayscaleImage:null},g=await e.evaluate(({code:N,argsObj:R})=>new Function("return "+N)()(R),{code:this.jsCode,argsObj:b});p.debug(`\u{1F4E6} Phase 1: Drew ${g.elementData?.length||0} bounding boxes`);let y=await e.screenshot({type:"png",fullPage:!1});p.debug("\u{1F4F8} Captured screenshot with bounding boxes");let E=performance.now(),T=await Ca(y);u=T.pixels;let A=Math.round(performance.now()-E);p.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${T.width}x${T.height}) in ${A}ms`);let I={...d,phase:"labels",grayscaleImage:u,elementData:g.elementData};c=await e.evaluate(({code:N,argsObj:R})=>new Function("return "+N)()(R),{code:this.jsCode,argsObj:I}),c.map=g.map,c.rootId=g.rootId,c.highlightCount=g.highlightCount,c.perfMetrics=g.perfMetrics,p.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){p.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),u=null;let g={...d,grayscaleImage:null};c=await e.evaluate(({code:y,argsObj:E})=>new Function("return "+y)()(E),{code:this.jsCode,argsObj:g}),p.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:b,argsObj:g})=>new Function("return "+b)()(g),{code:this.jsCode,argsObj:d}),p.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw p.error("Error evaluating JavaScript:",b.message),b}if(!c||typeof c!="object")throw p.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw p.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){p.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let b={...d,actionIntent:"all"};c=await e.evaluate(({code:g,argsObj:y})=>new Function("return "+g)()(y),{code:this.jsCode,argsObj:b})}let m=Object.entries(c.map).filter(([,b])=>b.tagName==="iframe");p.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[b,g]of m){let y=g;p.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${y.attributes?.src} inaccessibleFrame=${y.inaccessibleFrame}`)}let f=e.frames();p.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${f.length}`);for(let b of f)p.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let h=[];for(let[b,g]of Object.entries(c.map)){let y=g;this.shouldProcessWithPlaywrightFrameFallback(y,o)&&h.push({nodeId:b,src:y.attributes.src})}if(p.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${h.length}`),h.length>0){p.debug(`\u{1F50C} Found ${h.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let g of Object.values(c.map)){let y=g;y.highlightIndex!=null&&(b=Math.max(b,y.highlightIndex))}p.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let g=0;g<h.length;g++){let{nodeId:y,src:E}=h[g];p.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${g}]: ${E}`);let T=R=>{try{let O=new URL(R);if(O.protocol==="chrome-extension:"&&O.hostname)return`chrome-extension://${O.hostname}`;let K=O.origin;return K==="null"?null:K}catch{return null}},A=T(E);p.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let I=null,N=e.frames().find(R=>{let O=R.url();if(O===E)return I="exact",p.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${O}`),!0;let K=T(O);return p.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${O} origin=${K??"null"} vs srcOrigin=${A??"null"}`),A&&K===A?(I="origin",p.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${O}`),!0):!1});if(!N){p.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${E}`),p.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(R=>R.url()).join(", ")}`);continue}p.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${E} (frame url: ${N.url()})`);try{let R={...d,initialHighlightIndex:b+1,domTreeRoot:"body"};p.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${R.initialHighlightIndex}`);let O=await N.evaluate(({code:j,argsObj:V})=>new Function("return "+j)()(V),{code:this.jsCode,argsObj:R});if(p.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(O?.map??{}).length} rootId=${O?.rootId}`),!O?.map||!O.rootId){p.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let K=Object.values(O.map).filter(j=>j.highlightIndex!=null);p.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${K.length}`);for(let j of K){let V=j;p.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let j of Object.values(O.map)){let V=j;V.highlightIndex!=null&&(b=Math.max(b,V.highlightIndex))}let J=`ext_${g}_`;for(let[j,V]of Object.entries(O.map)){let pe={...V};pe.children&&(pe.children=pe.children.map(Ce=>`${J}${Ce}`)),c.map[`${J}${j}`]=pe}let me=c.map[y];me?(me.children=[...me.children||[],`${J}${O.rootId}`],p.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${y}`)):p.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${y} not found in map`),p.debug(`\u2705 Merged fallback iframe content from: ${E}`)}catch(R){p.warn(`Failed to process fallback iframe ${E}:`,R)}}}if(c&&c.perfMetrics){let b=c.perfMetrics.nodeMetrics?.totalNodes??0,g=0;if(c.map)for(let E of Object.values(c.map))typeof E=="object"&&E!==null&&E.isInteractive&&g++;let y=e.url().length>50?e.url().slice(0,50)+"...":e.url();p.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${y} interactive=${g}/${b}`)}p.debug("\u{1F504} Starting TypeScript DOM tree construction...");let x=await this.constructDomTree(c);return p.debug("\u2705 TypeScript DOM tree construction completed"),x}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 ve&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof ve)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 ve))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 pt(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 ve(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 Ra,ki=w(()=>{"use strict";L();M();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.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=C(e,t),r=P(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=Ae(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=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});import{z as Bl}from"zod";var Fa,_m,Si=w(()=>{"use strict";Fa=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},_m=Bl.object({})});var Ha,Ei=w(()=>{"use strict";L();M();Ha=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 Wa,Ti=w(()=>{"use strict";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.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
4088
  return (async () => {
4089
4089
  ${a}
4090
4090
  })();
4091
4091
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4092
- `):["// Skipping js_action: missing code"]}}});import{z as Ba}from"zod";var Ga,Cm,Ai=w(()=>{"use strict";Ga=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",`
4092
+ `):["// Skipping js_action: missing code"]}}});import{z as Ua}from"zod";var Ba,Pm,Ai=w(()=>{"use strict";Ba=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
4093
  return (async () => {
4094
4094
  ${a}
4095
4095
  })();
4096
4096
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4097
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Cm=Ba.object({code:Ba.string().describe("JavaScript code to execute in the browser context")})});var ja,$i=w(()=>{"use strict";L();M();ja=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 Ka,Mi=w(()=>{"use strict";L();M();Ka=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 za,Ii=w(()=>{"use strict";L();M();za=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=C(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let 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,f=u+o.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,f,{steps:n}):await e.mouse.move(m,f),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 Va,Pi=w(()=>{"use strict";Va=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",`
4097
+ `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Pm=Ua.object({code:Ua.string().describe("JavaScript code to execute in the browser context")})});var Ga,$i=w(()=>{"use strict";L();M();Ga=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 ja,Mi=w(()=>{"use strict";L();M();ja=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=C(e,t);if(a){await a.waitFor({state:"attached",timeout:P(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 Ka,Ii=w(()=>{"use strict";L();M();Ka=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=C(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let 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,f=u+o.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(m,f,{steps:n}):await e.mouse.move(m,f),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 za,Pi=w(()=>{"use strict";za=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
4098
  return (async () => {
4099
4099
  ${a}
4100
4100
  })();
4101
- `)(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(", ")})`}}});var Ci=w(()=>{"use strict";Ge()});var Xa,gt=w(()=>{"use strict";Xa=(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))(Xa||{})});var je={};et(je,{evaluateStatement:()=>Di,executeAction:()=>ft,executeStep:()=>Ni,generateActionStep:()=>Oi,runTask:()=>Li});var Ke=w(()=>{"use strict";wt();vi();yi();Be();li();di();ci();Fe();mi();gi();lt();ct();xe();rt();st();Ci();Ne();dt();ut();Ge();ht();mt();Q();ye();nt();at();He();G();Oe();F();Z();gt();L();ge()});import{z as Ya}from"zod";var Ja,Ip,Ri=w(()=>{"use strict";Ja=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(()=>(Ke(),je)),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});`]}},Ip=Ya.object({statement:Ya.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as qa}from"zod";var Za,Np,Fi=w(()=>{"use strict";Za=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(()=>(Ke(),je)),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"]}},Np=qa.object({statement:qa.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as An}from"zod";function eo(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:jl,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 Qa,jl,bt=w(()=>{"use strict";Qa=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(()=>(Ke(),je));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"]}},jl=An.object({condition:An.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:An.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Hi}from"zod";async function Kl(e,t,i,n){return{...await N(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function to(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 no(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:zl,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:to(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await Kl(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:to(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var io,zl,yt=w(()=>{"use strict";G();L();M();io=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=C(e,t),r=P(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},`),"});"]}};zl=Hi.object({element_index:Hi.number().int().describe("Index of the dropdown/select element"),option:Hi.string().describe("Option value, label, or index to select"),timeout_ms:Hi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Wi}from"zod";async function Vl(e,t,i,n){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function $n(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 oo(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4101
+ `)(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(", ")})`}}});var Ci=w(()=>{"use strict";Ge()});var Va,gt=w(()=>{"use strict";Va=(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))(Va||{})});var je={};et(je,{evaluateStatement:()=>Di,executeAction:()=>ft,executeStep:()=>Ni,generateActionStep:()=>Oi,runTask:()=>Li});var Ke=w(()=>{"use strict";wt();vi();yi();Be();li();di();ci();Fe();mi();gi();lt();ct();xe();rt();st();Ci();Ne();dt();ut();Ge();ht();mt();Q();ye();nt();He();at();G();Oe();F();Z();gt();L();ge()});import{z as Xa}from"zod";var Ya,Mp,Ri=w(()=>{"use strict";Ya=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(()=>(Ke(),je)),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});`]}},Mp=Xa.object({statement:Xa.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Ja}from"zod";var qa,Op,Fi=w(()=>{"use strict";qa=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(()=>(Ke(),je)),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"]}},Op=Ja.object({statement:Ja.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});import{z as Tn}from"zod";function Qa(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:Gl,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 Za,Gl,bt=w(()=>{"use strict";Za=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(()=>(Ke(),je));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"]}},Gl=Tn.object({condition:Tn.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Tn.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Hi}from"zod";async function jl(e,t,i,n){return{...await D(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function eo(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 io(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Kl,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:eo(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await jl(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:eo(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var to,Kl,yt=w(()=>{"use strict";G();L();M();to=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=C(e,t),r=P(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},`),"});"]}};Kl=Hi.object({element_index:Hi.number().int().describe("Index of the dropdown/select element"),option:Hi.string().describe("Option value, label, or index to select"),timeout_ms:Hi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Wi}from"zod";async function zl(e,t,i,n){return{...await D(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function An(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 ao(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
4102
 
4103
4103
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4104
4104
  Do NOT use it for custom/non-native date pickers
4105
4105
 
4106
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Xl,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:$n(`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:$n(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await Vl(`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:$n(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var ao,Xl,xt=w(()=>{"use strict";G();L();M();ao=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=C(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Xl=Wi.object({element_index:Wi.number().int().describe("Index of the native date picker input element"),date:Wi.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Wi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ro}from"zod";function lo(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Yl,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 so,Yl,vt=w(()=>{"use strict";so=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} } },`,"});"]}},Yl=ro.object({tab_index:ro.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import Jl from"fs";async function co(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){g.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Jl.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)g.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{g.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)}g.info(`Successfully uploaded ${i.length} file(s)`)}var _t=w(()=>{"use strict";F()});import{z as Me}from"zod";async function ql(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function uo(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 mo(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:Zl,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:uo(l||`Upload file to element ${a}`,{index:a,paths:o})};let c=await ql(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:uo(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var ho,Zl,rg,kt=w(()=>{"use strict";_t();G();L();M();ho=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=C(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 co(e,r,o,{useFileInput:s,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],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},`),"});"]}};Zl=Me.object({element_index:Me.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Me.string().describe("Paths to the files to upload"),timeout_ms:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});rg=Me.object({element_index:Me.number().int().describe("Index of the file input element"),paths:Me.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as po}from"zod";function fo(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Ql,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 go,Ql,St=w(()=>{"use strict";go=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});`]}},Ql=po.object({seconds:po.number().positive().describe("Number of seconds to wait")})});import{z as wo}from"zod";function yo(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:ec,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 bo,ec,Et=w(()=>{"use strict";bo=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} } },`,"});"]}},ec=wo.object({timeout_seconds:wo.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as xo}from"zod";function vo(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:tc,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 Mn,tc,Tt=w(()=>{"use strict";Mn=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)});`]}},tc=xo.object({keys:xo.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 ic}from"zod";function ko(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:nc,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 _o,nc,At=w(()=>{"use strict";L();M();_o=class{async execute(e,t){await e.reload({timeout:de}),await e.waitForLoadState("load",{timeout:de}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},nc=ic.object({})});import{z as In}from"zod";async function ac(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function So(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 Eo(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:oc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:So(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await ac("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:So(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Pn,oc,$t=w(()=>{"use strict";G();L();M();Pn=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};oc=In.object({element_index:In.number().int().describe("Index of the element to right-click"),timeout_ms:In.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Cn}from"zod";function Ao(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:rc,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 To,rc,Mt=w(()=>{"use strict";To=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)} } },`,"});"]}},rc=Cn.object({name:Cn.string().describe("Variable name to save"),value:Cn.string().describe("Value to save in the variable")})});import{z as On}from"zod";async function sc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function lc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function $o(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:cc,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 sc("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:lc(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var It,cc,Pt=w(()=>{"use strict";It=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)})');`]}};cc=On.object({down:On.boolean().describe("True to scroll down, False to scroll up"),num_pages:On.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Ct}from"zod";async function dc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Mo(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Po(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:uc,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 W(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Mo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await dc("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:Mo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Io,uc,Ot=w(()=>{"use strict";G();L();M();Io=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=C(e,t),s=P(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=Ae(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: ${P()} });`,`await page.mouse.wheel(${i}, ${n});`]}};uc=Ct.object({element_index:Ct.number().int().describe("Index of the scrollable element"),delta_x:Ct.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Ct.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Ct.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Co}from"zod";function No(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:hc,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 Oo,hc,Nt=w(()=>{"use strict";Oo=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();`]}},hc=Co.object({text:Co.string().describe("Text to scroll to on the page")})});import{z as Do}from"zod";async function mc(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Lo(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 Fo(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:pc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Lo(s||`Get options from dropdown ${a}`,{index:a})};let d=await mc(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:Lo(s||`Get options from dropdown ${a}`,{index:a})}}}})}var Ro,pc,Dt=w(()=>{"use strict";G();Ro=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(`
4106
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Vl,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:An(`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:An(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await zl(`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:An(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var no,Vl,xt=w(()=>{"use strict";G();L();M();no=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=C(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Vl=Wi.object({element_index:Wi.number().int().describe("Index of the native date picker input element"),date:Wi.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Wi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as oo}from"zod";function so(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Xl,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 ro,Xl,vt=w(()=>{"use strict";ro=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} } },`,"});"]}},Xl=oo.object({tab_index:oo.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import Yl from"fs";async function lo(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){p.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Yl.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)p.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{p.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)}p.info(`Successfully uploaded ${i.length} file(s)`)}var _t=w(()=>{"use strict";F()});import{z as Me}from"zod";async function Jl(e,t,i={},n){return{...await D(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function co(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 ho(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:ql,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:co(l||`Upload file to element ${a}`,{index:a,paths:o})};let c=await Jl(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:co(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var uo,ql,og,kt=w(()=>{"use strict";_t();G();L();M();uo=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=C(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 lo(e,r,o,{useFileInput:s,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],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},`),"});"]}};ql=Me.object({element_index:Me.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Me.string().describe("Paths to the files to upload"),timeout_ms:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});og=Me.object({element_index:Me.number().int().describe("Index of the file input element"),paths:Me.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as mo}from"zod";function go(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Zl,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 po,Zl,St=w(()=>{"use strict";po=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});`]}},Zl=mo.object({seconds:mo.number().positive().describe("Number of seconds to wait")})});import{z as fo}from"zod";function bo(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Ql,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 wo,Ql,Et=w(()=>{"use strict";wo=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} } },`,"});"]}},Ql=fo.object({timeout_seconds:fo.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as yo}from"zod";function xo(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:ec,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 $n,ec,Tt=w(()=>{"use strict";$n=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)});`]}},ec=yo.object({keys:yo.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 tc}from"zod";function _o(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:ic,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 vo,ic,At=w(()=>{"use strict";L();M();vo=class{async execute(e,t){await e.reload({timeout:de}),await e.waitForLoadState("load",{timeout:de}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},ic=tc.object({})});import{z as Mn}from"zod";async function nc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function ko(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 So(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:ac,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:ko(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await nc("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:ko(`Right-click element ${a}`,"right_click",{index:a})}}}})}var In,ac,$t=w(()=>{"use strict";G();L();M();In=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};ac=Mn.object({element_index:Mn.number().int().describe("Index of the element to right-click"),timeout_ms:Mn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Pn}from"zod";function To(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:oc,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 Eo,oc,Mt=w(()=>{"use strict";Eo=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)} } },`,"});"]}},oc=Pn.object({name:Pn.string().describe("Variable name to save"),value:Pn.string().describe("Value to save in the variable")})});import{z as Cn}from"zod";async function rc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function sc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Ao(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:lc,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 rc("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:sc(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var It,lc,Pt=w(()=>{"use strict";It=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)})');`]}};lc=Cn.object({down:Cn.boolean().describe("True to scroll down, False to scroll up"),num_pages:Cn.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Ct}from"zod";async function cc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function $o(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Io(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:dc,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 W(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:$o(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await cc("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:$o(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Mo,dc,Ot=w(()=>{"use strict";G();L();M();Mo=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=C(e,t),s=P(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=Ae(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: ${P()} });`,`await page.mouse.wheel(${i}, ${n});`]}};dc=Ct.object({element_index:Ct.number().int().describe("Index of the scrollable element"),delta_x:Ct.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Ct.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Ct.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Po}from"zod";function Oo(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:uc,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 Co,uc,Nt=w(()=>{"use strict";Co=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();`]}},uc=Po.object({text:Po.string().describe("Text to scroll to on the page")})});import{z as No}from"zod";async function hc(e,t,i){return{...await D(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Do(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 Ro(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:mc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Do(s||`Get options from dropdown ${a}`,{index:a})};let d=await hc(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:Do(s||`Get options from dropdown ${a}`,{index:a})}}}})}var Lo,mc,Dt=w(()=>{"use strict";G();Lo=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
4107
  `);a+=`
4108
- 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},`),"});"]}};pc=Do.object({element_index:Do.number().int().describe("Index of the dropdown/select element")})});import{z as gc}from"zod";function Wo(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:fc,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 Ho,fc,Lt=w(()=>{"use strict";L();M();Ho=class{async execute(e,t){await e.goBack({timeout:de}),await e.waitForLoadState("load",{timeout:de}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},fc=gc.object({})});import{z as Ui}from"zod";function Uo(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:wc,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}`,f={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,f,l),{success:!0,actionEntity:f,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(m){let f=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||f)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var Nn,wc,Rt=w(()=>{"use strict";L();M();Nn=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:de,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(", ")} } },`,"});"]}},wc=Ui.object({url:Ui.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Ui.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Ui.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as Dn}from"zod";async function bc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Bo(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 Go(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:yc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Bo(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await bc("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:Bo(`Hover element ${a}`,"hover",{index:a})}}}})}var Ln,yc,Ft=w(()=>{"use strict";G();L();M();Ln=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};yc=Dn.object({element_index:Dn.number().int().describe("Index of the element to hover over"),timeout_ms:Dn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Bi}from"zod";async function xc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function jo(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 Ko(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:vc,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:jo(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await xc("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:jo(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Rn,vc,Ht=w(()=>{"use strict";G();L();M();Rn=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=C(e,t),s=P(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},`),"});"]}};vc=Bi.object({element_index:Bi.number().int().describe("Index of the input element"),text:Bi.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:Bi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as zo}from"zod";function Xo(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:_c,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 Vo,_c,Wt=w(()=>{"use strict";Vo=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} } },`,"});"]}},_c=zo.object({index:zo.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as Fn}from"zod";function Jo(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:kc,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 Yo,kc,Ut=w(()=>{"use strict";Yo=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},kc=Fn.object({success:Fn.boolean().describe("Whether the task was completed successfully"),summary:Fn.string().describe("Summary of what was accomplished or why it failed")})});import{z as Hn}from"zod";async function Sc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function qo(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 Zo(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Ec,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:qo(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await Sc("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:qo(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Wn,Ec,Bt=w(()=>{"use strict";G();L();M();Wn=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};Ec=Hn.object({element_index:Hn.number().int().describe("Index of the element to double-click"),timeout_ms:Hn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qo}from"zod";function tr(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:Tc,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 er,Tc,Gt=w(()=>{"use strict";er=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)} } },`,"});"]}},Tc=Qo.object({otp_secret_key:Qo.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Ac}from"@babel/parser";function ir(e){if(!e.trim())return!1;try{return Ac(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Gi=w(()=>{"use strict"});import{z as nr}from"zod";import*as $c from"playwright/test";import{default as Mc}from"playwright/test";function ar(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:Ic,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 Un,ji,Ic,jt=w(()=>{"use strict";Gi();F();ge();Un={};ni(Un,{default:()=>Mc});sa(Un,$c);ji=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),g.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);g.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),g.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();g.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(Ke(),je)),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 g.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");g.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",`
4108
+ 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},`),"});"]}};mc=No.object({element_index:No.number().int().describe("Index of the dropdown/select element")})});import{z as pc}from"zod";function Ho(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:gc,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 Fo,gc,Lt=w(()=>{"use strict";L();M();Fo=class{async execute(e,t){await e.goBack({timeout:de}),await e.waitForLoadState("load",{timeout:de}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},gc=pc.object({})});import{z as Ui}from"zod";function Wo(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:fc,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}`,f={action_description:d||m,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,f,l),{success:!0,actionEntity:f,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(m){let f=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:m.message,actionEntity:{action_description:(d||f)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:m.message}}}}})}var On,fc,Rt=w(()=>{"use strict";L();M();On=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:de,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(", ")} } },`,"});"]}},fc=Ui.object({url:Ui.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Ui.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Ui.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as Nn}from"zod";async function wc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Uo(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 Bo(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:bc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Uo(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await wc("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:Uo(`Hover element ${a}`,"hover",{index:a})}}}})}var Dn,bc,Ft=w(()=>{"use strict";G();L();M();Dn=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};bc=Nn.object({element_index:Nn.number().int().describe("Index of the element to hover over"),timeout_ms:Nn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Bi}from"zod";async function yc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Go(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 jo(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:xc,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await W(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Go(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await yc("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:Go(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Ln,xc,Ht=w(()=>{"use strict";G();L();M();Ln=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=C(e,t),s=P(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},`),"});"]}};xc=Bi.object({element_index:Bi.number().int().describe("Index of the input element"),text:Bi.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:Bi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Ko}from"zod";function Vo(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:vc,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 zo,vc,Wt=w(()=>{"use strict";zo=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} } },`,"});"]}},vc=Ko.object({index:Ko.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as Rn}from"zod";function Yo(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:_c,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 Xo,_c,Ut=w(()=>{"use strict";Xo=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},_c=Rn.object({success:Rn.boolean().describe("Whether the task was completed successfully"),summary:Rn.string().describe("Summary of what was accomplished or why it failed")})});import{z as Fn}from"zod";async function kc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Jo(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 qo(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Sc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Jo(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await kc("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:Jo(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Hn,Sc,Bt=w(()=>{"use strict";G();L();M();Hn=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};Sc=Fn.object({element_index:Fn.number().int().describe("Index of the element to double-click"),timeout_ms:Fn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Zo}from"zod";function er(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:Ec,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 Qo,Ec,Gt=w(()=>{"use strict";Qo=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)} } },`,"});"]}},Ec=Zo.object({otp_secret_key:Zo.string().describe("The OTP secret key to generate the 2FA code from")})});import{parse as Tc}from"@babel/parser";function tr(e){if(!e.trim())return!1;try{return Tc(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Gi=w(()=>{"use strict"});import{z as ir}from"zod";import*as Ac from"playwright/test";import{default as $c}from"playwright/test";function nr(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:Mc,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 Wn,ji,Mc,jt=w(()=>{"use strict";Gi();F();ge();Wn={};ni(Wn,{default:()=>$c});ra(Wn,Ac);ji=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),p.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);p.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),p.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();p.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(Ke(),je)),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 p.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");p.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
4109
  return (async () => {
4110
4110
  ${t}
4111
4111
  })();
4112
- `)(e,Un.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(!ir(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
4112
+ `)(e,Wn.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(!tr(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
4113
4113
  `),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(`
4114
- `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Ic=nr.object({statement:nr.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as Bn}from"zod";function rr(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:Pc,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 or,Pc,Kt=w(()=>{"use strict";or=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(()=>(Ke(),je)),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||""}');`]}},Pc=Bn.object({element_description:Bn.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Bn.string().describe("Name of the variable to store the extracted value")})});import{z as Gn}from"zod";async function Cc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function sr(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 cr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Oc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:sr(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await Cc("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:sr(`Clear element ${a}`,"clear_input",{index:a})}}}})}var lr,Oc,zt=w(()=>{"use strict";G();L();M();lr=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};Oc=Gn.object({element_index:Gn.number().int().describe("Index of the input element to clear"),timeout_ms:Gn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as jn}from"zod";async function Nc(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function dr(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 ur(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Dc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:dr(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await Nc("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:dr(`Click element ${a}`,"click",{index:a})}}}})}var Ki,Dc,Vt=w(()=>{"use strict";G();L();M();Ki=class{async execute(e,t,i){let n=C(e,t),a=P(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=Ae(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Dc=jn.object({element_index:jn.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:jn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Lc,Rc,ze,zi=w(()=>{"use strict";Lc=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Rc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],ze=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:Lc.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:!Rc.includes(t)}}});var Kn,zn,Vn,Xn=w(()=>{"use strict";ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();zi();L();ge();Kn=class S{static registerAction(t,i){S.actions.set(t,i)}constructor(){S.initialized||(this.registerBuiltinActions(),S.initialized=!0)}registerBuiltinActions(){S.registerAction("go_to_url",new Nn),S.registerAction("go_back",new Ho),S.registerAction("reload_page",new _o),S.registerAction("close_tab",new Vo),S.registerAction("switch_tab",new so),S.registerAction("click",new Ki),S.registerAction("hover",new Ln),S.registerAction("right_click",new Pn),S.registerAction("double_click",new Wn),S.registerAction("click_by_coordinates",new ja),S.registerAction("right_click_by_coordinates",new Wa),S.registerAction("double_click_by_coordinates",new Ka),S.registerAction("drag_drop",new za),S.registerAction("input_text",new Rn),S.registerAction("clear_input",new lr),S.registerAction("press",new Mn),S.registerAction("send_keys_on_element",new Fa),S.registerAction("scroll_on_element",new Io),S.registerAction("scroll_to_text",new Oo),S.registerAction("scroll",new It),S.registerAction("upload_file",new ho),S.registerAction("wait_for_download_complete",new bo),S.registerAction("get_dropdown_options",new Ro),S.registerAction("select_dropdown_option",new io),S.registerAction("set_date_for_native_date_picker",new ao),S.registerAction("verify",new ji),S.registerAction("ai_action",new Ja),S.registerAction("ai_extract",new or),S.registerAction("ai_step",new Za),S.registerAction("ai_wait_until",new Qa),S.registerAction("generate_2fa_code",new er),S.registerAction("wait",new go),S.registerAction("wait_for_page_ready",new Ha),S.registerAction("save_variable",new To),S.registerAction("js_code",new Ga),S.registerAction("js_action",new Ua),S.registerAction("function",new Va),S.registerAction("done",new Yo),S.registerAction("click_element",new Ki),S.registerAction("click_element_by_index",new Ki),S.registerAction("hover_element_by_index",new Ln),S.registerAction("right_click_on_element",new Pn),S.registerAction("double_click_on_element",new Wn),S.registerAction("scroll_down",new It),S.registerAction("scroll_up",new It),S.registerAction("scroll_element",new It),S.registerAction("send_keys",new Mn),S.registerAction("open_tab",new Nn),S.registerAction("fill",new Rn),S.registerAction("ai_assert",new ji),S.registerAction("assert",new ji)}getAction(t){return S.actions.get(t)}hasAction(t){return S.actions.has(t)}getActionNames(){return Array.from(S.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}=(M(),hn(ai)),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(ze.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(f=>` ${f}`),u=ze.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}=(M(),hn(ai));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});`]}};Kn.actions=new Map,Kn.initialized=!1;zn=Kn,Vn=zn});var Vi={};et(Vi,{ActionHandler:()=>zn,default:()=>Vn});var Xi=w(()=>{"use strict";Xn();ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();Gi();_t();G();Oe();F();Z();gt();zi();L();ge()});import{z as Xt}from"zod";function Yi(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4114
+ `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Mc=ir.object({statement:ir.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as Un}from"zod";function or(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:Ic,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 ar,Ic,Kt=w(()=>{"use strict";ar=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(()=>(Ke(),je)),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||""}');`]}},Ic=Un.object({element_description:Un.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Un.string().describe("Name of the variable to store the extracted value")})});import{z as Bn}from"zod";async function Pc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function rr(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 lr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:Cc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:rr(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await Pc("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:rr(`Clear element ${a}`,"clear_input",{index:a})}}}})}var sr,Cc,zt=w(()=>{"use strict";G();L();M();sr=class{async execute(e,t,i){let n=C(e,t),a=P(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},`),"});"]}};Cc=Bn.object({element_index:Bn.number().int().describe("Index of the input element to clear"),timeout_ms:Bn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Gn}from"zod";async function Oc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function cr(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 dr(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Nc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await W(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:cr(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await Oc("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:cr(`Click element ${a}`,"click",{index:a})}}}})}var Ki,Nc,Vt=w(()=>{"use strict";G();L();M();Ki=class{async execute(e,t,i){let n=C(e,t),a=P(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=Ae(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Nc=Gn.object({element_index:Gn.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Gn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Dc,Lc,ze,zi=w(()=>{"use strict";Dc=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Lc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],ze=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:Dc.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:!Lc.includes(t)}}});var jn,Kn,zn,Vn=w(()=>{"use strict";ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();zi();L();ge();jn=class S{static registerAction(t,i){S.actions.set(t,i)}constructor(){S.initialized||(this.registerBuiltinActions(),S.initialized=!0)}registerBuiltinActions(){S.registerAction("go_to_url",new On),S.registerAction("go_back",new Fo),S.registerAction("reload_page",new vo),S.registerAction("close_tab",new zo),S.registerAction("switch_tab",new ro),S.registerAction("click",new Ki),S.registerAction("hover",new Dn),S.registerAction("right_click",new In),S.registerAction("double_click",new Hn),S.registerAction("click_by_coordinates",new Ga),S.registerAction("right_click_by_coordinates",new Ha),S.registerAction("double_click_by_coordinates",new ja),S.registerAction("drag_drop",new Ka),S.registerAction("input_text",new Ln),S.registerAction("clear_input",new sr),S.registerAction("press",new $n),S.registerAction("send_keys_on_element",new Ra),S.registerAction("scroll_on_element",new Mo),S.registerAction("scroll_to_text",new Co),S.registerAction("scroll",new It),S.registerAction("upload_file",new uo),S.registerAction("wait_for_download_complete",new wo),S.registerAction("get_dropdown_options",new Lo),S.registerAction("select_dropdown_option",new to),S.registerAction("set_date_for_native_date_picker",new no),S.registerAction("verify",new ji),S.registerAction("ai_action",new Ya),S.registerAction("ai_extract",new ar),S.registerAction("ai_step",new qa),S.registerAction("ai_wait_until",new Za),S.registerAction("generate_2fa_code",new Qo),S.registerAction("wait",new po),S.registerAction("wait_for_page_ready",new Fa),S.registerAction("save_variable",new Eo),S.registerAction("js_code",new Ba),S.registerAction("js_action",new Wa),S.registerAction("function",new za),S.registerAction("done",new Xo),S.registerAction("click_element",new Ki),S.registerAction("click_element_by_index",new Ki),S.registerAction("hover_element_by_index",new Dn),S.registerAction("right_click_on_element",new In),S.registerAction("double_click_on_element",new Hn),S.registerAction("scroll_down",new It),S.registerAction("scroll_up",new It),S.registerAction("scroll_element",new It),S.registerAction("send_keys",new $n),S.registerAction("open_tab",new On),S.registerAction("fill",new Ln),S.registerAction("ai_assert",new ji),S.registerAction("assert",new ji)}getAction(t){return S.actions.get(t)}hasAction(t){return S.actions.has(t)}getActionNames(){return Array.from(S.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}=(M(),hn(ai)),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(ze.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(f=>` ${f}`),u=ze.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}=(M(),hn(ai));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});`]}};jn.actions=new Map,jn.initialized=!1;Kn=jn,zn=Kn});var Vi={};et(Vi,{ActionHandler:()=>Kn,default:()=>zn});var Xi=w(()=>{"use strict";Vn();ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();Gi();_t();G();Oe();F();Z();gt();zi();L();ge()});import{z as Xt}from"zod";function Yi(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4115
4115
  ${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+=`
4116
4116
  \u2192 Action ${u+1}: ${m}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
4117
4117
  \u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
@@ -4131,7 +4131,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
4131
4131
  **Current URL**: ${i}
4132
4132
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4133
4133
 
4134
- ${o()}${r()}${a()}${n()}${s()}`.trim()}function hr(){return`
4134
+ ${o()}${r()}${a()}${n()}${s()}`.trim()}function ur(){return`
4135
4135
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4136
4136
 
4137
4137
  This is your last step. You MUST use the "done" action now.
@@ -4140,7 +4140,7 @@ This is your last step. You MUST use the "done" action now.
4140
4140
  - If the task is incomplete or partially complete, set success=false
4141
4141
  - Include everything you've accomplished in the done action's text field
4142
4142
  - No other actions are allowed on this step
4143
- `.trim()}function Fc(){let e=H.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 Xt.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof Xt.ZodNumber?l="number":s instanceof Xt.ZodString?l="string":s instanceof Xt.ZodBoolean?l="boolean":s instanceof Xt.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(`
4143
+ `.trim()}function Rc(){let e=H.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 Xt.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof Xt.ZodNumber?l="number":s instanceof Xt.ZodString?l="string":s instanceof Xt.ZodBoolean?l="boolean":s instanceof Xt.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
4144
  `)}function Ji(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
4145
4145
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4146
4146
  - "success: <reason>" if the goal was fully achieved
@@ -4248,7 +4248,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4248
4248
 
4249
4249
  When stuck, call \`done\` with success=false and explain what happened.
4250
4250
 
4251
- ${Fc()}
4251
+ ${Rc()}
4252
4252
  ## Reasoning Rules
4253
4253
 
4254
4254
  Use the \`thinking\` field to reason about each step:
@@ -4284,10 +4284,10 @@ ${m}
4284
4284
  **Current Goal Examples:**
4285
4285
  - "Add the product to the cart"
4286
4286
  - "Find more product listings and extract details from the next 5 items on the page"
4287
- ${f}`.trim()}var qi=w(()=>{"use strict";xe()});var Zi,Yn=w(()=>{"use strict";qi();Q();Zi=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=Yi(a,e,t);if(u.push({type:"text",text:m}),u.push({type:"text",text:`## CURRENT PAGE STATE
4287
+ ${f}`.trim()}var qi=w(()=>{"use strict";xe()});var Zi,Xn=w(()=>{"use strict";qi();Q();Zi=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=Yi(a,e,t);if(u.push({type:"text",text:m}),u.push({type:"text",text:`## CURRENT PAGE STATE
4288
4288
 
4289
4289
  **Interactive Elements**:
4290
- ${i}`}),r&&Array.isArray(r)&&r.length>0){let f=r.map(([h,x],y)=>`${y+1}. ${h} \u2192 ${x}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4290
+ ${i}`}),r&&Array.isArray(r)&&r.length>0){let f=r.map(([h,x],b)=>`${b+1}. ${h} \u2192 ${x}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4291
4291
 
4292
4292
  ${f.join(`
4293
4293
  `)}`})}if(s&&Object.keys(s).length>0){k.log("Adding placeholder data description");let f=this.getPlaceholderDataDescription(s,l);k.log(`Placeholder data description: ${f}`),f&&u.push({type:"text",text:f})}d&&c&&u.push({type:"text",text:c}),u.push({type:"image",image:n}),k.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
@@ -4300,19 +4300,19 @@ ${f.join(`
4300
4300
  `,n+=`- Use the EXACT placeholder name as shown above
4301
4301
  `,n+=`- Do NOT use the actual value directly in the action
4302
4302
  `,n+=`- The values shown are for context only to help you understand what data is available
4303
- `,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 Yt=w(()=>{"use strict"});async function Gc(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(f=>m.includes(f))},l=u=>{let m=u.resourceType(),f=u.url();if(!a.has(m)||s(f))return;let h=u.headers();h.purpose==="prefetch"||["video","audio"].includes(h["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let f=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(x=>f.includes(x))){i.delete(m);return}if(![...o].some(x=>f.startsWith(x))){i.delete(m);return}let h=u.headers()["content-length"];if(h)try{if(parseInt(h,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-Bc;for(let u of await e.requests()){let m=u.resourceType(),f=u.url(),h=u.timing();a.has(m)&&!s(f)&&h.responseEnd===-1&&h.startTime>=c&&(i.add(u),n=Date.now())}g.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=Uc;for(;;){await new Promise(h=>setTimeout(h,100));let f=Date.now();if(i.size===0&&f-n>=m){g.debug(`[waitForStableNetwork] Network idle after ${f-u}ms`);break}if(f-u>t){g.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ve(e,t=Wc,i=Hc){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Gc(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 Hc,Wc,Uc,Bc,Ie=w(()=>{"use strict";Yt();F();Hc=.5*1e3,Wc=30*1e3,Uc=1*1e3,Bc=3*1e3});import{generateText as jc}from"ai";function Kc(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 gr(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 $e(t.agentServices.getDomServiceOptions()),l={...t,domService:s};k.init(),k.section("Task Execution Started"),k.log(`Task: ${e}`),k.log(`Max steps: ${a}`),k.log(`Model: ${r}`);let d={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Ji(i.customPrompt),m=new Zi(u);k.log(`System prompt length: ${u.length} chars`);let f=!1,h="",x=[];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();k.section(`Step ${d.currentStep}/${a}`),k.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{k.log("Waiting for page to stabilize..."),await Ve(l.page),k.log("Page stabilized")}catch{k.log("Page stabilization timed out, continuing anyway")}let p;try{k.log("Preparing context (DOM + screenshot)...");let D=l.agentServices.getInteractiveClassNames(),R=l.agentServices.getIframeFallbackDomains();p=await pr(l.page,l.domService,D,R),k.log("Context prepared")}catch(D){if(D.message.includes("Execution context was destroyed")){k.log("Page navigating, waiting for load..."),await Ve(l.page);let R=l.agentServices.getInteractiveClassNames(),O=l.agentServices.getIframeFallbackDomains();p=await pr(l.page,l.domService,R,O)}else throw k.error("Error preparing context",D),D}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let b=await Vc(m,r,i,p.screenshotBase64);if(b.tokenUsages&&b.tokenUsages.length>0&&c.push(...b.tokenUsages),!b.stepOutput){if(k.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=o){h="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let E=b.stepOutput;qc(d.currentStep,a,E);let T=await Yc(E,l,p.domState,d.currentStep,i.onEvent,p.screenshotBase64,b.debugInfo);x.push(...T.actionEntities);let A=Jc(d.currentStep,E,T,d,y,b.debugInfo,b.tokenUsages),I=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:I}),d.consecutiveFailures>=o){k.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),h=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(T.doneResult){f=T.doneResult.success,h=T.doneResult.summary;break}if(T.completesInstruction){f=!0,h="Instruction completed";break}}return d.currentStep>=a&&!f&&(h="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),k.log(`Build success result: summary=${h}, completed=${f}, actions=${x.length}, tokens=${c.length}`),Zc(d,x,f,h,n,c,r)}catch(y){let p=y.message;return k.error(`Task execution failed: ${p}`,y),i.onEvent?.({type:"error",error:p,recoverable:!1}),Qc(d,p,n,c,r)}}async function pr(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 zc(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 Vc(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=be(t,s),d={model:we(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();k.log(`Calling LLM (${t})...`);let f=await jc(d),h=Date.now()-m,x=f,y=x.usage;k.llmCall(t,h,y);let p=x.reasoningText;p&&(k.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(f.text);let b={systemPrompt:o,userPrompt:zc(r),rawLlmResponse:f.text,reasoningContent:p,screenshotWithSom:n},E=[],T=Kc(y,t);T&&E.push(T);let A=Xc(f.text);if(!A)if(u<c-1){k.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(I=>setTimeout(I,i.retryDelay||1e3));continue}else return k.error("All parsing attempts failed"),{stepOutput:null,debugInfo:b,tokenUsages:E};return{stepOutput:A,debugInfo:b,tokenUsages:E}}catch(m){if(u<c-1){k.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(f=>setTimeout(f,i.retryDelay||1e3));continue}else throw k.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function Xc(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 k.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return k.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return k.error("Action missing required field: action_name"),null;if(!n.description)return k.error("Action missing required field: description"),null}return i}catch(i){return k.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),k.error(`Parse error: ${i.message}`),null}}async function Yc(e,t,i,n,a,o,r){let s=[],l=!0,d=null;k.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 f of e.actions){if(f.action_name==="done"){c={success:f.kwargs.success??!0,summary:f.kwargs.summary||f.kwargs.text||"Task completed"};break}let h={},x=f.kwargs?.element_index??f.kwargs?.index;if(typeof x=="number"){let p=i.selectorMap.get(x);p&&(h=await N(t.page,p))}let y={...h,action_description:f.description,action_data:{action_name:f.action_name,kwargs:f.kwargs}};try{let p=await H.execute(f.action_name,f.kwargs,u);f.action_name==="perform_accurate_operation"&&(y=p.actionEntity);let b=await u.agentServices.getCurrentPage();if(b&&(u.page=b,t.page=u.page),p?.success===!1){l=!1,k.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,k.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Jc(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 qc(e,t,i){if(k.log(`Step ${e}/${t}`),i.thinking&&k.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&k.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&k.log(`Memory: ${i.memory}`),k.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];k.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else k.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{k.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Zc(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 Qc(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 fr=w(()=>{"use strict";Yn();qi();xe();Ne();Q();Ie();ye();G()});var wr={};et(wr,{TaskMessageManager:()=>Zi,formatFinalStepWarning:()=>hr,formatTaskContext:()=>Yi,getBrowserTaskJSONPrompt:()=>Ji,runTaskLoop:()=>gr});var br=w(()=>{"use strict";fr();Yn();qi();xe();Ci();Ne();dt();ut();Ge();ht();mt();Q();Ie();Yt();ye();nt();at();He();G();Oe();F();Z();gt();L();ge()});async function ft(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(H.has(i)){let a=await H.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 ed()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function ed(){if(Qi)return Qi;let e=await Promise.resolve().then(()=>(Xi(),Vi));return Qi=new e.default,Qi}async function Oi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await vn(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 Ni(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await vn(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 ft(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 Di(e,t,i,n={}){let a={page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Ia(o,a,n)}async function Li(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(br(),wr)),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 Qi,wt=w(()=>{"use strict";vi();xe();Ne();Qi=null});import"uuid";import{z as v}from"zod";import"yaml";import"uuid";import"yaml";var Lr,Ix,Rr,cd,dd,tn,Px,Cx,Fr,Hr,ud,Dr,hd,Jt,md,pd,gd,te,fd,wd,Lx,Vx,qt=w(()=>{"use strict";ge();Lr=112,Ix=1080-Lr,Rr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Rr||{}),cd={"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"}},dd={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"]},tn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),dd[e].map(n=>cd[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Px={desktop:{label:"Desktop",type:"desktop",devices:tn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:tn("mobile")}},Cx={desktop:{label:"Desktop",type:"desktop",devices:tn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:tn("mobile",!0)}},Fr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Fr||{}),Hr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Hr||{}),ud=v.enum(["JS_CODE","AI_MODE"]),Dr=v.object({type:ud,expression:v.string()}),hd=v.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Jt=v.object({uid:v.string(),type:hd,comment:v.string().optional()}),md=v.object({action_data:v.object({action_name:v.string(),kwargs:v.record(v.any()).optional(),args:v.array(v.any()).optional()}),action_description:v.string().optional(),url:v.string().optional(),xpath:v.string().nullable().optional(),locator:v.string().nullable().optional(),css_selector:v.string().nullable().optional(),unique_selector:v.string().nullable().optional(),element_index:v.number().nullable().optional(),frame_path:v.array(v.any()).optional(),artifacts:v.record(v.any()).optional(),feedback:v.string().optional(),original_browser_use_action:v.any().optional()}).passthrough(),pd=Jt.extend({type:v.literal("DRAFT"),description:v.string()}),gd=Jt.extend({type:v.literal("ACTION"),description:v.string(),action_entity:md.optional(),locator:v.string().optional(),use_pure_vision:v.boolean().optional()}),te=v.lazy(()=>v.union([pd,gd,Jt.extend({type:v.literal("STEP"),description:v.string().optional().default(""),statements:v.array(te),reference_id:v.number().optional()}),Jt.extend({type:v.literal("IF_ELSE"),description:v.string().optional(),condition:Dr,then:v.array(te),else:v.array(te).optional()}),Jt.extend({type:v.literal("WHILE_LOOP"),description:v.string().optional(),condition:Dr,body:v.array(te),timeout_ms:v.number().optional()})])),fd=v.object({name:v.string(),statements:v.array(te),teardown:v.array(te).optional(),skip:v.union([v.boolean(),v.string()]).optional(),timeout:v.number().optional(),fail:v.union([v.boolean(),v.string()]).optional(),only:v.boolean().optional(),slow:v.boolean().optional()}),wd=v.object({tests:v.array(fd).min(1),beforeAll:v.array(te).optional(),afterAll:v.array(te).optional(),beforeEach:v.array(te).optional(),afterEach:v.array(te).optional()}),Lx=v.object({comment:v.string().optional(),version:v.string().optional(),goal:v.string().optional(),url:v.string().optional(),baseURL:v.string().optional(),final_feedback:v.string().optional(),completed:v.boolean().optional(),success:v.boolean().optional(),statements:v.array(te).optional(),teardown:v.array(te).optional(),last_modified_at:v.string().optional(),testGroup:wd.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"}),Vx=1024*1024});var Jn=w(()=>{"use strict";Q();Ie()});var Br=w(()=>{"use strict"});var Gr=w(()=>{"use strict"});var jr=w(()=>{"use strict"});import{v4 as Ek}from"uuid";var Kr=w(()=>{"use strict"});import{z as _}from"zod";var zr,qn,Vr,Ye,Xr,Yr,Jr,ee,qr,nn,Zn,Qn=w(()=>{"use strict";zr=_.enum(["JS_CODE","AI_MODE"]),qn=_.object({type:zr,expression:_.string()}),Vr=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ye=_.object({uid:_.string(),type:Vr,comment:_.string().optional()}),Xr=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Yr=Ye.extend({type:_.literal("DRAFT"),description:_.string()}),Jr=Ye.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Xr.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ee=_.lazy(()=>_.union([Yr,Jr,Ye.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ee),reference_id:_.number().optional()}),Ye.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:qn,then:_.array(ee),else:_.array(ee).optional()}),Ye.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:qn,body:_.array(ee),timeout_ms:_.number().optional()})])),qr=_.object({name:_.string(),statements:_.array(ee),teardown:_.array(ee).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),nn=_.object({tests:_.array(qr).min(1),beforeAll:_.array(ee).optional(),afterAll:_.array(ee).optional(),beforeEach:_.array(ee).optional(),afterEach:_.array(ee).optional()}),Zn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ee).optional(),teardown:_.array(ee).optional(),last_modified_at:_.string().optional(),testGroup:nn.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 Ed,parse as ts,parseAllDocuments as Pk,parseDocument as Td,Document as Ad,isMap as qe,isSeq as ce}from"yaml";import{v4 as le}from"uuid";function is(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(ie)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ie)),i}function an(e,t){if(e.testGroup)return as(e,t);let i=is(e,t),n=new Ad(i);return e.comment&&(n.commentBefore=e.comment),Zr(n,e.statements??[]),e.teardown&&Zr(n,e.teardown,"teardown"),n.toString(ns)}function Zr(e,t,i="statements"){let n=e.contents;if(!n||!qe(n))return;let a=n.get(i,!0);ce(a)&&ei(a,t)}function ei(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),qe(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);ce(r)&&ei(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);ce(r)&&ei(r,n.then);let s=o.get("ELSE",!0);ce(s)&&n.else&&ei(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);ce(r)&&ei(r,n.body)}}}}function as(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(ie)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ie)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ie)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ie)),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(ie),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(ie)),r}),n.suite=a,Ed(n,ns)}function ie(e){switch(e.type){case"DRAFT":return $d(e);case"ACTION":return Md(e);case"STEP":return Id(e);case"IF_ELSE":return Pd(e);case"WHILE_LOOP":return Cd(e)}}function $d(e){return{intent:e.description}}function Md(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{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 Id(e){let t={STEP:e.description,statements:e.statements.map(ie)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Pd(e){let t={IF:os(e.condition),THEN:e.then.map(ie)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ie)),t}function Cd(e){let t={WHILE:os(e.condition),DO:e.body.map(ie)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function os(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function ta(e){try{let t=ts(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 ea(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ea);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]=ea(o);return n}function ke(e){if(e.length>Qr)throw new Error(`YAML input too large (${e.length} bytes, max ${Qr})`);let t=ea(ts(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Od(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ne(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ne(t.teardown));let n=Zn.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return on(e,a),a}function Od(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:ne(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ne(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=ne(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ne(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ne(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ne(t.afterEach));let o=nn.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 ne(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Nd)}function Nd(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 Dd(t);if("WHILE"in t)return Ld(t);if("STEP"in t)return Rd(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:le(),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:le(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:le(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:le(),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:le(),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:le(),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 es({...n,action:"function",functionName:i})}if("action"in t)return es(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:le(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function rs(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 Dd(e){let t=rs(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:le(),type:"IF_ELSE",condition:t,then:ne(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ne(e.ELSE)),n}function Ld(e){let t=rs(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:le(),type:"WHILE_LOOP",condition:t,body:ne(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Rd(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:le(),type:"STEP",description:t,statements:ne(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function es(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))Fd.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:le(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function on(e,t){let i;try{i=Td(e)}catch{return}let n=i.contents;if(!n||!qe(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);ce(o)&&t.statements&&Je(o,t.statements);let r=a.get("teardown",!0);ce(r)&&t.teardown&&Je(r,t.teardown)}function Je(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"&&qe(n)){let o=n.get("statements",!0);ce(o)&&Je(o,a.statements)}else if(a.type==="IF_ELSE"&&qe(n)){let o=n.get("THEN",!0);ce(o)&&Je(o,a.then);let r=n.get("ELSE",!0);ce(r)&&a.else&&Je(r,a.else)}else if(a.type==="WHILE_LOOP"&&qe(n)){let o=n.get("DO",!0);ce(o)&&Je(o,a.body)}}}var ns,Qr,Fd,rn=w(()=>{"use strict";Qn();ns={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Qr=1024*1024;Fd=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as Lk,stringify as Rk}from"yaml";var ss=w(()=>{"use strict";rn()});var sn=w(()=>{"use strict"});var ls=w(()=>{"use strict";rn();sn()});var ln=w(()=>{"use strict"});var cs=w(()=>{"use strict";ln()});var ds,Ud,us,hs,ti,Bd,Gd,ms=w(()=>{"use strict";ds=112,Ud=1080-ds,us={"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"}},hs={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"]},ti=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),hs[e].map(n=>us[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Bd={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile")}},Gd={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile",!0)}}});var ps=w(()=>{"use strict"});var gs=w(()=>{"use strict";sn()});var De,fs=w(()=>{"use strict";De=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(De||{})});var ws=w(()=>{"use strict"});var bs=w(()=>{"use strict"});var ys=w(()=>{"use strict"});var xs=w(()=>{"use strict";ln()});var Ze=w(()=>{"use strict";Br();Gr();jr();Kr();ss();ls();rn();Qn();cs();ms();ps();gs();sn();fs();ws();bs();ys();xs();ln()});import{stringify as oT}from"yaml";import{createHash as Jd}from"crypto";import{parse as qd,stringify as Ts}from"yaml";import{readFileSync as Zd}from"fs";import{resolve as As,dirname as Qd}from"path";import{parse as _s,stringify as eu}from"yaml";function Xd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Yd(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 Es(e){let t=Xd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Yd(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){q.set(e,t)}function Le(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function vs(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let 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(", ")})`}function $s(e,t){let i={expandingPaths:new Set([As(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=Pe(n.statements,t,i)),Array.isArray(n.teardown)&&(n.teardown=Pe(n.teardown,t,i));for(let a of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[a])&&(n[a]=Pe(n[a],t,i));return{doc:n,referencedTemplatePaths:Array.from(i.referencedPaths)}}function Pe(e,t,i){let n=[];for(let a of e)if(tu(a)){let o=iu(a,t,i);n.push(...o)}else n.push(nu(a,t,i));return n}function tu(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function iu(e,t,i){if(i.depth>=ks)throw new Error(`Template expansion exceeded maximum depth of ${ks}. Check for deeply nested or circular template references.`);let n=As(Qd(t),e.template);if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let a;try{a=Zd(n,"utf-8")}catch(c){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${c.message}`)}let o=_s(a);if(!o||typeof o!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let r=o.params||[],s=e.params||{};for(let c of r)if(!(c in s))throw new Error(`Template ${e.template} requires param "${c}" but it was not provided. Required params: [${r.join(", ")}]`);let l=o.statements;if(!Array.isArray(l))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let u=eu(l);for(let[m,f]of Object.entries(s))u=u.split(`<<${m}>>`).join(String(f));l=_s(u)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths};return Pe(l,n,d)}function nu(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Pe(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Pe(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Pe(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Pe(n.DO,t,i)),n}function Is(e,t){let i=qd(e),n=i?.name,a=i?.tags,o=i?.use;if(i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use),i?.suite){if(i.goal||i.statements)throw new Ms('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return ou(i,n,a,o,t)}return au(i,n,a,o,t)}function au(e,t,i,n,a){let o=e?.beforeEach,r=e?.afterEach,s=Ps(e?.parameters),l=e?.timeout,d=e?.skip,c=e?.fail,u=e?.only,m=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new Ms(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let f=[];if(a&&e&&typeof e=="object"){let y=$s(e,a);e=y.doc,f=y.referencedTemplatePaths}let h=Ts(e),x=ke(h);return a&&(Qe(x.statements??[],a,"main"),x.teardown&&Qe(x.teardown,a,"teardown")),{testFlow:x,name:t,tags:i,use:n,beforeEach:o,afterEach:r,parameters:s,timeout:l,skip:d,fail:c,only:u,slow:m,referencedTemplatePaths:f}}function ou(e,t,i,n,a){let o=e.suite;if(!Array.isArray(o.tests)||o.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let r=o.beforeAll,s=o.afterAll,l=o.beforeEach,d=o.afterEach,c=[],u=o.tests.map(h=>{if(!h.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(h.statements)||h.statements.length===0)throw new Error(`Suite test "${h.name}" must have a non-empty "statements" array.`);let x={goal:h.name,statements:h.statements};h.teardown&&(x.teardown=h.teardown);let y=[],p=x;if(a&&typeof x=="object"){let A=$s(x,a);p=A.doc,y=A.referencedTemplatePaths,c.push(...y)}let b=Ts(p),E=ke(b),T=Ps(h.parameters);return{testFlow:E,name:h.name,tags:Array.isArray(h.tags)?h.tags:void 0,parameters:T,timeout:h.timeout,skip:h.skip,fail:h.fail,only:h.only,slow:h.slow}}),m=o.base_url,f=m?{...n,baseURL:m}:n;return{suite:{beforeAll:r,afterAll:s,beforeEach:l,afterEach:d,tests:u},name:t,tags:i,use:f,referencedTemplatePaths:c}}function Ps(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Qe(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=ru(t,o,r),a.type===De.STEP)Qe(a.statements,t,o);else if(a.type===De.IF_ELSE){let s=a;Qe(s.then,t,`${o}.then`),s.else&&Qe(s.else,t,`${o}.else`)}else a.type===De.WHILE_LOOP&&Qe(a.body,t,`${o}.body`)}}function ru(e,t,i){let n=Jd("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${n.slice(0,8)}-${n.slice(8,12)}-${n.slice(12,16)}-${n.slice(16,20)}-${n.slice(20,32)}`}var Ss,q,ks,Ms,Cs=w(()=>{"use strict";Ze();Ze();Ze();Ze();Ss=5e3;q=new Map;$("click",e=>{let t=Es(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Ss;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",q.get("click"));$("click_element_by_index",q.get("click"));$("double_click",e=>Le("double_click",e));$("double_click_on_element",q.get("double_click"));$("right_click",e=>Le("right_click",e));$("right_click_on_element",q.get("right_click"));$("hover",e=>Le("hover",e));$("hover_element_by_index",q.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Le("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",q.get("input_text"));$("clear_input",e=>Le("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",q.get("press"));$("send_keys_on_element",e=>{let t=Es(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??Ss;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Le("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",q.get("scroll"));$("scroll_up",q.get("scroll"));$("scroll_element",q.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Le("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",q.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
4303
+ `,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 Yt=w(()=>{"use strict"});async function Bc(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(f=>m.includes(f))},l=u=>{let m=u.resourceType(),f=u.url();if(!a.has(m)||s(f))return;let h=u.headers();h.purpose==="prefetch"||["video","audio"].includes(h["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let m=u.request();if(!i.has(m))return;let f=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(x=>f.includes(x))){i.delete(m);return}if(![...o].some(x=>f.startsWith(x))){i.delete(m);return}let h=u.headers()["content-length"];if(h)try{if(parseInt(h,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},c=Date.now()-Uc;for(let u of await e.requests()){let m=u.resourceType(),f=u.url(),h=u.timing();a.has(m)&&!s(f)&&h.responseEnd===-1&&h.startTime>=c&&(i.add(u),n=Date.now())}p.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),m=Wc;for(;;){await new Promise(h=>setTimeout(h,100));let f=Date.now();if(i.size===0&&f-n>=m){p.debug(`[waitForStableNetwork] Network idle after ${f-u}ms`);break}if(f-u>t){p.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Ve(e,t=Hc,i=Fc){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Bc(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 Fc,Hc,Wc,Uc,Ie=w(()=>{"use strict";Yt();F();Fc=.5*1e3,Hc=30*1e3,Wc=1*1e3,Uc=3*1e3});import{generateText as Gc}from"ai";function jc(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 pr(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 $e(t.agentServices.getDomServiceOptions()),l={...t,domService:s};k.init(),k.section("Task Execution Started"),k.log(`Task: ${e}`),k.log(`Max steps: ${a}`),k.log(`Model: ${r}`);let d={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Ji(i.customPrompt),m=new Zi(u);k.log(`System prompt length: ${u.length} chars`);let f=!1,h="",x=[];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 b=Date.now();k.section(`Step ${d.currentStep}/${a}`),k.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{k.log("Waiting for page to stabilize..."),await Ve(l.page),k.log("Page stabilized")}catch{k.log("Page stabilization timed out, continuing anyway")}let g;try{k.log("Preparing context (DOM + screenshot)...");let N=l.agentServices.getInteractiveClassNames(),R=l.agentServices.getIframeFallbackDomains();g=await mr(l.page,l.domService,N,R),k.log("Context prepared")}catch(N){if(N.message.includes("Execution context was destroyed")){k.log("Page navigating, waiting for load..."),await Ve(l.page);let R=l.agentServices.getInteractiveClassNames(),O=l.agentServices.getIframeFallbackDomains();g=await mr(l.page,l.domService,R,O)}else throw k.error("Error preparing context",N),N}m.addStateMessage(e,g.currentUrl,g.domTree,g.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let y=await zc(m,r,i,g.screenshotBase64);if(y.tokenUsages&&y.tokenUsages.length>0&&c.push(...y.tokenUsages),!y.stepOutput){if(k.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=o){h="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let E=y.stepOutput;Jc(d.currentStep,a,E);let T=await Xc(E,l,g.domState,d.currentStep,i.onEvent,g.screenshotBase64,y.debugInfo);x.push(...T.actionEntities);let A=Yc(d.currentStep,E,T,d,b,y.debugInfo,y.tokenUsages),I=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:I}),d.consecutiveFailures>=o){k.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),h=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(T.doneResult){f=T.doneResult.success,h=T.doneResult.summary;break}if(T.completesInstruction){f=!0,h="Instruction completed";break}}return d.currentStep>=a&&!f&&(h="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),k.log(`Build success result: summary=${h}, completed=${f}, actions=${x.length}, tokens=${c.length}`),qc(d,x,f,h,n,c,r)}catch(b){let g=b.message;return k.error(`Task execution failed: ${g}`,b),i.onEvent?.({type:"error",error:g,recoverable:!1}),Zc(d,g,n,c,r)}}async function mr(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 Kc(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 zc(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=be(t,s),d={model:we(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let m=Date.now();k.log(`Calling LLM (${t})...`);let f=await Gc(d),h=Date.now()-m,x=f,b=x.usage;k.llmCall(t,h,b);let g=x.reasoningText;g&&(k.thinking(g),i.onEvent?.({type:"thinking",text:g})),e.addAssistantMessage(f.text);let y={systemPrompt:o,userPrompt:Kc(r),rawLlmResponse:f.text,reasoningContent:g,screenshotWithSom:n},E=[],T=jc(b,t);T&&E.push(T);let A=Vc(f.text);if(!A)if(u<c-1){k.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(I=>setTimeout(I,i.retryDelay||1e3));continue}else return k.error("All parsing attempts failed"),{stepOutput:null,debugInfo:y,tokenUsages:E};return{stepOutput:A,debugInfo:y,tokenUsages:E}}catch(m){if(u<c-1){k.log(`Attempt ${u+1}/${c}: LLM call failed (${m.message}), retrying...`),await new Promise(f=>setTimeout(f,i.retryDelay||1e3));continue}else throw k.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function Vc(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 k.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return k.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return k.error("Action missing required field: action_name"),null;if(!n.description)return k.error("Action missing required field: description"),null}return i}catch(i){return k.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),k.error(`Parse error: ${i.message}`),null}}async function Xc(e,t,i,n,a,o,r){let s=[],l=!0,d=null;k.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 f of e.actions){if(f.action_name==="done"){c={success:f.kwargs.success??!0,summary:f.kwargs.summary||f.kwargs.text||"Task completed"};break}let h={},x=f.kwargs?.element_index??f.kwargs?.index;if(typeof x=="number"){let g=i.selectorMap.get(x);g&&(h=await D(t.page,g))}let b={...h,action_description:f.description,action_data:{action_name:f.action_name,kwargs:f.kwargs}};try{let g=await H.execute(f.action_name,f.kwargs,u);f.action_name==="perform_accurate_operation"&&(b=g.actionEntity);let y=await u.agentServices.getCurrentPage();if(y&&(u.page=y,t.page=u.page),g?.success===!1){l=!1,k.log("Action failed, stopping execution of remaining actions in this step"),d=g.error||"Action execution failed";break}s.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(g){l=!1,d=g.message,k.error(`Action execution failed: ${g.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Yc(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 Jc(e,t,i){if(k.log(`Step ${e}/${t}`),i.thinking&&k.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&k.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&k.log(`Memory: ${i.memory}`),k.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];k.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else k.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{k.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function qc(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 Zc(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 gr=w(()=>{"use strict";Xn();qi();xe();Ne();Q();Ie();ye();G()});var fr={};et(fr,{TaskMessageManager:()=>Zi,formatFinalStepWarning:()=>ur,formatTaskContext:()=>Yi,getBrowserTaskJSONPrompt:()=>Ji,runTaskLoop:()=>pr});var wr=w(()=>{"use strict";gr();Xn();qi();xe();Ci();Ne();dt();ut();Ge();ht();mt();Q();Ie();Yt();ye();nt();He();at();G();Oe();F();Z();gt();L();ge()});async function ft(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(H.has(i)){let a=await H.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 Qc()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Qc(){if(Qi)return Qi;let e=await Promise.resolve().then(()=>(Xi(),Vi));return Qi=new e.default,Qi}async function Oi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await xn(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 Ni(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await xn(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 ft(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 Di(e,t,i,n={}){let a={page:t,agentServices:i,domService:new $e(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Ma(o,a,n)}async function Li(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(wr(),fr)),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 Qi,wt=w(()=>{"use strict";vi();xe();Ne();Qi=null});import"uuid";import{z as v}from"zod";import"yaml";import"uuid";import"yaml";var Dr,Mx,Lr,ld,cd,tn,Ix,Px,Rr,Fr,dd,Nr,ud,Jt,hd,md,pd,te,gd,fd,Dx,zx,qt=w(()=>{"use strict";ge();Dr=112,Mx=1080-Dr,Lr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Lr||{}),ld={"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"}},cd={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"]},tn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),cd[e].map(n=>ld[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ix={desktop:{label:"Desktop",type:"desktop",devices:tn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:tn("mobile")}},Px={desktop:{label:"Desktop",type:"desktop",devices:tn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:tn("mobile",!0)}},Rr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Rr||{}),Fr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Fr||{}),dd=v.enum(["JS_CODE","AI_MODE"]),Nr=v.object({type:dd,expression:v.string()}),ud=v.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Jt=v.object({uid:v.string(),type:ud,comment:v.string().optional()}),hd=v.object({action_data:v.object({action_name:v.string(),kwargs:v.record(v.any()).optional(),args:v.array(v.any()).optional()}),action_description:v.string().optional(),url:v.string().optional(),xpath:v.string().nullable().optional(),locator:v.string().nullable().optional(),css_selector:v.string().nullable().optional(),unique_selector:v.string().nullable().optional(),element_index:v.number().nullable().optional(),frame_path:v.array(v.any()).optional(),artifacts:v.record(v.any()).optional(),feedback:v.string().optional(),original_browser_use_action:v.any().optional()}).passthrough(),md=Jt.extend({type:v.literal("DRAFT"),description:v.string()}),pd=Jt.extend({type:v.literal("ACTION"),description:v.string(),action_entity:hd.optional(),locator:v.string().optional(),use_pure_vision:v.boolean().optional()}),te=v.lazy(()=>v.union([md,pd,Jt.extend({type:v.literal("STEP"),description:v.string().optional().default(""),statements:v.array(te),reference_id:v.number().optional()}),Jt.extend({type:v.literal("IF_ELSE"),description:v.string().optional(),condition:Nr,then:v.array(te),else:v.array(te).optional()}),Jt.extend({type:v.literal("WHILE_LOOP"),description:v.string().optional(),condition:Nr,body:v.array(te),timeout_ms:v.number().optional()})])),gd=v.object({name:v.string(),statements:v.array(te),teardown:v.array(te).optional(),skip:v.union([v.boolean(),v.string()]).optional(),timeout:v.number().optional(),fail:v.union([v.boolean(),v.string()]).optional(),only:v.boolean().optional(),slow:v.boolean().optional()}),fd=v.object({tests:v.array(gd).min(1),beforeAll:v.array(te).optional(),afterAll:v.array(te).optional(),beforeEach:v.array(te).optional(),afterEach:v.array(te).optional()}),Dx=v.object({comment:v.string().optional(),version:v.string().optional(),goal:v.string().optional(),url:v.string().optional(),baseURL:v.string().optional(),final_feedback:v.string().optional(),completed:v.boolean().optional(),success:v.boolean().optional(),statements:v.array(te).optional(),teardown:v.array(te).optional(),last_modified_at:v.string().optional(),testGroup:fd.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"}),zx=1024*1024});var Yn=w(()=>{"use strict";Q();Ie()});var Ur=w(()=>{"use strict"});var Br=w(()=>{"use strict"});var Gr=w(()=>{"use strict"});import{v4 as Sk}from"uuid";var jr=w(()=>{"use strict"});import{z as _}from"zod";var Kr,Jn,zr,Ye,Vr,Xr,Yr,ee,Jr,nn,qn,Zn=w(()=>{"use strict";Kr=_.enum(["JS_CODE","AI_MODE"]),Jn=_.object({type:Kr,expression:_.string()}),zr=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ye=_.object({uid:_.string(),type:zr,comment:_.string().optional()}),Vr=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Xr=Ye.extend({type:_.literal("DRAFT"),description:_.string()}),Yr=Ye.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Vr.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),ee=_.lazy(()=>_.union([Xr,Yr,Ye.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(ee),reference_id:_.number().optional()}),Ye.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:Jn,then:_.array(ee),else:_.array(ee).optional()}),Ye.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:Jn,body:_.array(ee),timeout_ms:_.number().optional()})])),Jr=_.object({name:_.string(),statements:_.array(ee),teardown:_.array(ee).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),nn=_.object({tests:_.array(Jr).min(1),beforeAll:_.array(ee).optional(),afterAll:_.array(ee).optional(),beforeEach:_.array(ee).optional(),afterEach:_.array(ee).optional()}),qn=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(ee).optional(),teardown:_.array(ee).optional(),last_modified_at:_.string().optional(),testGroup:nn.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 Sd,parse as es,parseAllDocuments as Ik,parseDocument as Ed,Document as Td,isMap as qe,isSeq as ce}from"yaml";import{v4 as le}from"uuid";function ts(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(ie)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ie)),i}function an(e,t){if(e.testGroup)return ns(e,t);let i=ts(e,t),n=new Td(i);return e.comment&&(n.commentBefore=e.comment),qr(n,e.statements??[]),e.teardown&&qr(n,e.teardown,"teardown"),n.toString(is)}function qr(e,t,i="statements"){let n=e.contents;if(!n||!qe(n))return;let a=n.get(i,!0);ce(a)&&ei(a,t)}function ei(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),qe(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);ce(r)&&ei(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);ce(r)&&ei(r,n.then);let s=o.get("ELSE",!0);ce(s)&&n.else&&ei(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);ce(r)&&ei(r,n.body)}}}}function ns(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(ie)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ie)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ie)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ie)),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(ie),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(ie)),r}),n.suite=a,Sd(n,is)}function ie(e){switch(e.type){case"DRAFT":return Ad(e);case"ACTION":return $d(e);case"STEP":return Md(e);case"IF_ELSE":return Id(e);case"WHILE_LOOP":return Pd(e)}}function Ad(e){return{intent:e.description}}function $d(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 Md(e){let t={STEP:e.description,statements:e.statements.map(ie)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Id(e){let t={IF:as(e.condition),THEN:e.then.map(ie)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ie)),t}function Pd(e){let t={WHILE:as(e.condition),DO:e.body.map(ie)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function as(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function ea(e){try{let t=es(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 Qn(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Qn);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]=Qn(o);return n}function ke(e){if(e.length>Zr)throw new Error(`YAML input too large (${e.length} bytes, max ${Zr})`);let t=Qn(es(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Cd(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ne(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ne(t.teardown));let n=qn.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return on(e,a),a}function Cd(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:ne(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ne(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=ne(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ne(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ne(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ne(t.afterEach));let o=nn.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 ne(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Od)}function Od(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 Nd(t);if("WHILE"in t)return Dd(t);if("STEP"in t)return Ld(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:le(),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:le(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:le(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:le(),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:le(),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:le(),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 Qr({...n,action:"function",functionName:i})}if("action"in t)return Qr(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:le(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function os(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 Nd(e){let t=os(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:le(),type:"IF_ELSE",condition:t,then:ne(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ne(e.ELSE)),n}function Dd(e){let t=os(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:le(),type:"WHILE_LOOP",condition:t,body:ne(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Ld(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:le(),type:"STEP",description:t,statements:ne(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function Qr(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))Rd.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:le(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function on(e,t){let i;try{i=Ed(e)}catch{return}let n=i.contents;if(!n||!qe(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);ce(o)&&t.statements&&Je(o,t.statements);let r=a.get("teardown",!0);ce(r)&&t.teardown&&Je(r,t.teardown)}function Je(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"&&qe(n)){let o=n.get("statements",!0);ce(o)&&Je(o,a.statements)}else if(a.type==="IF_ELSE"&&qe(n)){let o=n.get("THEN",!0);ce(o)&&Je(o,a.then);let r=n.get("ELSE",!0);ce(r)&&a.else&&Je(r,a.else)}else if(a.type==="WHILE_LOOP"&&qe(n)){let o=n.get("DO",!0);ce(o)&&Je(o,a.body)}}}var is,Zr,Rd,rn=w(()=>{"use strict";Zn();is={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Zr=1024*1024;Rd=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as Dk,stringify as Lk}from"yaml";var rs=w(()=>{"use strict";rn()});var sn=w(()=>{"use strict"});var ss=w(()=>{"use strict";rn();sn()});var ln=w(()=>{"use strict"});var ls=w(()=>{"use strict";ln()});var cs,Wd,ds,us,ti,Ud,Bd,hs=w(()=>{"use strict";cs=112,Wd=1080-cs,ds={"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"}},us={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"]},ti=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),us[e].map(n=>ds[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ud={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile")}},Bd={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile",!0)}}});var ms=w(()=>{"use strict"});var ps=w(()=>{"use strict";sn()});var De,gs=w(()=>{"use strict";De=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(De||{})});var fs=w(()=>{"use strict"});var ws=w(()=>{"use strict"});var bs=w(()=>{"use strict"});var ys=w(()=>{"use strict";ln()});var Ze=w(()=>{"use strict";Ur();Br();Gr();jr();rs();ss();rn();Zn();ls();hs();ms();ps();sn();gs();fs();ws();bs();ys();ln()});import{stringify as aT}from"yaml";import{createHash as Yd}from"crypto";import{parse as Jd,stringify as Es}from"yaml";import{readFileSync as qd}from"fs";import{resolve as Ts,dirname as Zd}from"path";import{parse as vs,stringify as Qd}from"yaml";function Vd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Xd(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 Ss(e){let t=Vd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Xd(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){q.set(e,t)}function Le(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function xs(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let 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(", ")})`}function As(e,t){let i={expandingPaths:new Set([Ts(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=Pe(n.statements,t,i)),Array.isArray(n.teardown)&&(n.teardown=Pe(n.teardown,t,i));for(let a of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[a])&&(n[a]=Pe(n[a],t,i));return{doc:n,referencedTemplatePaths:Array.from(i.referencedPaths)}}function Pe(e,t,i){let n=[];for(let a of e)if(eu(a)){let o=tu(a,t,i);n.push(...o)}else n.push(iu(a,t,i));return n}function eu(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function tu(e,t,i){if(i.depth>=_s)throw new Error(`Template expansion exceeded maximum depth of ${_s}. Check for deeply nested or circular template references.`);let n=Ts(Zd(t),e.template);if(i.expandingPaths.has(n))throw new Error(`Circular template reference detected: ${n} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${n}`);i.referencedPaths.add(n);let a;try{a=qd(n,"utf-8")}catch(c){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${c.message}`)}let o=vs(a);if(!o||typeof o!="object")throw new Error(`Invalid template file: ${n} \u2014 expected a YAML object`);let r=o.params||[],s=e.params||{};for(let c of r)if(!(c in s))throw new Error(`Template ${e.template} requires param "${c}" but it was not provided. Required params: [${r.join(", ")}]`);let l=o.statements;if(!Array.isArray(l))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let u=Qd(l);for(let[m,f]of Object.entries(s))u=u.split(`<<${m}>>`).join(String(f));l=vs(u)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths};return Pe(l,n,d)}function iu(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Pe(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Pe(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Pe(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Pe(n.DO,t,i)),n}function Ms(e,t){let i=Jd(e),n=i?.name,a=i?.tags,o=i?.use;if(i&&(i.name!==void 0||i.tags!==void 0||i.use!==void 0)&&(delete i.name,delete i.tags,delete i.use),i?.suite){if(i.goal||i.statements)throw new $s('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return au(i,n,a,o,t)}return nu(i,n,a,o,t)}function nu(e,t,i,n,a){let o=e?.beforeEach,r=e?.afterEach,s=Is(e?.parameters),l=e?.timeout,d=e?.skip,c=e?.fail,u=e?.only,m=e?.slow;if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow),e?.url)throw new $s(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let f=[];if(a&&e&&typeof e=="object"){let b=As(e,a);e=b.doc,f=b.referencedTemplatePaths}let h=Es(e),x=ke(h);return a&&(Qe(x.statements??[],a,"main"),x.teardown&&Qe(x.teardown,a,"teardown")),{testFlow:x,name:t,tags:i,use:n,beforeEach:o,afterEach:r,parameters:s,timeout:l,skip:d,fail:c,only:u,slow:m,referencedTemplatePaths:f}}function au(e,t,i,n,a){let o=e.suite;if(!Array.isArray(o.tests)||o.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let r=o.beforeAll,s=o.afterAll,l=o.beforeEach,d=o.afterEach,c=[],u=o.tests.map(h=>{if(!h.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(h.statements)||h.statements.length===0)throw new Error(`Suite test "${h.name}" must have a non-empty "statements" array.`);let x={goal:h.name,statements:h.statements};h.teardown&&(x.teardown=h.teardown);let b=[],g=x;if(a&&typeof x=="object"){let A=As(x,a);g=A.doc,b=A.referencedTemplatePaths,c.push(...b)}let y=Es(g),E=ke(y),T=Is(h.parameters);return{testFlow:E,name:h.name,tags:Array.isArray(h.tags)?h.tags:void 0,parameters:T,timeout:h.timeout,skip:h.skip,fail:h.fail,only:h.only,slow:h.slow}}),m=o.base_url,f=m?{...n,baseURL:m}:n;return{suite:{beforeAll:r,afterAll:s,beforeEach:l,afterEach:d,tests:u},name:t,tags:i,use:f,referencedTemplatePaths:c}}function Is(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Qe(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=ou(t,o,r),a.type===De.STEP)Qe(a.statements,t,o);else if(a.type===De.IF_ELSE){let s=a;Qe(s.then,t,`${o}.then`),s.else&&Qe(s.else,t,`${o}.else`)}else a.type===De.WHILE_LOOP&&Qe(a.body,t,`${o}.body`)}}function ou(e,t,i){let n=Yd("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${n.slice(0,8)}-${n.slice(8,12)}-${n.slice(12,16)}-${n.slice(16,20)}-${n.slice(20,32)}`}var ks,q,_s,$s,Ps=w(()=>{"use strict";Ze();Ze();Ze();Ze();ks=5e3;q=new Map;$("click",e=>{let t=Ss(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??ks;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",q.get("click"));$("click_element_by_index",q.get("click"));$("double_click",e=>Le("double_click",e));$("double_click_on_element",q.get("double_click"));$("right_click",e=>Le("right_click",e));$("right_click_on_element",q.get("right_click"));$("hover",e=>Le("hover",e));$("hover_element_by_index",q.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Le("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",q.get("input_text"));$("clear_input",e=>Le("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",q.get("press"));$("send_keys_on_element",e=>{let t=Ss(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??ks;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Le("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",q.get("scroll"));$("scroll_up",q.get("scroll"));$("scroll_element",q.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Le("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",q.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
4304
4304
  `),s=JSON.stringify(a);return["{ const _t = Date.now(); try {",...r.map(l=>` ${l}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${s}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${s}\`);`,` await agent.assert(page, ${s}, ${JSON.stringify(t||"")});`,"} }"]}return n?i.code.split(`
4305
4305
  `):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",q.get("verify"));$("assert",q.get("verify"));$("ai_action",(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});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,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||""}');`]});$("ai_wait_until",(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"]});$("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4306
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,s]=a.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),d=`import { ${s} } from '${l}';`;i?.imports?.add(d);let c={...n,functionName:s},u=vs(c);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=vs(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],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},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]});$("done",()=>["// Done - no action needed"]);$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4307
- `):["// Skipping js_action: missing code"]});ks=5;Ms=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var Ns={};et(Ns,{createTestFlowRouter:()=>cu});import{Router as su}from"express";import*as ae from"fs/promises";import*as oe from"path";import{stringify as lu}from"yaml";function cn(e){if(!e||e.length===0)return[];let i=lu({goal:"_hook",statements:e});return ke(i).statements??[]}async function Os(e){try{let t=await ae.readdir(e,{withFileTypes:!0});for(let i of t)if(!(i.name==="node_modules"||i.name.startsWith("."))&&(i.isFile()&&i.name.endsWith(".test.yaml")||i.isDirectory()&&await Os(oe.join(e,i.name))))return!0}catch{}return!1}function cu(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=su();o.get("/api/files",async(s,l)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,c=oe.resolve(d),u=await ae.readdir(c,{withFileTypes:!0}),m=[];for(let h of u)if(h.name!=="node_modules"&&!h.name.startsWith("."))if(h.isDirectory()){let x=oe.join(c,h.name);await Os(x)&&m.push({name:h.name,type:"directory",path:x})}else h.isFile()&&h.name.endsWith(".test.yaml")&&m.push({name:h.name,type:"file",path:oe.join(c,h.name)});m.sort((h,x)=>h.type!==x.type?h.type==="directory"?-1:1:h.name.localeCompare(x.name));let f=oe.dirname(c);l.json({dir:c,parent:f!==c?f:null,entries:m,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),l.status(500).json({error:d.message})}});function r(s){if(typeof s=="string"&&s){let l=oe.resolve(s);return l.endsWith(".test.yaml")?{filePath:l}:{error:"File must be a .test.yaml file"}}return i?{filePath:i}:{error:"No file specified. Pass ?file= parameter."}}return o.get("/api/test-flow",async(s,l)=>{let d=r(s.query.file);if("error"in d)return l.status(400).json({error:d.error});let c=d.filePath;try{a?.(c);let u=await ae.readFile(c,"utf-8"),m=await ae.stat(c),f=ta(u),h=Is(u,c);if(h.suite){let x=h.suite,y={tests:x.tests.map(b=>({name:b.name,statements:b.testFlow.statements??[],teardown:b.testFlow.teardown,skip:b.skip,timeout:b.timeout,fail:b.fail,only:b.only,slow:b.slow})),beforeAll:cn(x.beforeAll),afterAll:cn(x.afterAll),beforeEach:cn(x.beforeEach),afterEach:cn(x.afterEach)},p={version:"1.3.0",baseURL:h.use?.baseURL,testGroup:y};l.json({isSuite:!0,testFlow:p,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:oe.basename(c),lastModified:m.mtimeMs})}else{let x=h.testFlow;on(u,x),l.json({isSuite:!1,testFlow:x,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:oe.basename(c),lastModified:m.mtimeMs})}}catch(u){if(u.code==="ENOENT")return l.status(404).json({error:`File not found: ${c}`});console.error("[debugger] Error loading test flow:",u),l.status(500).json({error:u.message})}}),o.put("/api/test-flow",async(s,l)=>{try{let d=r(s.query.file);if("error"in d)return l.status(400).json({error:d.error});let c=d.filePath,{testFlow:u,metadata:m}=s.body;if(!u)return l.status(400).json({error:"testFlow is required"});let f=an(u,m),h=c+".tmp";await ae.writeFile(h,f,"utf-8"),await ae.rename(h,c);let x=await ae.stat(c);l.json({success:!0,lastModified:x.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),l.status(500).json({error:d.message})}}),o}var Ds=w(()=>{"use strict";Ze();Cs()});var Ls={};et(Ls,{createIntRunnerRouter:()=>uu});import{Router as du}from"express";function uu(e){let t=du();return t.get("/api/browser-cdp",async(i,n)=>{let a=e.getCdpEndpoint();if(!a)return n.status(404).json({error:"No browser running. Start a debug session first."});n.json({cdpUrl:a})}),t.post("/api/int-runner/create-session",async(i,n)=>{try{let a=i.body.startingUrl||i.body.testFlow?.url||i.body.urlOverride,o=i.body.testFilePath,r=await e.createSession({startingUrl:a,testFilePath:o});n.json({status:"success",sessionId:r.sessionId,searchParams:""})}catch(a){console.error("[debugger] create-session error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/login",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.executeLogin(a.sessionId);n.json(o)}catch(a){console.error("[debugger] login error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/liveview-url",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.startDebug(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] start-debug error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/execute-action",async(i,n)=>{try{let{session:a,actionEntity:o,stepId:r,withSelfHealing:s,stmtUid:l,executionHistory:d}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let c=await e.executeAction(a.sessionId,o,r,{withSelfHealing:s,stmtUid:l,executionHistory:d});n.json(c)}catch(a){console.error("[debugger] execute-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/run-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:s}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let l=d=>{n.write(`data: ${JSON.stringify(d)}
4306
+ `);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,s]=a.split("#");if(r&&s){let l=r.replace(/\.(ts|js|mjs)$/,""),d=`import { ${s} } from '${l}';`;i?.imports?.add(d);let c={...n,functionName:s},u=xs(c);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=xs(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],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},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]});$("done",()=>["// Done - no action needed"]);$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4307
+ `):["// Skipping js_action: missing code"]});_s=5;$s=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var Os={};et(Os,{createTestFlowRouter:()=>lu});import{Router as ru}from"express";import*as ae from"fs/promises";import*as oe from"path";import{stringify as su}from"yaml";function cn(e){if(!e||e.length===0)return[];let i=su({goal:"_hook",statements:e});return ke(i).statements??[]}async function Cs(e){try{let t=await ae.readdir(e,{withFileTypes:!0});for(let i of t)if(!(i.name==="node_modules"||i.name.startsWith("."))&&(i.isFile()&&i.name.endsWith(".test.yaml")||i.isDirectory()&&await Cs(oe.join(e,i.name))))return!0}catch{}return!1}function lu(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=ru();o.get("/api/files",async(s,l)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,c=oe.resolve(d),u=await ae.readdir(c,{withFileTypes:!0}),m=[];for(let h of u)if(h.name!=="node_modules"&&!h.name.startsWith("."))if(h.isDirectory()){let x=oe.join(c,h.name);await Cs(x)&&m.push({name:h.name,type:"directory",path:x})}else h.isFile()&&h.name.endsWith(".test.yaml")&&m.push({name:h.name,type:"file",path:oe.join(c,h.name)});m.sort((h,x)=>h.type!==x.type?h.type==="directory"?-1:1:h.name.localeCompare(x.name));let f=oe.dirname(c);l.json({dir:c,parent:f!==c?f:null,entries:m,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),l.status(500).json({error:d.message})}});function r(s){if(typeof s=="string"&&s){let l=oe.resolve(s);return l.endsWith(".test.yaml")?{filePath:l}:{error:"File must be a .test.yaml file"}}return i?{filePath:i}:{error:"No file specified. Pass ?file= parameter."}}return o.get("/api/test-flow",async(s,l)=>{let d=r(s.query.file);if("error"in d)return l.status(400).json({error:d.error});let c=d.filePath;try{a?.(c);let u=await ae.readFile(c,"utf-8"),m=await ae.stat(c),f=ea(u),h=Ms(u,c);if(h.suite){let x=h.suite,b={tests:x.tests.map(y=>({name:y.name,statements:y.testFlow.statements??[],teardown:y.testFlow.teardown,skip:y.skip,timeout:y.timeout,fail:y.fail,only:y.only,slow:y.slow})),beforeAll:cn(x.beforeAll),afterAll:cn(x.afterAll),beforeEach:cn(x.beforeEach),afterEach:cn(x.afterEach)},g={version:"1.3.0",baseURL:h.use?.baseURL,testGroup:b};l.json({isSuite:!0,testFlow:g,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:oe.basename(c),lastModified:m.mtimeMs})}else{let x=h.testFlow;on(u,x),l.json({isSuite:!1,testFlow:x,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:oe.basename(c),lastModified:m.mtimeMs})}}catch(u){if(u.code==="ENOENT")return l.status(404).json({error:`File not found: ${c}`});console.error("[debugger] Error loading test flow:",u),l.status(500).json({error:u.message})}}),o.put("/api/test-flow",async(s,l)=>{try{let d=r(s.query.file);if("error"in d)return l.status(400).json({error:d.error});let c=d.filePath,{testFlow:u,metadata:m}=s.body;if(!u)return l.status(400).json({error:"testFlow is required"});let f=an(u,m),h=c+".tmp";await ae.writeFile(h,f,"utf-8"),await ae.rename(h,c);let x=await ae.stat(c);l.json({success:!0,lastModified:x.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),l.status(500).json({error:d.message})}}),o}var Ns=w(()=>{"use strict";Ze();Ps()});var Ds={};et(Ds,{createIntRunnerRouter:()=>du});import{Router as cu}from"express";function du(e){let t=cu();return t.get("/api/browser-cdp",async(i,n)=>{let a=e.getCdpEndpoint();if(!a)return n.status(404).json({error:"No browser running. Start a debug session first."});n.json({cdpUrl:a})}),t.post("/api/int-runner/create-session",async(i,n)=>{try{let a=i.body.startingUrl||i.body.testFlow?.url||i.body.urlOverride,o=i.body.testFilePath,r=await e.createSession({startingUrl:a,testFilePath:o});n.json({status:"success",sessionId:r.sessionId,searchParams:""})}catch(a){console.error("[debugger] create-session error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/login",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.executeLogin(a.sessionId);n.json(o)}catch(a){console.error("[debugger] login error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/liveview-url",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.startDebug(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] start-debug error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/execute-action",async(i,n)=>{try{let{session:a,actionEntity:o,stepId:r,withSelfHealing:s,stmtUid:l,executionHistory:d}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let c=await e.executeAction(a.sessionId,o,r,{withSelfHealing:s,stmtUid:l,executionHistory:d});n.json(c)}catch(a){console.error("[debugger] execute-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/run-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:s}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let l=d=>{n.write(`data: ${JSON.stringify(d)}
4308
4308
 
4309
4309
  `)};try{await e.runStep(a.sessionId,o,r,l,s)}catch(d){l({type:"error",data:{message:d.message}})}finally{n.end()}}),t.post("/api/int-runner/execute-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:s,maxSteps:l}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let d=c=>{n.write(`data: ${JSON.stringify(c)}
4310
4310
 
4311
4311
  `)};try{await e.runStep(a.sessionId,o,r,d,s)}catch(c){d({type:"error",data:{message:c.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-run-step",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=e.stopRunStep(a.sessionId);n.json({status:"success",aborted:o})}catch(a){console.error("[debugger] stop-run-step error:",a),n.status(500).json({status:"error",aborted:!1,details:a.message})}}),t.post("/api/int-runner/evaluate",async(i,n)=>{try{let{session:a,statement:o,stepId:r,executionHistory:s}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let l=await e.evaluate(a.sessionId,o,s);n.json(l)}catch(a){console.error("[debugger] evaluate error:",a),n.status(500).json({status:"error",conclusion:"unknown",explanation:a.message})}}),t.post("/api/int-runner/generate-action",async(i,n)=>{try{let{session:a,statement:o,stepId:r,executionHistory:s,usePureVision:l,includeDebugInfo:d}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let c=await e.generateAction(a.sessionId,o,r,{executionHistory:s,usePureVision:l,includeDebugInfo:d});n.json(c)}catch(a){console.error("[debugger] generate-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/screenshot",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.takeScreenshot(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] screenshot error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/start-recorder",async(i,n)=>{let{session:a,testIdAttributeName:o}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let r=s=>{n.write(`data: ${JSON.stringify(s)}
4312
4312
 
4313
- `)};try{await e.startRecorder(a.sessionId,r,o)}catch(s){r({type:"error",data:{message:s.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-recorder",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.stopRecorder(a.sessionId),n.json({status:"success"})}catch(a){console.error("[debugger] stop-recorder error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/terminate-session",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(a.sessionId),n.json({status:"success",details:`Session ${a.sessionId} terminated`})}catch(a){console.error("[debugger] terminate-session error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/session-status",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"timed_out"});n.json({status:"active",remainingSeconds:9999})}),t}var Rs=w(()=>{"use strict"});import Fs from"express";import*as Xe from"path";import*as Wr from"fs/promises";import*as Ur from"os";F();F();wt();Be();import{z as yr}from"zod";var td=yr.object({instruction:yr.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function xr(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:td,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Ue(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 ft(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}ye();F();import{generateText as id}from"ai";import{convert as nd}from"html-to-text";async function ad(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()}g.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(g.info(`message_url: ${u}`),!u){let h=(c.message||{}).headers||{},x=h.subject||"",y=h.from||"",p=h.to||"";if(i.from_email&&!y.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!x.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:x,from:y,to:p,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:h["message-id"]||""});continue}let m=u.split("/"),f=m[m.length-1];if(g.info(`Storage key: ${f}`),f){let h=`https://api.mailgun.net/v3/domains/${a}/messages/${f}`;try{let x=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(x.ok){let y=await x.json(),p=y.Subject||"",b=y.From||"",E=y.To||"",T=y.Date||"",A=y["Message-Id"]||"";g.info(`subject: ${p}`),g.info(`from_addr: ${b}`),g.info(`to_addr: ${E}`),g.info(`date: ${T}`),g.info(`message_id: ${A}`);let I=y["body-html"]||y["body-plain"]||"";if(I&&I.includes("<")&&(I=nd(I)),g.info(`Body: ${I.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!I.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:p,from:b,to:E,date:T,body:I,message_id:A});continue}else g.warn(`Messages API returned ${x.status}`)}catch(x){g.warn(`Failed to parse JSON response: ${x}`)}}try{let h=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!h.ok){g.warn(`Could not fetch stored message: ${h.status}`);continue}let x=await h.text();g.info(`Fallback: Raw email length: ${x.length}`);let y=x.split(`
4314
- `),p=!0,b={},E="";for(let O=0;O<y.length;O++){let K=y[O];if(K.trim()===""&&p){p=!1;continue}if(p){let J=K.match(/^([^:]+):\s*(.+)$/);J&&(b[J[1].toLowerCase()]=J[2])}else E+=K+`
4315
- `}let T=b.subject||"",A=b.from||"",I=b.to||"",D=b.date||"",R=b["message-id"]||"";if(i.subject&&!T.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!E.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:T,from:A,to:I,date:D,body:E.trim(),message_id:R})}catch(h){g.warn(`Error fetching raw message: ${h}`)}}if(o.length>0){try{o.sort((u,m)=>{let f=new Date(u.date).getTime();return new Date(m.date).getTime()-f})}catch{}let c=o[0];return g.info(`Returning most recent email: ${c.subject}`),[c]}return o}catch(r){throw g.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function od(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4313
+ `)};try{await e.startRecorder(a.sessionId,r,o)}catch(s){r({type:"error",data:{message:s.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-recorder",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.stopRecorder(a.sessionId),n.json({status:"success"})}catch(a){console.error("[debugger] stop-recorder error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/terminate-session",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(a.sessionId),n.json({status:"success",details:`Session ${a.sessionId} terminated`})}catch(a){console.error("[debugger] terminate-session error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/session-status",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"timed_out"});n.json({status:"active",remainingSeconds:9999})}),t}var Ls=w(()=>{"use strict"});import Rs from"express";import*as Xe from"path";import*as Hr from"fs/promises";import*as Wr from"os";F();F();wt();Be();import{z as br}from"zod";var ed=br.object({instruction:br.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function yr(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:ed,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Ue(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 ft(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}ye();F();import{generateText as td}from"ai";import{convert as id}from"html-to-text";async function nd(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()}p.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(p.info(`message_url: ${u}`),!u){let h=(c.message||{}).headers||{},x=h.subject||"",b=h.from||"",g=h.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!g.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!x.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:x,from:b,to:g,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:h["message-id"]||""});continue}let m=u.split("/"),f=m[m.length-1];if(p.info(`Storage key: ${f}`),f){let h=`https://api.mailgun.net/v3/domains/${a}/messages/${f}`;try{let x=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(x.ok){let b=await x.json(),g=b.Subject||"",y=b.From||"",E=b.To||"",T=b.Date||"",A=b["Message-Id"]||"";p.info(`subject: ${g}`),p.info(`from_addr: ${y}`),p.info(`to_addr: ${E}`),p.info(`date: ${T}`),p.info(`message_id: ${A}`);let I=b["body-html"]||b["body-plain"]||"";if(I&&I.includes("<")&&(I=id(I)),p.info(`Body: ${I.substring(0,200)}...`),i.subject&&!g.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!I.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:g,from:y,to:E,date:T,body:I,message_id:A});continue}else p.warn(`Messages API returned ${x.status}`)}catch(x){p.warn(`Failed to parse JSON response: ${x}`)}}try{let h=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!h.ok){p.warn(`Could not fetch stored message: ${h.status}`);continue}let x=await h.text();p.info(`Fallback: Raw email length: ${x.length}`);let b=x.split(`
4314
+ `),g=!0,y={},E="";for(let O=0;O<b.length;O++){let K=b[O];if(K.trim()===""&&g){g=!1;continue}if(g){let J=K.match(/^([^:]+):\s*(.+)$/);J&&(y[J[1].toLowerCase()]=J[2])}else E+=K+`
4315
+ `}let T=y.subject||"",A=y.from||"",I=y.to||"",N=y.date||"",R=y["message-id"]||"";if(i.subject&&!T.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!E.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:T,from:A,to:I,date:N,body:E.trim(),message_id:R})}catch(h){p.warn(`Error fetching raw message: ${h}`)}}if(o.length>0){try{o.sort((u,m)=>{let f=new Date(u.date).getTime();return new Date(m.date).getTime()-f})}catch{}let c=o[0];return p.info(`Returning most recent email: ${c.subject}`),[c]}return o}catch(r){throw p.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function ad(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4316
4316
 
4317
4317
  Please carefully examine the email content and look for:
4318
4318
  1. Numeric codes (usually 4-8 digits)
@@ -4369,24 +4369,24 @@ Examples of what to extract:
4369
4369
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4370
4370
 
4371
4371
  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+`
4372
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function rd(e,t,i){try{let n=`${t}
4372
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function od(e,t,i){try{let n=`${t}
4373
4373
  ---
4374
4374
  Email Content:
4375
4375
  ---
4376
4376
  ${e}
4377
4377
  ---
4378
- `,a=we(i);return(await id({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:be(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw g.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function vr(e,t){g.info(`extract_email_content:
4378
+ `,a=we(i);return(await td({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:be(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw p.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function xr(e,t){p.info(`extract_email_content:
4379
4379
  forward_email: ${t.forward_email}
4380
4380
  extraction_type: ${t.extraction_type}
4381
4381
  filters: ${JSON.stringify(t.filters||{})}
4382
4382
  timeout: ${t.timeout||60}
4383
- 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=od(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(g.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,g.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await ad(e,t.forward_email,d);if(c.length>0){g.info(`Found ${c.length} emails matching criteria`);let u=[];for(let m of c){let f=`Subject: ${m.subject}
4383
+ 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=ad(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(p.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,p.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await nd(e,t.forward_email,d);if(c.length>0){p.info(`Found ${c.length} emails matching criteria`);let u=[];for(let m of c){let f=`Subject: ${m.subject}
4384
4384
  From: ${m.from}
4385
4385
  To: ${m.to}
4386
4386
  Date: ${m.date}
4387
4387
 
4388
4388
  Body:
4389
- ${m.body}`,h=await rd(f,a,t.model);g.info(`Extracted content: ${h}`),h&&h!=="NOT_FOUND"&&u.push({content:h,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[0],f=`$email_${t.extraction_type}`;t.extraction_type==="custom"?f="$email_extracted_content":t.extraction_type==="activation_link"?f="$email_magic_link":t.extraction_type==="verification_code"&&(f="$email_otp_code");let h=(new Date().getTime()-o.getTime())/1e3;return g.info(`Successfully extracted content after ${s} attempts in ${h.toFixed(1)} seconds`),{data:m.content,result_variable:f,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else g.info(`Found emails but no extractable content in attempt ${s}`)}else g.info(`No emails found in attempt ${s}`)}catch(d){g.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){g.info("Not enough time for another polling attempt");break}g.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 g.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}F();Z();import{z as _e}from"zod";function _r(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var kr=class{getMailgunConfig(){let e=B().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 vr(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(/^\$/,"")||_r(o.extraction_type);i.variableStore.set(l,s.data),g.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)} },`,"});"]}},sd=_e.object({forward_email:_e.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:_e.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:_e.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:_e.string().optional().describe("Filter emails by sender address"),filter_to_email:_e.string().optional().describe("Filter emails by recipient address"),filter_subject:_e.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:_e.string().optional().describe("Filter emails by body content (partial match)"),timeout:_e.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Sr(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:sd,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:f}=n;g.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let h={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,h,f);let x=_r(o);return{success:!0,actionEntity:h,message:`Extracted ${o} and saved to $${x}`}}catch(h){return{success:!1,error:h.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:h.message}}}}})}bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();var en=null;async function he(){if(en)return en;let e=(await Promise.resolve().then(()=>(Xi(),Vi))).default;return en=new e,en}async function Er(e){let t=await he(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return ur(e,i),Go(e,n),Eo(e,a),Zo(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Tr(e){let t=await he(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return Uo(e,i),Wo(e,n),ko(e,a),"Navigate to URLs, go back, or reload the page"}async function Ar(e){let t=await he(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return cr(e,i),Ko(e,n),vo(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function $r(e){let t=await he(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Po(e,i),No(e,n),$o(e,a),"Scroll the page or scroll to specific text/elements"}async function Mr(e){let t=await he(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Xo(e,i),lo(e,n),"Switch between browser tabs or close tabs"}async function Ir(e){let t=await he(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return mo(e,i),yo(e,n),"Upload files or wait for downloads to complete"}async function Pr(e){let t=await he(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return Fo(e,i),no(e,n),oo(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Cr(e){let t=await he(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return fo(e,i),Ao(e,n),Jo(e,a),xr(e),"Wait for conditions, save variables, or complete tasks"}async function Or(e){let t=(await he()).getAction("generate_2fa_code");tr(e,t);let i=new kr;return(await Promise.resolve().then(()=>(Xi(),Vi))).default.registerAction("extract_email_content",i),Sr(e,i),"Generate 2FA codes or extract email/activation codes"}async function Nr(e){let t=await he(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return ar(e,i),rr(e,n),eo(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}xe();var ld=[Er(H),Tr(H),Ar(H),$r(H),Mr(H),Ir(H),Pr(H),Cr(H),Nr(H),Or(H)],_x=Promise.all(ld);rt();qt();Ie();Yt();F();import{chromium as cv,firefox as dv,webkit as uv}from"playwright";qt();var xd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(xd||{});wt();Ne();Jn();Q();qt();Ie();F();Ie();F();import{generateSync as Ov,createGuardrails as _d}from"otplib";var Nv=_d({MIN_SECRET_BYTES:1});var Zt=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Zt||{});_t();F();wt();vi();yi();Be();li();di();ci();Fe();mi();gi();lt();ct();xe();rt();st();Ci();Ne();dt();ut();Ge();ht();mt();Jn();Q();qt();Ie();Yt();ye();nt();at();He();Xn();ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();Gi();_t();G();Oe();F();Z();gt();zi();L();ge();var Qt=class{page;agent;testDir=process.cwd();sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;recorderStopResolver;recorderEnabled=!1;constructor(t,i){this.page=t,this.agent=i}cdpEndpoint=null;setCdpEndpoint(t){this.cdpEndpoint=t}getCdpEndpoint(){if(this.cdpEndpoint)return this.cdpEndpoint;let t=this.page.context().browser();if(!t)return null;let i=t.wsEndpoint?.();return typeof i=="string"?i:null}async createSession(t){return t?.testFilePath&&(this.testDir=Xe.dirname(t.testFilePath)),{sessionId:this.sessionId}}async executeLogin(t){return{status:"success",details:"Handled by Playwright"}}async ensureBrowser(t){return{page:this.page,liveviewUrl:""}}async startDebug(t){return{sessionId:this.sessionId,liveviewUrl:"",browserWsUrl:""}}async executeAction(t,i,n,a){let o=i.action_data||i.action;if(!o)throw new Error("ActionEntity has no action_data");if(console.error(`[pw-sandbox] executeAction stepId=${JSON.stringify(n)} action_name=${JSON.stringify(o.action_name)} locator=${JSON.stringify(i.locator)} kwargs=${JSON.stringify(o.kwargs)}`),o.action_name==="js_code"&&n==="prelude"){if(this.page.url()==="about:blank"){let m=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];m&&await this.page.goto(m,{waitUntil:"domcontentloaded"})}return{status:"success"}}if(o.action_name==="js_code"&&o.kwargs?.isSync===!0)return this.executeCode(t,o.kwargs.code||"");if(o.action_name==="function"&&o.kwargs?.functionName?.includes("#"))return this.executeFunction(o.kwargs);let r=i.action_description||o.action_name,s=a?.stmtUid,l=!!a?.withSelfHealing&&ze.canSelfHeal(i);s&&this.agent.getNewActionEntities().delete(s);let d=await this.agent.step(this.page,async()=>{await this.agent.execAction(o.action_name,this.page,i)},r,n,s,l),c=this.agent.getAgentNote(),u={...d,status:"success"};if(c&&(u.details=c),s){let m=this.agent.getNewActionEntities().get(s);if(m){let{element_index:f,...h}=m.action_data?.kwargs||{};u.newActionEntity={...m,action_data:m.action_data?{...m.action_data,kwargs:h}:m.action_data}}}return u}async runStep(t,i,n,a,o){let r=[];this.abortController=new AbortController;try{let s=await this.agent.run(this.page,i,n,{onAction:l=>{r.push(l),a({type:Zt.Action,data:{action_entity:l}})}});return a({type:Zt.Completion,data:{success:s?.success??!0,details:s?.details}}),{success:s?.success??!0,actions:r,details:s?.details}}finally{this.abortController=null}}async executeFunction(t){let i=t.functionName,[n,a]=i.split("#");try{let s=(await import(n.startsWith(".")?Xe.resolve(this.testDir,n):n))[a];if(typeof s!="function")return{status:"error",details:`Export "${a}" not found or not a function in ${n}`};let d=(Array.isArray(t.args)?t.args.map(String):[]).map(c=>{if(c==="page")return this.page;if(c==="agent")return this.agent;if(c!=="request")return c==="testContext"?this.agent._getContext?.()?.variableStore:c.startsWith("$")?this.agent.agentServices.readVariable(c.substring(1)):c});return await s(...d),{status:"success"}}catch(o){let r=o instanceof Error?o.message:String(o);return{status:"error",details:`Function call failed: ${i} \u2014 ${r}`}}}async executeCode(t,i){try{return{status:"success",result:await new Function("page","agent",`return (async () => { return (${i}); })();`)(this.page,this.agent)}}catch(n){return{status:"error",details:n instanceof Error?n.message:String(n)}}}stopRunStep(t){return this.abortController?(this.abortController.abort(),!0):!1}async evaluate(t,i,n){try{let a=await this.agent.evaluate(this.page,i);return{status:"success",conclusion:a?"true":"false",explanation:a?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(a){return{status:"error",conclusion:"unknown",explanation:a.message}}}async generateAction(t,i,n,a){let o=await this.agent.generate(this.page,i,n,a?.usePureVision),r=o.actions?.[0];return r?{status:"success",action:r,explanation:o.details,debugInfo:o.debugInfo,completes_instruction:o.success}:{status:"error",explanation:o.details||"Failed to generate action",debugInfo:o.debugInfo}}async takeScreenshot(t){let i=await this.page.screenshot(),n=Xe.join(Ur.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await Wr.writeFile(n,i),{screenshot:i.toString("base64"),screenshotPath:n}}async startRecorder(t,i,n){let a=this.page.context(),o=new Promise(s=>{this.recorderStopResolver=s}),r={actionAdded:(s,l,d)=>{i({type:"actionAdded",action:l.action,code:d,timestamp:Date.now()})},actionUpdated:(s,l,d)=>{i({type:"actionUpdated",action:l.action,code:d,timestamp:Date.now()})},signalAdded:(s,l)=>{i({type:"signal",signal:l.signal,timestamp:Date.now()})}};if(this.recorderEnabled)a._onRecorderEventSink=r;else{let s=["x-pw-tool-item.pick-locator, x-pw-tool-item.visibility, x-pw-tool-item.text, x-pw-tool-item.value, x-pw-tool-item.snapshot { display: none !important; }","x-pw-overlay { left: 10px !important; }"].join("\\n");await a.addInitScript(`(() => {
4389
+ ${m.body}`,h=await od(f,a,t.model);p.info(`Extracted content: ${h}`),h&&h!=="NOT_FOUND"&&u.push({content:h,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[0],f=`$email_${t.extraction_type}`;t.extraction_type==="custom"?f="$email_extracted_content":t.extraction_type==="activation_link"?f="$email_magic_link":t.extraction_type==="verification_code"&&(f="$email_otp_code");let h=(new Date().getTime()-o.getTime())/1e3;return p.info(`Successfully extracted content after ${s} attempts in ${h.toFixed(1)} seconds`),{data:m.content,result_variable:f,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${s})`}}else p.info(`Found emails but no extractable content in attempt ${s}`)}else p.info(`No emails found in attempt ${s}`)}catch(d){p.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){p.info("Not enough time for another polling attempt");break}p.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 p.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}F();Z();import{z as _e}from"zod";function vr(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var _r=class{getMailgunConfig(){let e=B().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 xr(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(/^\$/,"")||vr(o.extraction_type);i.variableStore.set(l,s.data),p.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)} },`,"});"]}},rd=_e.object({forward_email:_e.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:_e.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:_e.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:_e.string().optional().describe("Filter emails by sender address"),filter_to_email:_e.string().optional().describe("Filter emails by recipient address"),filter_subject:_e.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:_e.string().optional().describe("Filter emails by body content (partial match)"),timeout:_e.number().optional().describe("Timeout in seconds for polling (default: 60)")});function kr(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:rd,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:f}=n;p.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let h={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,h,f);let x=vr(o);return{success:!0,actionEntity:h,message:`Extracted ${o} and saved to $${x}`}}catch(h){return{success:!1,error:h.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:h.message}}}}})}bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();var en=null;async function he(){if(en)return en;let e=(await Promise.resolve().then(()=>(Xi(),Vi))).default;return en=new e,en}async function Sr(e){let t=await he(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return dr(e,i),Bo(e,n),So(e,a),qo(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Er(e){let t=await he(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return Wo(e,i),Ho(e,n),_o(e,a),"Navigate to URLs, go back, or reload the page"}async function Tr(e){let t=await he(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return lr(e,i),jo(e,n),xo(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Ar(e){let t=await he(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Io(e,i),Oo(e,n),Ao(e,a),"Scroll the page or scroll to specific text/elements"}async function $r(e){let t=await he(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Vo(e,i),so(e,n),"Switch between browser tabs or close tabs"}async function Mr(e){let t=await he(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return ho(e,i),bo(e,n),"Upload files or wait for downloads to complete"}async function Ir(e){let t=await he(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return Ro(e,i),io(e,n),ao(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Pr(e){let t=await he(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return go(e,i),To(e,n),Yo(e,a),yr(e),"Wait for conditions, save variables, or complete tasks"}async function Cr(e){let t=(await he()).getAction("generate_2fa_code");er(e,t);let i=new _r;return(await Promise.resolve().then(()=>(Xi(),Vi))).default.registerAction("extract_email_content",i),kr(e,i),"Generate 2FA codes or extract email/activation codes"}async function Or(e){let t=await he(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return nr(e,i),or(e,n),Qa(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}xe();var sd=[Sr(H),Er(H),Tr(H),Ar(H),$r(H),Mr(H),Ir(H),Pr(H),Or(H),Cr(H)],vx=Promise.all(sd);rt();qt();Ie();Yt();F();import{chromium as lv,firefox as cv,webkit as dv}from"playwright";qt();var yd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(yd||{});wt();Ne();Yn();Q();qt();Ie();F();Ie();F();import{generateSync as Cv,createGuardrails as vd}from"otplib";var Ov=vd({MIN_SECRET_BYTES:1});var Zt=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Zt||{});_t();F();wt();vi();yi();Be();li();di();ci();Fe();mi();gi();lt();ct();xe();rt();st();Ci();Ne();dt();ut();Ge();ht();mt();Yn();Q();qt();Ie();Yt();ye();nt();He();at();Vn();ki();Si();Ei();Ti();Ai();$i();Mi();Ii();Pi();Ri();Fi();bt();yt();xt();vt();kt();St();Et();Tt();At();$t();Mt();Pt();Ot();Nt();Dt();Lt();Rt();Ft();Ht();Wt();Ut();Bt();Gt();jt();Kt();zt();Vt();Gi();_t();G();Oe();F();Z();gt();zi();L();ge();var Qt=class{page;agent;testDir=process.cwd();sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;recorderStopResolver;recorderEnabled=!1;constructor(t,i){this.page=t,this.agent=i}cdpEndpoint=null;setCdpEndpoint(t){this.cdpEndpoint=t}getCdpEndpoint(){if(this.cdpEndpoint)return this.cdpEndpoint;let t=this.page.context().browser();if(!t)return null;let i=t.wsEndpoint?.();return typeof i=="string"?i:null}async createSession(t){return t?.testFilePath&&(this.testDir=Xe.dirname(t.testFilePath)),{sessionId:this.sessionId}}async executeLogin(t){return{status:"success",details:"Handled by Playwright"}}async ensureBrowser(t){return{page:this.page,liveviewUrl:""}}async startDebug(t){return{sessionId:this.sessionId,liveviewUrl:"",browserWsUrl:""}}async executeAction(t,i,n,a){let o=i.action_data||i.action;if(!o)throw new Error("ActionEntity has no action_data");if(console.error(`[pw-sandbox] executeAction stepId=${JSON.stringify(n)} action_name=${JSON.stringify(o.action_name)} locator=${JSON.stringify(i.locator)} kwargs=${JSON.stringify(o.kwargs)}`),o.action_name==="js_code"&&n==="prelude"){if(this.page.url()==="about:blank"){let m=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];m&&await this.page.goto(m,{waitUntil:"domcontentloaded"})}return{status:"success"}}if(o.action_name==="js_code"&&o.kwargs?.isSync===!0)return this.executeCode(t,o.kwargs.code||"");if(o.action_name==="function"&&o.kwargs?.functionName?.includes("#"))return this.executeFunction(o.kwargs);let r=i.action_description||o.action_name,s=a?.stmtUid,l=!!a?.withSelfHealing&&ze.canSelfHeal(i);s&&this.agent.getNewActionEntities().delete(s);let d=await this.agent.step(this.page,async()=>{await this.agent.execAction(o.action_name,this.page,i)},r,n,s,l),c=this.agent.getAgentNote(),u={...d,status:"success"};if(c&&(u.details=c),s){let m=this.agent.getNewActionEntities().get(s);if(m){let{element_index:f,...h}=m.action_data?.kwargs||{};u.newActionEntity={...m,action_data:m.action_data?{...m.action_data,kwargs:h}:m.action_data}}}return u}async runStep(t,i,n,a,o){let r=[];this.abortController=new AbortController;try{let s=await this.agent.run(this.page,i,n,{onAction:l=>{r.push(l),a({type:Zt.Action,data:{action_entity:l}})}});return a({type:Zt.Completion,data:{success:s?.success??!0,details:s?.details}}),{success:s?.success??!0,actions:r,details:s?.details}}finally{this.abortController=null}}async executeFunction(t){let i=t.functionName,[n,a]=i.split("#");try{let s=(await import(n.startsWith(".")?Xe.resolve(this.testDir,n):n))[a];if(typeof s!="function")return{status:"error",details:`Export "${a}" not found or not a function in ${n}`};let d=(Array.isArray(t.args)?t.args.map(String):[]).map(c=>{if(c==="page")return this.page;if(c==="agent")return this.agent;if(c!=="request")return c==="testContext"?this.agent._getContext?.()?.variableStore:c.startsWith("$")?this.agent.agentServices.readVariable(c.substring(1)):c});return await s(...d),{status:"success"}}catch(o){let r=o instanceof Error?o.message:String(o);return{status:"error",details:`Function call failed: ${i} \u2014 ${r}`}}}async executeCode(t,i){try{return{status:"success",result:await new Function("page","agent",`return (async () => { return (${i}); })();`)(this.page,this.agent)}}catch(n){return{status:"error",details:n instanceof Error?n.message:String(n)}}}stopRunStep(t){return this.abortController?(this.abortController.abort(),!0):!1}async evaluate(t,i,n){try{let a=await this.agent.evaluate(this.page,i);return{status:"success",conclusion:a?"true":"false",explanation:a?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(a){return{status:"error",conclusion:"unknown",explanation:a.message}}}async generateAction(t,i,n,a){let o=await this.agent.generate(this.page,i,n,a?.usePureVision),r=o.actions?.[0];return r?{status:"success",action:r,explanation:o.details,debugInfo:o.debugInfo,completes_instruction:o.success}:{status:"error",explanation:o.details||"Failed to generate action",debugInfo:o.debugInfo}}async takeScreenshot(t){let i=await this.page.screenshot(),n=Xe.join(Wr.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await Hr.writeFile(n,i),{screenshot:i.toString("base64"),screenshotPath:n}}async startRecorder(t,i,n){let a=this.page.context(),o=new Promise(s=>{this.recorderStopResolver=s}),r={actionAdded:(s,l,d)=>{i({type:"actionAdded",action:l.action,code:d,timestamp:Date.now()})},actionUpdated:(s,l,d)=>{i({type:"actionUpdated",action:l.action,code:d,timestamp:Date.now()})},signalAdded:(s,l)=>{i({type:"signal",signal:l.signal,timestamp:Date.now()})}};if(this.recorderEnabled)a._onRecorderEventSink=r;else{let s=["x-pw-tool-item.pick-locator, x-pw-tool-item.visibility, x-pw-tool-item.text, x-pw-tool-item.value, x-pw-tool-item.snapshot { display: none !important; }","x-pw-overlay { left: 10px !important; }"].join("\\n");await a.addInitScript(`(() => {
4390
4390
  const orig = Element.prototype.attachShadow;
4391
4391
  Element.prototype.attachShadow = function(init) {
4392
4392
  const shadow = orig.call(this, init);
@@ -4408,4 +4408,4 @@ ${m.body}`,h=await rd(f,a,t.model);g.info(`Extracted content: ${h}`),h&&h!=="NOT
4408
4408
  }
4409
4409
  return shadow;
4410
4410
  };
4411
- })()`).catch(()=>{});await a._enableRecorder({mode:"recording",recorderMode:"api",handleSIGINT:!1,omitCallTracking:!0,testIdAttributeName:n||"data-testid"},r),await this.page.evaluate(()=>window.__pw_recorderSetMode?.("standby")).catch(()=>{})}this.recorderEnabled=!0,await o}async stopRecorder(t){this.page.context()._onRecorderEventSink=void 0,this.recorderStopResolver&&(this.recorderStopResolver(),this.recorderStopResolver=void 0)}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function ST(e){let{yamlFilePath:t,port:i,cdpPort:n,page:a,agent:o}=e,r=new Qt(a,o);if(n)try{let f=await fetch(`http://localhost:${n}/json/version`);if(f.ok){let h=await f.json();h.webSocketDebuggerUrl&&(r.setCdpEndpoint(h.webSocketDebuggerUrl),console.error(`[debugger] CDP endpoint: ${h.webSocketDebuggerUrl}`))}}catch{console.error(`[debugger] Could not fetch CDP endpoint from port ${n}`)}let s=Fs();s.use(Fs.json({limit:"10mb"})),s.use((f,h,x)=>{if(h.setHeader("Access-Control-Allow-Origin","*"),h.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),h.setHeader("Access-Control-Allow-Headers","Content-Type, Accept, Cache-Control, Idempotency-Key"),f.method==="OPTIONS")return h.sendStatus(204);x()});let{createTestFlowRouter:l}=await Promise.resolve().then(()=>(Ds(),Ns)),{createIntRunnerRouter:d}=await Promise.resolve().then(()=>(Rs(),Ls)),c=await import("path");s.use(l({initialDir:c.dirname(t),initialFile:t})),s.use(d(r));let u=await new Promise((f,h)=>{let x=s.listen(i,"localhost",()=>f(x));x.on("error",h)});return{url:`http://localhost:${i}`,close:async()=>{await r.cleanupAll(),await new Promise((f,h)=>{u.close(x=>x?h(x):f())})}}}export{Qt as PlaywrightSandboxService,ST as startPlaywrightDebugServer};
4411
+ })()`).catch(()=>{});await a._enableRecorder({mode:"recording",recorderMode:"api",handleSIGINT:!1,omitCallTracking:!0,testIdAttributeName:n||"data-testid"},r),await this.page.evaluate(()=>window.__pw_recorderSetMode?.("standby")).catch(()=>{})}this.recorderEnabled=!0,await o}async stopRecorder(t){this.page.context()._onRecorderEventSink=void 0,this.recorderStopResolver&&(this.recorderStopResolver(),this.recorderStopResolver=void 0)}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function kT(e){let{yamlFilePath:t,port:i,cdpPort:n,page:a,agent:o}=e,r=new Qt(a,o);if(n)try{let f=await fetch(`http://localhost:${n}/json/version`);if(f.ok){let h=await f.json();h.webSocketDebuggerUrl&&(r.setCdpEndpoint(h.webSocketDebuggerUrl),console.error(`[debugger] CDP endpoint: ${h.webSocketDebuggerUrl}`))}}catch{console.error(`[debugger] Could not fetch CDP endpoint from port ${n}`)}let s=Rs();s.use(Rs.json({limit:"10mb"})),s.use((f,h,x)=>{if(h.setHeader("Access-Control-Allow-Origin","*"),h.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),h.setHeader("Access-Control-Allow-Headers","Content-Type, Accept, Cache-Control, Idempotency-Key"),f.method==="OPTIONS")return h.sendStatus(204);x()});let{createTestFlowRouter:l}=await Promise.resolve().then(()=>(Ns(),Os)),{createIntRunnerRouter:d}=await Promise.resolve().then(()=>(Ls(),Ds)),c=await import("path");s.use(l({initialDir:c.dirname(t),initialFile:t})),s.use(d(r));let u=await new Promise((f,h)=>{let x=s.listen(i,"localhost",()=>f(x));x.on("error",h)});return{url:`http://localhost:${i}`,close:async()=>{await r.cleanupAll(),await new Promise((f,h)=>{u.close(x=>x?h(x):f())})}}}export{Qt as PlaywrightSandboxService,kT as startPlaywrightDebugServer};