shiplightai 0.1.40 → 0.1.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/debugger-pw.cjs +74 -76
- package/dist/cjs/fixture.cjs +73 -75
- package/dist/cjs/index.cjs +90 -92
- package/dist/cjs/reporter.cjs +4 -4
- package/dist/cli.js +12 -12
- package/dist/debugger-pw.js +74 -76
- package/dist/fixture.js +73 -75
- package/dist/index.js +90 -92
- package/dist/reporter.js +7 -7
- package/package.json +23 -21
package/dist/cjs/debugger-pw.cjs
CHANGED
|
@@ -1,6 +1,21 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var ol=Object.create;var li=Object.defineProperty;var rl=Object.getOwnPropertyDescriptor;var sl=Object.getOwnPropertyNames;var ll=Object.getPrototypeOf,cl=Object.prototype.hasOwnProperty;var w=(e,t)=>()=>(e&&(t=e(e=0)),t);var He=(e,t)=>{for(var i in t)li(e,i,{get:t[i],enumerable:!0})},ka=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of sl(t))!cl.call(e,a)&&a!==i&&li(e,a,{get:()=>t[a],enumerable:!(n=rl(t,a))||n.enumerable});return e};var ee=(e,t,i)=>(i=e!=null?ol(ll(e)):{},ka(t||!e||!e.__esModule?li(i,"default",{value:e,enumerable:!0}):i,e)),dl=e=>ka(li({},"__esModule",{value:!0}),e);function G(){return Sa.getConfig()}var ul,Sa,ci,te=w(()=>{"use strict";ul=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}},Sa=new ul,ci=Sa});var hl,ml,g,H=w(()=>{"use strict";te();hl=class{getLevel(){return ci.get("logLevel")}isStderrOnly(){return ci.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){ci.set("logLevel",e)}},ml=new hl,g=ml});var kn,pl,k,ie=w(()=>{"use strict";te();kn=require("fs"),pl=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{(0,kn.appendFileSync)(e,`
|
|
2
|
+
=== Agent Execution Log ===
|
|
3
|
+
Started: ${new Date().toISOString()}
|
|
4
|
+
|
|
5
|
+
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=G().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,kn.appendFileSync)(t,`[${i}] ${e}
|
|
6
|
+
`)}catch{}}}section(e){this.log(`
|
|
7
|
+
${"=".repeat(60)}
|
|
8
|
+
${e}
|
|
9
|
+
${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,a=i.completionTokens||i.outputTokens||0,o=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${a} completion = ${o} total`)}}thinking(e){this.log(`Native Thinking:
|
|
10
|
+
${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
11
|
+
${e}`),this.log(`
|
|
12
|
+
User Prompt:
|
|
13
|
+
${t}`)}response(e){this.log(`LLM Response:
|
|
14
|
+
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!G().agentLogPath}},k=new pl});var En,gl,fl,wl,Ea,di,Sn,Ta,Tn,be=w(()=>{"use strict";En=Object.defineProperty,gl=Object.getOwnPropertyDescriptor,fl=Object.getOwnPropertyNames,wl=Object.prototype.hasOwnProperty,Ea=(e,t)=>()=>(e&&(t=e(e=0)),t),di=(e,t)=>{for(var i in t)En(e,i,{get:t[i],enumerable:!0})},Sn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of fl(t))!wl.call(e,a)&&a!==i&&En(e,a,{get:()=>t[a],enumerable:!(n=gl(t,a))||n.enumerable});return e},Ta=(e,t,i)=>(Sn(e,t,"default"),i&&Sn(i,t,"default")),Tn=e=>Sn(En({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??$n}function bl(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function C(e,t){let i=Te(t);return i?new Function("page",`return ${i}`)(e):null}async function An(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 yl(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 vl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function xl(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 Te(e){let t=vl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=xl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var ui,nt,$n,me,M,R=w(()=>{"use strict";be();ui={};di(ui,{ACTION_TIMEOUT:()=>$n,GOTO_TIMEOUT:()=>me,LOCATOR_TIMEOUT:()=>nt,getActionTimeoutMs:()=>P,getFrameContext:()=>An,getLocator:()=>C,getMinimalActionEntity:()=>yl,getPageLocatorExpression:()=>Te,sanitizeForComment:()=>bl});M=Ea(()=>{nt=5e3,$n=1e4,me=2e4})});async function Mn(e,t,i=[],n=[]){try{let a=await An(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=${Aa(s)}`),d=_l(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Aa(t)}`)).elementHandle({timeout:nt}),!o)return g.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:nt}),!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 In(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 Aa(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function _l(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";H();R();M()});async function $a(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 ne(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function hi(e,t){return t?{xpath:void 0,locator:await In(e,t)??void 0,frame_path:[]}:{xpath:void 0,locator:void 0,frame_path:[]}}function mi(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 We=w(()=>{"use strict";ie();Oe()});function pi(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ca(e){let t=G().env||{};if(pi()){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}`),(0,Pa.createVertex)({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}`),(0,Ia.createGoogleGenerativeAI)({apiKey:i})(e)}function Na(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ma.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Ma.MEDIA_RESOLUTION_HIGH)}return pi()?{vertex:a}:{google:a}}var Ia,Pa,Ma,Be=w(()=>{"use strict";H();te();Ia=require("@ai-sdk/google"),Pa=require("@ai-sdk/google-vertex"),Ma={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function Y(e,t){return Math.round(e/1e3*t)}async function Sl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=Y(i.x,n),l=Y(i.y,a),d=await ne(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=Y(i.x,n),l=Y(i.y,a),d=await ne(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=Y(i.x,n),l=Y(i.y,a),d=await ne(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"hover_at":{let s=Y(i.x,n),l=Y(i.y,a),d=await ne(e,s,l);o={action_name:"hover",kwargs:{}},r=d.element;break}case"scroll_at":{let s=Y(i.x,n),l=Y(i.y,a),d=await ne(e,s,l),c=i.direction??"down",u=Y(i.magnitude??800,c==="left"||c==="right"?n:a),p=c==="right"?u:c==="left"?-u:0,f=c==="down"?u:c==="up"?-u:0;o={action_name:"scroll_on_element",kwargs:{delta_x:p,delta_y:f}},r=d.element;break}case"drag_and_drop":{let s=Y(i.x,n),l=Y(i.y,a),d=Y(i.destination_x,n),c=Y(i.destination_y,a),u=await ne(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 hi(e,r)}}async function Da(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=G(),l;if(pi()){let m=s.env?.GOOGLE_CLOUD_PROJECT;if(!m)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let v=s.env?.GOOGLE_CLOUD_LOCATION??"global";l={vertexai:!0,project:m,location:v}}else{let m=s.env?.GOOGLE_API_KEY;if(!m)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};l={apiKey:m}}let d=new gi.GoogleGenAI(l);k.log("Sending request to Gemini CUA...");let c=await d.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:gi.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination"]}},{functionDeclarations:kl}],temperature:.1}});k.log("Received response from Gemini CUA");let u=c.candidates?.[0];if(!u)return{status:"error",error:"No candidates in Gemini response"};let p=u.content?.parts?.find(m=>m.functionCall);if(!p)return{status:"error",reasoning:u.content?.parts?.filter(m=>m.text).map(m=>m.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:h}=p.functionCall;k.log(`Generated function call: ${f} with args ${JSON.stringify(h)}`),g.debug(`Generated function call: ${f} with args ${JSON.stringify(h)}`);let{action_data:y,locatorInfo:b}=await Sl(i,f,h,a,o);return y?{status:"success",actionEntity:mi(t,y,b),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var gi,Oa,kl,fi=w(()=>{"use strict";We();ie();Be();H();te();gi=require("@google/genai");Oa={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"]},kl=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Oa},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Oa}]});async function El(e,t){let i=null,n=null;switch(t.type){case"click":{if(t.x===void 0||t.y===void 0)break;let a=t.button==="right"?"right_click_by_coordinates":"click_by_coordinates",o=await ne(e,t.x,t.y);i={action_name:a,kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"double_click":{if(t.x===void 0||t.y===void 0)break;let a=await ne(e,t.x,t.y);i={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},n=a.element;break}case"drag":{if(!t.path||t.path.length<2)break;let[a,o]=[t.path[0],t.path[1]],r=await ne(e,a.x,a.y);i={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:o.x-a.x,delta_y:o.y-a.y}},n=r.element;break}case"move":{if(t.x===void 0||t.y===void 0)break;let a=await ne(e,t.x,t.y);i={action_name:"hover",kwargs:{}},n=a.element;break}case"scroll":{if(t.x===void 0||t.y===void 0)break;let a=await ne(e,t.x,t.y);i={action_name:"scroll_on_element",kwargs:{delta_x:t.scroll_x,delta_y:t.scroll_y}},n=a.element;break}}return{action_data:i,locatorInfo:await hi(e,n)}}async function Ra(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o}=e,r=G().env?.OPENAI_API_KEY;if(!r)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let s=new La.default({apiKey:r});k.log("Sending request to OpenAI CUA...");let l=`You will be given an action to execute and screenshot of the current screen.
|
|
15
|
+
Output one computer_call object that will accomplish this action.
|
|
16
|
+
Action: ${t}`,d=await s.responses.create({model:"computer-use-preview",tools:[{type:"computer_use_preview",display_width:a,display_height:o,environment:"browser"}],input:[{role:"user",content:[{type:"input_text",text:l},{type:"input_image",detail:"auto",image_url:`data:image/png;base64,${n}`}]}],truncation:"auto",temperature:.1});k.log("Received response from OpenAI CUA");let c=d.output.find(f=>f.type==="computer_call")??null;if(!c)return{status:"error",reasoning:d.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};k.log(`Generated action: ${JSON.stringify(c.action)}`);let{action_data:u,locatorInfo:p}=await El(i,c.action);return u?{status:"success",actionEntity:mi(t,u,p),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:"Failed to map OpenAI action"}}var La,wi=w(()=>{"use strict";We();ie();te();La=ee(require("openai"),1)});function Tl(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Pn(e){return G().env?.[e]??process.env[e]}function Al(){return Tl(Pn("ANTHROPIC_MODELS_USE_VERTEXAI"))}function Wa(e){if(Al()){let i=Pn("GOOGLE_CLOUD_PROJECT"),n=Pn("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}`),(0,Ha.createVertexAnthropic)({project:i,location:n})(e)}let t=G().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}`),(0,Fa.createAnthropic)({apiKey:t})(e)}function Cn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Fa,Ha,at=w(()=>{"use strict";H();te();Fa=require("@ai-sdk/anthropic"),Ha=require("@ai-sdk/google-vertex/anthropic")});function Ua(e){let t=G(),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}`:""}`),(0,Ba.createOpenAI)({apiKey:i,baseURL:n})(e)}function Ga(e){return{}}var Ba,ot=w(()=>{"use strict";H();te();Ba=require("@ai-sdk/openai")});function Ka(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if($l.test(e))return"openai"}function bi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Ml.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function ye(e){let{provider:t,modelId:i}=bi(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=ja[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(ja).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function ve(e,t){let{provider:i,modelId:n}=bi(e),a=i??Ka(n);return a==="anthropic"||a==="vertex"?Cn(n):a==="openai"||a==="azure"?Ga(n):a==="bedrock"?n.startsWith("anthropic.")?Cn(n):{}:Na(t,n)}var $l,Ml,ja,xe=w(()=>{"use strict";at();Be();ot();$l=/^(gpt-|o\d|chatgpt-)/;Ml=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);ja={anthropic:Wa,google:Ca,openai:Ua}});function Pl(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 $a(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=bi(l),c=Pl(d),u=Il[c];k.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:d};try{return await u(p)}catch(f){return k.error(`CUA provider "${c}" threw an error`,f),{status:"error",error:f.message??"CUA provider failed"}}}var Il,Ge=w(()=>{"use strict";fi();wi();We();ie();xe();Il={google:Da,openai:Ra}});function yi(e){let t=(0,za.zodToJsonSchema)(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return rt(t),t}function rt(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))rt(i)}e.type==="array"&&e.items&&rt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(rt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&rt(i)}}var za,st=w(()=>{"use strict";za=require("zod-to-json-schema")});var Nn,vi=w(()=>{"use strict";st();Nn=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:yi(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:yi(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:yi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function Cl(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 Nl(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=Cl(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
2
17
|
|
|
3
|
-
`}),t.push(...o)}return t}function
|
|
18
|
+
`}),t.push(...o)}return t}function xi(e,t=Va){if(t){let i=Nl(e);if(i.length===0)return[];let n={type:"text",text:`
|
|
4
19
|
|
|
5
20
|
<retrieved_knowledge>
|
|
6
21
|
|
|
@@ -20,7 +35,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
|
|
|
20
35
|
|
|
21
36
|
</retrieved_knowledge>
|
|
22
37
|
|
|
23
|
-
`}]:[]}}function
|
|
38
|
+
`}]:[]}}function Xa(e,t=Va){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var Va,lt=w(()=>{"use strict";Va=!1});function Ol(){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 Ya(e){return`# Your Role
|
|
24
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.
|
|
25
40
|
|
|
26
41
|
# Rules
|
|
@@ -80,11 +95,11 @@ Example of empty action when the target element is not on the page, or the instr
|
|
|
80
95
|
"action": {}, // empty action object to indicate the instruction cannot be completed
|
|
81
96
|
"completes_instruction": false
|
|
82
97
|
}
|
|
83
|
-
`}function
|
|
98
|
+
`}function Dl(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
|
|
84
99
|
Feedback: ${n}
|
|
85
100
|
`}),`## Additional context
|
|
86
101
|
You just executed following steps in order:
|
|
87
|
-
${t}`}function
|
|
102
|
+
${t}`}function Ja(e,t,i,n,a,o,r=!1,s=Ol(),l=!1,d){let c=[],u=`
|
|
88
103
|
# Instruction
|
|
89
104
|
"${t}"
|
|
90
105
|
|
|
@@ -104,9 +119,9 @@ ${e.tabsText}
|
|
|
104
119
|
|
|
105
120
|
## Interactive elements from current page:
|
|
106
121
|
${e.elementsText}
|
|
107
|
-
`;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=
|
|
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=xi(a,l);c.push(...f)}let p="";if(p+=`
|
|
108
123
|
Current local time is ${s}.
|
|
109
|
-
`,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 y=i[h],b=typeof y=="string"?y:JSON.stringify(y);f.push(` - ${h}: "${b}"`)}
|
|
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 y=i[h],b=typeof y=="string"?y:JSON.stringify(y);f.push(` - ${h}: "${b}"`)}p+=`
|
|
110
125
|
## Available Data Placeholders
|
|
111
126
|
The following placeholders are available for use in your actions:
|
|
112
127
|
${f.join(`
|
|
@@ -117,42 +132,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
|
|
|
117
132
|
- Do NOT use the actual value directly
|
|
118
133
|
- The values shown are for context only to help you understand what data is available
|
|
119
134
|
- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
|
|
120
|
-
`}if(n&&n.length>0){let f=
|
|
121
|
-
`+f}return
|
|
135
|
+
`}if(n&&n.length>0){let f=Dl(n);p+=`
|
|
136
|
+
`+f}return p+=`
|
|
122
137
|
Based on the above information, please determine the right action to accomplish the task.
|
|
123
|
-
`,c.push({type:"text",text:
|
|
124
|
-
=== Agent Execution Log ===
|
|
125
|
-
Started: ${new Date().toISOString()}
|
|
126
|
-
|
|
127
|
-
`),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=K().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,pn.appendFileSync)(t,`[${i}] ${e}
|
|
128
|
-
`)}catch{}}}section(e){this.log(`
|
|
129
|
-
${"=".repeat(60)}
|
|
130
|
-
${e}
|
|
131
|
-
${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,a=i.completionTokens||i.outputTokens||0,o=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${a} completion = ${o} total`)}}thinking(e){this.log(`Native Thinking:
|
|
132
|
-
${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
133
|
-
${e}`),this.log(`
|
|
134
|
-
User Prompt:
|
|
135
|
-
${t}`)}response(e){this.log(`LLM Response:
|
|
136
|
-
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!K().agentLogPath}},k=new sl});var fn,ll,cl,dl,xa,ui,gn,_a,wn,fe=w(()=>{"use strict";fn=Object.defineProperty,ll=Object.getOwnPropertyDescriptor,cl=Object.getOwnPropertyNames,dl=Object.prototype.hasOwnProperty,xa=(e,t)=>()=>(e&&(t=e(e=0)),t),ui=(e,t)=>{for(var i in t)fn(e,i,{get:t[i],enumerable:!0})},gn=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of cl(t))!dl.call(e,a)&&a!==i&&fn(e,a,{get:()=>t[a],enumerable:!(n=ll(t,a))||n.enumerable});return e},_a=(e,t,i)=>(gn(e,t,"default"),i&&gn(i,t,"default")),wn=e=>gn(fn({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??yn}function ul(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function C(e,t){let i=ke(t);return i?new Function("page",`return ${i}`)(e):null}async function bn(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 hl(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 ml(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function pl(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 ke(e){let t=ml(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=pl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var hi,it,yn,ue,M,R=w(()=>{"use strict";fe();hi={};ui(hi,{ACTION_TIMEOUT:()=>yn,GOTO_TIMEOUT:()=>ue,LOCATOR_TIMEOUT:()=>it,getActionTimeoutMs:()=>P,getFrameContext:()=>bn,getLocator:()=>C,getMinimalActionEntity:()=>hl,getPageLocatorExpression:()=>ke,sanitizeForComment:()=>ul});M=xa(()=>{it=5e3,yn=1e4,ue=2e4})});async function vn(e,t,i=[],n=[]){try{let a=await bn(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=${ka(s)}`),d=gl(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${ka(t)}`)).elementHandle({timeout:it}),!o)return p.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:it}),!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 xn(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 ka(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function gl(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 Ce=w(()=>{"use strict";H();R();M()});async function fl(e,t,i){await e.evaluate(()=>{let c=document.getElementById("playwright-highlight-container");c&&c.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(u=>u()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),r=await o.metadata(),s=r.width||0,l=r.height||0;k.log(`Screenshot actual dimensions: ${s}x${l}, viewport: ${t}x${i}`);let d;return s!==t||l!==i?(k.log(`Resizing screenshot from ${s}x${l} to ${t}x${i}`),d=await o.resize(t,i).png().toBuffer()):d=n,d.toString("base64")}async function _n(e,t,i){let n=await e.evaluateHandle(l=>document.elementFromPoint(l.x,l.y),{x:t,y:i});if(!n)throw new Error(`No element found at (${t}, ${i})`);let 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 has no bounding box");let r=t-(o.x+o.width/2),s=i-(o.y+o.height/2);return{relative_x:r,relative_y:s,element:a}}async function wl(e,t){return t?{xpath:void 0,locator:(t?await xn(e,t):null)||void 0,frame_path:[]}:{xpath:void 0,locator:void 0,frame_path:[]}}async function bl(e,t){let i=null,n=null;switch(t.type){case"click":{let o=t.button==="right"?"right_click_by_coordinates":"click_by_coordinates";if(t.x===void 0||t.y===void 0)break;let r=await _n(e,t.x,t.y);i={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},n=r.element;break}case"double_click":{if(t.x===void 0||t.y===void 0)break;let o=await _n(e,t.x,t.y);i={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"drag":{if(!t.path||t.path.length<2)break;let o=t.path[0].x,r=t.path[0].y,s=t.path[1].x,l=t.path[1].y,d=await _n(e,o,r);i={action_name:"drag_drop",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y,delta_x:s-o,delta_y:l-r}},n=d.element;break}}let a=await wl(e,n);return{action_data:i,locatorInfo:a}}async function Fe(e,t,i={}){try{let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let o=a.width,r=a.height;k.log(`Viewport size: ${o}x${r}`);let s=await fl(n,o,r),l=K().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OpenAI API key not found. Set OPENAI_API_KEY environment variable or configure via SDK config."};let d=new Sa.default({apiKey:l});k.log("Sending request to OpenAI CUA...");let c=[{role:"user",content:[{type:"input_text",text:`
|
|
137
|
-
You will be given an action to execute and screenshot of the current screen.
|
|
138
|
-
Output one computer_call object that will accomplish this action.
|
|
139
|
-
Action: ${e}
|
|
140
|
-
`},{type:"input_image",detail:"auto",image_url:`data:image/png;base64,${s}`}]}],u=await d.responses.create({model:"computer-use-preview",tools:[{type:"computer_use_preview",display_width:o,display_height:r,environment:"browser"}],input:c,truncation:"auto",temperature:.1});k.log("Received response from OpenAI CUA");let m=u.output.filter(b=>b.type==="computer_call")[0]??null;if(!m)return{status:"error",reasoning:u.output_text||""||"Invalid action generation response",error:"No computer_call action generated"};let f=m.action;k.log(`Generated action: ${JSON.stringify(f)}`);let{action_data:h,locatorInfo:y}=await bl(n,f);return h?{status:"success",actionEntity:{action_description:e,action_data:h,locator:y.locator||void 0,xpath:y.xpath||void 0,frame_path:y.frame_path},reasoning:"Action generated successfully using pure vision mode",goalAccomplished:!0}:{status:"error",error:"Failed to map action to ActionDataEntity"}}catch(n){return k.error("Error generating CUA action",n),{status:"error",error:n.message||"Failed to generate action with pure vision"}}}var Sa,He=w(()=>{"use strict";de();Ce();te();Sa=Q(require("openai"),1)});function mi(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 nt=w(()=>{"use strict"});async function yl(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:p}),c}var _i=w(()=>{"use strict";lt()});function ki(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 ct=w(()=>{"use strict"});async function Ll(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(`
|
|
141
139
|
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
142
|
-
`:"",tabsText:a}}async function
|
|
140
|
+
`:"",tabsText:a}}async function Rl(e,t){let{currentTabText:i,tabsText:n}=await Ll(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Si(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),s=a.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=l.elementTree.clickableElementsToString(),p=await Rl(i,u);return c&&(p.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var dt=w(()=>{"use strict"});var oe,On,W,_e=w(()=>{"use strict";oe=require("zod"),On=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 oe.z.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 oe.z.object({done:oe.z.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof oe.z.ZodObject){let l=s._def.shape();s=oe.z.object({...l,description:oe.z.string().describe("Semantic, human-readable description of the action")})}if(s instanceof oe.z.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=oe.z.object({_empty:oe.z.boolean().optional()}))}return oe.z.object({[r.name]:s})});if(i.length===1)return i[0];let[n,a,...o]=i;return oe.z.union([n,a,...o])}},W=new On});async function B(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function Fl(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 Hl(e,t=!0){try{let i=Fl(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(`
|
|
143
141
|
`)&&(s=o.split(`
|
|
144
|
-
`)[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
|
|
145
|
-
Parameters: ${JSON.stringify(
|
|
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 Wl(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 Hl(e,!1)}function qa(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=Wl(o);g.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=qa(t);return t.xpath&&(i=await Mn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var j=w(()=>{"use strict";Oe();H()});function Bl(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 Ul(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 Gl(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=Ul(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 Za(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(Q=>(k.log(`Failed to retrieve knowledges: ${Q.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),f=p?Bl(e):"all";p&&f!=="all"&&k.log(`Action intent filtering: detected '${f}' intent from statement`);let{screenshotBase64:h,domState:y,pageContext:b}=await Si(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:f});t.domState=y;let m=new Nn(W).getToolDefinitions().map(Q=>{let Fe=Q.function;return`${Fe.name}: ${Fe.description}
|
|
143
|
+
Parameters: ${JSON.stringify(Fe.parameters,null,2)}`}).join(`
|
|
146
144
|
|
|
147
|
-
`),v=
|
|
145
|
+
`),v=Ya(m),T=await s,E=Ja(b,e,t.variables,t.executionHistory,T.length>0?T:void 0,h,l,void 0,c,t.sensitiveKeys),$=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(Q=>{Q.role==="user"?$.push({role:"user",content:Q.content}):Q.role==="assistant"&&$.push({role:"assistant",content:Q.content})}),$.push({role:"user",content:E});let I=Gl($),L=W.buildActionUnionSchema(),F=ut.z.object({thought:ut.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:ut.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:L,completes_instruction:ut.z.boolean().describe("Whether this action completes the given instruction").optional().default(!1)}),N=Array.isArray(E)?E.filter(Q=>Q.type==="image").length:0,z=ve(o,N),J=await(0,Ei.generateText)({model:ye(o),system:v,messages:$,temperature:r,output:Ei.Output.object({schema:F}),providerOptions:z}),fe=J.reasoningText;g.info(`Action Generation Reasoning: ${fe}`);let K=J.output,V=JSON.stringify(K,null,2);g.info(`Generate Action Raw Output: ${V}`);let we=[],Ie=ki(J.usage,o);Ie&&we.push(Ie);let Pe={systemPrompt:v,userPrompt:I,rawLlmResponse:V,tokenUsages:we},Ce=K.thought||"",Ne=K.description||"",U=K.action||{},q=K.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Ce||Ne||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Pe};let X=Object.keys(U)[0];if(X==="done")return{status:"error",reasoning:Ce||Ne||"Task marked as done",goalAccomplished:q,error:"Agent indicated task is done without generating an action",debugInfo:Pe};if(X==="perform_accurate_operation")return await Ue(e,t,i);let he=U[X]||{},xa={};if(typeof he.element_index=="number"){let Q=he.element_index;if(Q<0)return{status:"error",reasoning:Ce||Ne||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Pe};let Fe=y.selectorMap.get(Q);Fe&&(xa=await D(n,Fe))}let _a=Ne;return X==="verify"&&(_a=e,he.statement=e),{status:"success",actionEntity:{...xa,action_description:_a||Ce||`${X}(${JSON.stringify(he)})`,action_data:{action_name:X,kwargs:he}},reasoning:Ce||Ne,goalAccomplished:q,debugInfo:Pe}}var Ei,ut,Ti=w(()=>{"use strict";Ge();vi();_i();ct();dt();_e();ie();xe();j();H();Ei=require("ai"),ut=require("zod")});function jl(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 Dn(e,t,i={}){return i.usePureVision?Ue(e,t,i):Za(e,t,i)}function zl(){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 Vl(){return`# Role
|
|
148
146
|
You are an experienced QA person for web applications.
|
|
149
147
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
150
|
-
`}async function
|
|
148
|
+
`}async function Qa(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:p,domState:f,pageContext:h}=await Si(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=f;let y="";a&&a.length>0&&(y=`
|
|
151
149
|
# Previous actions in this session:
|
|
152
|
-
${a.map(([U,
|
|
153
|
-
Result: ${
|
|
150
|
+
${a.map(([U,q],X)=>`${X+1}. Action: ${U}
|
|
151
|
+
Result: ${q}`).join(`
|
|
154
152
|
`)}
|
|
155
|
-
`);let{dateString:b,timeString:
|
|
153
|
+
`);let{dateString:b,timeString:m}=zl(),v=`
|
|
156
154
|
# User statement
|
|
157
155
|
"${e}"
|
|
158
156
|
|
|
@@ -170,8 +168,8 @@ ${h.tabsText}
|
|
|
170
168
|
${c}
|
|
171
169
|
|
|
172
170
|
## Screenshot
|
|
173
|
-
${r&&
|
|
174
|
-
`,T="";if(t.variables&&Object.keys(t.variables).length>0){let U=[];for(let
|
|
171
|
+
${r&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
|
|
172
|
+
`,T="";if(t.variables&&Object.keys(t.variables).length>0){let U=[];for(let q of Object.keys(t.variables))if(!t.sensitiveKeys?.has(q)){let X=t.variables[q],he=typeof X=="string"?X:JSON.stringify(X);U.push(` - ${q}: "${he}"`)}U.length>0&&(T=`
|
|
175
173
|
## Available Variables
|
|
176
174
|
The following non-sensitive variables are available:
|
|
177
175
|
${U.join(`
|
|
@@ -179,14 +177,14 @@ ${U.join(`
|
|
|
179
177
|
${T}
|
|
180
178
|
${y}
|
|
181
179
|
|
|
182
|
-
Today is ${b}. Current local time is ${
|
|
180
|
+
Today is ${b}. Current local time is ${m}.
|
|
183
181
|
Based on the above information, please determine if the statement is true.
|
|
184
|
-
`,$=await t.agentServices.retrieveKnowledges(e),I=[{type:"text",text:v}],L=0;if(r&&
|
|
182
|
+
`,$=await t.agentServices.retrieveKnowledges(e),I=[{type:"text",text:v}],L=0;if(r&&p&&p.length>0)for(let U of p)I.push({type:"image",image:U}),L++;else I.push({type:"image",image:u}),L=1;if($&&$.length>0){let U=xi($,l);I.push(...U)}I.push({type:"text",text:E});let F=$?Xa($,l):0,N=L+F,z=ve(o,N),J=Vl(),fe=await(0,Ai.generateText)({model:ye(o),system:J,messages:[{role:"user",content:I}],output:Ai.Output.object({schema:Kl}),temperature:0,providerOptions:z}),{conclusion:K,explanation:V}=fe.output,we=JSON.stringify(fe.output,null,2),Ie=[],Pe=ki(fe.usage,o);Pe&&Ie.push(Pe);let Ce=[{role:"user",content:I.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let q=U.image,X=jl(q);if(X)return{type:"image",file:X};let he=typeof q=="string"?q:"";return{type:"image",file:he.startsWith("data:")?he:`data:image/png;base64,${he}`}}return{type:"text",text:"[unknown content type]"}})}],Ne={systemPrompt:J,userPrompt:Ce,rawLlmResponse:we,screenshotWithSom:u,tokenUsages:Ie,retrievedKnowledges:$&&$.length>0?$:void 0,elementTree:c};return{success:K==="true",explanation:V,debugInfo:Ne}}catch(r){return{success:!1,error:r.message}}}var Ai,ht,Kl,$i=w(()=>{"use strict";Ti();Ge();ct();dt();lt();xe();Ai=require("ai"),ht=require("zod");Kl=ht.z.object({screenshotDescription:ht.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
|
|
185
183
|
and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
|
|
186
184
|
[45] A modal dialog titled "Confirmation",
|
|
187
|
-
in the center of the screen`),explanation:
|
|
188
|
-
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??
|
|
189
|
-
`)}}});function
|
|
185
|
+
in the center of the screen`),explanation:ht.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:ht.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function to(){let{default:e}=await import("sharp");return e}async function Ln(e,t){let i=await to(),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,y)=>{let b=i(e).extract({left:h,top:0,width:y,height:r});return t?.resize&&(b=b.resize(eo,eo)),b.png().toBuffer()},[u,p,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,p,f]}async function io(e){let t=(await to())(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 eo,mt=w(()=>{"use strict";eo=768});var Rn,Fn,Hn,Wn,pt=w(()=>{"use strict";Rn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),Fn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Hn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],Wn=500});function no(e,t){return e.length>t?e.slice(0,t)+"...":e}var gt=w(()=>{"use strict"});var ao,oo,ft=w(()=>{"use strict";ao=["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"],oo={"react-flow__(\\S+)":"$1"}});var ro,wt,ke,je=w(()=>{"use strict";gt();ft();ro=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},wt=class extends ro{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}},ke=class Mi extends ro{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,p=null,f=null,h=null,y=null,b=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=f,this.pageCoordinates=h,this.viewportInfo=y,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof Mi&&a!==this&&a.highlightIndex!==null)){if(a instanceof wt)i.push(a.text);else if(a instanceof Mi)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
|
|
186
|
+
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??ao,n=t?.includeClassesWithRename??oo,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof Mi){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let $=r.attributes[E].trim();$!==""&&(m[E]=$)}let v=i.filter(E=>E in m);if(v.length>1){let E=new Set,$={};for(let I of v){let L=m[I];L.length>5&&(L in $?E.add(I):$[L]=I)}for(let I of E)delete m[I]}r.tagName===m.role&&delete m.role;let T=["aria-label","placeholder","title"];for(let E of T)m[E]&&m[E].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[E];Object.keys(m).length>0&&(u=Object.entries(m).map(([E,$])=>`${E}=${no($,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,f=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let v of m)for(let[T,E]of Object.entries(n))try{let $=new RegExp(`^${T}$`);if(v.match($)){let I=v.replace($,E);I&&f.push(I);break}}catch{continue}}let h=r.isScrollable?" (SCROLLABLE)":"",y=r.markAsClickable?" (CLICKABLE)":"",b=`${d}${p}${h}${y}<${r.tagName}`;if(f.length>0&&(b+=` ${f.join(" ")}`),u&&(b+=` ${u}`),c){let m=c.trim();u||(b+=" "),b+=`>${m}`}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 wt){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 Jl(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Xl,Yl,Ae,De=w(()=>{"use strict";mt();pt();je();H();Xl=`(
|
|
190
188
|
args = {
|
|
191
189
|
doHighlightElements: true,
|
|
192
190
|
focusHighlightIndex: -1,
|
|
@@ -1954,7 +1952,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
1954
1952
|
|
|
1955
1953
|
return { rootId, map: DOM_HASH_MAP };
|
|
1956
1954
|
}
|
|
1957
|
-
`,
|
|
1955
|
+
`,Yl=`((args = {
|
|
1958
1956
|
doHighlightElements: true,
|
|
1959
1957
|
focusHighlightIndex: -1,
|
|
1960
1958
|
viewportExpansion: 0,
|
|
@@ -4002,7 +4000,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
4002
4000
|
// Return element data from boxes phase for use in labels phase
|
|
4003
4001
|
elementData: phase === 'boxes' ? collectedElementData : undefined,
|
|
4004
4002
|
};
|
|
4005
|
-
})`;
|
|
4003
|
+
})`;Ae=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?Yl:Xl}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 Ln(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(m=>{if(m.ignored)return!1;let v=m.role?.value;return!(!v||!Rn.has(v)||m.properties?.find(T=>T.name==="disabled")?.value?.value||!m.backendDOMNodeId)});g.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(m=>m.role?.value==="button");g.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let v=[];m.ignored&&v.push("ignored"),m.backendDOMNodeId||v.push("no-backendDOMNodeId"),m.properties?.find(T=>T.name==="disabled")?.value?.value&&v.push("disabled"),g.debug(` - "${m.name?.value||"(no name)"}" ${v.length>0?`[SKIPPED: ${v.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)s.has(m.backendNodeId)||(o.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),d++);g.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${o.length})`);let c=await this.resolveAXNodesToDOM(n,o),u=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){g.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let v=[];m.isVisible||v.push("not-visible"),m.isInViewport||v.push("not-in-viewport"),m.isTopElement||v.push("not-top-element"),m.boundingRect||v.push("no-bounding-rect"),g.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${v.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 y=i.toString("base64"),b;if(t.useSlicedScreenshots)try{b=(await Ln(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){g.warn("Failed to slice screenshot:",m)}return{domState:f,screenshotBase64:y,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() {
|
|
4006
4004
|
const el = this;
|
|
4007
4005
|
const rect = el.getBoundingClientRect();
|
|
4008
4006
|
const rects = el.getClientRects();
|
|
@@ -4086,36 +4084,36 @@ Based on the above information, please determine if the statement is true.
|
|
|
4086
4084
|
} : null,
|
|
4087
4085
|
clientRects: clientRectsArray
|
|
4088
4086
|
};
|
|
4089
|
-
}`,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=Pn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=In.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=>Mn.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(Rl(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:L,argsObj:F})=>new Function("return "+L)()(F),{code:this.jsCode,argsObj:b});p.debug(`\u{1F4E6} Phase 1: Drew ${g.elementData?.length||0} bounding boxes`);let v=await e.screenshot({type:"png",fullPage:!1});p.debug("\u{1F4F8} Captured screenshot with bounding boxes");let T=performance.now(),E=await Ka(v);u=E.pixels;let $=Math.round(performance.now()-T);p.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${$}ms`);let I={...d,phase:"labels",grayscaleImage:u,elementData:g.elementData};c=await e.evaluate(({code:L,argsObj:F})=>new Function("return "+L)()(F),{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:v,argsObj:T})=>new Function("return "+v)()(T),{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:v})=>new Function("return "+g)()(v),{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 v=g;p.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${v.attributes?.src} inaccessibleFrame=${v.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 v=g;this.shouldProcessWithPlaywrightFrameFallback(v,o)&&h.push({nodeId:b,src:v.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 v=g;v.highlightIndex!=null&&(b=Math.max(b,v.highlightIndex))}p.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let g=0;g<h.length;g++){let{nodeId:v,src:T}=h[g];p.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${g}]: ${T}`);let E=F=>{try{let N=new URL(F);if(N.protocol==="chrome-extension:"&&N.hostname)return`chrome-extension://${N.hostname}`;let z=N.origin;return z==="null"?null:z}catch{return null}},$=E(T);p.debug(`\u{1F50D} [ext-iframe] iframe src origin=${$??"null"}`);let I=null,L=e.frames().find(F=>{let N=F.url();if(N===T)return I="exact",p.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${N}`),!0;let z=E(N);return p.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${N} origin=${z??"null"} vs srcOrigin=${$??"null"}`),$&&z===$?(I="origin",p.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${N}`),!0):!1});if(!L){p.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${T}`),p.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(F=>F.url()).join(", ")}`);continue}p.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${T} (frame url: ${L.url()})`);try{let F={...d,initialHighlightIndex:b+1,domTreeRoot:"body"};p.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${F.initialHighlightIndex}`);let N=await L.evaluate(({code:j,argsObj:V})=>new Function("return "+j)()(V),{code:this.jsCode,argsObj:F});if(p.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(N?.map??{}).length} rootId=${N?.rootId}`),!N?.map||!N.rootId){p.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let z=Object.values(N.map).filter(j=>j.highlightIndex!=null);p.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${z.length}`);for(let j of z){let V=j;p.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let j of Object.values(N.map)){let V=j;V.highlightIndex!=null&&(b=Math.max(b,V.highlightIndex))}let Y=`ext_${g}_`;for(let[j,V]of Object.entries(N.map)){let ge={...V};ge.children&&(ge.children=ge.children.map($e=>`${Y}${$e}`)),c.map[`${Y}${j}`]=ge}let pe=c.map[v];pe?(pe.children=[...pe.children||[],`${Y}${N.rootId}`],p.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${v}`)):p.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${v} not found in map`),p.debug(`\u2705 Merged fallback iframe content from: ${T}`)}catch(F){p.warn(`Failed to process fallback iframe ${T}:`,F)}}}if(c&&c.perfMetrics){let b=c.perfMetrics.nodeMetrics?.totalNodes??0,g=0;if(c.map)for(let T of Object.values(c.map))typeof T=="object"&&T!==null&&T.isInteractive&&g++;let v=e.url().length>50?e.url().slice(0,50)+"...":e.url();p.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${v} interactive=${g}/${b}`)}p.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(c);return p.debug("\u2705 TypeScript DOM tree construction completed"),y}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 Ja,vi=w(()=>{"use strict";R();M();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.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=ke(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} });`]}}});var qa,Za,kh,xi=w(()=>{"use strict";qa=require("zod"),Za=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},kh=qa.z.object({})});var Qa,_i=w(()=>{"use strict";R();M();Qa=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 eo,ki=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.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){g.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=Wn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Hn.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=>Fn.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 ke("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 ke(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 wt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=a[l%a.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let f=Math.max(0,c.y-16),h=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${f}px`,p.style.left=`${h}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),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(Jl(e.url()))return[new ke("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 b={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:L,argsObj:F})=>new Function("return "+L)()(F),{code:this.jsCode,argsObj:b});g.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let v=await e.screenshot({type:"png",fullPage:!1});g.debug("\u{1F4F8} Captured screenshot with bounding boxes");let T=performance.now(),E=await io(v);u=E.pixels;let $=Math.round(performance.now()-T);g.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${$}ms`);let I={...d,phase:"labels",grayscaleImage:u,elementData:m.elementData};c=await e.evaluate(({code:L,argsObj:F})=>new Function("return "+L)()(F),{code:this.jsCode,argsObj:I}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,g.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){g.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),u=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:v,argsObj:T})=>new Function("return "+v)()(T),{code:this.jsCode,argsObj:m}),g.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:b,argsObj:m})=>new Function("return "+b)()(m),{code:this.jsCode,argsObj:d}),g.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw g.error("Error evaluating JavaScript:",b.message),b}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 b={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:v})=>new Function("return "+m)()(v),{code:this.jsCode,argsObj:b})}let p=Object.entries(c.map).filter(([,b])=>b.tagName==="iframe");g.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[b,m]of p){let v=m;g.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${v.attributes?.src} inaccessibleFrame=${v.inaccessibleFrame}`)}let f=e.frames();g.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${f.length}`);for(let b of f)g.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let h=[];for(let[b,m]of Object.entries(c.map)){let v=m;this.shouldProcessWithPlaywrightFrameFallback(v,o)&&h.push({nodeId:b,src:v.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 b=-1;for(let m of Object.values(c.map)){let v=m;v.highlightIndex!=null&&(b=Math.max(b,v.highlightIndex))}g.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let m=0;m<h.length;m++){let{nodeId:v,src:T}=h[m];g.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${T}`);let E=F=>{try{let N=new URL(F);if(N.protocol==="chrome-extension:"&&N.hostname)return`chrome-extension://${N.hostname}`;let z=N.origin;return z==="null"?null:z}catch{return null}},$=E(T);g.debug(`\u{1F50D} [ext-iframe] iframe src origin=${$??"null"}`);let I=null,L=e.frames().find(F=>{let N=F.url();if(N===T)return I="exact",g.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${N}`),!0;let z=E(N);return g.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${N} origin=${z??"null"} vs srcOrigin=${$??"null"}`),$&&z===$?(I="origin",g.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${N}`),!0):!1});if(!L){g.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${T}`),g.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(F=>F.url()).join(", ")}`);continue}g.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${T} (frame url: ${L.url()})`);try{let F={...d,initialHighlightIndex:b+1,domTreeRoot:"body"};g.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${F.initialHighlightIndex}`);let N=await L.evaluate(({code:K,argsObj:V})=>new Function("return "+K)()(V),{code:this.jsCode,argsObj:F});if(g.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(N?.map??{}).length} rootId=${N?.rootId}`),!N?.map||!N.rootId){g.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let z=Object.values(N.map).filter(K=>K.highlightIndex!=null);g.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${z.length}`);for(let K of z){let V=K;g.debug(`\u{1F50D} [ext-iframe] - <${V.tagName}> highlightIndex=${V.highlightIndex} text="${V.children?.length?"...":""}"`)}for(let K of Object.values(N.map)){let V=K;V.highlightIndex!=null&&(b=Math.max(b,V.highlightIndex))}let J=`ext_${m}_`;for(let[K,V]of Object.entries(N.map)){let we={...V};we.children&&(we.children=we.children.map(Ie=>`${J}${Ie}`)),c.map[`${J}${K}`]=we}let fe=c.map[v];fe?(fe.children=[...fe.children||[],`${J}${N.rootId}`],g.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${v}`)):g.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${v} not found in map`),g.debug(`\u2705 Merged fallback iframe content from: ${T}`)}catch(F){g.warn(`Failed to process fallback iframe ${T}:`,F)}}}if(c&&c.perfMetrics){let b=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let T of Object.values(c.map))typeof T=="object"&&T!==null&&T.isInteractive&&m++;let v=e.url().length>50?e.url().slice(0,50)+"...":e.url();g.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${v} interactive=${m}/${b}`)}g.debug("\u{1F504} Starting TypeScript DOM tree construction...");let y=await this.constructDomTree(c);return g.debug("\u2705 TypeScript DOM tree construction completed"),y}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 ke&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof ke)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 ke))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 wt(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 ke(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 so,Ii=w(()=>{"use strict";R();M();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.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=Te(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} });`]}}});var lo,co,qh,Pi=w(()=>{"use strict";lo=require("zod"),co=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},qh=lo.z.object({})});var uo,Ci=w(()=>{"use strict";R();M();uo=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 ho,Ni=w(()=>{"use strict";ho=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",`
|
|
4090
4088
|
return (async () => {
|
|
4091
4089
|
${a}
|
|
4092
4090
|
})();
|
|
4093
4091
|
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4094
|
-
`):["// Skipping js_action: missing code"]}}});var
|
|
4092
|
+
`):["// Skipping js_action: missing code"]}}});var Bn,mo,om,Oi=w(()=>{"use strict";Bn=require("zod"),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.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",`
|
|
4095
4093
|
return (async () => {
|
|
4096
4094
|
${a}
|
|
4097
4095
|
})();
|
|
4098
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(`
|
|
4099
|
-
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},
|
|
4097
|
+
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},om=Bn.z.object({code:Bn.z.string().describe("JavaScript code to execute in the browser context")})});var po,Di=w(()=>{"use strict";R();M();po=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 go,Li=w(()=>{"use strict";R();M();go=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 fo,Ri=w(()=>{"use strict";R();M();fo=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,p=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(p,f,{steps:n}):await e.mouse.move(p,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 wo,Fi=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=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",`
|
|
4100
4098
|
return (async () => {
|
|
4101
4099
|
${a}
|
|
4102
4100
|
})();
|
|
4103
|
-
`)(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
|
|
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 Hi=w(()=>{"use strict";je()});var bo,bt=w(()=>{"use strict";bo=(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))(bo||{})});var Ke={};He(Ke,{evaluateStatement:()=>Ui,executeAction:()=>yt,executeStep:()=>Bi,generateActionStep:()=>Wi,runTask:()=>Gi});var ze=w(()=>{"use strict";vt();$i();Ti();Ge();fi();wi();We();vi();_i();ct();dt();_e();st();lt();Hi();De();mt();pt();je();gt();ft();ie();xe();at();Be();ot();j();Oe();H();te();bt();R();be()});var Un,yo,tp,ji=w(()=>{"use strict";Un=require("zod"),yo=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(()=>(ze(),Ke)),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});`]}},tp=Un.z.object({statement:Un.z.string().describe('The action to perform (e.g., "click the submit button")')})});var Gn,vo,ap,Ki=w(()=>{"use strict";Gn=require("zod"),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.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(ze(),Ke)),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"]}},ap=Gn.z.object({statement:Gn.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function _o(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:ql,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 zi,xo,ql,xt=w(()=>{"use strict";zi=require("zod"),xo=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(()=>(ze(),Ke));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"]}},ql=zi.z.object({condition:zi.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:zi.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function Zl(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 ko(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 Eo(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Ql,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:ko(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await Zl(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:ko(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var _t,So,Ql,kt=w(()=>{"use strict";j();R();_t=require("zod");M();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.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},`),"});"]}};Ql=_t.z.object({element_index:_t.z.number().int().describe("Index of the dropdown/select element"),option:_t.z.string().describe("Option value, label, or index to select"),timeout_ms:_t.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function ec(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 jn(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">).
|
|
4104
4102
|
|
|
4105
4103
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4106
4104
|
Do NOT use it for custom/non-native date pickers
|
|
4107
4105
|
|
|
4108
|
-
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Ul,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:On(`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:On(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await Bl(`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:On(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var xt,go,Ul,_t=w(()=>{"use strict";G();R();xt=require("zod");M();go=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},`),"});"]}};Ul=xt.z.object({element_index:xt.z.number().int().describe("Index of the native date picker input element"),date:xt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:xt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function bo(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Gl,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 Ln,wo,Gl,kt=w(()=>{"use strict";Ln=require("zod"),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.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} } },`,"});"]}},Gl=Ln.z.object({tab_index:Ln.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function vo(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(yo.default.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 yo,St=w(()=>{"use strict";H();yo=Q(require("fs"),1)});async function jl(e,t,i={},n){return{...await O(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function xo(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 ko(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:Kl,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:xo(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:xo(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var xe,_o,Kl,Vm,Et=w(()=>{"use strict";St();G();R();xe=require("zod");M();_o=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 vo(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},`),"});"]}};Kl=xe.z.object({element_index:xe.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:xe.z.string().describe("Paths to the files to upload"),timeout_ms:xe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Vm=xe.z.object({element_index:xe.z.number().int().describe("Index of the file input element"),paths:xe.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:xe.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Eo(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 Rn,So,zl,Tt=w(()=>{"use strict";Rn=require("zod"),So=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=Rn.z.object({seconds:Rn.z.number().positive().describe("Number of seconds to wait")})});function Ao(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Vl,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 Fn,To,Vl,At=w(()=>{"use strict";Fn=require("zod"),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.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} } },`,"});"]}},Vl=Fn.z.object({timeout_seconds:Fn.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function $o(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:Xl,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 Hn,Wn,Xl,$t=w(()=>{"use strict";Hn=require("zod"),Wn=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)});`]}},Xl=Hn.z.object({keys:Hn.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function Po(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:Yl,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 Mo,Io,Yl,Mt=w(()=>{"use strict";R();Mo=require("zod");M();Io=class{async execute(e,t){await e.reload({timeout:ue}),await e.waitForLoadState("load",{timeout:ue}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Yl=Mo.z.object({})});async function Jl(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Co(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 No(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:ql,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Co(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await Jl("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:Co(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Ri,Bn,ql,It=w(()=>{"use strict";G();R();Ri=require("zod");M();Bn=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},`),"});"]}};ql=Ri.z.object({element_index:Ri.z.number().int().describe("Index of the element to right-click"),timeout_ms:Ri.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Oo(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Zl,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 Fi,Do,Zl,Pt=w(()=>{"use strict";Fi=require("zod"),Do=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)} } },`,"});"]}},Zl=Fi.z.object({name:Fi.z.string().describe("Variable name to save"),value:Fi.z.string().describe("Value to save in the variable")})});async function Ql(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function ec(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Lo(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:tc,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 Ql("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:ec(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Hi,Ct,tc,Nt=w(()=>{"use strict";Hi=require("zod"),Ct=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)})');`]}};tc=Hi.z.object({down:Hi.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Hi.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function ic(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ro(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ho(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:nc,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 B(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Ro(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await ic("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:Ro(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Ge,Fo,nc,Dt=w(()=>{"use strict";G();R();Ge=require("zod");M();Fo=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=ke(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});`]}};nc=Ge.z.object({element_index:Ge.z.number().int().describe("Index of the scrollable element"),delta_x:Ge.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Ge.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Ge.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Bo(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:ac,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 Un,Wo,ac,Ot=w(()=>{"use strict";Un=require("zod"),Wo=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();`]}},ac=Un.z.object({text:Un.z.string().describe("Text to scroll to on the page")})});async function oc(e,t,i){return{...await O(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Uo(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 jo(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:rc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Uo(s||`Get options from dropdown ${a}`,{index:a})};let d=await oc(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:Uo(s||`Get options from dropdown ${a}`,{index:a})}}}})}var Gn,Go,rc,Lt=w(()=>{"use strict";G();Gn=require("zod"),Go=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:tc,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:jn(`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:jn(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await ec(`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:jn(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var St,To,tc,Et=w(()=>{"use strict";j();R();St=require("zod");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.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},`),"});"]}};tc=St.z.object({element_index:St.z.number().int().describe("Index of the native date picker input element"),date:St.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:St.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Mo(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:ic,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 Kn,$o,ic,Tt=w(()=>{"use strict";Kn=require("zod"),$o=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} } },`,"});"]}},ic=Kn.z.object({tab_index:Kn.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Po(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(Io.default.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 Io,At=w(()=>{"use strict";H();Io=ee(require("fs"),1)});async function nc(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 Oo(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:ac,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(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 nc(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 Se,No,ac,Sp,$t=w(()=>{"use strict";At();j();R();Se=require("zod");M();No=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 Po(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},`),"});"]}};ac=Se.z.object({element_index:Se.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Se.z.string().describe("Paths to the files to upload"),timeout_ms:Se.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Sp=Se.z.object({element_index:Se.z.number().int().describe("Index of the file input element"),paths:Se.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Se.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Lo(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:oc,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 zn,Do,oc,Mt=w(()=>{"use strict";zn=require("zod"),Do=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});`]}},oc=zn.z.object({seconds:zn.z.number().positive().describe("Number of seconds to wait")})});function Fo(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:rc,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 Vn,Ro,rc,It=w(()=>{"use strict";Vn=require("zod"),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.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} } },`,"});"]}},rc=Vn.z.object({timeout_seconds:Vn.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function Ho(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:sc,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 Xn,Yn,sc,Pt=w(()=>{"use strict";Xn=require("zod"),Yn=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)});`]}},sc=Xn.z.object({keys:Xn.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function Uo(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:lc,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 Wo,Bo,lc,Ct=w(()=>{"use strict";R();Wo=require("zod");M();Bo=class{async execute(e,t){await e.reload({timeout:me}),await e.waitForLoadState("load",{timeout:me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},lc=Wo.z.object({})});async function cc(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:"right_click",description:"Right-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 B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Go(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await cc("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:Go(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Vi,Jn,dc,Nt=w(()=>{"use strict";j();R();Vi=require("zod");M();Jn=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},`),"});"]}};dc=Vi.z.object({element_index:Vi.z.number().int().describe("Index of the element to right-click"),timeout_ms:Vi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function zo(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:uc,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 Xi,Ko,uc,Ot=w(()=>{"use strict";Xi=require("zod"),Ko=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)} } },`,"});"]}},uc=Xi.z.object({name:Xi.z.string().describe("Variable name to save"),value:Xi.z.string().describe("Value to save in the variable")})});async function hc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function mc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Vo(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:pc,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 hc("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:mc(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Yi,Dt,pc,Lt=w(()=>{"use strict";Yi=require("zod"),Dt=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)})');`]}};pc=Yi.z.object({down:Yi.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:Yi.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function gc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Xo(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Jo(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:fc,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 B(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Xo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await gc("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:Xo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Ve,Yo,fc,Rt=w(()=>{"use strict";j();R();Ve=require("zod");M();Yo=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=Te(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});`]}};fc=Ve.z.object({element_index:Ve.z.number().int().describe("Index of the scrollable element"),delta_x:Ve.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Ve.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Ve.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Zo(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:wc,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 qn,qo,wc,Ft=w(()=>{"use strict";qn=require("zod"),qo=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();`]}},wc=qn.z.object({text:qn.z.string().describe("Text to scroll to on the page")})});async function bc(e,t,i){return{...await D(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Qo(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 tr(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:yc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Qo(s||`Get options from dropdown ${a}`,{index:a})};let d=await bc(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:Qo(s||`Get options from dropdown ${a}`,{index:a})}}}})}var Zn,er,yc,Ht=w(()=>{"use strict";j();Zn=require("zod"),er=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(`
|
|
4109
4107
|
`);a+=`
|
|
4110
|
-
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},`),"});"]}};rc=Gn.z.object({element_index:Gn.z.number().int().describe("Index of the dropdown/select element")})});function Vo(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:sc,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 Ko,zo,sc,Rt=w(()=>{"use strict";R();Ko=require("zod");M();zo=class{async execute(e,t){await e.goBack({timeout:ue}),await e.waitForLoadState("load",{timeout:ue}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},sc=Ko.z.object({})});function Xo(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:lc,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 Ft,jn,lc,Ht=w(()=>{"use strict";R();Ft=require("zod");M();jn=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:ue,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(", ")} } },`,"});"]}},lc=Ft.z.object({url:Ft.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Ft.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Ft.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function cc(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Yo(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:"hover",description:"Hover over 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 B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Yo(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await cc("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:Yo(`Hover element ${a}`,"hover",{index:a})}}}})}var Wi,Kn,dc,Wt=w(()=>{"use strict";G();R();Wi=require("zod");M();Kn=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},`),"});"]}};dc=Wi.z.object({element_index:Wi.z.number().int().describe("Index of the element to hover over"),timeout_ms:Wi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function uc(e,t,i,n,a={}){return{...await O(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:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:hc,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:qo(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await uc("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:qo(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Bt,zn,hc,Ut=w(()=>{"use strict";G();R();Bt=require("zod");M();zn=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},`),"});"]}};hc=Bt.z.object({element_index:Bt.z.number().int().describe("Index of the input element"),text:Bt.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:Bt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function er(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:mc,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 Vn,Qo,mc,Gt=w(()=>{"use strict";Vn=require("zod"),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.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} } },`,"});"]}},mc=Vn.z.object({index:Vn.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function ir(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:pc,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 Bi,tr,pc,jt=w(()=>{"use strict";Bi=require("zod"),tr=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},pc=Bi.z.object({success:Bi.z.boolean().describe("Whether the task was completed successfully"),summary:Bi.z.string().describe("Summary of what was accomplished or why it failed")})});async function gc(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function nr(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 ar(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:fc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:nr(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await gc("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:nr(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Ui,Xn,fc,Kt=w(()=>{"use strict";G();R();Ui=require("zod");M();Xn=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},`),"});"]}};fc=Ui.z.object({element_index:Ui.z.number().int().describe("Index of the element to double-click"),timeout_ms:Ui.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function rr(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:wc,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 Yn,or,wc,zt=w(()=>{"use strict";Yn=require("zod"),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.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)} } },`,"});"]}},wc=Yn.z.object({otp_secret_key:Yn.z.string().describe("The OTP secret key to generate the 2FA code from")})});function lr(e){if(!e.trim())return!1;try{return(0,sr.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var sr,Gi=w(()=>{"use strict";sr=require("@babel/parser")});function dr(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:yc,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 Jn,bc,cr,qn,ji,yc,Vt=w(()=>{"use strict";Gi();H();fe();Jn=require("zod"),bc=Q(require("playwright/test"),1),cr=Q(require("playwright/test"),1),qn={};ui(qn,{default:()=>cr.default});_a(qn,bc);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(()=>(Ue(),Be)),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",`
|
|
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},`),"});"]}};yc=Zn.z.object({element_index:Zn.z.number().int().describe("Index of the dropdown/select element")})});function ar(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:vc,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 ir,nr,vc,Wt=w(()=>{"use strict";R();ir=require("zod");M();nr=class{async execute(e,t){await e.goBack({timeout:me}),await e.waitForLoadState("load",{timeout:me}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},vc=ir.z.object({})});function or(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:xc,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:a,new_tab:o??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,f={action_description:d||p,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(p){let f=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||f)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var Bt,Qn,xc,Ut=w(()=>{"use strict";R();Bt=require("zod");M();Qn=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:me,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,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(", ")} } },`,"});"]}},xc=Bt.z.object({url:Bt.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Bt.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Bt.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function _c(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 sr(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:kc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:rr(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await _c("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:rr(`Hover element ${a}`,"hover",{index:a})}}}})}var Ji,ea,kc,Gt=w(()=>{"use strict";j();R();Ji=require("zod");M();ea=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},`),"});"]}};kc=Ji.z.object({element_index:Ji.z.number().int().describe("Index of the element to hover over"),timeout_ms:Ji.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Sc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function lr(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:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Ec,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:lr(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await Sc("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:lr(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var jt,ta,Ec,Kt=w(()=>{"use strict";j();R();jt=require("zod");M();ta=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},`),"});"]}};Ec=jt.z.object({element_index:jt.z.number().int().describe("Index of the input element"),text:jt.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:jt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ur(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Tc,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 ia,dr,Tc,zt=w(()=>{"use strict";ia=require("zod"),dr=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} } },`,"});"]}},Tc=ia.z.object({index:ia.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function mr(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Ac,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 qi,hr,Ac,Vt=w(()=>{"use strict";qi=require("zod"),hr=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Ac=qi.z.object({success:qi.z.boolean().describe("Whether the task was completed successfully"),summary:qi.z.string().describe("Summary of what was accomplished or why it failed")})});async function $c(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function pr(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 gr(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Mc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:pr(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await $c("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:pr(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Zi,na,Mc,Xt=w(()=>{"use strict";j();R();Zi=require("zod");M();na=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},`),"});"]}};Mc=Zi.z.object({element_index:Zi.z.number().int().describe("Index of the element to double-click"),timeout_ms:Zi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function wr(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:Ic,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 aa,fr,Ic,Yt=w(()=>{"use strict";aa=require("zod"),fr=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)} } },`,"});"]}},Ic=aa.z.object({otp_secret_key:aa.z.string().describe("The OTP secret key to generate the 2FA code from")})});function yr(e){if(!e.trim())return!1;try{return(0,br.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var br,Qi=w(()=>{"use strict";br=require("@babel/parser")});function xr(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:Cc,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 oa,Pc,vr,ra,en,Cc,Jt=w(()=>{"use strict";Qi();H();be();oa=require("zod"),Pc=ee(require("playwright/test"),1),vr=ee(require("playwright/test"),1),ra={};di(ra,{default:()=>vr.default});Ta(ra,Pc);en=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 p=((Date.now()-c)/1e3).toFixed(1);g.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let c=Date.now();await this.executeJSAssertion(e,n.code,i),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(()=>(ze(),Ke)),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",`
|
|
4111
4109
|
return (async () => {
|
|
4112
4110
|
${t}
|
|
4113
4111
|
})();
|
|
4114
|
-
`)(e,
|
|
4112
|
+
`)(e,ra.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(!yr(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
|
|
4115
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(`
|
|
4116
|
-
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},yc=Jn.z.object({statement:Jn.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function hr(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:vc,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 Ki,ur,vc,Xt=w(()=>{"use strict";Ki=require("zod"),ur=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(()=>(Ue(),Be)),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||""}');`]}},vc=Ki.z.object({element_description:Ki.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Ki.z.string().describe("Name of the variable to store the extracted value")})});async function xc(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function mr(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 gr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:_c,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:mr(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await xc("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:mr(`Clear element ${a}`,"clear_input",{index:a})}}}})}var zi,pr,_c,Yt=w(()=>{"use strict";G();R();zi=require("zod");M();pr=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},`),"});"]}};_c=zi.z.object({element_index:zi.z.number().int().describe("Index of the input element to clear"),timeout_ms:zi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function kc(e,t,i,n,a={}){return{...await O(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function fr(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 wr(e,t){e.register({name:"click",description:"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 B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:fr(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await kc("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:fr(`Click element ${a}`,"click",{index:a})}}}})}var Vi,Xi,Sc,Jt=w(()=>{"use strict";G();R();Vi=require("zod");M();Xi=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=ke(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Sc=Vi.z.object({element_index:Vi.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Vi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Ec,Tc,je,Yi=w(()=>{"use strict";Ec=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Tc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],je=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:Ec.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:!Tc.includes(t)}}});var Zn,Qn,ea,ta=w(()=>{"use strict";vi();xi();_i();ki();Si();Ei();Ti();Ai();$i();Di();Oi();bt();vt();_t();kt();Et();Tt();At();$t();Mt();It();Pt();Nt();Dt();Ot();Lt();Rt();Ht();Wt();Ut();Gt();jt();Kt();zt();Vt();Xt();Yt();Jt();Yi();R();fe();Zn=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 jn),S.registerAction("go_back",new zo),S.registerAction("reload_page",new Io),S.registerAction("close_tab",new Qo),S.registerAction("switch_tab",new wo),S.registerAction("click",new Xi),S.registerAction("hover",new Kn),S.registerAction("right_click",new Bn),S.registerAction("double_click",new Xn),S.registerAction("click_by_coordinates",new io),S.registerAction("right_click_by_coordinates",new Qa),S.registerAction("double_click_by_coordinates",new no),S.registerAction("drag_drop",new ao),S.registerAction("input_text",new zn),S.registerAction("clear_input",new pr),S.registerAction("press",new Wn),S.registerAction("send_keys_on_element",new Ja),S.registerAction("scroll_on_element",new Fo),S.registerAction("scroll_to_text",new Wo),S.registerAction("scroll",new Ct),S.registerAction("upload_file",new _o),S.registerAction("wait_for_download_complete",new To),S.registerAction("get_dropdown_options",new Go),S.registerAction("select_dropdown_option",new mo),S.registerAction("set_date_for_native_date_picker",new go),S.registerAction("verify",new ji),S.registerAction("ai_action",new so),S.registerAction("ai_extract",new ur),S.registerAction("ai_step",new lo),S.registerAction("ai_wait_until",new co),S.registerAction("generate_2fa_code",new or),S.registerAction("wait",new So),S.registerAction("wait_for_page_ready",new Za),S.registerAction("save_variable",new Do),S.registerAction("js_code",new to),S.registerAction("js_action",new eo),S.registerAction("function",new oo),S.registerAction("done",new tr),S.registerAction("click_element",new Xi),S.registerAction("click_element_by_index",new Xi),S.registerAction("hover_element_by_index",new Kn),S.registerAction("right_click_on_element",new Bn),S.registerAction("double_click_on_element",new Xn),S.registerAction("scroll_down",new Ct),S.registerAction("scroll_up",new Ct),S.registerAction("scroll_element",new Ct),S.registerAction("send_keys",new Wn),S.registerAction("open_tab",new jn),S.registerAction("fill",new zn),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(),wn(hi)),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(je.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(f=>` ${f}`),u=je.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(),wn(hi));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});`]}};Zn.actions=new Map,Zn.initialized=!1;Qn=Zn,ea=Qn});var Ji={};Re(Ji,{ActionHandler:()=>Qn,default:()=>ea});var qi=w(()=>{"use strict";ta();vi();xi();_i();ki();Si();Ei();Ti();Ai();$i();Di();Oi();bt();vt();_t();kt();Et();Tt();At();$t();Mt();It();Pt();Nt();Dt();Ot();Lt();Rt();Ht();Wt();Ut();Gt();jt();Kt();zt();Vt();Xt();Yt();Jt();Gi();St();G();Ce();H();te();gt();Yi();R();fe()});function Zi(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4117
|
-
${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
|
|
4118
|
-
\u2192 Action ${u+1}: ${
|
|
4114
|
+
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},Cc=oa.z.object({statement:oa.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function kr(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:Nc,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 tn,_r,Nc,qt=w(()=>{"use strict";tn=require("zod"),_r=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(()=>(ze(),Ke)),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||""}');`]}},Nc=tn.z.object({element_description:tn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:tn.z.string().describe("Name of the variable to store the extracted value")})});async function Oc(e,t,i,n,a={}){return{...await D(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 Tr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable 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 B(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 Oc("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 nn,Er,Dc,Zt=w(()=>{"use strict";j();R();nn=require("zod");M();Er=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},`),"});"]}};Dc=nn.z.object({element_index:nn.z.number().int().describe("Index of the input element to clear"),timeout_ms:nn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Lc(e,t,i,n,a={}){return{...await D(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ar(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 $r(e,t){e.register({name:"click",description:"Click an interactive element.",schema:Rc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Ar(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await Lc("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:Ar(`Click element ${a}`,"click",{index:a})}}}})}var an,on,Rc,Qt=w(()=>{"use strict";j();R();an=require("zod");M();on=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=Te(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};Rc=an.z.object({element_index:an.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:an.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var Fc,Hc,Xe,rn=w(()=>{"use strict";Fc=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],Hc=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Xe=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:Fc.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:!Hc.includes(t)}}});var sa,la,ca,da=w(()=>{"use strict";Ii();Pi();Ci();Ni();Oi();Di();Li();Ri();Fi();ji();Ki();xt();kt();Et();Tt();$t();Mt();It();Pt();Ct();Nt();Ot();Lt();Rt();Ft();Ht();Wt();Ut();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();rn();R();be();sa=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 Qn),S.registerAction("go_back",new nr),S.registerAction("reload_page",new Bo),S.registerAction("close_tab",new dr),S.registerAction("switch_tab",new $o),S.registerAction("click",new on),S.registerAction("hover",new ea),S.registerAction("right_click",new Jn),S.registerAction("double_click",new na),S.registerAction("click_by_coordinates",new po),S.registerAction("right_click_by_coordinates",new uo),S.registerAction("double_click_by_coordinates",new go),S.registerAction("drag_drop",new fo),S.registerAction("input_text",new ta),S.registerAction("clear_input",new Er),S.registerAction("press",new Yn),S.registerAction("send_keys_on_element",new so),S.registerAction("scroll_on_element",new Yo),S.registerAction("scroll_to_text",new qo),S.registerAction("scroll",new Dt),S.registerAction("upload_file",new No),S.registerAction("wait_for_download_complete",new Ro),S.registerAction("get_dropdown_options",new er),S.registerAction("select_dropdown_option",new So),S.registerAction("set_date_for_native_date_picker",new To),S.registerAction("verify",new en),S.registerAction("ai_action",new yo),S.registerAction("ai_extract",new _r),S.registerAction("ai_step",new vo),S.registerAction("ai_wait_until",new xo),S.registerAction("generate_2fa_code",new fr),S.registerAction("wait",new Do),S.registerAction("wait_for_page_ready",new co),S.registerAction("save_variable",new Ko),S.registerAction("js_code",new mo),S.registerAction("js_action",new ho),S.registerAction("function",new wo),S.registerAction("done",new hr),S.registerAction("click_element",new on),S.registerAction("click_element_by_index",new on),S.registerAction("hover_element_by_index",new ea),S.registerAction("right_click_on_element",new Jn),S.registerAction("double_click_on_element",new na),S.registerAction("scroll_down",new Dt),S.registerAction("scroll_up",new Dt),S.registerAction("scroll_element",new Dt),S.registerAction("send_keys",new Yn),S.registerAction("open_tab",new Qn),S.registerAction("fill",new ta),S.registerAction("ai_assert",new en),S.registerAction("assert",new en)}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(),Tn(ui)),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(Xe.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(f=>` ${f}`),u=Xe.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(M(),Tn(ui));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});`]}};sa.actions=new Map,sa.initialized=!1;la=sa,ca=la});var sn={};He(sn,{ActionHandler:()=>la,default:()=>ca});var ln=w(()=>{"use strict";da();Ii();Pi();Ci();Ni();Oi();Di();Li();Ri();Fi();ji();Ki();xt();kt();Et();Tt();$t();Mt();It();Pt();Ct();Nt();Ot();Lt();Rt();Ft();Ht();Wt();Ut();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();Qi();At();j();Oe();H();te();bt();rn();R();be()});function cn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
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 p=c.action_description||"Unknown action";d+=`
|
|
4116
|
+
\u2192 Action ${u+1}: ${p}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
|
|
4119
4117
|
\u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
|
|
4120
4118
|
Error: ${c}${l.outcome.error.length>100?"...":""}`}return l.evaluation&&(d+=`
|
|
4121
4119
|
Eval: ${l.evaluation}`),d}).join(`
|
|
@@ -4133,7 +4131,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
|
|
|
4133
4131
|
**Current URL**: ${i}
|
|
4134
4132
|
**Step**: ${e.currentStep+1}/${e.maxSteps}
|
|
4135
4133
|
|
|
4136
|
-
${o()}${r()}${a()}${n()}${s()}`.trim()}function
|
|
4134
|
+
${o()}${r()}${a()}${n()}${s()}`.trim()}function Mr(){return`
|
|
4137
4135
|
\u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
|
|
4138
4136
|
|
|
4139
4137
|
This is your last step. You MUST use the "done" action now.
|
|
@@ -4142,8 +4140,8 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4142
4140
|
- If the task is incomplete or partially complete, set success=false
|
|
4143
4141
|
- Include everything you've accomplished in the done action's text field
|
|
4144
4142
|
- No other actions are allowed on this step
|
|
4145
|
-
`.trim()}function
|
|
4146
|
-
`)}function
|
|
4143
|
+
`.trim()}function Wc(){let e=W.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 Ye.z.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof Ye.z.ZodNumber?l="number":s instanceof Ye.z.ZodString?l="string":s instanceof Ye.z.ZodBoolean?l="boolean":s instanceof Ye.z.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
|
+
`)}function dn(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
|
|
4147
4145
|
1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
|
|
4148
4146
|
- "success: <reason>" if the goal was fully achieved
|
|
4149
4147
|
- "partial: <reason>" if the goal was partially achieved but needs more work
|
|
@@ -4165,7 +4163,7 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4165
4163
|
`:"",d=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
|
|
4166
4164
|
`:"",c=a?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
|
|
4167
4165
|
`:"",u=n?` "memory": "<important facts to remember>", // Update only when learning something new
|
|
4168
|
-
`:"",
|
|
4166
|
+
`:"",p=o?` "actions": [ // Can be single action or multiple actions in sequence
|
|
4169
4167
|
{
|
|
4170
4168
|
"description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
|
|
4171
4169
|
"action_name": "<name of action to execute>",
|
|
@@ -4250,7 +4248,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
|
|
|
4250
4248
|
|
|
4251
4249
|
When stuck, call \`done\` with success=false and explain what happened.
|
|
4252
4250
|
|
|
4253
|
-
${
|
|
4251
|
+
${Wc()}
|
|
4254
4252
|
## Reasoning Rules
|
|
4255
4253
|
|
|
4256
4254
|
Use the \`thinking\` field to reason about each step:
|
|
@@ -4268,7 +4266,7 @@ You must ALWAYS respond with a valid JSON in this exact format:
|
|
|
4268
4266
|
\`\`\`json
|
|
4269
4267
|
{
|
|
4270
4268
|
${d}${c}${u} "current_goal": "State the current goal. Include only what to achieve, not how to achieve it.",
|
|
4271
|
-
${
|
|
4269
|
+
${p}
|
|
4272
4270
|
"completes_instruction": true | false // Is the entire task complete?
|
|
4273
4271
|
}
|
|
4274
4272
|
\`\`\`
|
|
@@ -4286,7 +4284,7 @@ ${m}
|
|
|
4286
4284
|
**Current Goal Examples:**
|
|
4287
4285
|
- "Add the product to the cart"
|
|
4288
4286
|
- "Find more product listings and extract details from the next 5 items on the page"
|
|
4289
|
-
${f}`.trim()}var
|
|
4287
|
+
${f}`.trim()}var Ye,un=w(()=>{"use strict";_e();Ye=require("zod")});var hn,ua=w(()=>{"use strict";un();ie();hn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,a,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=o,u=[],p=cn(a,e,t);if(u.push({type:"text",text:p}),u.push({type:"text",text:`## CURRENT PAGE STATE
|
|
4290
4288
|
|
|
4291
4289
|
**Interactive Elements**:
|
|
4292
4290
|
${i}`}),r&&Array.isArray(r)&&r.length>0){let f=r.map(([h,y],b)=>`${b+1}. ${h} \u2192 ${y}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
|
|
@@ -4302,19 +4300,19 @@ ${f.join(`
|
|
|
4302
4300
|
`,n+=`- Use the EXACT placeholder name as shown above
|
|
4303
4301
|
`,n+=`- Do NOT use the actual value directly in the action
|
|
4304
4302
|
`,n+=`- The values shown are for context only to help you understand what data is available
|
|
4305
|
-
`,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 qt=w(()=>{"use strict"});async function Cc(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(y=>f.includes(y))){i.delete(m);return}if(![...o].some(y=>f.startsWith(y))){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()-Pc;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=Ic;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 ze(e,t=Mc,i=$c){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Cc(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 $c,Mc,Ic,Pc,Te=w(()=>{"use strict";qt();H();$c=.5*1e3,Mc=30*1e3,Ic=1*1e3,Pc=3*1e3});function Nc(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 _r(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 Ee(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=Qi(i.customPrompt),m=new tn(u);k.log(`System prompt length: ${u.length} chars`);let f=!1,h="",y=[];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 ze(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 L=l.agentServices.getInteractiveClassNames(),F=l.agentServices.getIframeFallbackDomains();g=await vr(l.page,l.domService,L,F),k.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){k.log("Page navigating, waiting for load..."),await ze(l.page);let F=l.agentServices.getInteractiveClassNames(),N=l.agentServices.getIframeFallbackDomains();g=await vr(l.page,l.domService,F,N)}else throw k.error("Error preparing context",L),L}m.addStateMessage(e,g.currentUrl,g.domTree,g.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let v=await Oc(m,r,i,g.screenshotBase64);if(v.tokenUsages&&v.tokenUsages.length>0&&c.push(...v.tokenUsages),!v.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 T=v.stepOutput;Hc(d.currentStep,a,T);let E=await Rc(T,l,g.domState,d.currentStep,i.onEvent,g.screenshotBase64,v.debugInfo);y.push(...E.actionEntities);let $=Fc(d.currentStep,T,E,d,b,v.debugInfo,v.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(E.doneResult){f=E.doneResult.success,h=E.doneResult.summary;break}if(E.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=${y.length}, tokens=${c.length}`),Wc(d,y,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}),Bc(d,g,n,c,r)}}async function vr(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 Dc(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 Oc(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=ye(t,s),d={model:be(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(0,xr.generateText)(d),h=Date.now()-m,y=f,b=y.usage;k.llmCall(t,h,b);let g=y.reasoningText;g&&(k.thinking(g),i.onEvent?.({type:"thinking",text:g})),e.addAssistantMessage(f.text);let v={systemPrompt:o,userPrompt:Dc(r),rawLlmResponse:f.text,reasoningContent:g,screenshotWithSom:n},T=[],E=Nc(b,t);E&&T.push(E);let $=Lc(f.text);if(!$)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:v,tokenUsages:T};return{stepOutput:$,debugInfo:v,tokenUsages:T}}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 Lc(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 Rc(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={},y=f.kwargs?.element_index??f.kwargs?.index;if(typeof y=="number"){let g=i.selectorMap.get(y);g&&(h=await O(t.page,g))}let b={...h,action_description:f.description,action_data:{action_name:f.action_name,kwargs:f.kwargs}};try{let g=await W.execute(f.action_name,f.kwargs,u);f.action_name==="perform_accurate_operation"&&(b=g.actionEntity);let v=await u.agentServices.getCurrentPage();if(v&&(u.page=v,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 Fc(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 Hc(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 Wc(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 Bc(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 xr,kr=w(()=>{"use strict";ia();en();we();Ne();de();Te();Se();G();xr=require("ai")});var Sr={};Re(Sr,{TaskMessageManager:()=>tn,formatFinalStepWarning:()=>br,formatTaskContext:()=>Zi,getBrowserTaskJSONPrompt:()=>Qi,runTaskLoop:()=>_r});var Er=w(()=>{"use strict";kr();ia();en();we();Mi();Ne();dt();ut();We();ht();mt();de();Te();qt();Se();ot();rt();st();G();Ce();H();te();gt();R();fe()});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(W.has(i)){let a=await W.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 Uc()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Uc(){if(nn)return nn;let e=await Promise.resolve().then(()=>(qi(),Ji));return nn=new e.default,nn}async function Ii(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ee(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Tn(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 Pi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ee(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Tn(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 Ci(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Ee(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Ua(o,a,n)}async function Ni(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Er(),Sr)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var nn,wt=w(()=>{"use strict";bi();we();Ne();nn=null});var x,Kb,Qb,iy,jr,Bb,Kr,Yc,Jc,on,Ub,Gb,zr,Vr,qc,Gr,Zc,Zt,Qc,ed,td,ne,id,nd,jb,ty,Qt=w(()=>{"use strict";fe();x=require("zod"),Kb=require("yaml"),Qb=require("uuid"),iy=require("yaml"),jr=112,Bb=1080-jr,Kr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(Kr||{}),Yc={"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"}},Jc={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"]},on=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Jc[e].map(n=>Yc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ub={desktop:{label:"Desktop",type:"desktop",devices:on("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:on("mobile")}},Gb={desktop:{label:"Desktop",type:"desktop",devices:on("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:on("mobile",!0)}},zr=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(zr||{}),Vr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Vr||{}),qc=x.z.enum(["JS_CODE","AI_MODE"]),Gr=x.z.object({type:qc,expression:x.z.string()}),Zc=x.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Zt=x.z.object({uid:x.z.string(),type:Zc,comment:x.z.string().optional()}),Qc=x.z.object({action_data:x.z.object({action_name:x.z.string(),kwargs:x.z.record(x.z.any()).optional(),args:x.z.array(x.z.any()).optional()}),action_description:x.z.string().optional(),url:x.z.string().optional(),xpath:x.z.string().nullable().optional(),locator:x.z.string().nullable().optional(),css_selector:x.z.string().nullable().optional(),unique_selector:x.z.string().nullable().optional(),element_index:x.z.number().nullable().optional(),frame_path:x.z.array(x.z.any()).optional(),artifacts:x.z.record(x.z.any()).optional(),feedback:x.z.string().optional(),original_browser_use_action:x.z.any().optional()}).passthrough(),ed=Zt.extend({type:x.z.literal("DRAFT"),description:x.z.string()}),td=Zt.extend({type:x.z.literal("ACTION"),description:x.z.string(),action_entity:Qc.optional(),locator:x.z.string().optional(),use_pure_vision:x.z.boolean().optional()}),ne=x.z.lazy(()=>x.z.union([ed,td,Zt.extend({type:x.z.literal("STEP"),description:x.z.string().optional().default(""),statements:x.z.array(ne),reference_id:x.z.number().optional()}),Zt.extend({type:x.z.literal("IF_ELSE"),description:x.z.string().optional(),condition:Gr,then:x.z.array(ne),else:x.z.array(ne).optional()}),Zt.extend({type:x.z.literal("WHILE_LOOP"),description:x.z.string().optional(),condition:Gr,body:x.z.array(ne),timeout_ms:x.z.number().optional()})])),id=x.z.object({name:x.z.string(),statements:x.z.array(ne),teardown:x.z.array(ne).optional(),skip:x.z.union([x.z.boolean(),x.z.string()]).optional(),timeout:x.z.number().optional(),fail:x.z.union([x.z.boolean(),x.z.string()]).optional(),only:x.z.boolean().optional(),slow:x.z.boolean().optional()}),nd=x.z.object({tests:x.z.array(id).min(1),beforeAll:x.z.array(ne).optional(),afterAll:x.z.array(ne).optional(),beforeEach:x.z.array(ne).optional(),afterEach:x.z.array(ne).optional()}),jb=x.z.object({comment:x.z.string().optional(),version:x.z.string().optional(),goal:x.z.string().optional(),url:x.z.string().optional(),baseURL:x.z.string().optional(),final_feedback:x.z.string().optional(),completed:x.z.boolean().optional(),success:x.z.boolean().optional(),statements:x.z.array(ne).optional(),teardown:x.z.array(ne).optional(),last_modified_at:x.z.string().optional(),testGroup:nd.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"}),ty=1024*1024});var oa=w(()=>{"use strict";de();Te()});var _,qr,ra,Zr,Ye,Qr,es,ts,ee,is,rn,sa,la=w(()=>{"use strict";_=require("zod"),qr=_.z.enum(["JS_CODE","AI_MODE"]),ra=_.z.object({type:qr,expression:_.z.string()}),Zr=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ye=_.z.object({uid:_.z.string(),type:Zr,comment:_.z.string().optional()}),Qr=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),es=Ye.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),ts=Ye.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:Qr.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),ee=_.z.lazy(()=>_.z.union([es,ts,Ye.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(ee),reference_id:_.z.number().optional()}),Ye.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:ra,then:_.z.array(ee),else:_.z.array(ee).optional()}),Ye.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:ra,body:_.z.array(ee),timeout_ms:_.z.number().optional()})])),is=_.z.object({name:_.z.string(),statements:_.z.array(ee),teardown:_.z.array(ee).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),rn=_.z.object({tests:_.z.array(is).min(1),beforeAll:_.z.array(ee).optional(),afterAll:_.z.array(ee).optional(),beforeEach:_.z.array(ee).optional(),afterEach:_.z.array(ee).optional()}),sa=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(ee).optional(),teardown:_.z.array(ee).optional(),last_modified_at:_.z.string().optional(),testGroup:rn.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function rs(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(oe)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(oe)),i}function sn(e,t){if(e.testGroup)return ls(e,t);let i=rs(e,t),n=new D.Document(i);return e.comment&&(n.commentBefore=e.comment),ns(n,e.statements??[]),e.teardown&&ns(n,e.teardown,"teardown"),n.toString(ss)}function ns(e,t,i="statements"){let n=e.contents;if(!n||!(0,D.isMap)(n))return;let a=n.get(i,!0);(0,D.isSeq)(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),(0,D.isMap)(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);(0,D.isSeq)(r)&&ei(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);(0,D.isSeq)(r)&&ei(r,n.then);let s=o.get("ELSE",!0);(0,D.isSeq)(s)&&n.else&&ei(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);(0,D.isSeq)(r)&&ei(r,n.body)}}}}function ls(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(oe)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(oe)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(oe)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(oe)),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(oe),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(oe)),r}),n.suite=a,(0,D.stringify)(n,ss)}function oe(e){switch(e.type){case"DRAFT":return ud(e);case"ACTION":return hd(e);case"STEP":return md(e);case"IF_ELSE":return pd(e);case"WHILE_LOOP":return gd(e)}}function ud(e){return{intent:e.description}}function hd(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(oe)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function pd(e){let t={IF:cs(e.condition),THEN:e.then.map(oe)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(oe)),t}function gd(e){let t={WHILE:cs(e.condition),DO:e.body.map(oe)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function cs(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function da(e){try{let t=(0,D.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function ca(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ca);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]=ca(o);return n}function _e(e){if(e.length>as)throw new Error(`YAML input too large (${e.length} bytes, max ${as})`);let t=ca((0,D.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return fd(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:re(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=re(t.teardown));let n=sa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return ln(e,a),a}function fd(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:re(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=re(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=re(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=re(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=re(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=re(t.afterEach));let o=rn.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 re(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(wd)}function wd(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 bd(t);if("WHILE"in t)return yd(t);if("STEP"in t)return vd(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,ae.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,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:(0,ae.v4)(),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:(0,ae.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,ae.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,ae.v4)(),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:(0,ae.v4)(),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 os({...n,action:"function",functionName:i})}if("action"in t)return os(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,ae.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function ds(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 bd(e){let t=ds(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,ae.v4)(),type:"IF_ELSE",condition:t,then:re(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=re(e.ELSE)),n}function yd(e){let t=ds(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,ae.v4)(),type:"WHILE_LOOP",condition:t,body:re(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function vd(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,ae.v4)(),type:"STEP",description:t,statements:re(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function os(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))xd.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:(0,ae.v4)(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function ln(e,t){let i;try{i=(0,D.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,D.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let a=n,o=a.get("statements",!0);(0,D.isSeq)(o)&&t.statements&&Je(o,t.statements);let r=a.get("teardown",!0);(0,D.isSeq)(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"&&(0,D.isMap)(n)){let o=n.get("statements",!0);(0,D.isSeq)(o)&&Je(o,a.statements)}else if(a.type==="IF_ELSE"&&(0,D.isMap)(n)){let o=n.get("THEN",!0);(0,D.isSeq)(o)&&Je(o,a.then);let r=n.get("ELSE",!0);(0,D.isSeq)(r)&&a.else&&Je(r,a.else)}else if(a.type==="WHILE_LOOP"&&(0,D.isMap)(n)){let o=n.get("DO",!0);(0,D.isSeq)(o)&&Je(o,a.body)}}}var D,ae,ss,as,xd,cn=w(()=>{"use strict";la();D=require("yaml"),ae=require("uuid");ss={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};as=1024*1024;xd=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});var us,hs=w(()=>{"use strict";cn();us=require("yaml")});var dn=w(()=>{"use strict"});var ms=w(()=>{"use strict";cn();dn()});var ps=w(()=>{"use strict"});var gs=w(()=>{"use strict"});var fs=w(()=>{"use strict"});var un=w(()=>{"use strict"});var ws=w(()=>{"use strict";un()});var bs,Sd,ys,vs,ti,Ed,Td,xs=w(()=>{"use strict";bs=112,Sd=1080-bs,ys={"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"}},vs={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"),vs[e].map(n=>ys[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ed={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile")}},Td={desktop:{label:"Desktop",type:"desktop",devices:ti("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ti("mobile",!0)}}});var _s=w(()=>{"use strict"});var ks=w(()=>{"use strict";dn()});var De,Ss=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 Es=w(()=>{"use strict"});var Ts=w(()=>{"use strict"});var As=w(()=>{"use strict"});var $s=w(()=>{"use strict";un()});var qe=w(()=>{"use strict";hs();ms();cn();la();ps();gs();fs();ws();xs();_s();ks();dn();Ss();Es();Ts();As();$s();un()});function Cd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Nd(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 Cs(e){let t=Cd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Nd(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function A(e,t){q.set(e,t)}function Oe(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 Ms(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 Os(e,t){let i={expandingPaths:new Set([(0,ai.resolve)(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=Ae(n.statements,t,i)),Array.isArray(n.teardown)&&(n.teardown=Ae(n.teardown,t,i));for(let a of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[a])&&(n[a]=Ae(n[a],t,i));return{doc:n,referencedTemplatePaths:Array.from(i.referencedPaths)}}function Ae(e,t,i){let n=[];for(let a of e)if(Dd(a)){let o=Od(a,t,i);n.push(...o)}else n.push(Ld(a,t,i));return n}function Dd(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function Od(e,t,i){if(i.depth>=Is)throw new Error(`Template expansion exceeded maximum depth of ${Is}. Check for deeply nested or circular template references.`);let n=(0,ai.resolve)((0,ai.dirname)(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=(0,Ds.readFileSync)(n,"utf-8")}catch(c){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${c.message}`)}let o=(0,ii.parse)(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=(0,ii.stringify)(l);for(let[m,f]of Object.entries(s))u=u.split(`<<${m}>>`).join(String(f));l=(0,ii.parse)(u)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths};return Ae(l,n,d)}function Ld(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Ae(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Ae(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Ae(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Ae(n.DO,t,i)),n}function Rs(e,t){let i=(0,ni.parse)(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 Ls('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Fd(i,n,a,o,t)}return Rd(i,n,a,o,t)}function Rd(e,t,i,n,a){let o=e?.beforeEach,r=e?.afterEach,s=Fs(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 Ls(`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=Os(e,a);e=b.doc,f=b.referencedTemplatePaths}let h=(0,ni.stringify)(e),y=_e(h);return a&&(Ze(y.statements??[],a,"main"),y.teardown&&Ze(y.teardown,a,"teardown")),{testFlow:y,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 Fd(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 y={goal:h.name,statements:h.statements};h.teardown&&(y.teardown=h.teardown);let b=[],g=y;if(a&&typeof y=="object"){let $=Os(y,a);g=$.doc,b=$.referencedTemplatePaths,c.push(...b)}let v=(0,ni.stringify)(g),T=_e(v),E=Fs(h.parameters);return{testFlow:T,name:h.name,tags:Array.isArray(h.tags)?h.tags:void 0,parameters:E,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 Fs(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function Ze(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Hd(t,o,r),a.type===De.STEP)Ze(a.statements,t,o);else if(a.type===De.IF_ELSE){let s=a;Ze(s.then,t,`${o}.then`),s.else&&Ze(s.else,t,`${o}.else`)}else a.type===De.WHILE_LOOP&&Ze(a.body,t,`${o}.body`)}}function Hd(e,t,i){let n=(0,Ns.createHash)("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 Pd,Ns,ni,Ds,ai,ii,Ps,q,Is,Ls,Hs=w(()=>{"use strict";qe();Pd=require("yaml");qe();Ns=require("crypto"),ni=require("yaml");qe();Ds=require("fs"),ai=require("path"),ii=require("yaml");qe();Ps=5e3;q=new Map;A("click",e=>{let t=Cs(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Ps;return[`await ${t}.click({ timeout: ${i} });`]});A("click_element",q.get("click"));A("click_element_by_index",q.get("click"));A("double_click",e=>Oe("double_click",e));A("double_click_on_element",q.get("double_click"));A("right_click",e=>Oe("right_click",e));A("right_click_on_element",q.get("right_click"));A("hover",e=>Oe("hover",e));A("hover_element_by_index",q.get("hover"));A("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Oe("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});A("fill",q.get("input_text"));A("clear_input",e=>Oe("clear_input",e));A("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});A("send_keys",q.get("press"));A("send_keys_on_element",e=>{let t=Cs(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??Ps;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});A("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Oe("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});A("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)})');`]});A("scroll_down",q.get("scroll"));A("scroll_up",q.get("scroll"));A("scroll_element",q.get("scroll"));A("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});A("scroll_on_element",e=>Oe("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));A("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)} } },`,"});"]});A("open_tab",q.get("go_to_url"));A("go_back",()=>['await agent.execAction("go_back", page, {});']);A("reload_page",()=>['await agent.execAction("reload_page", page, {});']);A("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);A("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);A("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 ei=w(()=>{"use strict"});async function Kc(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(f=>p.includes(f))},l=u=>{let p=u.resourceType(),f=u.url();if(!a.has(p)||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 p=u.request();if(!i.has(p))return;let f=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(y=>f.includes(y))){i.delete(p);return}if(![...o].some(y=>f.startsWith(y))){i.delete(p);return}let h=u.headers()["content-length"];if(h)try{if(parseInt(h,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-jc;for(let u of await e.requests()){let p=u.resourceType(),f=u.url(),h=u.timing();a.has(p)&&!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(),p=Gc;for(;;){await new Promise(h=>setTimeout(h,100));let f=Date.now();if(i.size===0&&f-n>=p){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 Je(e,t=Uc,i=Bc){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Kc(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 Bc,Uc,Gc,jc,$e=w(()=>{"use strict";ei();H();Bc=.5*1e3,Uc=30*1e3,Gc=1*1e3,jc=3*1e3});function zc(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 Nr(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 Ae(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=dn(i.customPrompt),p=new hn(u);k.log(`System prompt length: ${u.length} chars`);let f=!1,h="",y=[];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 Je(l.page),k.log("Page stabilized")}catch{k.log("Page stabilization timed out, continuing anyway")}let m;try{k.log("Preparing context (DOM + screenshot)...");let L=l.agentServices.getInteractiveClassNames(),F=l.agentServices.getIframeFallbackDomains();m=await Pr(l.page,l.domService,L,F),k.log("Context prepared")}catch(L){if(L.message.includes("Execution context was destroyed")){k.log("Page navigating, waiting for load..."),await Je(l.page);let F=l.agentServices.getInteractiveClassNames(),N=l.agentServices.getIframeFallbackDomains();m=await Pr(l.page,l.domService,F,N)}else throw k.error("Error preparing context",L),L}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let v=await Xc(p,r,i,m.screenshotBase64);if(v.tokenUsages&&v.tokenUsages.length>0&&c.push(...v.tokenUsages),!v.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 T=v.stepOutput;Zc(d.currentStep,a,T);let E=await Jc(T,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,v.debugInfo);y.push(...E.actionEntities);let $=qc(d.currentStep,T,E,d,b,v.debugInfo,v.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(E.doneResult){f=E.doneResult.success,h=E.doneResult.summary;break}if(E.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=${y.length}, tokens=${c.length}`),Qc(d,y,f,h,n,c,r)}catch(b){let m=b.message;return k.error(`Task execution failed: ${m}`,b),i.onEvent?.({type:"error",error:m,recoverable:!1}),ed(d,m,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 Vc(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 Xc(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(p=>p.type==="image").length);let l=ve(t,s),d={model:ye(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let p=Date.now();k.log(`Calling LLM (${t})...`);let f=await(0,Cr.generateText)(d),h=Date.now()-p,y=f,b=y.usage;k.llmCall(t,h,b);let m=y.reasoningText;m&&(k.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(f.text);let v={systemPrompt:o,userPrompt:Vc(r),rawLlmResponse:f.text,reasoningContent:m,screenshotWithSom:n},T=[],E=zc(b,t);E&&T.push(E);let $=Yc(f.text);if(!$)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:v,tokenUsages:T};return{stepOutput:$,debugInfo:v,tokenUsages:T}}catch(p){if(u<c-1){k.log(`Attempt ${u+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(f=>setTimeout(f,i.retryDelay||1e3));continue}else throw k.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Yc(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 Jc(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},p=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={},y=f.kwargs?.element_index??f.kwargs?.index;if(typeof y=="number"){let m=i.selectorMap.get(y);m&&(h=await D(t.page,m))}let b={...h,action_description:f.description,action_data:{action_name:f.action_name,kwargs:f.kwargs}};try{let m=await W.execute(f.action_name,f.kwargs,u);f.action_name==="perform_accurate_operation"&&(b=m.actionEntity);let v=await u.agentServices.getCurrentPage();if(v&&(u.page=v,t.page=u.page),m?.success===!1){l=!1,k.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,k.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function qc(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 Zc(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 ed(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 Cr,Or=w(()=>{"use strict";ua();un();_e();De();ie();$e();xe();j();Cr=require("ai")});var Dr={};He(Dr,{TaskMessageManager:()=>hn,formatFinalStepWarning:()=>Mr,formatTaskContext:()=>cn,getBrowserTaskJSONPrompt:()=>dn,runTaskLoop:()=>Nr});var Lr=w(()=>{"use strict";Or();ua();un();_e();Hi();De();mt();pt();je();gt();ft();ie();$e();ei();xe();at();Be();ot();j();Oe();H();te();bt();R();be()});async function yt(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(W.has(i)){let a=await W.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 td()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function td(){if(mn)return mn;let e=await Promise.resolve().then(()=>(ln(),sn));return mn=new e.default,mn}async function Wi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ae(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Dn(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 Bi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ae(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Dn(r,o,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,p=await yt(l,o);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:u}}async function Ui(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Ae(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),Qa(o,a,n)}async function Gi(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Lr(),Dr)),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 mn,vt=w(()=>{"use strict";$i();_e();De();mn=null});var x,_y,Iy,Ny,ts,by,is,ld,cd,gn,yy,vy,ns,as,dd,es,ud,ti,hd,md,pd,re,gd,fd,xy,Cy,ii=w(()=>{"use strict";be();x=require("zod"),_y=require("yaml"),Iy=require("uuid"),Ny=require("yaml"),ts=112,by=1080-ts,is=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(is||{}),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"]},gn=(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))},yy={desktop:{label:"Desktop",type:"desktop",devices:gn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:gn("mobile")}},vy={desktop:{label:"Desktop",type:"desktop",devices:gn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:gn("mobile",!0)}},ns=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ns||{}),as=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(as||{}),dd=x.z.enum(["JS_CODE","AI_MODE"]),es=x.z.object({type:dd,expression:x.z.string()}),ud=x.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ti=x.z.object({uid:x.z.string(),type:ud,comment:x.z.string().optional()}),hd=x.z.object({action_data:x.z.object({action_name:x.z.string(),kwargs:x.z.record(x.z.any()).optional(),args:x.z.array(x.z.any()).optional()}),action_description:x.z.string().optional(),url:x.z.string().optional(),xpath:x.z.string().nullable().optional(),locator:x.z.string().nullable().optional(),css_selector:x.z.string().nullable().optional(),unique_selector:x.z.string().nullable().optional(),element_index:x.z.number().nullable().optional(),frame_path:x.z.array(x.z.any()).optional(),artifacts:x.z.record(x.z.any()).optional(),feedback:x.z.string().optional(),original_browser_use_action:x.z.any().optional()}).passthrough(),md=ti.extend({type:x.z.literal("DRAFT"),description:x.z.string()}),pd=ti.extend({type:x.z.literal("ACTION"),description:x.z.string(),action_entity:hd.optional(),locator:x.z.string().optional(),use_pure_vision:x.z.boolean().optional()}),re=x.z.lazy(()=>x.z.union([md,pd,ti.extend({type:x.z.literal("STEP"),description:x.z.string().optional().default(""),statements:x.z.array(re),reference_id:x.z.number().optional()}),ti.extend({type:x.z.literal("IF_ELSE"),description:x.z.string().optional(),condition:es,then:x.z.array(re),else:x.z.array(re).optional()}),ti.extend({type:x.z.literal("WHILE_LOOP"),description:x.z.string().optional(),condition:es,body:x.z.array(re),timeout_ms:x.z.number().optional()})])),gd=x.z.object({name:x.z.string(),statements:x.z.array(re),teardown:x.z.array(re).optional(),skip:x.z.union([x.z.boolean(),x.z.string()]).optional(),timeout:x.z.number().optional(),fail:x.z.union([x.z.boolean(),x.z.string()]).optional(),only:x.z.boolean().optional(),slow:x.z.boolean().optional()}),fd=x.z.object({tests:x.z.array(gd).min(1),beforeAll:x.z.array(re).optional(),afterAll:x.z.array(re).optional(),beforeEach:x.z.array(re).optional(),afterEach:x.z.array(re).optional()}),xy=x.z.object({comment:x.z.string().optional(),version:x.z.string().optional(),goal:x.z.string().optional(),url:x.z.string().optional(),baseURL:x.z.string().optional(),final_feedback:x.z.string().optional(),completed:x.z.boolean().optional(),success:x.z.boolean().optional(),statements:x.z.array(re).optional(),teardown:x.z.array(re).optional(),last_modified_at:x.z.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"}),Cy=1024*1024});var pa=w(()=>{"use strict";ie();$e()});var fn=w(()=>{"use strict"});var _,ls,ga,cs,Qe,ds,us,hs,ae,ms,wn,fa,wa=w(()=>{"use strict";_=require("zod"),ls=_.z.enum(["JS_CODE","AI_MODE"]),ga=_.z.object({type:ls,expression:_.z.string()}),cs=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Qe=_.z.object({uid:_.z.string(),type:cs,comment:_.z.string().optional()}),ds=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),us=Qe.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),hs=Qe.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:ds.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),ae=_.z.lazy(()=>_.z.union([us,hs,Qe.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(ae),reference_id:_.z.number().optional()}),Qe.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:ga,then:_.z.array(ae),else:_.z.array(ae).optional()}),Qe.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:ga,body:_.z.array(ae),timeout_ms:_.z.number().optional()})])),ms=_.z.object({name:_.z.string(),statements:_.z.array(ae),teardown:_.z.array(ae).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),wn=_.z.object({tests:_.z.array(ms).min(1),beforeAll:_.z.array(ae).optional(),afterAll:_.z.array(ae).optional(),beforeEach:_.z.array(ae).optional(),afterEach:_.z.array(ae).optional()}),fa=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(ae).optional(),teardown:_.z.array(ae).optional(),last_modified_at:_.z.string().optional(),testGroup:wn.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function ws(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(le)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(le)),i}function bn(e,t){if(e.testGroup)return ys(e,t);let i=ws(e,t),n=new O.Document(i);return e.comment&&(n.commentBefore=e.comment),ps(n,e.statements??[]),e.teardown&&ps(n,e.teardown,"teardown"),n.toString(bs)}function ps(e,t,i="statements"){let n=e.contents;if(!n||!(0,O.isMap)(n))return;let a=n.get(i,!0);(0,O.isSeq)(a)&&ni(a,t)}function ni(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),(0,O.isMap)(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);(0,O.isSeq)(r)&&ni(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);(0,O.isSeq)(r)&&ni(r,n.then);let s=o.get("ELSE",!0);(0,O.isSeq)(s)&&n.else&&ni(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);(0,O.isSeq)(r)&&ni(r,n.body)}}}}function ys(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(le)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(le)),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(le),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(le)),r}),n.suite=a,(0,O.stringify)(n,bs)}function le(e){switch(e.type){case"DRAFT":return Sd(e);case"ACTION":return Ed(e);case"STEP":return Td(e);case"IF_ELSE":return Ad(e);case"WHILE_LOOP":return $d(e)}}function Sd(e){return{intent:e.description}}function Ed(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 Td(e){let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function Ad(e){let t={IF:vs(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function $d(e){let t={WHILE:vs(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function vs(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function ya(e){try{let t=(0,O.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function ba(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ba);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]=ba(o);return n}function Ee(e){if(e.length>gs)throw new Error(`YAML input too large (${e.length} bytes, max ${gs})`);let t=ba((0,O.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Md(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ce(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ce(t.teardown));let n=fa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return yn(e,a),a}function Md(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:ce(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ce(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=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ce(t.afterEach));let o=wn.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 ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Id)}function Id(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 Pd(t);if("WHILE"in t)return Cd(t);if("STEP"in t)return Nd(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,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:(0,se.v4)(),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:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,se.v4)(),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:(0,se.v4)(),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 fs({...n,action:"function",functionName:i})}if("action"in t)return fs(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function xs(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 Pd(e){let t=xs(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function Cd(e){let t=xs(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Nd(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,se.v4)(),type:"STEP",description:t,statements:ce(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function fs(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))Od.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:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function yn(e,t){let i;try{i=(0,O.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,O.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let a=n,o=a.get("statements",!0);(0,O.isSeq)(o)&&t.statements&&et(o,t.statements);let r=a.get("teardown",!0);(0,O.isSeq)(r)&&t.teardown&&et(r,t.teardown)}function et(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let a=t[i];if(a.type==="STEP"&&(0,O.isMap)(n)){let o=n.get("statements",!0);(0,O.isSeq)(o)&&et(o,a.statements)}else if(a.type==="IF_ELSE"&&(0,O.isMap)(n)){let o=n.get("THEN",!0);(0,O.isSeq)(o)&&et(o,a.then);let r=n.get("ELSE",!0);(0,O.isSeq)(r)&&a.else&&et(r,a.else)}else if(a.type==="WHILE_LOOP"&&(0,O.isMap)(n)){let o=n.get("DO",!0);(0,O.isSeq)(o)&&et(o,a.body)}}}var O,se,bs,gs,Od,vn=w(()=>{"use strict";wa();O=require("yaml"),se=require("uuid");bs={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};gs=1024*1024;Od=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});var _s=w(()=>{"use strict";fn();vn()});var ks=w(()=>{"use strict";fn()});var Ss,Es=w(()=>{"use strict";vn();Ss=require("yaml")});var Le,Ts=w(()=>{"use strict";Le=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Le||{})});var xn=w(()=>{"use strict"});var As=w(()=>{"use strict";xn()});var $s,Fd,Ms,Is,ai,Hd,Wd,Ps=w(()=>{"use strict";$s=112,Fd=1080-$s,Ms={"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"}},Is={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"]},ai=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Is[e].map(n=>Ms[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Hd={desktop:{label:"Desktop",type:"desktop",devices:ai("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ai("mobile")}},Wd={desktop:{label:"Desktop",type:"desktop",devices:ai("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ai("mobile",!0)}}});var Cs=w(()=>{"use strict"});var Ns=w(()=>{"use strict"});var Os=w(()=>{"use strict"});var Ds=w(()=>{"use strict"});var Ls=w(()=>{"use strict"});var Rs=w(()=>{"use strict"});var Fs=w(()=>{"use strict"});var Hs=w(()=>{"use strict";xn()});var tt=w(()=>{"use strict";_s();ks();fn();Es();vn();wa();Ts();As();Ps();Cs();Ns();Os();Ds();Ls();Rs();Fs();Hs();xn()});function Kd(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function zd(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 Gs(e){let t=Kd(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=zd(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function A(e,t){Z.set(e,t)}function Re(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 Ws(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 zs(e,t){let i={expandingPaths:new Set([(0,si.resolve)(t)]),depth:0,referencedPaths:new Set},n={...e};Array.isArray(n.statements)&&(n.statements=Me(n.statements,t,i)),Array.isArray(n.teardown)&&(n.teardown=Me(n.teardown,t,i));for(let a of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(n[a])&&(n[a]=Me(n[a],t,i));return{doc:n,referencedTemplatePaths:Array.from(i.referencedPaths)}}function Me(e,t,i){let n=[];for(let a of e)if(Vd(a)){let o=Xd(a,t,i);n.push(...o)}else n.push(Yd(a,t,i));return n}function Vd(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function Xd(e,t,i){if(i.depth>=Bs)throw new Error(`Template expansion exceeded maximum depth of ${Bs}. Check for deeply nested or circular template references.`);let n=(0,si.resolve)((0,si.dirname)(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=(0,Ks.readFileSync)(n,"utf-8")}catch(c){throw new Error(`Failed to read template file: ${n} (referenced from ${t}): ${c.message}`)}let o=(0,oi.parse)(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=(0,oi.stringify)(l);for(let[p,f]of Object.entries(s))u=u.split(`<<${p}>>`).join(String(f));l=(0,oi.parse)(u)}let d={expandingPaths:new Set([...i.expandingPaths,n]),depth:i.depth+1,referencedPaths:i.referencedPaths};return Me(l,n,d)}function Yd(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Me(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Me(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Me(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Me(n.DO,t,i)),n}function Xs(e,t){let i=(0,ri.parse)(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 Vs('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return qd(i,n,a,o,t)}return Jd(i,n,a,o,t)}function Jd(e,t,i,n,a){let o=e?.beforeEach,r=e?.afterEach,s=Ys(e?.parameters),l=e?.timeout,d=e?.skip,c=e?.fail,u=e?.only,p=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 Vs(`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=zs(e,a);e=b.doc,f=b.referencedTemplatePaths}let h=(0,ri.stringify)(e),y=Ee(h);return a&&(it(y.statements??[],a,"main"),y.teardown&&it(y.teardown,a,"teardown")),{testFlow:y,name:t,tags:i,use:n,beforeEach:o,afterEach:r,parameters:s,timeout:l,skip:d,fail:c,only:u,slow:p,referencedTemplatePaths:f}}function qd(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 y={goal:h.name,statements:h.statements};h.teardown&&(y.teardown=h.teardown);let b=[],m=y;if(a&&typeof y=="object"){let $=zs(y,a);m=$.doc,b=$.referencedTemplatePaths,c.push(...b)}let v=(0,ri.stringify)(m),T=Ee(v),E=Ys(h.parameters);return{testFlow:T,name:h.name,tags:Array.isArray(h.tags)?h.tags:void 0,parameters:E,timeout:h.timeout,skip:h.skip,fail:h.fail,only:h.only,slow:h.slow}}),p=o.base_url,f=p?{...n,baseURL:p}:n;return{suite:{beforeAll:r,afterAll:s,beforeEach:l,afterEach:d,tests:u},name:t,tags:i,use:f,referencedTemplatePaths:c}}function Ys(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 it(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Zd(t,o,r),a.type===Le.STEP)it(a.statements,t,o);else if(a.type===Le.IF_ELSE){let s=a;it(s.then,t,`${o}.then`),s.else&&it(s.else,t,`${o}.else`)}else a.type===Le.WHILE_LOOP&&it(a.body,t,`${o}.body`)}}function Zd(e,t,i){let n=(0,js.createHash)("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 jd,js,ri,Ks,si,oi,Us,Z,Bs,Vs,Js=w(()=>{"use strict";tt();jd=require("yaml");tt();js=require("crypto"),ri=require("yaml");tt();Ks=require("fs"),si=require("path"),oi=require("yaml");tt();Us=5e3;Z=new Map;A("click",e=>{let t=Gs(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??Us;return[`await ${t}.click({ timeout: ${i} });`]});A("click_element",Z.get("click"));A("click_element_by_index",Z.get("click"));A("double_click",e=>Re("double_click",e));A("double_click_on_element",Z.get("double_click"));A("right_click",e=>Re("right_click",e));A("right_click_on_element",Z.get("right_click"));A("hover",e=>Re("hover",e));A("hover_element_by_index",Z.get("hover"));A("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Re("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});A("fill",Z.get("input_text"));A("clear_input",e=>Re("clear_input",e));A("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});A("send_keys",Z.get("press"));A("send_keys_on_element",e=>{let t=Gs(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??Us;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});A("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Re("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});A("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)})');`]});A("scroll_down",Z.get("scroll"));A("scroll_up",Z.get("scroll"));A("scroll_element",Z.get("scroll"));A("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});A("scroll_on_element",e=>Re("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));A("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)} } },`,"});"]});A("open_tab",Z.get("go_to_url"));A("go_back",()=>['await agent.execAction("go_back", page, {});']);A("reload_page",()=>['await agent.execAction("reload_page", page, {});']);A("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);A("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);A("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(`
|
|
4306
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(`
|
|
4307
|
-
`):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});A("ai_assert",
|
|
4308
|
-
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i});A("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=
|
|
4309
|
-
`):["// Skipping js_action: missing code"]});
|
|
4305
|
+
`):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});A("ai_assert",Z.get("verify"));A("assert",Z.get("verify"));A("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});`]});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"]});A("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||""}');`]});A("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"]});A("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)} } },`,"});"]});A("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});A("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=Ws(c);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=Ws(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});A("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)} } },`,"});"]});A("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},`),"});"]});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} } },`,"});"]);A("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} } },`,"});"]);A("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} } },`,"});"]});A("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},`),"});"]});A("done",()=>["// Done - no action needed"]);A("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4307
|
+
`):["// Skipping js_action: missing code"]});Bs=5;Vs=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var el={};He(el,{createTestFlowRouter:()=>Qd});function _n(e){if(!e||e.length===0)return[];let i=(0,Zs.stringify)({goal:"_hook",statements:e});return Ee(i).statements??[]}async function Qs(e){try{let t=await de.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 Qs(ue.join(e,i.name))))return!0}catch{}return!1}function Qd(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=(0,qs.Router)();o.get("/api/files",async(s,l)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,c=ue.resolve(d),u=await de.readdir(c,{withFileTypes:!0}),p=[];for(let h of u)if(h.name!=="node_modules"&&!h.name.startsWith("."))if(h.isDirectory()){let y=ue.join(c,h.name);await Qs(y)&&p.push({name:h.name,type:"directory",path:y})}else h.isFile()&&h.name.endsWith(".test.yaml")&&p.push({name:h.name,type:"file",path:ue.join(c,h.name)});p.sort((h,y)=>h.type!==y.type?h.type==="directory"?-1:1:h.name.localeCompare(y.name));let f=ue.dirname(c);l.json({dir:c,parent:f!==c?f:null,entries:p,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=ue.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 de.readFile(c,"utf-8"),p=await de.stat(c),f=ya(u),h=Xs(u,c);if(h.suite){let y=h.suite,b={tests:y.tests.map(v=>({name:v.name,statements:v.testFlow.statements??[],teardown:v.testFlow.teardown,skip:v.skip,timeout:v.timeout,fail:v.fail,only:v.only,slow:v.slow})),beforeAll:_n(y.beforeAll),afterAll:_n(y.afterAll),beforeEach:_n(y.beforeEach),afterEach:_n(y.afterEach)},m={version:"1.3.0",baseURL:h.use?.baseURL,testGroup:b};l.json({isSuite:!0,testFlow:m,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:ue.basename(c),lastModified:p.mtimeMs})}else{let y=h.testFlow;yn(u,y),l.json({isSuite:!1,testFlow:y,metadata:f,name:h.name,tags:h.tags,use:h.use,filePath:c,fileName:ue.basename(c),lastModified:p.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:p}=s.body;if(!u)return l.status(400).json({error:"testFlow is required"});let f=bn(u,p),h=c+".tmp";await de.writeFile(h,f,"utf-8"),await de.rename(h,c);let y=await de.stat(c);l.json({success:!0,lastModified:y.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),l.status(500).json({error:d.message})}}),o}var qs,de,ue,Zs,tl=w(()=>{"use strict";qs=require("express"),de=ee(require("fs/promises"),1),ue=ee(require("path"),1);tt();Js();Zs=require("yaml")});var nl={};He(nl,{createIntRunnerRouter:()=>eu});function eu(e){let t=(0,il.Router)();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)}
|
|
4310
4308
|
|
|
4311
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)}
|
|
4312
4310
|
|
|
4313
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)}
|
|
4314
4312
|
|
|
4315
|
-
`)};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
|
|
4316
|
-
`),
|
|
4317
|
-
`}let E=v.subject||"",$=v.from||"",I=v.to||"",L=v.date||"",F=v["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!T.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:$,to:I,date:L,body:T.trim(),message_id:F})}catch(h){
|
|
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 il,al=w(()=>{"use strict";il=require("express")});var iu={};He(iu,{PlaywrightSandboxService:()=>qe,startPlaywrightDebugServer:()=>tu});module.exports=dl(iu);var va=ee(require("express"),1);var Ze=ee(require("path"),1),rs=ee(require("fs/promises"),1),ss=ee(require("os"),1);H();H();vt();Ge();var ha=require("zod"),id=ha.z.object({instruction:ha.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function Rr(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:id,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 yt(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}xe();H();var Fr=require("ai"),Hr=require("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()}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||{},y=h.subject||"",b=h.from||"",m=h.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!y.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:y,from:b,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:h["message-id"]||""});continue}let p=u.split("/"),f=p[p.length-1];if(g.info(`Storage key: ${f}`),f){let h=`https://api.mailgun.net/v3/domains/${a}/messages/${f}`;try{let y=await fetch(h,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(y.ok){let b=await y.json(),m=b.Subject||"",v=b.From||"",T=b.To||"",E=b.Date||"",$=b["Message-Id"]||"";g.info(`subject: ${m}`),g.info(`from_addr: ${v}`),g.info(`to_addr: ${T}`),g.info(`date: ${E}`),g.info(`message_id: ${$}`);let I=b["body-html"]||b["body-plain"]||"";if(I&&I.includes("<")&&(I=(0,Hr.convert)(I)),g.info(`Body: ${I.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!I.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:m,from:v,to:T,date:E,body:I,message_id:$});continue}else g.warn(`Messages API returned ${y.status}`)}catch(y){g.warn(`Failed to parse JSON response: ${y}`)}}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 y=await h.text();g.info(`Fallback: Raw email length: ${y.length}`);let b=y.split(`
|
|
4314
|
+
`),m=!0,v={},T="";for(let N=0;N<b.length;N++){let z=b[N];if(z.trim()===""&&m){m=!1;continue}if(m){let J=z.match(/^([^:]+):\s*(.+)$/);J&&(v[J[1].toLowerCase()]=J[2])}else T+=z+`
|
|
4315
|
+
`}let E=v.subject||"",$=v.from||"",I=v.to||"",L=v.date||"",F=v["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!T.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:$,to:I,date:L,body:T.trim(),message_id:F})}catch(h){g.warn(`Error fetching raw message: ${h}`)}}if(o.length>0){try{o.sort((u,p)=>{let f=new Date(u.date).getTime();return new Date(p.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 ad(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
|
|
4318
4316
|
|
|
4319
4317
|
Please carefully examine the email content and look for:
|
|
4320
4318
|
1. Numeric codes (usually 4-8 digits)
|
|
@@ -4371,24 +4369,24 @@ Examples of what to extract:
|
|
|
4371
4369
|
Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1¶m2=value2
|
|
4372
4370
|
|
|
4373
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+`
|
|
4374
|
-
Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function
|
|
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}
|
|
4375
4373
|
---
|
|
4376
4374
|
Email Content:
|
|
4377
4375
|
---
|
|
4378
4376
|
${e}
|
|
4379
4377
|
---
|
|
4380
|
-
`,a=
|
|
4378
|
+
`,a=ye(i);return(await(0,Fr.generateText)({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:ve(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 Wr(e,t){g.info(`extract_email_content:
|
|
4381
4379
|
forward_email: ${t.forward_email}
|
|
4382
4380
|
extraction_type: ${t.extraction_type}
|
|
4383
4381
|
filters: ${JSON.stringify(t.filters||{})}
|
|
4384
4382
|
timeout: ${t.timeout||60}
|
|
4385
|
-
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=
|
|
4386
|
-
From: ${
|
|
4387
|
-
To: ${
|
|
4388
|
-
Date: ${
|
|
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(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 nd(e,t.forward_email,d);if(c.length>0){g.info(`Found ${c.length} emails matching criteria`);let u=[];for(let p of c){let f=`Subject: ${p.subject}
|
|
4384
|
+
From: ${p.from}
|
|
4385
|
+
To: ${p.to}
|
|
4386
|
+
Date: ${p.date}
|
|
4389
4387
|
|
|
4390
4388
|
Body:
|
|
4391
|
-
${m.body}`,h=await zc(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}`}}}H();te();var he=require("zod");function Ir(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 Pr=class{getMailgunConfig(){let e=K().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 Mr(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(/^\$/,"")||Ir(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)} },`,"});"]}},Vc=he.z.object({forward_email:he.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:he.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:he.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:he.z.string().optional().describe("Filter emails by sender address"),filter_to_email:he.z.string().optional().describe("Filter emails by recipient address"),filter_subject:he.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:he.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:he.z.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Cr(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:Vc,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 y=Ir(o);return{success:!0,actionEntity:h,message:`Extracted ${o} and saved to $${y}`}}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();vt();_t();kt();Et();Tt();At();$t();Mt();It();Pt();Nt();Dt();Ot();Lt();Rt();Ht();Wt();Ut();Gt();jt();Kt();zt();Vt();Xt();Yt();Jt();var an=null;async function me(){if(an)return an;let e=(await Promise.resolve().then(()=>(qi(),Ji))).default;return an=new e,an}async function Nr(e){let t=await me(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return wr(e,i),Jo(e,n),No(e,a),ar(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Dr(e){let t=await me(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return Xo(e,i),Vo(e,n),Po(e,a),"Navigate to URLs, go back, or reload the page"}async function Or(e){let t=await me(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return gr(e,i),Zo(e,n),$o(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Lr(e){let t=await me(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Ho(e,i),Bo(e,n),Lo(e,a),"Scroll the page or scroll to specific text/elements"}async function Rr(e){let t=await me(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return er(e,i),bo(e,n),"Switch between browser tabs or close tabs"}async function Fr(e){let t=await me(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return ko(e,i),Ao(e,n),"Upload files or wait for downloads to complete"}async function Hr(e){let t=await me(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return jo(e,i),po(e,n),fo(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function Wr(e){let t=await me(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Eo(e,i),Oo(e,n),ir(e,a),Tr(e),"Wait for conditions, save variables, or complete tasks"}async function Br(e){let t=(await me()).getAction("generate_2fa_code");rr(e,t);let i=new Pr;return(await Promise.resolve().then(()=>(qi(),Ji))).default.registerAction("extract_email_content",i),Cr(e,i),"Generate 2FA codes or extract email/activation codes"}async function Ur(e){let t=await me(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return dr(e,i),hr(e,n),uo(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}we();var Xc=[Nr(W),Dr(W),Or(W),Lr(W),Rr(W),Fr(W),Hr(W),Wr(W),Ur(W),Br(W)],Nb=Promise.all(Xc);et();Qt();Te();qt();H();var aa=require("playwright");Qt();var rd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(rd||{});wt();Ne();oa();de();Qt();Te();H();Te();H();var ld=require("otplib");var Xr=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Xr||{});St();H();wt();bi();fi();li();di();He();nt();at();we();et();tt();Mi();Ne();dt();ut();We();ht();mt();oa();de();Qt();Te();qt();Se();ot();rt();st();ta();vi();xi();_i();ki();Si();Ei();Ti();Ai();$i();Di();Oi();bt();vt();_t();kt();Et();Tt();At();$t();Mt();It();Pt();Nt();Dt();Ot();Lt();Rt();Ht();Wt();Ut();Gt();jt();Kt();zt();Vt();Xt();Yt();Jt();Gi();St();G();Ce();H();te();gt();Yi();R();fe();var Ve=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&&je.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={status:"success",...d};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:"action",data:{action_entity:l}})}});return a({type:"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){return this.agent.generate(this.page,i,n,a?.usePureVision)}async takeScreenshot(t){let i=await this.page.screenshot(),n=Xe.join(Jr.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await Yr.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
|
+
${p.body}`,h=await od(f,a,t.model);g.info(`Extracted content: ${h}`),h&&h!=="NOT_FOUND"&&u.push({content:h,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=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:p.content,result_variable:f,status:"success",message:`Successfully extracted content from email: ${p.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}`}}}H();te();var pe=require("zod");function Br(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 Ur=class{getMailgunConfig(){let e=G().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let 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 Wr(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(/^\$/,"")||Br(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)} },`,"});"]}},rd=pe.z.object({forward_email:pe.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:pe.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:pe.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:pe.z.string().optional().describe("Filter emails by sender address"),filter_to_email:pe.z.string().optional().describe("Filter emails by recipient address"),filter_subject:pe.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:pe.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:pe.z.number().optional().describe("Timeout in seconds for polling (default: 60)")});function Gr(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:p,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(p,h,f);let y=Br(o);return{success:!0,actionEntity:h,message:`Extracted ${o} and saved to $${y}`}}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}}}}})}xt();kt();Et();Tt();$t();Mt();It();Pt();Ct();Nt();Ot();Lt();Rt();Ft();Ht();Wt();Ut();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();var pn=null;async function ge(){if(pn)return pn;let e=(await Promise.resolve().then(()=>(ln(),sn))).default;return pn=new e,pn}async function jr(e){let t=await ge(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return $r(e,i),sr(e,n),jo(e,a),gr(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Kr(e){let t=await ge(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return or(e,i),ar(e,n),Uo(e,a),"Navigate to URLs, go back, or reload the page"}async function zr(e){let t=await ge(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Tr(e,i),cr(e,n),Ho(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function Vr(e){let t=await ge(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Jo(e,i),Zo(e,n),Vo(e,a),"Scroll the page or scroll to specific text/elements"}async function Xr(e){let t=await ge(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return ur(e,i),Mo(e,n),"Switch between browser tabs or close tabs"}async function Yr(e){let t=await ge(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Oo(e,i),Fo(e,n),"Upload files or wait for downloads to complete"}async function Jr(e){let t=await ge(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return tr(e,i),Eo(e,n),Ao(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function qr(e){let t=await ge(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Lo(e,i),zo(e,n),mr(e,a),Rr(e),"Wait for conditions, save variables, or complete tasks"}async function Zr(e){let t=(await ge()).getAction("generate_2fa_code");wr(e,t);let i=new Ur;return(await Promise.resolve().then(()=>(ln(),sn))).default.registerAction("extract_email_content",i),Gr(e,i),"Generate 2FA codes or extract email/activation codes"}async function Qr(e){let t=await ge(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return xr(e,i),kr(e,n),_o(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}_e();var sd=[jr(W),Kr(W),zr(W),Vr(W),Xr(W),Yr(W),Jr(W),qr(W),Qr(W),Zr(W)],dy=Promise.all(sd);st();ii();$e();ei();H();var ma=require("playwright");ii();var yd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(yd||{});vt();De();pa();ie();ii();$e();H();$e();H();var xd=require("otplib");var os=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(os||{});At();H();vt();$i();Ti();Ge();fi();wi();We();vi();_i();ct();dt();_e();st();lt();Hi();De();mt();pt();je();gt();ft();pa();ie();ii();$e();ei();xe();at();Be();ot();da();Ii();Pi();Ci();Ni();Oi();Di();Li();Ri();Fi();ji();Ki();xt();kt();Et();Tt();$t();Mt();It();Pt();Ct();Nt();Ot();Lt();Rt();Ft();Ht();Wt();Ut();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();Qi();At();j();Oe();H();te();bt();rn();R();be();var qe=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=Ze.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 p=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];p&&await this.page.goto(p,{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&&Xe.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={status:"success",...d};if(c&&(u.details=c),s){let p=this.agent.getNewActionEntities().get(s);if(p){let{element_index:f,...h}=p.action_data?.kwargs||{};u.newActionEntity={...p,action_data:p.action_data?{...p.action_data,kwargs:h}:p.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:"action",data:{action_entity:l}})}});return a({type:"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(".")?Ze.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){return this.agent.generate(this.page,i,n,a?.usePureVision)}async takeScreenshot(t){let i=await this.page.screenshot(),n=Ze.join(ss.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await rs.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(`(() => {
|
|
4392
4390
|
const orig = Element.prototype.attachShadow;
|
|
4393
4391
|
Element.prototype.attachShadow = function(init) {
|
|
4394
4392
|
const shadow = orig.call(this, init);
|
|
@@ -4410,4 +4408,4 @@ ${m.body}`,h=await zc(f,a,t.model);p.info(`Extracted content: ${h}`),h&&h!=="NOT
|
|
|
4410
4408
|
}
|
|
4411
4409
|
return shadow;
|
|
4412
4410
|
};
|
|
4413
|
-
})()`).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
|
|
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 tu(e){let{yamlFilePath:t,port:i,cdpPort:n,page:a,agent:o}=e,r=new qe(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=(0,va.default)();s.use(va.default.json({limit:"10mb"})),s.use((f,h,y)=>{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"),f.method==="OPTIONS")return h.sendStatus(204);y()});let{createTestFlowRouter:l}=await Promise.resolve().then(()=>(tl(),el)),{createIntRunnerRouter:d}=await Promise.resolve().then(()=>(al(),nl)),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 y=s.listen(i,"localhost",()=>f(y));y.on("error",h)});return{url:`http://localhost:${i}`,close:async()=>{await r.cleanupAll(),await new Promise((f,h)=>{u.close(y=>y?h(y):f())})}}}0&&(module.exports={PlaywrightSandboxService,startPlaywrightDebugServer});
|