shiplightai 0.1.81 → 0.1.83

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,8 @@
1
- var wl=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var dt=(e,t)=>{for(var i in t)wl(e,i,{get:t[i],enumerable:!0})};function V(){return $a.getConfig()}var yl,$a,wi,ne=x(()=>{"use strict";yl=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}},$a=new yl,wi=$a});var bl,xl,w,U=x(()=>{"use strict";ne();bl=class{getLevel(){return wi.get("logLevel")}isStderrOnly(){return wi.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){wi.set("logLevel",e)}},xl=new bl,w=xl});import{zodToJsonSchema as vl}from"zod-to-json-schema";function yi(e){let t=vl(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 ut(t),t}function ut(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))ut(i)}e.type==="array"&&e.items&&ut(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(ut);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&ut(i)}}var ht=x(()=>{"use strict"});var Tn,bi=x(()=>{"use strict";ht();Tn=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()}}});import{appendFileSync as Ma}from"fs";var _l,E,ae=x(()=>{"use strict";ne();_l=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=V().agentLogPath;if(e)try{Ma(e,`
1
+ var yl=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var ut=(e,t)=>{for(var i in t)yl(e,i,{get:t[i],enumerable:!0})};function V(){return Ma.getConfig()}var bl,Ma,wi,ne=x(()=>{"use strict";bl=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}},Ma=new bl,wi=Ma});var xl,vl,w,U=x(()=>{"use strict";ne();xl=class{getLevel(){return wi.get("logLevel")}isStderrOnly(){return wi.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){wi.set("logLevel",e)}},vl=new xl,w=vl});import{zodToJsonSchema as _l}from"zod-to-json-schema";function yi(e){let t=_l(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 ht(t),t}function ht(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))ht(i)}e.type==="array"&&e.items&&ht(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(ht);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&ht(i)}}var mt=x(()=>{"use strict"});var Tn,bi=x(()=>{"use strict";mt();Tn=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 Pa(e){return e!=null&&typeof e=="object"}function ze(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Ia(e){return typeof e=="string"?e:void 0}function kl(e){let t,i;return Array.isArray(e)?(t=ze(e[0]),i=ze(e[1])):Pa(e)&&(t=ze(e.x),i=ze(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Ca(e){if(!Pa(e))return{};let t=Array.isArray(e.path)?e.path.map(kl).filter(i=>i!==null):void 0;return{type:Ia(e.type),x:ze(e.x),y:ze(e.y),button:Ia(e.button),path:t}}var xi=x(()=>{"use strict"});import{appendFileSync as Na}from"fs";var Sl,E,ae=x(()=>{"use strict";ne();Sl=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=V().agentLogPath;if(e)try{Na(e,`
2
2
  === Agent Execution Log ===
3
3
  Started: ${new Date().toISOString()}
4
4
 
5
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=V().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();Ma(t,`[${i}] ${e}
5
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=V().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();Na(t,`[${i}] ${e}
6
6
  `)}catch{}}}section(e){this.log(`
7
7
  ${"=".repeat(60)}
8
8
  ${e}
@@ -11,9 +11,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
11
11
  ${e}`),this.log(`
12
12
  User Prompt:
13
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!!V().agentLogPath}},E=new _l});var $n,kl,Sl,El,Ia,xi,An,Pa,Mn,ye=x(()=>{"use strict";$n=Object.defineProperty,kl=Object.getOwnPropertyDescriptor,Sl=Object.getOwnPropertyNames,El=Object.prototype.hasOwnProperty,Ia=(e,t)=>()=>(e&&(t=e(e=0)),t),xi=(e,t)=>{for(var i in t)$n(e,i,{get:t[i],enumerable:!0})},An=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Sl(t))!El.call(e,a)&&a!==i&&$n(e,a,{get:()=>t[a],enumerable:!(n=kl(t,a))||n.enumerable});return e},Pa=(e,t,i)=>(An(e,t,"default"),i&&An(i,t,"default")),Mn=e=>An($n({},"__esModule",{value:!0}),e)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Pn}function Tl(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function R(e,t){let i=Pe(t);return i?new Function("page",`return ${i}`)(e):null}async function In(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 Al(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 $l(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ml(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 Pe(e){let t=$l(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ml(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var vi,mt,Pn,pe,I,W=x(()=>{"use strict";ye();vi={};xi(vi,{ACTION_TIMEOUT:()=>Pn,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>mt,getActionTimeoutMs:()=>D,getFrameContext:()=>In,getLocator:()=>R,getMinimalActionEntity:()=>Al,getPageLocatorExpression:()=>Pe,sanitizeForComment:()=>Tl});I=Ia(()=>{mt=5e3,Pn=1e4,pe=2e4})});async function Cn(e,t,i=[],n=[]){try{let a=await In(e,i);if(!a)return w.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let l=n[0];if(!l)return w.warn(`Missing shadow host xpath for element: ${t}`),null;let s=a.locator(`xpath=${Ca(l)}`),c=Il(t);if(o=await(c?s.locator(`css=${c}`):s.locator(`xpath=${Ca(t)}`)).elementHandle({timeout:mt}),!o)return w.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:mt}),!o)return w.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(l=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(l):null,o);return await o.dispose(),r?(w.debug(`Generated locator for ${t}: ${r}`),r):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return w.error(`Error in pickBestLocator: ${a}`),null}}async function Nn(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?(w.debug(`Generated locator: ${i}`),i):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return w.error(`Error in pickBestLocator: ${i}`),null}}function Ca(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Il(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(),l=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${l}`)}return n.join(" > ")}var Re=x(()=>{"use strict";U();W();I()});async function pt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(s=>s()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),{width:r=0,height:l=0}=await o.metadata();return E.log(`Screenshot actual: ${r}x${l}, viewport: ${t}x${i}`),(r!==t||l!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function be(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 _i(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let l=1,s=r.previousElementSibling;for(;s;)s.tagName===r.tagName&&l++,s=s.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${l}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Nn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ki(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 Ke=x(()=>{"use strict";ae();Re()});function Ol(e){return e.startsWith(Pl)}function Fe(e,t){let i=t?.trim();return i?Ll(i):Ol(e)?Cl:Nl}function Ll(e){return e.endsWith("/")?e.slice(0,-1):e}var Pl,Cl,Nl,ze=x(()=>{"use strict";Pl="shp_",Cl="https://nova-api.shiplight.ai",Nl="https://api.shiplight.ai"});function Na(e,t){return`${Fe(e,t)}/llm/v1`}function Oa(e,t){return`${Fe(e,t)}/llm/v1`}function La(e,t){return`${Fe(e,t)}/llm/v1beta`}function Da(e,t){return`${Fe(e,t)}/llm`}var Ce=x(()=>{"use strict";ze()});import{createGoogleGenerativeAI as Ra}from"@ai-sdk/google";import{createVertex as Dl}from"@ai-sdk/google-vertex";function Si(){let e=(V().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ha(e){let t=V().env||{};if(Si()){let a=t.GOOGLE_CLOUD_PROJECT;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return w.debug(`Using Vertex AI provider: model=${e}, location=${o}`),Dl({project:a,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return w.debug(`Using Google AI provider (API key): model=${e}`),Ra({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let a=La(n,t.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${a}`),Ra({apiKey:n,baseURL:a})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Wa(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Fa.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Fa.MEDIA_RESOLUTION_HIGH)}return Si()?{vertex:a}:{google:a}}var Fa,Ve=x(()=>{"use strict";Ce();U();ne();Fa={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Rl,Environment as Fl}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function Wl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await be(e,l,s);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await be(e,l,s);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await be(e,l,s);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let l=ge(i.x,n),s=ge(i.y,a),c=ge(i.destination_x,n),d=ge(i.destination_y,a),u=await be(e,l,s);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:c-l,delta_y:d-s}},r=u.element;break}default:E.log(`Unsupported Gemini function: ${t}`)}}catch(l){E.error(`Error mapping Gemini action "${t}"`,l)}return{action_data:o,locatorInfo:await _i(e,r)}}async function ja(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,l=r||Ul,s=V(),c;if(Si()){let b=s.env?.GOOGLE_CLOUD_PROJECT;if(!b)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let v=s.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:b,location:v}}else{let b=s.env?.GOOGLE_API_KEY;if(b)w.debug(`Using Google AI provider (API key): model=${l}`),c={apiKey:b};else{let v=s.env?.SHIPLIGHT_API_TOKEN;if(v){let S=Da(v,s.env?.SHIPLIGHT_API_URL);w.debug(`Using Shiplight LLM proxy (Google CUA): model=${l}, baseUrl=${S}`),c={apiKey:v,httpOptions:{baseUrl:S}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new Rl(c);E.log(`Sending request to Gemini CUA (model=${l})...`);let u=await d.models.generateContent({model:l,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Fl.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Hl}],temperature:.1}});E.log("Received response from Gemini CUA");let p=u.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let h=p.content?.parts?.find(b=>b.functionCall);if(!h)return{status:"error",reasoning:p.content?.parts?.filter(b=>b.text).map(b=>b.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:g}=h.functionCall;E.log(`Generated function call: ${f} with args ${JSON.stringify(g)}`),w.debug(`Generated function call: ${f} with args ${JSON.stringify(g)}`);let{action_data:y,locatorInfo:m}=await Wl(i,f,g,a,o);return y?{status:"success",actionEntity:ki(t,y,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Ua,Hl,Ul,Ei=x(()=>{"use strict";Ke();ae();Ve();Ce();U();ne();Ua={type:"object",properties:{x:{type:"integer",description:"X coordinate in the 0-1000 normalized space."},y:{type:"integer",description:"Y coordinate in the 0-1000 normalized space."}},required:["x","y"]},Hl=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:Ua},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Ua}];Ul="gemini-3-flash-preview"});function Ga(e){return e!=null&&typeof e=="object"}function Xe(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function Ba(e){return typeof e=="string"?e:void 0}function jl(e){let t,i;return Array.isArray(e)?(t=Xe(e[0]),i=Xe(e[1])):Ga(e)&&(t=Xe(e.x),i=Xe(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function Ka(e){if(!Ga(e))return{};let t=Array.isArray(e.path)?e.path.map(jl).filter(i=>i!==null):void 0;return{type:Ba(e.type),x:Xe(e.x),y:Xe(e.y),button:Ba(e.button),path:t}}var Ti=x(()=>{"use strict"});import Bl from"openai";async function Gl(e,t){let i=Ka(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await be(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await be(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],l=await be(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:l.relative_x,relative_y:l.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=l.element;break}}return{action_data:n,locatorInfo:await _i(e,a)}}async function Va(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||Kl,l=await pt(i,n,a),s=V(),c=s.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=s.env?.OPENAI_BASE_URL,u=new Bl({apiKey:c,...d&&{baseURL:d}}),p=u.responses.create.bind(u.responses);E.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${l}`}]}];async function f(v,S){let T={model:r,tools:[zl],input:v,temperature:.1};return S&&(T.previous_response_id=S),p(T)}let g=await f(h,void 0),y;for(let v=0;v<za;v++){E.log(`Received response from OpenAI CUA (turn ${v+1})`);let S=g.output.find(N=>N.type==="computer_call");if(!S)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let T=S.actions??[];if(T.length>1&&E.log(`[openai CUA] dropping ${T.length-1} batched action(s); only the first is executed`),y=T[0],!y)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(y.type!=="screenshot")break;l=await pt(i,n,a);let M=[{type:"computer_call_output",call_id:S.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${l}`,detail:"original"}}];g=await f(M,g.id)}if(!y)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(y.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${za} turns`};E.log(`Generated action: ${JSON.stringify(y)}`);let{action_data:m,locatorInfo:b}=await Gl(i,y);return m?{status:"success",actionEntity:ki(t,m,b),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(y)}`}}var Kl,zl,za,Ai=x(()=>{"use strict";Ti();Ke();ae();ne();Kl="gpt-5.4",zl={type:"computer"},za=4});import{createAnthropic as Xa}from"@ai-sdk/anthropic";import{createVertexAnthropic as Vl}from"@ai-sdk/google-vertex/anthropic";function Xl(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Yl(){return Xl(V().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Ya(e){let t=V();if(Yl()){let a=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return w.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${a}, location=${o}`),Vl({project:a,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return w.debug(`Using Anthropic provider: model=${e}`),Xa({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Oa(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${a}`),Xa({apiKey:n,baseURL:a})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function On(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var gt=x(()=>{"use strict";Ce();U();ne()});import{createOpenAI as Ja}from"@ai-sdk/openai";function qa(e){let t=V(),i=t.env?.OPENAI_API_KEY;if(i){let a=t.env?.OPENAI_BASE_URL;return w.debug(`Using OpenAI provider: model=${e}${a?`, baseURL=${a}`:""}`),Ja({apiKey:i,baseURL:a})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Na(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${a}`),Ja({apiKey:n,baseURL:a})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Za(e){return{}}var ft=x(()=>{"use strict";Ce();U();ne()});function eo(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(Jl.test(e))return"openai"}function $i(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(ql.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function xe(e){let{provider:t,modelId:i}=$i(e),n=t??eo(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=Qa[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(Qa).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}=$i(e),a=i??eo(n);return a==="anthropic"||a==="vertex"?On(n):a==="openai"||a==="azure"?Za(n):a==="bedrock"?n.startsWith("anthropic.")?On(n):{}:Wa(t,n)}var Jl,ql,Qa,_e=x(()=>{"use strict";gt();Ve();ft();Jl=/^(gpt-|o\d|chatgpt-)/;ql=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);Qa={anthropic:Ya,google:Ha,openai:qa}});function Ql(e){return e.startsWith("gemini-")?"google":"openai"}async function Ye(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;E.log(`Viewport: ${o}x${r}`);let l=await pt(n,o,r),s=t.agentServices.getComputerUseModel();if(!s)return{status:"error",error:"No computer use model configured"};let{modelId:c}=$i(s),d=Ql(c),u=Zl[d];E.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:n,screenshotB64:l,viewportWidth:o,viewportHeight:r,modelId:c};try{return await u(p)}catch(h){return E.error(`CUA provider "${d}" threw an error`,h),{status:"error",error:h.message??"CUA provider failed"}}}var Zl,Je=x(()=>{"use strict";Ei();Ai();Ke();ae();_e();Zl={google:ja,openai:Va}});function ec(e,t){let i=new Map;for(let s of t)s.hash&&s.url?i.set(s.hash,s.url):s.uuid&&s.url&&i.set(s.uuid,s.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let s=e.slice(o,r.index);s&&a.push({type:"text",text:s});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let l=e.slice(o);return l&&a.push({type:"text",text:l}),a.length===0&&a.push({type:"text",text:e}),a}function tc(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=ec(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
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!!V().agentLogPath}},E=new Sl});var $n,El,Tl,Al,Oa,vi,An,La,Mn,ve=x(()=>{"use strict";$n=Object.defineProperty,El=Object.getOwnPropertyDescriptor,Tl=Object.getOwnPropertyNames,Al=Object.prototype.hasOwnProperty,Oa=(e,t)=>()=>(e&&(t=e(e=0)),t),vi=(e,t)=>{for(var i in t)$n(e,i,{get:t[i],enumerable:!0})},An=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Tl(t))!Al.call(e,a)&&a!==i&&$n(e,a,{get:()=>t[a],enumerable:!(n=El(t,a))||n.enumerable});return e},La=(e,t,i)=>(An(e,t,"default"),i&&An(i,t,"default")),Mn=e=>An($n({},"__esModule",{value:!0}),e)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Pn}function $l(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function R(e,t){let i=Pe(t);return i?new Function("page",`return ${i}`)(e):null}async function In(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 Ml(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 Il(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 Pe(e){let t=Il(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 _i,pt,Pn,pe,I,W=x(()=>{"use strict";ve();_i={};vi(_i,{ACTION_TIMEOUT:()=>Pn,GOTO_TIMEOUT:()=>pe,LOCATOR_TIMEOUT:()=>pt,getActionTimeoutMs:()=>D,getFrameContext:()=>In,getLocator:()=>R,getMinimalActionEntity:()=>Ml,getPageLocatorExpression:()=>Pe,sanitizeForComment:()=>$l});I=Oa(()=>{pt=5e3,Pn=1e4,pe=2e4})});async function Cn(e,t,i=[],n=[]){try{let a=await In(e,i);if(!a)return w.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let l=n[0];if(!l)return w.warn(`Missing shadow host xpath for element: ${t}`),null;let s=a.locator(`xpath=${Da(l)}`),c=Cl(t);if(o=await(c?s.locator(`css=${c}`):s.locator(`xpath=${Da(t)}`)).elementHandle({timeout:pt}),!o)return w.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:pt}),!o)return w.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(l=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(l):null,o);return await o.dispose(),r?(w.debug(`Generated locator for ${t}: ${r}`),r):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return w.error(`Error in pickBestLocator: ${a}`),null}}async function Nn(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?(w.debug(`Generated locator: ${i}`),i):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return w.error(`Error in pickBestLocator: ${i}`),null}}function Da(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Cl(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(),l=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${l}`)}return n.join(" > ")}var Re=x(()=>{"use strict";U();W();I()});async function gt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(s=>s()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),{width:r=0,height:l=0}=await o.metadata();return E.log(`Screenshot actual: ${r}x${l}, viewport: ${t}x${i}`),(r!==t||l!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function _e(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),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 ki(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let l=1,s=r.previousElementSibling;for(;s;)s.tagName===r.tagName&&l++,s=s.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${l}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Nn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Si(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 Ve=x(()=>{"use strict";ae();Re()});import Nl from"openai";async function Ol(e,t){let i=Ca(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await _e(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await _e(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],l=await _e(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:l.relative_x,relative_y:l.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=l.element;break}}return{action_data:n,locatorInfo:await ki(e,a)}}async function Fa(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||Ll,l=await gt(i,n,a),s=V(),c=s.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=s.env?.OPENAI_BASE_URL,u=new Nl({apiKey:c,...d&&{baseURL:d}}),p=u.responses.create.bind(u.responses);E.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${l}`}]}];async function f(v,S){let T={model:r,tools:[Dl],input:v,temperature:.1};return S&&(T.previous_response_id=S),p(T)}let g=await f(h,void 0),y;for(let v=0;v<Ra;v++){E.log(`Received response from OpenAI CUA (turn ${v+1})`);let S=g.output.find(N=>N.type==="computer_call");if(!S)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let T=S.actions??[];if(T.length>1&&E.log(`[openai CUA] dropping ${T.length-1} batched action(s); only the first is executed`),y=T[0],!y)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(y.type!=="screenshot")break;l=await gt(i,n,a);let M=[{type:"computer_call_output",call_id:S.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${l}`,detail:"original"}}];g=await f(M,g.id)}if(!y)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(y.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${Ra} turns`};E.log(`Generated action: ${JSON.stringify(y)}`);let{action_data:m,locatorInfo:b}=await Ol(i,y);return m?{status:"success",actionEntity:Si(t,m,b),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(y)}`}}var Ll,Dl,Ra,Ei=x(()=>{"use strict";xi();Ve();ae();ne();Ll="gpt-5.4",Dl={type:"computer"},Ra=4});function Wl(e){return e.startsWith(Rl)}function Fe(e,t){let i=t?.trim();return i?Ul(i):Wl(e)?Fl:Hl}function Ul(e){return e.endsWith("/")?e.slice(0,-1):e}var Rl,Fl,Hl,Xe=x(()=>{"use strict";Rl="shp_",Fl="https://nova-api.shiplight.ai",Hl="https://api.shiplight.ai"});function Ha(e,t){return`${Fe(e,t)}/llm/v1`}function Wa(e,t){return`${Fe(e,t)}/llm/v1`}function Ua(e,t){return`${Fe(e,t)}/llm/v1beta`}function ja(e,t){return`${Fe(e,t)}/llm`}var Ce=x(()=>{"use strict";Xe()});import{createGoogleGenerativeAI as Ba}from"@ai-sdk/google";import{createVertex as jl}from"@ai-sdk/google-vertex";function Ti(){let e=(V().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Ka(e){let t=V().env||{};if(Ti()){let a=t.GOOGLE_CLOUD_PROJECT;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return w.debug(`Using Vertex AI provider: model=${e}, location=${o}`),jl({project:a,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return w.debug(`Using Google AI provider (API key): model=${e}`),Ba({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let a=Ua(n,t.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${a}`),Ba({apiKey:n,baseURL:a})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function za(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ga.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Ga.MEDIA_RESOLUTION_HIGH)}return Ti()?{vertex:a}:{google:a}}var Ga,Ye=x(()=>{"use strict";Ce();U();ne();Ga={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});import{GoogleGenAI as Bl,Environment as Gl}from"@google/genai";function ge(e,t){return Math.round(e/1e3*t)}async function zl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await _e(e,l,s);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await _e(e,l,s);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let l=ge(i.x,n),s=ge(i.y,a),c=await _e(e,l,s);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let l=ge(i.x,n),s=ge(i.y,a),c=ge(i.destination_x,n),d=ge(i.destination_y,a),u=await _e(e,l,s);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:c-l,delta_y:d-s}},r=u.element;break}default:E.log(`Unsupported Gemini function: ${t}`)}}catch(l){E.error(`Error mapping Gemini action "${t}"`,l)}return{action_data:o,locatorInfo:await ki(e,r)}}async function Xa(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,l=r||Vl,s=V(),c;if(Ti()){let b=s.env?.GOOGLE_CLOUD_PROJECT;if(!b)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let v=s.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:b,location:v}}else{let b=s.env?.GOOGLE_API_KEY;if(b)w.debug(`Using Google AI provider (API key): model=${l}`),c={apiKey:b};else{let v=s.env?.SHIPLIGHT_API_TOKEN;if(v){let S=ja(v,s.env?.SHIPLIGHT_API_URL);w.debug(`Using Shiplight LLM proxy (Google CUA): model=${l}, baseUrl=${S}`),c={apiKey:v,httpOptions:{baseUrl:S}}}else return{status:"error",error:"Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment."}}}let d=new Bl(c);E.log(`Sending request to Gemini CUA (model=${l})...`);let u=await d.models.generateContent({model:l,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Gl.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Kl}],temperature:.1}});E.log("Received response from Gemini CUA");let p=u.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let h=p.content?.parts?.find(b=>b.functionCall);if(!h)return{status:"error",reasoning:p.content?.parts?.filter(b=>b.text).map(b=>b.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:g}=h.functionCall;E.log(`Generated function call: ${f} with args ${JSON.stringify(g)}`),w.debug(`Generated function call: ${f} with args ${JSON.stringify(g)}`);let{action_data:y,locatorInfo:m}=await zl(i,f,g,a,o);return y?{status:"success",actionEntity:Si(t,y,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var Va,Kl,Vl,Ai=x(()=>{"use strict";Ve();ae();Ye();Ce();U();ne();Va={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:Va},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:Va}];Vl="gemini-3-flash-preview"});import{createAnthropic as Ya}from"@ai-sdk/anthropic";import{createVertexAnthropic as Xl}from"@ai-sdk/google-vertex/anthropic";function Yl(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Jl(){return Yl(V().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function Ja(e){let t=V();if(Jl()){let a=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return w.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${a}, location=${o}`),Xl({project:a,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return w.debug(`Using Anthropic provider: model=${e}`),Ya({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Wa(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${a}`),Ya({apiKey:n,baseURL:a})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function On(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var ft=x(()=>{"use strict";Ce();U();ne()});import{createOpenAI as qa}from"@ai-sdk/openai";function Za(e){let t=V(),i=t.env?.OPENAI_API_KEY;if(i){let a=t.env?.OPENAI_BASE_URL;return w.debug(`Using OpenAI provider: model=${e}${a?`, baseURL=${a}`:""}`),qa({apiKey:i,baseURL:a})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Ha(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${a}`),qa({apiKey:n,baseURL:a})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function Qa(e){return{}}var wt=x(()=>{"use strict";Ce();U();ne()});function to(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ql.test(e))return"openai"}function $i(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Zl.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function fe(e){let{provider:t,modelId:i}=$i(e),n=t??to(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=eo[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(eo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function we(e,t){let{provider:i,modelId:n}=$i(e),a=i??to(n);return a==="anthropic"||a==="vertex"?On(n):a==="openai"||a==="azure"?Qa(n):a==="bedrock"?n.startsWith("anthropic.")?On(n):{}:za(t,n)}var ql,Zl,eo,ye=x(()=>{"use strict";ft();Ye();wt();ql=/^(gpt-|o\d|chatgpt-)/;Zl=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);eo={anthropic:Ja,google:Ka,openai:Za}});function ec(e){return e.startsWith("gemini-")?"google":"openai"}async function Je(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;E.log(`Viewport: ${o}x${r}`);let l=await gt(n,o,r),s=t.agentServices.getComputerUseModel();if(!s)return{status:"error",error:"No computer use model configured"};let{modelId:c}=$i(s),d=ec(c),u=Ql[d];E.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:n,screenshotB64:l,viewportWidth:o,viewportHeight:r,modelId:c};try{return await u(p)}catch(h){return E.error(`CUA provider "${d}" threw an error`,h),{status:"error",error:h.message??"CUA provider failed"}}}var Ql,qe=x(()=>{"use strict";Ei();Ai();Ve();ae();ye();Ql={google:Xa,openai:Fa}});function tc(e,t){let i=new Map;for(let s of t)s.hash&&s.url?i.set(s.hash,s.url):s.uuid&&s.url&&i.set(s.uuid,s.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let s=e.slice(o,r.index);s&&a.push({type:"text",text:s});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let l=e.slice(o);return l&&a.push({type:"text",text:l}),a.length===0&&a.push({type:"text",text:e}),a}function ic(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=tc(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
15
15
 
16
- `}),t.push(...o)}return t}function Mi(e,t=to){if(t){let i=tc(e);if(i.length===0)return[];let n={type:"text",text:`
16
+ `}),t.push(...o)}return t}function Mi(e,t=io){if(t){let i=ic(e);if(i.length===0)return[];let n={type:"text",text:`
17
17
 
18
18
  <retrieved_knowledge>
19
19
 
@@ -33,7 +33,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
33
33
 
34
34
  </retrieved_knowledge>
35
35
 
36
- `}]:[]}}function io(e,t=to){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var to,wt=x(()=>{"use strict";to=!1});function ic(){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(d=>d.type==="year").value,n=t.find(d=>d.type==="month").value,a=t.find(d=>d.type==="day").value,o=t.find(d=>d.type==="hour").value,r=t.find(d=>d.type==="minute").value,l=t.find(d=>d.type==="second").value,s=t.find(d=>d.type==="timeZoneName").value,c=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${a} ${o}:${r}:${l}.${c} ${s}`}function no(e){return`# Your Role
36
+ `}]:[]}}function no(e,t=io){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var io,yt=x(()=>{"use strict";io=!1});function nc(){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(d=>d.type==="year").value,n=t.find(d=>d.type==="month").value,a=t.find(d=>d.type==="day").value,o=t.find(d=>d.type==="hour").value,r=t.find(d=>d.type==="minute").value,l=t.find(d=>d.type==="second").value,s=t.find(d=>d.type==="timeZoneName").value,c=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${a} ${o}:${r}:${l}.${c} ${s}`}function ao(e){return`# Your Role
37
37
  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.
38
38
 
39
39
  # Rules
@@ -93,11 +93,11 @@ Example of empty action when the target element is not on the page, or the instr
93
93
  "action": {}, // empty action object to indicate the instruction cannot be completed
94
94
  "completes_instruction": false
95
95
  }
96
- `}function nc(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
96
+ `}function ac(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
97
97
  Feedback: ${n}
98
98
  `}),`## Additional context
99
99
  You just executed following steps in order:
100
- ${t}`}function ao(e,t,i,n,a,o,r=!1,l=ic(),s=!1,c){let d=[],u=`
100
+ ${t}`}function oo(e,t,i,n,a,o,r=!1,l=nc(),s=!1,c){let d=[],u=`
101
101
  # Instruction
102
102
  "${t}"
103
103
 
@@ -130,25 +130,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
130
130
  - Do NOT use the actual value directly
131
131
  - The values shown are for context only to help you understand what data is available
132
132
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
133
- `}if(n&&n.length>0){let h=nc(n);p+=`
133
+ `}if(n&&n.length>0){let h=ac(n);p+=`
134
134
  `+h}return p+=`
135
135
  Based on the above information, please determine the right action to accomplish the task.
136
- `,d.push({type:"text",text:p}),d}var Ii=x(()=>{"use strict";wt()});async function ac(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 l="(title unavailable)";try{l=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let s=`Tab ${o}: ${r.url()}`;l&&(s+=` - ${l.slice(0,50)}`),n.push(s)}let a=n.length>0?n.join(`
136
+ `,d.push({type:"text",text:p}),d}var Ii=x(()=>{"use strict";yt()});async function oc(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 l="(title unavailable)";try{l=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let s=`Tab ${o}: ${r.url()}`;l&&(s+=` - ${l.slice(0,50)}`),n.push(s)}let a=n.length>0?n.join(`
137
137
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
138
- `:"",tabsText:a}}async function oc(e,t){let{currentTabText:i,tabsText:n}=await ac(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Pi(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),l=a.getIframeFallbackDomains(),{domState:s,screenshotBase64:c,slicedScreenshotsBase64:d}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:l,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=s.elementTree.clickableElementsToString(),p=await oc(i,u);return d&&(p.slicedScreenshotsBase64=d),{domTree:u,screenshotBase64:c,slicedScreenshotsBase64:d,domState:s,pageContext:p}}var yt=x(()=>{"use strict"});function qe(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 bt=x(()=>{"use strict"});import{z as he}from"zod";var Ln,j,ke=x(()=>{"use strict";Ln=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),l={...i,actionDescription:a};return await n.execute(r,l)}catch(a){if(a instanceof he.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 he.object({done:he.any()});let i=e.map(r=>{let l=r.schema;if(t&&l instanceof he.ZodObject){let s=l._def.shape();l=he.object({...s,description:he.string().describe("Semantic, human-readable description of the action")})}if(l instanceof he.ZodObject){let s=l._def.shape();Object.keys(s).length===0&&(l=he.object({_empty:he.boolean().optional()}))}return he.object({[r.name]:l})});if(i.length===1)return i[0];let[n,a,...o]=i;return he.union([n,a,...o])}},j=new Ln});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 rc(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 sc(e,t=!0){try{let i=rc(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 l=o;o.includes(`
138
+ `:"",tabsText:a}}async function rc(e,t){let{currentTabText:i,tabsText:n}=await oc(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Pi(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),l=a.getIframeFallbackDomains(),{domState:s,screenshotBase64:c,slicedScreenshotsBase64:d}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:l,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=s.elementTree.clickableElementsToString(),p=await rc(i,u);return d&&(p.slicedScreenshotsBase64=d),{domTree:u,screenshotBase64:c,slicedScreenshotsBase64:d,domState:s,pageContext:p}}var bt=x(()=>{"use strict"});import{z as he}from"zod";var Ln,j,ke=x(()=>{"use strict";Ln=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),l={...i,actionDescription:a};return await n.execute(r,l)}catch(a){if(a instanceof he.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 he.object({done:he.any()});let i=e.map(r=>{let l=r.schema;if(t&&l instanceof he.ZodObject){let s=l._def.shape();l=he.object({...s,description:he.string().describe("Semantic, human-readable description of the action")})}if(l instanceof he.ZodObject){let s=l._def.shape();Object.keys(s).length===0&&(l=he.object({_empty:he.boolean().optional()}))}return he.object({[r.name]:l})});if(i.length===1)return i[0];let[n,a,...o]=i;return he.union([n,a,...o])}},j=new Ln});function He(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 Ze=x(()=>{"use strict"});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 sc(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 lc(e,t=!0){try{let i=sc(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 l=o;o.includes(`
139
139
  `)&&(l=o.split(`
140
- `)[0]),l=l.replace(/\s+/g," ").trim();let s=l.replace(/"/g,'\\"');i+=`[${r}*="${s}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function lc(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 sc(e,!1)}function oo(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=lc(o);w.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function H(e,t){let i=null,n=oo(t);return t.xpath&&(i=await Cn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var X=x(()=>{"use strict";Re();U()});import{generateText as cc,NoObjectGeneratedError as dc,Output as uc}from"ai";import{z as Ci}from"zod";function hc(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 mc(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 pc(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=mc(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 ro(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,l=a.retrieveKnowledges(e).catch(F=>(E.log(`Failed to retrieve knowledges: ${F.message}`),[])),s=a.isSlicedScreenshotsEnabled(),c=a.isResizeSlicedScreenshotsEnabled(),d=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),h=p?hc(e):"all";p&&h!=="all"&&E.log(`Action intent filtering: detected '${h}' intent from statement`);let{screenshotBase64:f,domState:g,pageContext:y}=await Pi(t,{useSlicedScreenshots:s,resizeSlicedScreenshots:c,useAccessibilityTree:u,actionIntent:h});t.domState=g;let m=new Tn(j).getToolDefinitions().map(F=>{let J=F.function;return`${J.name}: ${J.description}
140
+ `)[0]),l=l.replace(/\s+/g," ").trim();let s=l.replace(/"/g,'\\"');i+=`[${r}*="${s}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function cc(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 lc(e,!1)}function ro(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=cc(o);w.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function H(e,t){let i=null,n=ro(t);return t.xpath&&(i=await Cn(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var X=x(()=>{"use strict";Re();U()});import{generateText as dc,NoObjectGeneratedError as uc,Output as hc}from"ai";import{z as Ci}from"zod";function mc(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 pc(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 gc(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=pc(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 so(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,l=a.retrieveKnowledges(e).catch(F=>(E.log(`Failed to retrieve knowledges: ${F.message}`),[])),s=a.isSlicedScreenshotsEnabled(),c=a.isResizeSlicedScreenshotsEnabled(),d=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),h=p?mc(e):"all";p&&h!=="all"&&E.log(`Action intent filtering: detected '${h}' intent from statement`);let{screenshotBase64:f,domState:g,pageContext:y}=await Pi(t,{useSlicedScreenshots:s,resizeSlicedScreenshots:c,useAccessibilityTree:u,actionIntent:h});t.domState=g;let m=new Tn(j).getToolDefinitions().map(F=>{let J=F.function;return`${J.name}: ${J.description}
141
141
  Parameters: ${JSON.stringify(J.parameters,null,2)}`}).join(`
142
142
 
143
- `),b=no(m),v=await l,S=ao(y,e,t.variables,t.executionHistory,v.length>0?v:void 0,f,s,void 0,d,t.sensitiveKeys),T=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(F=>{F.role==="user"?T.push({role:"user",content:F.content}):F.role==="assistant"&&T.push({role:"assistant",content:F.content})}),T.push({role:"user",content:S});let M=pc(T),N=j.buildActionUnionSchema(),O=Ci.object({thought:Ci.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ci.string().describe("Detailed description of the action to be performed").optional().default(""),action:N,completes_instruction:Ci.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),L=Array.isArray(S)?S.filter(F=>F.type==="image").length:0,Q=ve(o,L),Y;try{Y=await cc({model:xe(o),system:b,messages:T,temperature:r,output:uc.object({schema:O}),providerOptions:Q})}catch(F){if(dc.isInstance(F)){let J={},Ge=!1;if(F.text!=null)try{J=JSON.parse(F.text),Ge=!0}catch{}let Ie=J.thought||J.description||"",ka=Ie.length>300?`${Ie.slice(0,300)}\u2026`:Ie,fl=!J.action||typeof J.action=="object"&&Object.keys(J.action).length===0,Sa=[],Ea=qe(F.usage,o);Ea&&Sa.push(Ea);let Ta={systemPrompt:b,userPrompt:M,rawLlmResponse:F.text??"",tokenUsages:Sa};if(Ge&&fl)return{status:"error",reasoning:Ie||"No matching element/action found",goalAccomplished:J.completes_instruction??!1,error:ka?`No matching element/action: ${ka}`:"Agent did not generate any action (no matching element found)",debugInfo:Ta};let Aa=Ge?"Action generation failed: the model returned an action that did not match any known action schema.":"Action generation failed: the model returned a response that could not be parsed as a valid action.";return{status:"error",reasoning:Ie||Aa,goalAccomplished:J.completes_instruction??!1,error:Aa,debugInfo:Ta}}throw F}if(Y.output==null){let F=Y.finishReason,J=F==="length"?"Action generation failed: the model response was truncated before a complete action could be produced (token limit reached).":F==="content-filter"?"Action generation failed: the model response was blocked by a content filter.":`Action generation failed: the model stopped before producing an action (finishReason=${F??"unknown"}).`,Ge=[],Ie=qe(Y.usage,o);return Ie&&Ge.push(Ie),{status:"error",reasoning:"",goalAccomplished:!1,error:J,debugInfo:{systemPrompt:b,userPrompt:M,rawLlmResponse:Y.text??"",tokenUsages:Ge}}}let ie=Y.reasoningText;w.info(`Action Generation Reasoning: ${ie}`);let G=Y.output,K=JSON.stringify(G,null,2);w.info(`Generate Action Raw Output: ${K}`);let we=[],De=qe(Y.usage,o);De&&we.push(De);let Ae={systemPrompt:b,userPrompt:M,rawLlmResponse:K,tokenUsages:we},$e=G.thought||"",Me=G.description||"",z=G.action||{},q=G.completes_instruction||!1;if(!z||Object.keys(z).length===0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let Z=Object.keys(z)[0];if(Z==="done")return{status:"error",reasoning:$e||Me||"Task marked as done",goalAccomplished:q,error:"Agent indicated task is done without generating an action",debugInfo:Ae};if(Z==="perform_accurate_operation")return await Ye(e,t,i);if(!q){let F="Can't complete the instruction in one action";return{status:"error",reasoning:$e||Me||F,goalAccomplished:!1,error:F,debugInfo:Ae}}let ue=z[Z]||{},va={};if(typeof ue.element_index=="number"){let F=ue.element_index;if(F<0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let J=g.selectorMap.get(F);J&&(va=await H(n,J))}let _a=Me;return Z==="verify"&&(_a=e,ue.statement=e),{status:"success",actionEntity:{...va,action_description:_a||$e||`${Z}(${JSON.stringify(ue)})`,action_data:{action_name:Z,kwargs:ue}},reasoning:$e||Me,goalAccomplished:q,debugInfo:Ae}}var Ni=x(()=>{"use strict";bi();Je();Ii();yt();bt();ke();ae();_e();X();U()});import{generateText as gc,Output as fc}from"ai";import{z as Oi}from"zod";function wc(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?Ye(e,t,i):ro(e,t,i)}function bc(){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 xc(){return`# Role
143
+ `),b=ao(m),v=await l,S=oo(y,e,t.variables,t.executionHistory,v.length>0?v:void 0,f,s,void 0,d,t.sensitiveKeys),T=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(F=>{F.role==="user"?T.push({role:"user",content:F.content}):F.role==="assistant"&&T.push({role:"assistant",content:F.content})}),T.push({role:"user",content:S});let M=gc(T),N=j.buildActionUnionSchema(),O=Ci.object({thought:Ci.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ci.string().describe("Detailed description of the action to be performed").optional().default(""),action:N,completes_instruction:Ci.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),L=Array.isArray(S)?S.filter(F=>F.type==="image").length:0,Q=we(o,L),Y;try{Y=await dc({model:fe(o),system:b,messages:T,temperature:r,output:hc.object({schema:O}),providerOptions:Q})}catch(F){if(uc.isInstance(F)){let J={},Ke=!1;if(F.text!=null)try{J=JSON.parse(F.text),Ke=!0}catch{}let Ie=J.thought||J.description||"",Sa=Ie.length>300?`${Ie.slice(0,300)}\u2026`:Ie,wl=!J.action||typeof J.action=="object"&&Object.keys(J.action).length===0,Ea=[],Ta=He(F.usage,o);Ta&&Ea.push(Ta);let Aa={systemPrompt:b,userPrompt:M,rawLlmResponse:F.text??"",tokenUsages:Ea};if(Ke&&wl)return{status:"error",reasoning:Ie||"No matching element/action found",goalAccomplished:J.completes_instruction??!1,error:Sa?`No matching element/action: ${Sa}`:"Agent did not generate any action (no matching element found)",debugInfo:Aa};let $a=Ke?"Action generation failed: the model returned an action that did not match any known action schema.":"Action generation failed: the model returned a response that could not be parsed as a valid action.";return{status:"error",reasoning:Ie||$a,goalAccomplished:J.completes_instruction??!1,error:$a,debugInfo:Aa}}throw F}if(Y.output==null){let F=Y.finishReason,J=F==="length"?"Action generation failed: the model response was truncated before a complete action could be produced (token limit reached).":F==="content-filter"?"Action generation failed: the model response was blocked by a content filter.":`Action generation failed: the model stopped before producing an action (finishReason=${F??"unknown"}).`,Ke=[],Ie=He(Y.usage,o);return Ie&&Ke.push(Ie),{status:"error",reasoning:"",goalAccomplished:!1,error:J,debugInfo:{systemPrompt:b,userPrompt:M,rawLlmResponse:Y.text??"",tokenUsages:Ke}}}let ie=Y.reasoningText;w.info(`Action Generation Reasoning: ${ie}`);let G=Y.output,K=JSON.stringify(G,null,2);w.info(`Generate Action Raw Output: ${K}`);let xe=[],De=He(Y.usage,o);De&&xe.push(De);let Ae={systemPrompt:b,userPrompt:M,rawLlmResponse:K,tokenUsages:xe},$e=G.thought||"",Me=G.description||"",z=G.action||{},q=G.completes_instruction||!1;if(!z||Object.keys(z).length===0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let Z=Object.keys(z)[0];if(Z==="done")return{status:"error",reasoning:$e||Me||"Task marked as done",goalAccomplished:q,error:"Agent indicated task is done without generating an action",debugInfo:Ae};if(Z==="perform_accurate_operation")return await Je(e,t,i);if(!q){let F="Can't complete the instruction in one action";return{status:"error",reasoning:$e||Me||F,goalAccomplished:!1,error:F,debugInfo:Ae}}let ue=z[Z]||{},_a={};if(typeof ue.element_index=="number"){let F=ue.element_index;if(F<0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let J=g.selectorMap.get(F);J&&(_a=await H(n,J))}let ka=Me;return Z==="verify"&&(ka=e,ue.statement=e),{status:"success",actionEntity:{..._a,action_description:ka||$e||`${Z}(${JSON.stringify(ue)})`,action_data:{action_name:Z,kwargs:ue}},reasoning:$e||Me,goalAccomplished:q,debugInfo:Ae}}var Ni=x(()=>{"use strict";bi();qe();Ii();bt();ke();ae();Ze();ye();X();U()});import{generateText as fc,Output as wc}from"ai";import{z as Oi}from"zod";function yc(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?Je(e,t,i):so(e,t,i)}function xc(){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 vc(){return`# Role
144
144
  You are an experienced QA person for web applications.
145
145
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
146
- `}async function so(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),l=t.agentServices.isResizeSlicedScreenshotsEnabled(),s=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:u,slicedScreenshotsBase64:p,domState:h,pageContext:f}=await Pi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:l,useAccessibilityTree:c});t.domState=h;let g="";a&&a.length>0&&(g=`
146
+ `}async function lo(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),l=t.agentServices.isResizeSlicedScreenshotsEnabled(),s=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:u,slicedScreenshotsBase64:p,domState:h,pageContext:f}=await Pi(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:l,useAccessibilityTree:c});t.domState=h;let g="";a&&a.length>0&&(g=`
147
147
  # Previous actions in this session:
148
148
  ${a.map(([z,q],Z)=>`${Z+1}. Action: ${z}
149
149
  Result: ${q}`).join(`
150
150
  `)}
151
- `);let{dateString:y,timeString:m}=bc(),b=`
151
+ `);let{dateString:y,timeString:m}=xc(),b=`
152
152
  # User statement
153
153
  "${e}"
154
154
 
@@ -177,12 +177,12 @@ ${g}
177
177
 
178
178
  Today is ${y}. Current local time is ${m}.
179
179
  Based on the above information, please determine if the statement is true.
180
- `,T=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:b}],N=0;if(r&&p&&p.length>0)for(let z of p)M.push({type:"image",image:z}),N++;else M.push({type:"image",image:u}),N=1;if(T&&T.length>0){let z=Mi(T,s);M.push(...z)}M.push({type:"text",text:S});let O=T?io(T,s):0,L=N+O,Q=ve(o,L),Y=xc(),ie=await gc({model:xe(o),system:Y,messages:[{role:"user",content:M}],output:fc.object({schema:yc}),temperature:0,providerOptions:Q}),{conclusion:G,explanation:K}=ie.output,we=JSON.stringify(ie.output,null,2),De=[],Ae=qe(ie.usage,o);Ae&&De.push(Ae);let $e=[{role:"user",content:M.map(z=>{if(z.type==="text")return{type:"text",text:z.text};if(z.type==="image"){let q=z.image,Z=wc(q);if(Z)return{type:"image",file:Z};let ue=typeof q=="string"?q:"";return{type:"image",file:ue.startsWith("data:")?ue:`data:image/png;base64,${ue}`}}return{type:"text",text:"[unknown content type]"}})}],Me={systemPrompt:Y,userPrompt:$e,rawLlmResponse:we,screenshotWithSom:u,tokenUsages:De,retrievedKnowledges:T&&T.length>0?T:void 0,elementTree:d};return{success:G==="true",explanation:K,debugInfo:Me}}catch(r){return{success:!1,error:r.message}}}var yc,Li=x(()=>{"use strict";Ni();Je();yt();bt();wt();_e();yc=Oi.object({screenshotDescription:Oi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
180
+ `,T=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:b}],N=0;if(r&&p&&p.length>0)for(let z of p)M.push({type:"image",image:z}),N++;else M.push({type:"image",image:u}),N=1;if(T&&T.length>0){let z=Mi(T,s);M.push(...z)}M.push({type:"text",text:S});let O=T?no(T,s):0,L=N+O,Q=we(o,L),Y=vc(),ie=await fc({model:fe(o),system:Y,messages:[{role:"user",content:M}],output:wc.object({schema:bc}),temperature:0,providerOptions:Q}),{conclusion:G,explanation:K}=ie.output,xe=JSON.stringify(ie.output,null,2),De=[],Ae=He(ie.usage,o);Ae&&De.push(Ae);let $e=[{role:"user",content:M.map(z=>{if(z.type==="text")return{type:"text",text:z.text};if(z.type==="image"){let q=z.image,Z=yc(q);if(Z)return{type:"image",file:Z};let ue=typeof q=="string"?q:"";return{type:"image",file:ue.startsWith("data:")?ue:`data:image/png;base64,${ue}`}}return{type:"text",text:"[unknown content type]"}})}],Me={systemPrompt:Y,userPrompt:$e,rawLlmResponse:xe,screenshotWithSom:u,tokenUsages:De,retrievedKnowledges:T&&T.length>0?T:void 0,elementTree:d};return{success:G==="true",explanation:K,debugInfo:Me}}catch(r){return{success:!1,error:r.message}}}var bc,Li=x(()=>{"use strict";Ni();qe();bt();yt();Ze();ye();bc=Oi.object({screenshotDescription:Oi.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
181
181
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
182
182
  [45] A modal dialog titled "Confirmation",
183
- in the center of the screen`),explanation:Oi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Oi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function co(){let{default:e}=await import("sharp");return e}async function Rn(e,t){let i=await co(),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,l=0,s=Math.floor((a-r)/2),c=Math.max(0,a-r),d=(f,g)=>{let y=i(e).extract({left:f,top:0,width:g,height:r});return t?.resize&&(y=y.resize(lo,lo)),y.png().toBuffer()},[u,p,h]=await Promise.all([d(l,Math.min(r,a)),d(s,Math.min(r,a-s)),d(c,Math.min(r,a-c))]);return[u,p,h]}async function uo(e){let t=(await co())(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 l=0;l<a;l++){r[l]=[];for(let s=0;s<n;s++)r[l][s]=o[l*n+s]}return{pixels:r,width:n,height:a}}var lo,xt=x(()=>{"use strict";lo=768});var Fn,Hn,Wn,Un,vt=x(()=>{"use strict";Fn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),Hn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Wn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],Un=500});function ho(e,t){return e.length>t?e.slice(0,t)+"...":e}var _t=x(()=>{"use strict"});var mo,po,kt=x(()=>{"use strict";mo=["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"],po={"react-flow__(\\S+)":"$1"}});var go,St,Se,Ze=x(()=>{"use strict";_t();kt();go=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},St=class extends go{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}},Se=class Di extends go{constructor(t,i,n,a,o,r=!1,l=!1,s=!1,c=!1,d=!1,u=!1,p=null,h=null,f=null,g=null,y=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=l,this.markAsClickable=s,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=h,this.pageCoordinates=f,this.viewportInfo=g,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof Di&&a!==this&&a.highlightIndex!==null)){if(a instanceof St)i.push(a.text);else if(a instanceof Di)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
184
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??mo,n=t?.includeClassesWithRename??po,a=[],o=(r,l)=>{let s=l,c=" ".repeat(l);if(r instanceof Di){if(r.highlightIndex!==null){s+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let S of Object.keys(r.attributes))if(i.includes(S)){let T=r.attributes[S].trim();T!==""&&(m[S]=T)}let b=i.filter(S=>S in m);if(b.length>1){let S=new Set,T={};for(let M of b){let N=m[M];N.length>5&&(N in T?S.add(M):T[N]=M)}for(let M of S)delete m[M]}r.tagName===m.role&&delete m.role;let v=["aria-label","placeholder","title"];for(let S of v)m[S]&&m[S].trim().toLowerCase()===d.trim().toLowerCase()&&delete m[S];Object.keys(m).length>0&&(u=Object.entries(m).map(([S,T])=>`${S}=${ho(T,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,h=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let b of m)for(let[v,S]of Object.entries(n))try{let T=new RegExp(`^${v}$`);if(b.match(T)){let M=b.replace(T,S);M&&h.push(M);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",g=r.markAsClickable?" (CLICKABLE)":"",y=`${c}${p}${f}${g}<${r.tagName}`;if(h.length>0&&(y+=` ${h.join(" ")}`),u&&(y+=` ${u}`),d){let m=d.trim();u||(y+=" "),y+=`>${m}`}else u||(y+=" ");y+=" />",a.push(y)}else{let d=["data-testid","data-test-id"].filter(u=>r.attributes[u]);d.length>0&&(s+=1,a.push(`${c}<${r.tagName} ${d.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let d of r.children)o(d,s)}else if(r instanceof St){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${c}${r.text}`)}};return o(this,0),a.join(`
185
- `)}}});function kc(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var vc,_c,Ne,He=x(()=>{"use strict";xt();vt();Ze();U();vc=`(
183
+ in the center of the screen`),explanation:Oi.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Oi.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function uo(){let{default:e}=await import("sharp");return e}async function Rn(e,t){let i=await uo(),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,l=0,s=Math.floor((a-r)/2),c=Math.max(0,a-r),d=(f,g)=>{let y=i(e).extract({left:f,top:0,width:g,height:r});return t?.resize&&(y=y.resize(co,co)),y.png().toBuffer()},[u,p,h]=await Promise.all([d(l,Math.min(r,a)),d(s,Math.min(r,a-s)),d(c,Math.min(r,a-c))]);return[u,p,h]}async function ho(e){let t=(await uo())(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 l=0;l<a;l++){r[l]=[];for(let s=0;s<n;s++)r[l][s]=o[l*n+s]}return{pixels:r,width:n,height:a}}var co,xt=x(()=>{"use strict";co=768});var Fn,Hn,Wn,Un,vt=x(()=>{"use strict";Fn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),Hn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Wn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],Un=500});function mo(e,t){return e.length>t?e.slice(0,t)+"...":e}var _t=x(()=>{"use strict"});var po,go,kt=x(()=>{"use strict";po=["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"],go={"react-flow__(\\S+)":"$1"}});var fo,St,Se,Qe=x(()=>{"use strict";_t();kt();fo=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},St=class extends fo{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}},Se=class Di extends fo{constructor(t,i,n,a,o,r=!1,l=!1,s=!1,c=!1,d=!1,u=!1,p=null,h=null,f=null,g=null,y=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=l,this.markAsClickable=s,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=h,this.pageCoordinates=f,this.viewportInfo=g,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof Di&&a!==this&&a.highlightIndex!==null)){if(a instanceof St)i.push(a.text);else if(a instanceof Di)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
184
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??po,n=t?.includeClassesWithRename??go,a=[],o=(r,l)=>{let s=l,c=" ".repeat(l);if(r instanceof Di){if(r.highlightIndex!==null){s+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let S of Object.keys(r.attributes))if(i.includes(S)){let T=r.attributes[S].trim();T!==""&&(m[S]=T)}let b=i.filter(S=>S in m);if(b.length>1){let S=new Set,T={};for(let M of b){let N=m[M];N.length>5&&(N in T?S.add(M):T[N]=M)}for(let M of S)delete m[M]}r.tagName===m.role&&delete m.role;let v=["aria-label","placeholder","title"];for(let S of v)m[S]&&m[S].trim().toLowerCase()===d.trim().toLowerCase()&&delete m[S];Object.keys(m).length>0&&(u=Object.entries(m).map(([S,T])=>`${S}=${mo(T,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,h=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let b of m)for(let[v,S]of Object.entries(n))try{let T=new RegExp(`^${v}$`);if(b.match(T)){let M=b.replace(T,S);M&&h.push(M);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",g=r.markAsClickable?" (CLICKABLE)":"",y=`${c}${p}${f}${g}<${r.tagName}`;if(h.length>0&&(y+=` ${h.join(" ")}`),u&&(y+=` ${u}`),d){let m=d.trim();u||(y+=" "),y+=`>${m}`}else u||(y+=" ");y+=" />",a.push(y)}else{let d=["data-testid","data-test-id"].filter(u=>r.attributes[u]);d.length>0&&(s+=1,a.push(`${c}<${r.tagName} ${d.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let d of r.children)o(d,s)}else if(r instanceof St){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${c}${r.text}`)}};return o(this,0),a.join(`
185
+ `)}}});function Sc(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var _c,kc,Ne,We=x(()=>{"use strict";xt();vt();Qe();U();_c=`(
186
186
  args = {
187
187
  doHighlightElements: true,
188
188
  focusHighlightIndex: -1,
@@ -1950,7 +1950,7 @@ Based on the above information, please determine if the statement is true.
1950
1950
 
1951
1951
  return { rootId, map: DOM_HASH_MAP };
1952
1952
  }
1953
- `,_c=`((args = {
1953
+ `,kc=`((args = {
1954
1954
  doHighlightElements: true,
1955
1955
  focusHighlightIndex: -1,
1956
1956
  viewportExpansion: 0,
@@ -3998,7 +3998,7 @@ Based on the above information, please determine if the statement is true.
3998
3998
  // Return element data from boxes phase for use in labels phase
3999
3999
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4000
4000
  };
4001
- })`;Ne=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={}){w.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?_c:vc}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:l=!1,sameRectIoUThreshold:s,actionIntent:c="all"}=t,[d,u]=await this.buildDomTree(e,i,n,a,o,r,l,s,c);return{elementTree:d,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 Rn(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){w.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){w.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});w.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(m=>{if(m.ignored)return!1;let b=m.role?.value;return!(!b||!Fn.has(b)||m.properties?.find(v=>v.name==="disabled")?.value?.value||!m.backendDOMNodeId)});w.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(m=>m.role?.value==="button");w.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let b=[];m.ignored&&b.push("ignored"),m.backendDOMNodeId||b.push("no-backendDOMNodeId"),m.properties?.find(v=>v.name==="disabled")?.value?.value&&b.push("disabled"),w.debug(` - "${m.name?.value||"(no name)"}" ${b.length>0?`[SKIPPED: ${b.join(", ")}]`:"[INCLUDED]"}`)}let l=new Set(o.map(m=>m.backendDOMNodeId)),s=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),c=0;for(let m of s)l.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(",")}}]}),l.add(m.backendNodeId),c++);w.debug(`\u{1F3AF} Added ${c} elements from event listeners (total: ${o.length})`);let d=await this.resolveAXNodesToDOM(n,o),u=d.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=d.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){w.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let b=[];m.isVisible||b.push("not-visible"),m.isInViewport||b.push("not-in-viewport"),m.isTopElement||b.push("not-top-element"),m.boundingRect||b.push("no-bounding-rect"),w.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${b.join(", ")}]`)}}w.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:h,highlightIndex:f}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let g=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await Rn(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){w.warn("Failed to slice screenshot:",m)}return{domState:h,screenshotBase64:g,screenshot:i,slicedScreenshotsBase64:y}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],l=a[o];if(l)try{let{result:s}=await e.send("Runtime.callFunctionOn",{objectId:l,functionDeclaration:`function() {
4001
+ })`;Ne=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={}){w.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?kc:_c}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:l=!1,sameRectIoUThreshold:s,actionIntent:c="all"}=t,[d,u]=await this.buildDomTree(e,i,n,a,o,r,l,s,c);return{elementTree:d,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 Rn(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){w.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){w.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});w.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(m=>{if(m.ignored)return!1;let b=m.role?.value;return!(!b||!Fn.has(b)||m.properties?.find(v=>v.name==="disabled")?.value?.value||!m.backendDOMNodeId)});w.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(m=>m.role?.value==="button");w.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let b=[];m.ignored&&b.push("ignored"),m.backendDOMNodeId||b.push("no-backendDOMNodeId"),m.properties?.find(v=>v.name==="disabled")?.value?.value&&b.push("disabled"),w.debug(` - "${m.name?.value||"(no name)"}" ${b.length>0?`[SKIPPED: ${b.join(", ")}]`:"[INCLUDED]"}`)}let l=new Set(o.map(m=>m.backendDOMNodeId)),s=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),c=0;for(let m of s)l.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(",")}}]}),l.add(m.backendNodeId),c++);w.debug(`\u{1F3AF} Added ${c} elements from event listeners (total: ${o.length})`);let d=await this.resolveAXNodesToDOM(n,o),u=d.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=d.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){w.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let b=[];m.isVisible||b.push("not-visible"),m.isInViewport||b.push("not-in-viewport"),m.isTopElement||b.push("not-top-element"),m.boundingRect||b.push("no-bounding-rect"),w.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${b.join(", ")}]`)}}w.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:h,highlightIndex:f}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let g=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await Rn(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){w.warn("Failed to slice screenshot:",m)}return{domState:h,screenshotBase64:g,screenshot:i,slicedScreenshotsBase64:y}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],l=a[o];if(l)try{let{result:s}=await e.send("Runtime.callFunctionOn",{objectId:l,functionDeclaration:`function() {
4002
4002
  const el = this;
4003
4003
  const rect = el.getBoundingClientRect();
4004
4004
  const rects = el.getClientRects();
@@ -4082,34 +4082,34 @@ Based on the above information, please determine if the statement is true.
4082
4082
  } : null,
4083
4083
  clientRects: clientRectsArray
4084
4084
  };
4085
- }`,returnByValue:!0});s.value&&i.push({axNode:r,...s.value})}catch(s){w.debug(`Failed to resolve element: ${s}`)}}return i}async getElementsWithEventListeners(e,t=Un){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Wn.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});w.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:l}=await e.send("DOM.resolveNode",{nodeId:r});if(!l.objectId)continue;let{listeners:s}=await e.send("DOMDebugger.getEventListeners",{objectId:l.objectId}),c=s.filter(d=>Hn.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:l.objectId})}catch{}w.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){w.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Se("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||"",l=["button","link","menuitem","tab","switch"].includes(o),s=new Se(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",l,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 c=new St(r,!0,s);s.children.push(c)}i.children.push(s),t.set(n,s),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((l,s)=>{if(!l.boundingRect)return;let c=a[s%a.length],d=l.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${c}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${d.y}px`,u.style.left=`${d.x}px`,u.style.width=`${d.width}px`,u.style.height=`${d.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=s>=100?"8px":"12px",p.textContent=String(s);let h=Math.max(0,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${h}px`,p.style.left=`${f}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),w.debug("\u2705 Highlights removed from page")}catch(n){w.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(l=>l.map(s=>s.src)),i=l=>{try{let s=new URL(l);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>s.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let l of o){let s=l.url();try{let c=new URL(s).hostname;c&&c!==a&&!t.includes(s)&&!i(s)&&r.push(s)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,l,s="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(kc(e.url()))return[new Se("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:l,actionIntent:s,domTreeRoot:this.domTreeRoot};w.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,u=null;if(this.useDomTreeTs&&t)try{let y={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:N,argsObj:O})=>new Function("return "+N)()(O),{code:this.jsCode,argsObj:y});w.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let b=await e.screenshot({type:"png",fullPage:!1});w.debug("\u{1F4F8} Captured screenshot with bounding boxes");let v=performance.now(),S=await uo(b);u=S.pixels;let T=Math.round(performance.now()-v);w.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${S.width}x${S.height}) in ${T}ms`);let M={...c,phase:"labels",grayscaleImage:u,elementData:m.elementData};d=await e.evaluate(({code:N,argsObj:O})=>new Function("return "+N)()(O),{code:this.jsCode,argsObj:M}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,w.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){w.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),u=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:b,argsObj:v})=>new Function("return "+b)()(v),{code:this.jsCode,argsObj:m}),w.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:y,argsObj:m})=>new Function("return "+y)()(m),{code:this.jsCode,argsObj:c}),w.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw w.error("Error evaluating JavaScript:",y.message),y}if(!d||typeof d!="object")throw w.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw w.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(s!=="all"&&d.highlightCount===0){w.debug(`\u26A0\uFE0F No elements matched intent '${s}', falling back to 'all'`);let y={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:b})=>new Function("return "+m)()(b),{code:this.jsCode,argsObj:y})}let p=Object.entries(d.map).filter(([,y])=>y.tagName==="iframe");w.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[y,m]of p){let b=m;w.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${b.attributes?.src} inaccessibleFrame=${b.inaccessibleFrame}`)}let h=e.frames();w.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${h.length}`);for(let y of h)w.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let f=[];for(let[y,m]of Object.entries(d.map)){let b=m;this.shouldProcessWithPlaywrightFrameFallback(b,o)&&f.push({nodeId:y,src:b.attributes.src})}if(w.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){w.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let m of Object.values(d.map)){let b=m;b.highlightIndex!=null&&(y=Math.max(y,b.highlightIndex))}w.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let m=0;m<f.length;m++){let{nodeId:b,src:v}=f[m];w.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${v}`);let S=O=>{try{let L=new URL(O);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let Q=L.origin;return Q==="null"?null:Q}catch{return null}},T=S(v);w.debug(`\u{1F50D} [ext-iframe] iframe src origin=${T??"null"}`);let M=null,N=e.frames().find(O=>{let L=O.url();if(L===v)return M="exact",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let Q=S(L);return w.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${Q??"null"} vs srcOrigin=${T??"null"}`),T&&Q===T?(M="origin",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!N){w.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${v}`),w.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(O=>O.url()).join(", ")}`);continue}w.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${v} (frame url: ${N.url()})`);try{let O={...c,initialHighlightIndex:y+1,domTreeRoot:"body"};w.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${O.initialHighlightIndex}`);let L=await N.evaluate(({code:G,argsObj:K})=>new Function("return "+G)()(K),{code:this.jsCode,argsObj:O});if(w.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){w.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let Q=Object.values(L.map).filter(G=>G.highlightIndex!=null);w.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${Q.length}`);for(let G of Q){let K=G;w.debug(`\u{1F50D} [ext-iframe] - <${K.tagName}> highlightIndex=${K.highlightIndex} text="${K.children?.length?"...":""}"`)}for(let G of Object.values(L.map)){let K=G;K.highlightIndex!=null&&(y=Math.max(y,K.highlightIndex))}let Y=`ext_${m}_`;for(let[G,K]of Object.entries(L.map)){let we={...K};we.children&&(we.children=we.children.map(De=>`${Y}${De}`)),d.map[`${Y}${G}`]=we}let ie=d.map[b];ie?(ie.children=[...ie.children||[],`${Y}${L.rootId}`],w.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${b}`)):w.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${b} not found in map`),w.debug(`\u2705 Merged fallback iframe content from: ${v}`)}catch(O){w.warn(`Failed to process fallback iframe ${v}:`,O)}}}if(d&&d.perfMetrics){let y=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let v of Object.values(d.map))typeof v=="object"&&v!==null&&v.isInteractive&&m++;let b=e.url().length>50?e.url().slice(0,50)+"...":e.url();w.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${b} interactive=${m}/${y}`)}w.debug("\u{1F504} Starting TypeScript DOM tree construction...");let g=await this.constructDomTree(d);return w.debug("\u2705 TypeScript DOM tree construction completed"),g}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[l,s]of Object.entries(t)){let[c,d]=this.parseNode(s);c!==null&&(a.set(l,c),o.set(l,d),c instanceof Se&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[l,s]of o){let c=a.get(l);if(c instanceof Se)for(let d of s){let u=a.get(d);u&&(u.parent=c,c.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof Se))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 St(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 Se(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]}}});import{z as Sc}from"zod";var fo,gp,Ri=x(()=>{"use strict";fo=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},gp=Sc.object({})});var wo,Fi=x(()=>{"use strict";W();I();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.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Pe(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var yo,Hi=x(()=>{"use strict";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.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",`
4085
+ }`,returnByValue:!0});s.value&&i.push({axNode:r,...s.value})}catch(s){w.debug(`Failed to resolve element: ${s}`)}}return i}async getElementsWithEventListeners(e,t=Un){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Wn.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});w.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:l}=await e.send("DOM.resolveNode",{nodeId:r});if(!l.objectId)continue;let{listeners:s}=await e.send("DOMDebugger.getEventListeners",{objectId:l.objectId}),c=s.filter(d=>Hn.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:l.objectId})}catch{}w.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){w.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Se("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||"",l=["button","link","menuitem","tab","switch"].includes(o),s=new Se(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",l,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 c=new St(r,!0,s);s.children.push(c)}i.children.push(s),t.set(n,s),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((l,s)=>{if(!l.boundingRect)return;let c=a[s%a.length],d=l.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${c}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${d.y}px`,u.style.left=`${d.x}px`,u.style.width=`${d.width}px`,u.style.height=`${d.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=s>=100?"8px":"12px",p.textContent=String(s);let h=Math.max(0,d.y-16),f=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${h}px`,p.style.left=`${f}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),w.debug("\u2705 Highlights removed from page")}catch(n){w.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(l=>l.map(s=>s.src)),i=l=>{try{let s=new URL(l);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>s.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let l of o){let s=l.url();try{let c=new URL(s).hostname;c&&c!==a&&!t.includes(s)&&!i(s)&&r.push(s)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,l,s="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Sc(e.url()))return[new Se("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:l,actionIntent:s,domTreeRoot:this.domTreeRoot};w.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,u=null;if(this.useDomTreeTs&&t)try{let y={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:N,argsObj:O})=>new Function("return "+N)()(O),{code:this.jsCode,argsObj:y});w.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let b=await e.screenshot({type:"png",fullPage:!1});w.debug("\u{1F4F8} Captured screenshot with bounding boxes");let v=performance.now(),S=await ho(b);u=S.pixels;let T=Math.round(performance.now()-v);w.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${S.width}x${S.height}) in ${T}ms`);let M={...c,phase:"labels",grayscaleImage:u,elementData:m.elementData};d=await e.evaluate(({code:N,argsObj:O})=>new Function("return "+N)()(O),{code:this.jsCode,argsObj:M}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,w.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){w.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),u=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:b,argsObj:v})=>new Function("return "+b)()(v),{code:this.jsCode,argsObj:m}),w.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:y,argsObj:m})=>new Function("return "+y)()(m),{code:this.jsCode,argsObj:c}),w.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw w.error("Error evaluating JavaScript:",y.message),y}if(!d||typeof d!="object")throw w.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw w.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(s!=="all"&&d.highlightCount===0){w.debug(`\u26A0\uFE0F No elements matched intent '${s}', falling back to 'all'`);let y={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:b})=>new Function("return "+m)()(b),{code:this.jsCode,argsObj:y})}let p=Object.entries(d.map).filter(([,y])=>y.tagName==="iframe");w.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[y,m]of p){let b=m;w.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${b.attributes?.src} inaccessibleFrame=${b.inaccessibleFrame}`)}let h=e.frames();w.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${h.length}`);for(let y of h)w.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let f=[];for(let[y,m]of Object.entries(d.map)){let b=m;this.shouldProcessWithPlaywrightFrameFallback(b,o)&&f.push({nodeId:y,src:b.attributes.src})}if(w.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){w.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let m of Object.values(d.map)){let b=m;b.highlightIndex!=null&&(y=Math.max(y,b.highlightIndex))}w.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let m=0;m<f.length;m++){let{nodeId:b,src:v}=f[m];w.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${v}`);let S=O=>{try{let L=new URL(O);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let Q=L.origin;return Q==="null"?null:Q}catch{return null}},T=S(v);w.debug(`\u{1F50D} [ext-iframe] iframe src origin=${T??"null"}`);let M=null,N=e.frames().find(O=>{let L=O.url();if(L===v)return M="exact",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let Q=S(L);return w.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${Q??"null"} vs srcOrigin=${T??"null"}`),T&&Q===T?(M="origin",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!N){w.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${v}`),w.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(O=>O.url()).join(", ")}`);continue}w.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${v} (frame url: ${N.url()})`);try{let O={...c,initialHighlightIndex:y+1,domTreeRoot:"body"};w.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${O.initialHighlightIndex}`);let L=await N.evaluate(({code:G,argsObj:K})=>new Function("return "+G)()(K),{code:this.jsCode,argsObj:O});if(w.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){w.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let Q=Object.values(L.map).filter(G=>G.highlightIndex!=null);w.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${Q.length}`);for(let G of Q){let K=G;w.debug(`\u{1F50D} [ext-iframe] - <${K.tagName}> highlightIndex=${K.highlightIndex} text="${K.children?.length?"...":""}"`)}for(let G of Object.values(L.map)){let K=G;K.highlightIndex!=null&&(y=Math.max(y,K.highlightIndex))}let Y=`ext_${m}_`;for(let[G,K]of Object.entries(L.map)){let xe={...K};xe.children&&(xe.children=xe.children.map(De=>`${Y}${De}`)),d.map[`${Y}${G}`]=xe}let ie=d.map[b];ie?(ie.children=[...ie.children||[],`${Y}${L.rootId}`],w.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${b}`)):w.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${b} not found in map`),w.debug(`\u2705 Merged fallback iframe content from: ${v}`)}catch(O){w.warn(`Failed to process fallback iframe ${v}:`,O)}}}if(d&&d.perfMetrics){let y=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let v of Object.values(d.map))typeof v=="object"&&v!==null&&v.isInteractive&&m++;let b=e.url().length>50?e.url().slice(0,50)+"...":e.url();w.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${b} interactive=${m}/${y}`)}w.debug("\u{1F504} Starting TypeScript DOM tree construction...");let g=await this.constructDomTree(d);return w.debug("\u2705 TypeScript DOM tree construction completed"),g}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[l,s]of Object.entries(t)){let[c,d]=this.parseNode(s);c!==null&&(a.set(l,c),o.set(l,d),c instanceof Se&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[l,s]of o){let c=a.get(l);if(c instanceof Se)for(let d of s){let u=a.get(d);u&&(u.parent=c,c.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof Se))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 St(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 Se(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]}}});import{z as Ec}from"zod";var wo,fp,Ri=x(()=>{"use strict";wo=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},fp=Ec.object({})});var yo,Fi=x(()=>{"use strict";W();I();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.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Pe(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=D();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var bo,Hi=x(()=>{"use strict";bo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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",`
4086
4086
  return (async () => {
4087
4087
  ${a}
4088
4088
  })();
4089
4089
  `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4090
- `):["// Skipping js_action: missing code"]}}});import*as Ec from"playwright/test";import{default as Tc}from"playwright/test";var Qe,Et=x(()=>{"use strict";ye();Qe={};xi(Qe,{default:()=>Tc});Pa(Qe,Ec)});import{z as bo}from"zod";var xo,$p,Wi=x(()=>{"use strict";Et();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.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","expect","agent",`
4090
+ `):["// Skipping js_action: missing code"]}}});import*as Tc from"playwright/test";import{default as Ac}from"playwright/test";var et,Et=x(()=>{"use strict";ve();et={};vi(et,{default:()=>Ac});La(et,Tc)});import{z as xo}from"zod";var vo,Mp,Wi=x(()=>{"use strict";Et();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.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","expect","agent",`
4091
4091
  return (async () => {
4092
4092
  ${a}
4093
4093
  })();
4094
- `)(e,Qe.expect,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4095
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},$p=bo.object({code:bo.string().describe("JavaScript code to execute in the browser context")})});var vo,Ui=x(()=>{"use strict";W();I();vo=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l,{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 _o,ji=x(()=>{"use strict";W();I();_o=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],l=[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 s=R(e,t);if(!s)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await s.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await s).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,u=c.y+o.relative_y+c.height/2,p=d+o.delta_x,h=u+o.delta_y;await e.mouse.move(d,u),await e.mouse.down(),n>0?await e.mouse.move(p,h,{steps:n}):await e.mouse.move(p,h),await e.mouse.up()}else if(r.every(s=>typeof s=="number")&&l.every(s=>typeof s=="number")){let[s,c]=r,[d,u]=l;await e.mouse.move(s,c),await e.mouse.down(),n>0?await e.mouse.move(d,u,{steps:n}):await e.mouse.move(d,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 ko,Bi=x(()=>{"use strict";ko=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",`
4094
+ `)(e,et.expect,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4095
+ `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Mp=xo.object({code:xo.string().describe("JavaScript code to execute in the browser context")})});var _o,Ui=x(()=>{"use strict";W();I();_o=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l,{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 ko,ji=x(()=>{"use strict";W();I();ko=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,l,{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 So,Bi=x(()=>{"use strict";W();I();So=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],l=[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 s=R(e,t);if(!s)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await s.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await s).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,u=c.y+o.relative_y+c.height/2,p=d+o.delta_x,h=u+o.delta_y;await e.mouse.move(d,u),await e.mouse.down(),n>0?await e.mouse.move(p,h,{steps:n}):await e.mouse.move(p,h),await e.mouse.up()}else if(r.every(s=>typeof s=="number")&&l.every(s=>typeof s=="number")){let[s,c]=r,[d,u]=l;await e.mouse.move(s,c),await e.mouse.down(),n>0?await e.mouse.move(d,u,{steps:n}):await e.mouse.move(d,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 Eo,Gi=x(()=>{"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=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",`
4096
4096
  return (async () => {
4097
4097
  ${a}
4098
4098
  })();
4099
- `)(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((l,s)=>s<r.length?String(r[s]):"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 Gi=x(()=>{"use strict";Ze()});var So,Tt=x(()=>{"use strict";So=(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))(So||{})});var et={};dt(et,{evaluateStatement:()=>Vi,executeAction:()=>At,executeStep:()=>zi,generateActionStep:()=>Ki,runTask:()=>Xi});var tt=x(()=>{"use strict";$t();Li();Ni();bi();Je();Ei();Ai();Ti();Ke();Ii();yt();bt();ke();ht();wt();Gi();He();xt();vt();Ze();_t();kt();ae();_e();gt();Ve();ft();Ce();ze();X();Re();U();ne();Tt();W();ye()});import{z as Eo}from"zod";var To,Eg,Yi=x(()=>{"use strict";To=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(tt(),et)),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"]}},Eg=Eo.object({statement:Eo.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});var Ao,Ji=x(()=>{"use strict";W();I();Ao=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l),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 $o,qi=x(()=>{"use strict";W();I();$o=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,l,{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},`),"});"]}}});import{z as Mo}from"zod";var Io,Lg,Zi=x(()=>{"use strict";Io=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(tt(),et)),l=await r(a,e,i,{usePureVision:o});if(l.status!=="success")throw new Error(l.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});`]}},Lg=Mo.object({statement:Mo.string().describe('The action to perform (e.g., "click the submit button")')})});import{z as Po}from"zod";function No(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Ac,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Waited ${a} seconds`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:s.message}}}}})}var Co,Ac,Mt=x(()=>{"use strict";Co=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},Ac=Po.object({seconds:Po.number().positive().describe("Number of seconds to wait")})});import{z as Oo}from"zod";function Do(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:$c,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let l={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,l,r),{success:!0,actionEntity:l,message:"Download completed"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:l.message}}}}})}var Lo,$c,It=x(()=>{"use strict";Lo=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} } },`,"});"]}},$c=Oo.object({timeout_seconds:Oo.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as jn}from"zod";function Fo(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:Mc,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Condition met: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:s.message}}}}})}var Ro,Mc,Pt=x(()=>{"use strict";Ro=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,l=Date.now(),{evaluateStatement:s}=await Promise.resolve().then(()=>(tt(),et));for(;Date.now()-l<o;){if((await s(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"]}},Mc=jn.object({condition:jn.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:jn.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Bn}from"zod";async function Ic(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Pc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function Ho(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:Cc,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=s||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await Ic("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:Pc(s||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Ct,Cc,Nt=x(()=>{"use strict";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)})');`]}};Cc=Bn.object({down:Bn.boolean().describe("True to scroll down, False to scroll up"),num_pages:Bn.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Ot}from"zod";async function Nc(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Wo(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:Oc,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:l,agentServices:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Wo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await Nc("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,l,{delta_x:o,delta_y:r});return await t.execute(l,d,s),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Wo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Uo,Oc,Lt=x(()=>{"use strict";X();W();I();Uo=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=R(e,t),l=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:l}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Pe(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Oc=Ot.object({element_index:Ot.number().int().describe("Index of the scrollable element"),delta_x:Ot.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Ot.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Ot.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Bo}from"zod";function Ko(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Lc,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Scrolled to text "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:s.message}}}}})}var Go,Lc,Dt=x(()=>{"use strict";Go=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.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();`]}},Lc=Bo.object({text:Bo.string().describe("Text to scroll to on the page")})});import{z as Qi}from"zod";async function Dc(e,t,i,n){return{...await H(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function zo(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 Xo(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Rc,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:zo(s||`Select option in dropdown ${a}`,{index:a,option:o})};let d=await Dc(c,r,o,s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:zo(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Vo,Rc,Rt=x(()=>{"use strict";X();W();I();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.text||n.kwargs.option,o=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};Rc=Qi.object({element_index:Qi.number().int().describe("Index of the dropdown/select element"),option:Qi.string().describe("Option value, label, or index to select"),timeout_ms:Qi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as en}from"zod";async function Fc(e,t,i,n){return{...await H(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Gn(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 Jo(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">).
4099
+ `)(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((l,s)=>s<r.length?String(r[s]):"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 Ki=x(()=>{"use strict";Qe()});var To,Tt=x(()=>{"use strict";To=(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))(To||{})});var tt={};ut(tt,{evaluateStatement:()=>Xi,executeAction:()=>At,executeStep:()=>Vi,generateActionStep:()=>zi,runTask:()=>Yi});var it=x(()=>{"use strict";$t();Li();Ni();bi();qe();Ei();xi();Ai();Ve();Ii();bt();yt();ke();mt();Ki();We();xt();vt();Qe();_t();kt();ae();Ze();ye();ft();Ye();wt();Ce();Xe();X();Re();U();ne();Tt();W();ve()});import{z as Ao}from"zod";var $o,Mg,Ji=x(()=>{"use strict";$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.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(it(),tt)),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"]}},Mg=Ao.object({statement:Ao.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});var Mo,qi=x(()=>{"use strict";W();I();Mo=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=R(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l),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},`),"});"]}}});import{z as Io}from"zod";var Po,Dg,Zi=x(()=>{"use strict";Po=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(()=>(it(),tt)),l=await r(a,e,i,{usePureVision:o});if(l.status!=="success")throw new Error(l.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});`]}},Dg=Io.object({statement:Io.string().describe('The action to perform (e.g., "click the submit button")')})});import $c from"fs";async function Co(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){w.info("Using mockShowOpenFilePicker approach");let l=i.map(s=>({path:s,buffer:new Uint8Array($c.readFileSync(s))}));await e.evaluate(s=>{window.__pw_showOpenFilePicker_mock_files=s},l),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)w.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{w.info("Using file chooser approach");let l=e.waitForEvent("filechooser",{timeout:o});l.catch(()=>{}),await t.click({timeout:o}),await(await l).setFiles(i),await e.waitForTimeout(3e3)}w.info(`Successfully uploaded ${i.length} file(s)`)}var Mt=x(()=>{"use strict";U()});import{z as ee}from"zod";async function Mc(e,t,i={},n){return{...await H(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function No(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 Lo(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:Ic,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:No(s||`Upload file to element ${a}`,{index:a,paths:o})};let d=await Mc(c,r,{paths:o},s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:No(s||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Oo,Ic,zg,It=x(()=>{"use strict";Mt();X();W();I();Oo=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(c=>i.getTestDataFilePath(c)),r=R(e,t);if(!r)throw new Error("Missing locator for upload_file action");let l=n.kwargs.use_file_input||!1,s=i.getActionSettings().mock_show_open_file_picker??!1;await Co(e,r,o,{useFileInput:l,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:s})}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},`),"});"]}};Ic=ee.object({element_index:ee.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:ee.union([ee.string(),ee.array(ee.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:ee.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});zg=ee.object({element_index:ee.number().int().describe("Index of the file input element"),paths:ee.union([ee.string(),ee.array(ee.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:ee.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Do}from"zod";function Fo(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Pc,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Waited ${a} seconds`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:s.message}}}}})}var Ro,Pc,Pt=x(()=>{"use strict";Ro=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});`]}},Pc=Do.object({seconds:Do.number().positive().describe("Number of seconds to wait")})});import{z as Ho}from"zod";function Uo(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Cc,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let l={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,l,r),{success:!0,actionEntity:l,message:"Download completed"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:l.message}}}}})}var Wo,Cc,Ct=x(()=>{"use strict";Wo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Cc=Ho.object({timeout_seconds:Ho.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});import{z as jn}from"zod";function Bo(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:Nc,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Condition met: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:s.message}}}}})}var jo,Nc,Nt=x(()=>{"use strict";jo=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,l=Date.now(),{evaluateStatement:s}=await Promise.resolve().then(()=>(it(),tt));for(;Date.now()-l<o;){if((await s(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"]}},Nc=jn.object({condition:jn.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:jn.number().positive().optional().describe("Timeout in seconds (default: 60)")})});import{z as Bn}from"zod";function Ko(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Oc,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Saved variable "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:s.message}}}}})}var Go,Oc,Ot=x(()=>{"use strict";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.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Oc=Bn.object({name:Bn.string().describe("Variable name to save"),value:Bn.string().describe("Value to save in the variable")})});import{z as Gn}from"zod";async function Lc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Dc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function zo(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:Rc,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=s||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await Lc("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:Dc(s||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var Lt,Rc,Dt=x(()=>{"use strict";Lt=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)})');`]}};Rc=Gn.object({down:Gn.boolean().describe("True to scroll down, False to scroll up"),num_pages:Gn.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});import{z as Rt}from"zod";async function Fc(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Vo(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Yo(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Hc,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:l,agentServices:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Vo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await Fc("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,l,{delta_x:o,delta_y:r});return await t.execute(l,d,s),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Vo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var Xo,Hc,Ft=x(()=>{"use strict";X();W();I();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.delta_x||0,o=n.kwargs.delta_y||0,r=R(e,t),l=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:l}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Pe(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${D()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Hc=Rt.object({element_index:Rt.number().int().describe("Index of the scrollable element"),delta_x:Rt.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Rt.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Rt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Jo}from"zod";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:l}=n;try{let s={action_description:l||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Scrolled to text "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:s.message}}}}})}var qo,Wc,Ht=x(()=>{"use strict";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=Jo.object({text:Jo.string().describe("Text to scroll to on the page")})});import{z as Qi}from"zod";async function Uc(e,t,i,n){return{...await H(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Qo(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 tr(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:jc,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Qo(s||`Select option in dropdown ${a}`,{index:a,option:o})};let d=await Uc(c,r,o,s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Qo(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var er,jc,Wt=x(()=>{"use strict";X();W();I();er=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=R(e,t),r=D(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};jc=Qi.object({element_index:Qi.number().int().describe("Index of the dropdown/select element"),option:Qi.string().describe("Option value, label, or index to select"),timeout_ms:Qi.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as en}from"zod";async function Bc(e,t,i,n){return{...await H(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Kn(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 nr(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4100
4100
 
4101
4101
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4102
4102
  Do NOT use it for custom/non-native date pickers
4103
4103
 
4104
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Hc,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:Gn(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=s.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:Gn(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await Fc(`Set date to ${o} on element ${a}`,s,r,o);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Gn(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Yo,Hc,Ft=x(()=>{"use strict";X();W();I();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.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=R(e,t);if(r){let l=await r.getAttribute("type").catch(()=>null);if(l&&l!=="date")throw new Error(`Element is not a native date picker (type="${l}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Hc=en.object({element_index:en.number().int().describe("Index of the native date picker input element"),date:en.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:en.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as qo}from"zod";function Qo(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Wc,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Switched to tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:s.message}}}}})}var Zo,Wc,Ht=x(()=>{"use strict";Zo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let l=await i.switchTab(r);await l.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await l.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} } },`,"});"]}},Wc=qo.object({tab_index:qo.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import Uc from"fs";async function er(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){w.info("Using mockShowOpenFilePicker approach");let l=i.map(s=>({path:s,buffer:new Uint8Array(Uc.readFileSync(s))}));await e.evaluate(s=>{window.__pw_showOpenFilePicker_mock_files=s},l),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)w.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{w.info("Using file chooser approach");let l=e.waitForEvent("filechooser",{timeout:o});l.catch(()=>{}),await t.click({timeout:o}),await(await l).setFiles(i),await e.waitForTimeout(3e3)}w.info(`Successfully uploaded ${i.length} file(s)`)}var Wt=x(()=>{"use strict";U()});import{z as ee}from"zod";async function jc(e,t,i={},n){return{...await H(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function tr(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 nr(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:Bc,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:tr(s||`Upload file to element ${a}`,{index:a,paths:o})};let d=await jc(c,r,{paths:o},s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:tr(s||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var ir,Bc,Ef,Ut=x(()=>{"use strict";Wt();X();W();I();ir=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(c=>i.getTestDataFilePath(c)),r=R(e,t);if(!r)throw new Error("Missing locator for upload_file action");let l=n.kwargs.use_file_input||!1,s=i.getActionSettings().mock_show_open_file_picker??!1;await er(e,r,o,{useFileInput:l,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:s})}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},`),"});"]}};Bc=ee.object({element_index:ee.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:ee.union([ee.string(),ee.array(ee.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:ee.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Ef=ee.object({element_index:ee.number().int().describe("Index of the file input element"),paths:ee.union([ee.string(),ee.array(ee.string())]).describe('Path to a file, relative to the test project root (e.g. "fixtures/data.csv"), or an array of such paths.'),timeout_ms:ee.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ar}from"zod";function or(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:Gc,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Pressed keys "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:s.message}}}}})}var Kn,Gc,jt=x(()=>{"use strict";Kn=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)});`]}},Gc=ar.object({keys:ar.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as Kc}from"zod";function sr(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:zc,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 rr,zc,Bt=x(()=>{"use strict";W();I();rr=class{async execute(e,t){await e.reload({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},zc=Kc.object({})});import{z as zn}from"zod";async function Vc(e,t,i,n,a={}){return{...await H(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:"right_click",description:"Right-click an interactive element.",schema:Xc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:lr(`Right-click element ${a}`,"right_click",{index:a})};let c=l||`Right-click element ${a}`,d=await Vc("right_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:lr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Vn,Xc,Gt=x(()=>{"use strict";X();W();I();Vn=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Xc=zn.object({element_index:zn.number().int().describe("Index of the element to right-click"),timeout_ms:zn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Xn}from"zod";function ur(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Yc,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Saved variable "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:s.message}}}}})}var dr,Yc,Kt=x(()=>{"use strict";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.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)} } },`,"});"]}},Yc=Xn.object({name:Xn.string().describe("Variable name to save"),value:Xn.string().describe("Value to save in the variable")})});import{z as hr}from"zod";function pr(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:Jc,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:l.message}}}}})}var mr,Jc,zt=x(()=>{"use strict";mr=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)} } },`,"});"]}},Jc=hr.object({otp_secret_key:hr.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as gr}from"zod";async function qc(e,t,i){return{...await H(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function fr(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 yr(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Zc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:fr(l||`Get options from dropdown ${a}`,{index:a})};let c=await qc(s,o,l);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(s){return{success:!1,error:s.message,actionEntity:fr(l||`Get options from dropdown ${a}`,{index:a})}}}})}var wr,Zc,Vt=x(()=>{"use strict";X();wr=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 l=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return l?{options:Array.from(l.options).map(s=>({text:s.text,value:s.value,index:s.index})),id:l.id,name:l.name}:null},t.xpath);if(o){let r=[];for(let l of o.options){let s=JSON.stringify(l.text);r.push(`${l.index}: text=${s}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
4104
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Gc,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:Kn(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=s.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:Kn(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await Bc(`Set date to ${o} on element ${a}`,s,r,o);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Kn(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var ir,Gc,Ut=x(()=>{"use strict";X();W();I();ir=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=R(e,t);if(r){let l=await r.getAttribute("type").catch(()=>null);if(l&&l!=="date")throw new Error(`Element is not a native date picker (type="${l}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Gc=en.object({element_index:en.number().int().describe("Index of the native date picker input element"),date:en.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:en.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ar}from"zod";function rr(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Kc,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Switched to tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:s.message}}}}})}var or,Kc,jt=x(()=>{"use strict";or=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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 l=await i.switchTab(r);await l.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await l.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} } },`,"});"]}},Kc=ar.object({tab_index:ar.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});import{z as tn}from"zod";async function zc(e,t,i,n,a={}){return{...await H(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 lr(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Vc,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:sr(s||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=s||`Input text to element ${a}`,u=await zc("input_text",d,c,r,{text:o});return await t.execute(r,u,l),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:sr(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var zn,Vc,Bt=x(()=>{"use strict";X();W();I();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=R(e,t),l=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:l}),await r.click({timeout:l}),await e.waitForTimeout(200);let s=i.getActionSettings().type_delay;s!==void 0?await e.keyboard.type(o,{delay:s}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Vc=tn.object({element_index:tn.number().int().describe("Index of the input element"),text:tn.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:tn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as cr}from"zod";function dr(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:Xc,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Pressed keys "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:s.message}}}}})}var Vn,Xc,Gt=x(()=>{"use strict";Vn=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)});`]}},Xc=cr.object({keys:cr.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});import{z as Yc}from"zod";function hr(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:Jc,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 ur,Jc,Kt=x(()=>{"use strict";W();I();ur=class{async execute(e,t){await e.reload({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Jc=Yc.object({})});import{z as Xn}from"zod";async function qc(e,t,i,n,a={}){return{...await H(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 pr(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Zc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:mr(`Right-click element ${a}`,"right_click",{index:a})};let c=l||`Right-click element ${a}`,d=await qc("right_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:mr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var Yn,Zc,zt=x(()=>{"use strict";X();W();I();Yn=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Zc=Xn.object({element_index:Xn.number().int().describe("Index of the element to right-click"),timeout_ms:Xn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as gr}from"zod";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:Qc,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:l.message}}}}})}var fr,Qc,Vt=x(()=>{"use strict";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)} } },`,"});"]}},Qc=gr.object({otp_secret_key:gr.string().describe("The OTP secret key to generate the 2FA code from")})});import{z as yr}from"zod";async function ed(e,t,i){return{...await H(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function br(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 vr(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:td,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:br(l||`Get options from dropdown ${a}`,{index:a})};let c=await ed(s,o,l);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(s){return{success:!1,error:s.message,actionEntity:br(l||`Get options from dropdown ${a}`,{index:a})}}}})}var xr,td,Xt=x(()=>{"use strict";X();xr=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 l=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return l?{options:Array.from(l.options).map(s=>({text:s.text,value:s.value,index:s.index})),id:l.id,name:l.name}:null},t.xpath);if(o){let r=[];for(let l of o.options){let s=JSON.stringify(l.text);r.push(`${l.index}: text=${s}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
4105
4105
  `);a+=`
4106
- 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},`),"});"]}};Zc=gr.object({element_index:gr.number().int().describe("Index of the dropdown/select element")})});import{z as Qc}from"zod";function xr(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:ed,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let l={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,l,o),{success:!0,actionEntity:l,message:"Navigated back"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:l.message}}}}})}var br,ed,Xt=x(()=>{"use strict";W();I();br=class{async execute(e,t){await e.goBack({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},ed=Qc.object({})});import{z as tn}from"zod";function vr(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:td,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:l,agentServices:s,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,h={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(l,h,s),{success:!0,actionEntity:h,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(p){let h=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||h)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var Yn,td,Yt=x(()=>{"use strict";W();I();Yn=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 c=e.url(),d=null;try{let u=new URL(c);u.origin&&u.origin!=="null"&&(d=u.origin)}catch{}d&&(r=d+r)}let l=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,s=e;o&&(s=await e.context().newPage(),i.setPage(s)),await s.goto(r,{timeout:l})}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(", ")} } },`,"});"]}},td=tn.object({url:tn.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:tn.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:tn.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as Jn}from"zod";async function id(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function _r(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 kr(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:nd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:_r(`Hover element ${a}`,"hover",{index:a})};let c=l||`Hover over element ${a}`,d=await id("hover",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:_r(`Hover element ${a}`,"hover",{index:a})}}}})}var qn,nd,Jt=x(()=>{"use strict";X();W();I();qn=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let l=r.x+r.width/2,s=r.y+r.height/2;await e.mouse.move(l,s)}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},`),"});"]}};nd=Jn.object({element_index:Jn.number().int().describe("Index of the element to hover over"),timeout_ms:Jn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as nn}from"zod";async function ad(e,t,i,n,a={}){return{...await H(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 Er(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:od,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await B(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Sr(s||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=s||`Input text to element ${a}`,u=await ad("input_text",d,c,r,{text:o});return await t.execute(r,u,l),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Sr(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Zn,od,qt=x(()=>{"use strict";X();W();I();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=R(e,t),l=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:l}),await r.click({timeout:l}),await e.waitForTimeout(200);let s=i.getActionSettings().type_delay;s!==void 0?await e.keyboard.type(o,{delay:s}):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},`),"});"]}};od=nn.object({element_index:nn.number().int().describe("Index of the input element"),text:nn.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:nn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qn}from"zod";async function rd(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Tr(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:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:sd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Tr(l||`Clear element ${a}`,"clear_input",{index:a})};let c=l||`Clear element ${a}`,d=await rd("clear_input",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Tr(`Clear element ${a}`,"clear_input",{index:a})}}}})}var Ar,sd,Zt=x(()=>{"use strict";X();W();I();Ar=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};sd=Qn.object({element_index:Qn.number().int().describe("Index of the input element to clear"),timeout_ms:Qn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ea}from"zod";async function ld(e,t,i,n,a={}){return{...await H(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 Ir(e,t){e.register({name:"click",description:"Click an interactive element.",schema:cd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Mr(`Click element ${a}`,"click",{index:a})};let c=l||`Click element ${a}`,d=await ld("click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Mr(`Click element ${a}`,"click",{index:a})}}}})}var an,cd,Qt=x(()=>{"use strict";X();W();I();an=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Pe(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};cd=ea.object({element_index:ea.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:ea.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Pr}from"zod";function Nr(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:dd,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Closed tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:s.message}}}}})}var Cr,dd,ei=x(()=>{"use strict";Cr=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} } },`,"});"]}},dd=Pr.object({index:Pr.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as ta}from"zod";function Lr(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:ud,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 Or,ud,ti=x(()=>{"use strict";Or=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},ud=ta.object({success:ta.boolean().describe("Whether the task was completed successfully"),summary:ta.string().describe("Summary of what was accomplished or why it failed")})});import{z as ia}from"zod";async function hd(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Dr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Rr(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:md,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Dr(`Double-click element ${a}`,"double_click",{index:a})};let c=l||`Double-click element ${a}`,d=await hd("double_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Dr(`Double-click element ${a}`,"double_click",{index:a})}}}})}var na,md,ii=x(()=>{"use strict";X();W();I();na=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};md=ia.object({element_index:ia.number().int().describe("Index of the element to double-click"),timeout_ms:ia.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as pd}from"@babel/parser";function Fr(e){if(!e.trim())return!1;try{return pd(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var on=x(()=>{"use strict"});import{z as Hr}from"zod";function Wr(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:gd,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Assertion verified: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:l.message}}}},availability:{openai:!0,mcp:!0}})}var rn,gd,ni=x(()=>{"use strict";Et();on();U();rn=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 d=Date.now();try{await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let p=((Date.now()-d)/1e3).toFixed(1);w.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/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();w.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:l}=await Promise.resolve().then(()=>(tt(),et)),s=await l(o,e,i,{useCleanScreenshotForAssertion:!0}),c=s.explanation||s.error||(s.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!s.success)throw w.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(s.error||s.explanation||"Assertion failed");w.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",`
4106
+ 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},`),"});"]}};td=yr.object({element_index:yr.number().int().describe("Index of the dropdown/select element")})});import{z as id}from"zod";function kr(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:nd,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let l={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,l,o),{success:!0,actionEntity:l,message:"Navigated back"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:l.message}}}}})}var _r,nd,Yt=x(()=>{"use strict";W();I();_r=class{async execute(e,t){await e.goBack({timeout:pe}),await e.waitForLoadState("load",{timeout:pe}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},nd=id.object({})});import{z as nn}from"zod";function Sr(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:ad,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:l,agentServices:s,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,h={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(l,h,s),{success:!0,actionEntity:h,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(p){let h=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||h)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var Jn,ad,Jt=x(()=>{"use strict";W();I();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 c=e.url(),d=null;try{let u=new URL(c);u.origin&&u.origin!=="null"&&(d=u.origin)}catch{}d&&(r=d+r)}let l=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:pe,s=e;o&&(s=await e.context().newPage(),i.setPage(s)),await s.goto(r,{timeout:l})}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(", ")} } },`,"});"]}},ad=nn.object({url:nn.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:nn.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:nn.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});import{z as qn}from"zod";async function od(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Er(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:"hover",description:"Hover over an interactive element.",schema:rd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Er(`Hover element ${a}`,"hover",{index:a})};let c=l||`Hover over element ${a}`,d=await od("hover",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Er(`Hover element ${a}`,"hover",{index:a})}}}})}var Zn,rd,qt=x(()=>{"use strict";X();W();I();Zn=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let l=r.x+r.width/2,s=r.y+r.height/2;await e.mouse.move(l,s)}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},`),"});"]}};rd=qn.object({element_index:qn.number().int().describe("Index of the element to hover over"),timeout_ms:qn.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Qn}from"zod";function $r(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:sd,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Extracted ${a} to ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:s.message}}}},availability:{openai:!1,mcp:!0}})}var Ar,sd,Zt=x(()=>{"use strict";Ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:l}=await Promise.resolve().then(()=>(it(),tt)),s=await l(r,e,i);if(s.status!=="success")throw new Error(s.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||""}');`]}},sd=Qn.object({element_description:Qn.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Qn.string().describe("Name of the variable to store the extracted value")})});import{z as ea}from"zod";async function ld(e,t,i,n,a={}){return{...await H(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 Pr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:cd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Mr(l||`Clear element ${a}`,"clear_input",{index:a})};let c=l||`Clear element ${a}`,d=await ld("clear_input",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Mr(`Clear element ${a}`,"clear_input",{index:a})}}}})}var Ir,cd,Qt=x(()=>{"use strict";X();W();I();Ir=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};cd=ea.object({element_index:ea.number().int().describe("Index of the input element to clear"),timeout_ms:ea.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as ta}from"zod";async function dd(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Cr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Nr(e,t){e.register({name:"click",description:"Click an interactive element.",schema:ud,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Cr(`Click element ${a}`,"click",{index:a})};let c=l||`Click element ${a}`,d=await dd("click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Cr(`Click element ${a}`,"click",{index:a})}}}})}var an,ud,ei=x(()=>{"use strict";X();W();I();an=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Pe(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};ud=ta.object({element_index:ta.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:ta.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{z as Or}from"zod";function Dr(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:hd,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Closed tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:s.message}}}}})}var Lr,hd,ti=x(()=>{"use strict";Lr=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} } },`,"});"]}},hd=Or.object({index:Or.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});import{z as ia}from"zod";function Fr(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:md,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 Rr,md,ii=x(()=>{"use strict";Rr=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},md=ia.object({success:ia.boolean().describe("Whether the task was completed successfully"),summary:ia.string().describe("Summary of what was accomplished or why it failed")})});import{z as na}from"zod";async function pd(e,t,i,n,a={}){return{...await H(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Hr(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:"double_click",description:"Double-click an interactive element.",schema:gd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await B(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Hr(`Double-click element ${a}`,"double_click",{index:a})};let c=l||`Double-click element ${a}`,d=await pd("double_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Hr(`Double-click element ${a}`,"double_click",{index:a})}}}})}var aa,gd,ni=x(()=>{"use strict";X();W();I();aa=class{async execute(e,t,i){let n=R(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};gd=na.object({element_index:na.number().int().describe("Index of the element to double-click"),timeout_ms:na.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});import{parse as fd}from"@babel/parser";function Ur(e){if(!e.trim())return!1;try{return fd(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var on=x(()=>{"use strict"});import{z as jr}from"zod";function Br(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:wd,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Assertion verified: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:l.message}}}},availability:{openai:!0,mcp:!0}})}var rn,wd,ai=x(()=>{"use strict";Et();on();U();rn=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 d=Date.now();try{await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let p=((Date.now()-d)/1e3).toFixed(1);w.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/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();w.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:l}=await Promise.resolve().then(()=>(it(),tt)),s=await l(o,e,i,{useCleanScreenshotForAssertion:!0}),c=s.explanation||s.error||(s.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!s.success)throw w.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(s.error||s.explanation||"Assertion failed");w.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",`
4107
4107
  return (async () => {
4108
4108
  ${t}
4109
4109
  })();
4110
- `)(e,Qe.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(!Fr(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let l=r.split(`
4110
+ `)(e,et.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(!Ur(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let l=r.split(`
4111
4111
  `),s=JSON.stringify(a);return["{ const _t = Date.now(); try {",...l.map(c=>` ${c}`),` 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}, ${o});`,"} }"]}return r.split(`
4112
- `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},gd=Hr.object({statement:Hr.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});import{z as aa}from"zod";function jr(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:fd,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Extracted ${a} to ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:s.message}}}},availability:{openai:!1,mcp:!0}})}var Ur,fd,ai=x(()=>{"use strict";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:l}=await Promise.resolve().then(()=>(tt(),et)),s=await l(r,e,i);if(s.status!=="success")throw new Error(s.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||""}');`]}},fd=aa.object({element_description:aa.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:aa.string().describe("Name of the variable to store the extracted value")})});var wd,yd,We,sn=x(()=>{"use strict";wd=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],yd=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],We=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:wd.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:!yd.includes(t)}}});var oa,ra,oi,sa=x(()=>{"use strict";Ri();Fi();Hi();Wi();Ui();ji();Bi();Yi();Ji();qi();Zi();Mt();It();Pt();Nt();Lt();Dt();Rt();Ft();Ht();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();sn();W();ye();oa=class A{static registerAction(t,i){A.actions.set(t,i)}constructor(){A.initialized||(this.registerBuiltinActions(),A.initialized=!0)}registerBuiltinActions(){A.registerAction("go_to_url",new Yn),A.registerAction("go_back",new br),A.registerAction("reload_page",new rr),A.registerAction("close_tab",new Cr),A.registerAction("switch_tab",new Zo),A.registerAction("click",new an),A.registerAction("hover",new qn),A.registerAction("right_click",new Vn),A.registerAction("double_click",new na),A.registerAction("click_by_coordinates",new Ao),A.registerAction("right_click_by_coordinates",new vo),A.registerAction("double_click_by_coordinates",new $o),A.registerAction("drag_drop",new _o),A.registerAction("input_text",new Zn),A.registerAction("clear_input",new Ar),A.registerAction("press",new Kn),A.registerAction("send_keys_on_element",new wo),A.registerAction("scroll_on_element",new Uo),A.registerAction("scroll_to_text",new Go),A.registerAction("scroll",new Ct),A.registerAction("upload_file",new ir),A.registerAction("wait_for_download_complete",new Lo),A.registerAction("get_dropdown_options",new wr),A.registerAction("select_dropdown_option",new Vo),A.registerAction("set_date_for_native_date_picker",new Yo),A.registerAction("verify",new rn),A.registerAction("ai_action",new Io),A.registerAction("ai_extract",new Ur),A.registerAction("ai_step",new To),A.registerAction("ai_wait_until",new Ro),A.registerAction("generate_2fa_code",new mr),A.registerAction("wait",new Co),A.registerAction("wait_for_page_ready",new fo),A.registerAction("save_variable",new dr),A.registerAction("js_code",new xo),A.registerAction("js_action",new yo),A.registerAction("function",new ko),A.registerAction("done",new Or),A.registerAction("click_element",new an),A.registerAction("click_element_by_index",new an),A.registerAction("hover_element_by_index",new qn),A.registerAction("right_click_on_element",new Vn),A.registerAction("double_click_on_element",new na),A.registerAction("scroll_down",new Ct),A.registerAction("scroll_up",new Ct),A.registerAction("scroll_element",new Ct),A.registerAction("send_keys",new Kn),A.registerAction("open_tab",new Yn),A.registerAction("fill",new Zn),A.registerAction("ai_assert",new rn),A.registerAction("assert",new rn)}getAction(t){return A.actions.get(t)}hasAction(t){return A.actions.has(t)}getActionNames(){return Array.from(A.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}=(I(),Mn(vi)),o=t.action_description||"",r=t.action_data?.action_name||"",l=this.getAction(r);if(!l)return[`// ${i}: Unknown action: ${r}`];let s=l.transpile(t,i);if(We.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...s];let c=JSON.stringify(o),d=s.map(h=>` ${h}`),u=We.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Mn(vi));if(!t)return[`// ${i}: Skipping - no description`];let l=JSON.stringify(t);if(a){let s=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${l}, '${i}'${s});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${l}, '${i}', ${n});`]}};oa.actions=new Map,oa.initialized=!1;ra=oa,oi=ra});var ln={};dt(ln,{ActionHandler:()=>ra,default:()=>oi});var cn=x(()=>{"use strict";sa();Ri();Fi();Hi();Wi();Ui();ji();Bi();Yi();Ji();qi();Zi();Mt();It();Pt();Nt();Lt();Dt();Rt();Ft();Ht();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();Et();ai();on();Wt();X();Re();U();ne();Tt();sn();W();ye()});import{z as ri}from"zod";function dn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4112
+ `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},wd=jr.object({statement:jr.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});var yd,bd,Ue,sn=x(()=>{"use strict";yd=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],bd=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ue=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:yd.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:!bd.includes(t)}}});var oa,ra,oi,sa=x(()=>{"use strict";Ri();Fi();Hi();Wi();Ui();ji();Bi();Gi();Ji();qi();Zi();It();Pt();Ct();Nt();Ot();Dt();Ft();Ht();Wt();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();sn();W();ve();oa=class A{static registerAction(t,i){A.actions.set(t,i)}constructor(){A.initialized||(this.registerBuiltinActions(),A.initialized=!0)}registerBuiltinActions(){A.registerAction("go_to_url",new Jn),A.registerAction("go_back",new _r),A.registerAction("reload_page",new ur),A.registerAction("close_tab",new Lr),A.registerAction("switch_tab",new or),A.registerAction("click",new an),A.registerAction("hover",new Zn),A.registerAction("right_click",new Yn),A.registerAction("double_click",new aa),A.registerAction("click_by_coordinates",new Mo),A.registerAction("right_click_by_coordinates",new _o),A.registerAction("double_click_by_coordinates",new ko),A.registerAction("drag_drop",new So),A.registerAction("input_text",new zn),A.registerAction("clear_input",new Ir),A.registerAction("press",new Vn),A.registerAction("send_keys_on_element",new yo),A.registerAction("scroll_on_element",new Xo),A.registerAction("scroll_to_text",new qo),A.registerAction("scroll",new Lt),A.registerAction("upload_file",new Oo),A.registerAction("wait_for_download_complete",new Wo),A.registerAction("get_dropdown_options",new xr),A.registerAction("select_dropdown_option",new er),A.registerAction("set_date_for_native_date_picker",new ir),A.registerAction("verify",new rn),A.registerAction("ai_action",new Po),A.registerAction("ai_extract",new Ar),A.registerAction("ai_step",new $o),A.registerAction("ai_wait_until",new jo),A.registerAction("generate_2fa_code",new fr),A.registerAction("wait",new Ro),A.registerAction("wait_for_page_ready",new wo),A.registerAction("save_variable",new Go),A.registerAction("js_code",new vo),A.registerAction("js_action",new bo),A.registerAction("function",new Eo),A.registerAction("done",new Rr),A.registerAction("click_element",new an),A.registerAction("click_element_by_index",new an),A.registerAction("hover_element_by_index",new Zn),A.registerAction("right_click_on_element",new Yn),A.registerAction("double_click_on_element",new aa),A.registerAction("scroll_down",new Lt),A.registerAction("scroll_up",new Lt),A.registerAction("scroll_element",new Lt),A.registerAction("send_keys",new Vn),A.registerAction("open_tab",new Jn),A.registerAction("fill",new zn),A.registerAction("ai_assert",new rn),A.registerAction("assert",new rn)}getAction(t){return A.actions.get(t)}hasAction(t){return A.actions.has(t)}getActionNames(){return Array.from(A.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}=(I(),Mn(_i)),o=t.action_description||"",r=t.action_data?.action_name||"",l=this.getAction(r);if(!l)return[`// ${i}: Unknown action: ${r}`];let s=l.transpile(t,i);if(Ue.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...s];let c=JSON.stringify(o),d=s.map(h=>` ${h}`),u=Ue.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Mn(_i));if(!t)return[`// ${i}: Skipping - no description`];let l=JSON.stringify(t);if(a){let s=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${l}, '${i}'${s});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${l}, '${i}', ${n});`]}};oa.actions=new Map,oa.initialized=!1;ra=oa,oi=ra});var ln={};ut(ln,{ActionHandler:()=>ra,default:()=>oi});var cn=x(()=>{"use strict";sa();Ri();Fi();Hi();Wi();Ui();ji();Bi();Gi();Ji();qi();Zi();It();Pt();Ct();Nt();Ot();Dt();Ft();Ht();Wt();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();Et();on();Mt();X();Re();U();ne();Tt();sn();W();ve()});import{z as ri}from"zod";function dn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4113
4113
  ${e.stepHistory.slice(-3).map(s=>{let c=`${s.outcome.success?"\u2713":"\u2717"} Step ${s.stepNumber}: ${s.goal}`;if(s.actions.length>1)s.actions.forEach((d,u)=>{let p=d.action_description||"Unknown action";c+=`
4114
4114
  \u2192 Action ${u+1}: ${p}`});else if(s.actions.length===1){let d=s.actions[0]?.action_description||"Unknown action";c+=`
4115
4115
  \u2192 ${d}`}if(!s.outcome.success&&s.outcome.error){let d=s.outcome.error.substring(0,100);c+=`
@@ -4129,7 +4129,7 @@ ${e.memory.map((s,c)=>`${c+1}. ${s}`).join(`
4129
4129
  **Current URL**: ${i}
4130
4130
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4131
4131
 
4132
- ${o()}${r()}${a()}${n()}${l()}`.trim()}function Br(){return`
4132
+ ${o()}${r()}${a()}${n()}${l()}`.trim()}function Gr(){return`
4133
4133
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4134
4134
 
4135
4135
  This is your last step. You MUST use the "done" action now.
@@ -4138,7 +4138,7 @@ This is your last step. You MUST use the "done" action now.
4138
4138
  - If the task is incomplete or partially complete, set success=false
4139
4139
  - Include everything you've accomplished in the done action's text field
4140
4140
  - No other actions are allowed on this step
4141
- `.trim()}function bd(){let e=j.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof ri.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let l=a[r],s="any";l instanceof ri.ZodNumber?s="number":l instanceof ri.ZodString?s="string":l instanceof ri.ZodBoolean?s="boolean":l instanceof ri.ZodEnum&&(s=l._def.values.map(c=>`"${c}"`).join(" | ")),o.push(`${r}: ${s}`)}),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(`
4141
+ `.trim()}function xd(){let e=j.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof ri.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let l=a[r],s="any";l instanceof ri.ZodNumber?s="number":l instanceof ri.ZodString?s="string":l instanceof ri.ZodBoolean?s="boolean":l instanceof ri.ZodEnum&&(s=l._def.values.map(c=>`"${c}"`).join(" | ")),o.push(`${r}: ${s}`)}),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(`
4142
4142
  `)}function un(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
4143
4143
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4144
4144
  - "success: <reason>" if the goal was fully achieved
@@ -4246,7 +4246,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4246
4246
 
4247
4247
  When stuck, call \`done\` with success=false and explain what happened.
4248
4248
 
4249
- ${bd()}
4249
+ ${xd()}
4250
4250
  ## Reasoning Rules
4251
4251
 
4252
4252
  Use the \`thinking\` field to reason about each step:
@@ -4298,19 +4298,19 @@ ${h.join(`
4298
4298
  `,n+=`- Use the EXACT placeholder name as shown above
4299
4299
  `,n+=`- Do NOT use the actual value directly in the action
4300
4300
  `,n+=`- The values shown are for context only to help you understand what data is available
4301
- `,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 si=x(()=>{"use strict"});async function Sd(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"],l=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(h=>p.includes(h))},s=u=>{let p=u.resourceType(),h=u.url();if(!a.has(p)||l(h))return;let f=u.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(u),n=Date.now())},c=async u=>{let p=u.request();if(!i.has(p))return;let h=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(g=>h.includes(g))){i.delete(p);return}if(![...o].some(g=>h.startsWith(g))){i.delete(p);return}let f=u.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},d=Date.now()-kd;for(let u of await e.requests()){let p=u.resourceType(),h=u.url(),f=u.timing();a.has(p)&&!l(h)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(u),n=Date.now())}w.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",s),e.on("response",c);try{let u=Date.now(),p=_d;for(;;){await new Promise(f=>setTimeout(f,100));let h=Date.now();if(i.size===0&&h-n>=p){w.debug(`[waitForStableNetwork] Network idle after ${h-u}ms`);break}if(h-u>t){w.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",s),e.removeListener("response",c)}}async function it(e,t=vd,i=xd){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Sd(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 xd,vd,_d,kd,Oe=x(()=>{"use strict";si();U();xd=.5*1e3,vd=30*1e3,_d=1*1e3,kd=3*1e3});import{generateText as Ed}from"ai";function Td(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 zr(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(),l=t.domService||new Ne(t.agentServices.getDomServiceOptions()),s={...t,domService:l};E.init(),E.section("Task Execution Started"),E.log(`Task: ${e}`),E.log(`Max steps: ${a}`),E.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],u=un(i.customPrompt),p=new mn(u);E.log(`System prompt length: ${u.length} chars`);let h=!1,f="",g=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let y=Date.now();E.section(`Step ${c.currentStep}/${a}`),E.log(`URL: ${s.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{E.log("Waiting for page to stabilize..."),await it(s.page),E.log("Page stabilized")}catch{E.log("Page stabilization timed out, continuing anyway")}let m;try{E.log("Preparing context (DOM + screenshot)...");let N=s.agentServices.getInteractiveClassNames(),O=s.agentServices.getIframeFallbackDomains();m=await Kr(s.page,s.domService,N,O),E.log("Context prepared")}catch(N){if(N.message.includes("Execution context was destroyed")){E.log("Page navigating, waiting for load..."),await it(s.page);let O=s.agentServices.getInteractiveClassNames(),L=s.agentServices.getIframeFallbackDomains();m=await Kr(s.page,s.domService,O,L)}else throw E.error("Error preparing context",N),N}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let b=await $d(p,r,i,m.screenshotBase64);if(b.tokenUsages&&b.tokenUsages.length>0&&d.push(...b.tokenUsages),!b.stepOutput){if(E.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let v=b.stepOutput;Cd(c.currentStep,a,v);let S=await Id(v,s,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,b.debugInfo);g.push(...S.actionEntities);let T=Pd(c.currentStep,v,S,c,y,b.debugInfo,b.tokenUsages),M=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){E.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(S.doneResult){h=S.doneResult.success,f=S.doneResult.summary;break}if(S.completesInstruction){h=!0,f="Instruction completed";break}}return c.currentStep>=a&&!h&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),E.log(`Build success result: summary=${f}, completed=${h}, actions=${g.length}, tokens=${d.length}`),Nd(c,g,h,f,n,d,r)}catch(y){let m=y.message;return E.error(`Task execution failed: ${m}`,y),i.onEvent?.({type:"error",error:m,recoverable:!1}),Od(c,m,n,d,r)}}async function Kr(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 Ad(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 $d(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),l=0;for(let u of r)Array.isArray(u.content)&&(l+=u.content.filter(p=>p.type==="image").length);let s=ve(t,l),c={model:xe(t),system:o,messages:r,temperature:a,providerOptions:s},d=3;for(let u=0;u<d;u++)try{let p=Date.now();E.log(`Calling LLM (${t})...`);let h=await Ed(c),f=Date.now()-p,g=h,y=g.usage;E.llmCall(t,f,y);let m=g.reasoningText;m&&(E.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(h.text);let b={systemPrompt:o,userPrompt:Ad(r),rawLlmResponse:h.text,reasoningContent:m,screenshotWithSom:n},v=[],S=Td(y,t);S&&v.push(S);let T=Md(h.text);if(!T)if(u<d-1){E.log(`Attempt ${u+1}/${d}: 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(M=>setTimeout(M,i.retryDelay||1e3));continue}else return E.error("All parsing attempts failed"),{stepOutput:null,debugInfo:b,tokenUsages:v};return{stepOutput:T,debugInfo:b,tokenUsages:v}}catch(p){if(u<d-1){E.log(`Attempt ${u+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(h=>setTimeout(h,i.retryDelay||1e3));continue}else throw E.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Md(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 E.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return E.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return E.error("Action missing required field: action_name"),null;if(!n.description)return E.error("Action missing required field: description"),null}return i}catch(i){return E.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),E.error(`Parse error: ${i.message}`),null}}async function Id(e,t,i,n,a,o,r){let l=[],s=!0,c=null;E.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,u={...t,domState:i},p=o;for(let h of e.actions){if(h.action_name==="done"){d={success:h.kwargs.success??!0,summary:h.kwargs.summary||h.kwargs.text||"Task completed"};break}let f={},g=h.kwargs?.element_index??h.kwargs?.index;if(typeof g=="number"){let m=i.selectorMap.get(g);m&&(f=await H(t.page,m))}let y={...f,action_description:h.description,action_data:{action_name:h.action_name,kwargs:h.kwargs}};try{let m=await j.execute(h.action_name,h.kwargs,u);h.action_name==="perform_accurate_operation"&&(y=m.actionEntity);let b=await u.agentServices.getCurrentPage();if(b&&(u.page=b,t.page=u.page),m?.success===!1){s=!1,E.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}l.push(y),a?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(m){s=!1,c=m.message,E.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:s,failReason:c,actionEntities:l,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Pd(e,t,i,n,a,o,r){let l={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 s=t.memory.trim();n.memory.includes(s)||(n.memory.push(s),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(l),l}function Cd(e,t,i){if(E.log(`Step ${e}/${t}`),i.thinking&&E.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&E.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&E.log(`Memory: ${i.memory}`),E.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];E.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else E.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{E.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Nd(e,t,i,n,a,o,r){let l=o.reduce((d,u)=>d+u.prompt_tokens,0),s=o.reduce((d,u)=>d+u.completion_tokens,0),c=o.reduce((d,u)=>d+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(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:l,completionTokens:s,totalTokens:c,tokenUsages:o}}}function Od(e,t,i,n,a){let o=n.reduce((s,c)=>s+c.prompt_tokens,0),r=n.reduce((s,c)=>s+c.completion_tokens,0),l=n.reduce((s,c)=>s+c.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(s=>s.outcome.success).length,failedSteps:e.stepHistory.filter(s=>!s.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:l,tokenUsages:n}}}var Vr=x(()=>{"use strict";la();hn();ke();He();ae();Oe();_e();X()});var Xr={};dt(Xr,{TaskMessageManager:()=>mn,formatFinalStepWarning:()=>Br,formatTaskContext:()=>dn,getBrowserTaskJSONPrompt:()=>un,runTaskLoop:()=>zr});var Yr=x(()=>{"use strict";Vr();la();hn();ke();Gi();He();xt();vt();Ze();_t();kt();ae();Oe();si();_e();gt();Ve();ft();Ce();ze();X();Re();U();ne();Tt();W();ye()});async function At(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(j.has(i)){let a=await j.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 Ld()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Ld(){if(pn)return pn;let e=await Promise.resolve().then(()=>(cn(),ln));return pn=new e.default,pn}async function Ki(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Dn(r,o,n);return l.status==="error"?{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error,debugInfo:l.debugInfo}:{status:"success",completed:l.goalAccomplished||!1,actionEntities:l.actionEntity?[l.actionEntity]:[],explanation:l.reasoning,debugInfo:l.debugInfo}}async function zi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Dn(r,o,n);if(l.status==="error"||!l.actionEntity)return{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error||"No action generated",debugInfo:l.debugInfo};let{actionEntity:s,reasoning:c,goalAccomplished:d,debugInfo:u}=l,p=await At(s,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[s],explanation:c,debugInfo:u}):{status:"error",completed:!1,actionEntities:[s],error:p.error||"Action execution failed",debugInfo:u}}async function Vi(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),so(o,a,n)}async function Xi(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Yr(),Xr)),r=n?s=>{n(s)}:void 0,l=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:l.success?"success":"error",completed:l.completed,actionEntities:l.trajectory.actions,explanation:l.summary,error:l.error,tokenUsages:l.metadata.tokenUsages}}var pn,$t=x(()=>{"use strict";Li();ke();He();pn=null});import{z as _}from"zod";import"yaml";import"uuid";import"yaml";import"uuid";var ms,Lv,ps,Gd,Kd,fn,Dv,Rv,gs,fs,zd,hs,Vd,li,Xd,Yd,Jd,le,qd,Zd,Hv,Jv,ci=x(()=>{"use strict";ye();ms=112,Lv=1080-ms,ps=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ps||{}),Gd={"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"}},Kd={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"]},fn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Kd[e].map(n=>Gd[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Dv={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile")}},Rv={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile",!0)}},gs=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(gs||{}),fs=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(fs||{}),zd=_.enum(["JS_CODE","AI_MODE"]),hs=_.object({type:zd,expression:_.string()}),Vd=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),li=_.object({uid:_.string(),type:Vd,comment:_.string().optional()}),Xd=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Yd=li.extend({type:_.literal("DRAFT"),description:_.string()}),Jd=li.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Xd.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),le=_.lazy(()=>_.union([Yd,Jd,li.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(le),reference_id:_.number().optional(),template_path:_.string().optional(),template_params:_.record(_.string()).optional()}),li.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:hs,then:_.array(le),else:_.array(le).optional()}),li.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:hs,body:_.array(le),timeout_ms:_.number().optional()})])),qd=_.object({name:_.string(),statements:_.array(le),teardown:_.array(le).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),Zd=_.object({tests:_.array(qd).min(1),beforeAll:_.array(le).optional(),afterAll:_.array(le).optional(),beforeEach:_.array(le).optional(),afterEach:_.array(le).optional()}),Hv=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(le).optional(),teardown:_.array(le).optional(),last_modified_at:_.string().optional(),testGroup:Zd.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"}),Jv=1024*1024});var da=x(()=>{"use strict";ae();Oe()});import{z as k}from"zod";var vs,ua,_s,at,ks,Ss,Es,re,Ts,wn,ha,ma=x(()=>{"use strict";vs=k.enum(["JS_CODE","AI_MODE"]),ua=k.object({type:vs,expression:k.string()}),_s=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),at=k.object({uid:k.string(),type:_s,comment:k.string().optional()}),ks=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),Ss=at.extend({type:k.literal("DRAFT"),description:k.string()}),Es=at.extend({type:k.literal("ACTION"),description:k.string(),action_entity:ks.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),re=k.lazy(()=>k.union([Ss,Es,at.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(re),reference_id:k.number().optional(),template_path:k.string().optional(),template_params:k.record(k.string()).optional()}),at.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:ua,then:k.array(re),else:k.array(re).optional()}),at.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:ua,body:k.array(re),timeout_ms:k.number().optional()})])),Ts=k.object({name:k.string(),statements:k.array(re),teardown:k.array(re).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),wn=k.object({tests:k.array(Ts).min(1),beforeAll:k.array(re).optional(),afterAll:k.array(re).optional(),beforeEach:k.array(re).optional(),afterEach:k.array(re).optional()}),ha=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(re).optional(),teardown:k.array(re).optional(),last_modified_at:k.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"})});import{stringify as US,parse as Is,parseAllDocuments as jS,parseDocument as pu,Document as Ps,isMap as rt,isSeq as se}from"yaml";import{v4 as me}from"uuid";function yn(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(ce)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ce)),i}function ga(e,t){if(e.testGroup)return Ns(e,t);let i=yn(e,t),n=new Ps(i),a=n.contents?.get("tags",!0);return se(a)&&(a.flow=!0),e.comment&&(n.commentBefore=e.comment),As(n,e.statements??[]),e.teardown&&As(n,e.teardown,"teardown"),n.toString(Cs)}function As(e,t,i="statements"){let n=e.contents;if(!n||!rt(n))return;let a=n.get(i,!0);se(a)&&hi(a,t)}function hi(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),rt(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);se(r)&&hi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);se(r)&&hi(r,n.then);let l=o.get("ELSE",!0);se(l)&&n.else&&hi(l,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);se(r)&&hi(r,n.body)}}}}function Ns(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let a={};e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(ce)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ce)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ce)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ce)),a.tests=i.tests.map(l=>{let s={name:l.name};return l.skip!==void 0&&(s.skip=l.skip),l.timeout!==void 0&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only!==void 0&&(s.only=l.only),l.slow!==void 0&&(s.slow=l.slow),s.statements=l.statements.map(ce),l.teardown&&l.teardown.length>0&&(s.teardown=l.teardown.map(ce)),s}),n.suite=a;let o=new Ps(n),r=o.contents?.get("tags",!0);return se(r)&&(r.flow=!0),o.toString(Cs)}function ce(e){switch(e.type){case"DRAFT":return gu(e);case"ACTION":return fu(e);case"STEP":return wu(e);case"IF_ELSE":return yu(e);case"WHILE_LOOP":return bu(e)}}function gu(e){return{intent:e.description}}function fu(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 l=i?.statement;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s=i?.code;return typeof s=="string"&&s.trim()?{VERIFY:l,js:s}:{VERIFY:l}}}if(t==="go_to_url"){let l=i?.url;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s={URL:l};return i?.new_tab===!0&&(s.new_tab=!0),typeof i?.timeout_seconds=="number"&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="js_action"){let l=i?.code;if(typeof l=="string"&&l.trim()&&e.description)return{description:e.description,js:l}}if(t==="ai_wait_until"){let l=i?.condition;if(typeof l=="string"){let s={WAIT_UNTIL:l};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="wait"){let l=i?.seconds,c={WAIT:e.description||`Wait ${l}s`};return typeof l=="number"&&(c.seconds=l),c}if(t==="js_code"){let l=i?.code;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:l}}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[l,s]of Object.entries(n.kwargs))l!=="uid"&&(l==="statement"&&(t==="ai_action"||t==="ai_step")||(a[l]=s));return n.args&&n.args.length>0&&(a.args=n.args),a}function wu(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(ce)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function yu(e){let t={IF:Os(e.condition),THEN:e.then.map(ce)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ce)),t}function bu(e){let t={WHILE:Os(e.condition),DO:e.body.map(ce)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Os(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function fa(e){try{let t=Is(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function pa(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(pa);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]=pa(o);return n}function Te(e){if(e.length>$s)throw new Error(`YAML input too large (${e.length} bytes, max ${$s})`);let t=pa(Is(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return xu(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:de(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=de(t.teardown));let n=ha.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return bn(e,a),a}function xu(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(l=>{if(!l.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(l.statements)||l.statements.length===0)throw new Error(`Suite test "${l.name}" must have a non-empty "statements" array`);let s={name:l.name,statements:de(l.statements)};return Array.isArray(l.teardown)&&l.teardown.length>0&&(s.teardown=de(l.teardown)),l.skip!==void 0&&(s.skip=l.skip),typeof l.timeout=="number"&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only===!0&&(s.only=!0),l.slow===!0&&(s.slow=!0),s})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=de(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=de(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=de(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=de(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 de(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(vu)}function vu(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 _u(t);if("WHILE"in t)return ku(t);if("STEP"in t)return Su(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:me(),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:me(),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:me(),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:me(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:me(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:me(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Ms({...n,action:"function",functionName:i})}if("action"in t)return Ms(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:me(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Ls(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 _u(e){let t=Ls(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:me(),type:"IF_ELSE",condition:t,then:de(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=de(e.ELSE)),n}function ku(e){let t=Ls(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:me(),type:"WHILE_LOOP",condition:t,body:de(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Su(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:me(),type:"STEP",description:t,statements:de(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,a={};for(let[o,r]of Object.entries(n))a[o]=String(r);i.template_params=a}return i}function Ms(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[c,d]of Object.entries(e))Eu.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let l={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(l.locator=n),a&&(l.xpath=a);let s={uid:me(),type:"ACTION",description:i,action_entity:l};return o&&(s.use_pure_vision=!0),s}function bn(e,t){let i;try{i=pu(e)}catch{return}let n=i.contents;if(!n||!rt(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let s=n.items?.[0];s?.key&&s.key.commentBefore&&(t.comment=s.key.commentBefore)}let a=n,o=a.get("statements",!0);se(o)&&t.statements&&ot(o,t.statements);let r=a.get("teardown",!0);se(r)&&t.teardown&&ot(r,t.teardown)}function ot(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"&&rt(n)){let o=n.get("statements",!0);se(o)&&ot(o,a.statements)}else if(a.type==="IF_ELSE"&&rt(n)){let o=n.get("THEN",!0);se(o)&&ot(o,a.then);let r=n.get("ELSE",!0);se(r)&&a.else&&ot(r,a.else)}else if(a.type==="WHILE_LOOP"&&rt(n)){let o=n.get("DO",!0);se(o)&&ot(o,a.body)}}}var Cs,$s,Eu,xn=x(()=>{"use strict";ma();Cs={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};$s=1024*1024;Eu=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as VS,stringify as XS}from"yaml";var Ds=x(()=>{"use strict";xn()});var vn=x(()=>{"use strict"});var Rs=x(()=>{"use strict";xn();vn()});var Fs=x(()=>{"use strict";vn()});import{v4 as nE}from"uuid";var Hs=x(()=>{"use strict"});var Ue,Ws=x(()=>{"use strict";Ue=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(Ue||{})});var _n=x(()=>{"use strict"});var Us=x(()=>{"use strict";_n()});var js,Mu,Bs,Gs,mi,Iu,Pu,Ks=x(()=>{"use strict";js=112,Mu=1080-js,Bs={"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"}},Gs={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"]},mi=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Gs[e].map(n=>Bs[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Iu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile")}},Pu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile",!0)}}});var zs=x(()=>{"use strict"});var Vs=x(()=>{"use strict"});var Xs=x(()=>{"use strict"});var Ys=x(()=>{"use strict"});var Js=x(()=>{"use strict"});var qs=x(()=>{"use strict"});var Zs=x(()=>{"use strict"});var Qs=x(()=>{"use strict";_n()});var st=x(()=>{"use strict";Ds();Rs();xn();ma();Fs();Hs();vn();Ws();Us();Ks();zs();Vs();Xs();Ys();Js();qs();Zs();Qs();_n()});import{stringify as _1}from"yaml";import{createHash as Ru}from"crypto";import{parse as Fu,stringify as ol}from"yaml";import{readFileSync as Hu,existsSync as Wu}from"fs";import{resolve as wa,dirname as Uu}from"path";import{parse as tl,stringify as ju}from"yaml";function Lu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Du(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 al(e){let t=Lu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Du(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){te.set(e,t)}function je(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 ya(e,t){let i=t.action_data?.kwargs||{},n=[];return typeof i.relative_x=="number"&&typeof i.relative_y=="number"?(n.push(`action_data: { kwargs: { relative_x: ${i.relative_x}, relative_y: ${i.relative_y} } }`),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)}`)):typeof i.x=="number"&&typeof i.y=="number"&&n.push(`action_data: { kwargs: { x: ${i.x}, y: ${i.y} } }`),[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function el(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 rl(e,t,i){let n={expandingPaths:new Set([wa(t)]),depth:0,referencedPaths:new Set,basePath:i},a={...e};Array.isArray(a.statements)&&(a.statements=Le(a.statements,t,n)),Array.isArray(a.teardown)&&(a.teardown=Le(a.teardown,t,n));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(a[o])&&(a[o]=Le(a[o],t,n));return{doc:a,referencedTemplatePaths:Array.from(n.referencedPaths)}}function Le(e,t,i){let n=[];for(let a of e)if(Bu(a)){let o=Gu(a,t,i);n.push(o)}else n.push(Ku(a,t,i));return n}function Bu(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function Gu(e,t,i){if(i.depth>=il)throw new Error(`Template expansion exceeded maximum depth of ${il}. Check for deeply nested or circular template references.`);let n=wa(Uu(t),e.template),a=!Wu(n)&&i.basePath?wa(i.basePath,e.template):n;if(i.expandingPaths.has(a))throw new Error(`Circular template reference detected: ${a} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${a}`);i.referencedPaths.add(a);let o;try{o=Hu(a,"utf-8")}catch(f){throw new Error(`Failed to read template file: ${a} (referenced from ${t}): ${f.message}`)}let r=tl(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${a} \u2014 expected a YAML object`);let l=r.params||[],s=e.params||{};for(let f of l)if(!(f in s))throw new Error(`Template ${e.template} requires param "${f}" but it was not provided. Required params: [${l.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let g=ju(c);for(let[y,m]of Object.entries(s))g=g.split(`<<${y}>>`).join(String(m));c=tl(g)}let d={expandingPaths:new Set([...i.expandingPaths,a]),depth:i.depth+1,referencedPaths:i.referencedPaths},u=Le(c,a,d),h={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:u};return Object.keys(s).length>0&&(h.template_params=s),h}function Ku(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Le(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Le(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Le(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Le(n.DO,t,i)),n}function ll(e,t,i){let n=Fu(e),a=n?.name,o=n?.tags,r=n?.use;if(n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use),n?.suite){if(n.goal||n.statements)throw new sl('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Vu(n,a,o,r,t,i)}return zu(n,a,o,r,t,i)}function zu(e,t,i,n,a,o){let r=e?.beforeEach,l=e?.afterEach,s=cl(e?.parameters),c=e?.timeout,d=e?.skip,u=e?.fail,p=e?.only,h=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 sl(`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 m=rl(e,a,o);e=m.doc,f=m.referencedTemplatePaths}let g=ol(e),y=Te(g);return a&&(lt(y.statements??[],a,"main"),y.teardown&&lt(y.teardown,a,"teardown")),{testFlow:y,name:t,tags:i,use:n,beforeEach:r,afterEach:l,parameters:s,timeout:c,skip:d,fail:u,only:p,slow:h,referencedTemplatePaths:f}}function Vu(e,t,i,n,a,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let l=r.beforeAll,s=r.afterAll,c=r.beforeEach,d=r.afterEach,u=[],p=r.tests.map(g=>{if(!g.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(g.statements)||g.statements.length===0)throw new Error(`Suite test "${g.name}" must have a non-empty "statements" array.`);let y={goal:g.name,statements:g.statements};g.teardown&&(y.teardown=g.teardown);let m=[],b=y;if(a&&typeof y=="object"){let M=rl(y,a,o);b=M.doc,m=M.referencedTemplatePaths,u.push(...m)}let v=ol(b),S=Te(v),T=cl(g.parameters);return{testFlow:S,name:g.name,tags:Array.isArray(g.tags)?g.tags:void 0,parameters:T,timeout:g.timeout,skip:g.skip,fail:g.fail,only:g.only,slow:g.slow}}),h=r.base_url,f=h?{...n,baseURL:h}:n;return{suite:{beforeAll:l,afterAll:s,beforeEach:c,afterEach:d,tests:p},name:t,tags:i,use:f,referencedTemplatePaths:u}}function cl(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 lt(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Xu(t,o,r),a.type===Ue.STEP)lt(a.statements,t,o);else if(a.type===Ue.IF_ELSE){let l=a;lt(l.then,t,`${o}.then`),l.else&&lt(l.else,t,`${o}.else`)}else a.type===Ue.WHILE_LOOP&&lt(a.body,t,`${o}.body`)}}function Xu(e,t,i){let n=Ru("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 nl,te,il,sl,dl=x(()=>{"use strict";st();st();st();st();nl=5e3;te=new Map;$("click",e=>{let t=al(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??nl;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",te.get("click"));$("click_element_by_index",te.get("click"));$("double_click",e=>je("double_click",e));$("double_click_on_element",te.get("double_click"));$("right_click",e=>je("right_click",e));$("right_click_on_element",te.get("right_click"));$("hover",e=>je("hover",e));$("hover_element_by_index",te.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return je("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",te.get("input_text"));$("clear_input",e=>je("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",te.get("press"));$("send_keys_on_element",e=>{let t=al(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??nl;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return je("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",te.get("scroll"));$("scroll_up",te.get("scroll"));$("scroll_element",te.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>je("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",te.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
4301
+ `,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 si=x(()=>{"use strict"});async function Ed(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"],l=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(h=>p.includes(h))},s=u=>{let p=u.resourceType(),h=u.url();if(!a.has(p)||l(h))return;let f=u.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(u),n=Date.now())},c=async u=>{let p=u.request();if(!i.has(p))return;let h=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(g=>h.includes(g))){i.delete(p);return}if(![...o].some(g=>h.startsWith(g))){i.delete(p);return}let f=u.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},d=Date.now()-Sd;for(let u of await e.requests()){let p=u.resourceType(),h=u.url(),f=u.timing();a.has(p)&&!l(h)&&f.responseEnd===-1&&f.startTime>=d&&(i.add(u),n=Date.now())}w.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",s),e.on("response",c);try{let u=Date.now(),p=kd;for(;;){await new Promise(f=>setTimeout(f,100));let h=Date.now();if(i.size===0&&h-n>=p){w.debug(`[waitForStableNetwork] Network idle after ${h-u}ms`);break}if(h-u>t){w.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",s),e.removeListener("response",c)}}async function nt(e,t=_d,i=vd){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Ed(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 vd,_d,kd,Sd,Oe=x(()=>{"use strict";si();U();vd=.5*1e3,_d=30*1e3,kd=1*1e3,Sd=3*1e3});import{generateText as Td}from"ai";function Ad(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 Vr(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(),l=t.domService||new Ne(t.agentServices.getDomServiceOptions()),s={...t,domService:l};E.init(),E.section("Task Execution Started"),E.log(`Task: ${e}`),E.log(`Max steps: ${a}`),E.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],u=un(i.customPrompt),p=new mn(u);E.log(`System prompt length: ${u.length} chars`);let h=!1,f="",g=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let y=Date.now();E.section(`Step ${c.currentStep}/${a}`),E.log(`URL: ${s.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{E.log("Waiting for page to stabilize..."),await nt(s.page),E.log("Page stabilized")}catch{E.log("Page stabilization timed out, continuing anyway")}let m;try{E.log("Preparing context (DOM + screenshot)...");let N=s.agentServices.getInteractiveClassNames(),O=s.agentServices.getIframeFallbackDomains();m=await zr(s.page,s.domService,N,O),E.log("Context prepared")}catch(N){if(N.message.includes("Execution context was destroyed")){E.log("Page navigating, waiting for load..."),await nt(s.page);let O=s.agentServices.getInteractiveClassNames(),L=s.agentServices.getIframeFallbackDomains();m=await zr(s.page,s.domService,O,L)}else throw E.error("Error preparing context",N),N}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let b=await Md(p,r,i,m.screenshotBase64);if(b.tokenUsages&&b.tokenUsages.length>0&&d.push(...b.tokenUsages),!b.stepOutput){if(E.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let v=b.stepOutput;Nd(c.currentStep,a,v);let S=await Pd(v,s,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,b.debugInfo);g.push(...S.actionEntities);let T=Cd(c.currentStep,v,S,c,y,b.debugInfo,b.tokenUsages),M=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){E.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(S.doneResult){h=S.doneResult.success,f=S.doneResult.summary;break}if(S.completesInstruction){h=!0,f="Instruction completed";break}}return c.currentStep>=a&&!h&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),E.log(`Build success result: summary=${f}, completed=${h}, actions=${g.length}, tokens=${d.length}`),Od(c,g,h,f,n,d,r)}catch(y){let m=y.message;return E.error(`Task execution failed: ${m}`,y),i.onEvent?.({type:"error",error:m,recoverable:!1}),Ld(c,m,n,d,r)}}async function zr(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 $d(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 Md(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),l=0;for(let u of r)Array.isArray(u.content)&&(l+=u.content.filter(p=>p.type==="image").length);let s=we(t,l),c={model:fe(t),system:o,messages:r,temperature:a,providerOptions:s},d=3;for(let u=0;u<d;u++)try{let p=Date.now();E.log(`Calling LLM (${t})...`);let h=await Td(c),f=Date.now()-p,g=h,y=g.usage;E.llmCall(t,f,y);let m=g.reasoningText;m&&(E.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(h.text);let b={systemPrompt:o,userPrompt:$d(r),rawLlmResponse:h.text,reasoningContent:m,screenshotWithSom:n},v=[],S=Ad(y,t);S&&v.push(S);let T=Id(h.text);if(!T)if(u<d-1){E.log(`Attempt ${u+1}/${d}: 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(M=>setTimeout(M,i.retryDelay||1e3));continue}else return E.error("All parsing attempts failed"),{stepOutput:null,debugInfo:b,tokenUsages:v};return{stepOutput:T,debugInfo:b,tokenUsages:v}}catch(p){if(u<d-1){E.log(`Attempt ${u+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(h=>setTimeout(h,i.retryDelay||1e3));continue}else throw E.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Id(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 E.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return E.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return E.error("Action missing required field: action_name"),null;if(!n.description)return E.error("Action missing required field: description"),null}return i}catch(i){return E.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),E.error(`Parse error: ${i.message}`),null}}async function Pd(e,t,i,n,a,o,r){let l=[],s=!0,c=null;E.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,u={...t,domState:i},p=o;for(let h of e.actions){if(h.action_name==="done"){d={success:h.kwargs.success??!0,summary:h.kwargs.summary||h.kwargs.text||"Task completed"};break}let f={},g=h.kwargs?.element_index??h.kwargs?.index;if(typeof g=="number"){let m=i.selectorMap.get(g);m&&(f=await H(t.page,m))}let y={...f,action_description:h.description,action_data:{action_name:h.action_name,kwargs:h.kwargs}};try{let m=await j.execute(h.action_name,h.kwargs,u);h.action_name==="perform_accurate_operation"&&(y=m.actionEntity);let b=await u.agentServices.getCurrentPage();if(b&&(u.page=b,t.page=u.page),m?.success===!1){s=!1,E.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}l.push(y),a?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(m){s=!1,c=m.message,E.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:s,failReason:c,actionEntities:l,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Cd(e,t,i,n,a,o,r){let l={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 s=t.memory.trim();n.memory.includes(s)||(n.memory.push(s),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(l),l}function Nd(e,t,i){if(E.log(`Step ${e}/${t}`),i.thinking&&E.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&E.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&E.log(`Memory: ${i.memory}`),E.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];E.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else E.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{E.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Od(e,t,i,n,a,o,r){let l=o.reduce((d,u)=>d+u.prompt_tokens,0),s=o.reduce((d,u)=>d+u.completion_tokens,0),c=o.reduce((d,u)=>d+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(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:l,completionTokens:s,totalTokens:c,tokenUsages:o}}}function Ld(e,t,i,n,a){let o=n.reduce((s,c)=>s+c.prompt_tokens,0),r=n.reduce((s,c)=>s+c.completion_tokens,0),l=n.reduce((s,c)=>s+c.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(s=>s.outcome.success).length,failedSteps:e.stepHistory.filter(s=>!s.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:l,tokenUsages:n}}}var Xr=x(()=>{"use strict";la();hn();ke();We();ae();Oe();ye();X()});var Yr={};ut(Yr,{TaskMessageManager:()=>mn,formatFinalStepWarning:()=>Gr,formatTaskContext:()=>dn,getBrowserTaskJSONPrompt:()=>un,runTaskLoop:()=>Vr});var Jr=x(()=>{"use strict";Xr();la();hn();ke();Ki();We();xt();vt();Qe();_t();kt();ae();Oe();si();ye();ft();Ye();wt();Ce();Xe();X();Re();U();ne();Tt();W();ve()});async function At(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(j.has(i)){let a=await j.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 Dd()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Dd(){if(pn)return pn;let e=await Promise.resolve().then(()=>(cn(),ln));return pn=new e.default,pn}async function zi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Dn(r,o,n);return l.status==="error"?{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error,debugInfo:l.debugInfo}:{status:"success",completed:l.goalAccomplished||!1,actionEntities:l.actionEntity?[l.actionEntity]:[],explanation:l.reasoning,debugInfo:l.debugInfo}}async function Vi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Dn(r,o,n);if(l.status==="error"||!l.actionEntity)return{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error||"No action generated",debugInfo:l.debugInfo};let{actionEntity:s,reasoning:c,goalAccomplished:d,debugInfo:u}=l,p=await At(s,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[s],explanation:c,debugInfo:u}):{status:"error",completed:!1,actionEntities:[s],error:p.error||"Action execution failed",debugInfo:u}}async function Xi(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Ne(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),lo(o,a,n)}async function Yi(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(Jr(),Yr)),r=n?s=>{n(s)}:void 0,l=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:l.success?"success":"error",completed:l.completed,actionEntities:l.trajectory.actions,explanation:l.summary,error:l.error,tokenUsages:l.metadata.tokenUsages}}var pn,$t=x(()=>{"use strict";Li();ke();We();pn=null});import"uuid";import{z as _}from"zod";import"yaml";import"uuid";import"yaml";var ps,Dv,gs,Kd,zd,fn,Rv,Fv,fs,ws,Vd,ms,Xd,li,Yd,Jd,qd,le,Zd,Qd,jv,Qv,ci=x(()=>{"use strict";ve();ps=112,Dv=1080-ps,gs=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(gs||{}),Kd={"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"}},zd={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"]},fn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),zd[e].map(n=>Kd[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Rv={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile")}},Fv={desktop:{label:"Desktop",type:"desktop",devices:fn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:fn("mobile",!0)}},fs=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(fs||{}),ws=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(ws||{}),Vd=_.enum(["JS_CODE","AI_MODE"]),ms=_.object({type:Vd,expression:_.string()}),Xd=_.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),li=_.object({uid:_.string(),type:Xd,comment:_.string().optional()}),Yd=_.object({action_data:_.object({action_name:_.string(),kwargs:_.record(_.any()).optional(),args:_.array(_.any()).optional()}),action_description:_.string().optional(),url:_.string().optional(),xpath:_.string().nullable().optional(),locator:_.string().nullable().optional(),css_selector:_.string().nullable().optional(),unique_selector:_.string().nullable().optional(),element_index:_.number().nullable().optional(),frame_path:_.array(_.any()).optional(),artifacts:_.record(_.any()).optional(),feedback:_.string().optional(),original_browser_use_action:_.any().optional()}).passthrough(),Jd=li.extend({type:_.literal("DRAFT"),description:_.string()}),qd=li.extend({type:_.literal("ACTION"),description:_.string(),action_entity:Yd.optional(),locator:_.string().optional(),use_pure_vision:_.boolean().optional()}),le=_.lazy(()=>_.union([Jd,qd,li.extend({type:_.literal("STEP"),description:_.string().optional().default(""),statements:_.array(le),reference_id:_.number().optional(),template_path:_.string().optional(),template_params:_.record(_.string()).optional()}),li.extend({type:_.literal("IF_ELSE"),description:_.string().optional(),condition:ms,then:_.array(le),else:_.array(le).optional()}),li.extend({type:_.literal("WHILE_LOOP"),description:_.string().optional(),condition:ms,body:_.array(le),timeout_ms:_.number().optional()})])),Zd=_.object({name:_.string(),statements:_.array(le),teardown:_.array(le).optional(),skip:_.union([_.boolean(),_.string()]).optional(),timeout:_.number().optional(),fail:_.union([_.boolean(),_.string()]).optional(),only:_.boolean().optional(),slow:_.boolean().optional()}),Qd=_.object({tests:_.array(Zd).min(1),beforeAll:_.array(le).optional(),afterAll:_.array(le).optional(),beforeEach:_.array(le).optional(),afterEach:_.array(le).optional()}),jv=_.object({comment:_.string().optional(),version:_.string().optional(),goal:_.string().optional(),url:_.string().optional(),baseURL:_.string().optional(),final_feedback:_.string().optional(),completed:_.boolean().optional(),success:_.boolean().optional(),statements:_.array(le).optional(),teardown:_.array(le).optional(),last_modified_at:_.string().optional(),testGroup:Qd.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"}),Qv=1024*1024});var da=x(()=>{"use strict";ae();Oe()});var _s=x(()=>{"use strict"});var ks=x(()=>{"use strict"});var Ss=x(()=>{"use strict"});var wn=x(()=>{"use strict"});var Es=x(()=>{"use strict";wn()});import{v4 as eE}from"uuid";var Ts=x(()=>{"use strict"});import{z as k}from"zod";var As,ha,$s,ot,Ms,Is,Ps,re,Cs,yn,ma,pa=x(()=>{"use strict";As=k.enum(["JS_CODE","AI_MODE"]),ha=k.object({type:As,expression:k.string()}),$s=k.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ot=k.object({uid:k.string(),type:$s,comment:k.string().optional()}),Ms=k.object({action_data:k.object({action_name:k.string(),kwargs:k.record(k.any()).optional(),args:k.array(k.any()).optional()}),action_description:k.string().optional(),url:k.string().optional(),xpath:k.string().nullable().optional(),locator:k.string().nullable().optional(),css_selector:k.string().nullable().optional(),unique_selector:k.string().nullable().optional(),element_index:k.number().nullable().optional(),frame_path:k.array(k.any()).optional(),artifacts:k.record(k.any()).optional(),feedback:k.string().optional(),original_browser_use_action:k.any().optional()}).passthrough(),Is=ot.extend({type:k.literal("DRAFT"),description:k.string()}),Ps=ot.extend({type:k.literal("ACTION"),description:k.string(),action_entity:Ms.optional(),locator:k.string().optional(),use_pure_vision:k.boolean().optional()}),re=k.lazy(()=>k.union([Is,Ps,ot.extend({type:k.literal("STEP"),description:k.string().optional().default(""),statements:k.array(re),reference_id:k.number().optional(),template_path:k.string().optional(),template_params:k.record(k.string()).optional()}),ot.extend({type:k.literal("IF_ELSE"),description:k.string().optional(),condition:ha,then:k.array(re),else:k.array(re).optional()}),ot.extend({type:k.literal("WHILE_LOOP"),description:k.string().optional(),condition:ha,body:k.array(re),timeout_ms:k.number().optional()})])),Cs=k.object({name:k.string(),statements:k.array(re),teardown:k.array(re).optional(),skip:k.union([k.boolean(),k.string()]).optional(),timeout:k.number().optional(),fail:k.union([k.boolean(),k.string()]).optional(),only:k.boolean().optional(),slow:k.boolean().optional()}),yn=k.object({tests:k.array(Cs).min(1),beforeAll:k.array(re).optional(),afterAll:k.array(re).optional(),beforeEach:k.array(re).optional(),afterEach:k.array(re).optional()}),ma=k.object({comment:k.string().optional(),version:k.string().optional(),goal:k.string().optional(),url:k.string().optional(),baseURL:k.string().optional(),final_feedback:k.string().optional(),completed:k.boolean().optional(),success:k.boolean().optional(),statements:k.array(re).optional(),teardown:k.array(re).optional(),last_modified_at:k.string().optional(),testGroup:yn.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});import{stringify as rE,parse as Ds,parseAllDocuments as sE,parseDocument as fu,Document as Rs,isMap as st,isSeq as se}from"yaml";import{v4 as me}from"uuid";function bn(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},...t?.tags&&t.tags.length>0?{tags:t.tags}:{},...t?.skip!==void 0?{skip:t.skip}:{},...t?.fail!==void 0?{fail:t.fail}:{},...t?.only?{only:t.only}:{},...t?.slow?{slow:t.slow}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},...t?.use&&Object.keys(t.use).length>0?{use:t.use}:{},...t?.beforeEach&&t.beforeEach.length>0?{beforeEach:t.beforeEach}:{},...t?.afterEach&&t.afterEach.length>0?{afterEach:t.afterEach}:{},...t?.parameters&&t.parameters.length>0?{parameters:t.parameters}:{},statements:(e.statements??[]).map(ce)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(ce)),i}function fa(e,t){if(e.testGroup)return Hs(e,t);let i=bn(e,t),n=new Rs(i),a=n.contents?.get("tags",!0);return se(a)&&(a.flow=!0),e.comment&&(n.commentBefore=e.comment),Ns(n,e.statements??[]),e.teardown&&Ns(n,e.teardown,"teardown"),n.toString(Fs)}function Ns(e,t,i="statements"){let n=e.contents;if(!n||!st(n))return;let a=n.get(i,!0);se(a)&&hi(a,t)}function hi(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),st(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);se(r)&&hi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);se(r)&&hi(r,n.then);let l=o.get("ELSE",!0);se(l)&&n.else&&hi(l,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);se(r)&&hi(r,n.body)}}}}function Hs(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let a={};e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(ce)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(ce)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(ce)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(ce)),a.tests=i.tests.map(l=>{let s={name:l.name};return l.skip!==void 0&&(s.skip=l.skip),l.timeout!==void 0&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only!==void 0&&(s.only=l.only),l.slow!==void 0&&(s.slow=l.slow),s.statements=l.statements.map(ce),l.teardown&&l.teardown.length>0&&(s.teardown=l.teardown.map(ce)),s}),n.suite=a;let o=new Rs(n),r=o.contents?.get("tags",!0);return se(r)&&(r.flow=!0),o.toString(Fs)}function ce(e){switch(e.type){case"DRAFT":return wu(e);case"ACTION":return yu(e);case"STEP":return bu(e);case"IF_ELSE":return xu(e);case"WHILE_LOOP":return vu(e)}}function wu(e){return{intent:e.description}}function yu(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 l=i?.statement;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s=i?.code;return typeof s=="string"&&s.trim()?{VERIFY:l,js:s}:{VERIFY:l}}}if(t==="go_to_url"){let l=i?.url;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s={URL:l};return i?.new_tab===!0&&(s.new_tab=!0),typeof i?.timeout_seconds=="number"&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="js_action"){let l=i?.code;if(typeof l=="string"&&l.trim()&&e.description)return{description:e.description,js:l}}if(t==="ai_wait_until"){let l=i?.condition;if(typeof l=="string"){let s={WAIT_UNTIL:l};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="wait"){let l=i?.seconds,c={WAIT:e.description||`Wait ${l}s`};return typeof l=="number"&&(c.seconds=l),c}if(t==="js_code"){let l=i?.code;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{description:e.description||"Code block",js:l}}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[l,s]of Object.entries(n.kwargs))l!=="uid"&&(l==="statement"&&(t==="ai_action"||t==="ai_step")||(a[l]=s));return n.args&&n.args.length>0&&(a.args=n.args),a}function bu(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(ce)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function xu(e){let t={IF:Ws(e.condition),THEN:e.then.map(ce)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(ce)),t}function vu(e){let t={WHILE:Ws(e.condition),DO:e.body.map(ce)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Ws(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function wa(e){try{let t=Ds(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),t.use&&typeof t.use=="object"&&!Array.isArray(t.use)&&(i.use=t.use),Array.isArray(t.tags)&&t.tags.every(n=>typeof n=="string")&&(i.tags=t.tags),(typeof t.skip=="boolean"||typeof t.skip=="string")&&(i.skip=t.skip),(typeof t.fail=="boolean"||typeof t.fail=="string")&&(i.fail=t.fail),t.only===!0&&(i.only=!0),t.slow===!0&&(i.slow=!0),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(i.beforeEach=t.beforeEach),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(i.afterEach=t.afterEach),Array.isArray(t.parameters)&&t.parameters.length>0&&(i.parameters=t.parameters),i}catch{return{}}}function ga(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(ga);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]=ga(o);return n}function Te(e){if(e.length>Os)throw new Error(`YAML input too large (${e.length} bytes, max ${Os})`);let t=ga(Ds(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return _u(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:de(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=de(t.teardown));let n=ma.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return xn(e,a),a}function _u(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(l=>{if(!l.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(l.statements)||l.statements.length===0)throw new Error(`Suite test "${l.name}" must have a non-empty "statements" array`);let s={name:l.name,statements:de(l.statements)};return Array.isArray(l.teardown)&&l.teardown.length>0&&(s.teardown=de(l.teardown)),l.skip!==void 0&&(s.skip=l.skip),typeof l.timeout=="number"&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only===!0&&(s.only=!0),l.slow===!0&&(s.slow=!0),s})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=de(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=de(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=de(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=de(t.afterEach));let o=yn.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 de(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(ku)}function ku(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 Su(t);if("WHILE"in t)return Eu(t);if("STEP"in t)return Tu(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:me(),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:me(),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:me(),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:me(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');let n=typeof t.description=="string"?t.description:"Code block";return{uid:me(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&!("VERIFY"in t)&&!("action"in t)){if("intent"in t||"desc"in t)throw new Error("A `js:` statement uses `description:`, not `intent:`. Raw JS does not self-heal \u2014 use `description: + js:` for code, or express it as a structured action (`intent:` + `action:`/`locator:`) to keep self-healing.");let i=typeof t.description=="string"&&t.description.trim()!==""?t.description:"Code block",n=t.js;return{uid:me(),type:"ACTION",description:i,action_entity:{action_description:i,action_data:{action_name:"js_code",kwargs:{code:typeof n=="string"?n:String(n)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return Ls({...n,action:"function",functionName:i})}if("action"in t)return Ls(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:me(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Us(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 Su(e){let t=Us(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:me(),type:"IF_ELSE",condition:t,then:de(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=de(e.ELSE)),n}function Eu(e){let t=Us(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:me(),type:"WHILE_LOOP",condition:t,body:de(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Tu(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:me(),type:"STEP",description:t,statements:de(e.statements)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,a={};for(let[o,r]of Object.entries(n))a[o]=String(r);i.template_params=a}return i}function Ls(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[c,d]of Object.entries(e))Au.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js),(t==="ai_action"||t==="ai_step")&&r.statement===void 0&&(r.statement=i);let l={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(l.locator=n),a&&(l.xpath=a);let s={uid:me(),type:"ACTION",description:i,action_entity:l};return o&&(s.use_pure_vision=!0),s}function xn(e,t){let i;try{i=fu(e)}catch{return}let n=i.contents;if(!n||!st(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let s=n.items?.[0];s?.key&&s.key.commentBefore&&(t.comment=s.key.commentBefore)}let a=n,o=a.get("statements",!0);se(o)&&t.statements&&rt(o,t.statements);let r=a.get("teardown",!0);se(r)&&t.teardown&&rt(r,t.teardown)}function rt(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let a=t[i];if(a.type==="STEP"&&st(n)){let o=n.get("statements",!0);se(o)&&rt(o,a.statements)}else if(a.type==="IF_ELSE"&&st(n)){let o=n.get("THEN",!0);se(o)&&rt(o,a.then);let r=n.get("ELSE",!0);se(r)&&a.else&&rt(r,a.else)}else if(a.type==="WHILE_LOOP"&&st(n)){let o=n.get("DO",!0);se(o)&&rt(o,a.body)}}}var Fs,Os,Au,vn=x(()=>{"use strict";pa();Fs={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Os=1024*1024;Au=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});import{parse as hE,stringify as mE}from"yaml";var js=x(()=>{"use strict";vn()});var Bs=x(()=>{"use strict";wn();vn()});var je,Gs=x(()=>{"use strict";je=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(je||{})});var _n=x(()=>{"use strict"});var Ks=x(()=>{"use strict";_n()});var zs=x(()=>{"use strict";_n()});var Vs,Pu,Xs,Ys,mi,Cu,Nu,Js=x(()=>{"use strict";Vs=112,Pu=1080-Vs,Xs={"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"}},Ys={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"]},mi=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Ys[e].map(n=>Xs[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Cu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile")}},Nu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile",!0)}}});var qs=x(()=>{"use strict"});var Zs=x(()=>{"use strict"});var Qs=x(()=>{"use strict"});var el=x(()=>{"use strict"});var lt=x(()=>{"use strict";_s();ks();Ss();Es();Ts();js();Bs();wn();vn();Gs();pa();Ks();zs();_n();Js();qs();Zs();Qs();el()});import{stringify as C1}from"yaml";import{createHash as Fu}from"crypto";import{parse as Hu,stringify as rl}from"yaml";import{readFileSync as Wu,existsSync as Uu}from"fs";import{resolve as ya,dirname as ju}from"path";import{parse as il,stringify as Bu}from"yaml";function Du(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ru(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 ol(e){let t=Du(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ru(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){te.set(e,t)}function Be(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 ba(e,t){let i=t.action_data?.kwargs||{},n=[];return typeof i.relative_x=="number"&&typeof i.relative_y=="number"?(n.push(`action_data: { kwargs: { relative_x: ${i.relative_x}, relative_y: ${i.relative_y} } }`),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)}`)):typeof i.x=="number"&&typeof i.y=="number"&&n.push(`action_data: { kwargs: { x: ${i.x}, y: ${i.y} } }`),[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function tl(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 sl(e,t,i){let n={expandingPaths:new Set([ya(t)]),depth:0,referencedPaths:new Set,basePath:i},a={...e};Array.isArray(a.statements)&&(a.statements=Le(a.statements,t,n)),Array.isArray(a.teardown)&&(a.teardown=Le(a.teardown,t,n));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(a[o])&&(a[o]=Le(a[o],t,n));return{doc:a,referencedTemplatePaths:Array.from(n.referencedPaths)}}function Le(e,t,i){let n=[];for(let a of e)if(Gu(a)){let o=Ku(a,t,i);n.push(o)}else n.push(zu(a,t,i));return n}function Gu(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function Ku(e,t,i){if(i.depth>=nl)throw new Error(`Template expansion exceeded maximum depth of ${nl}. Check for deeply nested or circular template references.`);let n=ya(ju(t),e.template),a=!Uu(n)&&i.basePath?ya(i.basePath,e.template):n;if(i.expandingPaths.has(a))throw new Error(`Circular template reference detected: ${a} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${a}`);i.referencedPaths.add(a);let o;try{o=Wu(a,"utf-8")}catch(f){throw new Error(`Failed to read template file: ${a} (referenced from ${t}): ${f.message}`)}let r=il(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${a} \u2014 expected a YAML object`);let l=r.params||[],s=e.params||{};for(let f of l)if(!(f in s))throw new Error(`Template ${e.template} requires param "${f}" but it was not provided. Required params: [${l.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let g=Bu(c);for(let[y,m]of Object.entries(s))g=g.split(`<<${y}>>`).join(String(m));c=il(g)}let d={expandingPaths:new Set([...i.expandingPaths,a]),depth:i.depth+1,referencedPaths:i.referencedPaths},u=Le(c,a,d),h={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:u};return Object.keys(s).length>0&&(h.template_params=s),h}function zu(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Le(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Le(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Le(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Le(n.DO,t,i)),n}function cl(e,t,i){let n=Hu(e),a=n?.name,o=n?.tags,r=n?.use;if(n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use),n?.suite){if(n.goal||n.statements)throw new ll('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Xu(n,a,o,r,t,i)}return Vu(n,a,o,r,t,i)}function Vu(e,t,i,n,a,o){let r=e?.beforeEach,l=e?.afterEach,s=dl(e?.parameters),c=e?.timeout,d=e?.skip,u=e?.fail,p=e?.only,h=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 ll(`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 m=sl(e,a,o);e=m.doc,f=m.referencedTemplatePaths}let g=rl(e),y=Te(g);return a&&(ct(y.statements??[],a,"main"),y.teardown&&ct(y.teardown,a,"teardown")),{testFlow:y,name:t,tags:i,use:n,beforeEach:r,afterEach:l,parameters:s,timeout:c,skip:d,fail:u,only:p,slow:h,referencedTemplatePaths:f}}function Xu(e,t,i,n,a,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let l=r.beforeAll,s=r.afterAll,c=r.beforeEach,d=r.afterEach,u=[],p=r.tests.map(g=>{if(!g.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(g.statements)||g.statements.length===0)throw new Error(`Suite test "${g.name}" must have a non-empty "statements" array.`);let y={goal:g.name,statements:g.statements};g.teardown&&(y.teardown=g.teardown);let m=[],b=y;if(a&&typeof y=="object"){let M=sl(y,a,o);b=M.doc,m=M.referencedTemplatePaths,u.push(...m)}let v=rl(b),S=Te(v),T=dl(g.parameters);return{testFlow:S,name:g.name,tags:Array.isArray(g.tags)?g.tags:void 0,parameters:T,timeout:g.timeout,skip:g.skip,fail:g.fail,only:g.only,slow:g.slow}}),h=r.base_url,f=h?{...n,baseURL:h}:n;return{suite:{beforeAll:l,afterAll:s,beforeEach:c,afterEach:d,tests:p},name:t,tags:i,use:f,referencedTemplatePaths:u}}function dl(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 ct(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Yu(t,o,r),a.type===je.STEP)ct(a.statements,t,o);else if(a.type===je.IF_ELSE){let l=a;ct(l.then,t,`${o}.then`),l.else&&ct(l.else,t,`${o}.else`)}else a.type===je.WHILE_LOOP&&ct(a.body,t,`${o}.body`)}}function Yu(e,t,i){let n=Fu("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 al,te,nl,ll,ul=x(()=>{"use strict";lt();lt();lt();lt();al=5e3;te=new Map;$("click",e=>{let t=ol(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??al;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",te.get("click"));$("click_element_by_index",te.get("click"));$("double_click",e=>Be("double_click",e));$("double_click_on_element",te.get("double_click"));$("right_click",e=>Be("right_click",e));$("right_click_on_element",te.get("right_click"));$("hover",e=>Be("hover",e));$("hover_element_by_index",te.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Be("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",te.get("input_text"));$("clear_input",e=>Be("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",te.get("press"));$("send_keys_on_element",e=>{let t=ol(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??al;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Be("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",te.get("scroll"));$("scroll_up",te.get("scroll"));$("scroll_element",te.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Be("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",te.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
4302
4302
  `),l=JSON.stringify(a);return["{ const _t = Date.now(); try {",...r.map(s=>` ${s}`),` 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}, ${JSON.stringify(t||"")});`,"} }"]}return n?i.code.split(`
4303
4303
  `):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",te.get("verify"));$("assert",te.get("verify"));$("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]});$("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});$("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4304
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,l]=a.split("#");if(r&&l){let s=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${l} } from '${s}';`;i?.imports?.add(c);let d={...n,functionName:l},u=el(d);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=el(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]});$("done",()=>["// Done - no action needed"]);$("click_by_coordinates",e=>ya("click_by_coordinates",e));$("right_click_by_coordinates",e=>ya("right_click_by_coordinates",e));$("double_click_by_coordinates",e=>ya("double_click_by_coordinates",e));$("drag_drop",e=>{let t=e.action_data?.kwargs||{},i={};typeof t.relative_x=="number"&&(i.relative_x=t.relative_x),typeof t.relative_y=="number"&&(i.relative_y=t.relative_y),typeof t.delta_x=="number"&&(i.delta_x=t.delta_x),typeof t.delta_y=="number"&&(i.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(i.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(i.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(i.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(i.coord_target_y=t.coord_target_y);let n=[`action_data: { kwargs: ${JSON.stringify(i)} }`];return e.locator?n.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&n.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...n.map(a=>` ${a},`),"});"]});$("get_dropdown_options",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},`),"});"]});$("extract_email_content",e=>{let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]});$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4305
- `):["// Skipping js_action: missing code"]});il=5;sl=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var hl={};dt(hl,{createTestFlowRouter:()=>qu});import{Router as Yu}from"express";import*as C from"fs/promises";import*as P from"path";import{stringify as fi,parse as ct}from"yaml";function pi(e){return e.map(t=>{if(t.type==="ACTION"&&t.action_entity){let i=t.action_entity,n=i.action_data??i.action,a=n?.kwargs?Object.fromEntries(Object.entries(n.kwargs).filter(([r])=>r!=="element_index")):n?.kwargs,o={...i};if(delete o.xpath,n&&a!==void 0){let r={...n,kwargs:a};i.action_data?o.action_data=r:o.action=r}return{...t,action_entity:o}}return t.type==="STEP"?{...t,statements:pi(t.statements)}:t.type==="IF_ELSE"?{...t,then:pi(t.then),...t.else?{else:pi(t.else)}:{}}:t.type==="WHILE_LOOP"?{...t,body:pi(t.body)}:t})}function Be(e){if(!e||e.length===0)return[];let i=fi({goal:"_hook",statements:e});return Te(i).statements??[]}async function ul(e){try{let t=await C.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 ul(P.join(e,i.name))))return!0}catch{}return!1}function kn(e){let t=2166136261;for(let i=0;i<e.length;i++)t^=e.charCodeAt(i),t=Math.imul(t,16777619)>>>0;return t%2147483647+1}async function Ju(e){let t=new Map,i;try{i=await C.readdir(e)}catch(n){if(n.code==="ENOENT")return t;throw n}for(let n of i.filter(a=>a.endsWith(".yaml")))try{let a=P.join(e,n),r=ct(await C.readFile(a,"utf-8"))?.name??P.basename(n,".yaml");t.set(kn(r),`templates/${n}`)}catch{}return t}function ba(e,t){if(Array.isArray(e))return e.map(o=>ba(o,t));if(!e||typeof e!="object")return e;let i=e,n={};for(let[o,r]of Object.entries(i))n[o]=ba(r,t);let a=typeof i.reference_id=="number"?i.reference_id:void 0;if(a!==void 0&&typeof n.template_path!="string"){let o=t.get(a);o&&(n.template_path=o,delete n.reference_id)}return n}function Sn(e){return yn({statements:e}).statements}async function gi(e,t){for(let i of e)if(i.type==="STEP"){if(i.template_path&&i.statements.length>0){let n=P.join(t,i.template_path);try{let a=ct(await C.readFile(n,"utf-8"))??{};a.statements=Sn(i.statements),await C.writeFile(n,fi(a),"utf-8")}catch{}}await gi(i.statements,t)}else i.type==="IF_ELSE"?(await gi(i.then,t),i.else&&await gi(i.else,t)):i.type==="WHILE_LOOP"&&await gi(i.body,t)}function qu(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=Yu();function r(){return P.join(n??t,"fixtures")}o.get("/api/files",async(s,c)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,u=P.resolve(d),p=await C.readdir(u,{withFileTypes:!0}),h=[];for(let g of p)if(g.name!=="node_modules"&&!g.name.startsWith("."))if(g.isDirectory()){let y=P.join(u,g.name);await ul(y)&&h.push({name:g.name,type:"directory",path:y})}else g.isFile()&&g.name.endsWith(".test.yaml")&&h.push({name:g.name,type:"file",path:P.join(u,g.name)});h.sort((g,y)=>g.type!==y.type?g.type==="directory"?-1:1:g.name.localeCompare(y.name));let f=P.dirname(u);c.json({dir:u,parent:f!==u?f:null,entries:h,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),c.status(500).json({error:d.message})}});function l(s){if(typeof s=="string"&&s){let c=P.resolve(s);return c.endsWith(".test.yaml")?{filePath:c}:{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,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath;try{a?.(u);let p=await C.readFile(u,"utf-8"),h=await C.stat(u),f=fa(p),g=ll(p,u,n);if(g.suite){let y=g.suite,m={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:Be(y.beforeAll),afterAll:Be(y.afterAll),beforeEach:Be(y.beforeEach),afterEach:Be(y.afterEach)},b={version:"1.3.0",baseURL:g.use?.baseURL,testGroup:m};c.json({isSuite:!0,testFlow:b,metadata:f,name:g.name,tags:g.tags,use:g.use,filePath:u,fileName:P.basename(u),lastModified:h.mtimeMs})}else{let y=g.testFlow;bn(p,y),c.json({isSuite:!1,testFlow:y,metadata:f,name:g.name,tags:g.tags,use:g.use,parameters:g.parameters,filePath:u,fileName:P.basename(u),lastModified:h.mtimeMs})}}catch(p){if(p.code==="ENOENT")return c.status(404).json({error:`File not found: ${u}`});console.error("[debugger] Error loading test flow:",p),c.status(500).json({error:p.message})}}),o.put("/api/test-flow",async(s,c)=>{try{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath,{testFlow:p,metadata:h}=s.body;if(!p)return c.status(400).json({error:"testFlow is required"});let f=P.join(n??t,"templates"),g=await Ju(f),y=ba(p,g),m=pi(y.statements??[]),b={...y,statements:m},v=n??t,S=[b.statements??[],b.teardown??[],...b.testGroup?.tests?.flatMap(O=>[O.statements,...O.teardown?[O.teardown]:[]])??[],...b.testGroup?.beforeEach?[b.testGroup.beforeEach]:[],...b.testGroup?.afterEach?[b.testGroup.afterEach]:[]];for(let O of S)await gi(O,v);let T=ga(b,h),M=u+".tmp";await C.writeFile(M,T,"utf-8"),await C.rename(M,u);let N=await C.stat(u);c.json({success:!0,lastModified:N.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),c.status(500).json({error:d.message})}}),o.get("/api/fixtures",async(s,c)=>{try{let d=r();try{let p=(await C.readdir(d,{withFileTypes:!0})).filter(h=>h.isFile()).map(h=>h.name).sort();c.json({files:p,dir:d})}catch(u){if(u.code==="ENOENT")c.json({files:[],dir:d});else throw u}}catch(d){console.error("[debugger] Error listing fixtures:",d),c.status(500).json({error:d.message})}}),o.post("/api/fixtures",async(s,c)=>{try{let d=r();await C.mkdir(d,{recursive:!0});let{name:u,content:p}=s.body;if(!u||!p)return c.status(400).json({error:"name and content are required"});let h=P.basename(u);if(!h)return c.status(400).json({error:"Invalid file name"});let f=P.join(d,h);await C.writeFile(f,Buffer.from(p,"base64")),c.json({fileName:h})}catch(d){console.error("[debugger] Error saving fixture:",d),c.status(500).json({error:d.message})}}),o.get("/api/functions",async(s,c)=>{let d=P.join(n??t,"helpers"),u;try{u=await C.readdir(d)}catch(g){return g.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading helpers dir:",g),c.status(500).json({error:g.message}))}let p=u.filter(g=>/\.(ts|js|mjs)$/.test(g)),h=[],f=1;for(let g of p){let y=await C.readFile(P.join(d,g),"utf-8"),m=/export\s+async\s+function\s+(\w+)\s*(\([^)]*\))/g,b;for(;(b=m.exec(y))!==null;){let[,v,S]=b,T=S.replace(/\s*:\s*[^,)]+/g,"");h.push({id:f++,name:`helpers/${g}#${v}`,description:"",status:"Active",code:`async function ${v}${T} {}`})}}c.json(h)}),o.get("/api/reusable-steps",async(s,c)=>{let d=P.join(n??t,"templates"),u;try{u=await C.readdir(d)}catch(f){return f.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading templates dir:",f),c.status(500).json({error:f.message}))}let p=u.filter(f=>f.endsWith(".yaml")).sort(),h=[];for(let f of p)try{let g=await C.readFile(P.join(d,f),"utf-8"),y=ct(g);if(!y||typeof y!="object")continue;let m=y.name??P.basename(f,".yaml"),b=y.description??"",v=Be(y.statements);h.push({id:kn(m),organizationId:"local",name:m,description:b,statements:v})}catch(g){console.error(`[debugger] Error parsing template ${f}:`,g)}c.json(h)}),o.post("/api/reusable-steps/exists/:name",async(s,c)=>{let d=P.join(n??t,"templates"),u=decodeURIComponent(s.params.name).toLowerCase(),p;try{p=await C.readdir(d)}catch(h){return h.code==="ENOENT"?c.json(!1):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=await C.readFile(P.join(d,h),"utf-8");if((ct(f)?.name??P.basename(h,".yaml")).toLowerCase()===u)return c.json(!0)}catch{}c.json(!1)}),o.post("/api/reusable-steps",async(s,c)=>{let d=P.join(n??t,"templates"),{reusableStep:u}=s.body??{};if(!u?.name||!Array.isArray(u.statements))return c.status(400).json({error:"reusableStep.name and reusableStep.statements are required"});await C.mkdir(d,{recursive:!0});let p=u.name.replace(/[/\\:*?"<>|]/g,"-").trim(),h=P.join(d,`${p}.yaml`),f={name:u.name,statements:Sn(u.statements)};u.description&&(f.description=u.description),await C.writeFile(h,fi(f),"utf-8"),c.json({id:kn(u.name),organizationId:"local",name:u.name,description:u.description??"",statements:u.statements})}),o.put("/api/reusable-steps/:id/update",async(s,c)=>{let d=parseInt(s.params.id,10),u=P.join(n??t,"templates"),p;try{p=await C.readdir(u)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=P.join(u,h),g=ct(await C.readFile(f,"utf-8"))??{},y=g.name??P.basename(h,".yaml");if(kn(y)!==d)continue;let m=s.body??{};return m.description!==void 0&&(g.description=m.description),m.statements!==void 0&&(g.statements=Sn(m.statements)),await C.writeFile(f,fi(g),"utf-8"),c.json({id:d,organizationId:"local",...g,statements:m.statements!==void 0?m.statements:Be(g.statements)})}catch{}c.status(404).json({error:`Template with id ${d} not found`})}),o.put("/api/templates/:name",async(s,c)=>{let d=P.join(n??t,"templates"),u=decodeURIComponent(s.params.name),p;try{p=await C.readdir(d)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=P.join(d,h),g=ct(await C.readFile(f,"utf-8"))??{};if((g.name??P.basename(h,".yaml"))!==u)continue;let m=s.body??{};return m.name!==void 0&&(g.name=m.name),m.description!==void 0&&(g.description=m.description),m.statements!==void 0&&(g.statements=Sn(m.statements)),await C.writeFile(f,fi(g),"utf-8"),c.json({organizationId:"local",...g,statements:m.statements!==void 0?m.statements:Be(g.statements)})}catch{}c.status(404).json({error:`Template "${u}" not found`})}),o.get("/api/test-results",async(s,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=n??t,p=P.basename(d.filePath,".test.yaml"),h=P.join(u,".shiplight","artifacts",p),f=[],g=null;try{let y=await C.readdir(h,{withFileTypes:!0});for(let m of y)if(m.isDirectory()){let b=P.join(h,m.name),v=await C.readdir(b);for(let S of v.filter(T=>/\.(png|jpe?g|webp)$/i.test(T))){let T=P.relative(h,P.join(b,S)),M=m.name.match(/^(.+?)_(before|after)$/),N=M?M[1]:m.name,O=M?M[2]:"screenshot";f.push({url:`/api/report-assets/${p}/${T}`,label:O,stepId:N})}}else/\.(webm|mp4)$/i.test(m.name)&&(g||(g=`/api/report-assets/${p}/${m.name}`));f.sort((m,b)=>m.stepId!==b.stepId?(m.stepId??"").localeCompare(b.stepId??""):m.label.localeCompare(b.label))}catch{}if(f.length===0&&!g)return c.status(404).json({error:"No test results found"});c.json({videoPath:g,screenshots:f})}),o}var ml=x(()=>{"use strict";st();dl()});var pl={};dt(pl,{createIntRunnerRouter:()=>Qu});import{Router as Zu}from"express";function Qu(e){let t=Zu();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:l,stmtUid:s,executionHistory:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let d=await e.executeAction(a.sessionId,o,r,{withSelfHealing:l,stmtUid:s,executionHistory:c});n.json(d)}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: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 s=c=>{n.write(`data: ${JSON.stringify(c)}
4304
+ `);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,l]=a.split("#");if(r&&l){let s=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${l} } from '${s}';`;i?.imports?.add(c);let d={...n,functionName:l},u=tl(d);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=tl(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]});$("done",()=>["// Done - no action needed"]);$("click_by_coordinates",e=>ba("click_by_coordinates",e));$("right_click_by_coordinates",e=>ba("right_click_by_coordinates",e));$("double_click_by_coordinates",e=>ba("double_click_by_coordinates",e));$("drag_drop",e=>{let t=e.action_data?.kwargs||{},i={};typeof t.relative_x=="number"&&(i.relative_x=t.relative_x),typeof t.relative_y=="number"&&(i.relative_y=t.relative_y),typeof t.delta_x=="number"&&(i.delta_x=t.delta_x),typeof t.delta_y=="number"&&(i.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(i.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(i.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(i.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(i.coord_target_y=t.coord_target_y);let n=[`action_data: { kwargs: ${JSON.stringify(i)} }`];return e.locator?n.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&n.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...n.map(a=>` ${a},`),"});"]});$("get_dropdown_options",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},`),"});"]});$("extract_email_content",e=>{let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]});$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
4305
+ `):["// Skipping js_action: missing code"]});nl=5;ll=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var ml={};ut(ml,{createTestFlowRouter:()=>Zu});import{Router as Ju}from"express";import*as C from"fs/promises";import*as P from"path";import{stringify as fi,parse as dt}from"yaml";function pi(e){return e.map(t=>{if(t.type==="ACTION"&&t.action_entity){let i=t.action_entity,n=i.action_data??i.action,a=n?.kwargs?Object.fromEntries(Object.entries(n.kwargs).filter(([r])=>r!=="element_index")):n?.kwargs,o={...i};if(delete o.xpath,n&&a!==void 0){let r={...n,kwargs:a};i.action_data?o.action_data=r:o.action=r}return{...t,action_entity:o}}return t.type==="STEP"?{...t,statements:pi(t.statements)}:t.type==="IF_ELSE"?{...t,then:pi(t.then),...t.else?{else:pi(t.else)}:{}}:t.type==="WHILE_LOOP"?{...t,body:pi(t.body)}:t})}function Ge(e){if(!e||e.length===0)return[];let i=fi({goal:"_hook",statements:e});return Te(i).statements??[]}async function hl(e){try{let t=await C.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 hl(P.join(e,i.name))))return!0}catch{}return!1}function kn(e){let t=2166136261;for(let i=0;i<e.length;i++)t^=e.charCodeAt(i),t=Math.imul(t,16777619)>>>0;return t%2147483647+1}async function qu(e){let t=new Map,i;try{i=await C.readdir(e)}catch(n){if(n.code==="ENOENT")return t;throw n}for(let n of i.filter(a=>a.endsWith(".yaml")))try{let a=P.join(e,n),r=dt(await C.readFile(a,"utf-8"))?.name??P.basename(n,".yaml");t.set(kn(r),`templates/${n}`)}catch{}return t}function xa(e,t){if(Array.isArray(e))return e.map(o=>xa(o,t));if(!e||typeof e!="object")return e;let i=e,n={};for(let[o,r]of Object.entries(i))n[o]=xa(r,t);let a=typeof i.reference_id=="number"?i.reference_id:void 0;if(a!==void 0&&typeof n.template_path!="string"){let o=t.get(a);o&&(n.template_path=o,delete n.reference_id)}return n}function Sn(e){return bn({statements:e}).statements}async function gi(e,t){for(let i of e)if(i.type==="STEP"){if(i.template_path&&i.statements.length>0){let n=P.join(t,i.template_path);try{let a=dt(await C.readFile(n,"utf-8"))??{};a.statements=Sn(i.statements),await C.writeFile(n,fi(a),"utf-8")}catch{}}await gi(i.statements,t)}else i.type==="IF_ELSE"?(await gi(i.then,t),i.else&&await gi(i.else,t)):i.type==="WHILE_LOOP"&&await gi(i.body,t)}function Zu(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=Ju();function r(){return P.join(n??t,"fixtures")}o.get("/api/files",async(s,c)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,u=P.resolve(d),p=await C.readdir(u,{withFileTypes:!0}),h=[];for(let g of p)if(g.name!=="node_modules"&&!g.name.startsWith("."))if(g.isDirectory()){let y=P.join(u,g.name);await hl(y)&&h.push({name:g.name,type:"directory",path:y})}else g.isFile()&&g.name.endsWith(".test.yaml")&&h.push({name:g.name,type:"file",path:P.join(u,g.name)});h.sort((g,y)=>g.type!==y.type?g.type==="directory"?-1:1:g.name.localeCompare(y.name));let f=P.dirname(u);c.json({dir:u,parent:f!==u?f:null,entries:h,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),c.status(500).json({error:d.message})}});function l(s){if(typeof s=="string"&&s){let c=P.resolve(s);return c.endsWith(".test.yaml")?{filePath:c}:{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,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath;try{a?.(u);let p=await C.readFile(u,"utf-8"),h=await C.stat(u),f=wa(p),g=cl(p,u,n);if(g.suite){let y=g.suite,m={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:Ge(y.beforeAll),afterAll:Ge(y.afterAll),beforeEach:Ge(y.beforeEach),afterEach:Ge(y.afterEach)},b={version:"1.3.0",baseURL:g.use?.baseURL,testGroup:m};c.json({isSuite:!0,testFlow:b,metadata:f,name:g.name,tags:g.tags,use:g.use,filePath:u,fileName:P.basename(u),lastModified:h.mtimeMs})}else{let y=g.testFlow;xn(p,y),c.json({isSuite:!1,testFlow:y,metadata:f,name:g.name,tags:g.tags,use:g.use,parameters:g.parameters,filePath:u,fileName:P.basename(u),lastModified:h.mtimeMs})}}catch(p){if(p.code==="ENOENT")return c.status(404).json({error:`File not found: ${u}`});console.error("[debugger] Error loading test flow:",p),c.status(500).json({error:p.message})}}),o.put("/api/test-flow",async(s,c)=>{try{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath,{testFlow:p,metadata:h}=s.body;if(!p)return c.status(400).json({error:"testFlow is required"});let f=P.join(n??t,"templates"),g=await qu(f),y=xa(p,g),m=pi(y.statements??[]),b={...y,statements:m},v=n??t,S=[b.statements??[],b.teardown??[],...b.testGroup?.tests?.flatMap(O=>[O.statements,...O.teardown?[O.teardown]:[]])??[],...b.testGroup?.beforeEach?[b.testGroup.beforeEach]:[],...b.testGroup?.afterEach?[b.testGroup.afterEach]:[]];for(let O of S)await gi(O,v);let T=fa(b,h),M=u+".tmp";await C.writeFile(M,T,"utf-8"),await C.rename(M,u);let N=await C.stat(u);c.json({success:!0,lastModified:N.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),c.status(500).json({error:d.message})}}),o.get("/api/fixtures",async(s,c)=>{try{let d=r();try{let p=(await C.readdir(d,{withFileTypes:!0})).filter(h=>h.isFile()).map(h=>h.name).sort();c.json({files:p,dir:d})}catch(u){if(u.code==="ENOENT")c.json({files:[],dir:d});else throw u}}catch(d){console.error("[debugger] Error listing fixtures:",d),c.status(500).json({error:d.message})}}),o.post("/api/fixtures",async(s,c)=>{try{let d=r();await C.mkdir(d,{recursive:!0});let{name:u,content:p}=s.body;if(!u||!p)return c.status(400).json({error:"name and content are required"});let h=P.basename(u);if(!h)return c.status(400).json({error:"Invalid file name"});let f=P.join(d,h);await C.writeFile(f,Buffer.from(p,"base64")),c.json({fileName:h})}catch(d){console.error("[debugger] Error saving fixture:",d),c.status(500).json({error:d.message})}}),o.get("/api/functions",async(s,c)=>{let d=P.join(n??t,"helpers"),u;try{u=await C.readdir(d)}catch(g){return g.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading helpers dir:",g),c.status(500).json({error:g.message}))}let p=u.filter(g=>/\.(ts|js|mjs)$/.test(g)),h=[],f=1;for(let g of p){let y=await C.readFile(P.join(d,g),"utf-8"),m=/export\s+async\s+function\s+(\w+)\s*(\([^)]*\))/g,b;for(;(b=m.exec(y))!==null;){let[,v,S]=b,T=S.replace(/\s*:\s*[^,)]+/g,"");h.push({id:f++,name:`helpers/${g}#${v}`,description:"",status:"Active",code:`async function ${v}${T} {}`})}}c.json(h)}),o.get("/api/reusable-steps",async(s,c)=>{let d=P.join(n??t,"templates"),u;try{u=await C.readdir(d)}catch(f){return f.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading templates dir:",f),c.status(500).json({error:f.message}))}let p=u.filter(f=>f.endsWith(".yaml")).sort(),h=[];for(let f of p)try{let g=await C.readFile(P.join(d,f),"utf-8"),y=dt(g);if(!y||typeof y!="object")continue;let m=y.name??P.basename(f,".yaml"),b=y.description??"",v=Ge(y.statements);h.push({id:kn(m),organizationId:"local",name:m,description:b,statements:v})}catch(g){console.error(`[debugger] Error parsing template ${f}:`,g)}c.json(h)}),o.post("/api/reusable-steps/exists/:name",async(s,c)=>{let d=P.join(n??t,"templates"),u=decodeURIComponent(s.params.name).toLowerCase(),p;try{p=await C.readdir(d)}catch(h){return h.code==="ENOENT"?c.json(!1):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=await C.readFile(P.join(d,h),"utf-8");if((dt(f)?.name??P.basename(h,".yaml")).toLowerCase()===u)return c.json(!0)}catch{}c.json(!1)}),o.post("/api/reusable-steps",async(s,c)=>{let d=P.join(n??t,"templates"),{reusableStep:u}=s.body??{};if(!u?.name||!Array.isArray(u.statements))return c.status(400).json({error:"reusableStep.name and reusableStep.statements are required"});await C.mkdir(d,{recursive:!0});let p=u.name.replace(/[/\\:*?"<>|]/g,"-").trim(),h=P.join(d,`${p}.yaml`),f={name:u.name,statements:Sn(u.statements)};u.description&&(f.description=u.description),await C.writeFile(h,fi(f),"utf-8"),c.json({id:kn(u.name),organizationId:"local",name:u.name,description:u.description??"",statements:u.statements})}),o.put("/api/reusable-steps/:id/update",async(s,c)=>{let d=parseInt(s.params.id,10),u=P.join(n??t,"templates"),p;try{p=await C.readdir(u)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=P.join(u,h),g=dt(await C.readFile(f,"utf-8"))??{},y=g.name??P.basename(h,".yaml");if(kn(y)!==d)continue;let m=s.body??{};return m.description!==void 0&&(g.description=m.description),m.statements!==void 0&&(g.statements=Sn(m.statements)),await C.writeFile(f,fi(g),"utf-8"),c.json({id:d,organizationId:"local",...g,statements:m.statements!==void 0?m.statements:Ge(g.statements)})}catch{}c.status(404).json({error:`Template with id ${d} not found`})}),o.put("/api/templates/:name",async(s,c)=>{let d=P.join(n??t,"templates"),u=decodeURIComponent(s.params.name),p;try{p=await C.readdir(d)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(f=>f.endsWith(".yaml")))try{let f=P.join(d,h),g=dt(await C.readFile(f,"utf-8"))??{};if((g.name??P.basename(h,".yaml"))!==u)continue;let m=s.body??{};return m.name!==void 0&&(g.name=m.name),m.description!==void 0&&(g.description=m.description),m.statements!==void 0&&(g.statements=Sn(m.statements)),await C.writeFile(f,fi(g),"utf-8"),c.json({organizationId:"local",...g,statements:m.statements!==void 0?m.statements:Ge(g.statements)})}catch{}c.status(404).json({error:`Template "${u}" not found`})}),o.get("/api/test-results",async(s,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=n??t,p=P.basename(d.filePath,".test.yaml"),h=P.join(u,".shiplight","artifacts",p),f=[],g=null;try{let y=await C.readdir(h,{withFileTypes:!0});for(let m of y)if(m.isDirectory()){let b=P.join(h,m.name),v=await C.readdir(b);for(let S of v.filter(T=>/\.(png|jpe?g|webp)$/i.test(T))){let T=P.relative(h,P.join(b,S)),M=m.name.match(/^(.+?)_(before|after)$/),N=M?M[1]:m.name,O=M?M[2]:"screenshot";f.push({url:`/api/report-assets/${p}/${T}`,label:O,stepId:N})}}else/\.(webm|mp4)$/i.test(m.name)&&(g||(g=`/api/report-assets/${p}/${m.name}`));f.sort((m,b)=>m.stepId!==b.stepId?(m.stepId??"").localeCompare(b.stepId??""):m.label.localeCompare(b.label))}catch{}if(f.length===0&&!g)return c.status(404).json({error:"No test results found"});c.json({videoPath:g,screenshots:f})}),o}var pl=x(()=>{"use strict";lt();ul()});var gl={};ut(gl,{createIntRunnerRouter:()=>eh});import{Router as Qu}from"express";function eh(e){let t=Qu();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:l,stmtUid:s,executionHistory:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let d=await e.executeAction(a.sessionId,o,r,{withSelfHealing:l,stmtUid:s,executionHistory:c});n.json(d)}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: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 s=c=>{n.write(`data: ${JSON.stringify(c)}
4306
4306
 
4307
4307
  `)};try{await e.runStep(a.sessionId,o,r,s,l)}catch(c){s({type:"error",data:{message:c.message}})}finally{n.end()}}),t.post("/api/int-runner/execute-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:l,maxSteps: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 c=d=>{n.write(`data: ${JSON.stringify(d)}
4308
4308
 
4309
4309
  `)};try{await e.runStep(a.sessionId,o,r,c,l)}catch(d){c({type:"error",data:{message:d.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:l}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let s=await e.evaluate(a.sessionId,o,l);n.json(s)}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:l,usePureVision:s,includeDebugInfo:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let d=await e.generateAction(a.sessionId,o,r,{executionHistory:l,usePureVision:s,includeDebugInfo:c});n.json(d)}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,s3Path:o}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let r;if(o){let s=o.split("/").pop()?.replace(/\.png$/,"");s&&(r=s)}let l=await e.takeScreenshot(a.sessionId,r);n.json({status:"success",...l})}catch(a){console.error("[debugger] screenshot error:",a),n.status(500).json({status:"error",message:a.message})}}),t.get("/api/int-runner/session-artifacts",async(i,n)=>{try{let a=e.getSessionArtifacts?.("default")??{screenshots:[]};n.json(a)}catch(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=l=>{n.write(`data: ${JSON.stringify(l)}
4310
4310
 
4311
- `)};try{await e.startRecorder(a.sessionId,r,o)}catch(l){r({type:"error",data:{message:l.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 gl=x(()=>{"use strict"});import xa from"express";import En from"path";import*as oe from"path";import*as nt from"fs/promises";import{pathToFileURL as uu}from"url";import*as xs from"os";import{parse as hu}from"yaml";import{expect as mu}from"@playwright/test";U();U();$t();Je();import{z as Jr}from"zod";var Dd=Jr.object({instruction:Jr.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 qr(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:Dd,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Ye(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,l=await At(r,a);return{success:l.success,actionEntity:r,message:l.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:l.error}}})}_e();U();import{generateText as Rd}from"ai";import{convert as Fd}from"html-to-text";async function Hd(e,t,i){let{apiKey:n,domain:a}=e;if(!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=!!e.baseURL,r=e.baseURL||"https://api.mailgun.net",l=e.authHeader||`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,s=[];try{let c=o?`${r}/events`:`${r}/v3/${a}/events`,d={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(d.from=i.from_email),i.since)d.begin=Math.floor(i.since/1e3).toString();else{let h=new Date(Date.now()-6e5);d.begin=Math.floor(h.getTime()/1e3).toString()}w.info(`Mailgun params: ${JSON.stringify(d)}`);let u=await fetch(c+"?"+new URLSearchParams(d),{method:"GET",headers:{Authorization:l}});if(!u.ok){let h=await u.text();throw new Error(`Mailgun events API error: ${h}`)}let p=(await u.json()).items||[];for(let h of p.slice(0,10)){if(h.event!=="accepted")continue;let f=(h.storage||{}).url;if(w.info(`message_url: ${f}`),!f){let m=(h.message||{}).headers||{},b=m.subject||"",v=m.from||"",S=m.to||"";if(i.from_email&&!v.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!S.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!b.toLowerCase().includes(i.subject.toLowerCase()))continue;s.push({subject:b,from:v,to:S,date:new Date(h.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:m["message-id"]||""});continue}let g=f.split("/"),y=g[g.length-1];if(w.info(`Storage key: ${y}`),y){let m=o?`${r}/messages/${y}`:`${r}/v3/domains/${a}/messages/${y}`;try{let b=await fetch(m,{method:"GET",headers:{Authorization:l,Accept:"application/json"}});if(b.ok){let v=await b.json(),S=v.Subject||"",T=v.From||"",M=v.To||"",N=v.Date||"",O=v["Message-Id"]||"";w.info(`subject: ${S}`),w.info(`from_addr: ${T}`),w.info(`to_addr: ${M}`),w.info(`date: ${N}`),w.info(`message_id: ${O}`);let L=v["body-html"]||v["body-plain"]||"";if(L&&L.includes("<")&&(L=Fd(L)),w.info(`Body: ${L.substring(0,200)}...`),i.subject&&!S.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!L.toLowerCase().includes(i.body_contains.toLowerCase()))continue;s.push({subject:S,from:T,to:M,date:N,body:L,message_id:O});continue}else w.warn(`Messages API returned ${b.status}`)}catch(b){w.warn(`Failed to parse JSON response: ${b}`)}}try{let m=await fetch(f,{method:"GET",headers:{Authorization:l}});if(!m.ok){w.warn(`Could not fetch stored message: ${m.status}`);continue}let b=await m.text();w.info(`Fallback: Raw email length: ${b.length}`);let v=b.split(`
4311
+ `)};try{await e.startRecorder(a.sessionId,r,o)}catch(l){r({type:"error",data:{message:l.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 fl=x(()=>{"use strict"});import va from"express";import En from"path";import*as oe from"path";import*as at from"fs/promises";import{pathToFileURL as hu}from"url";import*as vs from"os";import{parse as mu}from"yaml";import{expect as pu}from"@playwright/test";U();U();$t();qe();import{z as qr}from"zod";var Rd=qr.object({instruction:qr.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 Zr(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:Rd,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Je(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,l=await At(r,a);return{success:l.success,actionEntity:r,message:l.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:l.error}}})}ye();U();import{generateText as Fd}from"ai";import{convert as Hd}from"html-to-text";async function Wd(e,t,i){let{apiKey:n,domain:a}=e;if(!n)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=!!e.baseURL,r=e.baseURL||"https://api.mailgun.net",l=e.authHeader||`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,s=[];try{let c=o?`${r}/events`:`${r}/v3/${a}/events`,d={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(d.from=i.from_email),i.since)d.begin=Math.floor(i.since/1e3).toString();else{let h=new Date(Date.now()-6e5);d.begin=Math.floor(h.getTime()/1e3).toString()}w.info(`Mailgun params: ${JSON.stringify(d)}`);let u=await fetch(c+"?"+new URLSearchParams(d),{method:"GET",headers:{Authorization:l}});if(!u.ok){let h=await u.text();throw new Error(`Mailgun events API error: ${h}`)}let p=(await u.json()).items||[];for(let h of p.slice(0,10)){if(h.event!=="accepted")continue;let f=(h.storage||{}).url;if(w.info(`message_url: ${f}`),!f){let m=(h.message||{}).headers||{},b=m.subject||"",v=m.from||"",S=m.to||"";if(i.from_email&&!v.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!S.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!b.toLowerCase().includes(i.subject.toLowerCase()))continue;s.push({subject:b,from:v,to:S,date:new Date(h.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:m["message-id"]||""});continue}let g=f.split("/"),y=g[g.length-1];if(w.info(`Storage key: ${y}`),y){let m=o?`${r}/messages/${y}`:`${r}/v3/domains/${a}/messages/${y}`;try{let b=await fetch(m,{method:"GET",headers:{Authorization:l,Accept:"application/json"}});if(b.ok){let v=await b.json(),S=v.Subject||"",T=v.From||"",M=v.To||"",N=v.Date||"",O=v["Message-Id"]||"";w.info(`subject: ${S}`),w.info(`from_addr: ${T}`),w.info(`to_addr: ${M}`),w.info(`date: ${N}`),w.info(`message_id: ${O}`);let L=v["body-html"]||v["body-plain"]||"";if(L&&L.includes("<")&&(L=Hd(L)),w.info(`Body: ${L.substring(0,200)}...`),i.subject&&!S.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!L.toLowerCase().includes(i.body_contains.toLowerCase()))continue;s.push({subject:S,from:T,to:M,date:N,body:L,message_id:O});continue}else w.warn(`Messages API returned ${b.status}`)}catch(b){w.warn(`Failed to parse JSON response: ${b}`)}}try{let m=await fetch(f,{method:"GET",headers:{Authorization:l}});if(!m.ok){w.warn(`Could not fetch stored message: ${m.status}`);continue}let b=await m.text();w.info(`Fallback: Raw email length: ${b.length}`);let v=b.split(`
4312
4312
  `),S=!0,T={},M="";for(let ie=0;ie<v.length;ie++){let G=v[ie];if(G.trim()===""&&S){S=!1;continue}if(S){let K=G.match(/^([^:]+):\s*(.+)$/);K&&(T[K[1].toLowerCase()]=K[2])}else M+=G+`
4313
- `}let N=T.subject||"",O=T.from||"",L=T.to||"",Q=T.date||"",Y=T["message-id"]||"";if(i.subject&&!N.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;s.push({subject:N,from:O,to:L,date:Q,body:M.trim(),message_id:Y})}catch(m){w.warn(`Error fetching raw message: ${m}`)}}if(s.length>0){try{s.sort((f,g)=>{let y=new Date(f.date).getTime();return new Date(g.date).getTime()-y})}catch{}let h=s[0];return w.info(`Returning most recent email: ${h.subject}`),[h]}return s}catch(c){throw w.error(`Error fetching emails from Mailgun: ${c.message}`),new Error(`Error fetching emails from Mailgun: ${c.message}`)}}function Wd(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4313
+ `}let N=T.subject||"",O=T.from||"",L=T.to||"",Q=T.date||"",Y=T["message-id"]||"";if(i.subject&&!N.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;s.push({subject:N,from:O,to:L,date:Q,body:M.trim(),message_id:Y})}catch(m){w.warn(`Error fetching raw message: ${m}`)}}if(s.length>0){try{s.sort((f,g)=>{let y=new Date(f.date).getTime();return new Date(g.date).getTime()-y})}catch{}let h=s[0];return w.info(`Returning most recent email: ${h.subject}`),[h]}return s}catch(c){throw w.error(`Error fetching emails from Mailgun: ${c.message}`),new Error(`Error fetching emails from Mailgun: ${c.message}`)}}function Ud(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4314
4314
 
4315
4315
  Please carefully examine the email content and look for:
4316
4316
  1. Numeric codes (usually 4-8 digits)
@@ -4367,27 +4367,27 @@ Examples of what to extract:
4367
4367
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4368
4368
 
4369
4369
  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+`
4370
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Ud(e,t,i){try{let n=`${t}
4370
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function jd(e,t,i){try{let n=`${t}
4371
4371
  ---
4372
4372
  Email Content:
4373
4373
  ---
4374
4374
  ${e}
4375
4375
  ---
4376
- `,a=xe(i);return(await Rd({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:ve(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw w.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function Zr(e,t){w.info(`extract_email_content:
4376
+ `,a=fe(i);return(await Fd({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:we(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw w.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function Qr(e,t){w.info(`extract_email_content:
4377
4377
  forward_email: ${t.forward_email}
4378
4378
  extraction_type: ${t.extraction_type}
4379
4379
  filters: ${JSON.stringify(t.filters||{})}
4380
4380
  timeout: ${t.timeout||60}
4381
- 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=Wd(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),l=0;for(w.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){l++,w.info(`Polling attempt ${l}`);try{let c=t.filters||{},d=await Hd(e,t.forward_email,c);if(d.length>0){w.info(`Found ${d.length} emails matching criteria`);let u=[];for(let p of d){let h=`Subject: ${p.subject}
4381
+ 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=Ud(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),l=0;for(w.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){l++,w.info(`Polling attempt ${l}`);try{let c=t.filters||{},d=await Wd(e,t.forward_email,c);if(d.length>0){w.info(`Found ${d.length} emails matching criteria`);let u=[];for(let p of d){let h=`Subject: ${p.subject}
4382
4382
  From: ${p.from}
4383
4383
  To: ${p.to}
4384
4384
  Date: ${p.date}
4385
4385
 
4386
4386
  Body:
4387
- ${p.body}`,f=await Ud(h,a,t.model);w.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&u.push({content:f,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=u[0],h=`$email_${t.extraction_type}`;t.extraction_type==="custom"?h="$email_extracted_content":t.extraction_type==="activation_link"?h="$email_magic_link":t.extraction_type==="verification_code"&&(h="$email_otp_code");let f=(new Date().getTime()-o.getTime())/1e3;return w.info(`Successfully extracted content after ${l} attempts in ${f.toFixed(1)} seconds`),{data:p.content,result_variable:h,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${l})`}}else w.info(`Found emails but no extractable content in attempt ${l}`)}else w.info(`No emails found in attempt ${l}`)}catch(c){w.warn(`Error in polling attempt ${l}: ${c.message}`)}if(new Date(Date.now()+n*1e3)>=r){w.info("Not enough time for another polling attempt");break}w.info(`Waiting ${n} seconds before next attempt...`),await new Promise(c=>setTimeout(c,n*1e3))}let s=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${l} attempts over ${s.toFixed(1)} seconds`}}catch(a){return w.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}ze();U();ne();import{z as Ee}from"zod";function Qr(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 es=class{getMailgunConfig(){let e=V().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""};let t=e.SHIPLIGHT_API_TOKEN;if(t){let i=`${Fe(t,e.SHIPLIGHT_API_URL)}/mailgun`;return w.debug(`[extract_email_content] Using Shiplight proxy for Mailgun: ${i}`),{apiKey:t,domain:e.MAILGUN_DOMAIN||"",baseURL:i,authHeader:`Bearer ${t}`}}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN, or set SHIPLIGHT_API_TOKEN to route through the Shiplight proxy.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",l=await Zr(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(l.status==="success"&&l.data){let s=l.result_variable?.replace(/^\$/,"")||Qr(o.extraction_type);i.variableStore.set(s,l.data),w.info(`[extract_email_content] Extracted and saved to ${s}`)}else throw new Error(l.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)} },`,"});"]}},jd=Ee.object({forward_email:Ee.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ee.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:Ee.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ee.string().optional().describe("Filter emails by sender address"),filter_to_email:Ee.string().optional().describe("Filter emails by recipient address"),filter_subject:Ee.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ee.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ee.number().optional().describe("Timeout in seconds for polling (default: 60)")});function ts(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:jd,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}=i,{page:p,agentServices:h}=n;w.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}}};await t.execute(p,f,h);let g=Qr(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${g}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}},feedback:f.message}}}}})}Mt();It();Pt();Nt();Lt();Dt();Rt();Ft();Ht();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();var gn=null;async function fe(){if(gn)return gn;let e=(await Promise.resolve().then(()=>(cn(),ln))).default;return gn=new e,gn}async function is(e){let t=await fe(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Ir(e,i),kr(e,n),cr(e,a),Rr(e,o),"Click, hover, double-click, right-click, or drag elements"}async function ns(e){let t=await fe(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return vr(e,i),xr(e,n),sr(e,a),"Navigate to URLs, go back, or reload the page"}async function as(e){let t=await fe(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return $r(e,i),Er(e,n),or(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function os(e){let t=await fe(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return jo(e,i),Ko(e,n),Ho(e,a),"Scroll the page or scroll to specific text/elements"}async function rs(e){let t=await fe(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Nr(e,i),Qo(e,n),"Switch between browser tabs or close tabs"}async function ss(e){let t=await fe(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return nr(e,i),Do(e,n),"Upload files or wait for downloads to complete"}async function ls(e){let t=await fe(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return yr(e,i),Xo(e,n),Jo(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function cs(e){let t=await fe(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return No(e,i),ur(e,n),Lr(e,a),qr(e),"Wait for conditions, save variables, or complete tasks"}async function ds(e){let t=(await fe()).getAction("generate_2fa_code");pr(e,t);let i=new es;return(await Promise.resolve().then(()=>(cn(),ln))).default.registerAction("extract_email_content",i),ts(e,i),"Generate 2FA codes or extract email/activation codes"}async function us(e){let t=await fe(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return Wr(e,i),jr(e,n),Fo(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}ke();var Bd=[is(j),ns(j),as(j),os(j),rs(j),ss(j),ls(j),cs(j),us(j),ds(j)],Tv=Promise.all(Bd);ht();ci();Oe();si();U();import{chromium as g_,firefox as f_,webkit as w_}from"playwright";import{execFileSync as ws}from"child_process";import*as ys from"fs";import*as bs from"path";function nu(){if(process.platform==="win32"){let i=ws("powershell.exe",["-NoProfile","-NonInteractive","-Command","Get-CimInstance Win32_Process | Select-Object ProcessId,ParentProcessId,CommandLine | ConvertTo-Json -Compress"],{encoding:"utf-8",timeout:1e4}),n=JSON.parse(i.trim());return(Array.isArray(n)?n:[n]).filter(a=>a!==null&&typeof a=="object").filter(a=>typeof a.ProcessId=="number").map(a=>({pid:a.ProcessId,ppid:typeof a.ParentProcessId=="number"?a.ParentProcessId:0,args:typeof a.CommandLine=="string"?a.CommandLine:""}))}let e=ws("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),t=[];for(let i of e.split(`
4388
- `)){let n=i.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);n&&t.push({pid:parseInt(n[1],10),ppid:parseInt(n[2],10),args:n[3]})}return t}function au(e){let t=nu(),i=new Set([e]),n=!0;for(;n;){n=!1;for(let a of t)!i.has(a.pid)&&i.has(a.ppid)&&(i.add(a.pid),n=!0)}for(let a of t){if(a.pid===e||!i.has(a.pid)||!/chrome|chromium/i.test(a.args))continue;let o=a.args.match(/--user-data-dir=(?:"([^"]+)"|(\S+))/);if(o)return o[1]??o[2]}return null}async function ou(e,t){let i=bs.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let a=ys.readFileSync(i,"utf-8").trim(),[o,r]=a.split(`
4389
- `),l=parseInt(o,10);if(Number.isFinite(l)&&l>0&&typeof r=="string"&&r.startsWith("/"))return{port:l,wsPath:r}}catch{}await new Promise(a=>setTimeout(a,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function ca(e,t=3e4){let i=au(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:a}=await ou(i,t);return`ws://127.0.0.1:${n}${a}`}ci();var ru=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(ru||{});$t();He();da();ae();ci();Oe();U();Oe();U();import{generateSync as U_,createGuardrails as lu}from"otplib";var j_=lu({MIN_SECRET_BYTES:1});var di=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(di||{});Wt();U();$t();Li();Ni();bi();Je();Ei();Ai();Ti();Ke();Ii();yt();bt();ke();ht();wt();Gi();He();xt();vt();Ze();_t();kt();da();ae();ci();Oe();si();_e();gt();Ve();ft();Ce();ze();sa();Ri();Fi();Hi();Wi();Ui();ji();Bi();Yi();Ji();qi();Zi();Mt();It();Pt();Nt();Lt();Dt();Rt();Ft();Ht();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();Et();ai();on();Wt();X();Re();U();ne();Tt();sn();W();ye();var ui=class{page;agent;testDir=process.cwd();projectRoot;sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;recorderStopResolver;recorderEnabled=!1;screenshotHistory=[];yamlFilePath;artifactsDir;constructor(t,i,n,a){this.page=t,this.agent=i,this.projectRoot=a,n&&(this.agent._getContext().testDataDir=n)}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){if(t?.testFilePath){this.testDir=oe.dirname(t.testFilePath),this.yamlFilePath=t.testFilePath;let i=this.projectRoot??this.testDir,n=oe.basename(t.testFilePath,".test.yaml");if(this.artifactsDir=oe.join(i,".shiplight","artifacts",n),t.testFilePath.endsWith(".test.yaml"))try{let a=await nt.readFile(t.testFilePath,"utf-8"),r=hu(a)?.parameters;if(r&&r.length>0&&r[0].values)for(let[l,s]of Object.entries(r[0].values))this.agent.agentServices.saveVariable(l,s)}catch{}}return{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");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)}`);let r=this.agent.agentServices.validatePage(this.page);if(o.action_name==="js_code"&&n==="prelude"){if(r.url()==="about:blank"){let h=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];h&&await r.goto(h,{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 l=a?.stmtUid;l&&this.agent.getNewActionEntities().delete(l);let s;if(We.isAiAction(i)){let g=new oi().transpile(i,n,l).join(`
4390
- `),y=new Function("page","agent",`return (async () => { ${g} })();`);try{await y(r,this.agent),s={actionGenerationDebugInfo:this.agent._getContext()?.lastActionDebugInfo}}catch(m){let b=this.agent._getContext();return{status:"error",details:this.agent.getAgentNote()||m.message,actionGenerationDebugInfo:b?.lastActionDebugInfo,testContext:b?.variableStore?.getAll()}}}else{let h=i.action_description||o.action_name,f=!!a?.withSelfHealing&&We.canSelfHeal(i);s=await this.agent.step(r,async()=>{await this.agent.execAction(o.action_name,r,i)},h,n,l,f)}let c=this.agent.getAgentNote(),u=this.agent._getContext()?.variableStore,p={...s,status:"success",testContext:u?u.getAll():void 0};if(c&&(p.details=c),l){let h=this.agent.getNewActionEntities().get(l);if(h){let{element_index:f,...g}=h.action_data?.kwargs||{};p.newActionEntity={...h,action_data:h.action_data?{...h.action_data,kwargs:g}:h.action_data}}}return p}async runStep(t,i,n,a,o){let r=[];this.abortController=new AbortController;try{let l=await this.agent.run(this.agent.agentServices.validatePage(this.page),i,n,{onAction:c=>{r.push(c),a({type:di.Action,data:{action_entity:c}})}}),s=this.agent._getContext()?.variableStore;return a({type:di.Completion,data:{success:l?.success??!0,details:l?.details,testContext:s?s.getAll():void 0}}),{success:l?.success??!0,actions:r,details:l?.details}}finally{this.abortController=null}}async executeFunction(t){let i=t.functionName,[n,a]=i.split("#");try{let o=oe.isAbsolute(n)?n:oe.resolve(this.projectRoot??this.testDir,n),l=(await import(uu(o).href))[a];if(typeof l!="function")return{status:"error",details:`Export "${a}" not found or not a function in ${n}`};let c=l.toString().match(/\(([^)]*)\)/),d=c&&c[1].trim()?c[1].split(",").map(b=>b.split(":")[0].trim().replace(/\?$/,"")):[],u=Array.isArray(t.parameterNames)?t.parameterNames.map(String):[],p=Array.isArray(t.parameterValues)?t.parameterValues.map(String):Array.isArray(t.args)?t.args.map(String):[],h={};u.forEach((b,v)=>{let S=b.split(":")[0].trim();h[S]=p[v]??""});let f=["page","agent","request","testContext"],g=this.agent.agentServices.validatePage(this.page),y=d.map(b=>{if(b==="page")return g;if(b==="agent")return this.agent;if(b==="request")return;if(b==="testContext")return this.agent._getContext?.()?.variableStore;let v=h[b]??"";return v.startsWith("$")?this.agent.agentServices.readVariable(v.substring(1)):v}),m=d.length>0?y:p.map(b=>{if(b==="page")return g;if(b==="agent")return this.agent;if(b!=="request")return b==="testContext"?this.agent._getContext?.()?.variableStore:b.startsWith("$")?this.agent.agentServices.readVariable(b.substring(1)):b});return await l(...m),{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","expect","agent",`return (async () => { return (${i}); })();`)(this.agent.agentServices.validatePage(this.page),mu,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.agent.agentServices.validatePage(this.page),i);return{status:"success",conclusion:a?"true":"false",explanation:a?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(a){return{status:"error",conclusion:"unknown",explanation:a.message}}}async generateAction(t,i,n,a){let o=await this.agent.generate(this.agent.agentServices.validatePage(this.page),i,n,a?.usePureVision),r=o.actions?.[0];return r?{status:"success",action:r,explanation:o.details,debugInfo:o.debugInfo,completes_instruction:o.success}:{status:"error",explanation:o.details||"Failed to generate action",debugInfo:o.debugInfo}}async takeScreenshot(t,i){let n=await this.agent.agentServices.validatePage(this.page).screenshot(),a=i??`debug-${this.screenshotHistory.length}`,o;if(this.artifactsDir){let r=oe.join(this.artifactsDir,a.replace(/\./g,"-"));await nt.mkdir(r,{recursive:!0}),o=oe.join(r,"screenshot.png")}else o=oe.join(xs.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await nt.writeFile(o,n),this.screenshotHistory.push({stepId:a,path:o}),{screenshot:n.toString("base64"),screenshotPath:o}}getSessionArtifacts(t){return{outputDir:this.artifactsDir,screenshots:[...this.screenshotHistory]}}async startRecorder(t,i,n){let a=this.page.context(),o=new Promise(l=>{this.recorderStopResolver=l}),r={actionAdded:(l,s,c)=>{i({type:"actionAdded",action:s.action,code:c,timestamp:Date.now()})},actionUpdated:(l,s,c)=>{i({type:"actionUpdated",action:s.action,code:c,timestamp:Date.now()})},signalAdded:(l,s)=>{i({type:"signal",signal:s.signal,timestamp:Date.now()})}};if(this.recorderEnabled)a._onRecorderEventSink=r,await this.page.evaluate(()=>window.__pw_recorderSetMode?.("recording")).catch(()=>{});else{let l="x-pw-overlay { display: none !important; }";await a.addInitScript(`(() => {
4387
+ ${p.body}`,f=await jd(h,a,t.model);w.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&u.push({content:f,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=u[0],h=`$email_${t.extraction_type}`;t.extraction_type==="custom"?h="$email_extracted_content":t.extraction_type==="activation_link"?h="$email_magic_link":t.extraction_type==="verification_code"&&(h="$email_otp_code");let f=(new Date().getTime()-o.getTime())/1e3;return w.info(`Successfully extracted content after ${l} attempts in ${f.toFixed(1)} seconds`),{data:p.content,result_variable:h,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${l})`}}else w.info(`Found emails but no extractable content in attempt ${l}`)}else w.info(`No emails found in attempt ${l}`)}catch(c){w.warn(`Error in polling attempt ${l}: ${c.message}`)}if(new Date(Date.now()+n*1e3)>=r){w.info("Not enough time for another polling attempt");break}w.info(`Waiting ${n} seconds before next attempt...`),await new Promise(c=>setTimeout(c,n*1e3))}let s=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${l} attempts over ${s.toFixed(1)} seconds`}}catch(a){return w.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}Xe();U();ne();import{z as Ee}from"zod";function es(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 ts=class{getMailgunConfig(){let e=V().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""};let t=e.SHIPLIGHT_API_TOKEN;if(t){let i=`${Fe(t,e.SHIPLIGHT_API_URL)}/mailgun`;return w.debug(`[extract_email_content] Using Shiplight proxy for Mailgun: ${i}`),{apiKey:t,domain:e.MAILGUN_DOMAIN||"",baseURL:i,authHeader:`Bearer ${t}`}}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN, or set SHIPLIGHT_API_TOKEN to route through the Shiplight proxy.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",l=await Qr(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(l.status==="success"&&l.data){let s=l.result_variable?.replace(/^\$/,"")||es(o.extraction_type);i.variableStore.set(s,l.data),w.info(`[extract_email_content] Extracted and saved to ${s}`)}else throw new Error(l.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)} },`,"});"]}},Bd=Ee.object({forward_email:Ee.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:Ee.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:Ee.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:Ee.string().optional().describe("Filter emails by sender address"),filter_to_email:Ee.string().optional().describe("Filter emails by recipient address"),filter_subject:Ee.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:Ee.string().optional().describe("Filter emails by body content (partial match)"),timeout:Ee.number().optional().describe("Timeout in seconds for polling (default: 60)")});function is(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:Bd,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}=i,{page:p,agentServices:h}=n;w.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let f={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}}};await t.execute(p,f,h);let g=es(o);return{success:!0,actionEntity:f,message:`Extracted ${o} and saved to $${g}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}},feedback:f.message}}}}})}It();Pt();Ct();Nt();Ot();Dt();Ft();Ht();Wt();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();var gn=null;async function be(){if(gn)return gn;let e=(await Promise.resolve().then(()=>(cn(),ln))).default;return gn=new e,gn}async function ns(e){let t=await be(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Nr(e,i),Tr(e,n),pr(e,a),Wr(e,o),"Click, hover, double-click, right-click, or drag elements"}async function as(e){let t=await be(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return Sr(e,i),kr(e,n),hr(e,a),"Navigate to URLs, go back, or reload the page"}async function os(e){let t=await be(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Pr(e,i),lr(e,n),dr(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function rs(e){let t=await be(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Yo(e,i),Zo(e,n),zo(e,a),"Scroll the page or scroll to specific text/elements"}async function ss(e){let t=await be(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Dr(e,i),rr(e,n),"Switch between browser tabs or close tabs"}async function ls(e){let t=await be(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Lo(e,i),Uo(e,n),"Upload files or wait for downloads to complete"}async function cs(e){let t=await be(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return vr(e,i),tr(e,n),nr(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function ds(e){let t=await be(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return Fo(e,i),Ko(e,n),Fr(e,a),Zr(e),"Wait for conditions, save variables, or complete tasks"}async function us(e){let t=(await be()).getAction("generate_2fa_code");wr(e,t);let i=new ts;return(await Promise.resolve().then(()=>(cn(),ln))).default.registerAction("extract_email_content",i),is(e,i),"Generate 2FA codes or extract email/activation codes"}async function hs(e){let t=await be(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return Br(e,i),$r(e,n),Bo(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}ke();var Gd=[ns(j),as(j),os(j),rs(j),ss(j),ls(j),cs(j),ds(j),hs(j),us(j)],Av=Promise.all(Gd);mt();ci();Oe();si();U();import{chromium as f_,firefox as w_,webkit as y_}from"playwright";import{execFileSync as ys}from"child_process";import*as bs from"fs";import*as xs from"path";function au(){if(process.platform==="win32"){let i=ys("powershell.exe",["-NoProfile","-NonInteractive","-Command","Get-CimInstance Win32_Process | Select-Object ProcessId,ParentProcessId,CommandLine | ConvertTo-Json -Compress"],{encoding:"utf-8",timeout:1e4}),n=JSON.parse(i.trim());return(Array.isArray(n)?n:[n]).filter(a=>a!==null&&typeof a=="object").filter(a=>typeof a.ProcessId=="number").map(a=>({pid:a.ProcessId,ppid:typeof a.ParentProcessId=="number"?a.ParentProcessId:0,args:typeof a.CommandLine=="string"?a.CommandLine:""}))}let e=ys("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),t=[];for(let i of e.split(`
4388
+ `)){let n=i.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);n&&t.push({pid:parseInt(n[1],10),ppid:parseInt(n[2],10),args:n[3]})}return t}function ou(e){let t=au(),i=new Set([e]),n=!0;for(;n;){n=!1;for(let a of t)!i.has(a.pid)&&i.has(a.ppid)&&(i.add(a.pid),n=!0)}for(let a of t){if(a.pid===e||!i.has(a.pid)||!/chrome|chromium/i.test(a.args))continue;let o=a.args.match(/--user-data-dir=(?:"([^"]+)"|(\S+))/);if(o)return o[1]??o[2]}return null}async function ru(e,t){let i=xs.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let a=bs.readFileSync(i,"utf-8").trim(),[o,r]=a.split(`
4389
+ `),l=parseInt(o,10);if(Number.isFinite(l)&&l>0&&typeof r=="string"&&r.startsWith("/"))return{port:l,wsPath:r}}catch{}await new Promise(a=>setTimeout(a,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function ca(e,t=3e4){let i=ou(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:a}=await ru(i,t);return`ws://127.0.0.1:${n}${a}`}ci();var su=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(su||{});var di=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(di||{});$t();We();da();ae();ci();Oe();U();Oe();U();import{generateSync as B_,createGuardrails as cu}from"otplib";var G_=cu({MIN_SECRET_BYTES:1});Ze();ye();import{generateText as Y_}from"ai";var J_=20*1024*1024;Mt();U();$t();Li();Ni();bi();qe();Ei();xi();Ai();Ve();Ii();bt();yt();ke();mt();Ki();We();xt();vt();Qe();_t();kt();da();ae();ci();Oe();si();Ze();ye();ft();Ye();wt();Ce();Xe();sa();Ri();Fi();Hi();Wi();Ui();ji();Bi();Gi();Ji();qi();Zi();It();Pt();Ct();Nt();Ot();Dt();Ft();Ht();Wt();Ut();jt();Bt();Gt();Kt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ei();ti();ii();ni();ai();Et();on();Mt();X();Re();U();ne();Tt();sn();W();ve();function ua(e){if(!e)return;let t=e.getAll(),i=e.getAllSensitiveKeys();if(i.size===0)return t;let n={};for(let[a,o]of Object.entries(t))n[a]=i.has(a)?"\u2022\u2022\u2022\u2022\u2022\u2022\u2022\u2022":o;return n}var ui=class{page;agent;testDir=process.cwd();projectRoot;sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;recorderStopResolver;recorderEnabled=!1;screenshotHistory=[];yamlFilePath;artifactsDir;constructor(t,i,n,a){this.page=t,this.agent=i,this.projectRoot=a,n&&(this.agent._getContext().testDataDir=n)}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){if(t?.testFilePath){this.testDir=oe.dirname(t.testFilePath),this.yamlFilePath=t.testFilePath;let i=this.projectRoot??this.testDir,n=oe.basename(t.testFilePath,".test.yaml");if(this.artifactsDir=oe.join(i,".shiplight","artifacts",n),t.testFilePath.endsWith(".test.yaml"))try{let a=await at.readFile(t.testFilePath,"utf-8"),r=mu(a)?.parameters;if(r&&r.length>0&&r[0].values)for(let[l,s]of Object.entries(r[0].values))this.agent.agentServices.saveVariable(l,s)}catch{}}return{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");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)}`);let r=this.agent.agentServices.validatePage(this.page);if(o.action_name==="js_code"&&n==="prelude"){if(r.url()==="about:blank"){let h=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];h&&await r.goto(h,{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 l=a?.stmtUid;l&&this.agent.getNewActionEntities().delete(l);let s;if(Ue.isAiAction(i)){let g=new oi().transpile(i,n,l).join(`
4390
+ `),y=new Function("page","agent",`return (async () => { ${g} })();`);try{await y(r,this.agent),s={actionGenerationDebugInfo:this.agent._getContext()?.lastActionDebugInfo}}catch(m){let b=this.agent._getContext();return{status:"error",details:this.agent.getAgentNote()||m.message,actionGenerationDebugInfo:b?.lastActionDebugInfo,testContext:ua(b?.variableStore)}}}else{let h=i.action_description||o.action_name,f=!!a?.withSelfHealing&&Ue.canSelfHeal(i);s=await this.agent.step(r,async()=>{await this.agent.execAction(o.action_name,r,i)},h,n,l,f)}let c=this.agent.getAgentNote(),u=this.agent._getContext()?.variableStore,p={...s,status:"success",testContext:ua(u)};if(c&&(p.details=c),l){let h=this.agent.getNewActionEntities().get(l);if(h){let{element_index:f,...g}=h.action_data?.kwargs||{};p.newActionEntity={...h,action_data:h.action_data?{...h.action_data,kwargs:g}:h.action_data}}}return p}async runStep(t,i,n,a,o){let r=[];this.abortController=new AbortController;try{let l=await this.agent.run(this.agent.agentServices.validatePage(this.page),i,n,{onAction:c=>{r.push(c),a({type:di.Action,data:{action_entity:c}})}}),s=this.agent._getContext()?.variableStore;return a({type:di.Completion,data:{success:l?.success??!0,details:l?.details,testContext:ua(s)}}),{success:l?.success??!0,actions:r,details:l?.details}}finally{this.abortController=null}}async executeFunction(t){let i=t.functionName,[n,a]=i.split("#");try{let o=oe.isAbsolute(n)?n:oe.resolve(this.projectRoot??this.testDir,n),l=(await import(hu(o).href))[a];if(typeof l!="function")return{status:"error",details:`Export "${a}" not found or not a function in ${n}`};let c=l.toString().match(/\(([^)]*)\)/),d=c&&c[1].trim()?c[1].split(",").map(b=>b.split(":")[0].trim().replace(/\?$/,"")):[],u=Array.isArray(t.parameterNames)?t.parameterNames.map(String):[],p=Array.isArray(t.parameterValues)?t.parameterValues.map(String):Array.isArray(t.args)?t.args.map(String):[],h={};u.forEach((b,v)=>{let S=b.split(":")[0].trim();h[S]=p[v]??""});let f=["page","agent","request","testContext"],g=this.agent.agentServices.validatePage(this.page),y=d.map(b=>{if(b==="page")return g;if(b==="agent")return this.agent;if(b==="request")return;if(b==="testContext")return this.agent._getContext?.()?.variableStore;let v=h[b]??"";return v.startsWith("$")?this.agent.agentServices.readVariable(v.substring(1)):v}),m=d.length>0?y:p.map(b=>{if(b==="page")return g;if(b==="agent")return this.agent;if(b!=="request")return b==="testContext"?this.agent._getContext?.()?.variableStore:b.startsWith("$")?this.agent.agentServices.readVariable(b.substring(1)):b});return await l(...m),{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","expect","agent",`return (async () => { return (${i}); })();`)(this.agent.agentServices.validatePage(this.page),pu,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.agent.agentServices.validatePage(this.page),i);return{status:"success",conclusion:a?"true":"false",explanation:a?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(a){return{status:"error",conclusion:"unknown",explanation:a.message}}}async generateAction(t,i,n,a){let o=await this.agent.generate(this.agent.agentServices.validatePage(this.page),i,n,a?.usePureVision),r=o.actions?.[0];return r?{status:"success",action:r,explanation:o.details,debugInfo:o.debugInfo,completes_instruction:o.success}:{status:"error",explanation:o.details||"Failed to generate action",debugInfo:o.debugInfo}}async takeScreenshot(t,i){let n=await this.agent.agentServices.validatePage(this.page).screenshot(),a=i??`debug-${this.screenshotHistory.length}`,o;if(this.artifactsDir){let r=oe.join(this.artifactsDir,a.replace(/\./g,"-"));await at.mkdir(r,{recursive:!0}),o=oe.join(r,"screenshot.png")}else o=oe.join(vs.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await at.writeFile(o,n),this.screenshotHistory.push({stepId:a,path:o}),{screenshot:n.toString("base64"),screenshotPath:o}}getSessionArtifacts(t){return{outputDir:this.artifactsDir,screenshots:[...this.screenshotHistory]}}async startRecorder(t,i,n){let a=this.page.context(),o=new Promise(l=>{this.recorderStopResolver=l}),r={actionAdded:(l,s,c)=>{i({type:"actionAdded",action:s.action,code:c,timestamp:Date.now()})},actionUpdated:(l,s,c)=>{i({type:"actionUpdated",action:s.action,code:c,timestamp:Date.now()})},signalAdded:(l,s)=>{i({type:"signal",signal:s.signal,timestamp:Date.now()})}};if(this.recorderEnabled)a._onRecorderEventSink=r,await this.page.evaluate(()=>window.__pw_recorderSetMode?.("recording")).catch(()=>{});else{let l="x-pw-overlay { display: none !important; }";await a.addInitScript(`(() => {
4391
4391
  const orig = Element.prototype.attachShadow;
4392
4392
  Element.prototype.attachShadow = function(init) {
4393
4393
  const shadow = orig.call(this, init);
@@ -4409,4 +4409,4 @@ ${p.body}`,f=await Ud(h,a,t.model);w.info(`Extracted content: ${f}`),f&&f!=="NOT
4409
4409
  }
4410
4410
  return shadow;
4411
4411
  };
4412
- })()`).catch(()=>{});await a._enableRecorder({mode:"recording",recorderMode:"api",handleSIGINT:!1,omitCallTracking:!0,testIdAttributeName:n||"data-testid"},r),await this.page.evaluate(()=>window.__pw_recorderSetMode?.("recording")).catch(()=>{})}this.recorderEnabled=!0,await o}async stopRecorder(t){this.page.context()._onRecorderEventSink=void 0,await this.page.evaluate(()=>window.__pw_recorderSetMode?.("standby")).catch(()=>{}),this.recorderStopResolver&&(this.recorderStopResolver(),this.recorderStopResolver=void 0)}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function B1(e){let{yamlFilePath:t,port:i,page:n,agent:a,projectRoot:o}=e,r=o??En.dirname(t),l=new ui(n,a,r,o);try{let f=await ca(process.pid);l.setCdpEndpoint(f),console.error(`[debugger] CDP endpoint: ${f}`)}catch(f){console.error(`[debugger] Could not discover CDP endpoint: ${f.message}`)}let s=xa();s.use(xa.json({limit:"10mb"})),s.use((f,g,y)=>{if(g.setHeader("Access-Control-Allow-Origin","*"),g.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),g.setHeader("Access-Control-Allow-Headers","Content-Type, Accept, Cache-Control, Idempotency-Key"),f.method==="OPTIONS")return g.sendStatus(204);y()});let{createTestFlowRouter:c}=await Promise.resolve().then(()=>(ml(),hl)),{createIntRunnerRouter:d}=await Promise.resolve().then(()=>(gl(),pl)),u=En.join(o??En.dirname(t),".shiplight","artifacts");s.use("/api/report-assets",xa.static(u)),s.use(c({initialDir:En.dirname(t),initialFile:t,projectRoot:o})),s.use(d(l));let p=await new Promise((f,g)=>{let y=s.listen(i,"127.0.0.1",()=>f(y));y.on("error",g)});return{url:`http://localhost:${i}`,close:async()=>{await l.cleanupAll(),await new Promise((f,g)=>{p.close(y=>y?g(y):f())})}}}export{ui as PlaywrightSandboxService,B1 as startPlaywrightDebugServer};
4412
+ })()`).catch(()=>{});await a._enableRecorder({mode:"recording",recorderMode:"api",handleSIGINT:!1,omitCallTracking:!0,testIdAttributeName:n||"data-testid"},r),await this.page.evaluate(()=>window.__pw_recorderSetMode?.("recording")).catch(()=>{})}this.recorderEnabled=!0,await o}async stopRecorder(t){this.page.context()._onRecorderEventSink=void 0,await this.page.evaluate(()=>window.__pw_recorderSetMode?.("standby")).catch(()=>{}),this.recorderStopResolver&&(this.recorderStopResolver(),this.recorderStopResolver=void 0)}async terminateSession(t){console.error("[debugger] Playwright session released")}async cleanupAll(){}};async function Q1(e){let{yamlFilePath:t,port:i,page:n,agent:a,projectRoot:o}=e,r=o??En.dirname(t),l=new ui(n,a,r,o);try{let f=await ca(process.pid);l.setCdpEndpoint(f),console.error(`[debugger] CDP endpoint: ${f}`)}catch(f){console.error(`[debugger] Could not discover CDP endpoint: ${f.message}`)}let s=va();s.use(va.json({limit:"10mb"})),s.use((f,g,y)=>{if(g.setHeader("Access-Control-Allow-Origin","*"),g.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),g.setHeader("Access-Control-Allow-Headers","Content-Type, Accept, Cache-Control, Idempotency-Key"),f.method==="OPTIONS")return g.sendStatus(204);y()});let{createTestFlowRouter:c}=await Promise.resolve().then(()=>(pl(),ml)),{createIntRunnerRouter:d}=await Promise.resolve().then(()=>(fl(),gl)),u=En.join(o??En.dirname(t),".shiplight","artifacts");s.use("/api/report-assets",va.static(u)),s.use(c({initialDir:En.dirname(t),initialFile:t,projectRoot:o})),s.use(d(l));let p=await new Promise((f,g)=>{let y=s.listen(i,"127.0.0.1",()=>f(y));y.on("error",g)});return{url:`http://localhost:${i}`,close:async()=>{await l.cleanupAll(),await new Promise((f,g)=>{p.close(y=>y?g(y):f())})}}}export{ui as PlaywrightSandboxService,Q1 as startPlaywrightDebugServer};